The Scientific World Journal

Volume 2014, Article ID 513417, 12 pages

http://dx.doi.org/10.1155/2014/513417

## Disparity Map Generation from Illumination Variant Stereo Images Using Efficient Hierarchical Dynamic Programming

^{1}Computer Engineering Department, Government Engineering College, Gandhinagar, Gujarat 382028, India^{2}Computer Engineering Department, Sardar Vallabhbhai National Institute of Technology, Surat, Gujarat 395007, India

Received 19 April 2014; Revised 27 August 2014; Accepted 7 September 2014; Published 20 October 2014

Academic Editor: Andrea Torsello

Copyright © 2014 Viral H. Borisagar and Mukesh A. Zaveri. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

#### Abstract

A novel hierarchical stereo matching algorithm is presented which gives disparity map as output from illumination variant stereo pair. Illumination difference between two stereo images can lead to undesirable output. Stereo image pair often experience illumination variations due to many factors like real and practical situation, spatially and temporally separated camera positions, environmental illumination fluctuation, and the change in the strength or position of the light sources. Window matching and dynamic programming techniques are employed for disparity map estimation. Good quality disparity map is obtained with the optimized path. Homomorphic filtering is used as a preprocessing step to lessen illumination variation between the stereo images. Anisotropic diffusion is used to refine disparity map to give high quality disparity map as a final output. The robust performance of the proposed approach is suitable for real life circumstances where there will be always illumination variation between the images. The matching is carried out in a sequence of images representing the same scene, however in different resolutions. The hierarchical approach adopted decreases the computation time of the stereo matching problem. This algorithm can be helpful in applications like robot navigation, extraction of information from aerial surveys, 3D scene reconstruction, and military and security applications. Similarity measure SAD is often sensitive to illumination variation. It produces unacceptable disparity map results for illumination variant left and right images. Experimental results show that our proposed algorithm produces quality disparity maps for both wide range of illumination variant and invariant stereo image pair.

#### 1. Introduction

Stereo vision is one of the challenging problems in computer vision. It infers 3D structure from images acquired with different viewpoints. Stereo vision has been researched widely due to its usefulness in many applications like 3D scene reconstruction, robot navigation, parts inspection, virtual reality, teleconferencing, extraction of information from aerial surveys, image-based rendering, and military and security applications. It can be divided into two problems: matching and 3D reconstruction. The most difficult problem in stereo vision is the establishment of visual correspondence among images. Most of the stereo matching algorithms assume illumination invariant stereo image pair. However there exist numerous real and difficult situations in which illumination variation between stereo images is unavoidable. There are few algorithms which reduce the effect of illumination variation between stereo pair to generate quality disparity maps. In [1] an extensive review of stereo matching algorithms is given. The difference in the positions of the two corresponding pixels in their respective images is called disparity. The corresponding pixels are the projections of a single pixel in the 3D scene. Two image pixels and match if they result from the projection of the same pixel in the scene.

In general, stereo algorithms can be classified into two major classes [1]: the methods based on local constraints and the methods based on global constraints. Local methods estimate disparity at a pixel in one image by comparing a small window about that pixel with a series of small windows extracted from the other image. Different types of windows, like solid windows [2], multiple windows [3, 4], and adaptive windows [5], have been used. Local method uses difference between color and intensity to find all the corresponding pixels in two or more images. It works on the assumption that neighboring pixels usually have the same disparity. This method gives good result in textured regions and faces many difficulties especially in texture less regions, disparity discontinuous boundaries, and occluded regions; algorithms solve these difficulties according to constraints [6]. Global methods make explicit smoothness assumptions and then solve it through various optimization methods. However, these methods have high computational complexity due to iterative approach for energy minimization and the complex constraints. Therefore, it is not suitable to apply these methods in real-time applications. These methods are less susceptible to ambiguous regions since global constraints provide additional support for regions which are difficult to match locally.

The appearance of corresponding pixels will vary in stereo images due to different perspective projections. Pixel in one image may have many matching pixels in the second image especially in repetitive texture or textureless areas. This is called the problem of ambiguity. There are many constraints that make stereo an ill-posed problem. One type of issue is associated with the scene itself, specifically textureless areas, non-Lambertian surfaces, reflections, translucency, and occlusions. The others are camera-related issues like image noise, errors due to imperfect calibration, and orientation of camera. The utilization of multiple cameras to capture images introduces problems such as differences in exposure, white balancing, and other radiometric properties. Stereo algorithms should be reliable and efficient to be useful in real-time applications.

Nonuniform illumination between two images frequently occurs in real scenario. Stereo algorithms should be capable to handle such type of difficult illumination conditions [7]. Even with close to ideal measurements and least illumination deviation between images, the matching is still ambiguous for a large number of pixels. Mostly, illumination conditions of two consecutive images are nearly the same. Even though, a quick change of illumination might occur within short time. Illumination normalization [8] is essential to the stereo matching algorithms sensitive to illumination variation.

Similarity measures such as sum of absolute difference (SAD) and absolute difference (AD) [1] are used to calculate the matching costs to find the corresponding pixels. These methods suppose that matching pixels between left and right images will have the same color value. But due to illumination variation the corresponding pixels will have different color values [9]. Thus in case of illumination variation the estimated disparity map is extensively degraded as compared to the ground truth.

