The present invention relates to new and improved ways of carrying out ray tracing method having a reduced computational complexity.
Augmented reality (AR) is a live view of a physical, real-world environment whose elements are augmented by computer-generated graphics. Information about the augmented objects is overlaid onto the real world. Augmentation is conventionally in real time and in visual context with environmental elements. With the help of advanced AR technology, the information about the surrounding real world of the user becomes interactive and digitally manipulable. Because AR brings out the components of the digital world into a person's perceived real world, the user experiences and interacts with the augmented reality, strongly depend on the photo-realistic quality of the augmented object and its integration with the real environment.
In prior art, the graphics used in AR is based on the conventional raster technology. However, raster graphics are very mediocre due to the tradeoff of quality and speed, in favor of speed. Its visual context lacks such necessary elements of photo-realism as reflections, refractions, color bleeding, caustics, etc. The only graphics technology competent to deliver the required highest photo-realism is ray tracing, found today in the film industry.
Ray tracing is a computer graphics technique for generating images by tracing the rays of light and simulating the effects of their encounters with virtual objects. The idea behind ray-tracing is to find mathematical solutions to compute the intersection of a ray with various types of geometry, by solving the visibility between points. This technique is capable of producing a high visual realism. In low-end ray tracing, light sources are the only illuminating objects in the scene.
More realistic imaging is delivered by the high-end ray tracing, called path tracing, which is based on global illumination. Global illumination takes into account not only the light which comes directly from a light source, but also subsequent cases in which light is returned by other surfaces in the scene, whether reflective or not.
Path tracing, referred to as Monte Carlo ray tracing, renders a 3D scene by randomly tracing samples of light paths. Repeated sampling for any given pixel in the image will eventually cause the average of the samples to converge to the correct solution of a rendering equation, making it one of the most physically accurate 3D graphic rendering methods in existence. Path tracing can generate images that are faithful to reality, and are indistinguishable from photographs (e.g. the Avatar movie). The visual quality is higher than that of the low end ray tracing, but at a much greater computational cost.
The most time-consuming tasks in the ray tracing of prior art are traversals of acceleration structures, as well as intersection tests between rays and polygons. Every single ray is traversed across an accelerating structure (e.g. K-trees or BVH trees), seeking polygons that are candidates for intersection. These traversals become a major time-consuming action—they typically take 60%-70% of the image generation time. Then, many scene polygons located along a ray, must undergo a line-polygon intersection test, to determine the earliest hit along the ray's path.
The layout of the prior art ray tracing method is depicted in
There are two major drawbacks associated with the use of acceleration structures in ray tracing of prior art; (i) they must be repeatedly reconstructed for scene changes, and (ii) traversals of these structures are time-consuming. Both disadvantages contradict with the real-time requirements of AR.
Therefore, the primary object of the present invention is to introduce a global illumination ray tracing to AR and VR.
Another object of the present invention is to accelerate the performance of global illumination ray tracing up to real time, making it suitable for AR and VR.
Another object of the present invention is to reduce the computational complexity of ray tracing by making the prior art accelerating structures redundant.
Another object of the present invention is to further reduce the computational complexity of ray tracing by reducing and simplifying the intersection tests.
Another object of the present invention is to reduce the power consumption of ray tracing.
Yet another object of the present invention is to introduce global illumination ray tracing to the consumer level of computing devices.
Some embodiments of the current invention are applied to both augmented reality (AR) and virtual reality (VR). AR is a live view of a physical, real-world environment whose elements are augmented by computer-generated graphics. VR replaces the real world with a simulated one. Augmentation must be done in real time and in a convincing visual context with the surrounding real world (in AR) or computer generated (VR). The user's experience and interaction are directly affected by the level of realism.
In the prior art, the imaging of augmented objects is produced by the conventional raster graphics, due to its high speed. However, the ordinary raster graphics technology is mediocre in image quality and in visual context with the real-world environment. The desired image quality found today in the film industry, does not fit the AR because of its very high computational complexity, which causes long production times and requires expensive computing farms.
The present invention teaches an innovative way of delivering path tracing in real time, with reduced computational complexity and power consumption, and suitable to the processing level of consumer computing devices. Aspects of the present invention enable to concentrate on selected objects, generating their photo-realistic image, overlaid with a preset environment.
In the embodiments of the present invention, the Acceleration Structures of prior art are replaced by a new and novel device—a Dynamically Aligned Structure (DAS). DAS is a means for carrying out the intersection between the secondary rays and the scene geometry in large groups of rays, gaining a high speed and a reduced computational complexity.
The DAS is an aligned projection of rays, used to carry secondary rays associated with existing hit points. Instead of an individual shooting of secondary rays for every single hit point (or in small packets of rays), as in the prior art, we do it collectively, cutting the cost.
The invention is herein described, by way of non-limiting examples only, with reference to the accompanying figures and drawings, wherein like designations denote like elements. Understanding that these drawings only provide information concerning typical embodiments of the invention and are not therefore to be considered limiting in scope:
The principles and operation of an apparatus according to the present invention may be understood with reference to the figures and the accompanying description wherein similar components appearing in different figures are denoted by identical reference numerals. The drawings and descriptions are conceptual only. In actual practice, a single component can implement one or more functions; alternatively, each function can be implemented by a plurality of components and devices. It will be readily understood that the components of the present invention, as generally described and illustrated in the figures herein, could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of the embodiments of the apparatus, system, and method of the present invention, as represented in the figures herein, is not intended to limit the scope of the invention, as claimed, but is merely representative of embodiments of the invention.
Unless specifically stated otherwise, as apparent from the following discussions, it is appreciated that throughout the specification discussions, utilizing terms such as “processing”, “computing”, “calculating”, “determining”, “generating”, “creating” or the like, refer to the action and/or processes of a computer or computing system, or processor or similar electronic computing device, that manipulate and/or transform data represented as physical, such as electronic, quantities within the computing system's registers and/or memories into other data, similarly represented as physical quantities within the computing system's memories, registers or other such information storage, transmission or display devices.
Embodiments of the present invention may use terms such as processor, computer, apparatus, system, sub-system, module, unit, and device (in single or plural form) for performing the operations herein. This may be specially constructed for the desired purposes, or it may contain a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. Several technical terms specifically associated with our disclosure are herein defined.
Computer graphics pipeline refers to the most common form of computer 3D rendering, 3D polygon rendering, distinct from raytracing, and raycasting. In particular, in raycasting, a ray originates at the point where the camera resides, if that ray hits a surface, then the color and lighting of the point on the surface where the ray hit is calculated. In 3D polygon rendering the reverse happens, the area that is in view of the camera is calculated, and then rays are created from every part of every surface in view of the camera and traced back to the camera. The graphics pipeline is usually used in real-time rendering.
Rendering a projection is a 3D computer graphics process of automatically converting 3D wire frame models into 2D images rendering on a computer. The projection can be of a perspective, parallel, inverse or of another shape.
Render target is a feature of modern graphics processing units (GPUs) that allows a 3D scene to be rendered to an intermediate memory buffer, or Render Target Texture (RTT), instead of the frame buffer or back buffer. This RTT can then be manipulated by pixel shaders in order to make searches or apply effects to the final image.
Primary rays, are the first generation of rays in ray tracing, cast into the scene from camera or from eye to solve for visibility, i.e. to find whether the primary ray intersects a surface.
Secondary rays in ray tracing are spawned from primary rays at they ray-polygon intersection points. They are used to compute things like shadows, reflections, refractions, etc. Herein, we use the term collectively for all successive generations as well, such as for ternary rays, forth generation, etc.
Global illumination, is a general name of a group of algorithms used in 3D computer graphics that are meant to add more realistic lighting to 3D scenes, taking into account not only the light that comes directly from a light source (direct illumination), but also subsequent cases in which light rays from the same source are reflected by other surfaces in the scene, whether reflective or not (indirect illumination).
Color bleeding in computer graphics is the phenomenon in which objects or surfaces are colored by reflection of indirect light from nearby surfaces. This is a visible effect that appears when a scene is rendered with full global illumination.
Accelerating structures, such as grids, octrees, binary space partitioning trees (BSP trees), kd-trees and BVHs (bounding volume hierarchy), are used in ray tracing to solve for visibility, allowing improvement of render times in speed and efficiency, as compared to naïve ray tracing without accelerating structures.
GPGPU (general-purpose computing on graphics processing units) is the use of a graphics processing unit (GPU), which typically handles computation only for computer graphics, to perform computation in applications traditionally handled by the central processing unit (CPU).
Preset scene in AR, replaces the real time world. It is a preprocessed environment scene to contain the augmented object.
Object can stand for a primitive (polygon, triangle, solid, etc.), or a complex object made out of primitives.
Hit point is a point where a ray intersects an object. Termed also HIP.
Visibility—given a set of obstacles in the Euclidean space, two points in the space are said to be visible to each other, if the line segment that joins them does not intersect any obstacles.
Scene, a collection of 3D models and light sources in world space, into which a camera may be placed, describing a scene for 3D rendering. Scene model elements include geometric primitives: points or vertices; line segments or edges; polygons or faces.
Clipping, in the context of computer graphics, is a method to selectively enable or disable rendering operations within a defined region of interest.
BRDF
The processes/devices and displays presented herein are not inherently related to any particular computer or other apparatus, unless specifically stated otherwise. Various general purpose systems may be used with programs in accordance with the teachings herein, or it may prove convenient to construct a more specialized apparatus to perform the desired method. The desired structure for a variety of these systems will appear in the description below. In addition, embodiments of the present invention are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the inventions as described herein.
Diverting from prior art technologies, aspects of the present invention teach how to implement ray tracing at both a reduced computational complexity and a high speed. One aspect of the invention relates to path tracing, which is a high-quality ray tracing based on global illumination. Its superior performance stems from a different technological approach to solving the intersection between rays and scene objects. It is based on dynamically aligned structure (DAS), which is a projection of parallel rays, used to carry secondary rays emitting from existing hit points. The DAS mechanism can be implemented either by a GPU (graphics processing unit) graphics pipeline, or by a CPU (central processing unit). The mechanism can solve ray-triangle intersections by use of the conventional graphics mechanism, replacing the expensive traversals of accelerating structures in the prior art.
DAS mechanism. In one aspect the DAS mechanism is applied to path tracing, which is based on global illumination. Global illumination (or indirect illumination) takes into account not only the light that comes directly from a light source, but also light reflected by surfaces in the scene, whether specular, diffuse, or semi-reflective.
The basic mechanism of DAS is demonstrated in
According to an embodiment of the present invention, the DAS projection can be implemented by a CPU software graphics pipeline, but the most efficient device is the GPU hardware graphics pipeline. This well-known art computer graphics pipeline is the process of turning a 3D model into what the computer displays. A graphics pipeline consists of two subsystems: geometry and rasterization. First, all objects within the DAS frustum are transformed by the geometry sub-system, according to the camera view. Then, in the raster sub-system, a ray/triangle intersection point is selected by the Z-buffering mechanism. For example, the DAS ray 402 in
An exemplary cluster of three existing HIPs, with their underlying triangles, are shown, 405, 408 and 403. Secondary rays of HIPs 405, 408 are driven by the DAS structure. As an example, the carrier ray 402 runs into HIP 408. From the point of encounter with the HIP and onwards, it becomes a secondary ray 406, associated with the HIP, seeking for intersection 409. A DAS is relevant only to HIPs that have their hemispheres oriented toward the projection, like 405 and 408, but not 403. The DAS method is mathematically articulated as follows:
Let T be a tree-graph of d levels and let V be its vertices on top of geometries G in space.
Define Vd—vertices within V in level d.
Let Cd be a division of Vd to clusters.
We shall extend T to d+1 levels by finding Vd+1:
Choose cluster c∈Cd, with Vd
Instead of projecting every vertex v∈Vd
We optimize Cd/Lc in throughput/overfitting to have:
Lc is chosen to have a pseudo-random output, representing a possible segment of distribution for each v∈Vd
Multiple DAS projections are shot at a scene or part thereof, in slightly different directions; each direction can be taken in a random manner. As a result, multiple samples of the neighborhood can be taken at each HIP, for global illumination. This is illustrated in
There may be various ways to make use of the HIPs that are generated by successive DAS projections. According to one embodiment, shown in
Secondary rays are meant to intersect with scene objects, as demonstrated in
According to one embodiment of the present invention, the DAS projection utilizes the Z-buffering mechanism of GPU, as illustrated in
The DAS flowchart in
Various cases of secondary rays are shown In
The DAS mechanism of the present invention is implementable, among other fields, in AR. One of its embodiments enables a localized path tracing, focused on rendering of one or a few objects in the scene, and on a perfect integration between the augmented objects and the real environment.
Direct imaging of an augmented object. The basic image of the augmented object can be reconstructed just from the primary HIPs that cover the object's surface. However, for a global illumination effect, such as the environment reflected in the object, secondary rays shot from the object to its environment are required. The rendering task of the augmented object 110 is shown in
The shootings of primary rays are repeated while tilted, each with a slight change of direction, such that multi-sampling in the image pixels 112 is attained. The change of directions is done in a random fashion, in order to prevent unwanted patterns in the image. Multi-sampling contributes to an antialiased quality of the image. In
A truthful appearance of the augmented object as an integral part of the scene, is achieved by global illumination. The relevant environment for global illumination is sampled by secondary rays, shot from primary HIPs toward a relevant part of the scene. The relevant parts of the scene are those visible from the camera reflected in the object, if the object is reflective. For example, such a relevant part can be the sub-scene 123 in
The secondary rays are generated by DAS structures, either of perspective projection as in
Since all the successive DAS projections are targeting the same sub-scene 123, this sub-scene can be clipped out from the full scene, to enable a rendering operations within a reduced region, thus minimizing the rendering process.
Each of the multiple DAS projections is generated randomly from a slightly different point of view and in a different direction, creating multiple secondary rays at each HIP. The use of randomness prevents the appearance of unwanted patterns in the image. Secondary rays sample global illumination for a HIP (
The more projections of DAS, the better covering of global illumination. However, more projections may impair the performance. Therefore, there is a trade-off between image quality and performance.
The method of generating a direct image of an augmented object is summarized in a flowchart in
Reflecting the augmented object. Reflection of the object's image in the environment items is accomplished by following a ray from the camera to the surface at the scene, and then bouncing toward the augmented object. Reflection on a shiny surface or tile enhances the photo-realistic effects of a 3D rendering. The extent of reflection depends on surface's reflectivity (the BRDF of the material).
First, the reflective or semi-reflective surfaces (or items) in the real scene, which may reflect the augmented object, must be identified. Then we shoot primary rays at the surface in which the object is intended to be reflected, or part thereof, generating primary HIPs. From these HIPs, we shoot secondary rays targeting and sampling the augmented object. This way of generating reflections is illustrated in
The DAS 135, shown in
In order to take a spectral sampling of the BRDF function at a HIP, the multiple DAS projections are randomly deviated from the reference DAS projection—the one that starts at the reference point and has an axis of projection directed at the center of the augmented object. The inclination from the referenced DAS is done randomly, slightly deviating from the reference point 142 and central axis 145, as shown in
The relation between the deviation of a DAS secondary ray from the reference DAS, and its contribution to the aggregated light energy, is shown in
The way of generating a reflected image of an augmented object is summarized in the flowchart in
Color bleeding is the phenomenon in which objects or surfaces are colored by reflection of indirect light from nearby surfaces. It is a global illumination algorithm in the sense that the illumination arriving at a surface comes not just directly from the light sources, but also from other surfaces reflecting light. Color bleeding is viewpoint-independent, which makes it useful for all viewpoints. The color bleeding effect in AR or VR would occur in the direct neighborhood of the augmented object. An example of generating a color bleeding effect by an embodiment of the present invention is illustrated in
The way of generating color bleeding is summarized in the flowchart of
Collecting light and color values. The values of all samples in an HIP must be processed by a correct rendering equation for a physically accurate result. Parameters that are taken into account are the surface material, the geometry of the scene, the active area of the hemisphere, and others. For a specific image pixel, the light contribution of all HIPs generated by primary shots from the pixel, and all their secondary successors, must be aggregated, processed, and converged into the source pixel for image. As shown in
Implementation. The core of the present invention is the DAS mechanism. When implemented in path tracing, it generates secondary rays and locates their intersection with scene objects, excluding the use of accelerating structures of prior art. The DAS mechanism, which is based on a conventional raster graphics pipeline, is implementable either by a GPU hardware pipeline, or by a CPU software pipeline. The parallel structure of GPU makes it more efficient for graphics pipeline than general-purpose CPU. A GPU is a specialized electronic circuit designed to accelerate the graphics pipeline. Where a CPU consists of a few cores focused on sequential serial processing, GPUs pack thousands of smaller cores designed for multitasking. There are two main types of graphics processor: integrated and discrete. The DAS can be either utilized by a separate component in a system (discrete GPU), or by an embedded GPU on the CPU die (integrated GPU). Integrated GPU is used in embedded systems, mobile phones, personal computers, workstations, and game consoles.
The computing tasks that create the augmented objects and their visual context within the preset scene, as described in a great detail hereinbefore, are mostly based on graphics pipeline. For these tasks, the use of GPU is a great advantage. There is also additional task of collecting the sampled values of global illumination, processing these values according to the rendering equation, and converging the results in the image pixels. The collecting task, being associated with conventional processing, can be implemented either by a CPU or by a GPGPU. There is also an additional task, associated with user's viewing device 171, shown in
Consequently, the embodiments of the present invention call for a combined implementation of CPUs and GPUs, as generally shown in
Integrated graphics means that the GPU is integrated onto the CPU die and shares memory with the processor. Since integrated GPUs rely on the system RAM, they don't have the computing power of their discrete counterparts that are contained on their own card and come equipped with their own memory, VRAM. Integrated GPU has a lower memory bandwidth from system RAM, compared to discrete graphics cards between their VRAM and GPU core. This bandwidth is what is referred to as the memory bus and can be performance limiting. Moreover, as a GPU is extremely memory intensive, integrated processing may find itself competing with the CPU for the relatively slow system RAM, as it has minimal or no dedicated video memory. For the best possible graphics performance, discrete graphics chips outperform integrated GPUs.
On the other hand, sharing the same RAM memory can also be a benefit, as the graphics cores on a multicore chip can better collaborate with CPU cores for exchange big data. The pure graphics tasks of imaging objects, reflections and color bleeding produce big data of light values, that must be collected and calculated for rendering equation by the CPU cores.
However, despite the performance advantage of a discrete GPU, it is desirable to use integrated GPU for implementation of the present invention in such applications as augmented reality, virtual reality, and computer games, for its better power-efficiency, affordability, portability and versatility. Integrated GPU, as a constituent of a multicore CPU chip, is used in embedded systems, mobile phones, tablets and game consoles.
In addition to quest of use of discrete GPU or integrated GPU, there is also an alternative of using a hybrid system having discrete and integrated GPUs, collaborating and alternating, depending on the task.
This application is a Continuation of U.S. patent application Ser. No. 17/175,644, filed Feb. 13, 2021, which is a Continuation of U.S. patent application Ser. No. 16/788,792, filed Feb. 12, 2020 (now U.S. Pat. No. 10,930,053), which is a Continuation of U.S. patent application Ser. No. 16/004,348, filed Jun. 9, 2018, (now U.S. Pat. No. 10,614,612), which is a Continuation of U.S. patent application Ser. No. 15/659,618, filed Jul. 26, 2017 (now U.S. Pat. No. 10,410,401), which is a Continuation of U.S. patent application Ser. No. 15/615,037, filed Jun. 6, 2017 (now U.S. Pat. No. 10,297,068), which claims the benefit of priority to U.S. Provisional Application Ser. No. 62/354,755, filed Jun. 26, 2016, and U.S. Provisional Application Ser. No. 62/408,730, filed Oct. 15, 2016. U.S. patent application Ser. No. 15/615,037 is also a Continuation-In-Part of U.S. patent application Ser. No. 15/376,580, filed Dec. 12, 2016, and a Continuation-In-Part of U.S. patent application Ser. No. 15/009,442, filed Jan. 28, 2016 (now U.S. Pat. No. 9,741,160), each of which are incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
5442733 | Kaufman et al. | Aug 1995 | A |
6359618 | Heirich | Mar 2002 | B1 |
6621925 | Ohmori et al. | Sep 2003 | B1 |
6911984 | Sabella et al. | Jun 2005 | B2 |
6967663 | Bastos et al. | Nov 2005 | B1 |
7212207 | Green et al. | May 2007 | B2 |
9424685 | Howson et al. | Aug 2016 | B2 |
9483865 | Bakalash | Nov 2016 | B2 |
9576389 | Lee et al. | Feb 2017 | B2 |
9607426 | Peterson | Mar 2017 | B1 |
9672654 | Shin et al. | Jun 2017 | B2 |
9697640 | Obert et al. | Jul 2017 | B2 |
9741160 | Bakalash | Aug 2017 | B2 |
10204442 | Bakalash et al. | Feb 2019 | B2 |
10217268 | Bakalash et al. | Feb 2019 | B2 |
10229527 | Bakalash et al. | Mar 2019 | B2 |
10297068 | Bakalash et al. | May 2019 | B2 |
10332304 | Bakalash | Jun 2019 | B1 |
10395415 | Bakalash | Aug 2019 | B2 |
10395416 | Bakalash | Aug 2019 | B2 |
10403027 | Bakalash et al. | Sep 2019 | B2 |
10410401 | Bakalash et al. | Sep 2019 | B1 |
10565776 | Bakalash | Feb 2020 | B2 |
10614612 | Bakalash et al. | Apr 2020 | B2 |
10699468 | Bakalash et al. | Jun 2020 | B2 |
10789759 | Bakalash et al. | Sep 2020 | B2 |
10930053 | Bakalash et al. | Feb 2021 | B2 |
10950030 | Bakalash et al. | Mar 2021 | B2 |
11017582 | Bakalash et al. | May 2021 | B2 |
11302058 | Bakalash et al. | Apr 2022 | B2 |
11481955 | Bakalash et al. | Oct 2022 | B2 |
20070257911 | Bavoil et al. | Nov 2007 | A1 |
20080088622 | Shearer | Apr 2008 | A1 |
20080100617 | Keller et al. | May 2008 | A1 |
20080231627 | Shearer | Sep 2008 | A1 |
20090073167 | Brown et al. | Mar 2009 | A1 |
20090073187 | Rampson et al. | Mar 2009 | A1 |
20090102844 | Deparis | Apr 2009 | A1 |
20090128552 | Fujiki et al. | May 2009 | A1 |
20090128562 | McCombe et al. | May 2009 | A1 |
20090167763 | Waechter et al. | Jul 2009 | A1 |
20090213115 | Keller et al. | Aug 2009 | A1 |
20100053162 | Dammertz et al. | Mar 2010 | A1 |
20100060637 | Shearer | Mar 2010 | A1 |
20100079457 | Tavenrath | Apr 2010 | A1 |
20100239185 | Fowler et al. | Sep 2010 | A1 |
20110066682 | Aldunate et al. | Mar 2011 | A1 |
20120069023 | Hur et al. | Mar 2012 | A1 |
20120213430 | Nutter et al. | Aug 2012 | A1 |
20130120385 | Krishnaswamy et al. | May 2013 | A1 |
20130190602 | Liao et al. | Jul 2013 | A1 |
20140049539 | Lee et al. | Feb 2014 | A1 |
20140078143 | Lee et al. | Mar 2014 | A1 |
20140375641 | Bakalash | Dec 2014 | A1 |
20140375645 | Bakalash | Dec 2014 | A1 |
20150042655 | Gautron et al. | Feb 2015 | A1 |
20150109302 | Lee et al. | Apr 2015 | A1 |
20150172641 | Nakamura et al. | Jun 2015 | A1 |
20160005209 | Dachsbacher | Jan 2016 | A1 |
20160027204 | Lee et al. | Jan 2016 | A1 |
20160055608 | Frascati et al. | Feb 2016 | A1 |
20160155258 | Bakalash | Jun 2016 | A1 |
20160284118 | Howson et al. | Sep 2016 | A1 |
20170061674 | Lee et al. | Mar 2017 | A1 |
20170103567 | Peterson | Apr 2017 | A1 |
20170109931 | Knorr et al. | Apr 2017 | A1 |
20170178398 | Afra et al. | Jun 2017 | A1 |
20170236247 | Akenine-Moller | Aug 2017 | A1 |
20170236325 | Lecocq et al. | Aug 2017 | A1 |
20170372508 | Schoeneman | Dec 2017 | A1 |
20180350128 | Bakalash et al. | Dec 2018 | A1 |
20180365880 | Bakalash et al. | Dec 2018 | A1 |
20180374255 | Bakalash et al. | Dec 2018 | A1 |
20180374256 | Bakalash et al. | Dec 2018 | A1 |
20180374257 | Bakalash et al. | Dec 2018 | A1 |
20190057544 | Lecocq et al. | Feb 2019 | A1 |
20190147637 | Bakalash et al. | May 2019 | A1 |
20190180496 | Bakalash | Jun 2019 | A1 |
20190180497 | Bakalash | Jun 2019 | A1 |
20190188897 | Bakalash | Jun 2019 | A1 |
20190304162 | Bakalash | Oct 2019 | A1 |
20190304163 | Bakalash | Oct 2019 | A1 |
20190378323 | Bakalash et al. | Dec 2019 | A1 |
20200058155 | Bakalash et al. | Feb 2020 | A1 |
20200143581 | Bakalash et al. | May 2020 | A1 |
20200175743 | Bakalash et al. | Jun 2020 | A1 |
20200219305 | Bakalash et al. | Jul 2020 | A1 |
20200320773 | Bakalash et al. | Oct 2020 | A1 |
20200380764 | Bakalash et al. | Dec 2020 | A1 |
20200410744 | Bakalash et al. | Dec 2020 | A1 |
20210166463 | Bakalash et al. | Jun 2021 | A1 |
20210201560 | Bakalash et al. | Jul 2021 | A1 |
20210279941 | Bakalash et al. | Sep 2021 | A1 |
20220198740 | Bakalash et al. | Jun 2022 | A1 |
Number | Date | Country |
---|---|---|
WO-2015192117 | Dec 2015 | WO |
Entry |
---|
“U.S. Appl. No. 14/479,322, Final Office Action dated Jun. 4, 2015”, 19 pgs. |
“U.S. Appl. No. 14/479,322, Non Final Office Action dated Jan. 22, 2015”, 26 pgs. |
“U.S. Appl. No. 14/479,322, Notice of Allowance dated Aug. 29, 2016”, 8 pgs. |
“U.S. Appl. No. 14/479,322, Notice of Non-Compliant Amendment dated Apr. 29, 2015”, 2 pgs. |
“U.S. Appl. No. 14/479,322, Notice of Non-Compliant Amendment dated Jul. 29, 2016”, 3 pgs. |
“U.S. Appl. No. 14/479,322, Response filed Feb. 22, 2016 to Final Office Action dated Jun. 4, 2015”, 9 pgs. |
“U.S. Appl. No. 14/479,322, Response filed Apr. 22, 2015 to Non Final Office Action dated Jan. 22, 2015”, 10 pgs. |
“U.S. Appl. No. 14/479,322, Response filed May 21, 2015 to Notice of Non-Compliant Amendment dated Apr. 29, 2015”, 10 pgs. |
“U.S. Appl. No. 14/479,322, Response filed Aug. 15, 2016 to Notice of Non-Compliant Amendment dated Jul. 29, 2016”, 10 pgs. |
“U.S. Appl. No. 15/009,442, Non Final Office Action dated Mar. 21, 2017”, 9 pgs. |
“U.S. Appl. No. 15/009,442, Notice of Allowance dated Jun. 29, 2017”, 5 pgs. |
“U.S. Appl. No. 15/009,442, Response filed Jun. 12, 2017 to Non Final Office Action dated Mar. 21, 2017”, 4 pgs. |
“U.S. Appl. No. 15/615,037, Final Office Action dated Jul. 11, 2018”, 13 pgs. |
“U.S. Appl. No. 15/615,037, Non Final Office Action dated Sep. 27, 2017”, 15 pgs. |
“U.S. Appl. No. 15/615,037, Notice of Allowance dated Jan. 15, 2019”, 5 pgs. |
“U.S. Appl. No. 15/615,037, Notice of Non-Compliant Amendment dated Dec. 26, 2017”, 3 pgs. |
“U.S. Appl. No. 15/615,037, Response filed Jan. 7, 2019 to Final Office Action dated Jul. 11, 2018”, 4 pgs. |
“U.S. Appl. No. 15/615,037, Response filed Feb. 21, 2018 to Notice of Non-Compliant Amendment dated Dec. 26, 2017”, 5 pgs. |
“U.S. Appl. No. 15/615,037, Response filed Nov. 13, 2017 to Non Final Office Action dated Sep. 27, 2017”, 5 pgs. |
“U.S. Appl. No. 15/615,037, Response filed Dec. 31, 2018 to Final Office Action dated Jul. 11, 2018”, 4 pgs. |
“U.S. Appl. No. 15/640,464, 312 Amendment filed Dec. 10, 2018”, 3 pgs. |
“U.S. Appl. No. 15/640,464, Final Office Action dated Dec. 27, 2017”, 14 pgs. |
“U.S. Appl. No. 15/640,464, Non Final Office Action dated Mar. 30, 2018”, 11 pgs. |
“U.S. Appl. No. 15/640,464, Non Final Office Action dated Sep. 27, 2017”, 17 pgs. |
“U.S. Appl. No. 15/640,464, Notice of Allowance dated Oct. 26, 2018”, 5 pgs. |
“U.S. Appl. No. 15/640,464, PTO Response to Rule 312 Communication dated Dec. 13, 2018”, 2 pgs. |
“U.S. Appl. No. 15/640,464, Response filed Mar. 12, 18 to Final Office Action dated Dec. 27, 2017”, 1 pg. |
“U.S. Appl. No. 15/640,464, Response filed Nov. 13, 2017 to Non Final Office Action dated Sep. 27, 2017”, 6 pgs. |
“U.S. Appl. No. 15/640,466, Ex Parte Quayle Action dated Oct. 15, 2018”, 4 pgs. |
“U.S. Appl. No. 15/640,466, Final Office Action dated Apr. 3, 2018”, 9 pgs. |
“U.S. Appl. No. 15/640,466, Non Final Office Action dated Oct. 5, 2017”, 11 pgs. |
“U.S. Appl. No. 15/640,466, Notice of Allowance dated Jan. 28, 2019”, 5 pgs. |
“U.S. Appl. No. 15/640,466, Notice of Allowance dated Dec. 26, 2018”, 7 pgs. |
“U.S. Appl. No. 15/640,466, Response filed Mar. 5, 2018 to Non Final Office Action dated Oct. 5, 2017”, 4 pgs. |
“U.S. Appl. No. 15/640,466, Response filed Sep. 19, 2018 to Final Office Action dated Apr. 3, 2018”, 5 pgs. |
“U.S. Appl. No. 15/640,466, Response filed Dec. 10, 2018 to Ex Parte Quayle Action dated Oct. 15, 2018”, 6 pgs. |
“U.S. Appl. No. 15/640,467, 312 Amendment filed Dec. 10, 2018”, 3 pgs. |
“U.S. Appl. No. 15/640,467, Corrected Notice of Allowability dated Oct. 22, 2018”, 4 pgs. |
“U.S. Appl. No. 15/640,467, Final Office Action dated Apr. 3, 2018”, 9 pgs. |
“U.S. Appl. No. 15/640,467, Non Final Office Action dated Oct. 4, 2017”, 11 pgs. |
“U.S. Appl. No. 15/640,467, Notice of Allowance dated Oct. 3, 2018”, 7 pgs. |
“U.S. Appl. No. 15/640,467, PTO Response to Rule 312 Communication dated Dec. 17, 2018”, 2 pgs. |
“U.S. Appl. No. 15/640,467, Response filed Mar. 5, 2018 to Non Final Office Action dated Oct. 4, 2017”, 4 pgs. |
“U.S. Appl. No. 15/640,467, Response filed Sep. 23, 2018 to Final Office Action dated Apr. 3, 2018”, 6 pgs. |
“U.S. Appl. No. 15/659,618, Non Final Office Action dated Oct. 30, 2017”, 11 pgs. |
“U.S. Appl. No. 15/659,618, Notice of Allowance dated Apr. 10, 2018”, 7 pgs. |
“U.S. Appl. No. 15/659,618, PTO Response to Rule 312 Communication dated Jun. 19, 2018”, 2 pgs. |
“U.S. Appl. No. 15/659,618, Response filed Mar. 5, 2018 to Non Final Office Action dated Oct. 30, 2017”, 8 pgs. |
“U.S. Appl. No. 16/004,348, 312 Amendment filed Feb. 12, 2020”, 3 pgs. |
“U.S. Appl. No. 16/004,348, Advisory Action dated Jun. 5, 2019”, 3 pgs. |
“U.S. Appl. No. 16/004,348, Final Office Action dated Apr. 1, 2019”, 17 pgs. |
“U.S. Appl. No. 16/004,348, Non Final Office Action dated Aug. 8, 2019”, 9 pgs. |
“U.S. Appl. No. 16/004,348, Non Final Office Action dated Oct. 30, 2018”, 17 pgs. |
“U.S. Appl. No. 16/004,348, Notice of Allowance dated Nov. 14, 2019”, 8 pgs. |
“U.S. Appl. No. 16/004,348, Response filed Feb. 11, 2019 to Non Final Office Action dated Oct. 30, 2018”, 6 pgs. |
“U.S. Appl. No. 16/004,348, Response filed May 27, 2019 to Final Office Action dated Apr. 1, 2019”, 10 pgs. |
“U.S. Appl. No. 16/004,348, Response filed Jun. 23, 2019 to Advisory Action dated Jun. 5, 2019”, 10 pgs. |
“U.S. Appl. No. 16/004,348, Response filed Oct. 31, 2019 to Non Final Office Action dated Aug. 8, 2019”, 5 pgs. |
“U.S. Appl. No. 16/004,348, Supplemental Notice of Allowability dated Mar. 9, 2020”, 4 pgs. |
“U.S. Appl. No. 16/231,520, Final Office Action dated Apr. 10, 2019”, 6 pgs. |
“U.S. Appl. No. 16/231,520, Non Final Office Action dated Jan. 30, 2019”, 7 pgs. |
“U.S. Appl. No. 16/231,520, Notice of Allowance dated May 17, 2019”, 5 pgs. |
“U.S. Appl. No. 16/231,520, Notice of Allowance dated Jul. 26, 2019”, 5 pgs. |
“U.S. Appl. No. 16/231,520, Response filed Mar. 27, 2019 to Non Final Office Action dated Jan. 30, 2019”, 6 pgs. |
“U.S. Appl. No. 16/231,520, Response filed May 5, 2019 to Final Office Action dated Apr. 10, 2019”, 6 pgs. |
“U.S. Appl. No. 16/275,366, Non Final Office Action dated Apr. 1, 2019”, 8 pgs. |
“U.S. Appl. No. 16/275,366, Notice of Allowance dated May 13, 2019”, 7 pgs. |
“U.S. Appl. No. 16/275,366, Response filed Apr. 21, 2019 to Non Final Office Action dated Apr. 1, 2019”, 3 pgs. |
“U.S. Appl. No. 16/275,371, Non Final Office Action dated Apr. 1, 2019”, 10 pgs. |
“U.S. Appl. No. 16/275,371, Notice of Allowance dated May 10, 2019”, 7 pgs. |
“U.S. Appl. No. 16/275,371, Response filed Apr. 21, 2019 to Non Final Office Action dated Apr. 1, 2019”, 3 pgs. |
“U.S. Appl. No. 16/275,907, Non Final Office Action dated Apr. 10, 2019”, 6 pgs. |
“U.S. Appl. No. 16/275,907, Notice of Allowance dated May 13, 2019”, 5 pgs. |
“U.S. Appl. No. 16/275,907, Response filed Apr. 21, 2019 to Non Final Office Action dated Apr. 10, 2019”, 3 pgs. |
“U.S. Appl. No. 16/444,464, Non Final Office Action dated Jul. 9, 2019”, 14 pgs. |
“U.S. Appl. No. 16/444,464, Notice of Allowance dated Oct. 11, 2019”, 7 pgs. |
“U.S. Appl. No. 16/444,464, Response filed Oct. 3, 2019 to Non Final Office Action dated Jul. 9, 2019”, 5 pgs. |
“U.S. Appl. No. 16/662,657, Non Final Office Action dated Dec. 19, 2019”, 6 pgs. |
“U.S. Appl. No. 16/662,657, Notice of Allowance dated Mar. 23, 2020”, 5 pgs. |
“U.S. Appl. No. 16/662,657, Preliminary Amendment filed Nov. 15, 2019”, 3 pgs. |
“U.S. Appl. No. 16/662,657, Response filed Mar. 10, 2020 to Non Final Office Action dated Dec. 19, 2019”, 8 pgs. |
“U.S. Appl. No. 16/736,848, 312 Amendment filed Aug. 4, 2020”, 3 pgs. |
“U.S. Appl. No. 16/736,848, Non Final Office Action dated Feb. 11, 2020”, 16 pgs. |
“U.S. Appl. No. 16/736,848, Notice of Allowance dated May 14, 2020”, 7 pgs. |
“U.S. Appl. No. 16/736,848, Response filed May 5, 2020 to Non Final Office Action dated Feb. 11, 2020”, 3 pgs. |
“U.S. Appl. No. 16/788,792, Non Final Office Action dated Apr. 3, 2020”, 12 pgs. |
“U.S. Appl. No. 16/788,792, Notice of Allowance dated Oct. 22, 2020”, 8 pgs. |
“U.S. Appl. No. 16/788,792, Response filed Jun. 10, 2020 to Non Final Office Action dated Apr. 3, 2020”, 6 pgs. |
“U.S. Appl. No. 16/909,063, Non Final Office Action dated Aug. 25, 2020”, 8 pgs. |
“U.S. Appl. No. 16/909,063, Notice of Allowance dated Nov. 23, 2020”, 5 pgs. |
“U.S. Appl. No. 16/909,063, Response filed Nov. 8, 2020 to Non Final Office Action dated Aug. 25, 2020”, 5 pgs. |
“U.S. Appl. No. 16/994,615, Non Final Office Action dated Aug. 25, 2020”, 17 pgs. |
“U.S. Appl. No. 16/994,615, Notice of Allowance dated Feb. 1, 2021”, 7 pgs. |
“U.S. Appl. No. 16/994,615, Response filed Nov. 8, 2020 to Non Final Office Action dated Aug. 25, 2020”, 3 pgs. |
“U.S. Appl. No. 17/175,644, Notice of Allowance dated Jun. 20, 2022”, 9 pgs. |
“U.S. Appl. No. 17/175,644, Supplemental Notice of Allowability dated Jul. 7, 2022”, 2 pgs. |
“U.S. Appl. No. 17/183,395, Non Final Office Action dated Jul. 28, 2021”, 8 pgs. |
“U.S. Appl. No. 17/183,395, Notice of Allowance dated Dec. 20, 2021”, 5 pgs. |
“U.S. Appl. No. 17/183,395, Response filed Dec. 2, 2021 to Non Final Office Action dated Jul. 28, 2021”, 7 pgs. |
Alwani, Rishi, “Microsoft and Nvidia Tech to Bring Photorealistic Games With Ray Tracing”, Gadgets 360, [Online] Retrieved from the Internet: <URL: https://gadgets.ndtv.com/laptops/news/microsoft-dxr-nvidia-rtx-ray-tracing-volta-gpu-metro-exodus-1826988>, (Mar. 21, 2018), 8 pgs. |
Beck, et al., “CPU-GPU hybrid real time ray tracing framework”, vol. 0 (1981), (2005), 1-8. |
Bikker, J, “Real-time ray tracing through the eyes of a game developer”, In: Proceedings of the 2007 IEEE Symposium on Interactive Ray Tracing, Washington, DC, USA, IEEE Computer Society, (2007), 10 pgs. |
Broecker, Markus, et al., “Adapting ray tracing to spatial augmented reality”, Mixed and Augmented Reality (ISMAR), 2013 IEEE International Symposium on. IEEE, (2013). |
Celarek, Adam, “Merging ray tracking and rasterization in mixed reality”, Vienna University of Technology, (2012). |
Chen, C. C, et al., “Use of hardware z-buffered rasterization to accelerate ray tracing”, In: Proceedings of the 2007 ACM symposium on Applied computing. SAC '07, New York, NY, USA, ACM, (2007), 1046-1050. |
Fredriksson, Johan, et al., “Generating Real Time Reflections by Ray Tracing Approximate Geometry”, Chalmers University of Technology, Gothenburg, Sweden, (2016), 46 pgs. |
Hanraman, et al., “Ray tracing on programmable graphics hardware”, ACM Siggraph 2001 Proceedings, (2001), 703-712. |
Jenson, Henrik Wann, et al., “Photon maps in bidirectional Monte Carlo ray tracing of complex objects”, In Computers & Graphics, vol. 19, Issue 2, ISSN 0097-8493, (1995), 215-224. |
Kajiya, J. T, “The rendering equation”, In Proc. SIGGRAPH, vol. 20, No. 4, (1986), 143-150. |
Kan, Peter, “Differential irradiance caching for fast high-quality light transport between virtual and real worlds”, 2013 IEEE International Symposium on Mixed and Augmented Reality (ISMAR). IEEE, (2013). |
Kan, Peter, et al., “High-quality reflections, reflections, and caustics in augmented reality and their contribution to visual coherence”, Mixed and Augmented Reality (ISMAR), 2012 IEEE International Symposium on. IEEE, (2012). |
McGuire, et al., “Efficient GPU screen-space ray tracing”, Journal of Computer Graphics Techniques, vol. 3, No. 4, (2014), 13 pgs. |
Parker, et al., “OptiX: a general purpose ray tracing engine”, Journal ACM Transactions on Graphics—Proceedings of ACM SIGGRAPH 2010, vol. 29 Issue 4, Article No., (Jul. 4, 2010). |
Peddie, Jon, “Peddie predicts we could have real time ray tracing on our PCs in less than 6 years”, TechWatch, [Online] Retrieved from the Internet: <URL: https://www.jonpeddie.com/press-releases/peddie-predicts-we-could-have-real-time-ray-tracing-on-our-pcs-in-less-than/>, (Mar. 27, 2018), 2 pgs. |
Sabino, Thales, et al., “A Hybrid GPU Rasterized and Ray Traced Rendering Pipeline for Real Time Rendering of Per Pixel Effects”, ICEC 2012, Univ. Federal Fluminense, Rio de Janeiro, Brazil, (2013), 14 pgs. |
Sadeghi, Iman, et al., “Coherent Path Tracing”, Jensen University of California, San Diego, (2009), 12 pgs. |
Santos, D, et al., “Real time ray tracing for augmented reality”, 14th Symposium on Virtual and Augmented Reality IEEE, (May 28-31, 2012). |
Wald, et al., “Interactive Rendering with Coherent Ray Tracing”, Computer Graphics Forum, vol. 20, (Sep. 2001), 153-165. |
Wald, et al., “Ray Tracing Animated Scenes using Coherent Grid Traversal”, ACM, (2006). |
Wald, et al., “Realtime Ray Tracing and its use for Interactive Global Illumination”, Proceedings of Eurographics, (2003). |
Wyman, Chris, “Voxelized shadow volumes”, Proceedings of the ACM SIGGRAPH Symposium on High Performance Graphics, ACM, (2011), 34 pgs. |
Number | Date | Country | |
---|---|---|---|
20230017276 A1 | Jan 2023 | US |
Number | Date | Country | |
---|---|---|---|
62408730 | Oct 2016 | US | |
62354755 | Jun 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17175644 | Feb 2021 | US |
Child | 17934735 | US | |
Parent | 16788792 | Feb 2020 | US |
Child | 17175644 | US | |
Parent | 16004348 | Jun 2018 | US |
Child | 16788792 | US | |
Parent | 15659618 | Jul 2017 | US |
Child | 16004348 | US | |
Parent | 15615037 | Jun 2017 | US |
Child | 15659618 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15376580 | Dec 2016 | US |
Child | 15615037 | US | |
Parent | 15009442 | Jan 2016 | US |
Child | 15376580 | US |