The invention relates to augmented-reality technology.
In an area of emerging technology, “augmented reality”, a computer-generated image is superimposed on a user's view of the real world, thus providing a composite view. One context of augmented reality is in medicine and healthcare. See, e.g., Winner, et al., “Augmented Reality Imaging System for Cosmetic Surgical Procedures,” US 20170119471, published May 4, 2017; Gibby, et al. (Novarad Corp.), “Augmented reality viewing and tagging for medical procedures,” U.S. Pat. No. 10,010,379 issued Jul. 3, 2018.
Other contexts of augmented reality are outside of medicine or healthcare, such as in video gaming, virtual worlds, exercise and fitness, shopping/fashion, etc. See, e.g., Rublowsky, “Augmented Reality Simulator,” US 20150260474, published Sep. 17, 2015; Parisi, “Fantasy Sport Platform with Augmented Reality Player Acquisition,” US 20180036641, published Feb. 8, 2018; Henderson, “Incentivizing foodstuff consumption through the use of augmented reality features,” U.S. Pat. No. 10,019,628 issued Jul. 10, 2018; Bastide, et al (IBM), “Avatar-based augmented reality engagement,” U.S. Pat. No. 10,025,377 issued Jul. 17, 2018; Laughlin, (The Boeing Co.), “Portable augmented reality,” U.S. Pat. No. 10,026,227 issued Jul. 17, 2018; Yuen, et al. (Intel Corp.), “Scene modification for augmented reality using markers with parameters,” U.S. Pat. No. 10,026,228 issued Jul. 17, 2018; Fox, et al. (Liberty Mutual Ins. Co.), “Augmented reality insurance applications,” U.S. Pat. No. 10,032,225 issued Jul. 24, 2018; Papkipos, et al. (Facebook, Inc.) “Social context in augmented reality,” U.S. Pat. No. 10,032,233 issued Jul. 24, 2018; Aoki, et al. (Bally Gaming, Inc.), “Augmented reality for table games.” U.S. Pat. No. 10,046,232 issued Aug. 14, 2018; Zhang, et al. (Tencent Technology), “Method and system for performing interaction based on augmented reality,” U.S. Pat. No. 10,049,494 issued Aug. 14, 2018; Sisbot (Toyota), “Method of ground adjustment for in-vehicle augmented reality systems,” U.S. Pat. No. 10,049,499 issued Aug. 14, 2018; Morrison (3D Product Imaging Inc.), “Augmented reality e-commerce for home improvement,” U.S. Pat. No. 10,049,500 issued Aug. 14, 2018.
Techniques for acquiring images that might be useable and work in one context are not necessarily useful in another context, or may be too inaccurate or imprecise or prone to error, especially for medical and health care contexts. Various 3D imaging technology exists in medicine, but using relatively large equipment, and generally developed for diagnosis. Improvements in 3D imaging in a direction of acquiring images that will better work for augmented reality computer processing would be desirable.
To give one example, some imaging technology that has been proposed or attempted relies on color imaging, and an easy-to-use imaging device without the limitations and disadvantages of color-data processing could be advantageous.
The invention in one preferred embodiment provides an augmented reality method, comprising: operating an imaging device to acquire a 3D image; using the acquired 3D image, performing a detection algorithm that comprises capping or an interpolation method on a 2-dimensional grid in order to reconstruct a surface, wherein the step is performed by a computer or a processor and a surface reconstruction is generated; and, using the surface reconstruction, performing at least one augmented reality processing step, virtual reality processing step, authentic reality processing step, or mixed reality processing step, wherein the step is performed by a computer or a processor, such as, e.g. inventive methods wherein the acquired 3D image is an image of a wound, inventive methods wherein what is imaged in the device-operating step is other than a wound, inventive methods wherein a patient is imaged in the device-operating step, and the augmented reality is in a medical context, inventive methods wherein the acquired 3D image is of a non-wound, and the augmented reality is in a non-medical, non-health care context; inventive methods wherein a real animal (such as, e.g., a farm animal, a household pet, a zoo animal, etc.) is imaged, and the image is imported into a game; inventive methods wherein a body part is imaged; inventive methods wherein a healthy body part is imaged, and the image of the healthy body part is processed to construct an image of a proposed prosthesis and/or to construct prosthesis; inventive methods wherein the processing step is in gaming; inventive methods wherein the operating step is performed to image a patient in a first geography, and wherein the 3D image is simultaneously accessible to both a first medical doctor in a second geography and a second medical doctor in a third geography, wherein the first geography, second geography and third geography are remote from each other; inventive methods further comprising a step of expanding the 3D image; inventive methods further comprising a step of subjecting the 3D image to contrasting; inventive methods wherein the capping is an interpolation method on a 2D grid in order to “reconstruct” a skin surface; inventive methods comprising a step of solving a Laplace equation with Dirichlet boundary conditions; inventive methods wherein the method steps exclude any RGB data processing having been performed and without any other color-information data processing having been performed; inventive methods further comprising, using the acquired 3D image, performing a detection algorithm that comprises capping or an interpolation method on a 2-dimensional grid in order to reconstruct a surface; inventive methods further comprising performing steps of acquiring an image, previewing video images and selecting an Object, aiming at the center of the Object, at least one Object Scan step and at least one Object Detection step (such as, e.g. wherein the at least one Object Detection step comprises automatic detection of Object borders in the 3D depth image, Object capping and calculating an Object measurement); inventive methods further comprising rendering the 3D Object model from a perpendicular camera and generating a Z-buffer, converting the Z-buffer to depth image, defining a region of interest U for Object detection, Object capping, detecting rough Object boundaries and detecting refined Object boundaries; and other inventive methods.
An imaging device according to the invention is useable to acquire 3D images that can be subjected to computer processing steps such as in virtual reality technology, authentic reality technology, mixed reality technology, augmented reality technology, etc.
A significant advantage of the inventive technology is its usefulness in connection with a patient who suffers from a wound, to compute a Wound Volume Measurement, advantageously without any ruler, grid, marker (or such physical object) needing to have been placed on, or near, the patient (particularly, onto the patient wound or onto skin near the patient wound). For patient-related usages, the invention mainly contemplates a human patient, but also can be used in connection with a veterinary patient.
The inventive technology further is useable in connection with imaging a range of real-world objects and real-world living beings without any physical object needing to have been placed on, or near, the real-world object or living being. Post-imaging steps vary depending on what was imaged and on the application, such as a gaming application, a limb reconstruction application, etc.
We sometimes refer herein to “touchless”, by which we mean that the patient's wound and the wound's environ (or, in other embodiments, the real-world object or real-world living being) is untouched by any ruler, grid, marker, 3D camera, frame enclosure holding a 3D camera, or the like. For example, the inventive technology is useable to image a zoo animal from a safe distance, and the resulting imaged zoo animal is then useable, for example, in a game.
In one embodiment, an inventive augmented reality method comprises steps of: operating an imaging device to acquire a 3D image; using the acquired 3D image, performing a detection algorithm that comprises capping or an interpolation method on a 2-dimensional grid in order to reconstruct a surface; and performing at least one augmented reality processing step, virtual reality processing step, authentic reality processing step, or mixed reality processing step.
In the step of operating an imaging device to acquire a 3D image, examples of what is being imaged are, e.g., a real-world wound, a real-world object, a real-world living being.
In the step of operating an imaging device to acquire a 3D image, a preferred example of an imaging device is a 3D camera. Examples of a 3D camera for use in practicing the invention are, e.g., Real Sense 3D camera (manufactured by Intel); Orbbec Astra 3-D camera; ZED stereo 3-D camera by Stereolabs.
The invention may further be appreciated with reference to the following examples, without the invention being limited to these examples.
An imaging device according to this inventive Example is useable to acquire 3D images that can be subjected to computer processing steps. For example, an imaging device that we call “Presero” was constructed according to this example.
An imaging device was constructed as follows, according to a novel algorithm that consists of two main parts: wound detection and wound measurement.
The algorithm applies to a 3D model of a human body part containing a wound. The 3D model is obtained from a scan performed by an inventive application. The algorithm is not applied directly to the 3D model. Instead, the generated 3D model is rendered with camera parameters providing a good view of the wound (typically perpendicular to the wound or to the body part where the wound is), from which the algorithm acquires the Z-buffer (depth map) Z, calculated by the rendering process and the corresponding 4-by-4 projection matrix P as an input. The rendering process is based on OpenGL API (The Industry Standard for High Performance Graphics), and hence we use here the OpenGL terminology.
In addition, the algorithm gets a user defined outer-wound contour C as a hint for the wound location.
The algorithm does NOT use any color information.
Wound Detection
The following steps are performed.
1. Convert the Z-Buffer Z to the Depth Image D.
The conversion is given by:
where R={1, . . . , m}×{1, . . . , n}, m is a number of rows and n is a number of columns in Z and D.
2. Define a Region of Interest U for Wound Detection.
We include in U all (i,j) ∈ R laying inside C, except border pixels (i=1 or i=m or
j=1 or j=n) and except pixels which depth is too close to the far parameter of P, i.e.,
D(i,j)>(1−α)P(3,4)/(P(3,3)+1),
where α is a small positive constant.
3. Wound Capping.
We reconstruct skin surface S over the wound in order to enhance wound appearance by subtracting S from D.
(a) Calculate the First Approximation.
Since wound boundary is unknown yet, we start from the region U. Namely, we solve the following discrete Laplace equation with respect to S
4S(i,j)=S(i−1,j)−S(i+1,j)−S(i,j−1)−S(i,j+1)=0
if (i,j) ∈ U, and
S(i,j)=D(i,j)
if (i,j) ∈ R\U.
(b) Iteratively Raise the Capping if Required.
There is a possibility that the surface S is situated below the wound boundary. In this case S has to be raised. Let h be a maximum value of S−D. If, for some small tolerance threshold δ>0h>δ, then we find all pixels (i,j) ∈ U such that
S(i,j)−D(i,j)≥h−δ.
Assuming that these pixels are mostly (up to the threshold δ) outside the wound we redefine the region U by excluding these pixels from it. We return to the steps (3a) and (3b) with the updated region U. We proceed in this way until h≤δ or maximal allowed number of iterations is reached.
4. Detect a Wound.
To detect a wound we apply Chan-Vese algorithm (see T. Chan and L. Vese, Active contours without edges. IEEE Trans. Image Processing, 10 (2):266-277, February 2001) to the difference F=D−S. The Chan-Vese approach is to find among all 2-valued functions of the form
the one that minimizes the following energy functional,
μLength(∂W)+νArea(W)+λ1Σ(i,j)∈W(F(i,j)−c1)2+λ2Σ(i,j)∈R\W(F(i,j)−c2)2,
where ∂W denotes the boundary of W, μ>0, ν≥0, λ1>0, λ2>0 are fixed parameters.
Let W, c1 and c2 minimize the energy functional. We interpret W as a set of pixels belonging to the wound.
5. Correct Wound Boundary.
The wound boundary ∂W obtained in (4) is not accurate enough. It is located somewhere on the wound walls, but not necessarily on the top of them. We move it to the top as described below.
Starting from each pixel (i,j) ∈ ∂W we go in the direction orthogonal to ∂W and select a pixel (p(i,j), q(i,j)) located on the top of the wound wall by searching for the maximum value of the directional second derivative of the depth image D. Our intention is to move pixels (i,j) to pixels
(p(i,j), q(i,j)), but this operation can break continuity of the wound boundary.
Denote by dist(i,j,A) the euclidean distance from the pixel (i,j) to the set of pixels A. Let
Δ(i,j)=dist(i,j,W)−dist(i,j,R\W).
For any t>0, the set Wt={(i,j) ∈ R:Δ(i,j)<t} is an uniform expansion of W with size controlled by t, W0=W. In order to make this kind of expansion more flexible we replace t with a function T(i,j) which on the one hand has to be close to a constant, and on the other hand has to get values close to dist(p(i,j), q(i,j), W) at the pixels (p(i,j), q(i,j)).
We find T as the solution of the following optimization problem
Σi=2mΣj=1n[T(i,j)−T(i−1,j)]2+Σi=1mΣj=2n[T(i,j)−T(i,j−1)]2+ρΣ(i,j)∈∂W[T(p(i,j),q(i,j))−dist(p(i,j),q(i,j),W)]2→min,
where ρ>0 is a constant parameter. Finally, we declare
W*={(i,j)∈R: Δ(i,j)≤T(i,j)}
as a set of the wound pixels,
Wound Measurements
Formulas for calculating wound volume, maximal depth, area, perimeter, length and width are set forth below. Note that the last 4 measurements are calculated for wound projection onto a plane parallel to the camera image plane.
In order to calculate wound volume we perform capping again as described in (3a) using W* instead of U. Let S* be the result. We clamp it as follows
S*=min(S*,D).
Then
Tracing the wound boundary ∂W* we write down all pixels belonging to ∂W* as a sequence (i1,j1), (i2,j2), . . . , (iN,jN). Let Q be the inverse matrix of P and let for each k=1, . . . , N,
Put, in addition, X0=XN,Y0=YN and YN+1=Y1.
Then
WoundArea=|Σk=1NXk(Yk+1−Yk−1)|,
WoundPerimeter=Σk=1N√{square root over ((Xk−Xk−1)2+(Yk−Yk−1)2.)}
Assuming that a human body orientation is defined by an angle θ, wound length and width are given by
WoundLength=max{Xk cos θ+Yk sin θ,1≤k≤N}−min{Xk cos θ+Yk sin θ,1≤k≤N},
WoundWidth=max{−Xk sin θ+Yk cos θ,1≤k≤N}−min{−Xk sin θ+Yk cos θ,1≤k≤N}.
Optimal values for algorithm parameters in Example 1 are determined by testing the system on phantom wounds and other forms made from plasticine. For α (a small positive constant), 0.01 was chosen.
In this example, when an inventive device used according to an above example, an image was ready to view within 10 seconds of camera operation.
In this example, when an inventive device was used according to an above example, after a scan was completed, a 3D image was displayed to a user, and the displayed 3D image was subject to being manipulated by a finger of the user.
In this example according to Example 1C, a user manipulated a wound image on screen with the user's finger, including, the user looked behind and under a wound image on screen.
Referring to
Referring to
Referring to
Steps 303, 304, 305 are referred to as Wound Scan 306 steps.
Steps 308, 309, 310 are referred to as Wound Detection 311 steps.
Referring to
Referring to
Referring to
Referring to
Referring to
Referring to
In this example, an imaging device of Examples 1-1A is used to image something other than a wound.
In this example, when an imaging device was used according to any of Examples 1-2, an image was ready to view within 10 seconds of camera operation.
In this example, when an imaging device was used according to any of Examples 1-3, after a scan was completed, a 3D image was displayed to a user, and the displayed 3D image was subject to being manipulated by a finger of the user.
In this example according to Example 4, a user manipulated a wound image on screen with the user's finger, including to look behind and under a wound image on screen.
An imaging device for imaging an Object which may be other than a wound is constructed. A 3D model of the Object is obtained from a scan performed by the imaging application. The algorithm is not applied directly to the 3D model. Instead, the generated 3D model is rendered with camera parameters providing a good view of the Object (typically perpendicular to the Object or to the region where the Object is), from which the algorithm acquires the Z-buffer (depth map) Z, calculated by the rendering process and the corresponding 4-by-4 projection matrix P as an input. The rendering process is based on OpenGL API.
In addition, the algorithm gets a user defined outer-Object contour C as a hint for the Object location.
This Object-Detection part of the algorithm is represented by the following steps.
1. Convert the Z-buffer Z to the Depth Image D.
The conversion is given by
Where R=[1, . . . , m]×[1, . . . , n], m is a number of rows and n is a number of columns in Z And D.
2. Define a Region of Interest U for Object Detection.
We include in U all (i,j) ∈ R laying inside C, except border pixels (i=1 or i=m or j=1 or j=n) and except pixels which depth is too close to the far parameter of P, i.e.,
D(i,j)>(1−α)P(3,4)/(P(3,3)+1),
Where α is a small positive constant.
3. Object Capping.
We reconstruct skin surface S over the Object in order to enhance Object appearance by subtracting S from D.
(a) Calculate the First Approximation.
Because Object boundary is unknown yet, we start from the region U. Namely, we solve the following discrete Laplace equation with respect to S
4S(i,j)−S(i−1,j)−S(i+1,j)−S(i,j−1)−S(i,j+1)=0
if (i,j) ∈ U, and
S(i,j)=D(i,j)
if (i,j) ∈ R\U.
(b) Iteratively Raise the Capping if Required.
There is a possibility that the surface S is situated below the Object boundary. In this case S has to be raised. Let h be a maximum value of S−D. If, for some small tolerance threshold δ>0h>δ, then we find all pixels (i,j) ∈ U such that
S(i,j)−D(i,j)≥h−δ.
Assuming that these pixels are mostly (up to the threshold δ) outside the Object we redefine the region U by excluding these pixels from it. We return to the steps (3a) and (3b) with the updated region U. We proceed in this way till h≤δ or maximal allowed number of iterations is reached.
4. Detect an Object.
To detect an Object we apply Chan-Vese algorithm [1] to the difference F=D−S. The Chan-Vere approach is to find among all 2-valued functions of the form
the one that minimizes the following energy functional,
μLength(∂W)+νArea(W)+λ1Σ(i,j)∈W(F(i,j)−c1)2+λ2Σ(i,j)∈R\W(F(i,j)−c2)2,
Where ∂W denotes the boundary of W, μ>0, ν≥0, λ1>0, λ2>0 are fixed parameters.
Let W, c1 and c2 minimize the energy functional. We interpret W as a set of pixels belonging to the wound.
5. Correct Object Boundary.
The Object boundary ∂W obtained in (4) is not accurate enough. It is located somewhere on the Object walls, but not necessarily on the top of them. We move it to the top as described below.
Starting from each pixel (i,j) ∈ ∂W we go in the direction orthogonal to ∂W and select a pixel (p(i,j), q(i,j)) located on the top of the wound wall by searching for the maximum value of the directional second derivative of the depth image D. Our intention is to move pixels (i,j) to pixels (p(i,j), q(i,j)), but this operation can break continuity of the Object boundary.
Denote by dist(i,j,A) the euclidean distance from the pixel (i,j) to the set of pixels A. Let
Δ(i,j)=dist(i,j,W)−dist(i,j,R\W).
For any t>0, the set Wt={(i,j) ∈ R:Δ(i,j)<t} is an uniform expansion of W with size controlled by t, W0=W. In order to make this kind of expansion more flexible we replace t with a function T(i,j) which on the one hand has to be close to a constant, and on the other hand has to get values close to dist(p(i,j), q(i,j),W) at the pixels (p(i,j), q(i,j)).
We find T as the solution of the following optimization problem
Σi=2mΣj=1n[T(i,j)−T(i−1,j)]2+Σi=1mΣj=2n[T(i,j)−T(i,j−1)]2+ρΣ(i,j)∈∂W[T(p(i,j),q((i,j))=dist(p(i,j),q(i,j),W)]2→min,
where ρ>0 is a constant parameter. Finally, we declare
W*={(i,j)∈R:Δ(i,j)≤T(i,j)}
as a set of the Object pixels.
In this part we present formulas for calculating Object volume, maximal depth, area, perimeter, length and width. The last 4 measurements are calculated for Object projection onto a plane parallel to the camera image plane.
In order to calculate Object volume we perform capping again as described in (3a) using W* instead of U. Let S* be the result. We clamp it as follows
Tracing the Object boundary ∂W* we write down all pixels belonging to ∂W* as a sequence (i1,j1), (i2,j2), . . . , (iN,jN). Let Q be the inverse matrix of P and let for each k=1, . . . , N,
Put, in addition, X0=XN, Y0=YN and YN+1=Y1.
Then
ObjectArea=|Σk=1NXk(Yk+1−Yk−1)|,
ObjectPerimeter=Σk=1N√{square root over ((Xk−Xk−1)2+(Yk−Yk−1)2)}.
Assuming that a Locality orientation is defined by an angle θ, Object length and width are given by
ObjectLength=max{Xk cos θ+Yk sin θ,1≤k≤N}−min{Xk cos θ+Yk sin θ,1≤k≤N},
ObjectWidth=max[−Xk sin θ+Yk cos θ,1≤k≤N]−min[−Xk sin θ+Yk cos θ,1≤k≤N].
An example of an Object in Example 5.1 (Object Detection) above is an intact body part that is being 3D-imaged and the 3D image is processed in at least one prosthesis-modeling or prosthesis-construction steps.
The above described embodiments are set forth by way of example and are not limiting. It will be readily apparent that obvious modification, derivations and variations can be made to the embodiments. The claims appended hereto should be read in their full scope including any such modifications, derivations and variations.
Number | Name | Date | Kind |
---|---|---|---|
5923329 | Beale | Jul 1999 | A |
9251590 | Sharp | Feb 2016 | B2 |
9349183 | Douglas | May 2016 | B1 |
10010379 | Gibby | Jul 2018 | B1 |
10019628 | Henderson | Jul 2018 | B1 |
10025377 | Bastide et al. | Jul 2018 | B1 |
10026227 | Laughlin et al. | Jul 2018 | B2 |
10026228 | Yuen et al. | Jul 2018 | B2 |
10032225 | Fox et al. | Jul 2018 | B1 |
10032233 | Papakipos et al. | Jul 2018 | B2 |
10046232 | Aoki et al. | Aug 2018 | B2 |
10049494 | Zhang et al. | Aug 2018 | B2 |
10049499 | Sisbot | Aug 2018 | B2 |
10049500 | Morrison | Aug 2018 | B2 |
20050096515 | Geng | May 2005 | A1 |
20060176242 | Jaramaz | Aug 2006 | A1 |
20090316966 | Marshall | Dec 2009 | A1 |
20110299361 | Shin | Dec 2011 | A1 |
20130335445 | Bala | Dec 2013 | A1 |
20130342527 | Molyneaux | Dec 2013 | A1 |
20150260474 | Rublowsky | Sep 2015 | A1 |
20160143524 | Berard | May 2016 | A1 |
20170119471 | Winner | May 2017 | A1 |
20180036641 | Parisi | Feb 2018 | A1 |
20180182121 | Xu | Jun 2018 | A1 |
Entry |
---|
Vladislav Zorov, “Why there are not real pictures in computer games instead of only computer designed graphics?” www.quora.com/Why-there-are-not-real-pictures-in-compute . . . , Aug. 13, 2018. |
T. Chan and L. Vese, Active contours without edges. IEEE Trans. Image Processing, 10(2):266-277, Feb. 2001. |
Number | Date | Country | |
---|---|---|---|
20190066390 A1 | Feb 2019 | US |
Number | Date | Country | |
---|---|---|---|
62552090 | Aug 2017 | US |