Dynamic programming (DP) named by Richard Bellman [10] in 1953 is an effective global method to compute correspondences for pixels of an image. The minimum cost path going down and right from the top-left corner of the grid to its bottom-right corner is found. Thus, dynamic programming method can be used to find the best possible match sequence between the start and end points.

Many researchers have been attracted towards global algorithms due to their accurate results. Global algorithms such as graph cut [11–13] and belief propagation [14–16] give good results by finding local minima, that is, minima over large neighborhood. As these methods are computationally very costly they are not suitable for real-time applications. Since many years a lot of research is going on to develop real-time algorithms for disparity estimation. Global optimization techniques based on dynamic programming (DP) are gradually becoming acceptable in such type of algorithms because of its high effectiveness [17–19]. For all scanlines optimization in the image is performed independently in dynamic programming. However, this method needs strict enforcement of ordering constraints [20]*. *It provides global solution for the disparity estimation under local constraints like correlation, smoothness, and disparity gradient limit. It produces quality results on occlusion boundaries but ‘‘streaking’’ artifact is produced because of the inconsistency between scanlines.

The assumption that a 3D point in space has the same appearance under 2D projection from different geometries is not always true in case of illumination variation. Corresponding pixels in left and right images will have different color values due to different illumination conditions. Stereo image pair acquired by the camera often experience illumination variations due to spatially and temporally separated camera positions. Illumination variation between left and right image occurs because of varying lighting and exposure differences. The scene is assumed to be Lambertian in most of the disparity generation algorithms. This assumption is violated in real scenario due to the existence of illumination variation. When images of a stationary scene are recorded by camera at different timing interval, illumination variation occurs due to environmental illumination fluctuation and the change in the strength or position of the light sources. It may not be possible to manage the light source, for example, outdoors when image acquisition of large scenes will take some time. Such scenario exists during matching of aerial or satellite images. Because of all of the above mentioned factors, it can be concluded that real world stereo imaging algorithms should have illumination variation robustness.

The scope of this paper is to generate disparity map from a wide variety of illumination variant stereo image pair. Most of the stereo matching algorithms assume illumination invariant stereo image pair. However there exist numerous real and difficult situations in which illumination variation between stereo images is unavoidable. There are few algorithms which reduce the effect of illumination variation between stereo pair to generate quality disparity maps. It is not a trivial problem to estimate the disparity map from the stereo image pair having illumination variation as it seriously influences the performance of stereo matching algorithms. In order to get illumination variant stereo images changes are made synthetically in the Middlebury Stereo Datasets [1, 21]. Matching stereo image pair acquired under different illumination increases the error. Simulation results demonstrate that the proposed algorithm generates quality disparity maps if portion of one of the images of stereo pair is changed due to illumination. Our algorithm gives quality results for both illumination variant and invariant stereo image pair.

The rest of the paper is organized as follows: in Section 2 related work is explained and then in Section 3 proposed hierarchical stereo matching algorithm is described in detail. Section 4 discusses experimental results and demonstrates the performance of our algorithm. Section 5 depicts the conclusion of this paper and future work. At the end, references are listed.

#### 2. Related Work

A stereo algorithm [22] combines the use of lightness-invariant pixel difference evaluation within a dynamic programming depth estimation approach. This algorithm uses dynamic programming technique, projection of the HSL color space for lightness tolerance, and gestalt-based adaptive support weight aggregation. By applying histogram equalization to each color channel illumination normalization is done. The drawbacks of histogram equalization are color distortion and noise amplification [23]. To decrease the effect of these drawbacks, an illumination normalization technique is proposed in [8] in which the histogram of the second image is adjusted in accordance with that of the first image. Baker and Binford [24] worked on stereo using dynamic programming. Each probable solution of the disparity field is represented in the form of path through matching space. The monotonicity confines the space of probable solutions.

The effect of illumination variation can be reduced by two main approaches. Firstly, many algorithms are proposed to lessen the effect of illumination variations by normalizing color values [25–27]. Such algorithms are applied as a preprocessing step before the stereo matching to reduce the effect of illumination variation. Colors are normalized based on the averages by the grey-world assumption algorithm [25]. The dependency on the effect of global illumination and scene geometry is tried to be eradicated iteratively by the comprehensive color normalization algorithm [26]. The grey-edge algorithm [27] utilizes the average edge difference for the color normalization. Secondly, some algorithms utilize color invariant similarity measures [28, 29] for matching cost calculation. Similarity measure normalized cross-correlation (NCC) reduces the effect of illumination variation by compensating the gain and the bias difference between stereo images [28]. The adaptive normalized cross-correlation (ANCC) [29] utilizes the NCC adaptively based on the comprehensive color normalization.

The global minimum for independent scanlines can be found in polynomial time by using dynamic programming. In stereo vision DP was initially used in sparse, edge-based techniques [24, 30]. Dense (intensity-based) scanline optimization problem [31, 32] is addressed by current approaches. Minimum cost path through the matrix of all pairwise matching costs between two corresponding scanlines is calculated by these approaches.

Dynamic programming (DP) is used for matching epipolar scanlines and then the solutions are improved iteratively using edges [30]. Stereo matching algorithm based on DP considering the interscanline constraint is discussed in [32]. This technique needs less number of iterations to estimate the global solution. Bayesian approach for stereo matching is discussed in [31]. First of all DP is applied along epipolar scanlines to obtain initial estimate of disparity values and thereafter vertical smoothing is performed iteratively. To decrease the inconsistency among scanlines [33, 34] few DP based approaches use the concept of ground control points or reliability-based matching cost computation and few use the approach of global optimization [18, 34].

