One or more embodiments of the invention relate generally to thermal imaging devices and more particularly, for example, to the alignment of infrared sensors used to capture thermal image frames.
Conventional infrared imaging devices often use arrays of infrared sensors to capture thermal images of scenes. The infrared sensors are typically implemented in rows and columns to provide generally square or rectangular arrays. Such arrays are usually positioned within imaging devices such that, when the imaging devices are positioned to capture an image of a scene, the rows of sensors are oriented substantially parallel to the ground, and the columns of sensors are oriented substantially perpendicular to the ground.
In many environments, various features of a scene may be disposed in substantially horizontal and/or substantially vertical directions (e.g., relative to the ground or another reference plane). This is true for many manmade structures such as buildings, streets, sidewalks, and other structures. Many naturally occurring features are similarly disposed such as trees, rivers, other bodies of water, and other features. As a result, the horizontal and vertical features of an imaged scene may generally align with the rows and columns of the sensor arrays of conventional infrared imaging devices.
Sensor arrays may exhibit various types of noise (e.g., fixed pattern noise (FPN) or others) that may be substantially correlated to rows and/or columns of infrared sensors. For example, some FPN that appears as column noise may be caused by variations in column amplifiers which may inhibit the ability to distinguish between desired vertical features of a scene and vertical FPN.
Existing techniques used to reduce row and column noise can lead to unsatisfactory results. For example, existing noise reduction techniques may leave artifacts (e.g., image distortion or residual noise) in rows and columns of pixels of captured images. Such row and column noise artifacts may be exacerbated when features of an imaged scene are substantially aligned with rows and columns of the imager as is the case with conventionally oriented sensor arrays.
In various embodiments, an infrared imaging system may be implemented with an infrared sensor array that is fixably positioned to substantially de-align rows and columns of infrared sensors while a thermal image frame is captured of a scene. In one embodiment, an infrared imaging system includes an infrared sensor array comprising a plurality of infrared sensors arranged in rows and columns and adapted to capture a thermal image frame of a scene exhibiting at least one substantially horizontal or substantially vertical feature; a housing; and wherein the infrared sensor array is fixably positioned within the housing to substantially de-align the rows and columns from the feature while the thermal image frame is captured.
In another embodiment, an infrared imaging system includes an infrared sensor array comprising a plurality of infrared sensors arranged in rows and columns and adapted to capture a thermal image frame of a scene exhibiting at least one substantially horizontal or substantially vertical feature; a housing comprising a surface substantially parallel to the feature; and wherein the infrared sensor array is fixably positioned within the housing to substantially de-align the rows and columns from the surface while the thermal image frame is captured.
In another embodiment, a method includes capturing a thermal image frame of a scene exhibiting at least one substantially horizontal or substantially vertical feature; wherein the capturing is performed by an infrared sensor array comprising a plurality of infrared sensors arranged in rows and columns; and wherein the infrared sensor array is fixably positioned within a housing of an infrared imaging system to substantially de-align the rows and columns from the feature while the thermal image frame is captured.
The scope of the invention is defined by the claims, which are incorporated into this section by reference. A more complete understanding of embodiments of the invention will be afforded to those skilled in the art, as well as a realization of additional advantages thereof, by a consideration of the following detailed description of one or more embodiments. Reference will be made to the appended sheets of drawings that will first be described briefly.
Embodiments of the invention and their advantages are best understood by referring to the detailed description that follows. It should be appreciated that like reference numerals are used to identify like elements illustrated in one or more of the figures.
In one embodiment, infrared imaging module 100 may be configured to be implemented in a small portable host device 102, such as a mobile telephone, a tablet computing device, a laptop computing device, a personal digital assistant, a visible light camera, a music player, or any other appropriate mobile device. In this regard, infrared imaging module 100 may be used to provide infrared imaging features to host device 102. For example, infrared imaging module 100 may be configured to capture, process, and/or otherwise manage infrared images and provide such infrared images to host device 102 for use in any desired fashion (e.g., for further processing, to store in memory, to display, to use by various applications running on host device 102, to export to other devices, or other uses).
In various embodiments, infrared imaging module 100 may be configured to operate at low voltage levels and over a wide temperature range. For example, in one embodiment, infrared imaging module 100 may operate using a power supply of approximately 2.4 volts, 2.5 volts, 2.8 volts, or lower voltages, and operate over a temperature range of approximately −20 degrees C. to approximately +60 degrees C. (e.g., providing a suitable dynamic range and performance over an environmental temperature range of approximately 80 degrees C.). In one embodiment, by operating infrared imaging module 100 at low voltage levels, infrared imaging module 100 may experience reduced amounts of self heating in comparison with other types of infrared imaging devices. As a result, infrared imaging module 100 may be operated with reduced measures to compensate for such self heating.
As shown in
Motion sensors 194 may be implemented by one or more accelerometers, gyroscopes, or other appropriate devices that may be used to detect movement of host device 102. Motion sensors 194 may be monitored by and provide information to processing module 160 or processor 195 to detect motion. In various embodiments, motion sensors 194 may be implemented as part of host device 102 (as shown in
Processor 195 may be implemented as any appropriate processing device (e.g., logic device, microcontroller, processor, application specific integrated circuit (ASIC), or other device) that may be used by host device 102 to execute appropriate instructions, such as software instructions provided in memory 196. Display 197 may be used to display captured and/or processed infrared images and/or other images, data, and information. Other components 198 may be used to implement any features of host device 102 as may be desired for various applications (e.g., clocks, temperature sensors, a visible light camera, or other components). In addition, a machine readable medium 193 may be provided for storing non-transitory instructions for loading into memory 196 and execution by processor 195.
In various embodiments, infrared imaging module 100 and socket 104 may be implemented for mass production to facilitate high volume applications, such as for implementation in mobile telephones or other devices (e.g., requiring small form factors). In one embodiment, the combination of infrared imaging module 100 and socket 104 may exhibit overall dimensions of approximately 8.5 mm by 8.5 mm by 5.9 mm while infrared imaging module 100 is installed in socket 104.
Lens barrel 110 may at least partially enclose an optical element 180 (e.g., a lens) which is partially visible in
Infrared sensor assembly 128 may be implemented, for example, with a cap 130 (e.g., a lid) mounted on a substrate 140. Infrared sensor assembly 128 may include a plurality of infrared sensors 132 (e.g., infrared detectors) implemented in an array or other fashion on substrate 140 and covered by cap 130. For example, in one embodiment, infrared sensor assembly 128 may be implemented as a focal plane array (FPA). Such a focal plane array may be implemented, for example, as a vacuum package assembly (e.g., sealed by cap 130 and substrate 140). In one embodiment, infrared sensor assembly 128 may be implemented as a wafer level package (e.g., infrared sensor assembly 128 may be singulated from a set of vacuum package assemblies provided on a wafer). In one embodiment, infrared sensor assembly 128 may be implemented to operate using a power supply of approximately 2.4 volts, 2.5 volts, 2.8 volts, or similar voltages.
Infrared sensors 132 may be configured to detect infrared radiation (e.g., infrared energy) from a target scene including, for example, mid wave infrared wave bands (MWIR), long wave infrared wave bands (LWIR), and/or other thermal imaging bands as may be desired in particular implementations. In one embodiment, infrared sensor assembly 128 may be provided in accordance with wafer level packaging techniques.
Infrared sensors 132 may be implemented, for example, as microbolometers or other types of thermal imaging infrared sensors arranged in any desired array pattern to provide a plurality of pixels. In one embodiment, infrared sensors 132 may be implemented as vanadium oxide (VOx) detectors with a 17 μm pixel pitch. In various embodiments, arrays of approximately 32 by 32 infrared sensors 132, approximately 64 by 64 infrared sensors 132, approximately 80 by 64 infrared sensors 132, or other array sizes may be used.
Substrate 140 may include various circuitry including, for example, a read out integrated circuit (ROIC) with dimensions less than approximately 5.5 mm by 5.5 mm in one embodiment. Substrate 140 may also include bond pads 142 that may be used to contact complementary connections positioned on inside surfaces of housing 120 when infrared imaging module 100 is assembled as shown in
Infrared sensor assembly 128 may capture images (e.g., image frames) and provide such images from its ROIC at various rates. Processing module 160 may be used to perform appropriate processing of captured infrared images and may be implemented in accordance with any appropriate architecture. In one embodiment, processing module 160 may be implemented as an ASIC. In this regard, such an ASIC may be configured to perform image processing with high performance and/or high efficiency. In another embodiment, processing module 160 may be implemented with a general purpose central processing unit (CPU) which may be configured to execute appropriate software instructions to perform image processing, coordinate and perform image processing with various image processing blocks, coordinate interfacing between processing module 160 and host device 102, and/or other operations. In yet another embodiment, processing module 160 may be implemented with a field programmable gate array (FPGA). Processing module 160 may be implemented with other types of processing and/or logic circuits in other embodiments as would be understood by one skilled in the art.
In these and other embodiments, processing module 160 may also be implemented with other components where appropriate, such as, volatile memory, non-volatile memory, and/or one or more interfaces (e.g., infrared detector interfaces, inter-integrated circuit (I2C) interfaces, mobile industry processor interfaces (MIPI), joint test action group (JTAG) interfaces (e.g., IEEE 1149.1 standard test access port and boundary-scan architecture), and/or other interfaces).
In some embodiments, infrared imaging module 100 may further include one or more actuators 199 which may be used to adjust the focus of infrared image frames captured by infrared sensor assembly 128. For example, actuators 199 may be used to move optical element 180, infrared sensors 132, and/or other components relative to each other to selectively focus and defocus infrared image frames in accordance with techniques described herein. Actuators 199 may be implemented in accordance with any type of motion-inducing apparatus or mechanism, and may positioned at any location within or external to infrared imaging module 100 as appropriate for different applications.
When infrared imaging module 100 is assembled, housing 120 may substantially enclose infrared sensor assembly 128, base 150, and processing module 160. Housing 120 may facilitate connection of various components of infrared imaging module 100. For example, in one embodiment, housing 120 may provide electrical connections 126 to connect various components as further described.
Electrical connections 126 (e.g., conductive electrical paths, traces, or other types of connections) may be electrically connected with bond pads 142 when infrared imaging module 100 is assembled. In various embodiments, electrical connections 126 may be embedded in housing 120, provided on inside surfaces of housing 120, and/or otherwise provided by housing 120. Electrical connections 126 may terminate in connections 124 protruding from the bottom surface of housing 120 as shown in
In various embodiments, electrical connections 126 in housing 120 may be made from any desired material (e.g., copper or any other appropriate conductive material). In one embodiment, electrical connections 126 may aid in dissipating heat from infrared imaging module 100.
Other connections may be used in other embodiments. For example, in one embodiment, sensor assembly 128 may be attached to processing module 160 through a ceramic board that connects to sensor assembly 128 by wire bonds and to processing module 160 by a ball grid array (BGA). In another embodiment, sensor assembly 128 may be mounted directly on a rigid flexible board and electrically connected with wire bonds, and processing module 160 may be mounted and connected to the rigid flexible board with wire bonds or a BGA.
The various implementations of infrared imaging module 100 and host device 102 set forth herein are provided for purposes of example, rather than limitation. In this regard, any of the various techniques described herein may be applied to any infrared camera system, infrared imager, or other device for performing infrared/thermal imaging.
Substrate 140 of infrared sensor assembly 128 may be mounted on base 150. In various embodiments, base 150 (e.g., a pedestal) may be made, for example, of copper formed by metal injection molding (MIM) and provided with a black oxide or nickel-coated finish. In various embodiments, base 150 may be made of any desired material, such as for example zinc, aluminum, or magnesium, as desired for a given application and may be formed by any desired applicable process, such as for example aluminum casting, MIM, or zinc rapid casting, as may be desired for particular applications. In various embodiments, base 150 may be implemented to provide structural support, various circuit paths, thermal heat sink properties, and other features where appropriate. In one embodiment, base 150 may be a multi-layer structure implemented at least in part using ceramic material.
In various embodiments, circuit board 170 may receive housing 120 and thus may physically support the various components of infrared imaging module 100. In various embodiments, circuit board 170 may be implemented as a printed circuit board (e.g., an FR4 circuit board or other types of circuit boards), a rigid or flexible interconnect (e.g., tape or other type of interconnects), a flexible circuit substrate, a flexible plastic substrate, or other appropriate structures. In various embodiments, base 150 may be implemented with the various features and attributes described for circuit board 170, and vice versa.
Socket 104 may include a cavity 106 configured to receive infrared imaging module 100 (e.g., as shown in the assembled view of
Infrared imaging module 100 may be electrically connected with socket 104 through appropriate electrical connections (e.g., contacts, pins, wires, or any other appropriate connections). For example, socket 104 may include electrical connections 108 which may contact corresponding electrical connections of infrared imaging module 100 (e.g., interconnect pads, contacts, or other electrical connections on side or bottom surfaces of circuit board 170, bond pads 142 or other electrical connections on base 150, or other connections). Electrical connections 108 may be made from any desired material (e.g., copper or any other appropriate conductive material). In one embodiment, electrical connections 108 may be mechanically biased to press against electrical connections of infrared imaging module 100 when infrared imaging module 100 is inserted into cavity 106 of socket 104. In one embodiment, electrical connections 108 may at least partially secure infrared imaging module 100 in socket 104. Other types of electrical connections may be used in other embodiments.
Socket 104 may be electrically connected with host device 102 through similar types of electrical connections. For example, in one embodiment, host device 102 may include electrical connections (e.g., soldered connections, snap-in connections, or other connections) that connect with electrical connections 108 passing through apertures 190. In various embodiments, such electrical connections may be made to the sides and/or bottom of socket 104.
Various components of infrared imaging module 100 may be implemented with flip chip technology which may be used to mount components directly to circuit boards without the additional clearances typically needed for wire bond connections. Flip chip connections may be used, as an example, to reduce the overall size of infrared imaging module 100 for use in compact small form factor applications. For example, in one embodiment, processing module 160 may be mounted to circuit board 170 using flip chip connections. For example, infrared imaging module 100 may be implemented with such flip chip configurations.
In various embodiments, infrared imaging module 100 and/or associated components may be implemented in accordance with various techniques (e.g., wafer level packaging techniques) as set forth in U.S. patent application Ser. No. 12/844,124 filed Jul. 27, 2010, and U.S. Provisional Patent Application No. 61/469,651 filed Mar. 30, 2011, which are incorporated herein by reference in their entirety. Furthermore, in accordance with one or more embodiments, infrared imaging module 100 and/or associated components may be implemented, calibrated, tested, and/or used in accordance with various techniques, such as for example as set forth in U.S. Pat. No. 7,470,902 issued Dec. 30, 2008, U.S. Pat. No. 6,028,309 issued Feb. 22, 2000, U.S. Pat. No. 6,812,465 issued Nov. 2, 2004, U.S. Pat. No. 7,034,301 issued Apr. 25, 2006, U.S. Pat. No. 7,679,048 issued Mar. 16, 2010, U.S. Pat. No. 7,470,904 issued Dec. 30, 2008, U.S. patent application Ser. No. 12/202,880 filed Sep. 2, 2008, and U.S. patent application Ser. No. 12/202,896 filed Sep. 2, 2008, which are incorporated herein by reference in their entirety.
Referring again to
In various embodiments, shutter 105 may be made from various materials such as, for example, polymers, glass, aluminum (e.g., painted or anodized) or other materials. In various embodiments, shutter 105 may include one or more coatings to selectively filter electromagnetic radiation and/or adjust various optical properties of shutter 105 (e.g., a uniform blackbody coating or a reflective gold coating).
In another embodiment, shutter 105 may be fixed in place to protect infrared imaging module 100 at all times. In this case, shutter 105 or a portion of shutter 105 may be made from appropriate materials (e.g., polymers or infrared transmitting materials such as silicon, germanium, zinc selenide, or chalcogenide glasses) that do not substantially filter desired infrared wavelengths. In another embodiment, a shutter may be implemented as part of infrared imaging module 100 (e.g., within or as part of a lens barrel or other components of infrared imaging module 100), as would be understood by one skilled in the art.
Alternatively, in another embodiment, a shutter (e.g., shutter 105 or other type of external or internal shutter) need not be provided, but rather a NUC process or other type of calibration may be performed using shutterless techniques. In another embodiment, a NUC process or other type of calibration using shutterless techniques may be performed in combination with shutter-based techniques.
Infrared imaging module 100 and host device 102 may be implemented in accordance with any of the various techniques set forth in U.S. Provisional Patent Application No. 61/495,873 filed Jun. 10, 2011, U.S. Provisional Patent Application No. 61/495,879 filed Jun. 10, 2011, and U.S. Provisional Patent Application No. 61/495,888 filed Jun. 10, 2011, which are incorporated herein by reference in their entirety.
In various embodiments, the components of host device 102 and/or infrared imaging module 100 may be implemented as a local or distributed system with components in communication with each other over wired and/or wireless networks. Accordingly, the various operations identified in this disclosure may be performed by local and/or remote components as may be desired in particular implementations.
In block 505, infrared sensors 132 begin capturing image frames of a scene. Typically, the scene will be the real world environment in which host device 102 is currently located. In this regard, shutter 105 (if optionally provided) may be opened to permit infrared imaging module to receive infrared radiation from the scene. Infrared sensors 132 may continue capturing image frames during all operations shown in
In block 510, a NUC process initiating event is detected. In one embodiment, the NUC process may be initiated in response to physical movement of host device 102. Such movement may be detected, for example, by motion sensors 194 which may be polled by a processor. In one example, a user may move host device 102 in a particular manner, such as by intentionally waving host device 102 back and forth in an “erase” or “swipe” movement. In this regard, the user may move host device 102 in accordance with a predetermined speed and direction (velocity), such as in an up and down, side to side, or other pattern to initiate the NUC process. In this example, the use of such movements may permit the user to intuitively operate host device 102 to simulate the “erasing” of noise in captured image frames.
In another example, a NUC process may be initiated by host device 102 if motion exceeding a threshold value is exceeded (e.g., motion greater than expected for ordinary use). It is contemplated that any desired type of spatial translation of host device 102 may be used to initiate the NUC process.
In yet another example, a NUC process may be initiated by host device 102 if a minimum time has elapsed since a previously performed NUC process. In a further example, a NUC process may be initiated by host device 102 if infrared imaging module 100 has experienced a minimum temperature change since a previously performed NUC process. In a still further example, a NUC process may be continuously initiated and repeated.
In block 515, after a NUC process initiating event is detected, it is determined whether the NUC process should actually be performed. In this regard, the NUC process may be selectively initiated based on whether one or more additional conditions are met. For example, in one embodiment, the NUC process may not be performed unless a minimum time has elapsed since a previously performed NUC process. In another embodiment, the NUC process may not be performed unless infrared imaging module 100 has experienced a minimum temperature change since a previously performed NUC process. Other criteria or conditions may be used in other embodiments. If appropriate criteria or conditions have been met, then the flow diagram continues to block 520. Otherwise, the flow diagram returns to block 505.
In the NUC process, blurred image frames may be used to determine NUC terms which may be applied to captured image frames to correct for FPN. As discussed, in one embodiment, the blurred image frames may be obtained by accumulating multiple image frames of a moving scene (e.g., captured while the scene and/or the thermal imager is in motion). In another embodiment, the blurred image frames may be obtained by defocusing an optical element or other component of the thermal imager.
Accordingly, in block 520 a choice of either approach is provided. If the motion-based approach is used, then the flow diagram continues to block 525. If the defocus-based approach is used, then the flow diagram continues to block 530.
Referring now to the motion-based approach, in block 525 motion is detected. For example, in one embodiment, motion may be detected based on the image frames captured by infrared sensors 132. In this regard, an appropriate motion detection process (e.g., an image registration process, a frame-to-frame difference calculation, or other appropriate process) may be applied to captured image frames to determine whether motion is present (e.g., whether static or moving image frames have been captured). For example, in one embodiment, it can be determined whether pixels or regions around the pixels of consecutive image frames have changed more than a user defined amount (e.g., a percentage and/or threshold value). If at least a given percentage of pixels have changed by at least the user defined amount, then motion will be detected with sufficient certainty to proceed to block 535.
In another embodiment, motion may be determined on a per pixel basis, wherein only pixels that exhibit significant changes are accumulated to provide the blurred image frame. For example, counters may be provided for each pixel and used to ensure that the same number of pixel values are accumulated for each pixel, or used to average the pixel values based on the number of pixel values actually accumulated for each pixel. Other types of image-based motion detection may be performed such as performing a Radon transform.
In another embodiment, motion may be detected based on data provided by motion sensors 194. In one embodiment, such motion detection may include detecting whether host device 102 is moving along a relatively straight trajectory through space. For example, if host device 102 is moving along a relatively straight trajectory, then it is possible that certain objects appearing in the imaged scene may not be sufficiently blurred (e.g., objects in the scene that may be aligned with or moving substantially parallel to the straight trajectory). Thus, in such an embodiment, the motion detected by motion sensors 194 may be conditioned on host device 102 exhibiting, or not exhibiting, particular trajectories.
In yet another embodiment, both a motion detection process and motion sensors 194 may be used. Thus, using any of these various embodiments, a determination can be made as to whether or not each image frame was captured while at least a portion of the scene and host device 102 were in motion relative to each other (e.g., which may be caused by host device 102 moving relative to the scene, at least a portion of the scene moving relative to host device 102, or both).
It is expected that the image frames for which motion was detected may exhibit some secondary blurring of the captured scene (e.g., blurred thermal image data associated with the scene) due to the thermal time constants of infrared sensors 132 (e.g., microbolometer thermal time constants) interacting with the scene movement.
In block 535, image frames for which motion was detected are accumulated. For example, if motion is detected for a continuous series of image frames, then the image frames of the series may be accumulated. As another example, if motion is detected for only some image frames, then the non-moving image frames may be skipped and not included in the accumulation. Thus, a continuous or discontinuous set of image frames may be selected to be accumulated based on the detected motion.
In block 540, the accumulated image frames are averaged to provide a blurred image frame. Because the accumulated image frames were captured during motion, it is expected that actual scene information will vary between the image frames and thus cause the scene information to be further blurred in the resulting blurred image frame (block 545).
In contrast, FPN (e.g., caused by one or more components of infrared imaging module 100) will remain fixed over at least short periods of time and over at least limited changes in scene irradiance during motion. As a result, image frames captured in close proximity in time and space during motion will suffer from identical or at least very similar FPN. Thus, although scene information may change in consecutive image frames, the FPN will stay essentially constant. By averaging, multiple image frames captured during motion will blur the scene information, but will not blur the FPN. As a result, FPN will remain more clearly defined in the blurred image frame provided in block 545 than the scene information.
In one embodiment, 32 or more image frames are accumulated and averaged in blocks 535 and 540. However, any desired number of image frames may be used in other embodiments, but with generally decreasing correction accuracy as frame count is decreased.
Referring now to the defocus-based approach, in block 530, a defocus operation may be performed to intentionally defocus the image frames captured by infrared sensors 132. For example, in one embodiment, one or more actuators 199 may be used to adjust, move, or otherwise translate optical element 180, infrared sensor assembly 128, and/or other components of infrared imaging module 100 to cause infrared sensors 132 to capture a blurred (e.g., unfocused) image frame of the scene. Other non-actuator based techniques are also contemplated for intentionally defocusing infrared image frames such as, for example, manual (e.g., user-initiated) defocusing.
Although the scene may appear blurred in the image frame, FPN (e.g., caused by one or more components of infrared imaging module 100) will remain unaffected by the defocusing operation. As a result, a blurred image frame of the scene will be provided (block 545) with FPN remaining more clearly defined in the blurred image than the scene information.
In the above discussion, the defocus-based approach has been described with regard to a single captured image frame. In another embodiment, the defocus-based approach may include accumulating multiple image frames while the infrared imaging module 100 has been defocused and averaging the defocused image frames to remove the effects of temporal noise and provide a blurred image frame in block 545.
Thus, it will be appreciated that a blurred image frame may be provided in block 545 by either the motion-based approach or the defocus-based approach. Because much of the scene information will be blurred by either motion, defocusing, or both, the blurred image frame may be effectively considered a low pass filtered version of the original captured image frames with respect to scene information.
In block 550, the blurred image frame is processed to determine updated row and column FPN terms (e.g., if row and column FPN terms have not been previously determined then the updated row and column FPN terms may be new row and column FPN terms in the first iteration of block 550). As used in this disclosure, the terms row and column may be used interchangeably depending on the orientation of infrared sensors 132 and/or other components of infrared imaging module 100.
In one embodiment, block 550 includes determining a spatial FPN correction term for each row of the blurred image frame (e.g., each row may have its own spatial FPN correction term), and also determining a spatial FPN correction term for each column of the blurred image frame (e.g., each column may have its own spatial FPN correction term). Such processing may be used to reduce the spatial and slowly varying (1/f) row and column FPN inherent in thermal imagers caused by, for example, 1/f noise characteristics of amplifiers in ROIC 402 which may manifest as vertical and horizontal stripes in image frames.
Advantageously, by determining spatial row and column FPN terms using the blurred image frame, there will be a reduced risk of vertical and horizontal objects in the actual imaged scene from being mistaken for row and column noise (e.g., real scene content will be blurred while FPN remains unblurred).
In one embodiment, row and column FPN terms may be determined by considering differences between neighboring pixels of the blurred image frame. For example,
To prevent real scene data from being interpreted as noise, upper and lower threshold values may be used (thPix and −thPix). Pixel values falling outside these threshold values (pixels d1 and d4 in this example) are not used to obtain the offset error. In addition, the maximum amount of row and column FPN correction may be limited by these threshold values.
Further techniques for performing spatial row and column FPN correction processing are set forth in U.S. patent application Ser. No. 12/396,340 filed Mar. 2, 2009 which is incorporated herein by reference in its entirety.
Referring again to
In block 560, local contrast values (e.g., edges or absolute values of gradients between adjacent or small groups of pixels) in the blurred image frame are determined. If scene information in the blurred image frame includes contrasting areas that have not been significantly blurred (e.g., high contrast edges in the original scene data), then such features may be identified by a contrast determination process in block 560.
For example, local contrast values in the blurred image frame may be calculated, or any other desired type of edge detection process may be applied to identify certain pixels in the blurred image as being part of an area of local contrast. Pixels that are marked in this manner may be considered as containing excessive high spatial frequency scene information that would be interpreted as FPN (e.g., such regions may correspond to portions of the scene that have not been sufficiently blurred). As such, these pixels may be excluded from being used in the further determination of NUC terms. In one embodiment, such contrast detection processing may rely on a threshold that is higher than the expected contrast value associated with FPN (e.g., pixels exhibiting a contrast value higher than the threshold may be considered to be scene information, and those lower than the threshold may be considered to be exhibiting FPN).
In one embodiment, the contrast determination of block 560 may be performed on the blurred image frame after row and column FPN terms have been applied to the blurred image frame (e.g., as shown in
Following block 560, it is expected that any high spatial frequency content remaining in the blurred image frame may be generally attributed to spatially uncorrelated FPN. In this regard, following block 560, much of the other noise or actual desired scene based information has been removed or excluded from the blurred image frame due to: intentional blurring of the image frame (e.g., by motion or defocusing in blocks 520 through 545), application of row and column FPN terms (block 555), and contrast determination of (block 560).
Thus, it can be expected that following block 560, any remaining high spatial frequency content (e.g., exhibited as areas of contrast or differences in the blurred image frame) may be attributed to spatially uncorrelated FPN. Accordingly, in block 565, the blurred image frame is high pass filtered. In one embodiment, this may include applying a high pass filter to extract the high spatial frequency content from the blurred image frame. In another embodiment, this may include applying a low pass filter to the blurred image frame and taking a difference between the low pass filtered image frame and the unfiltered blurred image frame to obtain the high spatial frequency content. In accordance with various embodiments of the present disclosure, a high pass filter may be implemented by calculating a mean difference between a sensor signal (e.g., a pixel value) and its neighbors.
In block 570, a flat field correction process is performed on the high pass filtered blurred image frame to determine updated NUC terms (e.g., if a NUC process has not previously been performed then the updated NUC terms may be new NUC terms in the first iteration of block 570).
For example,
These absolute differences may be summed to provide a summed gradient for pixel 710. A weight value may be determined for pixel 710 that is inversely proportional to the summed gradient. This process may be performed for all pixels 710 of the blurred image frame until a weight value is provided for each pixel 710. For areas with low gradients (e.g., areas that are blurry or have low contrast), the weight value will be close to one. Conversely, for areas with high gradients, the weight value will be zero or close to zero. The update to the NUC term as estimated by the high pass filter is multiplied with the weight value.
In one embodiment, the risk of introducing scene information into the NUC terms can be further reduced by applying some amount of temporal damping to the NUC term determination process. For example, a temporal damping factor λ between 0 and 1 may be chosen such that the new NUC term (NUCNEW) stored is a weighted average of the old NUC term (NUCOLD) and the estimated updated NUC term (NUCUPDATE). In one embodiment, this can be expressed as NUCNEW=λ·NUCOLD+(1−λ)·(NUCOLD+NUCUPDATE).
Although the determination of NUC terms has been described with regard to gradients, local contrast values may be used instead where appropriate. Other techniques may also be used such as, for example, standard deviation calculations. Other types flat field correction processes may be performed to determine NUC terms including, for example, various processes identified in U.S. Pat. No. 6,028,309 issued Feb. 22, 2000, U.S. Pat. No. 6,812,465 issued Nov. 2, 2004, and U.S. patent application Ser. No. 12/114,865 filed May 5, 2008, which are incorporated herein by reference in their entirety.
Referring again to
In blocks 571-573, additional high pass filtering and further determinations of updated NUC terms may be optionally performed to remove spatially correlated FPN with lower spatial frequency than previously removed by row and column FPN terms. In this regard, some variability in infrared sensors 132 or other components of infrared imaging module 100 may result in spatially correlated FPN noise that cannot be easily modeled as row or column noise. Such spatially correlated FPN may include, for example, window defects on a sensor package or a cluster of infrared sensors 132 that respond differently to irradiance than neighboring infrared sensors 132. In one embodiment, such spatially correlated FPN may be mitigated with an offset correction. If the amount of such spatially correlated FPN is significant, then the noise may also be detectable in the blurred image frame. Since this type of noise may affect a neighborhood of pixels, a high pass filter with a small kernel may not detect the FPN in the neighborhood (e.g., all values used in high pass filter may be taken from the neighborhood of affected pixels and thus may be affected by the same offset error). For example, if the high pass filtering of block 565 is performed with a small kernel (e.g., considering only immediately adjacent pixels that fall within a neighborhood of pixels affected by spatially correlated FPN), then broadly distributed spatially correlated FPN may not be detected.
For example,
Referring again to
In block 572, a further high pass filter is applied with a larger kernel than was used in block 565, and further updated NUC terms may be determined in block 573. For example, to detect the spatially correlated FPN present in pixels 1110, the high pass filter applied in block 572 may include data from a sufficiently large enough neighborhood of pixels such that differences can be determined between unaffected pixels (e.g., pixels 1120) and affected pixels (e.g., pixels 1110). For example, a low pass filter with a large kernel can be used (e.g., an N by N kernel that is much greater than 3 by 3 pixels) and the results may be subtracted to perform appropriate high pass filtering.
In one embodiment, for computational efficiency, a sparse kernel may be used such that only a small number of neighboring pixels inside an N by N neighborhood are used. For any given high pass filter operation using distant neighbors (e.g., a large kernel), there is a risk of modeling actual (potentially blurred) scene information as spatially correlated FPN. Accordingly, in one embodiment, the temporal damping factor λ may be set close to 1 for updated NUC terms determined in block 573.
In various embodiments, blocks 571-573 may be repeated (e.g., cascaded) to iteratively perform high pass filtering with increasing kernel sizes to provide further updated NUC terms further correct for spatially correlated FPN of desired neighborhood sizes. In one embodiment, the decision to perform such iterations may be determined by whether spatially correlated FPN has actually been removed by the updated NUC terms of the previous performance of blocks 571-573.
After blocks 571-573 are finished, a decision is made regarding whether to apply the updated NUC terms to captured image frames (block 574). For example, if an average of the absolute value of the NUC terms for the entire image frame is less than a minimum threshold value, or greater than a maximum threshold value, the NUC terms may be deemed spurious or unlikely to provide meaningful correction. Alternatively, thresholding criteria may be applied to individual pixels to determine which pixels receive updated NUC terms. In one embodiment, the threshold values may correspond to differences between the newly calculated NUC terms and previously calculated NUC terms. In another embodiment, the threshold values may be independent of previously calculated NUC terms. Other tests may be applied (e.g., spatial correlation tests) to determine whether the NUC terms should be applied.
If the NUC terms are deemed spurious or unlikely to provide meaningful correction, then the flow diagram returns to block 505. Otherwise, the newly determined NUC terms are stored (block 575) to replace previous NUC terms (e.g., determined by a previously performed iteration of
Image frames captured by infrared sensors 132 may be provided to a frame averager 804 that integrates multiple image frames to provide image frames 802 with an improved signal to noise ratio. Frame averager 804 may be effectively provided by infrared sensors 132, ROIC 402, and other components of infrared sensor assembly 128 that are implemented to support high image capture rates. For example, in one embodiment, infrared sensor assembly 128 may capture infrared image frames at a frame rate of 240 Hz (e.g., 240 images per second). In this embodiment, such a high frame rate may be implemented, for example, by operating infrared sensor assembly 128 at relatively low voltages (e.g., compatible with mobile telephone voltages) and by using a relatively small array of infrared sensors 132 (e.g., an array of 64 by 64 infrared sensors in one embodiment).
In one embodiment, such infrared image frames may be provided from infrared sensor assembly 128 to processing module 160 at a high frame rate (e.g., 240 Hz or other frame rates). In another embodiment, infrared sensor assembly 128 may integrate over longer time periods, or multiple time periods, to provide integrated (e.g., averaged) infrared image frames to processing module 160 at a lower frame rate (e.g., 30 Hz, 9 Hz, or other frame rates). Further information regarding implementations that may be used to provide high image capture rates may be found in U.S. Provisional Patent Application No. 61/495,879 previously referenced herein.
Image frames 802 proceed through pipeline 800 where they are adjusted by various terms, temporally filtered, used to determine the various adjustment terms, and gain compensated.
In blocks 810 and 814, factory gain terms 812 and factory offset terms 816 are applied to image frames 802 to compensate for gain and offset differences, respectively, between the various infrared sensors 132 and/or other components of infrared imaging module 100 determined during manufacturing and testing.
In block 580, NUC terms 817 are applied to image frames 802 to correct for FPN as discussed. In one embodiment, if NUC terms 817 have not yet been determined (e.g., before a NUC process has been initiated), then block 580 may not be performed or initialization values may be used for NUC terms 817 that result in no alteration to the image data (e.g., offsets for every pixel would be equal to zero).
In blocks 818 and 822, column FPN terms 820 and row FPN terms 824, respectively, are applied to image frames 802. Column FPN terms 820 and row FPN terms 824 may be determined in accordance with block 550 as discussed. In one embodiment, if the column FPN terms 820 and row FPN terms 824 have not yet been determined (e.g., before a NUC process has been initiated), then blocks 818 and 822 may not be performed or initialization values may be used for the column FPN terms 820 and row FPN terms 824 that result in no alteration to the image data (e.g., offsets for every pixel would be equal to zero).
In block 826, temporal filtering is performed on image frames 802 in accordance with a temporal noise reduction (TNR) process.
Differences between corresponding pixels of neighborhoods 803a and 803b are determined and averaged to provide an averaged delta value 805c for the location corresponding to pixels 805a and 805b. Averaged delta value 805c may be used to determine weight values in block 807 to be applied to pixels 805a and 805b of image frames 802a and 802b.
In one embodiment, as shown in graph 809, the weight values determined in block 807 may be inversely proportional to averaged delta value 805c such that weight values drop rapidly towards zero when there are large differences between neighborhoods 803a and 803b. In this regard, large differences between neighborhoods 803a and 803b may indicate that changes have occurred within the scene (e.g., due to motion) and pixels 802a and 802b may be appropriately weighted, in one embodiment, to avoid introducing blur across frame-to-frame scene changes. Other associations between weight values and averaged delta value 805c may be used in various embodiments.
The weight values determined in block 807 may be applied to pixels 805a and 805b to determine a value for corresponding pixel 805e of image frame 802e (block 811). In this regard, pixel 805e may have a value that is a weighted average (or other combination) of pixels 805a and 805b, depending on averaged delta value 805c and the weight values determined in block 807.
For example, pixel 805e of temporally filtered image frame 802e may be a weighted sum of pixels 805a and 805b of image frames 802a and 802b. If the average difference between pixels 805a and 805b is due to noise, then it may be expected that the average change between neighborhoods 805a and 805b will be close to zero (e.g., corresponding to the average of uncorrelated changes). Under such circumstances, it may be expected that the sum of the differences between neighborhoods 805a and 805b will be close to zero. In this case, pixel 805a of image frame 802a may both be appropriately weighted so as to contribute to the value of pixel 805e.
However, if the sum of such differences is not zero (e.g., even differing from zero by a small amount in one embodiment), then the changes may be interpreted as being attributed to motion instead of noise. Thus, motion may be detected based on the average change exhibited by neighborhoods 805a and 805b. Under these circumstances, pixel 805a of image frame 802a may be weighted heavily, while pixel 805b of image frame 802b may be weighted lightly.
Other embodiments are also contemplated. For example, although averaged delta value 805c has been described as being determined based on neighborhoods 805a and 805b, in other embodiments averaged delta value 805c may be determined based on any desired criteria (e.g., based on individual pixels or other types of groups of sets of pixels).
In the above embodiments, image frame 802a has been described as a presently received image frame and image frame 802b has been described as a previously temporally filtered image frame. In another embodiment, image frames 802a and 802b may be first and second image frames captured by infrared imaging module 100 that have not been temporally filtered.
Referring again to
In
As shown in
Referring again to
Also in
In view of the present disclosure, it will be appreciated that techniques described herein may be used to remove various types of FPN (e.g., including very high amplitude FPN) such as spatially correlated row and column FPN and spatially uncorrelated FPN.
Other embodiments are also contemplated. For example, in one embodiment, the rate at which row and column FPN terms and/or NUC terms are updated can be inversely proportional to the estimated amount of blur in the blurred image frame and/or inversely proportional to the magnitude of local contrast values (e.g., determined in block 560).
In various embodiments, the described techniques may provide advantages over conventional shutter-based noise correction techniques. For example, by using a shutterless process, a shutter (e.g., such as shutter 105) need not be provided, thus permitting reductions in size, weight, cost, and mechanical complexity. Power and maximum voltage supplied to, or generated by, infrared imaging module 100 may also be reduced if a shutter does not need to be mechanically operated. Reliability will be improved by removing the shutter as a potential point of failure. A shutterless process also eliminates potential image interruption caused by the temporary blockage of the imaged scene by a shutter.
Also, by correcting for noise using intentionally blurred image frames captured from a real world scene (not a uniform scene provided by a shutter), noise correction may be performed on image frames that have irradiance levels similar to those of the actual scene desired to be imaged. This can improve the accuracy and effectiveness of noise correction terms determined in accordance with the various described techniques.
Systems and methods disclosed herein, in accordance with one or more embodiments, provide image processing algorithms for images captured by infrared imaging systems. For example, in one embodiment, the infrared images may be processed to reduce noise within the infrared images (e.g., improve image detail and/or image quality). For one or more embodiments, processing techniques may be applied to reduce noise within a row and/or a column of the infrared image.
A significant portion of noise may be defined as row and column noise. This type of noise may be explained by non-linearities in a Read Out Integrated Circuit (ROIC). This type of noise, if not eliminated, may manifest as vertical and horizontal stripes in the final image and human observers are particularly sensitive to these types of image artifacts. Other systems relying on imagery from infrared sensors, such as, for example, automatic target trackers may also suffer from performance degradation, if row and column noise is present.
Because of non-linear behavior of infrared detectors and read-out integrated circuit (ROIC) assemblies, even when a shutter operation or external black body calibration is performed, there may be residual row and column noise (e.g., the scene being imaged may not have the exact same temperature as the shutter). The amount of row and column noise may increase over time, after offset calibration, increasing asymptotically to some maximum value. In one aspect, this may be referred to as 1/f type noise.
In any given frame, the row and column noise may be viewed as high frequency spatial noise. Conventionally, this type of noise may be reduced using filters in the spatial domain (e.g., local linear or non-linear low pass filters) or the frequency domain (e.g., low pass filters in Fourier or Wavelet space). However, these filters may have negative side effects, such as blurring of the image and potential loss of faint details.
It should be appreciated by those skilled in the art that any reference to a column or a row may include a partial column or a partial row and that the terms “row” and “column” are interchangeable and not limiting. Thus, without departing from the scope of the invention, the term “row” may be used to describe a row or a column, and likewise, the term “column” may be used to describe a row or a column, depending upon the application.
The system 1200 may represent an infrared imaging device, such as an infrared camera, to capture and process images, such as video images of a scene 1270. The system 1200 may represent any type of infrared camera adapted to detect infrared radiation and provide representative data and information (e.g., infrared image data of a scene). For example, the system 1200 may represent an infrared camera that is directed to the near, middle, and/or far infrared spectrums. In another example, the infrared image data may comprise non-uniform data (e.g., real image data that is not from a shutter or black body) of the scene 1270, for processing, as set forth herein. The system 1200 may comprise a portable device and may be incorporated, e.g., into a vehicle (e.g., an automobile or other type of land-based vehicle, an aircraft, or a spacecraft) or a non-mobile installation requiring infrared images to be stored and/or displayed.
In various embodiments, the processing component 1210 comprises a processor, such as one or more of a microprocessor, a single-core processor, a multi-core processor, a microcontroller, a logic device (e.g., a programmable logic device (PLD) configured to perform processing functions), a digital signal processing (DSP) device, etc. The processing component 1210 may be adapted to interface and communicate with components 1220, 1230, 1240, and 1250 to perform method and processing steps and/or operations, as described herein. The processing component 1210 may include a noise filtering module 1212 adapted to implement a noise reduction and/or removal algorithm (e.g., a noise filtering algorithm, such as discussed in reference to
It should be appreciated that noise filtering module 1212 may be integrated in software and/or hardware as part of the processing component 1210, with code (e.g., software or configuration data) for the noise filtering module 1212 stored, e.g., in the memory component 1220. Embodiments of the noise filtering algorithm, as disclosed herein, may be stored by a separate computer-readable medium (e.g., a memory, such as a hard drive, a compact disk, a digital video disk, or a flash memory) to be executed by a computer (e.g., a logic or processor-based system) to perform various methods and operations disclosed herein. In one aspect, the computer-readable medium may be portable and/or located separate from the system 1200, with the stored noise filtering algorithm provided to the system 1200 by coupling the computer-readable medium to the system 1200 and/or by the system 1200 downloading (e.g., via a wired link and/or a wireless link) the noise filtering algorithm from the computer-readable medium.
The memory component 1200 comprises, in one embodiment, one or more memory devices adapted to store data and information, including infrared data and information. The memory device 1220 may comprise one or more various types of memory devices including volatile and non-volatile memory devices, such as RAM (Random Access Memory), ROM (Read-Only Memory), EEPROM (Electrically-Erasable Read-Only Memory), flash memory, etc. The processing component 1210 may be adapted to execute software stored in the memory component 1220 so as to perform method and process steps and/or operations described herein.
The image capture component 1230 comprises, in one embodiment, one or more infrared sensors (e.g., any type of multi-pixel infrared detector, such as a focal plane array) for capturing infrared image data (e.g., still image data and/or video data) representative of an image, such as scene 1270. In one implementation, the infrared sensors of the image capture component 1230 provide for representing (e.g., converting) the captured image data as digital data (e.g., via an analog-to-digital converter included as part of the infrared sensor or separate from the infrared sensor as part of the system 1200). In one aspect, the infrared image data (e.g., infrared video data) may comprise non-uniform data (e.g., real image data) of an image, such as scene 1270. The processing component 1210 may be adapted to process the infrared image data (e.g., to provide processed image data), store the infrared image data in the memory component 1220, and/or retrieve stored infrared image data from the memory component 1220. For example, the processing component 1210 may be adapted to process infrared image data stored in the memory component 1220 to provide processed image data and information (e.g., captured and/or processed infrared image data).
The control component 1240 comprises, in one embodiment, a user input and/or interface device, such as a rotatable knob (e.g., potentiometer), push buttons, slide bar, keyboard, etc., that is adapted to generate a user input control signal. The processing component 1210 may be adapted to sense control input signals from a user via the control component 1240 and respond to any sensed control input signals received therefrom. The processing component 1210 may be adapted to interpret such a control input signal as a value, as generally understood by one skilled in the art.
In one embodiment, the control component 1240 may comprise a control unit (e.g., a wired or wireless handheld control unit) having push buttons adapted to interface with a user and receive user input control values. In one implementation, the push buttons of the control unit may be used to control various functions of the system 1200, such as autofocus, menu enable and selection, field of view, brightness, contrast, noise filtering, high pass filtering, low pass filtering, and/or various other features as understood by one skilled in the art. In another implementation, one or more of the push buttons may be used to provide input values (e.g., one or more noise filter values, adjustment parameters, characteristics, etc.) for a noise filter algorithm. For example, one or more push buttons may be used to adjust noise filtering characteristics of infrared images captured and/or processed by the system 1200.
The display component 1250 comprises, in one embodiment, an image display device (e.g., a liquid crystal display (LCD)) or various other types of generally known video displays or monitors. The processing component 1210 may be adapted to display image data and information on the display component 1250. The processing component 1210 may be adapted to retrieve image data and information from the memory component 1220 and display any retrieved image data and information on the display component 1250. The display component 1250 may comprise display electronics, which may be utilized by the processing component 1210 to display image data and information (e.g., infrared images). The display component 1250 may be adapted to receive image data and information directly from the image capture component 1230 via the processing component 1210, or the image data and information may be transferred from the memory component 1220 via the processing component 1210.
The optional sensing component 1260 comprises, in one embodiment, one or more sensors of various types, depending on the application or implementation requirements, as would be understood by one skilled in the art. The sensors of the optional sensing component 1260 provide data and/or information to at least the processing component 1210. In one aspect, the processing component 1210 may be adapted to communicate with the sensing component 1260 (e.g., by receiving sensor information from the sensing component 1260) and with the image capture component 1230 (e.g., by receiving data and information from the image capture component 1230 and providing and/or receiving command, control, and/or other information to and/or from one or more other components of the system 1200).
In various implementations, the sensing component 1260 may provide information regarding environmental conditions, such as outside temperature, lighting conditions (e.g., day, night, dusk, and/or dawn), humidity level, specific weather conditions (e.g., sun, rain, and/or snow), distance (e.g., laser rangefinder), and/or whether a tunnel or other type of enclosure has been entered or exited. The sensing component 1260 may represent conventional sensors as generally known by one skilled in the art for monitoring various conditions (e.g., environmental conditions) that may have an effect (e.g., on the image appearance) on the data provided by the image capture component 1230.
In some implementations, the optional sensing component 1260 (e.g., one or more of sensors) may comprise devices that relay information to the processing component 1210 via wired and/or wireless communication. For example, the optional sensing component 1260 may be adapted to receive information from a satellite, through a local broadcast (e.g., radio frequency (RF)) transmission, through a mobile or cellular network and/or through information beacons in an infrastructure (e.g., a transportation or highway information beacon infrastructure), or various other wired and/or wireless techniques.
In various embodiments, components of the system 1200 may be combined and/or implemented or not, as desired or depending on the application or requirements, with the system 1200 representing various functional blocks of a related system. In one example, the processing component 1210 may be combined with the memory component 1220, the image capture component 1230, the display component 1250, and/or the optional sensing component 1260. In another example, the processing component 1210 may be combined with the image capture component 1230 with only certain functions of the processing component 1210 performed by circuitry (e.g., a processor, a microprocessor, a logic device, a microcontroller, etc.) within the image capture component 1230. Furthermore, various components of the system 1200 may be remote from each other (e.g., image capture component 1230 may comprise a remote sensor with processing component 1210, etc. representing a computer that may or may not be in communication with the image capture component 1230).
In accordance with an embodiment of the invention,
In one embodiment, the method 1320 of
Referring to
Referring to method 1320 of
Referring to the processing portion (e.g., recursive processing) of
Referring to the column noise filter portion 1301a, the method 1320 may be adapted to process the input video data 1300 and/or output video data 1319 as follows:
1. Apply previous column noise correction terms to a current frame as calculated in a previous frame (block 1301).
2. High pass filter the row of the current frame by subtracting the result of a low pass filter (LPF) operation (block 1308), for example, as discussed in reference to
3. For each pixel, calculate a difference between a center pixel and one or more (e.g., eight) nearest neighbors (block 1314). In one implementation, the nearest neighbors comprise one or more nearest horizontal neighbors. The nearest neighbors may include one or more vertical or other non-horizontal neighbors (e.g., not pure horizontal, i.e., on the same row), without departing from the scope of the invention.
4. If the calculated difference is below a predefined threshold, add the calculated difference to a histogram of differences for the specific column (block 1309).
5. At an end of the current frame, find a median difference by examining a cumulative histogram of differences (block 1310). In one aspect, for added robustness, only differences with some specified minimum number of occurrences may be used.
6. Delay the current correction terms for one frame (block 1311), i.e., they are applied to the next frame.
7. Add median difference (block 1312) to previous column correction terms to provide updated column correction terms (block 1313).
8. Apply updated column noise correction terms in the next frame (block 1301).
Referring to the row noise filter portion 1302a, the method 1320 may be adapted to process the input video data 1300 and/or output video data 1319 as follows:
1. Apply previous row noise correction terms to a current frame as calculated in a previous frame (block 1302).
2. High pass filter the column of the current frame by subtracting the result of a low pass filter (LPF) operation (block 1308), as discussed similarly above for column noise filter portion 1301a.
3. For each pixel, calculate a difference between a center pixel and one or more (e.g., eight) nearest neighbors (block 1315). In one implementation, the nearest neighbors comprise one or more nearest vertical neighbors. The nearest neighbors may include one or more horizontal or other non-vertical neighbors (e.g., not pure vertical, i.e., on the same column), without departing from the scope of the invention.
4. If the calculated difference is below a predefined threshold, add the calculated difference to a histogram of differences for the specific row (block 1307).
5. At an end of the current row (e.g., line), find a median difference by examining a cumulative histogram of differences (block 1306). In one aspect, for added robustness only differences with some specified minimum number of occurrences may be used.
6. Delay the current frame by a time period equivalent to the number of nearest vertical neighbors used, for example eight.
7. Add median difference (block 1304) to row correction terms (block 1303) from previous frame (block 1305).
8. Apply updated row noise correction terms in the current frame (block 1302). In one aspect, this may require a row buffer (e.g., as mentioned in 6).
In one aspect, for all pixels (or at least a large subset of them) in each column, an identical offset term (or set of terms) may be applied for each associated column. This may prevent the filter from blurring spatially local details.
Similarly, in one aspect, for all pixels (or at least a large subset of them) in each row respectively, an identical offset term (or set of terms) may be applied. This may inhibit the filter from blurring spatially local details.
In one example, an estimate of the column offset terms may be calculated using only a subset of the rows (e.g., the first 32 rows). In this case, only a 32 row delay is needed to apply the column correction terms in the current frame. This may improve filter performance in removing high temporal frequency column noise. Alternatively, the filter may be designed with minimum delay, and the correction terms are only applied once a reasonable estimate can be calculated (e.g., using data from the 32 rows). In this case, only rows 33 and beyond may be optimally filtered.
In one aspect, all samples may not be needed, and in such an instance, only every 2nd or 4th row, e.g., may be used for calculating the column noise. In another aspect, the same may apply when calculating row noise, and in such an instance, only data from every 4th column, e.g., may be used. It should be appreciated that various other iterations may be used by one skilled in the art without departing from the scope of the invention.
In one aspect, the filter may operate in recursive mode in which the filtered data is filtered instead of the raw data being filtered. In another aspect, the mean difference between a pixel in one row and pixels in neighboring rows may be approximated in an efficient way if a recursive (IIR) filter is used to calculate an estimated running mean. For example, instead of taking the mean of neighbor differences (e.g., eight neighbor differences), the difference between a pixel and the mean of the neighbors may be calculated.
In accordance with an embodiment of the invention,
In still other alternate approaches to methods 1320 and 1330, embodiments may exclude the histograms and rely on mean calculated differences instead of median calculated differences. In one aspect, this may be slightly less robust but may allow for a simpler implementation of the column and row noise filters. For example, the mean of neighboring rows and columns, respectively, may be approximated by a running mean implemented as an infinite impulse response (IIR) filter. In the row noise case, the IIR filter implementation may reduce or even eliminate the need to buffer several rows of data for mean calculations.
In still other alternate approaches to methods 1320 and 1330, new noise estimates may be calculated in each frame of the video data and only applied in the next frame (e.g., after noise estimates). In one aspect, this alternate approach may provide less performance but may be easier to implement. In another aspect, this alternate approach may be referred to as a non-recursive method, as understood by those skilled in the art.
For example, in one embodiment, the method 1340 of
Referring to
In one aspect of the invention, the column and row noise filter algorithm may operate continuously on image data provided by an infrared imaging sensor (e.g., image capture component 1230 of
For one or more embodiments, by first taking out one or more low spatial frequencies (e.g., using a high pass filter (HPF)), the scene contribution may be minimized to leave differences that correlate highly with actual row and column spatial noise. In one aspect, by using an edge preserving filter, such as a Median filter or a Bilateral filter, one or more embodiments may minimize artifacts due to strong edges in the image.
In accordance with one or more embodiments of the invention,
In one aspect of the invention, a final estimate of column and/or row noise may be referred to as an average or median estimate of all of the measured differences. Because noise characteristics of an infrared sensor are often generally known, then one or more thresholds may be applied to the noise estimates. For example, if a difference of 60 digital counts is measured, but it is known that the noise typically is less than 10 digital counts, then this measurement may be ignored.
In accordance with one or more embodiments of the invention,
In accordance with one or more embodiments of the invention,
In one embodiment,
In various embodiments, it should be understood that both row and column filtering is not required. For example, either column noise filtering 1301a or row noise filtering 1302a may be performed in methods 1320, 1330 or 1340.
It should be appreciated that any reference to a column or a row may include a partial column or a partial row and that the terms “row” and “column” are interchangeable and not limiting. For example, without departing from the scope of the invention, the term “row” may be used to describe a row or a column, and likewise, the term “column” may be used to describe a row or a column, depending upon the application.
In various aspects, column and row noise may be estimated by looking at a real scene (e.g., not a shutter or a black body), in accordance with embodiments of the noise filtering algorithms, as disclosed herein. The column and row noise may be estimated by measuring the median or mean difference between sensor readings from elements in a specific row (and/or column) and sensor readings from adjacent rows (and/or columns).
Optionally, a high pass filter may be applied to the image data prior to measuring the differences, which may reduce or at least minimize a risk of distorting gradients that are part of the scene and/or introducing artifacts. In one aspect, only sensor readings that differ by less than a configurable threshold may be used in the mean or median estimation. Optionally, a histogram may be used to effectively estimate the median. Optionally, only histogram bins exceeding a minimum count may be used when finding the median estimate from the histogram. Optionally, a recursive IIR filter may be used to estimate the difference between a pixel and its neighbors, which may reduce or at least minimize the need to store image data for processing, e.g., the row noise portion (e.g., if image data is read out row wise from the sensor). In one implementation, the current mean column value
In this equation α is the damping factor and may be set to for example 0.2 in which case the estimate for the running mean of a specific column i at row j will be a weighted sum of the estimated running mean for column i−1 at row j and the current pixel value at row j and column i. The estimated difference between values of row j and the values of neighboring rows (ΔRi) can now be approximated by taking the difference of each value Ci,j and the running recursive mean of the neighbors above row i (
In one embodiment, referring to
Generally, during processing, a recursive filter re-uses at least a portion of the output data as input data. The feedback input of the recursive filter may be referred to as an infinite impulse response (IIR), which may be characterized, e.g., by exponentially growing output data, exponentially decaying output data, or sinusoidal output data. In some implementations, a recursive filter may not have an infinite impulse response. As such, e.g., some implementations of a moving average filter function as recursive filters but with a finite impulse response (FIR).
In various embodiments, an infrared imaging system may be implemented with an infrared sensor array that is fixably positioned to substantially de-align rows and columns of infrared sensors while a thermal image frame is captured of a scene. For example, in some embodiments, the infrared sensor array may be fixably positioned in a rotated orientation relative to the scene (e.g., rotated relative to the housing and/or rotated about an optical axis of the infrared imaging system). De-alignment of the infrared sensor array may prevent the rows and columns of infrared sensors from being substantially parallel with one or more substantially horizontal and/or substantially vertical features of the scene. As a result, such features of the scene may be imaged across several different rows and columns of the infrared sensors and may not be generally aligned with rows and columns of pixels of the captured thermal image frame.
Such de-aligned orientations of the infrared sensor array may result in fewer row and column noise artifacts exhibited in captured thermal image frames of scenes including substantially horizontal and/or substantially vertical features. Moreover, such de-aligned orientations may prevent the imaged features from aligning with row and column noise and/or image artifacts that may result from noise reduction techniques applied to such row and column noise.
In some embodiments, an infrared imaging system may be expected to be used in one or more particular physical orientations. For example, for a handheld infrared imaging system, an expected physical orientation may be a comfortable position in which the imaging system is usually held by a user. In another embodiment, for a mounted infrared imaging system, an expected physical orientation may be a position in which the infrared imaging system is usually mounted. In these and similar embodiments, while the infrared imaging system is positioned in an expected physical orientation, rows and columns of the infrared sensor array may be de-aligned from horizontal and vertical features of the scene as discussed. In some embodiments, the expected physical orientation may be a physical orientation in which the housing or other components of the imaging system are generally parallel to a first reference plane (e.g., a plane generally parallel to the ground) and the infrared sensor array may be generally parallel to and facing a second reference plane (e.g., a plane corresponding to a view of the scene as perceived by the infrared sensor array). Other orientations are also contemplated.
As shown in
In some embodiments, infrared sensor array 1730 may be de-aligned relative to one or more surfaces of housing 1710. For example, in the particular embodiment illustrated in
In the embodiments shown in
In some embodiments, infrared sensor array 1730 may be de-aligned based on a rotational offset. For example, infrared sensor array 1730 may include an optical axis 1740 along which infrared radiation is received. While mounted within housing 1710, infrared sensor array 1730 may be rotationally offset (e.g., by angle A) about optical axis 1740. Accordingly, while infrared imaging system 1700 is positioned in an expected physical orientation, infrared sensor array 1730 may be rotationally offset within an X-Y plane (e.g., corresponding to the X and Y axes) relative to housing 1710, scene 1750, and/or other aspects.
In some embodiments, imaging system 1700 may include one or more optical components 1720 substantially aligned with optical axis 1740. In one embodiment, image capture component 1730 may be disposed within housing 1710 and behind optical components 1720 such that electromagnetic radiation from scene 1750 passes through optical components 1720 before being received by image capture component 1710.
In some embodiments, various portions of infrared imaging system 1700 may be implemented by components previously described herein. For example, infrared imaging system 1700 may include any components of infrared imaging module 100, host device 102, system 1200, and/or other components as may be desired in particular implementations.
In one embodiment, infrared imaging system 1700 may be implemented by infrared imaging module 100. For example, infrared sensors 1722 and infrared sensor array 1730 may be implemented by infrared sensors 132 of infrared sensor assembly 128, optical component 1720 may be implemented by optical element 180, and housing 1710 may be implemented by housing 120, socket 104, and/or host device 102. In such an embodiment, infrared imaging system 1700 may be implemented with one or more processing devices such as, for example, processing module 160, processor 195, and/or other devices to perform various operations described herein. Also in such an embodiment, infrared imaging system 1700 may be implemented with one or more memories such as, for example, memory 196 and/or other memories. Other embodiments using various components of imaging module 100 are also contemplated.
In another embodiment, infrared imaging system 1700 may be implemented by system 1200. For example, infrared sensors 1722 and infrared sensor array 1730 may be implemented by image capture component 1230. In such an embodiment, infrared imaging system 1700 may be implemented with one or more processing devices such as, for example, processing component 1210 and/or other devices to perform various operations described herein. Also in such an embodiment, infrared imaging system 1700 may be implemented with one or more memories such as, for example, memory component 1220 and/or other memories. Other embodiments using various components of system 1200 are also contemplated.
At block 1920, a particular scene 1750 to be imaged is selected. In one embodiment, such selection may be performed by a user of infrared imaging system 1700. In another embodiment, such selection may be performed by infrared imaging system 1700 itself (e.g., through appropriate selection processes performed by one or more processing devices).
At block 1930, infrared imaging system 1700 is positioned relative to scene 1750. In one embodiment, such positioning may be performed by a user of infrared imaging system 1700. In another embodiment, such positioning may be performed by infrared imaging system 1700 itself (e.g., through operation of appropriate actuators and/or other mechanisms).
At block 1940, infrared imaging system 1700 captures a thermal image frame of scene 1750. While the thermal image frame is captured in block 1940, rows 1732 and columns 1734 of infrared sensors 1722 of infrared sensor array 1730 are substantially de-aligned from substantially horizontal features (e.g., substantially horizontal feature 1782) and substantially vertical features (e.g., substantially vertical feature 1784) of scene 1750 as discussed.
For example,
At block 1950, row and column noise correction processing is performed on thermal image frame 2000 in accordance with the various techniques described herein. At block 1960, scene based NUC processing is performed on thermal image frame 2000 in accordance with the various techniques described herein.
At block 1970, further processing may be performed on thermal image frame 2000 as may be desired in particular implementations. For example, thermal image frame 2000 may be processed to provide a cropped thermal image frame 2100 as shown in
In view of the present disclosure, it will be appreciated that the use of de-aligned infrared sensor array 1730 permits thermal image frame 2000 and cropped thermal image frame 2100 to exhibit improvements over images captured with conventionally aligned sensors. For example, because thermal image frame 2100 was captured by de-aligned rows 1732 and columns 1734 of infrared sensor array 1730, thermal image frame 2100 and cropped thermal image frame 2100 may exhibit fewer row and column noise artifacts associated with features 1782 and 1784. In addition, any possible artifacts resulting from noise reduction operations (e.g., row and column noise correction processing of block 1950 and/or other noise reduction operations) will not be aligned with features 1782 and 1784 in thermal image frame 2100 and cropped thermal image frame 2100.
Where applicable, various embodiments provided by the present disclosure can be implemented using hardware, software, or combinations of hardware and software. Also where applicable, the various hardware components and/or software components set forth herein can be combined into composite components comprising software, hardware, and/or both without departing from the spirit of the present disclosure. Where applicable, the various hardware components and/or software components set forth herein can be separated into sub-components comprising software, hardware, or both without departing from the spirit of the present disclosure. In addition, where applicable, it is contemplated that software components can be implemented as hardware components, and vice-versa.
Software in accordance with the present disclosure, such as non-transitory instructions, program code, and/or data, can be stored on one or more non-transitory machine readable mediums. It is also contemplated that software identified herein can be implemented using one or more general purpose or specific purpose computers and/or computer systems, networked and/or otherwise. Where applicable, the ordering of various steps described herein can be changed, combined into composite steps, and/or separated into sub-steps to provide features described herein.
Embodiments described above illustrate but do not limit the invention. It should also be understood that numerous modifications and variations are possible in accordance with the principles of the invention. Accordingly, the scope of the invention is defined only by the following claims.
This patent application claims priority to and the benefit of U.S. Provisional Patent Application No. 61/646,781 filed May 14, 2012 and entitled “THERMAL IMAGE FRAME CAPTURE USING DE-ALIGNED SENSOR ARRAY,” which is incorporated herein by reference in its entirety. This patent application is a continuation-in-part of International Patent Application No. PCT/US2012/041744 filed Jun. 8, 2012 and entitled “LOW POWER AND SMALL FORM FACTOR INFRARED IMAGING,” which is incorporated herein by reference in its entirety. International Patent Application No. PCT/US2012/041744 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/656,889 filed Jun. 7, 2012 and entitled “LOW POWER AND SMALL FORM FACTOR INFRARED IMAGING,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041744 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/545,056 filed Oct. 7, 2011 and entitled “NON-UNIFORMITY CORRECTION TECHNIQUES FOR INFRARED IMAGING DEVICES,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041744 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,873 filed Jun. 10, 2011 and entitled “INFRARED CAMERA PACKAGING SYSTEMS AND METHODS,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041744 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,879 filed Jun. 10, 2011 and entitled “INFRARED CAMERA SYSTEM ARCHITECTURES,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041744 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,888 filed Jun. 10, 2011 and entitled “INFRARED CAMERA CALIBRATION TECHNIQUES,” which are incorporated herein by reference in their entirety. This patent application is a continuation-in-part of International Patent Application No. PCT/US2012/041749 filed Jun. 8, 2012 and entitled “NON-UNIFORMITY CORRECTION TECHNIQUES FOR INFRARED IMAGING DEVICES,” which is incorporated herein by reference in its entirety. International Patent Application No. PCT/US2012/041749 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/545,056 filed Oct. 7, 2011 and entitled “NON-UNIFORMITY CORRECTION TECHNIQUES FOR INFRARED IMAGING DEVICES,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041749 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,873 filed Jun. 10, 2011 and entitled “INFRARED CAMERA PACKAGING SYSTEMS AND METHODS,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041749 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,879 filed Jun. 10, 2011 and entitled “INFRARED CAMERA SYSTEM ARCHITECTURES,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041749 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,888 filed Jun. 10, 2011 and entitled “INFRARED CAMERA CALIBRATION TECHNIQUES,” which are incorporated herein by reference in their entirety. This patent application is a continuation-in-part of International Patent Application No. PCT/US2012/041739 filed Jun. 8, 2012 and entitled “INFRARED CAMERA SYSTEM ARCHITECTURES,” which is hereby incorporated by reference in its entirety. International Patent Application No. PCT/US2012/041739 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,873 filed Jun. 10, 2011 and entitled “INFRARED CAMERA PACKAGING SYSTEMS AND METHODS,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041739 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,879 filed Jun. 10, 2011 and entitled “INFRARED CAMERA SYSTEM ARCHITECTURES,” which are incorporated herein by reference in their entirety. International Patent Application No. PCT/US2012/041739 claims priority to and the benefit of U.S. Provisional Patent Application No. 61/495,888 filed Jun. 10, 2011 and entitled “INFRARED CAMERA CALIBRATION TECHNIQUES,” which are incorporated herein by reference in their entirety. This patent application is a continuation-in-part of U.S. patent application Ser. No. 13/622,178 filed Sep. 18, 2012 and entitled “SYSTEMS AND METHODS FOR PROCESSING INFRARED IMAGES,” which is a continuation-in-part of U.S. patent application Ser. No. 13/529,772 filed Jun. 21, 2012 and entitled “SYSTEMS AND METHODS FOR PROCESSING INFRARED IMAGES,” which is a continuation of U.S. patent application Ser. No. 12/396,340 filed Mar. 2, 2009 and entitled “SYSTEMS AND METHODS FOR PROCESSING INFRARED IMAGES,” which are incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
2764055 | Clemens et al. | Sep 1956 | A |
5258621 | Noble | Nov 1993 | A |
5394520 | Hall | Feb 1995 | A |
5541414 | Hori | Jul 1996 | A |
5561460 | Katoh | Oct 1996 | A |
5654549 | Landecker et al. | Aug 1997 | A |
5717208 | Woolaway, II | Feb 1998 | A |
5721427 | White et al. | Feb 1998 | A |
5881182 | Fiete et al. | Mar 1999 | A |
5903659 | Kilgore | May 1999 | A |
5960097 | Pfeiffer | Sep 1999 | A |
6297794 | Tsubouchi et al. | Oct 2001 | B1 |
6330371 | Chen | Dec 2001 | B1 |
6348951 | Kim | Feb 2002 | B1 |
6373522 | Mathews | Apr 2002 | B2 |
6396543 | Shin et al. | May 2002 | B1 |
6424843 | Reitmaa et al. | Jul 2002 | B1 |
6583416 | Villani | Jun 2003 | B1 |
6633231 | Okamoto et al. | Oct 2003 | B1 |
6642497 | Apostolopoulos | Nov 2003 | B1 |
6681120 | Kim | Jan 2004 | B1 |
6759949 | Miyahara | Jul 2004 | B2 |
6883054 | Yamaguchi et al. | Apr 2005 | B2 |
6911652 | Walkenstein | Jun 2005 | B2 |
7050107 | Frank et al. | May 2006 | B1 |
D524785 | Huang | Jul 2006 | S |
7084857 | Lieberman et al. | Aug 2006 | B2 |
7132648 | Ratiff | Nov 2006 | B2 |
7208733 | Mian et al. | Apr 2007 | B2 |
7263379 | Parkulo et al. | Aug 2007 | B1 |
7279675 | Cohen | Oct 2007 | B2 |
7284921 | Lapstun et al. | Oct 2007 | B2 |
7294817 | Voigt | Nov 2007 | B2 |
7296747 | Rohs | Nov 2007 | B2 |
7305368 | Lieberman et al. | Dec 2007 | B2 |
7321783 | Kim | Jan 2008 | B2 |
7333832 | Tsai et al. | Feb 2008 | B2 |
7377835 | Parkulo et al. | May 2008 | B2 |
7420663 | Wang et al. | Sep 2008 | B2 |
7453064 | Lee | Nov 2008 | B2 |
7477309 | Cuccias | Jan 2009 | B2 |
7566942 | Viens et al. | Jul 2009 | B2 |
7567818 | Pylkko | Jul 2009 | B2 |
7572077 | Lapstun et al. | Aug 2009 | B2 |
7575077 | Priepke et al. | Aug 2009 | B2 |
7595904 | Lapstun et al. | Sep 2009 | B2 |
7616877 | Zarnowski | Nov 2009 | B2 |
7627364 | Sato | Dec 2009 | B2 |
7697962 | Cradick et al. | Apr 2010 | B2 |
7723686 | Hannebauer | May 2010 | B2 |
7725141 | Su | May 2010 | B2 |
7728281 | Chen | Jun 2010 | B2 |
7735974 | Silverbrook et al. | Jun 2010 | B2 |
7747454 | Bartfeld et al. | Jun 2010 | B2 |
7760919 | Namgoong | Jul 2010 | B2 |
7761114 | Silverbrook et al. | Jul 2010 | B2 |
7772557 | Anderson | Aug 2010 | B2 |
7773870 | Naruse | Aug 2010 | B2 |
7801733 | Lee et al. | Sep 2010 | B2 |
7805020 | Trudeau et al. | Sep 2010 | B2 |
7810733 | Silverbrook et al. | Oct 2010 | B2 |
7872574 | Betts et al. | Jan 2011 | B2 |
7880777 | Anderson | Feb 2011 | B2 |
7900842 | Silverbrook et al. | Mar 2011 | B2 |
7903152 | Kim | Mar 2011 | B2 |
7947222 | Bae et al. | May 2011 | B2 |
7960700 | Craig et al. | Jun 2011 | B2 |
8189050 | Hughes et al. | May 2012 | B1 |
8189938 | Hohenberger | May 2012 | B2 |
8203116 | Young | Jun 2012 | B2 |
8208026 | Högasten et al. | Jun 2012 | B2 |
8275413 | Fraden et al. | Sep 2012 | B1 |
8305577 | Kivioja et al. | Nov 2012 | B2 |
8345226 | Zhang | Jan 2013 | B2 |
8378290 | Speake | Feb 2013 | B1 |
8537343 | Zhang | Sep 2013 | B2 |
8781420 | Schlub et al. | Jul 2014 | B2 |
8825112 | Fraden et al. | Sep 2014 | B1 |
20020006337 | Kimura et al. | Jan 2002 | A1 |
20020058352 | Jacksen | May 2002 | A1 |
20020122036 | Sasaki | Sep 2002 | A1 |
20020135571 | Klocek et al. | Sep 2002 | A1 |
20020140542 | Prokoski et al. | Oct 2002 | A1 |
20020149600 | Van Splunter et al. | Oct 2002 | A1 |
20030007193 | Sato et al. | Jan 2003 | A1 |
20030093805 | Gin | May 2003 | A1 |
20030112871 | Demos | Jun 2003 | A1 |
20030122957 | Emme | Jul 2003 | A1 |
20030146975 | Joung et al. | Aug 2003 | A1 |
20030198400 | Alderson et al. | Oct 2003 | A1 |
20030223623 | Gutta et al. | Dec 2003 | A1 |
20040047518 | Tiana | Mar 2004 | A1 |
20040101298 | Mandelbaum et al. | May 2004 | A1 |
20040127156 | Park | Jul 2004 | A1 |
20040128070 | Schmidt et al. | Jul 2004 | A1 |
20040157612 | Kim | Aug 2004 | A1 |
20040165788 | Perez et al. | Aug 2004 | A1 |
20040169860 | Jung et al. | Sep 2004 | A1 |
20040207036 | Ikeda | Oct 2004 | A1 |
20040256561 | Beuhler et al. | Dec 2004 | A1 |
20050030314 | Dawson | Feb 2005 | A1 |
20050067852 | Jeong | Mar 2005 | A1 |
20050068333 | Nakahashi et al. | Mar 2005 | A1 |
20050068517 | Evans | Mar 2005 | A1 |
20050089241 | Kawanishi et al. | Apr 2005 | A1 |
20050093890 | Baudisch | May 2005 | A1 |
20050110803 | Sugimura | May 2005 | A1 |
20050138569 | Baxter et al. | Jun 2005 | A1 |
20050157942 | Chen | Jul 2005 | A1 |
20050169655 | Koyama et al. | Aug 2005 | A1 |
20050184993 | Ludwin et al. | Aug 2005 | A1 |
20050213813 | Lin et al. | Sep 2005 | A1 |
20050213853 | Maier et al. | Sep 2005 | A1 |
20050219249 | Xie et al. | Oct 2005 | A1 |
20050247867 | Volgt | Nov 2005 | A1 |
20050248912 | Kang et al. | Nov 2005 | A1 |
20050265688 | Kobayashi | Dec 2005 | A1 |
20050270784 | Hahn et al. | Dec 2005 | A1 |
20050277447 | Buil et al. | Dec 2005 | A1 |
20060039686 | Soh et al. | Feb 2006 | A1 |
20060060984 | Wakabayashi et al. | Mar 2006 | A1 |
20060077246 | Kawakami et al. | Apr 2006 | A1 |
20060097172 | Park | May 2006 | A1 |
20060120712 | Kim | Jun 2006 | A1 |
20060132642 | Hosaka et al. | Jun 2006 | A1 |
20060140501 | Tadas | Jun 2006 | A1 |
20060147191 | Kim | Jul 2006 | A1 |
20060154559 | Yoshida | Jul 2006 | A1 |
20060210249 | Seto | Sep 2006 | A1 |
20060234744 | Sung et al. | Oct 2006 | A1 |
20060240867 | Wang et al. | Oct 2006 | A1 |
20060256226 | Alon | Nov 2006 | A1 |
20060262210 | Smith et al. | Nov 2006 | A1 |
20060279632 | Anderson | Dec 2006 | A1 |
20060279758 | Myoki | Dec 2006 | A1 |
20060285907 | Kang et al. | Dec 2006 | A1 |
20070004449 | Sham | Jan 2007 | A1 |
20070019077 | Park | Jan 2007 | A1 |
20070019099 | Lieberman et al. | Jan 2007 | A1 |
20070019103 | Lieberman et al. | Jan 2007 | A1 |
20070033309 | Kuwabara et al. | Feb 2007 | A1 |
20070034800 | Huang | Feb 2007 | A1 |
20070052616 | Yoon | Mar 2007 | A1 |
20070057764 | Sato et al. | Mar 2007 | A1 |
20070103479 | Kim et al. | May 2007 | A1 |
20070120879 | Kanade et al. | May 2007 | A1 |
20070132858 | Chiba et al. | Jun 2007 | A1 |
20070139739 | Kim et al. | Jun 2007 | A1 |
20070159524 | Kim et al. | Jul 2007 | A1 |
20070189583 | Shimada et al. | Aug 2007 | A1 |
20070211965 | Helbing et al. | Sep 2007 | A1 |
20070216786 | Hung et al. | Sep 2007 | A1 |
20070222798 | Kuno | Sep 2007 | A1 |
20070247611 | Tamaki et al. | Oct 2007 | A1 |
20070248284 | Bernsen et al. | Oct 2007 | A1 |
20070274541 | Uetake et al. | Nov 2007 | A1 |
20070285439 | King et al. | Dec 2007 | A1 |
20070286517 | Paik et al. | Dec 2007 | A1 |
20070296838 | Erdtmann | Dec 2007 | A1 |
20070299226 | Park et al. | Dec 2007 | A1 |
20080038579 | Schuisky et al. | Feb 2008 | A1 |
20080056606 | Kilgore | Mar 2008 | A1 |
20080056612 | Park et al. | Mar 2008 | A1 |
20080079834 | Chung et al. | Apr 2008 | A1 |
20080095212 | Jonnalagadda | Apr 2008 | A1 |
20080112012 | Yokoyama et al. | May 2008 | A1 |
20080112594 | Williams | May 2008 | A1 |
20080151056 | Ahamefula | Jun 2008 | A1 |
20080165190 | Min et al. | Jul 2008 | A1 |
20080165342 | Yoshida et al. | Jul 2008 | A1 |
20080165359 | Mattox | Jul 2008 | A1 |
20080170082 | Kim | Jul 2008 | A1 |
20080211916 | Ono | Sep 2008 | A1 |
20080218474 | Ahn et al. | Sep 2008 | A1 |
20080248833 | Silverbrook et al. | Oct 2008 | A1 |
20080259181 | Yamashita | Oct 2008 | A1 |
20080266079 | Lontka | Oct 2008 | A1 |
20080278772 | Silverbrook et al. | Nov 2008 | A1 |
20080284880 | Numata | Nov 2008 | A1 |
20080292144 | Kim | Nov 2008 | A1 |
20080297614 | Lieberman et al. | Dec 2008 | A1 |
20080316350 | Gottwald | Dec 2008 | A1 |
20090023421 | Parkulo et al. | Jan 2009 | A1 |
20090027525 | Lin et al. | Jan 2009 | A1 |
20090040042 | Lontka | Feb 2009 | A1 |
20090040195 | Njolstad et al. | Feb 2009 | A1 |
20090052883 | Lee et al. | Feb 2009 | A1 |
20090129700 | Rother et al. | May 2009 | A1 |
20090131104 | Yoon | May 2009 | A1 |
20090141124 | Liu et al. | Jun 2009 | A1 |
20090148019 | Hamada et al. | Jun 2009 | A1 |
20090160951 | Anderson | Jun 2009 | A1 |
20090213110 | Kato et al. | Aug 2009 | A1 |
20090215479 | Karmarkar | Aug 2009 | A1 |
20090227287 | Kotidis | Sep 2009 | A1 |
20090238238 | Hollander et al. | Sep 2009 | A1 |
20090257679 | Högasten | Oct 2009 | A1 |
20090278048 | Choe et al. | Nov 2009 | A1 |
20090297062 | Molne et al. | Dec 2009 | A1 |
20090303363 | Blessinger | Dec 2009 | A1 |
20100013979 | Golub | Jan 2010 | A1 |
20100020229 | Hershey et al. | Jan 2010 | A1 |
20100045809 | Packard | Feb 2010 | A1 |
20100066866 | Lim | Mar 2010 | A1 |
20100090965 | Birkler | Apr 2010 | A1 |
20100090983 | Challener et al. | Apr 2010 | A1 |
20100103141 | Challener et al. | Apr 2010 | A1 |
20100113068 | Rothschild | May 2010 | A1 |
20100131268 | Moeller | May 2010 | A1 |
20100144387 | Chou | Jun 2010 | A1 |
20100163730 | Schmidt et al. | Jul 2010 | A1 |
20100165122 | Castorina et al. | Jul 2010 | A1 |
20100220193 | Hogasten et al. | Sep 2010 | A1 |
20100234067 | Silverbrook et al. | Sep 2010 | A1 |
20100245582 | Harel | Sep 2010 | A1 |
20100245585 | Fisher et al. | Sep 2010 | A1 |
20100245826 | Lee | Sep 2010 | A1 |
20100314543 | Lee et al. | Dec 2010 | A1 |
20100329583 | Whiteside et al. | Dec 2010 | A1 |
20110043486 | Hagiwara et al. | Feb 2011 | A1 |
20110063446 | McMordie et al. | Mar 2011 | A1 |
20110102599 | Kwon et al. | May 2011 | A1 |
20110115793 | Grycewicz | May 2011 | A1 |
20110117532 | Relyea et al. | May 2011 | A1 |
20110121178 | Strandemar | May 2011 | A1 |
20110121978 | Schwörer et al. | May 2011 | A1 |
20110122075 | Seo et al. | May 2011 | A1 |
20110128384 | Tiscareno et al. | Jun 2011 | A1 |
20120007987 | Gaber | Jan 2012 | A1 |
20120083314 | Ng et al. | Apr 2012 | A1 |
20120091340 | Young | Apr 2012 | A1 |
20120184252 | Hirsch | Jul 2012 | A1 |
20120200766 | Hjelmstrom | Aug 2012 | A1 |
20120211648 | Linsacum et al. | Aug 2012 | A1 |
20120229650 | Matthews | Sep 2012 | A1 |
20120273688 | Tsai et al. | Nov 2012 | A1 |
20120274814 | Wajs | Nov 2012 | A1 |
20120276954 | Kowalsky | Nov 2012 | A1 |
20120292518 | Goldstein | Nov 2012 | A1 |
20120320086 | Kasama et al. | Dec 2012 | A1 |
20130204570 | Mendelson et al. | Aug 2013 | A1 |
20130307991 | Olsen | Nov 2013 | A1 |
20130320220 | Donowsky | Dec 2013 | A1 |
Number | Date | Country |
---|---|---|
2764055 | Jul 2012 | CA |
1917590 | Feb 2007 | CN |
2874947 | Feb 2007 | CN |
2899321 | May 2007 | CN |
101065953 | Oct 2007 | CN |
201203922 | Mar 2009 | CN |
101635754 | Jan 2010 | CN |
201481406 | May 2010 | CN |
201550169 | Aug 2010 | CN |
101859209 | Oct 2010 | CN |
201628839 | Nov 2010 | CN |
101945154 | Jan 2011 | CN |
102045423 | May 2011 | CN |
102045448 | May 2011 | CN |
102055836 | May 2011 | CN |
201869255 | Jun 2011 | CN |
201897853 | Jul 2011 | CN |
102178510 | Sep 2011 | CN |
102415091 | Apr 2012 | CN |
202261481 | May 2012 | CN |
102880289 | Jan 2013 | CN |
202998279 | Jun 2013 | CN |
102006057431 | Jun 2008 | DE |
1983485 | Oct 2008 | EP |
2136554 | Dec 2009 | EP |
2477391 | Jul 2012 | EP |
2533226 | Dec 2012 | EP |
07193753 | Jul 1995 | JP |
1997275518 | Apr 1999 | JP |
2002344814 | Nov 2002 | JP |
2004004465 | Jan 2004 | JP |
2004048571 | Feb 2004 | JP |
2004241491 | Aug 2004 | JP |
2006098098 | Apr 2006 | JP |
2006105655 | Apr 2006 | JP |
2007006475 | Jan 2007 | JP |
2007267035 | Oct 2007 | JP |
2007325842 | Dec 2007 | JP |
2010181324 | Aug 2010 | JP |
2012231309 | Nov 2012 | JP |
20000026757 | May 2000 | KR |
100227582 | Nov 2000 | KR |
100272582 | Nov 2000 | KR |
20000073381 | Dec 2000 | KR |
100285817 | Jan 2001 | KR |
20010001341 | Jan 2001 | KR |
20010002462 | Jan 2001 | KR |
20010010010 | Feb 2001 | KR |
20010014992 | Feb 2001 | KR |
20010044756 | Jun 2001 | KR |
20010050263 | Jun 2001 | KR |
20010060752 | Jul 2001 | KR |
20010068202 | Jul 2001 | KR |
20010070355 | Jul 2001 | KR |
20010074565 | Aug 2001 | KR |
20020006967 | Jan 2002 | KR |
20020044339 | Jun 2002 | KR |
20020049605 | Jun 2002 | KR |
20060071220 | Jun 2002 | KR |
20020061406 | Jul 2002 | KR |
20020061920 | Jul 2002 | KR |
20020069690 | Sep 2002 | KR |
20020078469 | Oct 2002 | KR |
20020083368 | Nov 2002 | KR |
20020083961 | Nov 2002 | KR |
20020085124 | Nov 2002 | KR |
20020085490 | Nov 2002 | KR |
20020095752 | Dec 2002 | KR |
20030000332 | Jan 2003 | KR |
20030007030 | Jan 2003 | KR |
20030012444 | Feb 2003 | KR |
20030016607 | Mar 2003 | KR |
20030024545 | Mar 2003 | KR |
20030037101 | May 2003 | KR |
20030051140 | Jun 2003 | KR |
20030055693 | Jul 2003 | KR |
20030056667 | Jul 2003 | KR |
20030067116 | Aug 2003 | KR |
20030085742 | Nov 2003 | KR |
20030088968 | Nov 2003 | KR |
20040001684 | Jan 2004 | KR |
20040001686 | Jan 2004 | KR |
20040023826 | Mar 2004 | KR |
20040027692 | Apr 2004 | KR |
20040033223 | Apr 2004 | KR |
20040033532 | Apr 2004 | KR |
20040033986 | Apr 2004 | KR |
20040033993 | Apr 2004 | KR |
20040039868 | May 2004 | KR |
20040040296 | May 2004 | KR |
20040042475 | May 2004 | KR |
20040044624 | May 2004 | KR |
100437890 | Jun 2004 | KR |
20040054416 | Jun 2004 | KR |
20040058969 | Jul 2004 | KR |
20040062802 | Jul 2004 | KR |
20040064855 | Jul 2004 | KR |
20040066724 | Jul 2004 | KR |
20040068864 | Aug 2004 | KR |
20040070840 | Aug 2004 | KR |
20040076308 | Sep 2004 | KR |
20040086994 | Oct 2004 | KR |
20040102386 | Dec 2004 | KR |
20050008245 | Jan 2005 | KR |
20050011313 | Jan 2005 | KR |
20050012505 | Feb 2005 | KR |
20050014448 | Feb 2005 | KR |
20050015293 | Feb 2005 | KR |
20050015526 | Feb 2005 | KR |
20050015745 | Feb 2005 | KR |
20050018370 | Feb 2005 | KR |
20050023950 | Mar 2005 | KR |
20050028537 | Mar 2005 | KR |
20050033308 | Apr 2005 | KR |
101006660 | Sep 2005 | KR |
1020050095463 | Sep 2005 | KR |
100547739 | Jan 2006 | KR |
20060023957 | Mar 2006 | KR |
1020060019715 | Mar 2006 | KR |
100645746 | May 2006 | KR |
20060054877 | May 2006 | KR |
100612890 | Aug 2006 | KR |
100633792 | Oct 2006 | KR |
100646966 | Nov 2006 | KR |
20060119077 | Nov 2006 | KR |
20060119236 | Nov 2006 | KR |
20060120318 | Nov 2006 | KR |
20060121595 | Nov 2006 | KR |
100660125 | Dec 2006 | KR |
100663528 | Jan 2007 | KR |
100672377 | Jan 2007 | KR |
20070002590 | Jan 2007 | KR |
20070005263 | Jan 2007 | KR |
20070005553 | Jan 2007 | KR |
20070009380 | Jan 2007 | KR |
100677913 | Feb 2007 | KR |
100689465 | Mar 2007 | KR |
20070028201 | Mar 2007 | KR |
100722974 | May 2007 | KR |
100729813 | Jun 2007 | KR |
20070067650 | Jun 2007 | KR |
100743171 | Jul 2007 | KR |
100743254 | Jul 2007 | KR |
20070068501 | Jul 2007 | KR |
20070078477 | Aug 2007 | KR |
20070082960 | Aug 2007 | KR |
20070087513 | Aug 2007 | KR |
20070091486 | Sep 2007 | KR |
100766953 | Oct 2007 | KR |
100771364 | Oct 2007 | KR |
20070104957 | Oct 2007 | KR |
100777428 | Nov 2007 | KR |
20070115754 | Dec 2007 | KR |
20070122344 | Dec 2007 | KR |
20070122345 | Dec 2007 | KR |
100802525 | Feb 2008 | KR |
20080013314 | Feb 2008 | KR |
20080015099 | Feb 2008 | KR |
20080015100 | Feb 2008 | KR |
20080015973 | Feb 2008 | KR |
20080018407 | Feb 2008 | KR |
100822053 | Apr 2008 | KR |
20080045551 | May 2008 | KR |
100841243 | Jun 2008 | KR |
20080053057 | Jun 2008 | KR |
20080054596 | Jun 2008 | KR |
100846192 | Jul 2008 | KR |
20080059882 | Jul 2008 | KR |
20080069007 | Jul 2008 | KR |
100854932 | Aug 2008 | KR |
20080071070 | Aug 2008 | KR |
20080078315 | Aug 2008 | KR |
100866177 | Oct 2008 | KR |
100866475 | Nov 2008 | KR |
100866476 | Nov 2008 | KR |
100866573 | Nov 2008 | KR |
100870724 | Nov 2008 | KR |
20080096918 | Nov 2008 | KR |
20080098409 | Nov 2008 | KR |
100871916 | Dec 2008 | KR |
20080112331 | Dec 2008 | KR |
20090003899 | Jan 2009 | KR |
20090018486 | Feb 2009 | KR |
20090020864 | Feb 2009 | KR |
100888554 | Mar 2009 | KR |
20090036734 | Apr 2009 | KR |
100897170 | May 2009 | KR |
20090052526 | May 2009 | KR |
100901784 | Jun 2009 | KR |
100903348 | Jun 2009 | KR |
20090089931 | Aug 2009 | KR |
100922497 | Oct 2009 | KR |
20090105424 | Oct 2009 | KR |
100932752 | Dec 2009 | KR |
100935495 | Jan 2010 | KR |
20100006652 | Jan 2010 | KR |
2010022327 | Mar 2010 | KR |
20100039170 | Apr 2010 | KR |
100958030 | May 2010 | KR |
20100059681 | Jun 2010 | KR |
20100070116 | Jun 2010 | KR |
20100070119 | Jun 2010 | KR |
20100072994 | Jul 2010 | KR |
100977516 | Aug 2010 | KR |
2010091758 | Aug 2010 | KR |
20100089125 | Aug 2010 | KR |
20100090521 | Aug 2010 | KR |
20100091758 | Aug 2010 | KR |
20100098958 | Sep 2010 | KR |
100985816 | Oct 2010 | KR |
100990904 | Nov 2010 | KR |
20100123021 | Nov 2010 | KR |
1006660 | Jan 2011 | KR |
20110006437 | Jan 2011 | KR |
20110011264 | Feb 2011 | KR |
2011019994 | Mar 2011 | KR |
2011024290 | Mar 2011 | KR |
101111167 | Apr 2011 | KR |
1111167 | Feb 2012 | KR |
1020130142810 | Dec 2013 | KR |
201116030 | May 2011 | TW |
WO 0023814 | Apr 2000 | WO |
WO 02067575 | Aug 2002 | WO |
WO 03093963 | Nov 2003 | WO |
WO 2005002228 | Jan 2005 | WO |
WO 2005088846 | Sep 2005 | WO |
WO 2006112866 | Oct 2006 | WO |
WO 2007006242 | Jan 2007 | WO |
WO 2008094102 | Aug 2008 | WO |
WO 2009122114 | Oct 2009 | WO |
WO 2010005152 | Jan 2010 | WO |
WO 2010033142 | Mar 2010 | WO |
WO 2011131758 | Oct 2011 | WO |
WO 2012027739 | Mar 2012 | WO |
WO 2012170949 | Dec 2012 | WO |
WO 2012170953 | Dec 2012 | WO |
WO 2012170946 | Dec 2012 | WO |
Entry |
---|
Written Opinion of international application PCT/US2012/041749 (published as WO/2012/170949), (dated 2013). |
Neto et al., “Figures of merit and optimization of a VO2 microbolometer with strong electrothermal feedback”, SPIE, Jul. 1, 2008, pp. 1-15, vol. 47, No. 7, Bellingham, WA. |
Tzimopoulou et al., “Scene based techniques for nonuniformity correction of infrared focal plane arrays”, Proceedings of SPIE, Jul. 19, 1998, pp. 172-183, vol. 3436, International Society for Optical Engineering, US. |
Perry, Greg, “Counters and Accumulators”, Absolute Beginner's Guide to Programming, Apr. 2001, 4 pages, Second Edition, QUE, Safari Books, [online], [retrieved on May 19, 2014]. Retrieved from the Internet: <URL:http://techbus.safaribooksonline.com/print?xmlid=0-7897-2529-0%2Fcopyrightpg>. |
FLIR, “FLIR P640 Infrared Camera”, Jan. 23, 2010, pp. 1-2 http://www.flir.com/uploadedFiles/Thermography—APAC/Products/Product—Literature/AU—P640—Datasheet—APAD.pdf. |
DARPA, “Broad Agency Announcement Low Cost Thermal Imager Manufacturing (LCTI-M)”, Microsystems Technology Office, DARPA-BAA-11-27, Jan. 24, 2011. pp. 1-42, Arlington, VA. |
Number | Date | Country | |
---|---|---|---|
20130250125 A1 | Sep 2013 | US |
Number | Date | Country | |
---|---|---|---|
61646781 | May 2012 | US | |
61656889 | Jun 2012 | US | |
61545056 | Oct 2011 | US | |
61495873 | Jun 2011 | US | |
61495879 | Jun 2011 | US | |
61495888 | Jun 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12396340 | Mar 2009 | US |
Child | 13529772 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/US2012/041744 | Jun 2012 | US |
Child | 13893809 | US | |
Parent | PCT/US2012/041749 | Jun 2012 | US |
Child | PCT/US2012/041744 | US | |
Parent | PCT/US2012/041739 | Jun 2012 | US |
Child | PCT/US2012/041749 | US | |
Parent | 13622178 | Sep 2012 | US |
Child | PCT/US2012/041739 | US | |
Parent | 13529772 | Jun 2012 | US |
Child | 13622178 | US |