Embodiments disclosed herein relate in general to spectral imaging systems and methods.
Spectral imaging (SI) and hyperspectral imaging (HSI) may be performed using various systems (cameras) and methods. In particular snapshot SI and HSI may be performed using known and commercially available cameras. Also known are snapshot SI and HSI using a monochromatic digital camera (i.e. a cameras with a clear (monochromatic) image sensor) that has a minimal hardware addition in the form of a diffuser element. The monochromatic digital camera is adapted to provide a large number of spectral images in a snapshot. The spectral images are reconstructed from a single diffused-dispersed (DD) image, which is a single image obtained at the image sensor through the camera and the diffuser. Some of the reconstruction algorithms may be based on compressed sensing (CS).
In many real life scenarios, a digital camera used for SSI or HSI may suffer from changing lightning and visibility conditions. For example, weather conditions such as fog, snow or rain may cause bad visibility. Furthermore, camera saturation caused by high reflection from snow, fog, rail or other conditions may result in inability of the camera to provide reasonable footage. At night, the problem worsens to the point that a standard (off-the shelf) camera may fail completely (due to saturation and light sensitivity).
There is therefore a need for, and it would be advantageous to have, digital cameras that can provide spectral, hyperspectral or color images that can also overcome adverse bad visibility effects.
In various embodiments, there are disclosed camera systems and methods that perform adaptive spectral and hyperspectral imaging. A camera system disclosed herein may convert a standard digital camera for use as an adaptive spectral filter (ASF) camera or an adaptive hyperspectral filter (AHSF) camera.
As used herein, the term “adaptive” refers to a camera that adapts a camera output based on camera input conditions (i.e. based on a camera “input”). As used herein, a spectral (or hyperspectral) filter is a hardware (HW) component or a software (SW) component that performs mathematical operations on a sampled, discrete-time spectral cube to reduce or enhance certain aspects of that cube. The SW filter can run on a processor of the camera or on a separate processor. The AHSF camera is adapted to process hyperspectral images (“input”) from a hyperspectral camera such that the AHSF camera outputs M spectral bands that have the highest energy (“output”). For example, during daytime, when lighting conditions are good, an AHSF camera disclosed herein may output M images from all the visible (VIS)+near infrared (NIR) bands. At nighttime, where lightning conditions are poor, the same AHSF camera may automatically output M images from the NIR band only.
While the description that follows is given in detail for hyperspectral cameras and methods, it is to be understood that it applies equally well to spectral cameras and methods. The differentiation between “spectral” and “hyperspectral” arises from the number of bands a given wavelength range is divided into. While different definitions are given in known art, one generally accepted definition refers to a plurality of up to 10 bands as “spectral” and to bands between 10 and hundreds of bands as “hyperspectral”. This generally accepted definition is by no means limiting.
In one embodiment, the AHSF camera is adapted to process hyperspectral images from a hyperspectral camera and depth indication from a depth estimator per hyperspectral image such that the AHSF camera outputs the M spectral bands that have the largest estimated depth inside the image (in essence, acting as a filter). Thereby, when the image acquisition conditions are such that some of the bands are blocked (for example in fog conditions) the AHSF camera will output the bands that are not blocked (for example the NIR in case of fog).
In exemplary embodiments there are provided camera systems, comprising: a spectral camera; a spectral filter; and a spectral conditioner, wherein the spectral camera is configured to communicate a plurality N of spectral images (im_b_1, . . . , im_b_N) in N spectral bands to the spectral filter and to the spectral conditioner, wherein the spectral conditioner is configured to process the communicated images and to provide at least one control message to the spectral filter, and wherein the spectral filter is configured to translate the at least one control message into a filtering operation performed on the communicated images to generate a set of filtered images that can be combined into at least one output image.
In some embodiments, the spectral filter includes a filter configuration manager operative to translate the at least one control message into a set of coefficients, and a set of NxM multipliers operative to use the set of coefficients to filter the communicated images to generate a set of filtered images (im_o_1, . . . , im_o_M).
In some embodiments, the spectral filter further includes a summing module operative to sum all the multiplied images to generate the at least one output image.
In some embodiments, the spectral conditioner is configured to measure/estimate intensity of light inside at least one light wavelength range and to use the measured/estimated intensity of light as input for the at least one control message.
In some embodiments, the spectral conditioner is configured to measure/estimate saturation of each band of the N spectral bands and to use the measured/estimated saturation as input for the at least one control message.
In some embodiments, spectral images from the spectral camera are processed together with a depth indication per spectral image received from a depth estimator, such that the camera system outputs M spectral bands that have the largest estimated depth inside each spectral image.
In some embodiments, the N spectral bands cover both a visible RGB wavelength range and an infrared (IR) wavelength range and the camera system is adapted to perform as a RGB to IR selector.
In some embodiments, the N spectral bands cover both a visible RGB wavelength range and an IR wavelength range and the camera system is adapted to perform as a fog depth optimizer.
In some embodiments, the N spectral bands cover a visible RGB wavelength range and the camera system is adapted to mitigate saturation.
In some embodiments, the spectral camera is a hyperspectral camera.
In an embodiment, there is provided a method comprising: providing a camera system comprising a spectral camera, a spectral filter and a spectral conditioner; configuring the spectral camera to communicate a plurality N of spectral images (im_b_1, . . . , im_b_N) in N spectral bands to the spectral filter and to the spectral conditioner; configuring the spectral conditioner to process the communicated images and to provide at least one control message to the spectral filter; and configuring the spectral filter to translate the at least one control message into a filtering operation performed on the communicated images to generate a set of filtered images that can be combined into at least one output image.
In a method embodiment, the method further comprises using a filter configuration manager of the spectral filter to translate the at least one control message into a set of coefficients and using a set of MxN multipliers of the spectral filter and the set of coefficients to filter the communicated images to generate a set of filtered images (im_o_1, . . . , im_o_M).
In a method embodiment, the method further comprises using a summing module of the spectral filter to sum all the multiplied images to generate the at least one output image.
Aspects, embodiments and features disclosed herein will become apparent from the following detailed description when considered in conjunction with the accompanying drawings, wherein:
Optionally, the spectral filter and/or the spectral conditioner can be implemented as software modules in a processor that also runs algorithms for image reconstruction for an acquired spectral cube (not shown).
The following reconstruction flow describes the processing flow of N spectral or hyperspectral images im_b_1-im_b_N to produce an output image Im_o_k. It is to be understood that where the term “hyperspectral” is used, it may also refer to “spectral”. The spectral cube includes N bands (the “_b” in the image numbering). Each image in the cube im_b_i (1≤i≤N) is multiplied by a filter coefficient W_i,k. Index i relates to the input hyperspectral image and index k relates to the output image i.e., 1≤k≤M where M is the number of output images. To produce M output images, we have N×M coefficients.
Given a spectral cube with N bands generated by a hyperspectral camera of any kind, the cube is communicated to the spectral conditioner and to the spectral filter. The spectral conditioner processes the images (or alternatively is configured to operate according to some predetermined rules) and outputs a control message to the spectral filter. The spectral filter is adapted to receive the control message and to configure the N×M multipliers accordingly (either from its own memory or from the control message). Each image is multiplied by the corresponding coefficient to produce the output images im_o_1, . . . , im_o_M.
In an example, the best M images in terms of depth may be chosen, using for example combinations from available computer vision algorithms such as depth estimation. A “depth estimator” is broadly defined herein as any device structurally configured for estimating a depth field from imaging data (e.g. a single image of mono-color or RGB, or a sequence of such images). A non-limiting example may be found in David Eigen, Christian Puhrsch and Rob Fergus. “Depth map prediction from a single image using a multi-scale deep network.” Advances in neural information processing systems, 2014. In one embodiment, the AHSF camera is adapted to process hyperspectral images from a hyperspectral camera and depth indication per hyperspectral image received from a depth estimator (not shown), such that the AHSF camera outputs the M spectral bands that have the largest estimated depth inside the image. Many depth estimators known in the art can be used for this purpose. Thereby, when the image acquisition conditions are such that some of the bands are blocked (for example in fog conditions) the AHSF camera will output only the bands that are most informative in terms of depth information (for example the NIR bands in case of fog).
1. RGB to IR selector: in an example, the source hyperspectral camera produces N=130 bands spanning from 400 nm to 1700 nm. (1300 nm/130=10 nm wide). For each produced spectral cube, the spectral conditioner is adapted or configured to measure/estimate the intensity of light in the range 400-720 nm (for example by summing all the relevant bands) and is adapted to measure/estimate the intensity of light in the range 900-1700 nm. The spectral conditioner is further configured to decide in which range the light is more intense based on the estimations, and it is further adapted to produce a control message to the spectral filter. In one embodiment, the control message includes coefficients W_i,K_R, W_i,K_G and W_i,K_B to produce a RGB image and/or coefficients W_i,k to produce a short wave IR (SWIR) image. Thereby, for each produced spectral cube, the most intense band is selected and translated into an image that can be processed by the receiving module.
The data for the IR case (i.e. for a band that is higher than 720 nm) includes M=1: W_j,1=1/80 for any i that corresponds to a band in the range 900 nm-1700 nm. Otherwise w_j,1=0;
2. Fog depth optimizer: in another example, the source hyperspectral camera produces N=130 bands spanning from 400 nm to 1700 nm. (1300 nm/130=10 nm wide). For each produced spectral cube, the spectral conditioner is adapted to measure/estimate the depth of each band in the cube and give it a depth score. This estimation can be done as known in the art. Given the estimated depth, the spectral conditioner is adapted to produce a control message to the spectral filter that includes information (like a specific band index i, or a specific coefficient) on the depth score of each image. The spectral filter is adapted to translate the depth score into a coefficient W_i,k. The filter is further adapted to multiply each image in the cube by the corresponding W_i,k to produce the output image cube.
In yet another example, the output cube includes M=3 output images, where each output image is computed according to the following logic/table: if the depth score of each image in the visible range is sufficiently large (30 m for example) than a RGB image is computed by utilizing coefficients W_i,K_R, W_i,K_G and W_i,K_B that are adapted for RGB image generation. Otherwise, the indexes of the 3 bands with the largest depth score are selected by setting their coefficient W_i,k to 1. All other coefficients are set to 0. Thereby, the receiving module always receives the image set that consists of the largest depth information.
3. Saturation mitigation: in yet another example, the source hyperspectral camera produces a spectral cube with N=33 bands spanning from 400 nm to 730 nm. For each produced spectral cube, the spectral conditioner is adapted to measure/estimate the saturation of each band in the cube. This estimation can be done as known in the art. Given the estimated saturation per image, the spectral conditioner is adapted to produce a message to the spectral filter that includes information (like a specific band index i, or a specific coefficient) on the saturation score of each image. The spectral filter is adapted to translate the saturation score into a coefficient W_i,k. The spectral filter is further adapted to multiply each image in the cube by the corresponding W_i,k to produce the output image cube. In one embodiment, the output cube consists of M=3 output RGB images, where each output image is computed according to the following logic/table: if the saturation score of any band in RGB band related images 1≤i≤33 is sufficiently low (e.g. about zero), then a RGB image is computed by utilizing coefficients W_j,K_R, W_j,K_G and W_j,K_B that are adapted for RGB image generation. Otherwise, the coefficient W_i,k that corresponds to any image with a saturation score larger than 0 is set to 0. Thereby, the receiving module receives an estimated RGB image that ignores any band that is saturated.
While this disclosure describes a limited number of embodiments, it will be appreciated that many variations, modifications and other applications of such embodiments may be made.
All references mentioned in this specification are herein incorporated in their entirety by reference into the specification, to the same extent as if each individual reference was specifically and individually indicated to be incorporated herein by reference. In addition, citation or identification of any reference in this application shall not be construed as an admission that such reference is available as prior art to the present application.
This application claims the benefit of priority of U.S. Provisional patent application No. 62/720,940 filed Aug. 22, 2018, which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62720940 | Aug 2018 | US |