The present invention relates to the field of 3D graphics. In particular, the present invention relates to methods and devices for determining a 3D model.
Traditional texture mapping approaches require the meshed 3D model to be parameterized: each vertex on the model is associated with 2D coordinates on a texture map. One effectively “unwraps” the 3D model onto the 2D space.
When using implicit surface modeling however, one does not have an explicit representation of the surface. Parameterizing such an implicit model is thus not straightforward.
Not many automated solutions exist for implicit model texturing, and even fewer that can do so in real-time. One can first make the model explicit by meshing, however the resulting problem is still very big. Only when limiting the potential topology of the explicit model can one effectively construct a viable texture map in real-time.
An alternative to texture mapping is the use of projective texturing for generating an appearance when rendering the 3D model. For projective texture, one essentially projects the image back from the camera onto the geometry; effectively the inverse process as when a camera captures an image. While projective texturing is a good approach for modeling temporal variations, its use is less applicable for rendering based on noisy geometry estimates. The problem that then occurs is that the projected texture has an embedded assumption of the geometry while the geometry on which one projects this texture is only an estimate of this geometry. This can cause errors that can be difficult to detect and remedy.
No solutions are known that allow for the traditional texture mapping approach to be used in combination with an (unrestricted) implicit model.
It is thus an object of embodiments of the present invention to propose a method and a device for determining a 3D model, which do not show the inherent shortcomings of the prior art.
Accordingly, embodiments relate to Method for determining a 3D model of a surface, executed by a 3D model determination device, comprising:
obtaining a plurality of 2D+Z images of said surface from respective 2D+Z image sources,
determining, in function of the 2D+Z images, implicit surface data modeling said surface, wherein the implicit surface data specify, for respective sample points of a 3D field, a distance between said sample point and said surface and a 2D+Z image source identifier associated with said sample point,
determining a plurality of surface points in function of the implicit surface data,
for at least one of said surface points, determining at least one 2D+Z image source associated with said vertex in function of the implicit surface data, and at least one texture identifier and 2D texture coordinates associated with said surface point in function of 2D+Z image source modeling data associated with the determined at least one 2D+Z image source.
Correlatively, embodiments relates to a 3D model determination device for determining a 3D model of a surface, comprising a processor and a memory configured for:
obtaining a plurality of 2D+Z images of said surface from respective 2D+Z image sources,
determining, in function of the 2D+Z images, implicit surface data modeling said surface, wherein the implicit surface data specify, for respective sample points of a 3D field, a distance between said sample point and said surface and a 2D+Z image source identifier associated with said sample point,
determining a plurality of surface points in function of the implicit surface data,
for at least one of said surface points, determining at least one 2D+Z image source associated with said surface point in function of the implicit surface data, and at least one texture identifier and 2D texture coordinates associated with said surface point in function of 2D+Z image source modeling data associated with the determined at least one 2D+Z image source.
Determining the implicit surface data may comprise selecting one of the 2D+Z image sources as the most reliable 2D+Z image source for a sample point, the distance between said sample point and the surface being determined in function of the 2D+Z image obtained from the selected 2D+Z image source, the 2D+Z image source identifier associated with said sample point corresponding to the selected 2D+Z image source.
Some embodiments comprise obtaining reliability information from said 2D+Z image sources, and determining said implicit surface data in function of said reliability information.
Determining at least one 2D+Z image source associated with a surface point may comprise selecting the 2D+Z image source identifier of a sample point which has the smallest absolute distance to the surface among a set of sample points in the neighborhood of the surface point.
Determining 2D texture coordinates associated with a surface point may comprise projecting said surface point to an image plane of the identified 2D+Z image source, in function of said 2D+Z image source modeling data which specify a modelview matrix and a projection matrix.
Some embodiments comprise determining a parameterized 3D model having a weighted multi-textures format in function of the determined surface points, texture identifiers and 2D texture coordinates.
Some embodiments comprise determining successive 3D models of said surface at a rate of at least 10 3D models per seconds.
Some embodiments comprise transmitting the determined 3D model to a rendering device.
Embodiments relates to a computer program comprising instructions for performing the method above when said instructions are executed by a computer.
Embodiments relates to a system comprising a 3D model determination device and a plurality of 2D+Z image sources.
The above and other objects and features of the invention will become more apparent and the invention itself will be best understood by referring to the following description of embodiments taken in conjunction with the accompanying drawings wherein:
The object 2 may be for example (part of) a living being such a human face, a material object of fixed or variable shape . . .
A 2D+Z image source 3 is a capture device capable of providing a 2D+Z image of a part of the surface S, that is a 2D image wherein depth (Z) information is associated with respective pixels. A 2D+Z image source 3 is for example a stereoscopic camera wherein depth information may be determined in function of disparity, a time-of-flight camera . . .
The 3D model determination device 4 receives 2D+Z images of the surface S from the 2D+Z image sources 3 and determines a parameterized 3D model of the surface S, as described hereafter with reference to
The 3D model determination device 4 receives a plurality of 2D+Z images of the surface S from the 2D+Z image sources 3 (Step S1). In some embodiments, the data received from a 2D+Z image sources 3 may require some pre-processing, such as format conversion, by the 3D model determination device 4. For example, if a stereoscopic camera determines depth in function of disparity itself, no preprocessing needs to be performed by the 3D model determination device 4, but if the stereoscopic camera provides a pair of stereoscopic images as representation of a 2D+Z image, the 3D model determination device 4 may need to determine depth in function of disparity.
Then, the 3D model determination device 4 determines implicit surface data sdf+ in function of the received 2D+Z images (Step S2). The implicit surface data sdf+ specify, for respective sample points of a 3D field, a signed distance between said sample point and the surface S and a 2D+Z image source identifier associated with said sample point. The signed distance is positive for sample points outside the object 2 and negative for sample points inside the object 2. This is illustrated on
The result of this process is an implicit representation that has the nearest distance along with the identification source of this nearest distance. We denote this function as sdf+ with sdf+[0] defined to be the signed nearest distances and sdf+[1] the 2D+Z image source identifiers. For illustrative purposes, the following table shows a 2D representation of sdf+ determined in function of three 2D+Z image sources 3 with respective identifiers C0, C1 and C2:
Then, the 3D model determination device 4 determines surface points in function of the implicit surface data sdf+ (Step S3). Known techniques have been proposed for converting an implicit surface to an explicit surface, thereby determining the surface points. Hereafter, the surface points are call vertices V. The terms vertices and vertex are usually link to triangle meshes, which may be used for rendering the 3D model. However, some embodiments do not rely on meshes, hence the use of the more generic terms “surface points”.
Then, for the respective vertices Vi, the 3D model determination device 4 determines at least one 2D+Z image source 3 associated with said vertex Vi in function of the implicit surface data sdf+, and determines a texture identifier TID and 2D texture coordinates vi associated with said vertex Vi in function of 2D+Z image source modeling data associated with the determined at least one 2D+Z image source identifier (Step S4).
More specifically, in an embodiment, the 3D model determination device 4 determines an identifier of the 2D+Z image source 3 associated with vertex Vi, which is regarded as the main contributor for the vertex Vi. This may be determined for example as:
ID:=id(argminx(abs(d(x)))
with x the neighboring implicit surface sample points for vertex Vi, id(x):=sdf+(x)[1] and d(x):=sdf+(x)[0]
The images provided by the 2D+Z image sources 3 may be used as texture for the 3D model, and in that case the texture identifier TID associated to vertex Vi correspond to the identifier of the determined the 2D+Z image source 3. For example, TID=ID.
The texture coordinates vi may be determined by projecting vertex V, to the identified 2D+Z image source 3:
v
i
=P*M*V
i
with vi the 2D projection of the 3D point Vi, M the modelview matrix defining the rotation and translation of the 2D+Z image source and P the projection matrix defining the intrinsics of the 2D+Z image source (focal length, aspect ratio, etc. of the camera).
The following table shows the data specified by the parameterized 3D model of the surface S after step S4 (in an illustrative simplified example with only 8 vertices Vi):
In this table, each vertex Vi of the 3D model is associated with a texture identifier TID and 2D texture coordinates vi. One may design a 3D graphic rendering device capable of generating a view of the 3D model by using such information. In some embodiment, however, the 3D model determination device 4 converts the parameterized 3D model determined after step S4 to a multi-texture-compatible rendering format that uses weights along with the texture coordinates to determine the blending factor of each texture (step S5). One needs a list per texture in this case that defines for each vertex the weight of the texture sample and the texture coordinates for that texture. This is illustrated in the following table:
This can be rendered by any renderer that supports multi-texturing (which is basically every recent 3D-capable device).
In the embodiment described above, one 2D+Z image source 3 is determined as the main contributor for a vertex Vi, and the corresponding texture is applied to this vertex Vi when rendering the 3D model. In other embodiments, the 3D model determination device 4 determines (at step S4) the N main contributors for a vertex Vi, with weighting factors which reflect the relative contributions. The parameterized 3D model then specifies N texture identifiers associated with the vertex Vi, with corresponding weights. A weighted combination of the textures is applied to the vertex V, when rendering the 3D model.
In the system 1, texture mapping may be used on arbitrary implicitly defined shapes in a computationally efficient fashion. By linking the texture coordinate generation to the actual geometry and the defining source cameras, one can prevent quality issues due to mismatches between the reconstructed geometry and the actual geometry.
It is to be remarked that the functions of the various elements shown in the figures may be provided through the use of dedicated hardware as well as hardware capable of executing software in association with appropriate software. When provided by a processor, the functions may be provided by a single dedicated processor, by a single shared processor, or by a plurality of individual processors, some of which may be shared, for example in a cloud computing architecture. Moreover, explicit use of the term “processor” should not be construed to refer exclusively to hardware capable of executing software, and may implicitly include, without limitation, digital signal processor (DSP) hardware, network processor, application specific integrated circuit (ASIC), field programmable gate array (FPGA), read only memory (ROM) for storing software, random access memory (RAM), and non volatile storage. Other hardware, conventional and/or custom, may also be included. Their function may be carried out through the operation of program logic, through dedicated logic, through the interaction of program control and dedicated logic, or even manually, the particular technique being selectable by the implementer as more specifically understood from the context.
It should be further appreciated by those skilled in the art that any block diagrams herein represent conceptual views of illustrative circuitry embodying the principles of the invention. Similarly, it will be appreciated that any flow charts represents various processes which may be substantially represented in computer readable medium and so executed by a computer or processor, whether or not such computer or processor is explicitly shown.
Embodiments of the method can be performed by means of dedicated hardware and/of software or any combination of both.
While the principles of the invention have been described above in connection with specific embodiments, it is to be clearly understood that this description is made only by way of example and not as a limitation on the scope of the invention, as defined in the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
16305460.4 | Apr 2016 | EP | regional |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2017/059140 | 4/18/2017 | WO | 00 |