Information
-
Patent Application
-
20040100565
-
Publication Number
20040100565
-
Date Filed
November 22, 200222 years ago
-
Date Published
May 27, 200420 years ago
-
Inventors
-
Original Assignees
-
CPC
-
US Classifications
-
International Classifications
Abstract
In a method of obtaining an extended dynamic range panorama of a scene from a plurality of limited dynamic range images captured by an image sensor in a digital camera, a plurality of digital images comprising image pixels of the scene are captured from a plurality of positions by exposing the image sensor to light transmitted from the scene, wherein light transmittance upon the image sensor is adjustable. Each image is evaluated after it is captured for an illumination level exceeding the limited dynamic range of the image for at least some of the image pixels. Based on the evaluation of each image exceeding the limited dynamic range, the light transmittance upon the image sensor is adjusted in order to obtain a subsequent digital image having a different scene brightness range. The plurality of digital images are stored, and subsequently the stored digital images are processed to generate a plurality of composite images, each having an extended dynamic range greater than any of the digital images by themselves. The plurality of composite images are used in producing an extended range panorama. In addition, light attenuation data may be stored with the images for subsequent reconstruction of higher bit-depth panorama than the original panorama.
Description
FIELD OF THE INVENTION
[0001] The present invention relates to the field of digital image processing and, in particular, to capturing and digitally processing an extended dynamic range panoramic image.
BACKGROUND OF INVENTION
[0002] With advances in digital imaging technology over the last decade, innovative use of real photographs has been emerging in various ways, such as the creation of panoramic views of a real-world scene from multiple photographs in order to provide the viewer with an encompassing, photorealistic virtual reality. One standard method by which such panoramic views are created is by placing a conventional digital camera on a tripod, capturing images from different views by rotating the camera about the vertical axis through the center of the tripod, and stitching together the captured images to form a single large field of view panoramic image. A variety of software packages exist that perform image stitching (for example, QuickTime® VR Authoring Studio by Apple Computer, Inc., Live Picture by MGI Software Corporation, and Stitcher® by REALVIZ®), and many of these packages address some of the typical associated problems. Such problems include the presence of lens distortion, perspective distortion, unknown focal length, parallax errors if the images were not captured on a tripod, and exposure differences if the images were not captured with identical exposure settings.
[0003] Specifically with regard to the problem of exposure differences between captured images, MGI Software offers a potential solution. In U.S. Pat. No. 6,128,108, assigned to MGI Software, Teo describes a method of combining two overlapping images, wherein the code values of one or both images are adjusted by a nonlinear optimization procedure so that the overall brightness, contrast and gamma factors of both images are similar. However, Tco's method suffers in situations where each captured image has already been optimally rendered into a form suitable for hardcopy output or softcopy display. In this case, the nonlinear optimization procedure will adjust these optimal characteristics, generating a sub-optimally rendered panoramic image.
[0004] Another technique for correcting exposure differences that generates a panoramic image that can be optimally rendered is described in commonly assigned, co-pending U.S. patent application Ser. No. 10/008,026, entitled “Method and System for Compositing Images” and filed Nov. 5, 2001, and which is incorporated herein by reference. In this technique, two overlapping images are first transformed by a metric transform. A metric transform refers to a transformation that is applied to the pixel values of a digital image, the transformation yielding transformed pixel values that are linearly or logarithmically related to scene intensity values. An example of a color space that is logarithmically related to scene intensity values is the nonlinearly encoded Extended Reference Input Medium Metric (ERIMM) (PIMA standard #7466, found at http://www.pima.net/standards/it10/IT10_POW.htm on the World Wide Web). Once the metric transform has been applied, the pixel values of at least one of the images are modified by a linear exposure transform so that the pixel values in the overlap regions of overlapping images are similar, yielding a set of adjusted images. The adjusted images are then combined by a feathering scheme, weighted averages, or some other blending technique known in the art, to form a composite image. The composite image can then be optionally transformed back into the original color space.
[0005] In both of the aforementioned methods for correcting exposure differences, another problem exists; namely, if the exposure differences between two or more images are too drastic, any adjustment may force certain areas of the panoramic images to clip at the lower or higher ends of the dynamic range of the image sensor. For an example of such a drastic scenario, consider that 8-bit images are captured outside with the camera in auto exposure mode. Furthermore, consider that at one position the camera points so that a bright region occupies the left side of the image and a tree occupies the right side of the image. The camera is rotated to a second position, where the same tree now occupies the left side of the image, and a shadow area occupies the right side of the image. The auto exposure mode of the camera will attempt to bring the bright areas and shadow areas to within the dynamic range of the camera, thus reducing the exposure of the tree in the first image relative to the exposure of the tree in the second image. When the exposures are adjusted for subsequent stitching purposes, the adjustment step must either increase the exposure of the first image, or decrease the exposure of the second image, or both, in order to match the exposures in the overlapping region (the tree). This adjustment will likely push either the bright region or the shadow region or both outside of the 8-bit range, and clipping will occur.
[0006] In order to solve the clipping problem, a number of potential solutions have been proposed. For example, in “Generalized Mosaicing,” published in Proceedings of International Conference on Computer Vision, 2001, Schechner and Nayar teach a method of attaching an optical filter with spatially varying transmittance to a digital camera to effectively measure each scene point with different exposures when the camera moves. With this method, an extended dynamic range panorama of the scene can be built upon the multiple measurements.
[0007] In “High Dynamic Range Panoramic lmaging,” published in Proceedings of International Conference on Computer Vision, 2001, Aggarwal and Ahuja teach a method to generate an extended dynamic range panorama of a scene. The method involves placing a graded transparency (mask) in front of the camera sensor that allows every scene point to be imaged under multiple exposure settings as the camera pans. This process is required to capture large fields of view at high resolution. The sequence of images is then stitched to construct a high resolution, extended dynamic range panoramic image.
[0008] Both of these methods adopt a fixed transmittance attenuation pattern to all scenes regardless of the actual brightness, although the pattern itself varies spatially. Also, for each scene point, there are, effectively, more measurements performed than what are needed. In order for each scene point to be exposed in the same transmittance variation pattern, a careful calibration between the speed of camera panning and camera frame capture rate has to be performed. Moreover, neither method teaches how to generate a high bit-depth panorama in the process of building an extended dynamic range panoramic image.
[0009] One existing camera system is capable of generating both extended dynamic range and high bit-depth images by using a simple attachment that can be added to a conventional low bit-depth electronic camera. In commonly assigned, co-pending U.S. patent application Ser. No. 10/193,342, entitled “Method and Apparatus for Generating Images Used in Extended Range Image Composition” and filed Jul. 11, 2002, and which is incorporated herein by reference, Chen et. al. describe a method for generating such an extended dynamic range and high bit-depth image that has the advantages that it does not change camera optimal charge transfer efficiency (CTE), use multiple sensors and mirrors, or adversely affect the image resolution.
[0010] What is needed in the art, therefore, is a method for building an extended dynamic range panoramic image and a high bit-depth panorama from a sequence of photographs of a scene.
SUMMARY OF INVENTION
[0011] The present invention is directed to overcoming one or more of the problems set forth above. Briefly summarized, the invention resides in a method of obtaining an extended dynamic range panorama of a scene from a plurality of limited dynamic range images captured by an image sensor in a digital camera. The method includes the steps of: (a) from a first position, capturing a first plurality of digital images comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the first position, wherein light transmittance upon the image sensor is adjustable; (b) evaluating each image after it is captured for an illumination level exceeding the limited dynamic range of the image at either a higher or a lower end of the dynamic range for at least some of the image pixels; (c) based on the evaluation of each image exceeding the limited dynamic range, adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range; (d) storing the first plurality of digital images; (e) processing the stored digital images to generate a first composite image having an extended dynamic range greater than any of the digital images by themselves; (t) from a second position, capturing a second plurality of digital images comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the second position, and then repeating the steps (b) through (e) for the second plurality of images to generate a second composite image; and (g) processing the first and second composite images to generate an extended dynamic range panorama image.
[0012] According to another aspect of the invention, a high bit depth panorama of a scene is obtained from a plurality of high bit depth images converted from a plurality of images of lower bit depth captured by an image sensor in a digital camera, where the lower bit depth images also comprise lower dynamic range images. This method includes the steps of: (a) from a first position, capturing a first plurality of digital images of lower bit depth comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the first position, wherein light transmittance upon the image sensor is variably attenuated for at least one of the images; (b) evaluating each image after it is captured for an illumination level exceeding the limited dynamic range of the image for at least some of the image pixels; (c) based on the evaluation of each image exceeding the limited dynamic range, adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range; (d) calculating an attenuation coefficient for each of the images corresponding to the degree of attenuation for each image; (e) storing data for the reconstruction of one or more high bit depth images from the low bit depth images, said data including the first plurality of digital images and the attenuation coefficients; (f) processing the stored data to generate a first composite image having a higher bit depth than any of the digital images by themselves; (g) from a second position, capturing a second plurality of digital images of lower bit depth comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the second position, and then repeating the steps (b) through (f) on the second plurality of images to generate a second composite image; and (h) processing the first and second composite images to generate a panorama image having a higher bit depth.
[0013] In both embodiments, steps (f) and (g), respectively, may be repeated for one or more additional positions to accordingly generate one or more additional composite images, and the extended dynamic range panorama image is generated in the final step from the first and second, and the one or more additional, composite images.
[0014] The advantage of this invention is the ability to convert a conventional low-bit depth electronic camera (e.g., having an electronic sensor device) to an extended dynamic range panorama imaging device without changing camera optimal charge transfer efficiency (CTE), or having to use multiple sensors and mirrors, or affecting the image resolution. Furthermore, by varying the light transmittance upon the image sensor for a group of images in order to obtain a series of different scene brightness ranges, an attenuation factor may be calculated for the images. The attenuation factor represents additional image information that can be used together with image data (low bit-depth data) to further characterize the bit-depth of the images, thereby enabling the generation of high-bit depth panorama images from a low bit-depth device.
[0015] These and other aspects, objects, features and advantages of the present invention will be more clearly understood and appreciated from a review of the following detailed description of the preferred embodiments and appended claims, and by reference to the accompanying drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
[0016]
FIG. 1A is a perspective view of a first embodiment of a camera for generating images used in extended dynamic range image composition according to the invention.
[0017]
FIG. 1B is a perspective view of a second embodiment of a camera for generating images used in extended dynamic range image composition according to the invention.
[0018]
FIG. 2 is a perspective view taken of the rear of the cameras shown in FIGS. 1A and 1B.
[0019]
FIG. 3 is a block diagram of the relevant components of the cameras shown in FIGS. 1A and 1B.
[0020]
FIG. 4 is a diagram of the components of a liquid crystal variable attenuator used in the cameras shown in FIGS. 1A and 1B.
[0021]
FIG. 5 is a flow diagram of a presently preferred embodiment for extended range composition according to the present invention.
[0022]
FIG. 6 is a flow diagram of a presently preferred embodiment of the image alignment step shown in FIG. 5 for correcting unwanted motion in the captured images.
[0023]
FIG. 7 is a flow diagram of a presently preferred embodiment of the automatic adjustment step shown in FIG. 5 for controlling light attenuation.
[0024]
FIG. 8 is a diagrammatic illustration of an image processing system for performing the alignment correction shown in FIGS. 5 and 6.
[0025]
FIG. 9 is a pictorial illustration of collected images with different illumination levels and a composite image.
[0026]
FIG. 10 is a flow chart of a presently preferred embodiment for producing recoverable information in order to generate a high bit-depth image from a low bit-depth capture device.
[0027] FIGS. 11(A), 11(B) and 11(C) are histograms showing different intensity distributions for original scene data, and for the scene data as captured and processed according to the prior art and according to the invention.
[0028]
FIG. 12 is a view of an embodiment three positions of a camera for generating panoramas used in extended dynamic range panorama composition according to the invention.
[0029]
FIG. 13 is a pictorial illustration of collected images with different illumination levels at different positions.
[0030]
FIG. 14 is a pictorial illustration of composite images.
[0031]
FIG. 15 is a flow chart of a presently preferred embodiment for composting images.
DETAILED DESCRIPTION OF THE INVENTION
[0032] Because imaging devices employing electronic sensors are well known, the present description will be directed in particular to elements forming part of, or cooperating more directly with, a method and a system in accordance with the present invention. Elements not specifically shown or described herein may be selected from those known in the art. Certain aspects of the embodiments to be described may be provided in software. Given the method and system as shown and described according to the invention in the following materials, software not specifically shown, described or suggested herein that is useful for implementation of the invention is conventional and within the ordinary skill in such arts.
[0033] The present invention describes a method and a system for building an extended dynamic range panoramic image and a high bit-depth panorama by converting a conventional low-bit depth electronic camera (e.g., having a CCD sensor device) to a extended dynamic range imaging device, without changing camera optimal charge transfer efficiency (CTE), by attaching a device known as a variable attenuator and limited additional electronic circuitry to the camera system, and by applying digital image processing methods to the acquired images. Optical devices that vary light transmittance are commercially available. Meadowlark Optics manufactures an assortment of these devices known as Liquid Crystal Variable Attenuators. The liquid crystal variable attenuator offers real-time continuous control of light intensity. Light transmission is maximized by applying the correct voltage to achieve half-wave retardance from the liquid crystal. Transmission decreases as the applied voltage amplitude increases.
[0034] Any type of single sensor method of capturing a collection of images that are used to form a extended dynamic range image necessarily suffers from unwanted motion in the camera or scene during the time that the collection of images is captured. Therefore, the present invention furthermore describes a method of generating a extended dynamic range image by capturing a collection of images using a single CCD sensor camera with an attached Liquid crystal variable attenuator, wherein subsequent processing according to the method corrects for unwanted motion in the collection of images.
[0035] In addition, the present invention teaches a method that uses a low bit-depth device to generate extended dynamic range images (low bit-depth images), and at the same time, produces recoverable information to be used to generate high bit-depth images, that, in turn, are used to generate a high bit depth panorama.
[0036]
FIGS. 1A, 1B and 2 show several related perspective views of camera systems useful for generating images used in extended dynamic range panorama composition according to the invention. Each of these figures illustrate a camera body 104, a lens 102, a liquid crystal variable attenuator 100, an image capture switch 318 and a manual controller 322 for the attenuator voltage. The lens 102 focuses an image upon an image sensor 308 inside the camera body 104 (e.g., a charge coupled device (CCD) sensor), and the captured image is displayed on a light emitting diode (LED) display 316 as shown in FIG. 2. A menu screen 210 and a menu selector 206 are provided for selecting camera operation modes.
[0037] The second embodiment for a camera as shown in FIG. 1B illustrates the variable attenuator 100 as an attachment placed in an optical path 102A (see FIG. 3) of the camera. To enable attachment, the variable attenuator 100 includes a threaded section 10A that is conformed to engage a corresponding threaded section on the inside 102B of the lens barrel of the lens 102. Other forms of attachment, such as a bayonet attachment, may be used. The objective of an attachment is to enable use of the variable attenuator with a conventional camera; however, a conventional camera will not include any voltage control circuitry for the variable attenuator. Consequently, in this second embodiment, the manual controller 322 is located on a power atttachment 106 that is attached to the camera, e.g., by attaching to a connection on the bottom plate of the camera body 104. The variable attenuator 100 and the power attachment 106 are connected by a cable 108 for transmitting power and control signals therebetween. (The cable 108 would typically be coupled, at least on the attenuator end of the connection, to a cable jack (not shown) so that the attenuator 100 could be screwed into the lens 102 and then connected to the cable 108.)
[0038] Referring to the block diagram of FIG. 3, a camera system used for generating images for extended dynamic range panorama composition is generally designated by a reference character 300. The camera system 300 includes the body 104, which provides the case and chassis to which all elements of the camera system 300 are firmly attached. Light from an object 301 enters the liquid crystal variable attenuator 100, and the light exiting the attenuator 100 is then collected and focused by the lens 102 through an aperture 306 upon the CCD sensor 308. In the CCD sensor 308, the light is converted into an electrical signal and applied to an amplifier 310. The amplified electrical signal from the amplifier 310 is digitized by an analog to digital converter 312. The digitized signal is then processed in a digital processor 314 so that it is ready for display or storing.
[0039] The signal from the digital processor 314 is then utilized to excite the LED display 316 and produce an image on its face which is a duplicate of the image formed at the input face of the CCD sensor 308. Typically, a brighter object in a scene causes a corresponding portion of the CCD sensor 308 to become saturated, thereby producing a white region without any, or at least very few, texture details in the image shown on the display face of the LED display 316. The brightness information from at least the saturated portion is translated by the processor 314 into a voltage change on a line 330 that is processed by an auto controller 324 and applied as voltage 333 through a gate 328 to the liquid crystal variable attenuator 100. Alternatively, the manual controller 322 may produce a voltage change that is applied through the gate 328 to the liquid crystal variable attenuator 100.
[0040] Referring to FIG. 4, the liquid crystal variable attenuator 100 comprises a liquid crystal variable retarder 404 operating between two crossed linear polarizers: an entrance polarizer 402 and an exit polarizer 406. Such a liquid crystal variable attenuator is available from Meadowlark Optics, Frederick, Colo. With crossed polarizers, light transmission is maximized by applying a correct voltage 333 to the retarder 404 to achieve half-wave retardance from its liquid crystal cell, as shown in FIG. 4. An incoming unpolarized input light beam 400 is polarized by the entrance polarizer 402. Half-wave operation of the retarder 404 rotates the incoming polarization direction by 90 degrees, so that light is passed by the exit polarizer 406. Minimum transmission is obtained with the retarder 404 operating at zero waves.
[0041] Transmission decreases as the applied voltage 333 increases (from half to zero waves retardance). A relationship between transmittance T and retardance 5 (in degrees) for a crossed polarizer configuration is given by
1
[0042] where Tmax is a maximum transmittance when retardance is exactly one-half wave (or 180 degrees). The retardance δ (in degrees) is a function of an applied voltage V and could be written as δ=f(V), where function f can be derived from the specifications of the attenuator 100 or determined through experimental calibrations. With this relationship, Equation (1) is re-written as
2
[0043] Next, define a transmittance attenuation coefficients =T(δ)/Tmax. From Equation (2), it is known that the transmittance attenuation coefficient is a function of v and can be expressed as
3
[0044] The transmittance attenuation coefficient (V) defined here is to be used later in an embodiment describing how to recover useful information to generate high bit-depth images. The values of (V) can be pre-computed off-line and stored in a look up table (LUT) in the processor 314, or computed in real time in the processor 314.
[0045] Maximum transmission is dependent upon properties of the liquid crystal variable retarder 404 as well as the polarizers 402 and 406 used. With a system having a configuration as shown in FIG. 4, the unpolarized light source 400 exits at the exit polarizer 406 as a polarized light beam 408. The camera system 300 is operated in different modes, as selected by the mode selector 206. In a manual control mode, a voltage adjustment 333 is sent to the gate 328 from the manual controller 322, which is activated and controlled by a user if there is a saturated portion in the displayed image. Accordingly, the attenuator 100 produces a lower light transmittance, therefore, reducing the amount of saturation that the CCD sensor 308 can produce. An image can be captured and stored in a storage 320 through the gate 326 by closing the image capture switch 318, which is activated by the user.
[0046] In a manual control mode, the user may take as many images as necessary for extended dynamic range image composition, depending upon scene illumination levels. In other words, an arbitrary dynamic range resolution can be achieved. For example, a saturated region of an area B1 can be shrunk to an area B2, (where B2≦B1), by adjusting the controller 322 so that the transmittance T1(δ) of the light attenuator 100 is set to an appropriate level. A corresponding image I1 is stored for that level of attenuation. Likewise, the controller 322 can be adjusted a second time so that the transmittance T2(δ) of the light attenuator 100 causes the spot B2 in the display 316 to shrink to B3, (where B3≦B2). A corresponding image I2 is stored for that level of luminance. This process can be repeated for N, BN=0, or until minimum transmittance is attained by the light attenuator.
[0047] In an automatic control mode, when the processor 314 detects saturation and provides a signal on the line 330 to the auto controller 324, the controller 324 generates a voltage adjustment 333 that is sent to the gate 328. Accordingly, the attenuator 100 produces a lower light transmittance, thereby reducing the amount of saturation that the CCD sensor 308 can produce. The resulting image is applied to the storage 320 through the gate 326 upon a signal from the auto controller 324, and the image is stored in the storage 320. The detection of saturation by the digital processor 314 and the auto controlling process performed by the auto controller 324 are explained below.
[0048] In the auto mode, the processor 314 checks an image to determine what ratio of the number of pixels have an intensity level exceeding a pre-programmed threshold TV. An exemplary value TV is 240.0. If there are pixels whose intensity levels exceed TV, and if the ratio, R, is greater than a pre-programmed threshold TN, where R is the ratio of the number of pixels whose intensity levels exceed TV to the total number of pixels of the image, then the processor 314 generates a non-zero value signal that is applied to the auto controller 324 through line 330. Otherwise, the processor 314 generates a zero value that is applied to the auto controller 324. An exemplary value for the threshold TN is 0.01. Upon receiving a non-zero signal, the auto controller 324 increases an adjustment voltage V by an amount of δV. The initial value for the adjustment voltage V is Vmin. The maximum allowable value of V is Vmax. The value of δV can be easily determined based on how many attenuation levels are desired and the specification of the attenuator. An exemplary value of δV is 0.5 volts. Both Vmin, and Vmax are values that are determined by the specifications of the attenuator. An exemplary value of Vmin is 2 volts and an exemplary value of Vmax is 7 volts.
[0049]
FIG. 7 shows the process flow for an automatic control mode of operation. In the initial state, the camera captures an image (step 702), and sets the adjustment voltage V to Vmin (step 704). In step 706, the processor 314 checks the intensity of the image pixels to determine if there is a saturation region (where pixel intensity levels exceed TV) in the image and checks the ratio R to determine if R>TN, where R is the aforementioned ratio of the number of pixels whose intensity levels exceed TV to the total number of pixels of the image. If the answer is ‘No’, the processor 314 saves the image to storage 320 and the process stops at step 722. If the answer is ‘Yes’, the processor 314 saves the image to storage 320 and increases the adjustment voltage V by an amount of δV (step 712). In step 714, the processor 314 checks the feedback 332 from the auto controller 324 to see if the adjustment voltage V is less than Vmax. If the answer is ‘Yes’, the processor 314 commands the auto controller 324 to send the adjustment voltage V to the gate 328. Another image is then captured and the process repeats. If the answer from step 714 is ‘No’, then the process stops.
[0050] It is understood that the above discussed light transmittance adjustment procedures for recovering higher end (bright) saturated pixels are applicable to recovering lower end clipped pixels by altering the parameters and formulations used in the procedures accordingly.
[0051] Referring to FIG. 12, there is an exemplary operation showing a camera system (300) used for generating an extended dynamic range panorama moving from a first position 1202, to a second position 1204, then to a third position 1206. At each of these positions, the camera system 300 takes one or more images according to the above descriptions. Exemplary images are shown in FIG. 13. In the first position the camera system 300 takes three images: image I11 (1302), image I21 (1303) and image I31 (1304), where the superscript signifies the position of the camera. In the second position, the camera system 300 takes two images: image I12 (1306), and image I22 (1307). In the third position, the camera system 300 takes three images: image I13 (1308), image I23 (1309) and image I33 (1310). These images are stored in storage 320.
[0052] Images collected in the storage 320 in the camera 300 are further processed for alignment and composition in an image processing system as shown in FIG. 8.
[0053] Referring to FIG. 8, the digital images from the digital image storage 320 are provided to an image processor 802, such as a programmable personal computer, or a digital image processing work station such as a Sun Sparc workstation. The image processor 802 may be connected to a CRT display 804, an operator interface such as a keyboard 806 and a mouse 808. The image processor 802 is also connected to a computer readable storage medium 807. The image processor 802 transmits processed digital images to an output device 809. The output device 809 can comprise a hard copy printer, a long-term image storage device, a connection to another processor, or an image telecommunication device connected, for example, to the Internet. The image processor 802 contains software for implementing the process of image alignment and composition, which is explained next.
[0054] As previously mentioned, the preferred system for capturing multiple images at a specific position to form a extended dynamic range image does not capture all images simultaneously, so any unwanted motion in the camera or scene during the capture process will cause misalignment of the images. Correct formation of an extended dynamic range image assumes the camera is stable, or not moving, and that there is no scene motion during the capture of the collection of images. If the camera is mounted on a tripod or a monopod, or placed on top of or in contact with a stationary object, then the stability assumption is likely to hold. However, if the collection of images is captured while the camera is held in the hands of the photographer, the slightest jitter or movement of the hands may introduce stabilization errors that will adversely affect the formation of the extended dynamic range image.
[0055] The process of removing any unwanted motion from a sequence of images captured when the camera is at a specific position is called image stabilization. Some systems use optical, mechanical, or other physical means to correct for the unwanted motion at the time of capture or scanning. However, these systems are often complex and expensive. To provide stabilization for a generic digital image sequence, several digital image processing methods have been developed and described in the prior art.
[0056] A number of digital image processing methods use a specific camera motion model to estimate one or more parameters such as zoom, translation, rotation, etc. between successive frames in the sequences. These parameters are computed from a motion vector field that describes the correspondence between image points in two successive frames. The resulting parameters can then be filtered over a number of frames to provide smooth motion. An example of such a system is described in U.S. Pat. No. 5,629,988, entitled “System and Method for Electronic Image Stabilization” and issued May 13, 1997 in the names of Burt et al, and which is incorporated herein by reference. A fundamental assumption in these systems is that a global transformation dominates the motion between adjacent frames. In the presence of significant local motion, such as multiple objects moving with independent motion trajectories, these methods may fail due to the computation of erroneous global motion parameters. In addition, it may be difficult to apply these methods to a collection of images captured with varying exposures because the images will differ dramatically in overall intensity. Only the information contained in the phase of the Fourier Transform of the image is similar.
[0057] Other digital image processing methods for removing unwanted motion make use of a technique known as phase correlation for precisely aligning successive frames. An example of such a method has been reported by Eroglu et al. (in “A fast algorithm for subpixel accuracy image stabilization for digital film and video,” Proc. SPIE Visual Communications and Image Processing, Vol. 3309, pp. 786-797, 1998). These methods would be more applicable to the stabilization of a collection of images used to form a extended dynamic range image because the correlation procedure only compares the information contained in the phase of the Fourier Transform of the images.
[0058]
FIG. 5 shows a flow chart of a system that unifies the previously explained manual control mode and auto control mode, and which includes the process of image alignment and composition. This system is capable of capturing, storing, and aligning a collection of images, where each image corresponds to a distinct luminance level. In this system, the extended dynamic range camera 300 is used to capture (step 500) an image of the scene. This captured image corresponds to the first luminance level, and is stored (step 502) in memory. A query 504 is made as to whether enough images have been captured to form the extended dynamic range image. A negative response to query 504 indicates that the degree of light attenuation is changed (step 506) e.g., by the auto controller 324 or by user adjustment of the manual controller 322. The process of capturing (step 500) and storing (step 502) images corresponding to different luminance levels is repeated until there is an affirmative response to query 504. An affirmative response to query 504 indicates that all images have been captured and stored, and the system proceeds to the step 508 of aligning the stored images. It should be understood that in the manual control mode, steps 504 and 506 represent actions including manual voltage adjustment and the user's visual inspection of the result. In the auto control mode, steps 504 and 506 represent actions including automatic image saturation testing, automatic voltage adjustment, automatic voltage limit testing, etc., as stated in previous sections. Also, step 502 stores images in the storage 320.
[0059] Referring now to FIG. 6, an embodiment of the step 508 of aligning the stored images is described. During the step 508 of aligning the stored images 600, the translational difference TJ,J+1 (a two element vector corresponding to horizontal and vertical translation) between IJ and IJ+1 is computed by phase correlation 602 (as described in the aforementioned Eroglu reference, or in C. Kuglin and D. Hines, “The Phase Correlation Image Alignment Method”, Proc. 1975 International Conference on Cybernetics and Society, pp. 163-165, 1975.) for each integral value of j for 1≦j≦N−1, where N is the total number of stored images. The counter i is initialized (step 604) to one, and image Ii+1 is shifted (step 606), or translated by
4
[0060] This shift corrects for the unwanted motion in image Ij+1 found by the translational model. A query 608 is made as to whether i=N−1. A negative response to query 608 indicates that i is incremented (step 610) by one, and the process continues at step 606. An affirmative response to query 608 indicates that all images have been corrected (step 612) for unwanted motion, which completes step 508.
[0061]
FIG. 9 shows exemplary contents of three images taken when the camera 300 is at the first position as shown in FIG. 13. The first image, I11, 902 is taken before manual or automatic light attenuation adjustment, the second image, I21, 904 is taken after a first manual or automatic light attenuation adjustment, the third image, I31, 906 is taken after a second manual or automatic light attenuation adjustment. It should be understood that FIG. 9 only shows an exemplary set of images; the number of images (or adjustment steps) in a set could be, in theory, any positive integer. The first image 902 has a saturated region B1 (922). The second image 904 has a saturated region B2 (924), (where B2<B1). The third image 906 has no saturated region. FIG. 9 shows a pixel 908 in the image 902, a pixel 910 in image 904, and a pixel 912 in the image 906. The pixels 908, 910, and 912 are aligned in the aforementioned image alignment step. FIG. 9 shows that pixels 908, 910, and 912 reflect different illumination levels. The pixels 908, 910, and 912 are used in composition to produce a value for a composite image, IC1, 942 at location 944. Image IC1 is also shown in FIG. 14 as 1410. Accordingly, using the same procedure, at the second position, a composite image IC2 (1412) is generated from image I12 (1306) and image I22 (1307); at the third position, a composite image IC3 (1414) is generated from image I13 (1308), image I23 (1309) and image I33 (1310).
[0062] The process of producing a value for a pixel in a composite image can be formulated as a robust statistical estimation (Handbook for Digital Signal Processing by Mitra Kaiser, 1993). Denote a set of pixels (e.g. pixels 908, 910, and 912) collected from N aligned images by {pi,}iε[1, . . . N]. Denote an estimation of a composite pixel in a composite image corresponding to set {pi} by pest. The computation of pest is simply
p
est
=median{p
i
}, iε[j
1
j
1
+1,N−j2−1,N−j2]
[0063] where j1ε[0, . . . N], j2ε[0, N], subject to 0<j1+j2<N. This formulation gives a robust estimation by excluding outliers (e.g. saturated pixels or dark pixels). This formulation also provides flexibility in selecting unsymmetrical exclusion boundaries, j1 and j2. Exemplary selections are j1=1 and j2=1.
[0064] The described robust estimation process is applied to every pixel in the collected images to complete the step 510 in FIG. 5. For the example scene intensity distribution shown in FIG. 11(A), a histogram of intensity levels of the composite image using the present invention is predicted to be like a curve 1156 shown in FIG. 11(C) with a range of 0 (1152) to 255 (1158). Note that the intensity distribution 1156 has a shape similar to intensity distribution curve 1116 of the original scene (FIG. 11(A)). However, as can be seen, the intensity resolution has been reduced from 1024 levels to 256 levels. In contrast, however, without the dynamic range correction provided by the invention, the histogram of intensity levels would be as shown in FIG. 11(B), where considerable saturation is evident.
[0065]
FIG. 10 shows a flow chart corresponding to a preferred embodiment of the present invention for producing recoverable information that is to be used to generate a high bit-depth image from a low bit-depth capture device. In its initial state, the camera captures a first image in step 1002. In step 1006, the processor 314 (automatic mode) or the user (manual mode) queries to see if there are saturated pixels in the image. If the answer is negative, the image is saved and the process terminates (step 1007). If the answer is affirmative the process proceeds to step 1008, which determines if the image is a first image. If the image is a first image, the processor 314 stores the positions and intensity values of the unsaturated pixels in a first file. If the image is other than a first image or after completion of step 1009, the locations of the saturated pixels are temporarily stored (step 1010) in a second file. The attenuator voltage is adjusted either automatically (by the auto controller 324 in FIG. 3) or manually (by the manual controller 322 in FIG. 3) as indicated in step 1011. Adjustment and checking of voltage limits are carried out as previously described.
[0066] After the attenuator voltage is adjusted, the next image is captured, as indicated in step 1016, and this new image becomes the current image. In step 1018, the processor 314 stores positions and intensity levels in the first file of only those pixels whose intensity levels were saturated in the previous image but are unsaturated in the current image. The pixels are referred to as “de-saturated” pixels. The processor 314 also stores the value of the associated transmission attenuation coefficient (V) defined in Equation (3). Upon completion of step 1018, the process loops back to step 1006 where the processor 314 (automatic mode) or user (manual mode) checks to see if there are any saturated pixels in the current image. The steps described above are then repeated.
[0067] The process is further explained using the example images in FIG. 13. In order to better understand the process, it is helpful to define several general terms. Let Iik denote a captured image at position k, possibly having saturated pixels, where iε{1, . . . , Mk} and Mk is the total number of captured images Mk≧1. All captured images are assumed to contain the same number of pixels N and each pixel in a particular image Iik at position k is identified by an index n, where nε{1, . . . , N}. It is further assumed that all images are mutually aligned to one another so that a particular value of pixel index n refers to a pixel location, which is independent of Iik. The Cartesian co-ordinates associated with pixel n are denoted (xn,yn) and the intensity level associated with this pixel in image Iik at position k is denoted Pik(xn,yn). The term Sik={ni1, . . . , nif, . . . , niJik} refers to the subset of pixel indexes corresponding to saturated pixels in image Iik. The subscript jε{1, . . . ,Jik} is associated with pixel index nij in this subset where Jik>0 is the total number of saturated pixels in image Iik. The last image IMkk is assumed to contain no saturated pixels. Accordingly, SMkk=NULL is an empty set for this image. Although the last assumption does not necessarily always hold true, it can usually be achieved in practice since the attenuator can be continuously tuned until the transmittance reaches a very low value. In any event, the assumption is not critical to the overall method as described herein.
[0068] Referring now to FIG. 9, the exemplary images having saturated regions are the first image 902, denoted by I11 and the second image 904, denoted by I21. An exemplary last image I31 in FIG. 9 is the third image 906. Exemplary saturated sets are the region 922, denoted by S11 and the region 924, denoted by S21. According to the assumption mentioned in the previous paragraph, S31=NULL.
[0069] After the adjustment of the attenuator control voltage V and after capturing a new current image at position k, image Ii+1k (i.e., steps 1011 and 1016, respectively, in FIG. 10), the processor 314 retrieves the locations of saturated pixels in image Iik at position k that were temporarily stored in the second file. In step 1018 it checks to see if pixel nij at location (xnij, ynij) has become de-saturated in the new current image. If de-saturation has occurred for this pixel, the new intensity level Pi+1k (xnij,ynij) and the position (xnij, ynij) are stored in the first file along with the value of the associated attenuation coefficient, i+1k(V). The process of storing information on de-saturated pixels starts after a first adjustment of the attenuator control voltage and continues until a last adjustment is made.
[0070] Referring back to the example in FIG. 9 in connection with the process flow diagram shown in FIG. 10, locations and intensities of unsaturated pixels of the first image 902 are stored in the first storage file (step 1009). The locations of saturated pixels in the region 922 are stored temporarily in the second storage file (step 1010). The second image 904 is captured (step 1016) after a first adjustment of the attenuator control voltage (step 1011). The processor 314 then retrieves from the second temporary storage file the locations of saturated pixels in the region 922 of the first image 902. A determination is made automatically by the processor or manually by the operator to see if pixels at these locations have become de-saturated in the second image 904. The first storage file is then updated with the positions and intensities of the newly de-saturated pixels (step 1018). For example, pixel 908 is located in the saturated region 922 of the first image. This pixel corresponds to pixel 910 in the second image 904, which lies in the de-saturated region 905 of the second image 904. The intensities and locations of all pixels in the region 905 are stored in the first storage file along with the transmittance attenuation factor 2k(V). The process then loops back to step 1006. Information stored in the second temporary storage file is replaced by the locations of saturated pixels in the region 924 in the second image 904 (step 1010). A second and final adjustment of attenuator control voltage is made (step 1011) followed by the capture of the third image 906 (step 1016). Since all pixels in the region 924 have become newly de-saturated in the example, the first storage file is updated (step 1018) to include the intensities and locations of all pixels in this region along with the transmittance attenuation factor 3k (V). Since there are no saturated pixels in the third image 906, the process terminates (steps 1007) after the process loops back to step 1006. It will be appreciated that only one attenuation coefficient needs to be stored for each adjustment of the attenuator control voltage, that is, for each new set of de-saturated pixels. The above described process is applied to k sets of images, where kε[1, . . . , K], and K is the number of positions where the moving camera stops and takes images.
[0071] Equation (4) expresses a piece of pseudo code describing this process at K positions. In Equation (4), i is the image index, n is the pixel index, (xn, yn) are the Cartesian co-ordinates of pixel n, Pik (xn,yn) is the intensity in image Iik, at the position k, associated with pixel n, and nij is the index associated with the jth saturated pixel in image Iik.
1|
|
for (k = 1; k ≦ K; k++){
for (n = 1; n ≦ N; n++){
if (n ∉ S1k){
store (xn, yn), P1k (xn, yn), and 1
}
}
for (i = 1; i ≦ (Mk − 1); i++;){(4)
for (j = 1; j ≦ j1k; j++){
if (nij ∉ Si+1k){
store (xnij, ynij), Pi+1k(xnij, ynij), and i+1k(V)
}
}
}
}
|
[0072] Another feature of the present invention is to use a low bit-depth device, such as the digital camera shown in FIGS. 1, 2 and 3, to generate extended dynamic range panorama (which as discussed to this point are still low bit-depth panorama), and at the same time, produce recoverable information that may be used to additionally generate high bit-depth panorama. This feature is premised on the observation that the attenuation coefficient represents additional image information that can be used together with image data (low bit-depth data) to further characterize the bit-depth of the images.
[0073] Having the information stored in Equation (4), it is a straightforward process to generate a high bit-depth image using the stored data. Notice that the exemplary data format in the file is for each row to have three elements: pixel position in Cartesian coordinates, pixel intensity and attenuation coefficient. For convenience, denote the intensity data at position k in the file for each row by Pk, the position data by Xk, and attenuation coefficient by k. Also, denote new intensity data for a reconstructed high bit-depth image (denoted by Ĩk), by PHIGHk. A simple reconstruction for K high bit depth images is shown as
2|
|
for k = 1; k ≦ K; k++){
for (n = 1; n ≦ N; n++){
PHIGHk(Xnk) = Pk(Xnk)/nk(5)
}
}
|
[0074] where n is either 1 or (V) as indicated by Equation (4).
[0075] The method of producing recoverable information to be used to generate a high bit-depth image described with the preferred embodiment can be modified for other types of extended dynamic range techniques such as controlling an integration time of a CCD sensor of a digital camera (see U.S. Pat. No. 5,144,442, which is entitled “Wide Dynamic Range Camera” and issued Sep. 1, 1992 in the name of Ran Ginosar et al). In this case, the transmittance attenuation coefficient is a function of time, that is, 9<(t).
[0076] The resultant composite images ICk are used to generate the extended dynamic panorama of the scene. Note that every two neighboring two composite images have an overlapping region needed for stitching. An exemplary region is shown in FIG. 14. In FIG. 14, a part, ICo1 (1420), of image IC1 (1410) overlaps with a part, ICo2 (1422), of image IC2 (1412). In general, the overall brightness and contrast in the overlapping region for two composite images are not the same due to the composite procedure discussed above. To overcome this problem, the transformation method disclosed in the aforementioned U.S. Ser. No. 10/008,026, “Method and systems for compositing images” by Cahill et a., is employed, as discussed with respect to the following figure. Alternatively, the transformation method disclosed in the aforementioned U.S. Pat. No. 6,128,108, is employed.
[0077] Referring to FIG. 15, two source digital images (two neighboring composite images) are provided in step 2200. The pixel values of at least one of the source digital images are modified 2202 by a linear exposure transform so that the pixel values in the overlap regions of overlapping source digital images are similar, yielding a set of adjusted source digital images. A linear exposure transform refers to a transformation that is applied to the pixel values of a source digital image, the transformation being linear with respect to the scene intensity values at each pixel. The adjusted source digital images are then combined 2204 by a feathering scheme, weighted averages, or some other blending technique known in the art, to form a composite digital image 2206. After applying this process to all K composite images ICk, the final composite image in step 2206 is the extended dynamic range panorama of the scene.
[0078] This same transformation process can be applied to the reconstructed high bit depth image Ĩk to generate a final high bit depth panorama of the scene.
[0079] The invention has been described in detail with particular reference to certain preferred embodiments thereof, but it will be understood that variations and modifications can be effected within the spirit and scope of the invention.
Parts List
[0080]
100
Variable attenuator
[0081]
100
A threaded section
[0082]
100
B threaded section
[0083]
102
Lens
[0084]
102
A optical path
[0085]
104
Camera box
[0086]
106
power attachment
[0087]
108
cable
[0088]
206
Menu controller
[0089]
210
Menu display
[0090]
300
Extended dynamic range camera
[0091]
301
object
[0092]
306
Aperture
[0093]
308
image sensor
[0094]
310
Amplifier
[0095]
312
A/D converter
[0096]
314
Processor
[0097]
316
Display
[0098]
318
Switch
[0099]
320
Storage
[0100]
322
Manual Controller
[0101]
324
Auto Controller
[0102]
326
Gate
[0103]
328
Gate
[0104]
330
Line
[0105]
333
Voltage
[0106]
332
Feedback
[0107]
334
Command Line
[0108]
400
Unpolarized light
[0109]
402
Entrance Polarizer
[0110]
404
Retarder
[0111]
406
Exit Polarizer
[0112]
408
Polarized light
[0113]
500
Image Capture Step
[0114]
502
Image Storage Step
[0115]
504
Query
[0116]
506
Adjust Light Attenuation Step
[0117]
508
Image Alignment Step
[0118]
510
Image Composition Step
[0119]
600
Stored Images
[0120]
602
Translational Differences
[0121]
604
Initialize Counter
[0122]
606
Image Shifting Step
[0123]
608
Query
[0124]
610
Increment Counter
[0125]
612
Alignment Complete
[0126]
702
Take Image Step
[0127]
704
Set V Step
[0128]
706
Query Step
[0129]
708
Save Image Step
[0130]
710
Save Image Step
[0131]
712
Set V Step
[0132]
714
Query Step
[0133]
716
Send V Step
[0134]
718
Take Image Step
[0135]
720
Stop Step
[0136]
722
Stop Step
[0137]
802
image processor
[0138]
804
image display
[0139]
806
data and command entry device
[0140]
807
computer readable storage medium
[0141]
808
data and command control device
[0142]
809
output device
[0143]
902
Image
[0144]
904
Image
[0145]
906
Image
[0146]
908
Pixel
[0147]
910
Pixel
[0148]
912
Pixel
[0149]
922
Region
[0150]
924
Region
[0151]
942
Composite Image
[0152]
944
Composite Pixel
[0153]
1002
Take an image step
[0154]
1006
Query Step
[0155]
1007
Stop step
[0156]
1008
Query
[0157]
1009
Store data step
[0158]
1010
Store data step
[0159]
1011
Adjust voltage step
[0160]
1016
Take an image step
[0161]
1018
Store data step
[0162]
1112
level
[0163]
1114
level
[0164]
1116
intensity distribution curve
[0165]
1134
level
[0166]
1136
distorted intensity histogram
[0167]
1138
level
[0168]
1152
level
[0169]
1156
intensity distribution curve
[0170]
1158
level
[0171]
1202
camera at position 1
[0172]
1204
camera at position 2
[0173]
1206
camera at position 3
[0174]
1302
image
[0175]
1303
image
[0176]
1304
image
[0177]
1306
image
[0178]
1307
image
[0179]
1308
image
[0180]
1309
image
[0181]
1310
image
[0182]
1410
image
[0183]
1411
image
[0184]
1414
image
[0185]
1420
partial image
[0186]
1422
partial image
[0187]
2200
a step
[0188]
2202
a step
[0189]
2203
a step
[0190]
2206
a step
Claims
- 1. A method of obtaining an extended dynamic range panorama image of a scene from a plurality of limited dynamic range images captured by an image sensor in a digital camera, said method comprising steps of:
(a) from a first position, capturing a first plurality of digital images comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the first position, wherein light transmittance upon the image sensor is adjustable; (b) evaluating each image after it is captured for an illumination level exceeding the limited dynamic range of the image at either a higher or a lower end of the dynamic range for at least some of the image pixels; (c) based on the evaluation of each image exceeding the limited dynamic range, adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range; (d) storing the first plurality of digital images; (e) processing the stored digital images to generate a first composite image having an extended dynamic range greater than any of the digital images by themselves; (f) from a second position, capturing a second plurality of digital images comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the second position, and then repeating the steps (b) through (e) for the second plurality of images to generate a second composite image; and (g) processing the first and second composite images to generate an extended dynamic range panorama image.
- 2. The method as claimed in claim 1 wherein the step (b) of evaluating each image after it is captured comprises evaluating each image for an illumination level indicative of saturated regions of the image.
- 3. The method as claimed in claim 1 wherein the step (b) of evaluating each image after it is captured comprises displaying each image after it is captured and evaluating the displayed image for an illumination level indicative of one or more regions of the image exceeding the limited dynamic range of the image.
- 4. The method as claimed in claim 3 wherein the step (b) of evaluating an image after it is captured uses a manual resource of a human observer.
- 5. The method as claimed in claim 1 further involving a digital processor and wherein the step (b) of evaluating each image after it is captured comprises using the digital processor to automatically evaluate the image pixels comprising each image for an illumination level indicative of one or more regions of the image exceeding the limited dynamic range of the image
- 6. The method as claimed in claim 5 wherein the step (b) of automatically evaluating each image after it is captured comprises comparing the image pixels of each image against an intensity threshold indicative of saturation, determining a number of image pixels exceeding the threshold, and evaluating a ratio of the number of pixels exceeding the threshold to the image pixels in the image.
- 7. The method as claimed in claim 1 wherein the step (c) of adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range comprises using a liquid crystal variable attenuator to adjust the light transmittance.
- 8. The method as claimed in claim 1, wherein the plurality of images are subject to unwanted image motion and wherein the step (e) of processing the stored digital images comprises aligning the stored digital images through an image processing algorithm, thereby producing a plurality of aligned images, and generating a composite image from the aligned images.
- 9. The method as claimed in claim 8 wherein a phase correlation technique is used to align the stored digital images.
- 10. The method as claimed in claim 1 wherein the first and second composite images partially overlap and have pixel values that are linearly or logarithmically related to scene intensity, said step (g) further comprising the steps of:
modifying the first and second composite images by applying one or more linear exposure transforms to one or more of the composite images to produce adjusted composite images having pixel values that closely match in an overlapping region; and combining the adjusted composite images to form the extended dynamic range panorama image.
- 11. The method as claimed in claim 1 wherein step (f) is repeated for one or more additional positions to accordingly generate one or more additional composite images, and the extended dynamic range panorama image is generated in step (g) from the first and second, and the one or more additional, composite images.
- 12. A system for obtaining an extended dynamic range panorama image of a scene from a plurality of limited dynamic range images of the scene captured by a digital camera, said system comprising:
a camera having (a) an image sensor for capturing a plurality of digital images comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene, wherein light transmittance upon the image sensor is adjustable; (b) means for evaluating each image after it is captured for an illumination level exceeding the limited dynamic range of the image for at least some of the image pixels; (c) a controller for adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range, whereby said controller is operative based on the evaluation of each image exceeding the limited dynamic range; and (d) a storage device for storing the plurality of digital images, whereby the camera is operated in a plurality of positions to capture respective pluralities of digital images comprising image pixels of the scene as observed from the plurality of positions; and an offline processor for (a) processing the respective pluralities of stored images to generate a plurality of composite images, each having an extended dynamic range greater than any of the digital images by themselves and (b) processing the plurality of composite images to generate an extended dynamic range panorama image.
- 13. The system as claimed in claim 12 wherein said means for evaluating each image after it is captured evaluates each image for an illumination level indicative of saturated regions of the image.
- 14. The system as claimed in claim 12 wherein said means for evaluating each image after it is captured comprises a display device for displaying each image after it is captured and said controller comprises a manual controller for adjusting the light transmittance upon the image sensor.
- 15. The system as claimed in claim 12 wherein said means for evaluating each image after it is captured comprises a digital processor for automatically evaluating each image for an illumination level indicative of one or more regions of the image exceeding the limited dynamic range of the image and for generating a control signal indicative of the evaluation, and said controller comprises an automatic controller responsive to the control signal for adjusting the light transmittance upon the image sensor.
- 16. The system as claimed in claim 15 wherein the digital processor includes an image processing algorithm for comparing the image pixels of each image against an intensity threshold indicative of saturation, determining a number of image pixels exceeding the threshold, and evaluating a ratio of the number of pixels exceeding the threshold to the image pixels in the image.
- 17. The system as claimed in claim 12 wherein said controller further is connected to an attenuator located in an optical path of the image sensor for adjusting light transmittance upon the image sensor.
- 18. The system as claimed in claim 17 wherein the attenuator is a liquid crystal variable attenuator responsive to a control voltage produced by the controller.
- 19. The system as claimed in claim 17 wherein the attenuator is an attachment placed in-the optical path of the camera.
- 20. The system as claimed in claim 17 wherein an attenuation coefficient is generated for each attenuation level of the attenuator, wherein said attenuation coefficient specifies a degree of attenuation provided by the attenuator and is stored with each digital image in the storage device.
- 21. The system as in claim 12 wherein the respective pluralities of images are subject to unwanted image motion and wherein the offline digital processor includes an image processing algorithm for aligning the respective pluralities of stored images, thereby producing respective pluralities of aligned images, and for generating the plurality of composite images from the respective pluralities of aligned images.
- 22. A method of obtaining a high bit depth panorama image of a scene from images of lower bit depth of the scene captured by an image sensor in a digital camera, said lower bit depth images also comprising lower dynamic range images, said method comprising steps of:
(a) from a first position, capturing a first plurality of digital images of lower bit depth comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the first position, wherein light transmittance upon the image sensor is variably attenuated for at least one of the images; (b) evaluating each image after it is captured for an illumination level exceeding the limited dynamic range of the image for at least some of the image pixels; (c) based on the evaluation of each image exceeding the limited dynamic range, adjusting the light transmittance upon the image sensor in order to obtain a subsequent digital image having a different scene brightness range; (d) calculating an attenuation coefficient for each of the images corresponding to the degree of attenuation for each image; (e) storing data for the reconstruction of one or more high bit depth images from the low bit depth images, said data including the first plurality of digital images and the attenuation coefficients; (f) processing the stored data to generate a first composite image having a higher bit depth than any of the digital images by themselves; (g) from a second position, capturing a second plurality of digital images of lower bit depth comprising image pixels of the scene by exposing the image sensor to light transmitted from the scene as observed from the second position, and then repeating the steps (b) through (f) on the second plurality of images to generate a second composite image; and (h) processing the first and second composite images to generate a panorama image having a higher bit depth.
- 23. The method as claimed in claim 22 wherein the step (e) of storing data for the reconstruction of a high bit depth image comprises the steps of:
storing intensity values for de-saturated pixels obtained by changing light transmittance in step (c); storing image positions for the de-saturated pixels obtained by changing light transmittance in step (c); storing a transmittance attenuation coefficient associated with de-saturated pixels obtained by changing light transmittance in step (c); storing intensity values for unsaturated pixels; storing image positions for the unsaturated pixels captured in step (a); and storing a transmittance attenuation coefficient associated with unsaturated pixels.
- 24. The method as claimed in claim 22 wherein the first and second composite images partially overlap and have pixel values that are linearly or logarithmically related to scene intensity, said step (h) further comprising the steps of:
modifying the first and second composite images by applying one or more linear exposure transforms to one or more of the composite images to produce adjusted composite images having pixel values that closely match in an overlapping region; and combining the adjusted composite images to form the panorama image having a higher bit depth.
- 25. The method as claimed in claim 22 wherein step (g) is repeated for one or more additional positions to accordingly generate one or more additional composite images, and the panorama image is generated in step (h) from the first and second, and the one or more additional, composite images.