1
General Image Operations Three type of image operations 1.Point operations 2.Geometric operations 3.Spatial operations
Point Operations
Operation depends on Pixel's value. Context free (memory-less). Operation can be performed on the Histogram. Example:
Geometric Operations
Operation depend on pixel's coordinates. Context free. Independent of pixels value. Example:
Spatial Operations
Operation depends on Pixel's value and coordinates. Context dependant. Spatial v.s. Frequency domain. Example:
Point Operations A point operation can be defined as a mapping function: where v stands for gray values. M(v) takes any value v in the source image into v new in the destination image. Simplest case - Linear Mapping: M(v) v p q p’p’ q’q’
If it is required to map the full gray-level range (256 values) to its full range while keeping the gray-level order - a non-decreasing monotonic mapping function is needed: v M(v) 255 contraction stretching
Contrast Enhancement If most of the gray-levels in the image are in [u 1 u 2 ], the following mapping increases the image contrast. The values u 1 and u 2 can be found by using the image’s accumulated histogram. v M(v) 255 u1u1 u2u2
The Negative Mapping v M(v) 255
Point Operations and the Histogram Given a point operation: M(v a ) takes any value v a in image A and maps it into v b in image B. Requirement: the mapping M is a non descending function (M -1 exists). In this case, the area under H a between 0 and v a is equal to the area under H b between 0 and v b
A A B B M(v) M -1 (v) HaHa HbHb CaCa CbCb A point operation and the induced histograms:
v v HaHa HbHb M(v) v The area under H a between 0 and v a is equal to the area under H b between 0 and v b =M(v a )
Q: Is it possible to obtain H b directly from H a and M(v)? A: Since M(v) is monotonic, C a (v a )=C b (v b ) therefore: v v CaCa CbCb M(v) v
The histogram of image B can be calculated: A A B B M(v) M -1 (v) HaHa CaCa M(v) HbHb CbCb
Q: Is it possible to obtain M(v) directly from H a and H b ? A: Since C b is monotonic and C b (v b )=C a (v a ) Alternatively M(v a )=v b if C a (v a )=C b (v b ) A A HaHa CaCa B B HbHb CbCb M(v)
v CaCa CbCb v vava vbvb Calculating M(v) from C a and C b :
Histogram Equalization Visual discrimination between objects depends on the their gray-level separation. How can we improve discrimination after image has been acquired? Hard to discriminate Doesn’t helpThis is betterWhat about this?
Histogram Equalization For a better visual discrimination of an image we would like to re-assign gray-levels so that gray-level resource will be optimally assigned. Our goal: finding a gray-level transformation M(v) such that: –The histogram H b is as flat as possible. –The order of gray-levels is maintained. –The histogram bars are not fragmented.
Histogram Equalization: Algorithm A A HaHa HbHb CaCa CbCb Define: Assign:
Hist. Eq.: The two pointers algorithm old new
old new (4) (3) (4) (3) (1) (20) (22) (30) (5) (21) Result Goal Original Hist. Eq.: The two pointers algorithm
OriginalEqualized Hist. Eq.: Example 1
OriginalEqualized Hist. Eq.: Example 2
Hist. Eq.: Example 3
Histogram matching Transforms an image A so that its histogram will match that of another image B. Usage: before comparing two images of the same scene (change detection) acquired under different lighting conditions or different camera parameters. sourcetargetmapped source
However, in cases where corresponding colors between images are not “consistent” this mapping may fail: from: S. Kagarlitsky: M.Sc. thesis 2010.
Surprising usage: Texture Synthesis (Heeger & Bergen 1995). –Start with a random image. –Step1: multi-resolution decomposition –Step2: histogram matching for each resolution –Iterate synthesis
More results: (Heeger & Bergen 1995):
Discussion: Histogram matching produces the optimal monotonic mapping so that the resulting histogram will be as close as possible to the target histogram. This does not necessarily imply similar images.
hist. match results Example:
The Slice Transform (SLT): Hel-Or & Shaked 2008 The Slice Transform (SLT) can be seen as a representation of a signal using a linear sum of “slice” signals: = Signal x A
Tone mapping using SLT: The Slice Transform can represents tone mapping (point operations) in a linear form = =
Tone mapping using SLT: If a signal A can be mapped into signal B we have: In practice we find an optimal q so that image A will be as close as possible to image B in a LS sense: Takes into account spatial information as well. Mapping is not necessarily monotonic.
SLT results Example: Hist. Eq.
T H E E N D 38