In horizontal grid type the smoothness constraints are imposed only within the horizontal scanlines. In [35] the optimization of the energy function for each scanline is done separately by using DP. Inconsistency between scanlines, that is, streaking effect, is produced in the output due to skipping of vertical edges. Graph-based global methods are proposed to solve this problem of streaking effect. To optimize this problem approaches like graph cuts [11] and belief propagation [36] can be used. These approaches are giving quality output but are computationally very expensive.

Multiresolution stereo matching exists in addition to cost calculation for matching and disparity optimization. This hierarchical stereo matching method can be implemented using image pyramids to improve the disparity estimation based on the coarse-to-fine approach [37, 38]. Multiresolution or coarse-to-fine paradigm for stereo matching is faster than one without multiresolution [39], because the search range in each stage of the pyramid is small. In addition to fast computation, higher quality disparity map can also be obtained by utilizing the multiresolution data structure. Overview of the scene can be obtained at coarse level and detailed information can be found at fine level. There are three advantages of coarse-to-fine method [40]: (a) search range can be increased, because at a lower resolution pyramidal level only rough initial values are required; (b) increase in speed can be achieved as only the neighborhood of the previous result requires to be searched; and (c) the reliability of finding the right matching can be increased.

The assignment of the accurate cost for occluded pixels and maintenance of interscanline consistency are the difficulties associated with the dynamic programming. Various algorithms are proposed to address interscanline consistency [30–32]. The monotonicity or ordering constraint [20] is needed to be imposed in dynamic programming. The relative ordering of pixels on a scanline must be the same between the two views in this constraint, which may not be the case for thin foreground objects containing images.

Anisotropic diffusion has been applied as the regularization term by latest energy-based methods to avoid oversmoothing of significant edges. Perona and Malik [41] proposed anisotropic diffusion to achieve image enhancement and restoration. The diffusion coefficient is changed at edges with sharp intensity gradients. This technique is used for disparity and depth generation.

#### 3. Proposed Algorithm

Many stereo matching algorithms assume illumination invariant stereo image pair. However there exist numerous real and difficult situations in which illumination variation between stereo images is unavoidable. When corresponding pixels between left and right images have dissimilar colors because of illumination variations as shown in Figures 4(a) and 4(b), the inaccurate disparity map is generated. A new hierarchical stereo vision algorithm is proposed which gives disparity map as output from illumination variant stereo pair. Illumination variation between two stereo images affects the quality of the disparity map generated. When images of a stationary scene are recorded by camera at different timing interval, illumination variation occurs due to environmental illumination fluctuation and the change in the strength or position of the light sources. Hence there will be illumination variation between left and right images in many real-time situations. This illumination variation degrades the performance of stereo matching algorithms. If illumination variation is not suppressed in preprocessing stage, then that will lead to false matching and in turn will result into inaccurate disparity map estimation. So in order to get accurate disparity map as output, illumination difference between two images must be suppressed before starting matching process. Illumination variation suppression is done by using homomorphic filtering to make the pixels of both images more or less illumination invariant.

Homomorphic filtering of both images will improve the quality of input images. It is a general method for image and signal processing. First of all nonlinear mapping to a different domain is done and then linear filtering methods are applied on the image. Lastly mapping back to the original domain is performed. This concept was developed in the 1960s by Thomas Stockham, Alan V. Oppenheim, and Ronald W. Schafer at MIT [42]. This filtering method has been used in various imaging applications such as robotics, biometrics, and image enhancement.

Image can be viewed as a product of illumination and reflectance of scene. The low frequency components due to illumination can be removed by taking the log of the image and thereafter applying high-pass filtering. In this way, enhancement of details within an image is done by homomorphic filtering.

Illumination variations can be treated as a multiplicative noise and can be reduced by filtering in the log domain. The brightness across an image is normalized by homomorphic filtering and it also enhances contrast. Multiplicative noise can be removed by using homomorphic filtering. Approximate position of illumination and reflectance can be found in frequency domain. Illumination and reflectance are combined together multiplicatively. These multiplicative components of the image are made additive and thus can be separated linearly in the frequency domain by taking the logarithm of the image intensity.

The reflectance is represented by the high frequency components whereas illumination in the scene is represented by the low frequency components. The high frequency components are increased and low frequency components are decreased to normalize the illumination of an image. Thus in the log-intensity domain [43], suppression of low frequencies and amplification of high frequencies are done by high-pass filtering.

Homomorphic filtering method uses illumination-reflectance model. Image can be characterized by two major components in this model. The first component is the amount of source illumination incident on the scene being viewed and reflectance component of the objects in the scene is the second component. The image can be related [44–46] to and as mentioned below:

Thus, according to (1) intensity at a particular pixel within an image is a product of illumination and reflectance. As intensity alters slowly compared to , is having more number of low frequency components than . leads to high frequency components mainly at the borders of two reflecting objects. The main purpose of homomorphic filtering is to lessen the effect of by decreasing the low frequency components of the image and then filtering process is performed. Homomorphic filtering can be implemented using the following steps [46].

*Step 1. *Take a natural logarithm on both sides of (1) to change the multiplication operation between and into addition operation:

*Step 2. *Image is transformed from spatial domain to frequency domain by using Fourier transform
or
where and are the Fourier transforms of and , respectively.

*Step 3. *Filter function is used to high pass the to get a filtered :

