This application claims the priority benefit of Korean Patent Application No. 10-2012-0007210, filed on Jan. 25, 2012, in the Korean Intellectual Property Office, the disclosure of which is incorporated herein by reference.
1. Field
The following description relates to an apparatus and method of expediting generation of a three-dimensional (3D) hologram, and more particularly, to a method and apparatus for generating a hologram pattern using an operational apparatus by receiving an input of data of a spatial object or image data including color and depth.
2. Description of the Related Art
A stereoscopic image is provided to realize a three-dimensional (3D) image. However, since the stereoscopic image has a limit due to visual fatigue, a limited number of view points, and the like, a method of realizing a 3D image using a hologram is drawing attention.
A hologram is technology for representing a 3D space that has a limitless number of viewpoints and causes little visual fatigue by reproducing a 3D spatial object using a strength and phase of light. Generally, a hologram is generated using a computer generated hologram (CGH) in a method of generating a digital hologram. That is, in the digital hologram generating method, optical signals are approximated, and a hologram is generated using an interference pattern generated through a mathematical operation.
In the digital hologram generating method, a 3D spatial object is construed as a set of 3D points, and point holograms corresponding to all 3D points constituting the 3D spatial object are generated. In this instance, as the sophistication or complexity of the 3D spatial object increases so too does a number of 3D points included in the 3D spatial object, and thus, an amount of calculation subsequently increases.
According to example embodiments, an apparatus and method of generating a hologram that may expedite generation of a three-dimensional (3D) hologram are disclosed.
According to example embodiments, an apparatus and method that may expedite generation of a 3D hologram, without relying on a separate look-up table (LUT), are disclosed.
According to example embodiments, an apparatus and method of generating a hologram that may be suitable for a parallel process using multiple processors, and may minimize an operational delay resulting from external memory access, are disclosed.
The foregoing and/or other aspects are achieved by providing an apparatus for generating a hologram, the apparatus including a calculation unit to generate a pattern for a partial area by recurrent interpolation using input 3D data, the partial area corresponding to a portion of an entire area for which a hologram pattern is to be generated, and a pattern duplicating unit to complete a pattern for the entire area by duplicating the generated pattern for the partial area.
The partial area may correspond to a one-eighth area of the entire area.
The calculation unit may calculate Fresnel Zone Plate (FZP) pattern values for a plurality of reference points in the partial area, and may calculate FZP pattern values for points excluding the plurality of reference points in the partial area, by performing interpolation using an FZP pattern value calculated for at least one point, among the plurality of reference points.
In this instance, the calculation unit may calculate FZP pattern values for the plurality of reference points, using a solution of a wave equation, for example, a Rayleigh-Sommerfeld solution.
The calculation unit may include a plurality of processors to perform parallel recurrent interpolation, and the apparatus may further include a scheduling unit to perform scheduling for the parallel recurrent interpolation with respect to the plurality of processors.
The apparatus may further include a pattern setting unit to select the partial area from the entire area, and to determine a size of a pattern in the partial area.
The foregoing and/or other aspects are achieved by providing an apparatus for generating a hologram, the apparatus including a pattern setting unit to set points at which a hologram pattern is to be generated with respect to a one-eighth area of an entire area for which a hologram pattern may be generated, and a calculation unit to calculate pattern values for a plurality of reference points selected in the one-eighth area of the entire area, and to generate a pattern for the one-eighth area by a recurrent interpolation scheme, based on the calculated pattern values for the plurality of reference points.
In this instance, the apparatus may further include a pattern duplicating unit to complete a pattern for the entire area by duplicating the generated pattern for the one-eighth area.
The calculation unit may calculate FZP pattern values for the plurality of reference points, using a solution of a wave equation.
The calculation unit may include a plurality of processors to perform parallel recurrent interpolation, and the apparatus may further include a scheduling unit to perform scheduling for the parallel recurrent interpolation with respect to the plurality of processors.
The foregoing and/or other aspects are achieved by providing a method of generating a hologram, the method include generating, by a calculation unit of a hologram generating apparatus, a pattern for a partial area by recurrent interpolation using input 3D data, the partial area corresponding to a portion of an entire area for which a hologram pattern is to be generated, and completing, by a pattern duplicating unit of the hologram generating apparatus, a pattern for the entire area by duplicating the generated pattern for the partial area.
Additional aspects of embodiments will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the disclosure.
These and/or other aspects will become apparent and more readily appreciated from the following description of embodiments, taken in conjunction with the accompanying drawings of which:
Reference will now be made in detail to embodiments, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to like elements throughout. Embodiments are described below to explain the present disclosure by referring to the figures.
When memory allocation and hologram initialization are performed, and 3D point data is received by the apparatus 100, a process of generating a three-dimensional (3D) hologram image may be initiated.
A pattern setting unit 110 may set a size of a Fresnel Zone Plate (FZP) pattern, which is an interval of a point for which a pattern value may be calculated, by determining a size of a pattern. A shape of the pattern and a size of the pattern will be further described with reference to
A calculation unit 130 may calculate pattern values for reference points in order to directly calculate a pattern value for a one-eighth area, and also may calculate pattern values for other points in the one-eighth area, using recurrent interpolation.
A scheduling unit 120 may perform scheduling to minimize a number of idle processors and a number of processing iterations when processors included in the calculation unit 130 calculate the pattern values through recurrent interpolation.
The scheduling process will be further described with reference to
Through the aforementioned processes, the calculation unit 130 may complete the pattern for the one-eighth area, and a pattern duplicating unit 140 may complete a pattern for the entire area by duplicating the completed pattern for the one-eighth area throughout the entire area.
The process of duplicating the pattern will be further described with reference to
A hologram may refer to technology for restoring a 3D image identical to an original image, by recording and reproducing phase information and intensity of light, that is, an electromagnetic (EM) wave, in a space.
In a case of a computer generated hologram, a hologram pattern may generally be generated based on information about a 3D space and an object, in order to directly capture phase information and intensity of light, due to such difficulties as maintenance of darkroom environment, control of short-wavelength light, or management of movements of an object, for example.
However, because intensity and phase information on a hologram plane may need to be calculated for all spatial points, a great amount of time may be expended in generating a hologram. Typically, thousands to tens of thousands of seconds are expended in generating a single piece of a hologram.
Example embodiments may expedite an operational process in the process of generating the hologram.
According to example embodiments, a hologram pattern may be generated using a solution of a wave equation. For example, a 3D hologram may be obtained by generating a hologram pattern for a one-eighth area corresponding to a portion of an entire area, using a Rayleigh-Sommerfeld solution, hereinafter referred to as an R-S solution, as expressed by Equation 1, and generating a pattern for the entire area by duplicating the generated hologram pattern for the one-eighth area over the entire area.
In the process of generating the pattern for the one-eighth area, pattern values for only a portion of reference points may be calculated, and pattern values for other points excluding the reference points may be calculated using recurrent interpolation.
Terms dp and k in Equation 1 may be defined as expressed by Equations 2 and 3, respectively.
The R-S solution may be approximated using binominal expansion as follows.
In particular, if Equation 4 is true, then dp may be calculated by Equation 5.
Accordingly, an approximation of the R-S solution may be expressed by Equation 6.
As can be understood from the hologram pattern 400 for an entire area and the approximation of Equation 6, a hologram pattern to be generated at portions that are located a predetermined distance away from a predetermined point may be concentrically symmetric. Accordingly, in view of concentric symmetry elimination, an FZP pattern for only a one-eighth area may be generated without generating all patterns for the entire area one by one, and the generated pattern for the one-eighth area may be duplicated for remaining areas, whereby a pattern for the entire area may be obtained.
That is, when the concentric symmetry of the hologram pattern is used, pattern values for one-dimensional (1D) points may be calculated directly through ρ=√{square root over ((ξ−xp)2+(η−yp)2)}{square root over ((ξ−xp)2+(η−yp)2)} of Equation 2, and patterns for other points corresponding to (ξ, η) may be obtained indirectly by using the pre-calculated pattern values.
As aforementioned, when an FZP pattern for a one-eighth area 510 is generated, an FZP pattern for a quarter area as shown in the conceptual diagram 500 may be generated by duplicating the generated FZP pattern for the one-eighth area 510. By iteratively duplicating the generated FZP pattern for the quarter area, an FZP pattern for an entire area may be generated.
When the FZP pattern is generated for the one-eighth area 510, patterns for only points present on a 1D line in a single predetermined direction may be generated, without generating patterns for all points in the one-eighth area 510, and the FZP pattern for the one-eighth area 510 may be generated through recurrent interpolation.
In this instance, a look-up table (LUT) containing a correlation between 1D pattern data and radius data may be used.
A value ρ according to the radius data may be pre-calculated in the LUT, and patterns for uncalculated portions may be determined directly by referring to the LUT table, based on calculations performed with respect to the 1D pattern data.
However, when a resolution of a hologram to be displayed increases, a size of the LUT may increase, an amount of time required for external memory access may increase, and a large amount of data may need to be stored in a global memory. Accordingly, a plurality of processors may experience difficulty in performing parallel processes.
Thus, according to example embodiments, a hologram pattern for the one-eighth area 510 may be generated by directly calculating only 1D pattern data, without using an LUT of radius data, and rapidly calculating data for other portions through recurrent interpolation.
For ease of description, it may be assumed that xp=0, yp=0 in coordinates (xp, yp) of a point corresponding to the center of a pattern having concentric symmetry. The assumption may not be problematic since relative coordinates and absolute coordinates may be readily interchangeable.
A pattern value at the origin corresponding to xp=0, yp=0 may be calculated based on Equation 6, as expressed by Equation 7.
In Equation 7, a value in (the dashed box) may be referred to as a variable phase distance (VPD). According to the aforementioned concentric symmetry, when the VPD is identical, a pattern may have an identical phase on a holographic plane.
Although an R-S solution may be calculated along a diagonal line, the R-S solution may not necessarily be calculated along the diagonal line. Instead, initial R-S solutions may be calculated for points on a suitable 1D line, or a portion of predetermined reference points, depending on applications.
The calculating process may be performed in real time using the calculated initial values for the reference points. Depending on example embodiments, the calculated initial values may be used as an LUT.
Among the reference points of
In the abovementioned equations, when Q is a point that is distant from the origin by dm-1,n, and positioned on a line
Also, let a hologram pattern value at a point A be V(m−1, n−1), and a hologram pattern value at a point B be V(m, n). A hologram pattern value V(m−1, n) at a point P which is yet to be calculated may be calculated by linear interpolation, as expressed by Equation 13.
A process of performing the aforementioned process iteratively, using points for which pattern values are pre-calculated with respect to points for which pattern values are yet to be calculated, may correspond to recurrent interpolation that is mentioned throughout the present disclosure.
The above described process may be performed in parallel by processors included in the calculation unit 130 of
As shown in
Although linear interpolation is used as an example for ease of description, it may be possible to recurrently perform higher order interpolation to obtain a more accurate hologram pattern value. In addition, it will be understood that various changes in form and details may be made therein without departing from the spirit and scope of the present disclosure.
The pattern duplicating unit 140 of
A pattern for a quarter area 1010 may be completed, and the pattern duplicating unit 140 may duplicate the pattern for the quarter area 1010 to another neighboring quarter area 1020.
By iterating the process, the pattern duplicating unit 140 may complete patterns for other quarter areas 1030 and 1040, and may complete a pattern 1000 for an entire area.
A process of generating patterns for all points in a one-eighth area may be performed by sequential computation of one processor included in the calculation unit 130 of
However, the process of generating the patterns for all points in the one-eighth area may be performed by parallel computation of a plurality of processors included in the calculation unit 130.
Because a number of idle processors may increase as the iterations are performed iteratively in the parallel process, improvement in efficiency may be demanded.
According to other example embodiments, separate scheduling may be performed to increase a computing rate by reducing a number of idle processors.
The scheduling unit 120 of
When the iterations are performed, recurrent interpolation may be allocated to processors, for example, Proc #1 through Proc #9, as shown in
Operational states of the processors may be shown in
When compared to the operational states of
In operation 1410, a process of generating a 3D hologram image may be initiated, and memory allocation and hologram initialization may be performed.
In operation 1420, the apparatus 100 of
In operation 1430, the pattern setting unit 110 of
In operation 1440, the calculation unit 130 of
In operation 1450, the calculation unit 130 may generate an FZP pattern in a one-eighth area using recurrent interpolation. The calculation process performed by the recurrent interpolation may be identical to the description provided with reference to
In operation 1460, the pattern duplicating unit 140 may duplicate the FZP pattern for the one-eighth area that is generated by the calculation unit 130, whereby patterns for other one-eighth areas or patterns for other quarter areas may be completed. This process may be identical to the description provided with reference to
In operation 1470, the FZP patterns generated thus far may be added as a hologram pattern. Whether an additional hologram pattern is to be generated may be determined in operation 1480, and the process of operations 1420 through 1470 may be iterated, as necessary.
In operation 1510, a size of an FZP pattern may be determined by the pattern setting unit 110 of
In operation 1520, memory allocation and FZP pattern initialization may be performed. A process of calculating pattern values for reference points in operation 1530 may be similar to the flowchart of
In operations 1540 through 1580, pattern values may be calculated for points, which neighbor the reference points and for which pattern values are yet to be calculated, through recurrent interpolation, by sequentially increasing a number of iterations.
When the iterations are terminated, the calculated pattern values may be stored in operation 1590, and a process of generating a pattern for an entire area may be performed by the pattern duplicating unit 140 of
The method according to the above-described embodiments may be recorded in non-transitory computer-readable media including program instructions to implement various operations embodied by a computer. The media may also include, alone or in combination with the program instructions, data files, data structures, and the like. The program instructions recorded on the media may be those specially designed and constructed for the purposes of embodiments, or they may be of the kind well-known and available to those having skill in the computer software arts. Examples of non-transitory computer-readable media include magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD ROM discs and DVDs; magneto-optical media such as optical discs; and hardware devices that are specially configured to store and perform program instructions, such as read-only memory (ROM), random access memory (RAM), flash memory, and the like. The computer-readable media may also be a distributed network, so that the program instructions are stored and executed in a distributed fashion. The program instructions may be executed by one or more processors. The computer-readable media may also be embodied in at least one application specific integrated circuit (ASIC) or Field Programmable Gate Array (FPGA), which executes (processes like a processor) program instructions. Examples of program instructions include both machine code, such as produced by a compiler, and files containing higher level code that may be executed by the computer using an interpreter. The described hardware devices may be configured to act as one or more software modules in order to perform the operations of the above-described embodiments, or vice versa.
Although embodiments have been shown and described, it would be appreciated by those skilled in the art that changes may be made in these embodiments without departing from the principles and spirit of the disclosure, the scope of which is defined by the claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
10-2012-0007210 | Jan 2012 | KR | national |