This application claims the benefit under 35 USC 119(a) of Korean Patent Application No. 10-2014-0187323 filed on Dec. 23, 2014, in the Korean Intellectual Property Office, the entire disclosure of which is incorporated herein by reference for all purposes.
1. Field
The following description relates to an image rendering field of photon mapping.
2. Description of Related Art
Photon mapping is used as a photorealistic high-definition rendering method. Photon mapping enables various effects such as specular, diffuse, caustics, and indirect illumination. However, photon mapping requires a high computational complexity for ray tracing.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
In one general aspect, an image processing apparatus includes a memory configured to store a data structure in which gather rays generated by performing gather ray tracing from a rendering viewpoint are clustered hierarchically, the gather rays including a first gather ray and a second gather ray associated with the first gather ray in the data structure; and a processor configured to merge a photon gathering result associated with the second gather ray with a photon gathering result associated with the first gather ray in response to the photon gathering result associated with the first gather ray not satisfying a first condition.
The data structure may be built by clustering the gather rays based on a similarity between characteristic information corresponding to the gather rays, and setting a hierarchical connection relationship of the clustered gather rays.
The characteristic information may include any one or any combination of any two or more of a three-dimensional (3D) position of an object point corresponding to each of the gather rays, a normal direction of the object point, a texture corresponding to the object point, and a bidirectional reflectance distribution function (BRDF) corresponding to the object point.
The second gather ray may be a neighbor gather ray of the first gather ray in the data structure that enables the first condition to be satisfied by the merging.
The first condition may be a condition in which a difference between the photon gathering result associated with the first gather ray and a photon gathering result associated with a neighbor gather ray of the first gather ray in the data structure is less than or equal to a first threshold.
The processor may be further configured to rebuild the data structure so that a second condition is satisfied in response to the photon gathering result associated with the first gather ray not satisfying the second condition.
The second condition may be a condition in which the difference between the photon gathering result associated with the first gather ray and the photon gathering result associated with the neighbor gather ray of the first gather ray in the data structure is less than or equal to a second threshold that is greater than the first threshold.
In another general aspect, an image processing apparatus includes a memory configured to store a data structure built by clustering gather rays generated by performing gather ray tracing from a rendering viewpoint based on a similarity between characteristic information corresponding to the gather rays and setting a hierarchical connection relationship of the clustered gather rays, the gather rays including a first gather ray, the data structure including parent nodes in an upper hierarchy of the first gather ray in the data structure; and a processor configured to determine a representative node of the first gather ray that enables a first condition to be satisfied among the parent nodes in response to a photon gathering result associated with the first gather ray not satisfying the first condition.
The data structure may further include leaf nodes corresponding to the gather rays; and the representative node may be a parent node of a leaf node corresponding to the first gather ray and a leaf node corresponding to a second gather ray among the gather rays that enables the first condition to be satisfied by sharing photon gathering between the first gather ray and the second gather ray.
The first condition may be a condition in which a difference between the photon gathering result associated with the first gather ray and a photon gathering result associated with a neighbor gather ray of the first gather ray in the data structure is less than or equal to a first threshold.
The processor may be further configured to rebuild the data structure so that a second condition is satisfied in response to the photon gathering result associated with the first gather ray not satisfying the second condition.
The second condition may be a condition in which the difference between the photon gathering result associated with the first gather ray and the photon gathering result associated with the neighbor gather ray of the first gather ray in the data structure is less than or equal to a second threshold that is greater than the first threshold.
In another general aspect, an image processing method of an image processing apparatus including computing hardware includes building a data structure in which gather rays generated by performing gather ray tracing from a rendering viewpoint are clustered hierarchically, the gather rays including a first gather ray and a second gather ray that is a neighbor gather ray of the first gather ray in the data structure; and associating the second gather ray with the first gather ray in response to a photon gathering result associated with the first gather ray not satisfying a first condition.
The data structure may include leaf nodes corresponding to the gather rays, and parent nodes in an upper hierarchy of the first gather ray in the data structure; and the associating may include determining a representative node that enables the first condition to be satisfied among the parent nodes, the representative node being a parent node of a leaf node corresponding to the first gather ray and a leaf node corresponding to a second gather ray among the gather rays; and sharing photon gathering between the first gather ray and the second gather ray.
The first condition may be a condition in which a difference between the photon gathering result associated with the first gather ray and a photon gathering result associated with a neighbor gather ray of the first gather ray in the data structure is less than or equal to a first threshold.
The method may further include rebuilding the data structure so that a second condition is satisfied in response to the photon gathering result associated with the first gather ray not satisfying the second condition.
The second condition may be a condition in which the difference between the photon gathering result associated with the first gather ray and the photon gathering result associated with the neighbor gather ray of the first gather ray in the data structure is less than or equal to a second threshold that is greater than the first threshold.
In another general aspect, a non-transitory computer-readable storage medium stores instructions to cause computing hardware to perform the method described above.
Other features and aspects will be apparent from the following detailed description, the drawings, and the claims.
Throughout the drawings and the detailed description, the same reference numerals refer to the same elements. The drawings may not be to scale, and the relative size, proportions, and depiction of elements in the drawings may be exaggerated for clarity, illustration, and convenience.
The following detailed description is provided to assist the reader in gaining a comprehensive understanding of the methods, apparatuses, and/or systems described herein. However, various changes, modifications, and equivalents of the methods, apparatuses, and/or systems described herein will be apparent to one of ordinary skill in the art. The sequences of operations described herein are merely examples, and are not limited to those set forth herein, but may be changed as will be apparently to one of ordinary skill in the art, with the exception of operations necessarily occurring in a certain order. Also, descriptions of functions and constructions that are well known to one of ordinary skill in the art may be omitted for increased clarity and conciseness.
The features described herein may be embodied in different forms, and are not to be construed as being limited to the examples described herein. Rather, the examples described herein have been provided so that this disclosure will be thorough and complete, and will convey the full scope of the disclosure to one of ordinary skill in the art.
The terms used herein are mainly selected from general terms currently being used in light of the features described in this application. However, other terms may be used depending on development and/or changes in technology, custom, or a preference of an operator. Thus, it should be understood that the terms used herein are terms merely used to describe the examples, rather terms intended to limit the spirit and scope of this disclosure.
In addition, in a specific case, most appropriate terms have been arbitrarily selected by the inventors for ease of description and/or for ease of understanding. In this instance, the meanings of the arbitrarily used terms will be clearly explained in the corresponding description. Hence, the terms should be understood not by the simple names of the terms, but by the meanings of the terms and the following overall description of this specification.
Referring to
The processor 120 associates a first gather ray with a second gather ray in the data structure when a photon gathering result associated with the first gather ray does not satisfy a first condition. The foregoing process may be construed as a process of sharing photons between the first gather ray or a corresponding first measurement point and the second gather ray or a corresponding second measurement point. In detail, when the first gather ray is merged with the second gather ray, respective photon gathering results are shared therebetween. As will be described in more detail, the first condition is a condition that is satisfied when a difference between the photon gathering result associated with the first gather ray and a photon gathering result associated with a neighbor gather ray of the first gather ray in the data structure is less than or equal to a first threshold.
When the first condition is not satisfied, the data structure is rebuilt, rather than merging the gather rays. Such rebuilding is performed when the photon gathering result associated with the first gather ray does not satisfy a second condition. For example, but not limited thereto, the second condition is a condition that is satisfied when the difference between the photon gathering result associated with the first gather ray and the photon gathering result associated with the neighbor gather ray of the first gather ray in the data structure is less than or equal to a second threshold. In this example, the second threshold is greater than the first threshold. Examples will be described in detail with reference to
The second pass is referred to as gather ray tracing, and corresponds to a process of determining a measurement point at which a color value generated by a photon is to be measured through ray tracing from a viewpoint 240 at which an image is to be rendered. Determined measurement points correspond to portions to be used to calculate color values at object points. A color value at a viewpoint is determined by accumulating effects of color values of photons on the measurement points, whereby rendering by photon mapping is completed. In a case of progressive photon mapping (PPM) that is widely used, a measurement point is determined by performing ray tracing from the viewpoint 240. Photons around the measurement point are gathered and measured through photon tracing or photon distribution as illustrated. In the photon distribution process, when a rendering result is noisy, a process of sharing photons between measurement points is performed, rather than increasing a number of photons to be distributed. The foregoing process will be described in detail with reference to
Referring to
The gather rays 361, 362, and 363 and/or the measurement points 371, 372, and 373 associated therewith are built and managed as a hierarchical data structure. In existing typical photon mapping, when an image acquired as a result of gathering photons at measurement points is noisy, a number of photons to be distributed is increased. However, such a process of increasing photon distribution is performed without considering a characteristic of a scene or a measurement point. Thus, in some cases, redundant distributing of photons causes an increase in a computational complexity. In one example, in lieu of and/or in addition to increasing the number of photons to be distributed, a portion of measurement points are associated to share photons therebetween. Measurement points between which photons are to be shared are preset as a hierarchical data structure, which will be described with reference to
Referring to
The leaf nodes 411, 412, 413, 414, 415, 416, 417, and 418 corresponding to gather rays or measurement points are clustered based on characteristic information of the measurement points and/or the gather rays. Clustering may be construed as associating leaf nodes with the same parent node. In the data structure of
For example, but not limited thereto, the characteristic information includes any one or any combination of any two or more of 3D positions, normal directions, textures, and BRDFs of measurement points. When measurement points are disposed at different 3D positions despite corresponding gather rays being adjacent to each other, the adjacent gather rays may correspond to different objects, and thus photon sharing therebetween may be inappropriate. By such a data structure, a relationship for photon sharing may be identified.
In one example, a data structure as shown may be built through gather ray tracing, and an error metric may be performed on a result of performing photon distribution and photon gathering. For example, color values are generated as a photon gathering result, and color values of neighbor leaf nodes, for example, the leaf nodes 411 and 412, are compared. The leaf nodes correspond to points that are adjacent to each other and have similar textures and BRDFs. Thus, a slight difference in color values between the leaf nodes after photon mapping is performed may be expected. Thus, when a condition that the difference in color values the leaf nodes is less than or equal to a first threshold, hereinafter referred to as a first condition, is not satisfied, a corresponding result is construed as being noisy due to insufficient photons being distributed to the leaf nodes. In this example, an image processing apparatus determines the parent node 421 of the leaf nodes 411 and 412 to be a representative node, without separately distinguishing the leaf nodes 411 and 412. All photons distributed to the leaf nodes 411 and 412 belonging to the parent node 421 are associated with gather rays associated with the leaf nodes 411 and 412. Color values are shared between the gather rays. When the first condition is not satisfied even when the parent node 421 is determined to be the representative node, the grandparent node 431 is determined to be the representative node by re-performing a hierarchical search. The grandparent node 432 is determined to be a representative node of the leaf nodes 415, 416, 417, and 418 in that manner. In some cases, when the first condition is satisfied at leaf nodes without performing such merging or photon sharing, the leaf nodes 413 and 414 are determined to be representative nodes autonomously.
However, in some other cases, the data structure may need to be rebuilt. For example, when a condition that a difference between color values of two leaf nodes is less than or equal to a second threshold, hereinafter referred to as a second condition, is not satisfied, the two leaf nodes are assumed not to be associated with the same parent node in a data structure. In this example, the second threshold is a value much greater than the first threshold. Measurement points or gather rays classified as being adjacent and similar to each other based on characteristic information may in fact correspond to different objects in reality or have different color values due to different directions, not because noise occurs due to insufficient photons being distributed, but because a probability of measurement points having different color values is relatively high. In this example, the data structure needs to be rebuilt. Thus, the characteristic information is re-analyzed, and one leaf node is separated from its parent node and moved to another parent node. The foregoing error metric will be described with reference to
An example of merging measurement points so that a number of photons distributed at each measurement point is greater than or equal to a predetermined number of photons, rather than so that a difference in color values obtained as a photon gathering result is less than or equal to the first threshold, is also possible. However, in some cases, a corresponding result may not be noisy despite there being a relatively fewer number of photons distributed at a measurement point. In this example, skipping such processing may be helpful to increase a quality of rendering. When a number of measurement points to be merged increases, for example, when a representative node is selected as a node of an upper hierarchy in the example of
Referring to
In operation 630, photon tracing is performed. In this example, photon distribution is performed and a color value generated by the distributed photons is determined. A first iteration of operations 620 and 630 may not be a final rendering result. In operation 640, the error metric as described above is performed by comparing a color value at each gather ray and/or each measurement point to a color value at an adjacent gather ray and or measurement point. Through iterative performing of operations 620 and 630, optimal representative nodes, for example, the nodes indicated in black in the data structure of
Referring to
When the first condition is not satisfied in operation 710, operation 720 is performed. In operation 720, whether a second condition is satisfied is determined. As described with reference to
As described above, distributed photons are adaptively shared between hierarchically associated measurement points and/or gather rays. Through the foregoing process, a quality of photon mapping is greatly improved without performing additional photon distribution and tracing. Further, such examples cause only a relatively slight increase in a computational complexity compared to an example of additionally distributing photons, and thus operation resources may be utilized efficiently.
The image processing apparatus 100, the memory 110, and the processor 120 illustrated in
The method illustrated in
Instructions or software to control a processor or computer to implement the hardware components and perform the methods as described above are written as computer programs, code segments, instructions or any combination thereof, for individually or collectively instructing or configuring the processor or computer to operate as a machine or special-purpose computer to perform the operations performed by the hardware components and the methods as described above. In one example, the instructions or software include machine code that is directly executed by the processor or computer, such as machine code produced by a compiler. In another example, the instructions or software include higher-level code that is executed by the processor or computer using an interpreter. Programmers of ordinary skill in the art can readily write the instructions or software based on the block diagrams and the flow charts illustrated in the drawings and the corresponding descriptions in the specification, which disclose algorithms for performing the operations performed by the hardware components and the methods as described above.
The instructions or software to control a processor or computer to implement the hardware components and perform the methods as described above, and any associated data, data files, and data structures, are recorded, stored, or fixed in or on one or more non-transitory computer-readable storage media. Examples of a non-transitory computer-readable storage medium include read-only memory (ROM), random-access memory (RAM), flash memory, CD-ROMs, CD-Rs, CD+Rs, CD-RWs, CD+RWs, DVD-ROMs, DVD-Rs, DVD+Rs, DVD-RWs, DVD+RWs, DVD-RAMS, BD-ROMs, BD-Rs, BD-R LTHs, BD-REs, magnetic tapes, floppy disks, magneto-optical data storage devices, optical data storage devices, hard disks, solid-state disks, and any device known to one of ordinary skill in the art that is capable of storing the instructions or software and any associated data, data files, and data structures in a non-transitory manner and providing the instructions or software and any associated data, data files, and data structures to a processor or computer so that the processor or computer can execute the instructions. In one example, the instructions or software and any associated data, data files, and data structures are distributed over network-coupled computer systems so that the instructions and software and any associated data, data files, and data structures are stored, accessed, and executed in a distributed fashion by the processor or computer.
While this disclosure includes specific examples, it will be apparent to one of ordinary skill in the art that various changes in form and details may be made in these examples without departing from the spirit and scope of the claims and their equivalents. The examples described herein are to be considered in a descriptive sense only, and not for purposes of limitation. Descriptions of features or aspects in each example are to be considered as being applicable to similar features or aspects in other examples. Suitable results may be achieved if the described techniques are performed in a different order, and/or if components in a described system, architecture, device, or circuit are combined in a different manner, and/or replaced or supplemented by other components or their equivalents. Therefore, the scope of the disclosure is defined not by the detailed description, but by the claims and their equivalents, and all variations within the scope of the claims and their equivalents are to be construed as being included in the disclosure.
Number | Date | Country | Kind |
---|---|---|---|
10-2014-0187323 | Dec 2014 | KR | national |