*Step 4. *To get the filtered image in spatial domain, an inverse Fourier transformation is applied:

*Step 5. *The filtered enhanced image can be obtained as follows:
where and are the illumination and reflectance components, respectively.

In this way, low frequency components can be reduced and high frequency components can be improved. Homomorphic filter decreases the contribution due to illumination and information which is not available in the original image can be seen in the enhanced image. Hierarchical dynamic programming is applied on both left and right images after illumination variation suppression. It minimizes the global cost for each scanline of image to determine the optimal path, that is, least costly disparity values for each pixel.

In dynamic programming (DP) the problem is divided into smaller problems recursively; the smallest problem is solved first and its answer is used to solve the problem of the preceding level [47]. In case of stereo, the problem is to find the best path of matching between two scanlines, that is, to find the disparity field with minimum cost. Error propagation issues on the same line can be avoided by solving every small problem globally. DP is proficient algorithm to solve sequential decision, that is, optimal path problems.

DP stereo algorithm treats the correspondence problem as an energy minimization problem. The energy function denotes the total cost of a sequence of matching pixels in a scanline. According to (8), consists of a data and smoothness term:
where denotes matching cost. For every pixel, it is used to find the best matching pixel in the other image. indicates smoothness cost, which ensures that neighboring pixels should usually have same disparity.

DP gives better disparity map compared to that obtained by correlation methods. It is also speedy compared to correlation and requires lesser scanline buffers than correlation window. It moves forward in a scanline, produces solution by backtracking through predecessor array, averages noise over a scanline, does not alter values in backtrack, identifies occlusions, and utilizes ordering constraint to give global solution along scanlines. If a pixel is on the right of a matched pixel in the left scanline, then its corresponding pixel will also be on the right of the matched pixel in the right scanline.

DP gives the optimal path through grid as shown in Figure 1. This path gives the best set of matches satisfying the ordering constraint. In DP raster intensities are arranged on two sides of a grid. The diagonal line within grid indicates possible correspondences. Optimal cost for each node is calculated from given upper-left neighbors. In order to find the minimum cost path, the least cost path for every pixel in a scanline is computed starting from the origin, left to right and top to bottom. Disparity of each pixel can be calculated by path backtracking. A cost is associated with every path and out of all paths the optimal one is selected.

As shown in Figure 1, pixel can be either sequential or occluded or disoccluded. The cost of matching has to be calculated for sequential pixels whereas it will not be computed for occluded and disoccluded pixels.

The typical implementation of DP [48] can be described as follows.

*Step 1. *Initialization:

*Step 2. *Recursion from time to :

*Step 3. *Termination:

*Step 4. *Path backtracking from time to 0:
where is the matching cost, is the length of a scanline, is the penalty for inconsistent disparity, is the point index of the second scanline, is the accumulated matching cost at th pixel with a disparity , and are the minimum disparity and the maximum disparity, respectively, and is the disparity of the pixel estimated by the DP.

We provide preprocessed color stereo image pair as input and convert the images to gray scale for the matching process and perform window matching. As the images are rectified, search has to be done only over columns and not over rows. Window matching estimates the disparity for every pixel based on its cost function. The disparity values obtained by window matching are all integers; the disparity map obtained displays contouring effect as there is no smooth transition between areas having different disparity. This problem of contouring effect can be solved by introducing subpixel calculation into the matching metric. Fast method of interpolation is required to increase the speed. Every pixel of left image is compared with , , and pixels of the right image to find the dissimilarity, where is the disparity obtained by the stereo algorithm. A quadratic polynomial is then fitted to these three dissimilarity values obtained and its minimum is found which is the refined floating point disparity value associated with pixel . This disparity value may lie to the right or left of . In textureless areas, the minimum value may not lie in between and . In such conditions, depending on where the dissimilarity value is the least either or is selected. Thus by introducing subpixel computation with window matching contouring effects are mostly removed and refined values of disparity are obtained.

Now we want to assign disparity value with probably suboptimal cost to pixel locally. Increasing pixel’s agreement in disparity with its neighbors will balance this additional cost. Each disparity estimate is confined to lie near to disparity values of its neighboring pixels along an image row. The problem of estimating the best possible disparity values for a row of pixels is now converted into the problem of finding the optimal path from top-left part to bottom-right part of the image. Metric obtained after subpixel calculation is used as the cost function and disparity values are allowed to change only by a specific amount between neighboring pixels to find the optimal path. We have attempted to solve this problem by using dynamic programming.

Dynamic programming increases the correctness of the disparity map. However the computational complexity is increased due to both window matching and dynamic programming. Hierarchical DP can be used along with the window matching [49, 50] to solve this problem of computational complexity. Hierarchical DP, as originally proposed in [51], works on almost the same principles as of typical DP. This hierarchical stereo matching method is implemented using image pyramids to improve the disparity estimates based on the coarse-to-fine model. The images are downsampled an optimal number of times and the disparity map of a coarser level is used as an “offset” disparity map at a finer level. Here we have considered image pyramids with 3 levels for the coarse-to-fine process. For downsampling a 2D image, the image is subdivided into groups of 4 pixels and its average is calculated. In the hierarchical approach, standard DP is performed on the lowest level and the results obtained are used as an offset for the next higher level to find the minimum cost. Thus search over a smaller range of disparities is required. This process is continued until the highest level, that is, original image, is reached. In the original image search over a 15 pixel range is required to estimate the disparities. If the image is downsized by a factor of two, this search reduces to 7 pixels on an image with a quarter of the area; this approach would cost less by a factor of 8. The results obtained by this hierarchical approach are of high quality and are achieved at a reduced computational cost compared to combination of both window matching and dynamic programming.

