Method and System for Encoding a 3D Scene
A computer-implemented method for encoding a scene volume includes: (a) identifying features of a scene volume that are within a camera perspective range with respect to a default camera perspective; (b) converting the identified features into rendered features; and (c) sorting the rendered features into a plurality of scene layers, each including corresponding depth, color, and transparency maps for the respective rendered features. Further, (a), (b), and (c) may be repeated, operating on temporally ordered scene volumes, to produce and output a sequence encoding a video. Corresponding systems and non-transitory computer-readable media are disclosed for encoding a 3D scene and for decoding an encoded 3D scene. Efficient compression, transmission, and playback of video describing a 3D scene can be enabled, including for virtual reality displays with updates based on a changing perspective of a user viewer for variable-perspective playback.
This application is a continuation-in-part of U.S. application Ser. No. 17/668,373, filed Feb. 9, 2022, which claims the benefit of U.S. Provisional Application No. 63/181,820, filed on Apr. 29, 2021. The entire teachings of the above application are incorporated herein by reference.
BACKGROUNDSeveral kinds of 6 degree-of-freedom (6 DoF) displays have been produced and sold, and their users are interested in viewing 3D scenes with these displays. To maintain a sense of presence, as well as to maintain viewer comfort, the display of a 3D scene to a user must take into account changes in the user's (viewer's) head pose and adjust the displayed perspectives to match the changes.
An existing application, BitGym™, allows users working out on exercise machines, such as cardiovascular (cardio) exercise machines, to be transported to far away locations virtually.
SUMMARYThere is a need for a 3D video format that allows for efficient compression, transmission, and playback of video describing a 3D scene. Such 3D scenes can be displayed to a user via a (6 DoF) 6 degree-of-freedom display, such as a virtual reality (VR) headset, an augmented reality (AR) headset, or a holographic display. Further, it is desirable that, while observing a 3D scene, a viewer may be enabled to move or rotate their head and be presented with an appropriately rendered perspective. However, existing formats do not achieve a combination of efficient compression, transmission, and playback while also providing variable-perspective playback.
In accordance with some embodiments of the disclosed subject matter, a method, corresponding system, and one or more non-transitory computer-readable media, such as software, are provided and can be used for, or as part of, compressing, transmitting, decompressing, and/or displaying a 3D scene. Embodiments achieve a combination of efficient compression, transmission, and playback while also providing variable-perspective playback. Such advantages can be realized in various systems such as by streaming content from a server, over an internet connection, and providing a 3D display to a user via a receiving client device.
Embodiments illustrated and described herein as necessary for an understanding by those of ordinary skill in the relevant arts include the following.
In one embodiment, a computer-implemented method for encoding a scene volume includes: (a) identifying features of a scene volume that are within a camera perspective range with respect to a default camera perspective; (b) converting the identified features into rendered features; and (c) sorting the rendered features into a plurality of scene layers. Each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
Sorting the rendered features into the plurality of scene layers can include sorting by depth of the rendered features, sorting by proximity of the rendered features to each other, sorting by type of rendered feature, sorting by other parameters, or sorting by a combination of parameters.
The method can further include writing the plurality of scene layers to a non-transitory computer-readable medium, such as to a computer's memory.
The method can further include constructing the scene volume using sequential color images captured by a camera. As an alternative, the method can further include constructing the scene volume using a single frame from a camera. In the case of a single frame, constructing the scene volume can include, for example, inferring, using a machine learning model, one or more features that are occluded from the single frame.
The method can further include repeating (a) identifying, (b) converting, and (c) sorting, for a respective plurality of temporally ordered scene volumes, to produce a sequence of temporally ordered pluralities of scene layers. The sequence of pluralities of scene layers can further be encoded to create a compressed sequence. In one variation of the embodiment, the method further includes packaging each plurality of scene layers into a series of image files, and then compressing the series of image files into a respective video file corresponding to the respective plurality of scene layers.
In another embodiment, a system for encoding a scene volume includes one or more processors configured to: (a) identify features of a scene volume that are within a camera perspective range with respect to a default camera perspective; (b) convert the identified features into rendered features; and (c) sort the rendered features into a plurality of scene layers. Each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
The system can further include a non-transitory computer-readable medium, and the one or more processors can be further configured to output the plurality of scene layers for storage in the non-transitory computer-readable medium.
The one or more processors can be further configured to: receive a plurality of temporally ordered scene volumes; to identify, convert, and sort according to (a), (b), and (c), respectively; and to output a sequence of pluralities of scene layers into the non-transitory computer medium.
In yet another embodiment, a computer-implemented method for generating a encoded scene volume includes: (a) assigning depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume; (b) assigning color to the respective features of the scene volume based on respective color maps of the respective scene layers; and (c) assigning transparency to the respective features of the scene volume based on respective transparency maps of the respective scene layers.
The method can further include receiving the plurality of scene layers. Receiving can be, for example, at one or more computer processors from one or more non-transitory computer-readable media over a computer bus, from a server over a network connection, or by other known means of receiving data in general, which will be understood by those or ordinary skill in the art in light of the description herein given the nature of data structures described herein.
The method can also include creating a rendered perspective from the scene volume.
The method can further include generating a plurality of temporally ordered scene volumes by repeating (a) assigning depth, (b) assigning color, and (c) assigning transparency, for each scene volume of a plurality of respective, temporally ordered, pluralities of scene layers.
In still another embodiment, a system for generating an encoded scene volume includes one or more processors configured to: (a) assign depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume; (b) assign color to the respective features of the scene volume based on respective color maps of the respective scene layers; and (c) assign transparency to the respective features of the scene volume based on respective transparency maps of the scene layers.
In still a further embodiment, one or more non-transitory, computer-readable media include instructions that, when executed by one or more processors, cause a device to: (a) identify features of a scene volume that are within a camera perspective range with respect to a default camera perspective; (b) convert the identified features into rendered features; and (c) sort the rendered features into a plurality of scene layers. Each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
In yet a further embodiment, one or more non-transitory, computer-readable media include instructions that, when executed by one or more processors, cause a device to: (a) assign depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume; (b) assign color to the respective features of the scene volume based on respective color maps of the respective scene layers; and (c) assign transparency to the respective features of the scene volume based on respective transparency maps of the scene layers.
Besides the summary of the embodiments given above, certain embodiments can be summarized as follows.
In one embodiment, a computer-implemented method, also referred to herein as packed MSR creation, includes: (i) receiving a scene volume able to be queried for features with respect to an input camera perspective; (ii) sorting the features into a plurality of scene layers, based on the depth of each feature (iii) combining the scene layers into an MSR; (iv) encoding the MSR into a packed MSR; (v) storing the packed MSR in a non-transitory computer-readable medium.
In another embodiment, also referred to herein as packed MSR video creation, a computer-implemented method includes encoding a plurality of temporally sequential representations of a 3D scene, each according to the packed MSR creation embodiment method described above, into a sequence of packed MSRs. These packed MSRs are then encoded into a sequence of 2D images which are assembled into a video which is compressed for storage or transmission.
In still another embodiment, also referred to herein as packed MSR decoding, a packed MSR is unpacked into a camera perspective, a depth map, a color map and a transparency map which are assembled into an MSR.
In still another embodiment, also referred to herein as packed MSR video decoding, packed MSR video is decoded into a sequence of packed MSRs which are each decoded and assembled into MSRs, which are finally used to create a scene volume.
In a further embodiment, a computer-implemented method includes reducing the size of an input representation a scene volume into a preconfigured number of layers, where the perspective of a camera inside of the scene is used to determine relevant surface points and then for each surface point a layer placement decision is made such that the resulting placed surface points represent the scene from the perspective of the camera with less data than the input representation.
The placed surface points may be converted into a 2D array of pixels where each pixel is mapped to the angular offset from the camera perspective.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
The foregoing will be apparent from the following more particular description of example embodiments, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating embodiments.
A description of example embodiments follows.
An existing application, BitGym™, allows users working out on exercise machines, such as cardiovascular (cardio) exercise machines, to be transported to far away locations virtually and progress through forward-motion video (FMV) while they exercise. In the virtual environment, users can be immersed in landscapes where they progress through the landscape at the speed of their own exercise.
However, it is desirable to present users a 3D version of these landscapes on a six-degree-of-freedom (6 DoF) display which can display several perspectives around the original perspective from which the original camera observed the scene, because as users exercise, their heads will move, thus requiring a change in perspective from which the video is played back in order to be realistic. However, existing formats do not achieve a combination of efficient compression, transmission and playback while also providing variable-perspective playback.
Certain three-dimensional 6 DoF displays are capable of rendering 3D video to a user/observer, but the available 3D video formats that are used as input to this process are very nascent. The most common format, stereo packed video, transmits a 3D scene representation but only from a single perspective point and single rotation, meaning if a viewer moves their head or tilts their head, the illusion of viewing the originally captured scene will be broken. Red blue green and depth information (RGBD) video will allow presentation to both eyes at any focal distance and will look correct from any head tilt or rotation. However, RGBD video presentations will still look incorrect and unrealistic if the viewer translates their head. There are experimental systems that send much more of the 3D scene, resulting in renderings that are more correct and realistic, but these experimental systems result in impractically large file sizes that are not suitable for streaming on consumer internet connections.
The new methods described herein yield at least three benefits over existing methods, systems, and video compression formats. First, because the viewer can observe the scene from a perspective a distance away from the original camera position, a viewer in a VR headset can move or rotate their head and see believable projections of the original 3D scene, which increases realism and reduces the experience of motion sickness. Secondly, and also because the viewer can observe the scene from a perspective a distance away from the original camera position, the scene can be viewed from a virtual camera taking a smooth path even if the scene was generated with a camera which moved with an uneven path when capturing data. Third, the playback of packed MSR video when the camera is moving, as is the case for the BitGym™ immersive tours, allows for the client to convincingly display at an arbitrarily high frame rate by moving a virtual camera incrementally along the camera path in the reconstructed scene and interpolating between the rendered scene volumes created by the previous and next MSRs. One embodiment will demonstrate how a packed MSR video decoder can create and output rendered perspectives to a display at 60 frame per a second (fps) playback despite receiving packed MSR video containing just one packed MSR from per a second, and the advantage of such an embodiment is that in constrained bandwidth environments a client can select a stream with a lower frame rate instead of a stream with a lower resolution, preserving visual fidelity.
As part of the sorting 106, each depth map, color map and transparency map can optionally be represented as a 2D array of values. Furthermore, as part of sorting 106, each depth map can optionally be represented as coordinates of a vertex mesh.
In some embodiments, the scene volume is first created using a series of sequential color images captured by a video camera. In other embodiments, the scene volume is first created using a single color image captured by a video camera. In yet other embodiments, the scene volume may be created or modified by a trained machine learning model. For example, such a machine learning model can use established techniques to take as input a photograph and to output a 3D representation of that photograph with depth as a scene volume. Furthermore, such a machine learning model can create occluded features in the scene volume not described in the original photograph
Optionally, at 108, the procedure can also include repeating (a), (b), and (c) (identify 102, convert 104, and sort 106, respectively, as each of those elements is set forth particularly in the drawing and in the above description), for a respective plurality of temporally ordered scene volumes, to produce a sequence of temporally ordered pluralities of scene layers
Also optionally, at 110, the procedure can include encoding the sequence of pluralities of scene layers to create a compressed sequence.
As will be understood by those of skill in the art, in various embodiments, the procedure 100 can be modified further to include any of the other optional elements described above in the Summary section above or in the embodiments illustrated in other drawings and described hereinafter.
As also illustrated in
The scene volume 204 can be queried for features within a camera perspective, such as illustrated at 102 in
Optionally, the system 200 may further include a non-transitory computer readable medium 216 to which the respective scene layers may be output, as illustrated in
As will be understood by those of skill in the art, in various embodiments, the system 200 can be further configured, with appropriate modifications in hardware, software, firmware, or other means, to perform any of the other functions described above in connection with
At 304, depth is assigned to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume. Thus, for each scene layer, the depth map is used to place features into a scene map. This projection function can assume a camera perspective, but such a perspective can be a preconfigured default. Some embodiments can receive a camera perspective along with a plurality of scene layers, and use this camera perspective to place the features in the scene volume.
At 306, color is assigned to the respective features of the scene volume based on respective color maps of the respective scene layers. Thus, for each scene layer, the color of placed features is set according to the color map. Similarly, at 308, transparency is assigned to the respective features of the scene volume based on respective transparency maps of the respective scene layers. Thus, the transparency of placed features is set according to the transparency map.
Optionally, at 310, a plurality of temporally ordered scene volumes may be generated by repeating 304, 306, and 308 for a plurality of respective, temporally ordered, pluralities of scene layers. Optionally, at 312, the generated scene volume can be used to create a rendered perspective. The rendered perspective can be created from a camera perspective inside of the newly created scene volume. The same camera perspective used to create the scene volume can be used. However, alternatively, a different nearby camera perspective can be used instead. In embodiments wherein a user is using a 6 DoF display, the camera perspective from which to create the rendered perspective can be determined by knowledge of the user's head position.
The one or more processors 404 can optionally be configured to output a scene volume 405 and a camera perspective to an optional graphics processor 406. The graphics processor 406 is configured to create a rendered perspective 312 of a scene volume from the perspective of a camera perspective in the scene volumes coordinate system.
Next, the layer condenser queries the scene volume 502 for features within the camera perspective or anticipated camera perspectives in a locality around the camera perspective, a process illustrated in
The MSR 508 is then passed to the MSR packer 510 which will encode the MSR component scene layers in 2D pixel array representations, and then pack them together into a single packed MSR 512, which is, in this embodiment, a 2D pixel array. The pixels in this 2D array are each a simple data structure with usually 3, and sometimes 4, channels of color information. A channel of color information is commonly described with 8 bits of information, but it can be as few as 4 or as many as 32, depending on the color space the embodiment is configured to work with. The output packed MSR 512 need not preserve all information which was present in the MSR 508, as a key advantage of this embodiment is to compress information describing a scene volume 502 into a smaller data structure for practical storage or transmission. The MSR packer 510 embodiment can be configured with different packing strategies depending on the number of scene layers it will receive, different output pixel formats and different 2D pixel array output sizes. A larger 2D pixel array will encode more visual detail, but will increase the storage and transmission size. A detailed description of a packed MSR 512, according to one embodiment, is shown in
Optionally the camera perspective 504 can be passed to the MSR packer 510 so that the packed MSR contains a packed camera perspective.
The system and processes described in connection with
The layer condenser is a very advantageous part of the overall system because it can take a data intensive or computationally intensive scene volume, which by itself may be impractical for viewing in real time due to bandwidth or computational limits, and condense the visual information able to be seen from a locality around a camera perspective into a much small representation suitable for storage, real-time playback or transmission over a network.
One Embodiment Layer CondenserOne embodiment of the layer condenser has specific characteristics and functions as follows.
The layer condenser receives a camera perspective, and with it queries a scene volume for rendered features relevant to that camera perspective, including those rendered features that would be occluded by other rendered features. The layer condenser stores the spatial coordinates of these rendered features in memory. As part of this process some of the rendered features may be determined as erroneous or otherwise irrelevant. Thus, rendered features finally committed to memory can be referred to as “relevant rendered features.”
The layer condenser can be configured to output a number of scene layers, and the number should be at least 2 to be useful, while an example number of 4 is better. More generally, the number of scene layers may be greater than or equal to 2, or greater than or equal to 4. More preferably, the number of scene layers can be 4, 5, 6, 7 or 8, for example. Conceptually, each scene layer is a set of vertices in space where each vertex may be considered to be connected to its nearest neighbor vertex or vertices with a polygon edge. There is a relative order to the layers, where layer N+1 is further away from the camera, on average, than layer N. In order to sort the relevant rendered features into scene layers, the layer condenser may advantageously optimize for the following properties of the sorting:
-
- a) Scene layers should preferably be maximally utilized. The most foreground scene layer should hold the nearest rendered features in a given angular offset from the camera perspective. If this angular offset contains rendered features which occlude other rendered features, these occluded features must be sorted into another layer or discarded. This process of sorting rendered features into scene layers, or discarding features which cannot be fit, is referred to as “sorting by depth.” This will reduce representational load on subsequent scene layers. As the total number of scene layers is fixed, this strategy helps ensure that any visual features in the scene that are likely to be visible from and around the target camera perspective are represented in a scene layer before the MSR's capacity for representation is filled up.
- b) Surfaces may often contain areas wherein a transition between scene layers is required. In such regions, it is advantageous to have at least one vertex of overlap (“seam”) between the projection of the scene layers. In practice, it is preferred to have two vertices of overlap between projected scene layers. These “seams” are necessary to prevent “cracks” from appearing in a final rendering of the scene volume created from projected scene layers which overlap. Two vertices are preferred, because it is ultimately the triangles between vertices that can be rendered. Having two vertices also ensures that there is a continuous seam of overlapping triangles between projected scene layers; the vertices on all sides of those triangles will need to be the same between layers.
- c) Whenever any single scene layer (except the most background layer) transitions from representing the rendered features of relatively nearby object to the rendered features of a relatively further away object it is desirable to ensure that the rendered features will ultimately be rendered without any visible seams or gaps along that transition. One way of achieving this is to redundantly represent the features of that object by each of the participating layers along their transition boundary.
Once the structure of scene layers has been determined, each will be assigned a 2D array to hold color and opacity data. In order to fill the 2D arrays with color and opacity information, an iterative approach may be employed whereby the estimated occlusion of rendered features by nearer rendered features from a number of observed perspectives is used to fill in colors, selectively, that should be visible from each perspective. The color for each rendered feature will vary by the perspective used to observe it, and so the final value selected for storage must be determined. In one configuration, this value is determined by taking a weighted average of colors from multiple camera perspectives inside of a camera perspective range, where the weights correspond to the inverse likelihood that the rendered feature was being occluded in each sampled camera perspective.
A difference between the weighted average color for each scene layer and the original observations is then used to refine the estimated opacity of each scene layer wherein a high enough difference in color indicates a high likelihood of occlusion and, therefore, an increased likelihood of opacity of the occluding scene layer. These improved opacity estimates can then be used to improve the occlusion estimation, which in turn can then be used to refine the color estimation. The back and forth refinement of opacity and color can be repeated for several iterations until a stable configuration emerges.
With a temporally ordered sequence of camera perspectives 602 and a temporally ordered scene volume sequence 605, both of which contain the same number of elements, MSR packing process 500 can be invoked in a loop for each pair of inputs and it will produce a packed MSR for each execution. The resulting temporally ordered packed MSR sequence 606
In this embodiment, each element of packed MSR sequence 606 is a packed MSR 512 (see
In one configuration, a packed MSR is 3840 pixels wide and 2160 pixels tall, with three color channels per a pixel. In this configuration, a h265 video encoder would offer a good compression ratio and furthermore be a format which is easily decoded with the computing resources found in consumer grade computing devices available today. Such a packed MSR encoded to the h265 standard and embedded in a MPEG4 video container can then be streamed over the network to a VR headset, which can decode the stream into a series of MSRs, which can then be used to create a series of scene volumes, each of which can be used to present a rendered perspective to the VR headset display.
In general, when streaming video to a client, it is advantageous to use an adaptive bitrate system that scales up stream size based on available bandwidth. In the prior art, the generally accepted method is to reduce resolution and bitrate to accomplish this. However, in contrast to the prior art, the embodiments described herein make it possible to keep the per-frame resolution high while only reducing the frame rate of the packed MSR video. Packed MSR video can advantageously be viewed at arbitrarily high “frame rate” by stepping the virtual camera tiny amounts through the created scene volumes, and this feature can contribute significantly to achieving the combination of high resolution and reduced overall frame rate.
In
To composite the scene layer transparency maps (which are themselves 2D arrays of values) into a 2D array of three channel pixels, a transform function is applied such that fourth layer is assumed to be entirely opaque and can be omitted, and the first three transparency maps are encoded in the red, blue and green dimensions of the color space. Because these colors are distinct to human perception, modern video codecs are likely to preserve the distinction between these four dimensions during compression steps.
To fit the depth maps into the space available, and to keep the total representation size down, the packed depth maps are represented by 25% as many pixels as the color maps. A transform function is used to convert the input depth maps, which can be represented as high precision inside of a scene layer, into the likely lower precision 24 bits available across the three channels of each output pixel. This transform function is preferably non-linear such that pixels with smaller depth values, those representing visual features nearby the camera, are stored in higher resolution than those pixels with larger depth values.
Another embodiment of the MSR frame packer is designed to output 2D pixel arrays with four channels each. Such a four channel 2D pixel array can be encoded by some modern video codecs. In this embodiment, the color maps are packed into three channels and their corresponding transparency maps are packed into the fourth channel. To keep the output rectangular, the depth layers are arranged in a vertical column on the side.
These are two possible frame packing strategies, but there are many possible, especially when different frame sizes, pixel depth, or pixel striping strategies are used by the stream the frames are intended to be embedded in.
An especially advantageous aspect of embodiments is that, because an MSR can be packed into a 2D array of pixel values, common image and video codecs can be used for storage and transmission over a network. This allows for embodiments to take advantage of hardware accelerated encoders and decoders already available on consumer grade computing hardware. As the information in a packed MSR follows many of the same dynamics as a normal image (e.g. adjacent pixels tend to have similar values), and that similarly a sequence of packed MSR frames follow the same dynamics as a normal video (e.g. pixels tend not to change between frames) common image and video encoding techniques offer efficient compression of packed MSRs. Optionally, the layer condenser can be configured to output fewer scene layers for scenes with less complexity, and when this happens the resulting packed MSR frames will have blank regions which modern video codecs will compress extremely effectively. Additionally, it can be useful for the embodiment to anticipate the group of pictures (GOP) size and concentrate changes in adjacent frames to keyframes in the resulting video stream. One such method is to only change the location of the camera perspective at such keyframes.
As the MSR sequence 806 is output, each MSR is input to an MSR renderer process 1000, which will for each input create an output rendered perspective.
The render process optionally can be passed a user head pose along with the input MSR. In some embodiments the user head pose is observed with a head pose sensor 808, an example of which is the motion sensor in a VR headset.
The MSR constructor 910 is passed 904, 906, 908 and 912 and it will output a plurality of scene layers. These scene layers plus the camera perspective are the constituent parts of the MSR 912 which is the output of this module.
In some embodiments, the camera perspective 912 is not output from 902 and thus not input into 910 and thus not included in the output MSR data structure.
In parallel, the MSR 912 is passed to scene volume constructor 1010 which will use it to create a corresponding scene volume 1012.
Finally, for each constructed scene volume 1012, and the corresponding render camera perspective 1008, the render engine 1014 will create a rendered perspective 1016 which is suitable to be sent to a 6 DoF display to be viewed by a user. In one example embodiment running on a VR headset, the constructed scene volumes are loaded into graphical memory and processed by a graphics pipeline on a graphics processor unit in order to produce the rendered perspective. For a VR headset, as is the case with most 6 DoF displays, the rendered perspective must be composed of two images, one intended to be displayed to the left eye and the other intended to be displayed to the right eye.
The process described above advantageously allows the user to view the scene volume from multiple positions and angles for an immersive viewing experience. For example, a user wearing a virtual reality headset can look around or move the position of the user's head to see a presented scene from different perspectives. Similarly, a user with a holographic display or other 3D panel display can be enabled to move in relation to the panel, resulting in a new vantage point, while having the scene render correctly for the user's new vantage point.
In order to enhance performance, this component may be implemented by the operating system in a computing system that contains a hardware decoder processor suitable to decode the video stream. In other embodiments, the MSR unpacker process 900 can be a pure software component running in an application layer, for example in cases wherein a client operating system does not have the capability required for a dedicated hardware decoder.
The depth maps in scene layers encode the distance and angular offset of features from a camera perspective. In one embodiment this is implemented as a 2D pixel array of depth values, and depth map 1102a, 1102b and 1102c can be represented as a grayscale image wherein darker pixels represent a distance further from the camera perspective. In another embodiment, the scene layer depth maps are stored in a vertex mesh. Other storage strategies will be known to those skilled in the art. layer 1's depth map 1102a represents objects which are generally closest to the camera, so the depth values are smaller and thus represented by a lighter color than the other depth maps. layer 2's depth map 1102b is a bit darker, and layer 3's depth map 1102c is the darkest of all where the sky is, and it is lighter when representing the ground lower down.
The color maps in scene layers are 2D pixel arrays with three color channels each. Layer 1's color map 1104a represents the stone arch in the foreground, but is otherwise black in areas which will be fully transparent when projected. layer 2's color map 1104b has two cacti, and layer 3's color map 1104c has the ground and far background.
The transparency maps in scene layers are 2D pixel arrays with a single channel, and in
The depth map projection 1110 is a rendition of how the depth maps of an MSR would look if projected into a scene volume. The neutral camera perspective 1108 is projection of the camera perspective into a 3D rendering context. The depth map and color map projection 1120 demonstrates how the color maps are added in. The complete projection 1130 has the color, depth and transparency maps all projected into a 3D rendering context such that the render camera 1110 can now generate images suitable to show to a human observer. The position, rotation and field of view of the render camera 1110 can be dynamic, responding to a viewer's head position in a VR headset or some other form of camera controls.
The camera perspective origin 1206 is important for determining depth, occlusion and observability of features. The depth of a feature inside of a camera perspective is the distance of the feature from the camera perspective origin. The occlusion of a feature is determined by checking if the line between the feature and the camera perspective origin at least partially allows light through. The observability of a feature is a special property only relevant in scene volumes in which polygonal representations are used. In such scene volumes a feature is only observable if its polygon face partially points at the camera perspective origin.
The specific way in which a layer condenser identifies features can vary by embodiment and further by the underlying data structure of the scene volume being queried. Consider an example wherein scene volume 1204 is represented by polygons. In this example, a layer condenser implementation can query for all observable features, even those occluded, which fall inside of the camera perspective. In this case, the features on half of the sphere A and sphere B (those nearest the camera origin point) would be identified. Next, they can be converted into rendered features, and those rendered features can then be sorted by depth, such that the rendered features of sphere A can go on the first scene layer, and the rendered features of sphere B can be sorted to the next scene layer.
Consider an example wherein scene volume 1204 is represented by voxels. In this example a layer condenser implementation could first create a set of camera perspectives inside of a camera perspective range, and for each camera perspective in the set, query the scene volume for non-occluded features. Some of the camera perspectives considered would see around sphere A to have a non-occluded view of features on sphere B. Thus, in total, features from most of sphere A and some of sphere B would be identified. The identified features would then be converted to rendered features from the default camera perspective and sorted in scene layers by depth.
A packed MSR video can benefit from being compressed by a h265 encoder and packaged in a MPEG4 container, however, other codecs and containers formats may also be used. Both the creation of an MSR from a scene volume, as well as construction of a scene volume from an MSR, benefit from being implemented in a 3D engine such as Unity3D™, although it need not be, and other tools known in the art may be used.
In one aspect, described systems and methods may be used for AR or VR headsets and worn by users exercising on cardio machines so that the users can explore 3D landscapes while they exercise. Alternatively, systems and methods can be used with holographic displays positioned in front of the user as the user as they exercise. In other embodiments, no exercise machine is involved, and even without exercise equipment being involved in any way, MSRs described herein a superior way to transmit and display many kinds of 3D video currently being sent in other formats to 6 DoF displays.
In the cardio machine case, wherein a user observes the MSRs via a series of Smooth Camera Perspective that move forward over time, if the system presents each MSR for a shorter period of time, it can appear as if the camera were moving faster through the scene. Similarly, showing each MSR for a longer time creates an appearance of moving slower through the scene. This means that the system can present the view of the scene at a rate according to user preference, or in the exercise case, at a rate corresponding to the user's exercise pace. Further advantageously, instead of simply producing rendered video simulating teleportation of the viewing camera to discrete pose locations, alternatively the camera logic component can smoothly interpolate the camera position between these positions at any frequency that the client display hardware can handle. In this manner, the client can have an arbitrarily high rendering frame rate, even if the presenting rate of each MSR is relatively slow.
Consider a user on a treadmill who is walking slowly while watching a forward motion 3D video captured at running speed. The client system can keep each MSR on the screen longer while still moving the virtual camera slightly forward and rendering novel viewpoints with a 120 hertz (Hz) update loop.
Embodiments are also particularly advantageous in bandwidth-constrained circumstances, wherein it may not be feasible to send a full-resolution video at 60 frames per second (fps). Existing video streaming systems may appear very different when the frame rate changes and, thus, attempt to keep the frame rate fixed while reducing the resolution and bitrate. In contrast, when embodiment systems render a mostly static scene from a moving camera (which is often the case for forward motion footage filmed outside), the effective frame rate can be kept high by updating the virtual camera even if the rendered scene volume is updating at a much slower rate. Thus, when bandwidth is constrained, the client can optionally switch to a stream with fewer frames per second instead of a stream with fewer bits per frame.
Certain Advantages of EmbodimentsEmbodiments that include packing the MSR data into a frame for transmission over a standard video stream result in video compression that is much improved over existing approaches, such as stereo packed video.
Further, quite low frame rates can be encoded into the packed MSR video, even frame rates as low as 1 frame per second, and these low frame rates can still provide a good playback experience for a playback client when interpolation of the virtual camera is used. This means that streaming options for low-bandwidth conditions are much more appealing than for existing compression formats, methods, and systems.
Renderings can be exceedingly realistic using embodiments, even when the resolution of the opacity layer is low and/or the opacity of each pixel is encoded with a low bit depth. Those of skill in the art would have generally understood that precise opacity specification would matter a lot. However, it has been discovered that for embodiment methods, when rendering organic shapes like those found in the real world, opacity blending need not be particularly precise, and renderings can still remain very good.
Furthermore, embodiments include the advantage that better machine learning in the reconstruction steps, by using semantic scene understanding, can result in more accurate estimations of scene depth.
DefinitionsA “multilayer scene representation” (MSR) is a plurality of scene layers describing a scene volume. An MSR may optionally describe the camera perspective used by each or all scene layers.
A “depth map” is a mapping of depth values to angular offset. One can be used in conjunction with a camera perspective to place features into a scene volume.
A “color map” is a mapping of color values to angular offset. One can be used in conjunction with a camera perspective to set color values of features placed in a scene volume.
A “transparency map” is a mapping of transparency values to angular offset. One can be used in conjunction with a camera perspective to set transparency values of features placed in a scene volume.
A “scene layer” is the combination of a depth map, color map and optionally transparency map. Together these can be used in conjunction with a camera perspective to place features in a scene layer and set color and transparency values for them.
A “packed MSR” is data describing an MSR which has been compressed to be described in fewer total bits than the input MSR. A packed MSR may exist as a continuous data structure or it may instead be split across two or more data structures. An example of being split across data structures includes the case where the transparency and color maps from an MSR are packed and compressed into four channel color image format and the depth maps are encoded into a vertex mesh data format.
A “packed MSR video” is data containing a time ordered series of compressed MSR data structures. One example is a MP4 video where each frame represents a compressed MSR. Another example is a pair of data structures, the first being a time indexed sequence of 3D mesh data, where each 3D mesh encodes a depth map, and the second being a MP4 video where each frame encodes color and transparency maps. A second example is a MP4 video where each frame contains the data from an MSR packed into an image.
A “camera perspective” represents a 3D angular field of view of a scene volume. A camera perspective can be specified by the position, rotation and lens geometry. The simplest example would be a cone of a certain field of view, but other less regular shapes are possible.
A “camera perspective range” is a specification for a range of three position and three rotation values with respect to a default camera perspective. A simple example specification would be “all positions within 1 meter of the default camera perspective, at all possible rotation values.” A second and more complicated example might specify all positions 100 cm above, below, left and right of a default camera perspective, but no positions in front of it or behind it, and furthermore only camera rotations resulting in a forward axis within 45 degrees of the default camera position forward axis.
A “scene volume” is a data structure describing features in three dimensions (3D). The utility of a scene volume derives from an ability to query features from multiple possible camera perspectives. A scene volume can be constructed in many ways. For example, a scene volume describing the inside of a house can be created by recording an existing home with a camera and processing the camera data into textures and surfaces. Alternatively, a scene volume of a house can be created by an artist using a CAD program. A scene volume can be created synthetically and can, thus, be a synthetic scene volume, as will be understood by those of ordinary skill in the arts of computer-generated graphics and animation in reference to this disclosure. Another example of a scene volume is a trained machine learning model which has been configured to take a camera perspective as input and produce visual features as output. A scene volume has no internal concept of time, and so can be assumed to represent spatial information at a single time slice.
A “4D scene volume” is a data structure describing scene volumes at multiple time values within a range. A simple example would be a collection of scene volumes indexed by discrete timestamp. Another example is a computer-generated animation where components are programmed to change appearance as a function of time.
A “rendered perspective” is data sufficient to fill a display with visual information from a virtual camera inside of a scene volume.
A “display” is a television, computer monitor, virtual reality headset, augmented reality headset, or other physical technology used to present visual data to a user.
A “feature” is a region of a scene volume which influences the light which will reach virtual cameras within the scene volume. In a scene volume configured to represent the light physics of the actual world, the influence may be due to emission, occlusion, reflection, or a combination.
A “rendered feature” is the location, color and transparency values of a scene volume feature as observed within a camera perspective.
The “depth” of a rendered feature is defined as the distance between the rendered feature's location in a scene volume and the origin of the camera perspective from which the rendered feature was observed.
While example embodiments have been particularly shown and described, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the scope of the embodiments encompassed by the appended claims.
Claims
1. A computer-implemented method for encoding a scene volume, the method comprising:
- (a) identifying features of a scene volume that are within a camera perspective range with respect to a default camera perspective;
- (b) converting the identified features into rendered features; and
- (c) sorting the rendered features into a plurality of scene layers, wherein each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
2. The method of claim 1, wherein sorting the rendered features into the plurality of scene layers includes sorting by depth of the rendered features.
3. The method of claim 1, further including writing the plurality of scene layers to a non-transitory computer-readable medium.
4. The method of claim 1, further including constructing the scene volume using sequential color images captured by a camera.
5. The method of claim 1, further including constructing the scene volume using a single frame from a camera.
6. The method of claim 5, wherein constructing the scene volume includes inferring, using a machine learning model, one or more features that are occluded from the single frame.
7. The method of claim 1, further including repeating (a), (b), and (c), for a respective plurality of temporally ordered scene volumes, to produce a sequence of temporally ordered pluralities of scene layers.
8. The method of claim 7, further including encoding the sequence of pluralities of scene layers to create a compressed sequence.
9. The method of claim 7, further including packaging each plurality of scene layers into a series of image files, and then compressing the series of image files into a respective video file corresponding to the respective plurality of scene layers.
10. A system for encoding a scene volume, the system comprising:
- one or more processors configured to: (a) identify features of a scene volume that are within a camera perspective range with respect to a default camera perspective; (b) convert the identified features into rendered features; and (c) sort the rendered features into a plurality of scene layers, wherein each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
11. The system of claim 10, further including a non-transitory computer-readable medium, and wherein the one or more processors are further configured to output the plurality of scene layers for storage in the non-transitory computer-readable medium.
12. The system of claim 11, wherein the one or more processors are further configured to: receive a plurality of temporally ordered scene volumes; to identify, convert, and sort according to (a), (b), and (c), respectively; and to output a sequence of pluralities of scene layers into the non-transitory computer medium.
13. A computer-implemented method for generating a scene volume, the method comprising:
- (a) assigning depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume;
- (b) assigning color to the respective features of the scene volume based on respective color maps of the respective scene layers; and
- (c) assigning transparency to the respective features of the scene volume based on respective transparency maps of the respective scene layers.
14. The method of claim 13, further comprising receiving the plurality of scene layers.
15. The method of claim 13, further comprising creating a rendered perspective from the scene volume.
16. The method of claim 13, further including generating a plurality of temporally ordered scene volumes by repeating (a), (b), and (c) for a plurality of respective, temporally ordered, pluralities of scene layers.
17. A system for generating a scene volume, the system comprising:
- one or more processors configured to:
- (a) assign depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume;
- (b) assign color to the respective features of the scene volume based on respective color maps of the respective scene layers; and
- (c) assign transparency to the respective features of the scene volume based on respective transparency maps of the scene layers.
18. One or more non-transitory, computer-readable media comprising instructions that, when executed by one or more processors, cause a device to:
- (a) identify features of a scene volume that are within a camera perspective range with respect to a default camera perspective;
- (b) convert the identified features into rendered features; and
- (c) sort the rendered features into a plurality of scene layers, wherein each respective scene layer of the plurality of scene layers includes, for respective rendered features that are sorted into the respective scene layer: (i) a corresponding depth map for the respective rendered features, the depth map based on depth information from the scene volume, (ii) a corresponding color map for the respective rendered features, and (iii) a corresponding transparency map for the respective rendered features.
19. One or more non-transitory, computer-readable media comprising instructions that, when executed by one or more processors, cause a device to:
- (a) assign depth to respective features of a scene volume based on respective depth maps of respective scene layers, the respective scene layers being of a plurality of scene layers of an encoded scene volume;
- (b) assign color to the respective features of the scene volume based on respective color maps of the respective scene layers; and
- (c) assign transparency to the respective features of the scene volume based on respective transparency maps of the scene layers.
Type: Application
Filed: Feb 10, 2022
Publication Date: Nov 3, 2022
Inventors: Joshua McCready (Truckee, CA), Alexander Gourley (Grass Valley, CA)
Application Number: 17/669,343