The present invention generally relates to the technical field of digital holograms.
It relates in particular to a method and a device for transmitting data representative of a digital hologram.
It has been proposed to represent a digital hologram by means of atoms located in the plane of the hologram and each representing a light contribution linked to a particular wavelet (in practice a Gabor wavelet).
When the digital hologram has to be reconstructed by means of a remote holographic display, descriptive data of these atoms are transmitted, which comprise, for example, for each atom: the position of this atom in the plane of the hologram, the coefficient associated with this atom and values defining the Gabor wavelet associated with this atom.
In order to limit the quantity of information to be transmitted, it has been proposed in document WO 2015/097 358 to transmit only the data relating to Gabor wavelets whose emission cone has an intersection with a volume linked to the observer.
In this context, the invention proposes a method for transmitting data representative of a digital hologram represented by a set of atoms each having a diffraction spectrum in a plane of observation, comprising the following steps:
The atoms are hence ordered as a function of the interest they have for the reconstruction of the digital hologram at the position of observation (which is the position from which the digital hologram is viewed). The first data transmitted are hence the most relevant and allow a rapid acceptable reconstruction of the digital hologram. This reconstruction can then be improved when the subsequent data are received. The quantity of transmitted data can further be adapted as a function of the circumstances (for example, the rate available on the communication network used).
As explained hereinafter, each above-mentioned set can include a single atom (as in the first embodiment described hereinafter) or a variable number of atoms (as in the second embodiment described hereinafter).
The method defined hereinabove can comprise a previous step of receiving data representative of the position of observation in the plane of observation.
According to a first possibility, each set can include a single atom; it can then be provided that the position associated with the involved set is the position of the center of the diffraction spectrum (in the plane of observation) of the atom included in the involved set.
The order can also be determined as a function of an angular dispersion or an amplitude associated with the atom included in the involved set.
The descriptive data of the atom that are transmitted can moreover include data representative of the position of the center of the diffraction spectrum of this atom in a viewing window linked to the position of observation. The quantity of data to be transmitted to represent the position of the involved atom is hence reduced.
According to a second possibility, each set includes the atom having a diffraction spectrum whose center is located in a corresponding region (for example a block) of the plane of observation.
In this case, the position associated with the involved set is for example the center of the region corresponding to said involved set.
The descriptive data of at least one atom included in the involved set can then comprise data representative of the position of the center of the diffraction spectrum of this atom in the region corresponding to the involved set. The quantity of data to be transmitted to represent the position of the involved atom is hence reduced.
The method can then comprise a step of transmitting data representative of the position of said region in the plane of observation.
Moreover, it can then be provided a previous step of associating each atom with the region (for example the block) of the plane of observation that contains the center of the diffraction spectrum of this atom.
The method can also comprise, for at least one given region of the plane of observation, a step of ordering the atoms associated with said given region as a function of an angular dispersion or an amplitude associated with each of these atoms.
The invention also proposes a device for transmitting data representative of a digital hologram represented by a set of atoms each having a diffraction spectrum in a plane of observation, comprising:
Such a device can include a module for receiving data representative of the position of observation in the plane of observation.
As already indicated, each set can include a single atom; the determination module is then, for example, designed to determine the order among said sets as a function of the distance, in the plane of observation, between a position of observation and the position of the center of the diffraction spectrum of the atom included in the involved set.
The transmission module can be designed to transmit data representative of the position of the center of the diffraction spectrum of said at least one atom in a viewing window linked to the position of observation.
As already indicated, according to another possibility, each set can include the atoms having a diffraction spectrum whose center is included in a corresponding region (for example a block) of the plane of observation; the determination module can then be designed to determine the order among said sets as a function of the distance, in the plane of observation, between a position of observation and the center of the region corresponding to said involved set.
The transmission module can then be designed to transmit data representative of the position of the center of the diffraction spectrum of said at least one atom in the region corresponding to the involved set.
In this case, it can also be provided a module for associating each atom with the region of the plane of observation containing the center of the diffraction spectrum of this atom.
It is also proposed, in an original manner per se, a method for transmitting data representative of a digital hologram represented by a set of Gabor atoms each having a diffraction spectrum in a plane of observation, comprising the following steps for transmitting descriptive data of a given Gabor atom:
These characteristic data define for example an index of dilation and index of rotation associated with the given atom.
As explained hereinafter, it is indeed possible, using the characteristics of the Gabor wavelet and the position of the diffraction spectrum center, to find the position associated with the given atom in the plane of the digital hologram (also taking into account the distance between the plane of observation and the plane of the digital hologram, represented for example by an ordinate zO and potentially previously received at the two transmission steps mentioned hereinabove, for example at receipt of data representative of a position of observation xO, yO, zO).
The characteristic data can also define a coefficient (typically a complex coefficient) associated with the atom and used for reconstructing the hologram as explained hereinafter.
It is hence also proposed, within this framework, a method for receiving data representative of a digital hologram represented by a set of Gabor atoms each having a diffraction spectrum in a plane of observation, comprising the following steps, at receipt of descriptive data of a given Gabor atom:
It is hence possible, at receipt, to reconstruct the digital hologram on the basis notably of the position of the atom in the plane of a digital hologram.
Of course, the different features, alternatives and embodiments of the invention can be associated with each other according to various combinations, insofar as they are not mutually incompatible or exclusive.
Moreover, various other features of the invention will be apparent from the appended description made with reference to the drawings that illustrate non-limitative embodiments of the invention, and wherein:
In the following, we will consider a digital hologram H of resolution (Nx, Ny) represented by a set AK of atoms (here Gabor atoms) ak each corresponding to a light contribution linked to a particular wavelet (here a Gabor wavelet). For purposes of this disclosure, the term atom is used as it is defined in the article “The Work of Yves Meyer”, by I. Daubechies, in Proceedings of the International Congress of Mathematicians, Hyderabad, 2000, p. 120.
As proposed in article “Color digital hologram compression based on matching pursuit” by A. El Rhammad, P. Gioia, A. Gilles, M. Cagnazzo and B. Pesquet-Popescu, in Applied Optics, Vol. 57, n° 17, Jun. 10, 2018, each atom ak of the set AK can be in practice defined by:
In this definition, the index of dilation lk is an integer whose value is between 1 and a predetermined number S; likewise, the index of rotation pk is an integer whose value is between 1 and a predetermined number P.
The index of dilation lk and the index of rotation pk define a discrete Gabor wavelet glk, pk (as described in more detail in the above-mentioned article) and the coefficient ck then corresponds to the scalar product of the digital hologram H and this Gabor wavelet glk, pk taken at the point of coordinates (tx, ty) in the plane PH of the digital hologram H.
Each atom ak (defined as indicated hereinabove) hence corresponds to a light ray diffracted at the point of coordinates (tx, ty) of the digital hologram H with a direction defined by an azimuth angle θk and a diffraction angle φk and an angular dispersion Δφk, as shown in
These angles θk, φk and angular dispersion Δφk are defined for each atom ak (due to the Gabor wavelet associated with this atom ak), here from the parameters defining the involved atom ak as indicated hereinabove:
θk=(pk−1).π/P;
φk=arcsin(λ.f/s(lk));
Δφk=arcsin(λ.(f+αk))−arcsin(λ.f),
where λ is the wavelength of the involved light, s(lk) the parameter of dilation associated (in a manner defined in the chosen representation) with the index of dilation lk, αk the frequency width of the Gaussian window, which depends on the parameter of dilation s(lk), and f the spatial frequency of the Gabor mother wavelet (from which the Gabor wavelet associated with the atom ak is constructed, notably by dilation by the above-mentioned parameter of dilation; we generally take f=(2Δ)−1 where Δ is the spacing between 2 pixels of the digital hologram H).
It should be noted in this respect that the operation is described here for a particular chromatic component (of wavelength λ) of the digital hologram H. However, the digital hologram H could in practice include other chromatic components, each of the chromatic components being then processed and transmitted as will described hereinafter.
Moreover, as indicated hereinabove, the embodiment described here uses a decomposition using Gabor wavelets. However, as an alternative, other decompositions could also be used, for example using Morlet wavelets, as described for example in article “Morlet Wavelet transformed holograms for numerical adaptive view-based reconstruction”, by K. Viswanathan, P. Gioia and L. Morin, in Proc. SPIE 9216, Optics and Photonics for Information Processing VIII, August 2014, San Diego, United-States.
Moreover, in the example described herein, the set Ak of atoms ak representing the digital hologram H is obtained by selecting the atoms ak among a wider set AN of atoms an, here by means of a “Matching Pursuit” algorithm as described in the precited article and mentioned hereinafter. (The wider set AN is for example the set of the N atoms an associated with all the Gabor wavelets conceivable for the Nx.Ny points of the digital hologram, respectively, for the S discretized indices of dilation and the P discretized indices of rotation, i.e. N=Nx.Ny.S.P).
Such a selection allows obtaining a parsimonious representation of the digital hologram H by the atoms ak of the set Ak.
The invention is however not limited to the case of a set Ak ensuing from such a selection and could therefore be applied, for example, to the set AN mentioned hereinabove.
This system includes a first electronic device 100 (here a server) and a second electronic device 200 (here a client device such as a personal computer or a multifunction mobile).
The electronic device 100 includes a unit 120 for the construction of a representation of the digital hologram H and a unit 140 for the preparation and sending of a flow of data.
As will be apparent from the following description, the construction unit 120 includes several modules intended to operate offline, i.e. before the exchange of data with the second electronic device 200. The preparation and sending unit 140 itself includes several modules intended to operate online, i.e. during the exchange of data with the second electronic device 200.
The electronic device 100 includes (here within the above-mentioned construction unit 120) a digital hologram generation module 122, an expansion module 124 and a reduction module 126.
The digital hologram generation module 122 is designed to calculate the digital hologram H from descriptive data of different views and depth of a three-dimensional scene, as described for example in article “Computer generated hologram from multiview-plus-depth data considering specular reflections” by A. Gilles et al., in 2016 IEEE International Conference on Multimedia & Expo Workshops (ICMEW), IEEE 2016.
As an alternative, the digital hologram H could be determined by acquisition of a real scene using image sensors.
As already indicated, the digital hologram H has a resolution (Nx, Ny) and can hence be defined by a matrix of dimensions Nx×Ny with complex coefficients.
The expansion module 124 is designed to produce a first representation AN of the digital hologram H, here by means of N Gabor atoms an.
As indicated hereinabove, this first representation AN is obtained by projecting (in practice by means of a scalar product operation) the digital hologram H on a set of Gabor wavelets g (by considering, for each point of the digital hologram H, the different Gabor wavelets g each having a parameter of dilation chosen among S predefined parameters of dilation and a parameter of orientation chosen among P predefined parameters of orientation).
Each atom an of the set AN is hence defined by:
The reduction module 126 is designed to obtain, based on the first representation AN of the digital hologram H, a second representation AK of the digital hologram H, here by selection (among the atoms an described hereinabove) of the most relevant atoms ak for the reconstruction by means of a “Matching Pursuit” algorithm, as described in the above-mentioned article “Color digital hologram compression based on matching pursuit”.
Each atom ak of the set AK is hence an atom of the set AN and can thus be defined by:
The electronic device 100 moreover includes (here within the above-mentioned preparation and sending unit 140) a reception module 142, a selection module 144, an ordering module 146, an encoding module 148 and a transmission module 150.
The reception module 142 is in particular designed to receive data defining the position of an observer O that wants to view the digital hologram H. This position is for example defined by coordinates (xO, yO, zO) in the above-mentioned reference system, linked to the digital hologram H (the plane PH of the digital hologram H corresponding, as already indicated, to the plane of equation z=0).
The data received by the reception module 142 (here the first 2 coordinates xO, yO) are hence representative in particular of the position of observation (position of the observer O) in the plane of observation PO (plane parallel to the plane PH of the digital hologram H and passing through the position of the observer O, hence of equation z=zO).
It is herein described a solution in which data representative of the digital hologram H are transmitted for a single observer O. It could however be provided, in practice, to receive the respective positions of several observers, then to prepare and send data for each of these observers (by using the solution proposed hereinafter separately for each of these observers and gathering the data relating to the different observers in a same flow of data).
It is possible to define, based on the position of the observer O, a viewing window V located in the plane of observation PO and containing the position of the observer O (by being for example centered on the position of the observer O). The (predefined) resolution of the viewing window V is denoted (Vx, Vy).
As well seen in
The position (t′x, t′y) of the center Ck of the diffraction spectrum Sk (in the plane of observation PO) can hence be obtained based on the coordinates (tx, ty) of the involved atom ak, on the azimuth angle θk and the diffraction angle φk associated with the involved atom ak (as explained hereinabove) and on the ordinate zO of the plane of observation PO. Precisely, we have:
t′
x
=t
x
−z
O.tan φk.sin θk and t′y=ty+zO.tan φk. cos θk.
The selection module 144 is designed to select, among the atoms ak of the set Ak, the atoms am whose diffraction spectrum Sm in the plane of observation PO has an intersection with the viewing window V. (It is to be noted, within this framework, that the radius of the diffraction spectrum Sk is equal to zO.tan(Δφk).)
We denote AM the set of the M atoms am so selected by the selection module 144:
A
M
={a
k
€ A
K
|S
k
∩ V≠Ø}.
As an alternative, the selection module 144 could select among the atoms ak of the set AK, the atoms am for which the center Cm of the diffraction spectrum Sm is located in the viewing window V.
The ordering module 146 is designed to determine an order of transmission within the atoms am of the set AM, taking into account in particular the distance between the position of observation (position of the observer O) and the center Cm of the diffraction spectrum Sm associated with each of these atoms am, but also here (subsidiarily) the amplitude |cm| of the coefficient cm of each of these atoms am and/or the angular dispersion Δφm associated with each of these atoms am, as described hereinafter.
For that purpose, the ordering module 146 calculates, for each atom am, the distance OCm between the position of observation and the center Cm of the diffraction spectrum Sm associated with this atom am.
The ordering module 146 can then rank the atoms am as a function of the associated distance OCm, for example in increasing order of the associated distance OCm (it can then be talked about “spiral scan” of the atoms am).
This amounts to saying that the ordering module 146 determines in this case a function f:[1; M]→[1; M] defining the obtained ordering and such that:
OC
f(i−1)
≤OC
f(i) for any integer i between 2 and M.
The atoms of the set AM are then ordered as follows: af(1), af(2), . . . af(M) as a function of the distance (in the plane of observation PO) between the position of observation O and the center Cm of the diffraction spectrum Sm associated with the involved atom am (precisely in increasing associated distance OCm).
It is here moreover proposed to refine as follows this ordering for atoms am having relatively close distances OCm.
For two atoms ai and aj for which |OCi−OCj|<ϵ (with ϵ a predefined value, preferably low, typically ϵ<0.1.Vx and ϵ<0.1.Vy):
In this case, the above-mentioned function f defining the ordering is such that, for any integer i between 2 and M:
OC
f(i−1)
≤OC
f(i) if |OCf(i−1)−OCf(i)|≥ϵ;
Δφf(i−1)>Δφf(i) if |OCf(i−1)−OCf(i)|<ϵ and Δφf(i−1)≠Δφf(i) and ||Cf(i−1)|−|Cf(i)||<T;
|Cf(i−1)|>|Cf(i)| if |OCf(i−1)−OCf(i)|<ϵ and Δφf(i−1)≠Δφf(i) and ||Cf(i−1)|−|Cf(i)||24 T.
The atoms of the set AM are then ordered as follows: af(1), af(2), . . . af(M) as a function of the distance (in the plane of observation PO) between the position of observation O and the center Cm of the diffraction spectrum Sm associated with the involved atom am, of the angular dispersion Δφm associated with the involved atom am and of the amplitude |cm| of the involved atom am.
The encoding module 148 is designed to encode the parameters defining each of the atoms am of the set AM, in the order defined by the ordering module 146, into a flow of data to be transmitted.
In order to limit the quantity of data to be transmitted, it is herein proposed to encode the position of each atom am by means of data representative of the position of the center Cm of the diffraction spectrum Sm of this atom am in the viewing window V. (The quantity of data required for the encoding of this position in the viewing window is linked to the resolution Vx, Vy of this window and can be estimated by log2(Vx)+log2(Vy), i.e. less than the required quantity for encoding the position in the plane PH of the digital hologram H, of the order of log2(Nx)+log2(Ny).
Indeed, as already indicated and visible in
In the case of the above-mentioned spiral scan, a differential encoding of the positions of the centers Cm of the diffraction spectra Sm of the successively encoded atoms am can further be used. For example, the positions in the viewing window V being discretized, a spiral path can be defined (within the viewing window V), starting from the position of observation O; the respective positions of the centers Cm of the diffraction spectra Sm of the atoms am can then be encoded by means of the distance separating, on the spiral path, the involved center Cm from the preceding center Cm.
The other parameters defining the atoms am (index of dilation lm, index of rotation pm, coefficient cm) can themselves be encoded as described in the above-mentioned article “Color digital hologram compression based on matching pursuit”:
The transmission module 150 is designed to transmit the flow of data prepared by the encoding module 148 on a communication network towards the second electronic device 200.
These data are transmitted in the order determined by the ordering module 146 (order followed by the encoding module 148 as indicated hereinabove) so that the descriptive data of the different atoms am are transmitted in the order allocated to these atoms am by the ordering module 146.
The above-mentioned modules 122, 124, 126, 142, 144, 146, 148, 150 can in practice be implemented by the cooperation of at least one hardware element (such as a processor of the first electronic device 100 and/or, in particular for the reception module 142 and/or the transmission module 150, a communication circuit) and software elements (such as computer program instructions executable by the above-mentioned processor).
These computer program instructions can in particular be such that the first electronic device 100 implements a part at least of the steps described hereinafter with reference to
The second electronic device 200 includes a transmission module 202, a receiving module 204, a reconstruction module 206, a display 208 and a storage module 210.
The transmission module 202 is designed to transmit (towards the first electronic device 100, and precisely the above-mentioned reception module 142) the above-mentioned data defining the position of an observer O, here defined by coordinates (xO, yO, zO) in the reference system linked to the digital hologram H. (This position corresponds for example to a virtual position of the wearer of the second electronic device 200 with respect to the digital hologram H).
The transmission module 202 can in practice transmit these data on the above-mentioned communication network (used by the transmission module 150 of the first electronic device 100). However, as an alternative, the transmission module 202 could transmit these data on another communication network (but always towards the reception module 142 of the first electronic device 100, this reception module 142 being in this case connected to this other communication network).
The receiving module 204 is designed to receive the descriptive data of the different atoms am from the transmission module 150 of the first electronic device 100 and to decode these data.
The receiving module 204 hence receives the descriptive data of different atoms am in the order determined by the ordering module 146, these data here representing (after decoding), for each atom am:
The reconstruction module 206 is designed to calculate a sub-digital hologram H′ by means of the atoms am for which the descriptive data have been received.
For that purpose, for each atom am whose descriptive data are received, the reconstruction module 206 determines the position (tx, ty) of the involved atom am as a function of the coordinates (t′x, t′y) of the center Cm of the diffraction spectrum Sm of this atom am, of the azimuth angle θm and of the diffraction angle φm associated with this atom am and of the ordinate zO of the position of the observer O. (It is recalled that the azimuth angle θm and the diffraction angle φm can be calculated as a function of the index of dilation lm and the index of rotation pm, as indicated hereinabove).
The reconstruction module 206 can then calculate the sub-digital hologram H′ by summing the contribution of the different atoms am for which the descriptive data have been received:
H′=Σ
(am received)
c
m
, g
lm, pm(tx, ty).
The display 208 (using for example a spatial light modulator, or SLM, and potentially integrated into a head-mounted display, for example an augmented reality head-mounted display) can then display the sub-digital hologram H′ reconstructed as indicated hereinabove by the reconstruction module 206.
The storage module 210 stores the atom descriptive data received for all or part of the atoms am (in order to avoid a new transmission of the data relating to these atoms when some of them are used for constructing a new sub-hologram after the observer O has moved). The use of such a storage module 210 is optional. In this case, the second electronic device 200 can indicate (by transmission of suitable information) to the first electronic device 100 the atoms for which the descriptive data are stored in the storage module 210, so that the first electronic device 100 does not retransmit these data latter.
According to another possibility, this is the first electronic device 100 that stores a history indicating, for each atom ak participating to the representation of the digital hologram H, if the descriptive data of this atom ak have been transmitted to the second electronic device 200. The encoding module 148 can also consult this history and not include in the flow of data to be transmitted data relating to the atoms ak mentioned in this history as already transmitted.
The above-mentioned modules 202, 204, 206, 208, 210 can in practice be implemented by the cooperation of at least one hardware element (such as a processor of the second electronic device 200 and/or, in particular for the receiving module 204 and/or the transmission module 202, a communication circuit) and software elements (such as computer program instructions executable by the above-mentioned processor).
These computer program instructions can in particular be such that the second electronic device 200 implements a part at least of the steps described hereinafter with reference to
This method begins at step E2, at which the transmission module 202 of the second electronic device 200 transmits to the reception module 142 of the first electronic device 100 the coordinates (x0, y0, z0) representative of the position of the observer O. In particular, the coordinates (xO, yO) are hence representative of a position of observation in the plane of observation PO (parallel to the plane PH of the digital hologram H), plane of observation PO defined by the equation z=zO.
The reception module 142 of the first electronic device 100 receives the coordinates (x0, y0, z0) representative of the position of the observer O at step E4.
The selection module 144 then selects (step E6), among the atoms ak of the set AK representing the digital hologram H, the atoms am whose diffraction spectrum Sm in the plane of observation PO has an intersection with the viewing window V (or, as an alternative, the atoms am for which the center Cm of the diffraction spectrum Sm is located in the viewing window V).
It is recalled that the viewing window V contains the position of the observer O (by being for example centered on the position of the observer O) and has a predefined resolution (Vx, Vy). The viewing window V therefore depends on the coordinates (x0, y0) received at step E4.
The ordering module 146 can then determine, at step E8, an order for the atoms am selected at step E6, as a function of the distance, in the plane of observation (PO), between the position of observation (defined by the coordinates (x0, y0)) and the center Cm of the diffraction spectrum Sm of each of these atoms am, as explained in more detail hereinabove.
As also indicated hereinabove, the above-mentioned order can also be determined as a function of the angular dispersion Δφm and/or of the amplitude of the coefficient |cm| associated with each of these atoms am.
The encoding module 148 proceeds, for each of the atoms am selected at step E6 and in the order determined at step E8, to the encoding of the descriptive data of the involved atom am (step E10), i.e. here, as explained hereinabove:
For these atoms am whose descriptive data are encoded, and hence in the order determined at step E8, the encoded descriptive data are further transmitted at step E10 by the transmission module 150 of the first electronic device 100 towards the receiving module 204 of the second electronic device 200, via the communication network.
These descriptive data of atoms am are hence received by the receiving module 204 and are decoded (step E12).
The reconstruction module 206 can then calculate, at step E14, the sub-digital hologram H′ by means of the descriptive data of the atoms am received at this precise time.
This step E14 comprises in particular the following sub-steps at receipt of the descriptive data of an atom am:
The current sub-digital hologram H′ can hence be displayed by means of the display 208 at step E16.
It is then determined, at step E18 (for example by the processor of the second electronic device 200), if the position of the observer O has changed.
In case of negative result (i.e., if the position of the observer O is unchanged), the method continues at step E12 for potentially receiving descriptive data of other atoms am (then adding their contribution at step E14 and displaying the completed sub-digital hologram H′ at step E16).
A progressive transmission and display of the sub-digital hologram H′ is hence obtained.
In case of positive result at step E18 (i.e. if the position of the observer O has changed), the method continues at step E2 for transmitting the coordinates of the new position of the observer O. In this case, the reiteration of steps E6, E8 and E10 will allow an adaptation of the viewing window V, of the order of the atoms am and hence of the data transmitted to the new position of the observer O.
It can be provided as an alternative that the coordinates (x0, y0, z0) are periodically transmitted from the transmission module 202 of the second electronic device 200 to the reception module 142 of the first electronic device 100 (without waiting for a potential change of position of the observer O). In this case, the first electronic device 100 is for example designed not to reiterate steps E6 and E8 as long as the position of the observer O is unchanged.
This system includes a first electronic device 300 (here a server) and a second electronic device 400 (here a client device such as a personal computer or a multifunction mobile).
The electronic device 300 includes a unit 320 for the construction of data packets and a unit 340 for the preparation and sending of a flow of data.
As will become apparent from the following description, the construction unit 320 includes several modules intended to operate offline, i.e. before the exchange of data with the second electronic device 400. The preparation and sending unit 340 itself includes several modules intended to operate online, i.e. during the exchange of data with the second electronic device 400.
The electronic device 300 includes (herein within the above-mentioned construction unit 320) a digital hologram generation module 322, an expansion module 324, a reduction module 326, an association module 328, an ordering module 330, an encoding module 332 and a data packet generation module 334.
The modules 322, 324, 326 are identical to the modules 122, 124, 126 described hereinabove with reference to
The digital hologram generation module 322 is designed to calculate the digital hologram H, based on data simulating a scene or by acquisition of a real scene by means of image sensors.
The expansion module 324 is designed to produce a first representation AN of the digital hologram H, here by means of N Gabor atoms an.
Each atom an of the set AN is defined by:
The reduction module 326 is designed to obtain, based on the first representation AN of the digital hologram H, a second representation AK of the digital hologram H, here by selection (among the above-described atoms an) of the most relevant atoms ak for the reconstruction by means of a “Matching Pursuit” algorithm, as described in the above-mentioned article “Color digital hologram compression based on matching pursuit”.
Each atom ak of the set AK is hence an atom of the set AN and can hence be defined by:
In the present embodiment, as shown in
The association module 328 is designed to associate, for a given plane of observation PO, each of the atoms ak of the set AK with a block Th,w, precisely the block Th,w containing the center Ck of the diffraction spectrum Sk of the involved atom ak.
As already indicated in relation with the first embodiment, the position of the center Ck of the diffraction spectrum Sk can be obtained based on the coordinates (tx, ty) of the involved atom ak, the azimuth angle θk and the diffraction angle φk associated with the involved atom ak (as explained hereinabove) and on the distance separating the plane of observation PO and the plane PH of the digital hologram H.
The just-described distribution of the atoms ak among the blocks Th,w (by means of the association module 328) can be made in practice for a plurality of planes of observation PO in such a way as to cover the space accessible by the observer O.
The ordering module 330 is designed to order, for each block Th,w, the different atoms ak associated with this block Th,w, for example as a function of the angular dispersion Δφk and/or the amplitude |ck| of the coefficient ck respectively associated with these atoms ak.
The ordering module 330 can for example, in practice, order, for a given block Th,w, the atoms ak associated with this block Th,w in decreasing associated values of angular dispersion Δφk and, for atoms ak of same angular dispersion Δφk, in decreasing associated values of amplitude |ck|.
The encoding module 332 is designed to encode, for each block Th,w:
The encoding module 332 is also designed to encode, for all the atoms of each block Th,w, the descriptive data of the involved atom ak:
The encoding of the position of the center Ck of the diffraction spectrum is particularly inexpensive in this case (of the order of log2(Mx)+log2(My)).
For each atom ak, the coefficient ck can in practice be encoded on several planes of bits (in such a way as to be able to adapt the quantity of data to be transmitted to the rate available on the communication network, as explained hereinafter). It can be provided, for example, an encoding of the coefficients ck using a lower number of bits if these coefficients belong to blocks Th,w remote from the position of observation O, by adaptatively reducing for example the number of planes of bits as a function of the distance OPh,w.
Reference can moreover be made on that subject to the explanations given within the framework of the first embodiment and in the above-mentioned article “Color digital hologram compression based on matching pursuit”.
The data packet generation module 334 is designed to construct, for each block Th,w, an associated packet of data Bh,w.
In this data packet Bh,w, the descriptive data of the atoms ak, encoded by the encoding module 332, are placed in accordance with the order determined by the ordering module 330.
When several planes of bits are used for the encoding of the coefficients ck, the generation module 334 constructs the packet of data Bh,w by placing:
It is provided, in this case, that the planes are defined in a decreasing order of significance of the involved bits: the first plane of bits corresponding to the most significant bits, the second plane of bits corresponding to less significant bits, and the third plane of bits (in the above-mentioned example) to still less significant bits.
It is observed that, just as the module 328, the modules 330, 332, 334 can perform the above-mentioned processing operations for a plurality of planes of observation PO in such a way as to cover the space accessible by the observer O.
The electronic device 300 moreover includes (here within the above-mentioned preparation and sending unit 340) a receiving module 342, a calculation module 344, a selection module 346 and a transmission module 350.
The receiving module 342 is designed to receive data defining the position of an observer O that wants to view the digital hologram H and here also data β indicative of the bandwidth available on the communication network.
As in the first embodiment, the position of the observer O is for example defined by coordinates (xO, yO, zO) in a reference system linked to the digital hologram H (the plane PH of the dispositive corresponding to the plane of equation z=0).
Here, a solution is described in which the data representative of the digital hologram H are transmitted for a single observer O. As for the first embodiment, it could however be provided in practice to receive the respective positions of several observers, then to prepare and send data for each of these observers (by using the solution proposed hereinafter separately for each of these observers and by gathering the data relating to the different observers in a same flow of data).
The calculation module 344 is designed to calculate, for a part at least of the blocks Th,w, the distance OPh,w between the position of the observer O and the center Ph,w of the involved block Th,w in the plane of observation PO. (It is recalled that the blocks Th,w form a predefined division, or partition, of the accessible part of the plane of observation PO and the coordinates of the centers Ph,w of these blocks Th,w are hence predefined in the plane of observation PO.)
The selection module 346 is designed to assemble data coming from the different packets Bh,w (prepared by the generation module 334), according to an order determined as a function of the distance OPh,w associated with the different blocks Th,w, respectively, in order to construct the flow of data to be transmitted. The quantity of data used in each packet Bh,w can depend in practice on the available bandwidth (indicated by the data β received by the receiving module 342), each packet Bh,w being able to be truncated in such a way as to include, for example, in the flow of data to be transmitted, only a part of the planes of bits representing the coefficients ck.
It is observed that the packets Bh,w that are used are those which have been produced by the generation module 334 for the plane of observation PO that is the closest to the position of the observer O (as received by the receiving module 342).
In practice, the selection module 346 ranks the blocks Th,w in increasing order of the distance OPh,w associated with each of these blocks Th,w, and, by going through the blocks Th,w in this order, places in the flow of data a part at least of the packet Bh,w associated with the current block Th,w (this part can depend on the available bandwidth β as indicated hereinabove).
The transmission module 350 is designed to transmit the flow of data so prepared by the selection module 346 towards the second electronic device 400. The data are hence transmitted in the order determined by the selection module 346 as explained hereinabove.
The above-mentioned modules 322, 324, 326, 328, 330, 332, 334, 342, 344, 346, 348, 350 can in practice be implemented by the cooperation of at least of one hardware element (such as a processor of the first electronic device 300 and/or, in particular for the receiving module 342 and/or the transmission module 350, a communication circuit) and of software elements (such as computer program instructions executable by the above-mentioned processor).
These computer program instructions can in particular be such that the first electronic device 300 implements a part at least of the steps described hereinafter with reference to
The second electronic device 400 includes a transmission module 402, a reception module 404, a reconstruction module 406 and a display 408.
The transmission module 402 is designed to transmit (towards the first electronic device 300 and, precisely the above-mentioned receiving module 342) the above-mentioned data β (indicative of the bandwidth available on the communication network) and the above-mentioned data defining the position of an observer O, here defined by coordinates (xO, yO, zO) in the reference system linked to the digital hologram H. (This position corresponds for example to a virtual position of the wearer of the second electronic device 400 with respect to the digital hologram H).
The transmission module 402 can transmit in practice these data on the above-mentioned communication network (used by the transmission module 350 of the first electronic device 300). However, as an alternative, the transmission module 402 could transmit these data on another communication network (but still towards the receiving module 342 of the first electronic device 300, this receiving module 342 being in this case connected to this other communication network).
The reception module 404 is designed to receive the descriptive data of the different atoms am (relating to different blocks Th,w successively) from the transmission module 350 of the first electronic device 300 and to decode these data.
The reception module 404 hence receives the descriptive data of different atoms ak associated with certain blocks Th,w in the order determined for these blocks Th,w by the selection module 346. These data represent (after decoding) for each block Th,w:
then, for the atoms ak of this block:
The reconstruction module 406 is designed to calculate a sub-digital hologram H′ by means of the atoms ak for which the descriptive data have been received.
For that purpose, for each atom ak whose descriptive data are received, the reconstruction module 406 determines the position (tx, ty) of the involved atom ak as a function of the coordinates (t″x, t″y) of the center Cm of the diffraction spectrum Sm of this atom ak within the block Th,w, of the position of the involved block Th,w, of the azimuth angle θk and the diffraction angle φk associated with this atom ak and of the ordinate zO of the position of the observer O (or of the plane of observation PO for which the packet of data Bh,w has been calculated as indicated hereinabove, these planes of observation being predefined). (It is recalled that the position of each block Th,w is predefined and hence known when the block Th,w is identified, here by the indices h and w, and that the azimuth angle θk and the diffraction angle φk can be calculated as a function of the index of dilation lk and the index of rotation pk, as indicated hereinabove).
The reconstruction module 406 can then calculate the sub-digital hologram H′ by summing the contribution of the different atoms am for which the descriptive data have been received:
H′=Σ
(ak received)
c
k
, g
lk, pk(tx, ty).
The display 408 (using for example a spatial light modulator, or SLM, and potentially integrated into a head-mounted display, for example an augmented reality head-mounted display) can then display the sub-digital hologram H′ reconstructed as indicated hereinabove by the reconstruction module 406.
The above-mentioned modules 402, 404, 406, 408 can in practice be implemented by the cooperation of at least one hardware element (such as a processor of the second electronic device 400 and/or, in particular for the reception module 404 and/or the transmission module 402, a communication circuit) and software elements (such as computer program instructions executable by the above-mentioned processor).
These computer program instructions can in particular be such that the second electronic device 400 implements a part at least of the steps described hereinafter with reference to
This method starts at step E52 at which the transmission module 402 of the second electronic device 400 transmits, on the communication network and towards the receiving module 342 of the first electronic device 300, the data β indicative of the bandwidth available on the communication network and the data (xO, yO, zO) representative of the position of the observer O.
The coordinates (xO, yO) are hence representative of a position of observation in the plane of observation PO (parallel to the plane PH of the digital hologram H).
The receiving module 342 of the first electronic device 300 receives that way the data β indicative of the bandwidth available on the communication network and the data (xO, yO, zO) representative of the position of the observer O at step E54.
The calculation module 344 then calculates, at step E56, for a part at least of the blocks Th,w, the distance OPh,w between the position of the observer O and the center Ph,w of the involved block Th,w in the plane of observation PO.
The selection module 346 can hence determine, at step E58, an order within these blocks Th,w as a function of the distance OPh,w previously calculated for each of these blocks Th,w.
The selection module 346 then constructs, at step E60, the flow of data to be transmitted by assembling data from the different packets Bh,w (pre-calculated for the relevant plane of observation PO as explained hereinabove) in the order determined at step E58 for the blocks Th,w associated with these packets Bh,w. As already explained, the quantity of data placed in the flow of data for a given packet Bh,w can be chosen in practice as a function of the available bandwidth indicated by the data β.
The transmission module 350 of the first electronic device 300 transmits at step E62 the flow of data constructed at step E60.
This flow of data hence contains, in the order of the blocks Th,w determined at step E58 and for each block Th,w:
The data are transmitted in encoded form, as explained hereinabove.
The reception module 404 of the second electronic device 400 receives and decodes this flow of data at step E64.
The reconstruction module 406 can then calculate, at step E66, a sub-digital hologram H′ by means of the descriptive data of the atoms ak received at this precise time.
This step E66 comprises in particular the following sub-steps at receipt of the descriptive data of an atom ak:
The current sub-digital hologram H′ can hence be displayed by means of the display 408 at step E68.
It is then determined, at step E70 (for example, by the processor of the second electronic device 400), if the position of the observer O has changed.
In case of negative result (i.e. if the position of the observer O is unchanged), the method continues at step E64 for continuing the reception of the flow of data and hence decoding data relating to the following blocks Th,w and thus to the atoms ak contained in these blocks Th,w. The respective contributions of these atoms ak are added at step E66 and the supplemented sub-digital hologram H′ is displayed at step E68).
A progressive transmission and display of the sub-digital hologram H′ is hence obtained.
In case of positive result at step E70 (i.e. if the position of the observer O has changed), the method continues at step E52 for transmitting the coordinates of the new position of the observer O. In this case, the reiteration of steps E56, E58, notably, will allow new choices and orderings of new blocks Th,w for which descriptive data of the atoms am will be sent.
It can be provided as an alternative that the coordinates (x0, y0, z0) are transmitted periodically from the transmission module 402 of the second electronic device 400 to the receiving module 342 of the first electronic device 300 (without waiting for a potential change of position of the observer O). In this case, the first electronic device 300 is for example designed not to reiterate steps E56, E58 and E60 as long as the position of the observer O is unchanged.
It can moreover be provided to store within the second electronic device 400 the previously received data relating to blocks Th,w in order to use these data when they are required for the reconstruction of the digital hologram H, as seen from the new position of the observer O.
In this case, according to a first possibility, the second electronic device 400 transmits for example to the first electronic device 300 the indices h, w of the blocks Th,w for which data have been received (and are hence stored within the second electronic device 400), as well as possibly an indication of the planes of bits received for each of these blocks Th,w. The first electronic device 300 will not transmit again the so-indicated data.
According to another possibility, a history can be stored within the first electronic device 300, indicating, for each block Th,w, the planes of bits that have already been transmitted to the second electronic device 400 for this block Th,w in such a way that these data are not transmitted again to the second electronic device 400 when the position of the observer O has changed (only the planes of bits completing the description of block Th,w being then transmitted, for example, when this block Th,w is closer to the new position of the observer O, in particular in the embodiment contemplated hereinabove in which the number of planes of bits transmitted is variable as a function of the distance OPh,w).
Of course, various other modifications can be brought to the invention within the framework of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
1900838 | Jan 2019 | FR | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/FR2020/050140 | 1/29/2020 | WO | 00 |