In DP algorithm individual scanlines are matched well but there is no intrascanline consistency. Scanlines in the reference image are matched independent of each other in DP and the output contains disparity discontinuities in the vertical direction of the image, giving a streaky appearance. The hierarchical DP gives better results because of the inherent image smoothing resulting from downsampling. But if scanline inconsistency is made on lower level of the hierarchy, that error is propagated all the way to the top level.

The result obtained from hierarchical DP is smoothed by applying anisotropic diffusion [41, 52] instead of plane fitting. Diffusion is a physical process which plans to minimize differences in the spatial concentration of a substance. The aim is to have less diffusion, that is, smoothing on edge locations. Anisotropic diffusion is a smoothing method that smoothes images without crossing any edges. Anisotropic diffusion conserves and increases the contrast at sharp intensity gradients. Gradient norm serves as edge indicator. Diffusivity should decrease with increasing The smoothing mechanism follows the following diffusion equation:
is called a contrast parameter. Areas where will not be affected much by the diffusion process.

Thus a refined disparity map without blurring any edges is obtained.

#### 4. Results and Discussion

In this section, we present the experimental results of our algorithm. The Middlebury Dataset [1, 21] is used to evaluate the results of the proposed algorithm. The popular and extensively used image pairs like tsukuba, cones, venus, and sawtooth are used for an evaluation purpose. These images contain different objects with different characteristics. Computation of our proposed algorithm is carried out in Matlab version: 7.14.0.739 (R2012a) on Intel(R) Core(TM) i3 CPU M 350 @ 2.27 GHz (4 CPUs) laptop.

The proposed algorithm has been applied to a series of illumination variant stereo pairs. As shown in Figure 4, our proposed algorithm is tested by using the tsukuba image pair having 0% (first row), 6.25% (second row), 12.50% (third row), 25% (fourth row), and 50% (fifth row) pixel illumination variation between left and right images. All these images are derived by changing the values of each one of the RGB channels of left tsukuba image by 10% and keeping right tsukuba image unchanged. Thus a series of tsukuba pairs is obtained with a fixed illumination difference between the left and right image of each pair. The proposed algorithm is tested on these image pairs and quality results are obtained as shown in Figure 4.

To evaluate the performance of a stereo algorithm we need a quantitative way to estimate the quality of the computed disparity map. The quality of the estimated disparity map can be compared with respect to ground truth by using similarity measure root mean square error. RMSE is calculated in terms of disparity units between the estimated disparity map and the ground truth and is given as follows: where is the total number of pixels.

Table 1 shows the root mean square error (RMSE) of the disparity maps generated for each of the tsukuba pairs shown in Figure 4 with respect to the ground truth disparity maps. It also shows comparison of results of our proposed algorithm based on hierarchical DP with the results obtained by similarity measure sum of absolute difference (SAD). RMSE values are obtained by comparing estimated disparity map with the ground truth of the corresponding image. Here, in our proposed approach based on hierarchical DP we have considered image pyramids with 3 levels and disparity search range of 4 and size of the tsukuba image is 384 288. Results of SAD are directly obtained by giving different illumination variant tsukuba image pairs as input without applying any preprocessing and postprocessing steps. Figures 3 and 4 and Table 1 demonstrate that in case of illumination variant images SAD gives undesirable results, while our proposed approach gives excellent results.

The sum of absolute differences (SAD) does not consider varying illumination conditions. Figure 3(d) shows that inaccurate disparity map is estimated by using similarity measure SAD by giving tsukuba stereo image pair as input. 50% of total pixels of input left image are changed due to 10% illumination variation and the pixels of right image are left unchanged. As the illumination variation increases, the quality of estimated disparity map is affected which leads to increase in RMSE values. Figures 3(d) and 4(c) (fifth row) and Table 1 show that the performance of our proposed algorithm is better than the SAD method.

The performance of the proposed algorithm is summarized and compared with the results obtained by conventional image pyramiding approach in Table 2. Results of image pyramiding approach are obtained without applying homomorphic filtering, dynamic programming approach, and anisotropic diffusion. Image pyramiding stereo matching is applied to calculate the matching cost from coarse level to fine level. Image pyramiding or coarse-to-fine approach for stereo matching is faster than one without image pyramiding, because the search range in each stage of the pyramid is small. Outline of the scene can be obtained at coarse level and thorough information can be found at fine level. We have applied window based method SAD at each level to calculate the matching cost. As the results of coarser level are inaccurate due to the presence of illumination variation, it also affects the results of finer level leading to generation of inaccurate disparity map. Table 2 shows the comparison between root mean square error (RMSE) values obtained for our proposed approach based on hierarchical DP and image pyramiding approach.

Figure 2 shows the comparison of RMSE values obtained under 10%, 20%, and 30% illumination variation between tsukuba image pair with 0%, 6.25%, 12.50%, 25%, and 50% of total pixels changed within image due to illumination variation. As the illumination variation increases the quality of estimated disparity map is affected which leads to increase in RMSE values. Also the increase in number of affected pixels in an image due to illumination variation leads to increase in RMSE values.

