A range camera acquires distances to features in a scene that the range camera images and provides the distances in a range image. Typically, the range camera is an active lighting range camera and comprises a light source that the camera controls to transmit light to illuminate the scene. The range camera images light that the features reflect from the transmitted light back to the camera on pixels of a photosensor that the camera comprises to provide data which may be processed to determine the distances and generate the range image. In a time of flight range camera the camera provides the range image by determining how long it takes the transmitted light that is reflected and imaged on the pixels to make a round trip from the camera to the features and back to the camera. The camera uses the round trip times and the speed of light to determine the distances. In a stereo range camera, the camera provides the range image by determining binocular disparity for features in the scene responsive to the transmitted light that is reflected and imaged on the pixels. The camera triangulates the features responsive to their disparity to determine the distances. Usually, the transmitted light is infrared light (IR). In addition to a range image of a scene, a range camera may also provide a contrast image, a “picture image”, of the scene responsive to intensity of the transmitted light that is reflected by the features of the scene and reaches the camera. The picture image provides recognizable images of features in the scene and is advantageous for identifying the features for which the range image provides distances. The picture image and range image of a scene may be acquired by imaging the scene on a same photosensor or on different photosensors registered to each other.
An aspect of an embodiment of the disclosure relates to providing a range camera that provides a reflectance image of a scene for which the range camera acquires a range image and a picture image. The reflectance image provides a reflectance for features in the scene imaged on pixels of the range camera photosensor for which the range camera provides distances.
To provide the reflectance for the features in the scene, the camera is calibrated in accordance with the disclosure by imaging under known calibration imaging conditions a “calibration surface” having known reflectance on a photosensor of the range camera to acquire a “calibration image”. The calibration image comprises measures of amounts of light that pixels in the photosensor register responsive to irradiation by light from regions of the calibration surface imaged on the pixels under the calibration conditions. An amount of light that a pixel registers from a region of the calibration surface may be referred to as registered calibration irradiance (RCI). A reflectance of a given feature of the scene imaged on a pixel of the range camera photosensor in the picture image is determined responsive to an amount of light, hereinafter also referred to as registered scene irradiance (RSI), registered by the pixel for the given feature in the picture image, distance of the feature from the camera determined from a range image of the scene, and the RCI of a corresponding pixel in the calibration image. The corresponding pixel is a pixel that images a region of the calibration surface corresponding to the given feature. The corresponding region of the calibration surface is a region that the range camera illuminates to acquire the calibration image along a same direction that the range camera illuminates the given feature of the scene to acquire the picture image of the scene. The RCI for a corresponding pixel on which the corresponding calibration region is imaged in the calibration image is used to normalize the RSI to provide a reflectance for the region of the scene and a reflectance image of the scene.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Non-limiting examples of embodiments of the disclosure are described below with reference to figures attached hereto that are listed following this paragraph. Identical features that appear in more than one figure are generally labeled with a same label in all the figures in which they appear. A label labeling an icon representing a given feature of an embodiment of the disclosure in a figure may be used to reference the given feature. Dimensions of features shown in the figures are chosen for convenience and clarity of presentation and are not necessarily shown to scale.
In the following detailed description a method of operating a range camera to acquire a calibration image of an optionally planar calibration surface in accordance with an embodiment of the disclosure is discussed with reference to
In the discussion, unless otherwise stated, adjectives such as “substantially” and “about” modifying a condition or relationship characteristic of a feature or features of an embodiment of the disclosure, are understood to mean that the condition or characteristic is defined to within tolerances that are acceptable for operation of the embodiment for an application for which it is intended. Unless otherwise indicated, the word “or” in the description and claims is considered to be the inclusive “or” rather than the exclusive or, and indicates at least one of, or any combination of items it conjoins.
It is noted that methods of providing a range camera with a calibration image and using the calibration image to determine reflectivity of features of a scene imaged by the camera in accordance with an embodiment of the disclosure are substantially independent of camera design and how the range camera determines distance to the features. Different range cameras calibrated and operated in accordance with an embodiment of the disclosure may therefore be expected to provide same reflectance images for a same scene substantially independent of how the range cameras operate to acquire range and picture images of the scene. The reflectance images may also be expected to be substantially independent of imaging conditions, such as, for a same spectrum, intensity of illumination of the scene and distances of the cameras from the scene.
As a result, image processing algorithms that process images of scenes acquired by a range camera calibrated in accordance with an embodiment of the disclosure to provide functionalities that may be responsive to reflectance of features in the scenes may be generic to range camera types. That is, the image processing algorithms may process a reflectance image of a scene to provide functionalities substantially in a same way and provide substantially a same result independent of type and design of a range camera that provides the image and/or imaging conditions under which the range camera acquired the image. Among functionalities responsive to reflectance of features that the image processing algorithms may advantageously provide include by way of example, person identification, gesture recognition, determination of emotional or physiological state from changes in skin tone, and avatar generation.
Optionally, range camera 20 comprises a light source 30 controllable to transmit, optionally infrared (IR) light to illuminate features in a scene the camera images, a photosensor 22 having pixels 23, and an optical system, which is represented by, and referred to as, a lens 24. Lens 24 collects light reflected by the features from light transmitted by light source 30 and images the reflected light onto pixels 23 of photosensor 22. The lens has an optical axis 25, optical center 26 and a diameter “D” that optionally defines an optical aperture, α=πD2/4, of the lens and the optical system the lens represents. A unit vector {circumflex over (γ)} lies along, and represents a direction of optical axis 25. Photosensor 22 is substantially perpendicular to optical axis 25 and located at a focal distance, “f”, from optical center 26. A pixel 23 comprised in photosensor 22 is located in the photosensor by pixel coordinates measured long x and y axes shown along edges of the photosensor. A pixel coordinate origin from which pixel coordinates may be measured is located at an intersection of optical axis 25 and photosensor 22. A pixel located at pixel coordinates xi and yj may be represented by p(xi,yj) or p(i,j).
A controller 28 controls operation of range camera 20. The controller may by way of example, control intensity and modulation of light that light source 30 transmits to illuminate features in an imaged scene and shuttering of the camera to provide desired exposure periods for imaging transmitted light that is reflected by the features back to the range camera on pixels 23. Controller 28 may process light reflected by the features and registered by pixels 23 during the exposure periods to determine distances to the features and therefrom a range image of the scene and/or a picture image of the scene.
A pixel in a range camera, such as a pixel 23 in photosensor 22, registers incident light that irradiates the pixel by accumulating positive or negative electric charge, also referred to as “photocharge”, provided by electron-hole pairs generated by photons in the incident light. Circuitry in the range camera may convert photocharge accumulated by the pixels into voltages that are used as measures of the amounts of photocharge they respectively accumulate and thereby of irradiance of the pixels. An amount of light that a pixel registers, also referred to as registered irradiance, may refer to an amount of optical energy that irradiates the pixel, an amount of photocharge accumulated by a pixel responsive to irradiance, or to any representation of the accumulated photocharge such as a voltage, current, or digital data generated responsive to the accumulated photocharge.
Spatial locations of features in a field of view (FOV) of range camera 20 relative to the range camera are defined by spatial coordinates measured along X, Y, and Z axes of an optionally Cartesian coordinate system 41. The Z axis is optionally coincident with optical axis 25 of range camera 20. Light source 30 is located along the X axis at a distance XS from optical center 26 and has an illumination axis 32, which is optionally parallel to optical axis 25 and intersects the X axis at a distance XS. Spatial locations of features in the FOV of range camera 20 relative to light source 30 may be defined by spatial coordinates measured along “primed” axes X′, Y′, and Z′ of a primed coordinate system 42. Optionally, the Z′ axis is coincident with illumination axis 32, and the X′ and Y′ axes are respectively parallel to the X and Y axes. Origins of coordinate systems 41 and 42 may be considered to be, and may be referred to as, the locations of lens 24 and light source 30.
Calibration surface 50 is optionally planar, and has a known reflectance “ρo”, which, optionally, is the same for substantially all regions of the calibration surface. The calibration conditions under which range camera 20 images calibration surface 50 optionally comprise a known distance and orientation of calibration surface 50 relative to the range camera optical axis 25, known range camera settings, such as aperture and exposure period, and a known optical output power with which light source 30 illuminates the calibration surface. By way of example, in
Let a region of calibration surface 50 imaged on a given pixel p(i,j,) shown in
(Xi,Yj,Zo) is located at a distance defined by a distance vector, “R(i,j,Zo)” that extends from optical center 26 to coordinates Xi,Yj,Zo at a zenith angle θ(i,j,Zo) relative to the Z axis of coordinate system 41 and at an azimuth angle φ(i,j,Zo) relative to the X axis of the coordinate system. The absolute value of |R(i,j,Zo)|≡R(i,j,Zo)=[Xi2+Yj2+Zo2]1/2. In primed coordinate system 42, region (Xi,Yj,Zo) has coordinates X′i=(Xi−XS), Y′j=Yj, and Z′=Zo, and is located at distance defined by a distance vector R′(i,j,Zo) directed from light source 30 at a zenith angle θ′(i,j,Zo) relative to the Z′ axis and at an azimuth angle φ′(i,j,Zo) relative to the X′ axis. |R′(i,j,Zo)|≡R′(i,j,Zo)=[X′i2+Y′j2+Z′o2]=1/2=[Xi−XS)2+Yj2+Zo2]1/2. Arrows along distance vectors R(i,j,Zo) and R′(i,j,Zo) indicate direction of propagation of light from light source 30 to region (Xi,Yj,Zo) and therefrom to pixel p(i,j) of photosensor 22. A unit normal to (Xi,Yj,Zo) is represented by {circumflex over (η)}(i,j,Zo). If “Ap” represents the area of a pixel p(i,j), and (i,j,Zo) the area of region (Xi,Yj,Zo), then,
(i,j,Zo)=Ap(Zo/f)2. (1)
If, under calibration conditions, optical power per unit solid angle of light that light source 30 transmits in a direction defined by a given zenith angle θ′ and azimuth angle φ′ is represented by a vector Po(θ′,φ′), then optical power per unit solid angle that light source 30 transmits in the direction of (Xi,Yj,Zo) is Po(θ′(i,j,Zo),φ′(i,j,Zo)), which, for convenience, may also be written Po(θ′,φ′,(i,j,Zo)). A total amount of optical power, hereinafter also referred to as “total irradiance” (TIR), incident on (Xi,Yj,Zo) from light source 30 under calibration conditions is therefore equal to the area (i,j,Zo) times the scalar product of {circumflex over (η)}(i,j,Zo) and Po(θ′,φ′,(i,j,Zo)) divided by the square of the distance from light source 30 to (Xi,Yj,Zo). In symbols, letting TIR((Xi,Yj,Zo)) represent a total irradiance of region (Xi,Yj,Zo) by light source 30 under calibration conditions, TIR((Xi,Yj,Zo)) may therefore be written:
TIR((Xi,Yj,Zo))=(i,j,Zo){circumflex over (η)}(i,j,Zo)·Po(θ′,φ′,(i,j,Zo))/R′(i,j,Zo)2, (2)
where “·” indicates a scalar product.
Since calibration plane 50 is assumed parallel to photosensor 22, {circumflex over (η)}(i,j,Zo) is parallel to axis Z and axis Z′ and,
{circumflex over (η)}(i,j,Zo)·Po(θ′,φ′,(i,j,Zo))=Po(θ′,φ′,(i,j,Zo))cos θ′(i,j,Zo)=Po(θ′,φ′,(i,j,Zo))[Zo/R′(i,j,Zo)]. (3)
The expression for TIR((Xi,Yj,Zo)) in equation (2) may therefore be written,
TIR((Xi,Yj,Zo))=(i,j,Zo)Po(θ′,φ′,(i,j,Zo))[Zo/R′(i,j,Zo)3]. (4)
Substituting the expression for (i,j,Zo) from equation (1) provides
Assuming that (i,j,Zo) is a diffuse reflector that reflects light with equal optical power per unit solid angle in all directions in a hemisphere centered on (i,j,Zo) and facing range camera 20, (i,j,Zo) reflects light towards lens 24 along a direction of R(i,j,Zo) defined by zenith and azimuth angles θ(i,j,Zo) and φ(i,j,Zo), with “reflected” optical power per solid angle,
RPo(θ,φ,(i,j,Zo))={circumflex over (R)}(i,j,Zo)ρoTIR((Xi,Yj,Zo))/2π, (6)
where {circumflex over (R)}(i,j,Zo) is a unit vector along R(i,j,Zo) in a direction from (i,j,Zo) to lens 24.
Reflected optical power incident on aperture α of lens 24 from region (Xi,Yj,Zo), that is total irradiance, TIR(α,(Xi,Yj,Zo)), of lens 24 by reflected light from (Xi,Yj,Zo) may therefore be given by an expression:
where (α/R(i,j)2){circumflex over (γ)}·{circumflex over (R)}(i,j,Zo) is a solid angle subtended by aperture α at (Xi,Yj,Zo). Noting that {circumflex over (γ)}·{circumflex over (R)}(i,j,Zo)=cos θ(i,j,Zo)=Zo/R(i,j,Zo), expression (7) may be rewritten:
TIR(α,(Xi,Yj,Zo))=(αZo/R(i,j,Zo)3)ρoTIR((Xi,Yj,Zo))/2π. (8)
Using the expression for TIR((Xi,Yj,Zo)) given by equation (5), and rearranging terms, equation (8) becomes,
TIR(α,(Xi,Yj,Zo))=ρo(Apα/2πf2)Zo4Po(θ′,φ′,(i,j,Zo))[R(i,j,Zo)R′(i,j,Zo)]−3. (9)
Let τ, represent a coefficient that relates optical power, TIR(α,(Xi,Yj,Zo)), incident on pixel p(i,j) to the registered calibration irradiance RCI(i,j,Zo), that the pixel provides as a measure of total irradiance TIR(α,(Xi,Yj,Zo)). RCI(i,j,Zo), may be given by the equation:
Measurements RCI(i,j,Zo) acquired for a plurality of pixels p(i,j,Zo) that image different regions (Xi,Yj,Zo) of calibration surface 50 provide a calibration image for range camera 20. The calibration image may be used to determine reflectances of features in a scene imaged in a picture image of the scene acquired by range camera 20, in accordance with an embodiment of the disclosure as described below.
Let an amount of light, that is, registered scene irradiance RSI, that pixel p(i,j,k) registers for light from region A(Xi,Yj,Zk) when acquiring the picture image of the scene comprising A(Xi,Yj,Zk) be represented by “RSI(i,j,Zk)”. Assume that controller 28 operates light source 30 to illuminate the scene with optical power Po(θ′,φ′,(i,j,Zo)). Then, similar to determining RCI(i,j,Zo) in accordance with equation (10) for pixel p(i,j,Zo) that images region (Xi,Yj,Zo) of calibration surface 50 under calibration conditions, RSI(i,j,Zk), may be determined by an equation:
RSI(i,j,Zk)=τρ(i,j,k)(Apα/2πf2)Zk4Po(θ′,φ′,(i,j,Zk))[R(i,j,Zk)R′(i,j,Zk)]−3. (11)
To determine ρ(i,j,k) for A(Xi,Yj,Zk) according to an embodiment of the disclosure, controller 28 controls range camera 20 to acquire a range image for the scene comprising region A(Xi,Yj,Zk) to determine a distance, R(i,j,Zk), from the range camera to region A(Xi,Yj,Zk). The controller uses distance R(i,j,Zk), RSI(i,j,Zk) provided by pixel p(i,j,k) for A(Xi,Yj,Zk), and a RCI(i,j,Zo) acquired for a pixel that images a region of calibration surface 50 in the calibration image acquired for range camera 20 that corresponds to region A(Xi,Yj,Zk) to determine reflectance ρ(i,j,k).
In an embodiment of the disclosure, a region of calibration surface 50 that corresponds to region A(Xi,Yj,Zk) comprises a region of the calibration surface that is illuminated by light from light source 30 when imaged by range camera 20 to acquire the calibration image along substantially a same direction along which light from light source 30 illuminates region A(Xi,Yj,Zk) to acquire the picture image of the scene comprising an image of A(Xi,Yj,Zk). In an embodiment of the disclosure, the corresponding region is a region (X*i,Y*j,Zo) shown in
X*i=Xi+(1−(Zo/Zk)XS and Y*j=(Zo/Zk)Yj, (12)
Using equations (12), the coordinates xi* and yj* of pixel p(i*,j*,Zo) may be written
xi*=−(f/Zo)X*i and yj*=−(f/Zo)Y*j. (13)
The determined coordinates xi* and yj* identify a pixel p(i*,j*, Zo) that provides a registered calibration irradiation, RCI(i*,j*,Zo), for region (Xi*,Yj*,Zo) corresponding to region A(Xi,Yj,Zk). In accordance with an embodiment of the disclosure, RCI(i*,j*,Zo) is used to determine ρ(i,j,k) for region A(Xi,Yj,Zk) as described below.
From equation (10),
RCI(i*,j*,Zo)=(τρoApα/2πf2)Zo4Po(θ′,φ′,(i*,j*,Zo))[R(i*,j*,Zo)R′(i*,*j,Zo)]−3. (14)
where R(i*,j*,Zo)=[Xi*2+Yj*2+Zo2]1/2 and R′(i*,j*,Zo)=[Xi*−XS)2+Yj*2+Zo*2]1/2. In expression (14) Po(θ′,φ′,(i*,j*,Zo)) is the magnitude of the optical power per unit solid angle that light source 30 transmits in the direction of region A(Xi,Yj,Zk) to illuminate A(Xi,Yj,Zk) with light. Rearranging equation (11) provides an equation for reflectance ρ(i,j,k) of A(Xi,Yj,Zk):
ρ(i,j,k)=(τApα/2πf2)−1Zk−4[R(i,j,Zk)R′(i,j,Zk)]3RSI(i,j,Zk)/Po(θ′,φ′,(i,j,Zk)). (15)
Rearranging equation 10 provides an expression for optical power Po(θ′,φ′,(i,j,Zk)):
Po(θ′,φ′,(i*,j*,Zo))=(2πf2/τρoApα)RCI(i*,j*,Zo)Zo−4[R(i*,j*,Zo)R′(i*,*j,Zo)]3. (16)
Substituting the expression for Po(θ′,φ′,(i*,j*,Zo)) from equation (16) into equation (15) provides an equation that determines ρ(i,j,k):
ρ(i,j,k)=ρo(Zo/Zk)4[RSI(i,j,Zk)/RCI(i*,j*,Zo)][(R(i,j,Zk)/R(i*,j*,Zo))(R′(i,j,Zk)/R′(i*,*j,Zo))]3 (17)
Equation (17) determines reflectance for region A(Xi,Yj,Zk) in accordance with an embodiment of the disclosure in terms of calibration reflectance ρo, registered irradiances RSI(i,j,Zk) and RCI(i*,j*,Zo), and spatial coordinates provided by a range image acquired by range camera 20.
An alternative expression for ρ(i,j,k) may be determined by normalizing coordinates Xi,Yj and X′i,Y′j to Zo and writing equations (10) in terms of pixel coordinates xi and yj of a pixel p(i,j) to provide:
RCI(i,j,Zo)={τ(Apα/2πf2)[1+(xi/f)2+(yj/f)2]−3/2}ρoPo(θ′,φ′,(i,j,Zo))Zo−2[1+((xi/f)−XS/Zo)2+(yj/f)2]−3/2. (18)
The quantities in curly brackets are constants and independent of Zo for a given pixel. Representing the quantities in brackets by a constant K(i,j), the expression (18) may be written.
RCI(i,j,Zo)=K(i,j)ρoPo(θ′,φ′,(i,j,Zo))Zo−2[1+((xi/f)−XS/Zo)2+(yj/f)2]−3/2. (19)
Similarly, equation (11) for the pixel may be written,
RSI(i,j,Zk)=K(i,j)ρ(i,j,k)Po(θ′,φ′,(i,j,Zk))Zk−2[1+((xi/f)−XS/Zk)2+(yj/f)2]−3/2. (20)
As a result, p(i,j,k) may be determined in accordance with an expression,
ρ(i,j,k)=ρo[RSI(i,j,Zk,)/RCI(i,j,Zo,ρo)](Zk2/Zo2)Po(θ′,φ′,(i,j,Zo))/Po(θ′,φ′,(i,j,Zk))×[1+((xi/f)−XS/Zk)2+(yj/f)2]3/2/[1+((xi/f)−XS/Zo)2+(yj/f)2]3/2. (21)
In general, the term XS/Zk and XS/Zo are relatively small compared to the other terms in the expressions [1+((xi/f)−XS/Zk)2+(yj/f)2] and [1+((xi/f)−XS/Zo)2+(yj/f)2], and the ratio is Po(θ′,φ′,(i,j,Zo))/Po(θ′,φ′,(i,j,Zk)) is a weak function of Zk. The terms following the term (Zk2/Zo2) in equation (21) may therefore conveniently be expressed as a power series about the coordinate Zo optionally of the form (ao(i,j,Zo)+a1(i,j,Zo)Zk−1+a2(i,j,Zo)Zk−2. . . ) so that
ρ(i,j,k)=ρo[RSI(i,j,Zk,)/RCI(i,j,Zo,ρo)](Zk2/Zo2)(ao(i,j,Zo)+a1(i,j,Zo)Zk−1+. . . ) (22)
In an embodiment of the disclosure range camera 20 is calibrated by imaging calibration surface 50 at each of a plurality of different known calibration distances from the range camera to provide calibration images and registered calibration irradiances RCI(i,j,Z′o) for a plurality of known different distances “Z′o” from the range camera. Coefficients for the power series may be determined from the calibration irradiances for each of the distances Z′o. Values of the calibration irradiances RCI(i,j,Z′o) and associated coefficients (ao(i,j,Zo), a1(i,j,Zo), . . . for each pixel may be stored in a look up table (LUT) in controller 28. The controller uses the LUT values for a given pixel p(i,j) to determine a reflectance ρ(i,j,k), optionally in accordance with expression (22) for a feature that range camera 20 images on the given pixel.
In an embodiment, distances between calibration distances Z′o are determined so that a number of power series coefficients stored in the LUT for a pixel p(i,j) occupies a desired amount of memory in controller 28, and is sufficient to provide values for ρ(i,j,k) for the pixel having desired accuracy in a desired controller processing time. In an embodiment, a number of power coefficients stored per pixel is less than or equal to about 5. Optionally, the number is less than or equal to 2.
In an embodiment of the disclosure each of a plurality of range cameras of a same given type and/or make is calibrated in a calibration procedure in which the range camera is operated to image calibration surface 50 at each of a plurality of known distances to acquire an empirical LUT specific to the camera. Values for irradiances and power series coefficients in the acquired empirical LUTs are suitably average to generate a generic LUT. The generic LUT may be installed in a range camera of the same given type and/or make for use in determining reflectances without having to operate the range camera to acquire an empirical LUT.
In deriving equation (17)-(22) it is assumed that reflectance of calibration surface 50 is the same for all regions of the calibration surface, the calibration surface is planar, and that range camera 20 illuminates the scene comprising A(Xi,Yj,Zk) with a same optical power Po(θ′,φ′,(i*,j*,Zo)) used to acquire a calibration image for the range camera. Embodiments are not limited to planar calibration surfaces having uniform reflectance ρo. For example, RCIs useable for determining a reflectance ρ(i,j,k) for features in a scene may be determined for a cylindrical or a spherical calibration surface using a modification of equations (17)-(22) that accounts for the non-planar geometry of the calibration surface. And reflectance of calibration surface 50 may for example, be a known, non-constant function ρo(i,j,k) of coordinates Xi,Yj,Zk on the calibration surface. Nor is practice of an embodiment of the disclosure limited to illuminating a scene with optical power Po(θ′,φ′,(i*,j*,Zo)). Light source 30 may be operated to illuminate scenes imaged by range camera 20 at different levels of optical power. Equations (17)-(22) may be modified to account for illuminating a scene at an optical power different from Po(θ′,φ′,(i*,j*,Zo)) by multiplying the right hand side of equation (17) and (22) by a suitable ratio between the different optical power and Po(θ′,φ′,(i*,j*,Zo)).
It is noted that in the above description, the normal {circumflex over (η)}(i,j,Zo) to calibration surface region (Xi,Yj,Zo), and the normal {circumflex over (η)}(i,j,Zk) to scene region A(Xi,Yj,Zk) are assumed parallel to optic axis 25 of range camera 20. However, practice of an embodiment of the disclosure is not limited to determining reflectances for scene regions having normals parallel to optic axis 25 and for tilted scene regions a modification of expression (17) may be used to provide reflectances ρ(i,j,k) for the regions.
For example,
where [Ap(Zk/f)2] is the area A(i,j,Zk) of non-tilted scene region A(Xi,Yj,Zk) determined similarly to determining (i,j,Zo) in accordance with equation (1).
In addition, in an equation for total irradiance TIR(AT(Xi,Yj,Zk)) of tilted scene region AT(Xi,Yj,Zk) similar to equation (2) for TIR((Xi,Yj,Zo)), it may not be appropriate, as provided for TIR((Xi,Yj,Zo)) by equation (3), to replace {circumflex over (η)}(i,j,Zk,T)·Po(θ′,φ′,(i,j,Zk)) with Po(θ′,φ′,(i,j,Zk))[Zk/R′(i,j,Zk)]. In equation (3), {circumflex over (η)}(i,j,Zo)·Po(θ′,φ′,(i,j,Zo)) is replaced by Po(θ′,φ′,(i,j,Zo))[Zo/R′(i,j,Zo)] under the assumption that normal {circumflex over (η)}(i,j,Zo) to (Xi,Yj,Zo) is parallel to optic axis 25 and as a result {circumflex over (η)}(i,j,Zo)·{circumflex over (P)}o(θ′,φ′,(i,j,Zo))=cos θ′(i,j,Zo)=[Zo/R′(i,j,Zo)]. Irradiance RSI(i,j,Zk) of A(Xi,Yj,Zk) given by expression (11) is similarly dependent on the assumption that normal {circumflex over (η)}(i,j,Zk) to A(Xi,Yj,Zk) is parallel to optic axis 25 and therefore that {circumflex over (η)}(i,j,Zk)·{circumflex over (P)}o(θ′,φ′,(i,j,Zk))=cos θ′(i,j,Zk)=[Zk/R′(i,j,Zk)].
Since the assumption that {circumflex over (η)}(i,j,Zk) is parallel to optic axis 25 and its consequence that cos θ′(i,j,Zo)=[Zo/R′(i,j,Zo)] do not obtain for {circumflex over (η)}(i,j,Zk,T), equation (17) may not provide a satisfactory value for ρ(i,j,k) for tilted scene region AT(Xi,Yj,Zk).
Therefore, in an embodiment of the disclosure, for a tilted scene region such as AT(Xi,Yj,Zk) equation (17) may be adjusted for tilt by multiplying the right hand side of the equation by a “tilt factor” (TF) defined by an expression:
TF=[Zk/R′(i,j,Zk)cos θ(i,j,Zk)][{circumflex over (R)}(i,j,Zk)·{circumflex over (η)}(i,j,k,T)/{circumflex over (R)}′(i,j,Zk)·{circumflex over (η)}(i,j,k,T)]. (24)
And if reflectance for a tilted scene region is represented by ρT(i,j,k), then ρT(i,j,k)=TFρ(i,j,k), which if ρ(i,j,k) is determined in accordance with equation (17), equals
TFρo(Zo/Zk)4[RSI(i,j,Zk)/RCI(i*,j*,Zo)][(R(i,j,Zk)/R(i*,j*,Zo))(R′(i,j,Zk)/R′(i*,*j,Zo))]3. (25)
The expression for TF assumes that registered calibration irradiance RCI(i,j,Zo) is determined for a planar calibration surface 50 as shown in
Total irradiance of tilted scene region AT(Xi,Yj,Zk) by light from light source 42 may similarly be written,
Using expression (23) for AT(i,j,Zk) in equation (27) results in:
Expression (28) defines TF for planar calibration surface 50 and a tilted scene region TIR(AT (Xi,Yj,Zk)).
Equations (23)-(28) express variables and reflectance of a tilted surface region AT(i,j,Zk) of a scene imaged by range camera 20 as a function of a unit normal, {circumflex over (η)}(i,j,Zk,T) of the region, which is not necessarily parallel to optic axis 25. In an embodiment of the disclosure, range camera 20 acquires 3D spatial coordinates, Xi, Yj, and Zk, for points in a scene that define a range image of the scene and thereby 3D surfaces for features in the scene. In an embodiment of the disclosure, range camera 20 processes the 3D spatial coordinates to determine gradients for regions of the surfaces and therefrom normals {circumflex over (η)}(i,j,Zk,T) to the surface regions. The normals are optionally used in accordance with equations (23)-(28) or equations similar to equations (23)-(28) to determine reflectances for the surface regions. It is noted that whereas equations (23)-(28) relax a constraint that {circumflex over (η)}(i,j,Zk,T) is parallel to optic axis 50, the equations are constrained by an assumption that intensity of reflected light per unit solid angle from an illuminated surface is independent of angle of reflection relative to normals {circumflex over (η)}(i,j,Zk) and {circumflex over (η)}(i,j,Zk,T). In an embodiment of the disclosure the constraint may be relaxed to determine RCI(i,j,Zo) and it may be assumed for example that intensity of reflected light decreases proportional to the cosine of an angle that direction of propagation of the reflected light makes relative to normal {circumflex over (η)}(i,j,Zk) and/or normal {circumflex over (η)}(i,j,Zk,T)
Controller 28 may determine skin reflectance for regions of facial skin of user 180 in accordance with equation (17) or equation (22) under the assumption that normals to regions of the user's facial skin are substantially parallel to optic axis 25 of the range camera. Controller 28 may determine skin reflectance for regions of facial skin of user 180 in accordance with equations (23-28) after determining normals {circumflex over (η)}(i,j,Zk,T) to the user's facial skin regions. Optionally, the normals are determined by calculating gradients to surfaces of the user's facial skin responsive to 3D spatial coordinates provided by the range images.
In an embodiment of the disclosure range camera 20 illuminates the face of user 180 with IR light and monitors changes in IR reflectance of the user's facial skin region to determine the user's heartbeat and/or temperature. Optionally controller 28 uses changes in reflectance to provide information characterizing the user's emotional state. For example to determine if the user is blushing or angry.
There is therefore provided in accordance with an embodiment of the disclosure a range camera operable to determine distances to and reflectance for features of a scene that the range camera images, the range camera comprising: a light source operable to transmit light to illuminate a scene that the range camera images; a photosensor having light sensitive pixels; optics having an optical axis and optical center configured to receive light reflected from the transmitted light by features in the scene and image the reflected light on a plurality of the pixels, each of which plurality of pixels registers reflected light from a feature of the scene that the optics images on the pixel to provide a registered scene irradiance (RSI) for the feature; a calibration image comprising a registered calibration irradiance (RCI) for each of the light sensitive pixels that provides a measure of irradiance that the pixel registers responsive to light reflected from light transmitted by the light source by a region of a calibration surface having known shape, reflectance, and location that the range camera images on the pixel; and a controller operable to determine a reflectance for a feature of the scene imaged on a first pixel of the photosensor comprised in the plurality of pixels responsive to the RSI for the feature and an RCI for a region of the calibration surface imaged on a second pixel of the photosensor corresponding to the feature imaged on the first pixel.
In an embodiment, the feature imaged on the first pixel and the corresponding region of the calibration surface imaged on the second pixel are imaged on their respective pixels with light they reflect from light transmitted along a same direction by the light source. The determined reflectance for the feature imaged on the first pixel may be a function of a ratio RSI/RCI times reflectance ρo of the corresponding region of the calibration surface.
In an embodiment, the range camera determines a distance vector R for the feature that defines a location of the feature in a field of view (FOV) of the camera relative to the optics and a distance vector R′ that defines a location for the feature imaged on the first pixel in the FOV relative to the light source and uses R and R′ to determine a location on the calibration surface of the corresponding region of the calibration surface. Optionally, the range camera determines a distance vector Ro for the corresponding region of the calibration surface in the FOV of the range camera relative to the optics, and a distance vector Ro′ that defines a location of the corresponding region in the FOV relative to a location of the light source responsive to the determined location of the corresponding region of the calibration surface.
In an embodiment, the reflectance for the feature imaged on the first pixel is proportional to ρo(RSI/RCI)[(|R|/|Ro|)(|R′|/|R′o|)]3 where ρo is reflectance of the corresponding region of the calibration surface.
Optionally, the calibration surface is oriented perpendicular to an optical axis of the camera at a fixed distance Zo from the optical center along the optical axis and the feature imaged on the first pixel is located at a distance Z from the optical center along the optical axis.
In an embodiment, the reflectance for the feature imaged on the first pixel is proportional to ρo(Zo/Z)4(RSI/RCI)[(|R|/|Ro|)(|R′|/|R′o|)]3 where ρo is reflectance of the corresponding region of the calibration surface.
In an embodiment of the disclosure, the controller is operable to determine a tilt factor TF for the feature imaged on the first pixel and use the tilt factor to determine the reflectance for the feature, wherein TF=[Z/(|R′|({circumflex over (R)}·{circumflex over (Z)}))][({circumflex over (R)}·{circumflex over (η)})/({circumflex over (R)}′·{circumflex over (η)})] and {circumflex over (η)} is a unit normal to a surface of the feature imaged on the first pixel, “Z” is distance of the feature from the optical center along the optical axis, and {circumflex over (R)} and {circumflex over (R)}′ are unit vectors pointing from the feature to the optical center and the light source respectively. Optionally, the reflectance for the feature imaged on the first pixel is proportional to TFρo(Zo/Z)4(RSI/RCI)[(|R|/|Ro|)(|R′|/|R′o|)]3 where ρo is a known reflectance of the region imaged on the second pixel. The controller may control the range camera to acquire a range image of the scene and determines {circumflex over (η)} responsive to a gradient of a surface of the feature defined by the range image.
In an embodiment of the disclosure, the reflectance of the calibration surface is substantially the same for all regions of the calibration surface having an RCI comprised in the calibration image. In an embodiment of the disclosure, the calibration surface is planar.
There is further provided in accordance with an embodiment of the disclosure a method of determining reflectance for a feature of a scene, the method comprising: using an active lighting range camera to acquire a range image and a picture image of the scene responsive to light transmitted by the range camera to illuminate the scene that is reflected by features in the scene back to the range camera; determining a location of the feature in the FOV responsive to the range image; determining registered irradiance of the range camera by light reflected from the transmitted light by the feature responsive to the picture image; determining a corresponding region of a calibration surface imaged in a calibration image acquired by the range camera; determining registered irradiance of the range camera by light reflected from the transmitted light by the corresponding region responsive to the calibration image; and using the determined registered irradiances from the feature and the corresponding calibration region and known reflectance of the calibration surface to determine the reflectance of the feature.
Optionally, determining the corresponding region of the calibration surface comprises determining a region of the calibration surface for which light from the range camera that illuminates the region to acquire the calibration image is transmitted along a same direction that the range camera illuminates the feature to acquire the picture image. Determining the reflectance of the feature may comprise multiplying the known reflectance by a ratio equal to the registered irradiance from the feature divided by the registered irradiance from the corresponding region.
The method may comprise determining a unit normal {circumflex over (η)} to a surface of the feature responsive to the range image and using the unit normal to determine the reflectance. Optionally, using the normal comprises determining a first distance vector from an optical center of the range camera to the feature responsive to the range image and determining a first scalar product of the normal with the first distance vector. Using the normal may comprise determining a second distance vector from a location from which the range camera transmits light to illuminate the scene to the feature responsive to the range image and determining a second scalar product of the normal with the second distance vector. Optionally, determining the reflectance comprises determining a ratio between the first scalar product and the second scalar product.
In the description and claims of the present application, each of the verbs, “comprise” “include” and “have”, and conjugates thereof, are used to indicate that the object or objects of the verb are not necessarily a complete listing of components, elements or parts of the subject or subjects of the verb.
Descriptions of embodiments of the disclosure in the present application are provided by way of example and are not intended to limit the scope of the disclosure. The described embodiments comprise different features, not all of which are required in all embodiments. Some embodiments utilize only some of the features or possible combinations of the features. Variations of embodiments of the disclosure that are described, and embodiments comprising different combinations of features noted in the described embodiments, will occur to persons of the art. The scope of the invention is limited only by the claims.
Number | Name | Date | Kind |
---|---|---|---|
5838428 | Pipitone | Nov 1998 | A |
6639594 | Zhang | Oct 2003 | B2 |
6876392 | Uomori | Apr 2005 | B1 |
8049163 | Granneman et al. | Nov 2011 | B1 |
8130292 | Lee | Mar 2012 | B2 |
8194149 | Thomas et al. | Jun 2012 | B2 |
9007457 | Levesque | Apr 2015 | B2 |
20030137646 | Hoffman | Jul 2003 | A1 |
20040070565 | Nayar | Apr 2004 | A1 |
20040201586 | Marschner | Oct 2004 | A1 |
20040263510 | Marschner | Dec 2004 | A1 |
20100026850 | Katz | Feb 2010 | A1 |
20100053592 | Yahav | Mar 2010 | A1 |
20110149041 | Eccles et al. | Jun 2011 | A1 |
20110176709 | Park | Jul 2011 | A1 |
20110211066 | Fujiki | Sep 2011 | A1 |
20120098976 | Matsushita | Apr 2012 | A1 |
20130100250 | Raskar | Apr 2013 | A1 |
20140002610 | Xi | Jan 2014 | A1 |
20140085625 | Ahmed et al. | Mar 2014 | A1 |
20140112574 | Kim et al. | Apr 2014 | A1 |
20140118501 | Kim et al. | May 2014 | A1 |
Number | Date | Country |
---|---|---|
2458927 | Oct 2009 | GB |
Entry |
---|
“Second Written Opinion Issued in PCT Application No. PCT/US2015/063568”, dated Aug. 5, 2016, 4 Pages. |
Raposo, et al., “Fast and Accurate Calibration of a Kinect Sensor”, In Proceedings of International Conference on 3D Vision, Jun. 29, 2013, 8 pages. |
Park, et al., “Real Time Rectification Using Differentially Encoded Lookup Table”, In Proceedings of the 5th International Conference on Ubiquitous Information Management and Communication, Feb. 21, 2011, 4 pages. |
Herrera C, et al., “Joint Depth and Color Camera Calibration with Distortion Correction”, In IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 34, Issue 10, May 29, 2012, 8 pages. |
“Computer Vision Group”, Published on: Jun. 18, 2012, Available at: https://vision.in.tum.de/data/datasets/rgbd-dataset/file_formats. |
“Depth Biomechanics”, Published on: Jan. 27, 2014, Available at: http://www.depthbiomechanics.co.uk/?p=2659. |
Ellmauthaler, et al., “A Novel Iterative Calibration Approach for Thermal Infrared Cameras”, In 20th IEEE International Conference on Image Processing, Sep. 15, 2013, pp. 2182-2186. |
“openni_launch/ Tutorials/ Extrinsic Calibration”, Retrieved on: Oct. 6, 2014, Available at: http://wiki.ros.org/openni_launch/Tutorials/ExtrinsicCalibration. |
Dunne, et al., “Efficient Generic Calibration Method for General Cameras with Single Centre of Projection”, In IEEE 11th International Conference on Computer Vision, Oct. 14, 2007, 8 pages. |
Abdo, et al., “3D Camera Calibration”, Retrieved on: Oct. 6, 2014, Available at: http://ais.informatik.uni-freiburg.de/teaching/ws09/robotics2/projects/mr2-p4-paper.pdf. |
Fuchs, et al., “Extrinsic and Depth Calibration of ToF-Cameras”, In IEEE Conference on Computer Vision and Pattern Recognition, Jun. 23, 2008, 6 pages. |
McIlroy, et al., “Kinectrack: Agile 6-DoF Tracking Using a Projected Dot Pattern”, In IEEE International Symposium on Mixed and Augmented Reality, Nov. 5, 2012, 7 pages. |
Staranowicz, et al., “Easy-to-Use and Accurate Calibration of RGB-D Cameras from Spheres”, In Proceedings of Image and Video Technology—6th Pacific-Rim Symposium, Oct. 28, 2013, 14 pages. |
U.S. Appl. No. 14/055,897, filed Oct. 17, 2013. |
International Search Report and Written Opinion issued in PCT Application No. PCT/US2015/063568, dated Mar. 3, 2016, 11 Pages. |
“International Preliminary Report on Patentability Issued in PCT Application No. PCT/US2015/063568”, dated Mar. 30, 2017, 5 Pages. |
Number | Date | Country | |
---|---|---|---|
20160178512 A1 | Jun 2016 | US |