Table 3 compares RMSE values obtained for illumination variant stereo pair like venus, cones, and sawtooth as input to our proposed algorithm. These illumination variant images are generated synthetically by changing the values of each one of the RGB channels of left image by 10% and keeping right image unchanged. Our proposed algorithm is tested by using the venus, cones, and sawtooth image pair having 0%, 6.25%, 12.50%, 25%, and 50% pixel illumination variation between left and right images. From Table 3 it can be understood that our algorithm gives quality results for different types of stereo images having different image characteristics.

From the results shown in Figures 2, 3, and 4 and Tables 1, 2, and 3 it can be demonstrated that the output of our algorithm is mostly independent of the illumination variation between the two input stereo images. The proposed algorithm presents a robust behavior having low RMSE constantly over a wide range of illumination variation between the two input stereo images. The performance of our algorithm is comparable to the state-of-the-art stereo algorithms. The disparity maps estimated by our algorithm are of good quality. The background small objects in tsukuba image are not clearly visible in the estimated disparity map. The simulation results indicate that the proposed algorithm is efficient for disparity map generation under varying illumination conditions.

The quality of disparity map generated depends on the number of illumination sources used, percentage by which pixel value is changed due to illumination, percentage of pixels changed due to illumination, and characteristic of stereo images.

#### 5. Conclusion and Future Work

This paper presents a novel, robust, efficient, and flexible hierarchical dynamic programming based stereo matching algorithm. Most of the stereo matching algorithms assume illumination invariant stereo image pair. However there exist numerous real and difficult situations in which illumination variation between stereo images is unavoidable. The algorithm presented can be useful in real-time application where there is illumination variation between left and right images.

We compared results of our proposed approach with the results of similarity measure SAD method. SAD method gives fast but inaccurate disparity map results, as it lacks the ability to lessen the effect of illumination variation. Window matching and DP are used for the generation of disparity map. The proposed approach preserves edge information very well. The hierarchical DP approach leads to reduction in the computational complexity compared to DP. But the computational complexity of hierarchical DP is more compared to image pyramiding approach. The total runtime for our proposed algorithm is 223.37 seconds and for image pyramiding the total time required is 112.23 seconds.

Evaluation and comparison of the root mean square error values for various illumination variations for different input stereo images like venus, cones, and sawtooth show that our proposed algorithm gives quality results for different stereo images having different image characteristics. Experiments on various standard datasets show that the performance of our algorithm is comparable to the state-of-the-art stereo algorithms. Testing on different stereo pairs reveals that homomorphic filtering deals with shot noise remarkably but result is affected due to the presence of Gaussian noise and strong brightness changes. Dynamic programming performs relatively well at low contrast regions. DP blurs the edges due to smoothness constraint and it also does nothing to smooth between rows. In spite of these drawbacks, the quality of the disparity map is improved, as the noise is almost completely removed and many of the objects are better reconstructed. Using hierarchical DP we have been able to efficiently find a minimum cost path.

Anisotropic diffusion method is applied instead of plane fitting for disparity map refinement. It is applied on the disparity map obtained by hierarchical DP for smoothing the disparity map along with preserving the edges. Anisotropic diffusion is an image smoothing method that smoothes images without crossing edges, while enhancing and conserving the contrast at sharp intensity gradients. The results obtained are of good quality. The background tiny objects present in tsukuba image are not clearly detectable in the generated disparity map. Simulation results demonstrate that the proposed algorithm generates quality disparity maps if portion of one of the images of stereo pair is changed due to illumination. Our algorithm gives quality results for both illumination variant and invariant stereo image pair. There is still a possibility to decrease the computational complexity. The accuracy of disparity map estimated depends on the number of illumination sources used, percentage by which pixel value is altered due to illumination, percentage of pixels changed due to illumination, and characteristic of stereo images. The proposed algorithm can be implemented using FPGA or GPU for hardware acceleration in future.

#### Conflict of Interests

The authors declare that there is no conflict of interests regarding the publication of this paper.

#### Acknowledgments

The authors would like to express gratitude to Daniel Scharstein and Richard Szeliski for making stereo images available with ground truth.

#### References

- D. Scharstein and R. Szeliski, “A taxonomy and evaluation of dense two-frame stereo correspondence algorithms,”
*International Journal of Computer Vision*, vol. 47, no. 1–3, pp. 7–42, 2002. View at Publisher · View at Google Scholar · View at Scopus - M. Okutomi and T. Kanade, “Multiple-baseline stereo,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 15, no. 4, pp. 353–363, 1993. View at Publisher · View at Google Scholar · View at Scopus - A. Fusiello, V. Roberto, and E. Trucco, “Efficient stereo with multiple windowing,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition*, pp. 858–863, San Juan, Puerto Rico, June 1997. View at Scopus - D. Geiger, B. Ladendorf, and A. L. Yuille, “Occlusions and binocular stereo,” in
*Proceedings of the 2nd European Conference on Computer Vision*, pp. 425–433, 1992. - O. Veksler, “Fast variable window for stereo correspondence using integral images,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition*, vol. 1, pp. I-556–I-561, June 2003. View at Publisher · View at Google Scholar · View at Scopus - Y. Ma and W. Liu, “Progressive matching based on segmentation for 3D reconstruction,” in
*Proceedings of the 5th International Conference on Computer and Information Technology (CIT '05)*, pp. 575–579, Shanghai, China, September 2005. View at Publisher · View at Google Scholar · View at Scopus - G. Klančar, M. Kristan, and R. Karba, “Wide-angle camera distortions and non-uniform illumination in mobile robot tracking,”
*Robotics and Autonomous Systems*, vol. 46, no. 2, pp. 125–133, 2004. View at Publisher · View at Google Scholar · View at Scopus - J. Cai and R. Walker, “Height estimation from monocular image sequences using dynamic programming with explicit occlusions,”
*IET Computer Vision*, vol. 4, no. 3, pp. 149–161, 2010. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - A. Gijsenij, T. Gevers, and J. van de Weijer, “Computational color constancy: survey and experiments,”
*IEEE Transactions on Image Processing*, vol. 20, no. 9, pp. 2475–2489, 2011. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - H. Sadeghi, P. Moallem, and S. A. Monadjemi, “Feature based dense stereo matching using dynamic programming and color,”
*International Journal of Information and Mathematical Sciences*, vol. 4, no. 3, pp. 179–186, 2008. View at Google Scholar - Y. Boykov, O. Veksler, and R. Zabih, “Fast approximate energy minimization via graph cuts,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 23, no. 11, pp. 1222–1239, 2001. View at Publisher · View at Google Scholar · View at Scopus - O. Veksler,
*Efficient graph-based energy minimization methods in computer vision [Ph.D. thesis]*, Cornell University, 1999. - L. Hong and G. Chen, “Segment-based stereo matching using graph cuts,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition (CVPR '04)*, vol. 1, pp. I-74–I-81, usa, July 2004. View at Publisher · View at Google Scholar · View at Scopus - P. F. Felzenszwalb and D. P. Huttenlocher, “Efficient belief propagation for early vision,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition (CVPR '04)*, pp. I261–I268, July 2004. View at Scopus - J. Sun, N.-N. Zheng, and H.-Y. Shum, “Stereo matching using belief propagation,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 25, no. 7, pp. 787–800, 2003. View at Publisher · View at Google Scholar · View at Scopus - J. Sun, Y. Li, S. B. Kang, and H.-Y. Shum, “Symmetric stereo matching for occlusion handling,” in
*Proceedings of the Computer Society Conference on Computer Vision and Pattern Recognition (CVPR '05)*, vol. 2, pp. 399–406, June 2005. View at Publisher · View at Google Scholar · View at Scopus - S. Birchfield and C. Tomasi, “Depth discontinuities by pixel-to-pixel stereo,” in
*Proceedings of the IEEE 6th International Conference on Computer Vision*, pp. 1073–1080, Bombay, India, January 1998. View at Scopus - O. Veksler, “Stereo correspondence by dynamic programming on a tree,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition (CVPR '05)*, pp. 384–390, June 2005. View at Publisher · View at Google Scholar · View at Scopus - S. Forstmann, Y. Kanou, J. Ohya, S. Thuering, and A. Schmitt, “Real-time stereo by using dynamic programming,” in
*Proceedings of the Conference on Computer Vision and Pattern Recognition Workshop*, p. 29, June 2004. - A. L. Yuille and T. Poggio,
*A Generalized Ordering Constraint for Stereo Correspondence*, A.I. Memo 777, Artificial Intelligence Laboratory, Massachusetts Institute of Technology, Cambridge, Mass, USA, 1984. - [Online], http://vision.middlebury.edu/stereo/.
- L. Nalpantidis, J. Kalomiros, and A. Gasteratos, “Robust 3D vision for robots using dynamic programming,” in
*Proceedings of the IEEE International Conference on Imaging Systems and Techniques (IST '11)*, pp. 89–93, Penang, Malaysia, May 2011. View at Publisher · View at Google Scholar · View at Scopus - J. B. Zimmerman, S. M. Pizer, E. V. Staab, J. R. Perry, W. McCartney, and B. C. Brenton, “Evaluation of the effectiveness of adaptive histogram equalization for contrast enhancement,”
*IEEE Transactions on Medical Imaging*, vol. 7, no. 4, pp. 304–312, 1988. View at Publisher · View at Google Scholar · View at Scopus - H. H. Baker and T. O. Binford, “Depth from edge and intensity based stereo,” in
*Proceedings of the 7th International Joint Conference on Artificial Intelligence (IJCAI '81)*, pp. 631–636, 1981. View at Scopus - G. Buchsbaum, “A spatial processor model for object colour perception,”
*Journal of the Franklin Institute*, vol. 310, no. 1, pp. 1–26, 1980. View at Publisher · View at Google Scholar · View at Scopus - G. D. Finlayson, B. Schiele, and J. L. Crowley, “Comprehensive colour image normalization,” in
*Proceedings of the 5th European Conference on Computer Vision (ECCV '98)*, vol. 1, pp. 475–490, 1998. - J. van de Weijer, T. Gevers, and A. Gijsenij, “Edge-based color constancy,”
*IEEE Transactions on Image Processing*, vol. 16, no. 9, pp. 2207–2214, 2007. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - H. Hirschmüller and D. Scharstein, “Evaluation of cost functions for stereo matching,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition, (CVPR '07)*, pp. 1–8, Minneapolis, Minn, USA, June 2007. View at Publisher · View at Google Scholar · View at Scopus - Y. S. Heo, K. M. Lee, and S. U. Lee, “Robust Stereo matching using adaptive normalized cross-correlation,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 33, no. 4, pp. 807–822, 2011. View at Publisher · View at Google Scholar · View at Scopus - Y. Ohta and T. Kanade, “Stereo by intra- and inter-scanline search using dynamic programming,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 7, no. 2, pp. 139–154, 1985. View at Google Scholar · View at Scopus - P. N. Belhumeur, “A Bayesian approach to binocular steropsis,”
*International Journal of Computer Vision*, vol. 19, no. 3, pp. 237–260, 1996. View at Publisher · View at Google Scholar · View at Scopus - I. J. Cox, S. L. Hingorani, S. B. Rao, and B. M. Maggs, “A maximum likelihood stereo algorithm,”
*Computer Vision and Image Understanding*, vol. 63, no. 3, pp. 542–567, 1996. View at Publisher · View at Google Scholar · View at Scopus - M. Gong and Y. H. Yang, “Real-time stereo matching using orthogonal reliability-based dynamic programming,”
*IEEE Transactions on Image Processing*, vol. 16, no. 3, pp. 879–884, 2007. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - J. C. Kim, K. M. Lee, B. T. Choi, and S. U. Lee, “A dense stereo matching using two-pass dynamic programming with generalized ground control points,” in
*Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition (CVPR '05)*, vol. 2, pp. 1075–1082, San Diego, Calif, USA, June 2005. View at Publisher · View at Google Scholar · View at Scopus - L. Wang, M. Liao, M. Gong, R. Yang, and D. Nister, “High-quality real-time stereo using adaptive cost aggregation and dynamic programming,” in
*Proceedings of the International Symposium on 3D Data Processing, Visualization and Transmission*, pp. 798–805, June 2006. View at Publisher · View at Google Scholar · View at Scopus - A. Klaus, M. Sormann, and K. Karner, “Segment-based stereo matching using belief propagation and a self-adapting dissimilarity measure,” in
*Proceedings of the 18th International Conference on Pattern Recognition (ICPR '06)*, vol. 3, pp. 15–18, Hong Kong, China, August 2006. View at Publisher · View at Google Scholar · View at Scopus - Y.-P. Hung, C.-S. Chen, K.-C. Hung, Y.-S. Chen, and C.-S. Fuh, “Multipass hierarchical stereo matching for generation of digital terrain models from aerial images,”
*Machine Vision and Applications*, vol. 10, no. 5-6, pp. 280–291, 1998. View at Publisher · View at Google Scholar · View at Scopus - L. Zhang, “Fast stereo matching algorithm for intermediate view reconstruction of stereoscopic television images,”
*IEEE Transactions on Circuits and Systems for Video Technology*, vol. 16, no. 10, pp. 1259–1270, 2006. View at Publisher · View at Google Scholar · View at Scopus - K. S. Kumar and U. B. Desai, “New algorithms for 3D surface description from binocular stereo using integration,”
*Journal of the Franklin Institute*, vol. 331, no. 5, pp. 531–554, 1994. View at Publisher · View at Google Scholar · View at Scopus - F. Ackermann and M. Hahn, “Image pyramids for digital photogrammetry,” in
*Digital Photogrammetric Systems*, pp. 43–58, Wichmann, Karlsruhe, Germany, 1991. View at Google Scholar - P. Perona and J. Malik, “Scale-space and edge detection using anisotropic diffusion,”
*IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 12, no. 7, pp. 629–639, 1990. View at Publisher · View at Google Scholar · View at Scopus - http://en.wikipedia.org/wiki/Homomorphic_filtering.
- V. Madisetti and D. B. Williams, Eds.,
*Digital Signal Processing Handbook*, CRC Press, Boca Raton, Fla, USA, 1999, CD-ROM. - R. C. Gonzalez and R. E. Woods,
*Digital Image Processing*, Prentice Hall, 2008. - B. Horn,
*Robot Vision*, The MIT Press, 1986. - S. A. M. Saleh and H. Ibrahim, “Mathematical equations for homomorphic filtering in frequency domain: a literature survey,” in
*Proceedings of the International Conference on Information and Knowledge Management*, pp. 74–77, Singapore, 2012. - F. Singels,
*Real-time stereo reconstruction using hierarchical dynamic programming and LULU filtering [M.S. thesis]*, Stellenbosch University, 2010. - J. Cai, “Integration of optical flow and dynamic programming for stereo matching,”
*IET Image Processing*, vol. 6, no. 3, pp. 205–212, 2012. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - P. Thévenaz, U. E. Ruttimann, and M. Unser, “A pyramid approach to subpixel registration based on intensity,”
*IEEE Transactions on Image Processing*, vol. 7, no. 1, pp. 27–41, 1998. View at Publisher · View at Google Scholar · View at Scopus - A. Koschan, V. Rodehorst, and K. Spiller, “Color stereo vision using hierarchical block matching and active color illumination,” in
*Proceedings of the 13th International Conference on Pattern Recognition*, pp. 835–839, Vienna, Austria, August 1996. View at Publisher · View at Google Scholar · View at Scopus - G. van Meerbergen, M. Vergauwen, M. Pollefeys, and L. van Gool, “A hierarchical symmetric stereo algorithm using dynamic programming,”
*International Journal of Computer Vision*, vol. 47, no. 1–3, pp. 275–285, 2002. View at Publisher · View at Google Scholar · View at Scopus - A. Banno and K. Ikeuchi, “Disparity map refinement and 3D surface smoothing via directed anisotropic diffusion,” in
*Proceedings of the 12th IEEE International Conference on Computer Vision Workshops (ICCV Workshops '09)*, pp. 1870–1877, Kyoto, Japan, October 2009. View at Publisher · View at Google Scholar · View at Scopus