This is a 371 of PCT/FR09/050512 filed Mar. 25, 2009, which has a priority of French no. 08 51985 filed Mar. 27, 2008, hereby incorporated by reference.
The present invention relates to a method for determining a three-dimensional representation of an object.
The invention applies in particular for the reconstruction of micro objects in microscopic-imaging systems.
The prior art document EP 1 413 911 A1 describes a method for determining a three-dimensional representation of an object on the basis of a sequence of sectional images of the object in a section plane, each sectional image having been captured at a respective instant of picture capture while the object moved with respect to the section plane.
In this prior art document, the object is a cell of dimension of the order of a few micrometers. The cell is marked with a fluorescent compound and is placed in a receptacle of a microscopic-imaging system. A confinement field is created in the receptacle so as to control the position of the cell, without the latter being squashed. The microscopic-imaging system furthermore comprises an optical microscope having a focal plane forming the section plane. In order to obtain the sequence of sectional images, the cell is rotated at a constant angular rate around an axis of the focal plane, and sectional images are captured at a rate of between 1 and 1000 acquisitions per second.
The prior art document furthermore proposes to determine the three-dimensional representation of the cell on the basis of the usual reconstruction techniques used in tomography. These usual techniques consist in determining the three-dimensional representation of an object on the basis of sectional images and of the positions of the object with respect to the section plane, the positions of the object with respect to the section plane being determined by the knowledge of the adjustment settings of the radiography machine and/or of physical sensors making it possible to ascertain the position of the radiography machine.
The aim of the invention is to provide a reconstruction method allowing the fast determination of a three-dimensional representation while having good resolution.
Thus, the subject of the invention is a method for determining a three-dimensional representation of an object, characterized in that it comprises:
According to other characteristics of the invention:
The subject of the invention is also a computer program product which, when implemented on a computer, implements a method of the invention.
The subject of the invention is also an imaging system characterized in that it comprises: means making it possible to obtain images in a focal plane, a receptacle for receiving an object, means for setting the object into motion, means for receiving sectional images captured in the focal plane, which means are adapted for implementing a method according to the invention.
These characteristics, as well as others, will become apparent on reading the description which follows of preferred embodiments of the invention. This description is given with reference to the appended drawings, among which:
The description which follows relates to the determination of a three-dimensional representation of a live cell. However, the person skilled in the art will have no hardship in transposing this description to other types of objects, live or inert.
Moreover, the mathematical relations indicated subsequently are expressed in a fixed XYZ frame, tied to the section plane P (which will be described further on) and whose XY plane coincides with this section plane P.
Furthermore, in the present description, the term “value” does not signify solely a number value, but can also be a vector value (that is to say a particular vector) or a line value (that is to say a particular line), etc., according to the nature of the mathematical object whose value is considered.
With reference to
The microscopic-imaging system 10 furthermore comprises a receptacle 18 for receiving an object O of microscopic size, such as a cell, into which a fluorescent material has been introduced.
Generally, it is possible to replace the fluorescent material by any marker adapted to the object under study, and able to be detected by the imaging system used.
The receptacle 18 comprises a chamber 20 intended to contain a fluid microsystem comprising the object O. The chamber 20 is situated facing the lens 14 of the optical microscope 12. The chamber 20 is delimited by a support 24, lateral walls 26 and a glass pane 28 covering the walls 26 so that the lens can observe the content of the chamber 20. The chamber 20 defines a volume U.
The lateral walls comprise microelectrodes 30 for creating an electric field, the latter making it possible to position the object O.
The microscopic-imaging system 10 furthermore comprises a device 32 for illuminating the marker contained in the object O, so that each point o of the object O emits a luminosity O(o). Conversely, the environment of the object O emits a very low or even zero luminosity.
The microscopic-imaging system 10 also comprises a control unit 34, acting in particular on the microelectrodes 30 so as to set the object O into motion, and on the camera 16 so as to capture a sequence of sectional images X0 . . . Xm in the focal plane P (which thus forms a section plane P of the volume U of the chamber 20, and in particular of the object O), at respective picture-capture instants t0 . . . tm.
An XYZ reference frame is tied to the section plane P. Another reference frame, termed the reference frame of the object O, is furthermore tied to the object O. This other reference frame is chosen, preferably, such that it coincides with the XYZ reference frame at the initial instant t0. Moreover, the term “a point of the object” subsequently signifies, unless explicitly indicated, a point in the reference frame of the object O.
Each sectional image Xk extends over a support plane Pk tied to the object O, this support plane Pk coinciding with the section plane P at the moment tk of the capture of the sectional image Xk.
Each sectional image Xk comprises a grid G of pixels s. The grid G is the same for all the sectional images X0 . . . Xm. Each pixel s records a value Xk(s) of the luminosity of the marker at the position of the pixel s in the volume U of the chamber 20. In the present description, this luminosity value is recorded in a monochrome manner, in the form of a gray level.
Thus, when a point o of the object O is situated at the position of the pixel s, at the instant tk of capture of the sectional image Xk, the value Xk(s) of this pixel s is dependent in particular on the luminosity O(o) of the point o. When no point of the object O is situated at the position of the pixel s, it is the luminosity of the “void” which is recorded (in fact, that of the fluid comprising the object O). Thus, the background of the sectional images X0 . . . Xm, has a low gray level.
Furthermore, the value Xk(s) of a pixel s also depends on a point spread function (PSF) introducing a fuzziness. In general, the point spread function has a shape which is elongated perpendicularly to the section plane P.
The microscopic-imaging system 10 moreover comprises an image processing computing device 36, linked to the control unit 30 so as to receive the sectional images X0 . . . Xm. A reconstruction computer program 38 is installed on the computing device 36. The computer program 38 is designed to implement a reconstruction method intended to determine a three-dimensional representation V of the object O on the basis of the sequence of sectional images X0 . . . Xm. The computing device 36 is able to export the three-dimensional representation V in the form of a digital file and/or to display this three-dimensional representation V on a screen 40.
A method of analyzing an object O, implemented by the imaging system 10, is illustrated in
The analysis method furthermore comprises a step 54 of acquiring at least one sequence of sectional images X0 . . . Xm at respective picture-capture instants t0 . . . tm, and a step 56 of processing the sectional images X0 . . . Xm with the computer program 38.
In practice, the axis of rotation L is never exactly that set by the control unit 34. The invention therefore proposes to determine the axis of rotation L on the basis of the sectional images X0 . . . Xm, and then to determine a three-dimensional representation V on the basis of the axis of rotation L determined, rather than on the basis of the axis of rotation set on the basis of the adjustment of the control unit 34.
Furthermore, in practice, the motion of the object O is never perfectly rotary. The motion error with respect to the rotation of fixed axis is represented by a series of perturbation translations T1 . . . Tm, each perturbation translation being undergone by the object O between two respective successive sectional images Xk−1, Xk. The perturbation translations T1 . . . Tm have variable direction and value.
Thus, the position of a point o of the object O at a picture-capture instant tk, starting from the position u of the point o at the previous picture-capture instant tk−1, is:
R{right arrow over (a)},τ(t
where R{right arrow over (a)},τ(t
R{right arrow over (a)},α=I+sin α[{right arrow over (a)}]x+(1−cos α)[{right arrow over (a)}]x2,
where I is the 3-by-3 identity matrix, and
with {right arrow over (a)}=(a1,a2,a3).
It will also be noted that the perturbation translation Tk does not depend on the position of u0 on the axis of rotation L.
Processing of the Sectional Images Acquired
With reference to
Step 56 implemented by the computer program 38 furthermore comprises a step 200 of determining the parameters of the motion of the object O with respect to the section plane P. In the course of this step of determining the parameters of the motion 200, the parameters of regular motion (angular rate τ, the axis of rotation L) are determined, as are the perturbation motion parameters (series of perturbation translations T1 . . . Tm).
The motion parameters (angular rate τ, the axis of rotation L and series of perturbation translations T1 . . . Tm) determine the position of the object O at each instant of capture tk of a sectional image Xk: the position at the instant of capture tk of a point o which is situated at the position u at the initial instant t0 is given by:
R{right arrow over (a)},τ(t
where
The position of the object O at each instant of capture tk of a sectional image Xk determines the position of the section plane P at the instant of capture tk in an arbitrary reference frame tied to the object O (and vice-versa): the position in the reference frame of the object O chosen (which coincides with the fixed XYZ reference frame at the initial instant of capture t0) of a pixel s of the section plane P at the instant of capture tk is:
R{right arrow over (a)},τ(t
with R{right arrow over (a)},τ(t
π3x is the position in the XYZ three-dimensional reference frame of a point x of a sectional image, when merging the support plane of the sectional image with the XY plane. The position of the section plane P in any other reference frame tied to the object O at each instant of capture tk follows from the position of the section plane P in the reference frame of the object O chosen at the instant of capture tk and from the relation between the reference frame of the object chosen and this other reference frame.
In the description which follows, the motion of the object O with respect to the section plane P is expressed in the XYZ reference frame tied to the section plane P. Quite obviously, the motion of the object O with respect to the section plane P could be expressed in another frame of reference, which would not necessarily be tied to the section plane. In this case, the determination of the motion of the object O with respect to the section plane P would furthermore comprise the determination of the motion of the section plane P with respect to this other frame of reference.
Step 56 implemented by the computer program 38 furthermore comprises a step 400 of determining a three-dimensional representation V of the object O, on the basis of the sectional images X0 . . . Xm, and of the motion parameters τ, L, T1 . . . Tm.
Determination of the Angular Rate in Absolute Value
The sign of the angular rate τ indicates the direction of the rotation of the motion. The sign of the angular rate τ is positive if the rotation occurs in the positive sense with respect to the direction {right arrow over (a)}, and negative if the rotation occurs in the negative sense with respect to the direction {right arrow over (a)}. The sign of the angular rate τ is known, for example, according to the adjustment of the imaging system 10, once the direction {right arrow over (a)} of the axis of rotation has been chosen.
If the sign of the angular rate τ is not known, it may be chosen arbitrarily: in this case, the three-dimensional representation V of the object O will at worst be the three-dimensional representation V of the mirror of the object O.
With reference to
This step 210 comprises first of all a step 212 of determining a period p>0 such that each pair of sectional images Xk, Xk′ captured at respective instants tk, tk′ separated by a time substantially equal to a (nonzero) multiple of the period p, are substantially similar. This period p is thus the period of revolution of the object O.
More precisely, step 212 of determining the period of revolution p comprises a step 214 of determining an initial group of positive candidate periods p1 . . . pn, and a step 216 of selecting the period of revolution p from among the candidate periods p1 . . . pn of the initial group.
In the example described, the step 214 of determining the candidate periods p1 . . . pn consists in choosing the candidate periods p1 . . . pn. Preferably, the candidate periods p1 . . . pn are chosen uniformly spaced.
Simple Determination of the Period
Step 216 of selecting the period of revolution p comprises, in a simple variant, the determination of the best period from among the candidate periods p1 . . . pn, by maximizing the likelihood according to a chosen probabilistic model.
Enhanced Determination of the Period
However, to improve the reliability of the determination of the period of revolution p, one or more prior selections are carried out on the candidate periods p1 . . . pn, the probabilistic model taking account of this or these selections.
With reference to
Selection of the First Subsets
The first step 218 of selecting the first subsets pj(k,1), . . . , pj(k,e) comprises, for each sectional image Xk and for each candidate period pj, a step 222 of determining substantially periodic sectional images Xk′ (according to the candidate period pj) to the sectional image Xk.
Step 222 of determining the substantially periodic sectional images Xk′ comprises a step 224 of determining the sectional images Xk′ captured at picture-capture instants tk′ separated from the instant tk of capture of the sectional image Xk by a time which is close to a (nonzero) multiple of the candidate period pj. “Close” signifies that the difference between the close time and the (nonzero) multiple of the candidate period pj lies in a time interval J comprising 0. Preferably, the time interval J is centered on 0. For example, J=[ζ,ζ] with C small with respect to each candidate period pj, with ζ≦pj/3 for the set of candidate periods pj. As a variant, ζ varies as a function of the candidate period pj by choosing for example ζ=pj/10 for each candidate period pj.
The first step 218 of selecting the first subsets {pj(k,1), . . . , pj(k,e)} furthermore comprises a step 226 of recentering each substantially periodic sectional image Xk, with respect to the sectional image Xk.
The recentering step 226 comprises first of all a step 228 of selecting luminous pixels, in the sectional image Xk and in the substantially periodic sectional image Xk′. Preferably, the pixels selected are those whose gray level is greater than a predetermined threshold α, this threshold being for example the q-quantile of gray level of the sectional images X0 . . . Xm (this signifying that the proportion of the pixels of the sectional images X0 . . . Xm which have a gray level of less than or equal to α is substantially equal to q, and that of the pixels which have a gray level greater than α is substantially equal to 1−q), with q being equal for example to between 60% and 95%.
The recentering step 226 furthermore comprises a step 230 of calculating, on the one hand, a first center d(Xk) of the luminous points selected in the sectional image Xk and, on the other hand, the calculation of a second center d(Xk′) of the luminous points selected in the sectional image Xk.
The center of an image X (Xk or Xk′) is given by:
where 1A>B is the indicator function: 1A>B=1 if A>B, and 1A>B=0 otherwise. The recentering step 226 furthermore comprises the determination 232 of a shift dk,k′ between the centers of the luminous points of the sectional image Xk and of the substantially periodic sectional image Xk′: dk,k′=d(Xk)−d(Xk′).
The recentering step 226 furthermore comprises a step 234 of translating the substantially periodic sectional image Xk′ by the shift dk,k′ between the centers, so as to obtain a centered substantially periodic sectional image, denoted Trans(Xk,dk,k′). The centered substantially periodic sectional image Trans(Xk′,dk,k′) is calculated, for each pixel s, by:
Trans(Xk′,dk,k′)(s)=Xk′(s−dk,k′).
The first step 218 of selecting the first subsets pj(k,1), . . . , pj(k,e) furthermore comprises a step 236 of determining a distance T(k,k′) between the sectional image Xk and each centered substantially periodic sectional image Trans(Xk′,dk,k′). Preferably, the distance T(k,k′) is given by the following relation:
∀0≦k,k′≦m,T(k,k′)=χ(Xk,Trans(Xk′,dk,k′)),
with χ a distance function, χ(X,Y) measures the difference between two images X and Y. The distance function χ is for example a quadratic distance of the gray levels of the pixels between the two images, given by:
The first step 218 of selecting the first subsets pj(k,1), . . . , pj(k,e) furthermore comprises a step 238 of determining a periodic similitude level sim(Xk,pj) of the sectional image Xk on the basis of the distances T(k,k′).
The periodic similitude level sim(Xk,pj) characterizes the level of similitude of the sectional image Xk with the substantially periodic sectional images Xk′, for the candidate period pj. Preferably, step 238 of determining a periodic similitude level sim(Xk,pj) comprises a step of calculating the inverse of the similitude through the following relation:
with:
where r is a nonzero integer, ζ is defined in the same manner as for step 224 of determining the substantially periodic sectional images, and w is a positive weighting function defined on the interval J=[−ζ,ζ]. Preferably, w is symmetric with respect to 0 (w(t)=w(−t)), and the high values of w are concentrated around 0. For example w(t)=exp(−ct2) with c a positive constant. The function w makes it possible to decrease the influence of the substantially periodic sectional images Xk′ which are far distant from a multiple of the candidate period pj.
The first step 218 of selecting the first subsets pj(k,1), . . . , pj(k,e) furthermore comprises a step 240 of selecting, from among the candidate periods p1 . . . pn, for each sectional image Xk, a first subset pj(k,1), . . . , pj(k,e) grouping together the candidate periods p1 . . . pn having the highest similitude levels (that is to say the smallest values of sim−1(Xk,pj)). Preferably, a predetermined number e of candidate periods are selected. Preferably also, this number e is chosen between 1 and 15.
Selection of the Second Subset
The second step 220 of selecting the second subset pj(1) . . . pj(l) of candidate periods comprises, for each candidate period pj, a step 242 of calculating a number of appearances S(pj) of the candidate period pj, corresponding to the number of first subsets pj(k,1), . . . , pk(k,e) in which the candidate period pj appears.
The values of the number of appearances S for the candidate periods p1 . . . pn are for example given by the relation:
where lAεB is the indicator function: lAεB=1 if AεB, and lAεB=0 otherwise.
The second step 220 of selecting the second subset pj(1) . . . pj(l) of candidate periods furthermore comprises, for each candidate period pj, a step 244 of calculating a dispersion ℑ of the values of the number of appearance S, about each multiple (greater than or equal to 1) of the candidate period pj. The dispersions for a candidate period pj indicates whether high values of the number of appearance S are concentrated (low dispersion) or dispersed (high dispersion) around each multiple (greater than or equal to 1) of the candidate period pj.
Preferably, the dispersion ℑ of a candidate period pj is calculated in such a way that, the more distant another candidate period pj, is from the closest multiple (greater than or equal to 1) of the candidate period pj, the more the value of the number of appearance S of this other candidate period pj, contributes to the dispersion.
Preferably, the dispersion 3 of the candidate period pj is given by the relation:
where [x] is the integer closest to x.
The second step 220 of selecting the second subset pj(1) . . . p(l) of candidate periods furthermore comprises a step 246 of selecting, from among the candidate periods pj, of the second subset pj(1) . . . pj(l), candidate periods having the lowest dispersions ℑ. Preferably, a predetermined number l of candidate periods are selected. Preferably also, this number l is chosen between 4 and 40.
Selection of the Period on the Basis of the First Subsets, of the Second Subset, and of a Probability Law
The selection 216 of the period of revolution p furthermore comprises a step 248 of determining a probability law Pp describing the probability that a period pj is chosen, in the course of step 218, in at least one of the first sets pj(k,1), . . . pj(k,e). The probability law Pp is defined with the period of revolution p as parameter.
The selection 216 of the period of revolution p furthermore comprises a step 249 of calculating a histogram h of the candidate periods selected in step 218. It has been noted that the large values of the histogram h are in general concentrated around the true value of the period of revolution p and multiples of the true value of the period of revolution p.
Preferably, it is considered that the selections for obtaining the candidate periods in step 218 are approximately independent, and that the choosing of each of the candidate periods in step 218 is carried out randomly according to a probability law Pp.
For this purpose, the probability law Pp, having as parameter the period of revolution p, is such that the shape of the probability function Pp can “hug” that of the histogram h to within an expansion factor, by varying the value of the parameter p.
More precisely, it is considered than each period pj obtained in step 218 is selected either randomly, with a low probability β, from among all the candidate periods p1 . . . pn according to the uniform law, or with the probability 1−β through an alternative choice which consists in choosing a period around a multiple (greater than or equal to 1) of the period of revolution p. This alternative choice is carried out by choosing firstly a multiple ip (i an integer and i≧1) with a probability bi and thereafter by choosing pj around ip (ip already being chosen) with the probability
In this case, the probability law Pp is defined by the relation:
where l(p) is the number of multiples of p.
The law Pp is a mixture of the uniform law on the set of candidate periods p1 . . . pn, and of the laws
The probability
Preferably l(p)=max{iεN*:{p1, . . . , pn}∩supp(vip)≠Ø}, with supp(vip)={x:vip(x)≠0}, and
In practice β is chosen between 0 and 25%.
The selecting 216 of the period of revolution p furthermore comprises a step 250 of determining the period of revolution p, as being the period of the second subset of candidate periods pj(1) . . . pj(l) which maximizes the likelihood Like (p) (or, equivalently, the log-likelihood log Like (p)) associated with the above probability law Pp, given the first subsets of selected periods pj(k,1), . . . , pj(k,e), 0≦k≦m. The log-likelihood is given by:
As a variant, step 212 of determining the period of revolution p does not comprise step 220 of determining the second subset, and, in step 250, the period of revolution p is determined as being the period of the set of candidate periods p1 . . . pn, maximizing the above likelihood Like (p).
Step 210 of determining the angular rate in absolute value |τ| then comprises a step 252 of calculating the angular rate in absolute value |τ| on the basis of the period of revolution p:
|τ|=2π/p.
Once the direction {right arrow over (a)} of the axis of rotation has been chosen, the angular rate τ is determined from the known (or assumed) direction of rotation with respect to the direction {right arrow over (a)} of the axis of rotation, through the following relation:
Step 200 of determining the parameters of the motion furthermore comprises a step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm.
First Variant for Determining the Axis of Rotation and the Series of Perturbation Translations
Step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm is implemented by determining an axis of rotation L and a series of perturbation translations T1 . . . Tm such that the value Xk (s) of each pixel s of each sectional image Xk is substantially equal, for each spatially neighboring sectional image Xk′ (that is to say whose support plane Pk′ is spatially neighboring the support plane Pk of the sectional image Xk), to the value Xk′(x′) of a point x′ “close” to this pixel s, on the spatially neighboring sectional image Xk′. The closest point x′ is determined according to a given proximity criterion.
More precisely, step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm comprises a step 304 of determining, for each sectional image Xk, sectional images Xk′ spatially neighboring this sectional image Xk.
A sectional image Xk′ is spatially neighboring the sectional image Xk, when the angle separating their respective support planes Pk, Pk′ is less than a predetermined value Δ1. The angle is preferably determined on the basis of the angular rate in absolute value |τ| and of the instants tk, tk′ of capture of the two sectional images Xk, Xk′. This predetermined value Δ1 is preferably taken less than or equal to 12 degrees. For a sectional image Xk, the spatially neighboring sectional images Xk′ are therefore the sectional images satisfying:
there exists an integer q such that |τ|(tk−tk′)=2πq+r, with |r|≦Δ1.
The previous condition on the angle separating the sectional images Xk and Xk′ is equivalent to a condition on the time interval separating the captures of the two sectional images.
Step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 306 of choosing a proximity criterion.
With reference to
This choice of this proximity criterion is particularly suitable in the case of a point spread function having an elongate shape perpendicularly to the section plane P.
Thus, returning to
Preferably, step 308 of calculating the orthogonal projection Fk,k′(Xk) is carried out by calculating an affine transformation Aff(Qk,k′,vk,k′,Xk) of the sectional image Xk, the affine transformation Aff(Qk,k′,vk,k′,Xk) having a linear transformation component Qk,k′({right arrow over (a)},τ) and a translation component vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm) which are dependent on, respectively, on the one hand, the direction {right arrow over (a)} of the value of axis of rotation and the rotation rate τ and, on the other hand, the value of axis of rotation L, the rotation rate τ and the value of series of perturbation translations T1 . . . Tm. Thus:
Fk,k′(X)=Aff(Qk,k′({right arrow over (a)},τ),vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm),X),
with Aff(Q,v,X) the affine transform of X defined by:
∀x,Aff(Q,v,X)(x)=X(Q−1(x−v))
with Q an invertible 2×2 matrix and v a translation vector, and
Qi,j({right arrow over (a)},τ)=π2R{right arrow over (a)},τ(t
vi,j(u0,{right arrow over (a)},τ,T1 . . . Tm)=(π2−π2R{right arrow over (a)},τ(t
where
is the projection on the XY plane,
π3x is the position in the XYZ three-dimensional reference frame of a point x of a sectional image, when merging the support plane of the sectional image with the XY plane, and
(if the direction of rotation is chosen arbitrarily: in this case, the three-dimensional representation V of the object O will at worst be the three-dimensional representation V of the mirror of the object O).
Step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 310 of comparing the values Xk(s) of the pixels s of each sectional image Xk with the values Xk′(x′) of the points x′ closest to the spatially neighboring sectional images Xk′. Preferably, the comparison step 310 is carried out by calculating a distance χ(Aff(Qk,k′, vk,k′, Xk), Xk′) between the affine transform Aff(Qk,k′, vk,k′, Xk) of the sectional image Xk and the neighboring sectional image Xk′.
Step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 312 of determining an axis of rotation L and a series of perturbation translations T1 . . . Tm whose values minimize a cost function E comprising a first part dependent on the calculated distances, so that the reduction in the calculated distances gives rise to the reduction in the cost function E.
Preferably, the cost function E also comprises a second part which depends, for a series of perturbation translations T1 . . . Tm, on the amplitude of the translations of the series of perturbation translations T1 . . . Tm. This second part thus comprises a regularization function Reg, which gives a low value when the translations of the series of perturbation translations T1 . . . Tm have a low amplitude, and gives a high value in the converse case. The regularization function Reg is preferably a quadratic norm, for example given by the relation:
Reg(T1 . . . Tm)=∥T∥M2≡TtMT,
with M a symmetric positive definite matrix, and T=T1 . . . Tm may be written in the form of a column vector with the translations Tk one after the other. For example, M=I3m, the 3m×3m identity matrix.
Preferably, the cost function E is given by the following relation:
with Nk the set of indices of the sectional images spatially neighboring the sectional image Xk, χ(Fk,k′(Xk), Xk′) a measure of the distance between, on the one hand, the projection Fk,k′(Xk) of the sectional image Xk on the support plane Pk′ of the spatially neighboring sectional image Xk′ and, on the other hand, the spatially neighboring sectional image Xk′, and λ≧0 is a parameter of compromise between, on the one hand, the distances between the projections Fk,k′(Xk) of the sectional images Xk and the spatially neighboring sectional images Xk′ of the sectional, images Xk, and, on the other hand, the regularization of translations T1 . . . Tm.
Second Variant for Determining the Axis of Rotation and the Series of Perturbation Translations
A second variant of step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm is represented in
With reference to this figure, step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm comprises, the angular rate in absolute value |τ| being known, a step 314 of determining the direction {right arrow over (a)} of the axis of rotation L, before a step 326 of determining a point of passage u0 of the axis of rotation L and of the series of perturbation translations T1 . . . Tm.
Determination of the Direction of the Axis of Rotation
Step 314 of determining the direction {right arrow over (a)} of the axis of rotation L comprises a step 316, identical to the previous step 304, of determining, for each sectional image Xk, the spatially neighboring sectional images Xk′ of this sectional image Xk.
Step 314 of determining the direction {right arrow over (a)} of the axis of rotation L furthermore comprises a step 318, identical to the previous step 306, of choosing a proximity criterion, according to which the point x′ of a spatially neighboring sectional image Xk′, closest to a pixel s of the sectional image Xk, is the position Projk,k′(s) of the orthogonal projection o′ of the point of the object o merged with the pixel s of the sectional image Xk, on the support plane Pk′ of the spatially neighboring image Xk′.
Thus, step 314 of determining the direction {right arrow over (a)} of the axis of rotation L furthermore comprises a step 320 of calculating the orthogonal projection Fk,k′(Xk) of the sectional image Xk on the support plane Pk′ of each spatially neighboring sectional image Xk′ of the sectional image Xk.
Preferably, step 320 of calculating the orthogonal projection Fk,k′(Xk) is carried out by calculating an affine transformation Aff(Qk,k′,vk,k′,Xk) of the sectional image Xk, the affine transformation Aff(Qk,k′,vk,k′,Xk) having a linear transformation component Qk,k′({right arrow over (a)},τ) and a translation component vk,k′. The linear transformation component Qk,k′({right arrow over (a)},τ) is a function of a direction {right arrow over (a)} of axis of rotation and of the rotation rate τ, while, unlike in the first variant, the translation component vk,k′ is considered to be a variable, and is therefore not expressed as a function of the motion parameters of the object O. The family of translation vectors in the affine transformations Fk,k′ will be denoted hereinafter v=(vk,k′)0≦k≦m,k′εN
Fk,k′(X)=Aff(Qk,k′({right arrow over (a)},τ),vk,k′,X),
with Aff(Q,v,X) the affine transform of X defined by:
∀x,Aff(Q,v,X)(x)=X(Q−1(x−v))
with Q an invertible 2×2 matrix and v a translation vector, and
Qi,j({right arrow over (a)},τ)=π2R{right arrow over (a)},τ(t
where
is the projection on the XY plane,
π3x is the position in the XYZ three-dimensional reference frame of a point x of a sectional image, when merging the support plane of the sectional image with the XY plane, and it is noted that for each possible direction {right arrow over (a)} of the axis of rotation, the sign of the angular rate τ is determined from the known (or assumed) direction of rotation with respect to the direction {right arrow over (a)} of the axis of rotation, for example according to the adjustment of the imaging system 10, by the following relation:
(if the direction of rotation is chosen arbitrarily: in this case, the three-dimensional representation V of the object O will at worst be the three-dimensional representation V of the mirror of the object O).
Step 314 of determining the direction {right arrow over (a)} of the axis of rotation L furthermore comprises a step 322 of comparing the values Xk(s) of the pixels s of each sectional image Xk with the values Xk′(x′) of the points x′ closest to the spatially neighboring sectional images Xk′. Preferably, the comparison step 322 is carried out by calculating a distance χ(Aff(Qk,k′,vk,k′,Xk), Xk′) between the affine transform Aff(Qk,k′,vk,k′,Xk) of the sectional image Xk and the neighboring sectional image Xk′.
Step 314 of determining the direction {right arrow over (a)} of the axis of rotation L furthermore comprises a step 324 of minimizing a cost function U, in which the translation components vk,k′ are not expressed as a function of the parameters of the motion, but are left as variables of the cost function U.
Step 324 of minimizing the cost function U therefore amounts to finding the direction {right arrow over (a)} of axis of rotation and the family of translation components vk,k′ which minimize the cost function U.
Preferably, the cost function U is given by the relation:
with Nk the set of indices of the sectional images neighboring the sectional image Xk, χ(Aff(Qk,k′({right arrow over (a)},τ),vk,k′,Xk), Xk′) a measure of the distance between the affine transform of the sectional image Xk and the spatially neighboring sectional image Xk′.
In the previous definition of the cost function U, the translation components vk,k′ are variables independent of u0,{right arrow over (a)},τ,T1 . . . Tm.
Determination of a Point of Passage of the Axis of Rotation and of the Series of Perturbation Translations
The direction {right arrow over (a)} of the axis of rotation L and of the translation components vk,k′, subsequently called the reference translation components vk,k′, having been determined, step 326 of determining a point of passage u0 of the axis of rotation L and the series of perturbation translations T1 . . . Tm comprises a step 328 of expressing translation components vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm) as a function of a series of perturbation translations T1 . . . Tm and of a point of passage u0, the direction {right arrow over (a)} of the axis of rotation L and the rotation rate τ being known:
vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm)=(π2−π2R{right arrow over (a)},τ(t
where
Step 326 of determining a point of passage u0 of the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 330 of determining the series of perturbation translations T1 . . . Tm and the point of passage u0, such that the translation components vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm) approximate the reference translation components vk,k′.
Preferably, step 330 of determining the series of perturbation translations T1 . . . Tm and the point of passage u0 comprises a step 332 of minimizing a cost function K which comprises a first part representing, for a series of perturbation translations T1 . . . Tm and a point of passage u0, a distance between the reference translation components vk,k′ and the translation components vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm) expressed as a function of the series of perturbation translations T1 . . . Tm and of the point of passage u0.
Preferably also, the cost function K comprises a second part representing the regularization Reg of the value T1 . . . Tm of series of perturbation translations whose minimization reduces the amplitude of the translations T1 . . . Tm. The regularization function Reg is preferably a quadratic norm, for example given by the relation:
Reg(T1 . . . Tm)=∥T∥M2≡TtMT,
with M a symmetric positive definite matrix, and T=T1 . . . Tm may be written in the form of a column vector with the translations Tk one after the other. For example, M=I3m, the 3 m×3 m identity matrix.
Preferably, the cost function K is given by the relation:
with α≧0 a compromise between the quadratic discrepancy between vk,k′ and vk,k′(u0,{right arrow over (a)},τ,T1 . . . Tm), and the regularization of T1 . . . Tm to control the amplitude of the translations T1 . . . Tm.
Third Variant for Determining the Axis of Rotation and the Series of Perturbation Translations
A third variant of step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm is represented in
With reference to this
Determination of the Direction of the Axis of Rotation
Step 334 of determining the direction {right arrow over (a)} comprises a step 336 of determining a projection LXY of the axis of rotation L on the section plane P, on the basis of the sectional images X0 . . . Xm.
Determination of a Projection of the Axis of Rotation on the Section Plane
The procedure for determining the projection LXY uses the fact that each pixel s and its symmetric point LXY(s) on the section plane P with respect to the projection LXY have histograms hs and hL
In the course of step 336, the projection LXY of the axis of rotation L on the section plane P is determined by choosing the line lXY of the section plane P having the highest level of symmetry of histograms, that is to say, such that the histograms hs and hl
Thus, step 336 of determining a projection LXY comprises, for each pixel s of the grid G, a step 338 of calculating a histogram hs of the gray levels taken by this pixel s in at least a part of the sectional images X0, . . . , Xm. The histogram hs represents the countdown of the values of the pixel s, without taking account of the order in which these values appear in the sequence of sectional images X0, . . . , Xm.
Preferably, the part of sectional images corresponds to the sectional images X0, . . . , Xm′ (with m′≦m) acquired while the object O carries out an integer number of rotations about the axis of rotation L. This results in:
Step 336 of determining a projection LXY furthermore comprises a step 340 of determining, for each pixel s of the grid G and for a line lXY of the section plane P, a histogram hl
Step 336 of determining a projection LXY furthermore comprises a step 342 of determining the distances Δ(hs, hl
Step 336 of determining a projection LXY furthermore comprises a step 344 of minimizing a cost function Ψ, which represents, for a line lXY of the section plane P, the differences between the histogram hs of each pixel s and the histogram hl
LXY is determined as being the line lXY on the XY plane which minimizes the cost function Ψ.
Determination of the Angle Between the Axis of Rotation and its Projection
Step 334 of determining the direction {right arrow over (a)} furthermore comprises a step 346 of determining the angle between the axis of rotation L and its projection LXY on the section plane P. This angle between the axis of rotation L and its projection LXY is determined by calculating the angle θ between the Z axis of the XYZ reference frame (perpendicular to the section plane P) and the axis of rotation L.
With reference to
Returning to
This results in the fact that the value Xk(s) of a pixel s on a sectional image Xk captured at an instant tk is substantially equal to the value Xk′(LXY(s)) of the symmetric point LXY(s) on a sectional image Xk′ captured at an instant tk′ shifted substantially by the symmetrization time t(s) with respect to the instant of capture tk.
Thus, the symmetrization time t(s) is preferably determined by determining the best temporal offset between the two vectors (X0(s), X1(s), . . . , Xm(s)) and (X0(LXY(s)),X1(LXY(s)), . . . , Xm(LXY(s))). Thus, the vector offset by time μ of the vector (X0(LXY(s)),X1(LXY(s)), . . . , Xm(LXY(s))) is defined by v(μ)=(Xq(t
Err(μ)=κ((X0(s),X1(s), . . . , Xj(μ)(s)),v(μ)),
with κ(u,v) a measure of distance between two vectors u and v, κ is chosen for example as being a normalized quadratic distance:
with l the length of the vectors. Thus t(s) is obtained by minimizing the offset error Err (μ):
with p=2π/|τ| the period of revolution.
Step 346 of determining the angle θ furthermore comprises a step 350 of determining the angle θ on the basis of the symmetrization times t(s).
Step 350 of determining the angle θ on the basis of the symmetrization times t(s) comprises a step 352 of determining a direction {right arrow over (b)} of the projection LXY, with ∥{right arrow over (b)}∥=1, as well as a point of passage y0 of the projection LXY. The projection LXY is determined by its direction and the point of passage (y0, {right arrow over (b)}). The direction {right arrow over (b)} of the projection LXY is chosen as being, to within a multipartite positive constant, the projection on the XY plane of the direction of the axis of rotation {right arrow over (a)} that is determined subsequently:
{right arrow over (b)}=πXY({right arrow over (a)})/∥πXY({right arrow over (a)})∥,
with
the matrix of projection on the XY plane. Thus it is assumed that the direction of rotation of the object O with respect to the direction of the axis of rotation {right arrow over (a)} which is determined subsequently, is known (or assumed), for example according to the adjustment of the imaging system 10, once the direction {right arrow over (b)} has been chosen (such that {right arrow over (b)}=πXY({right arrow over (a)})/∥πXY({right arrow over (a)})∥). Thus the angular rate τ of rotation is determined:
If the direction of rotation of the object is unknown, it is chosen arbitrarily: in this case, the three-dimensional representation V of the object O will at worst be the three-dimensional representation V of the mirror of the object O.
Step 350 of determining the angle φ on the basis of the symmetrization times t(s) furthermore comprises a step 354 of determining, for each pixel s, a distance z(s) between, on the one hand, the middle
of the segment between the pixel s and its symmetric counterpart LXY(s) with respect to the projection LXY, and, on the other hand, the center c(s) of the circle about which rotates a point o of the object O passing through the pixel s. This distance is positive if the center c(s) is above the XY plane, it is zero if c(s) is in the XY plane, and negative otherwise.
Preferably, the distance z(s) is given by the relation:
with t(s)τ the angle of the arc of the circle from s to the symmetric point LXY(s) in the direction of rotation,
PR and PL being the two half-planes of the section plane P, separated by the projection LXY. PR and PL are defined by:
PL={sεP:<{right arrow over (b)}(s−y0),{right arrow over (e)}3>≧0}
PR={sεP:<{right arrow over (b)}(s−y0),{right arrow over (e)}3><0},
with the vector product, <.,.> the scalar product, and
the direction of the Z axis of the reference frame. PR and PL do not depend on the position of y0 on the projection LXY.
In theory, there is an affine relation between the distance z(s) and the position on projection LXY of the axis of rotation, of the point
(which is also the projection of s on the projection LXY of the axis of rotation) with respect to the point y0:
z(s)=<s−y0,{right arrow over (b)}>cos φ+z0,
with z0≧0 if the projection of the point y0 on the axis of rotation L is above the XY plane or in the XY plane and z0<0 otherwise, and |z0| is the distance between y0 and the axis of rotation L.
Thus, preferably, step 350 of determining the angle θ on the basis of the symmetrization times t(s) furthermore comprises a step 356 of determining the angle θ through the regression of the previous affine relation:
with Gδ,σ
In practice, δ is chosen between 4 and 20 pixels, σmin2 is for example the q-quantile of the empirical variances of the gray levels, calculated for each pixel s of the grid G, taken by the pixel s in the sequence of sectional images X0, . . . , Xm (thereby signifying that the proportion of the pixels s of the grid G, where the calculated empirical variance of the gray levels is less than or equal to σmin2, is substantially equal to q), q equals between 60% and 95% in general.
Limiting the previous regression to the pixels in Gδ,σ
Step 334 of determining the direction {right arrow over (a)} furthermore comprises a step 358 of determining the direction {right arrow over (a)}, on the basis of the projection LXY and of the angle φ. The direction {right arrow over (a)} of the axis of rotation L is for example given by the vector of spherical coordinates (1,θ,φ), with θ the angle between the X axis and the direction {right arrow over (b)} of the projection LXY, such that {right arrow over (b)}=πXY({right arrow over (a)})/∥πXY({right arrow over (a)})∥.
Optional Determination of the Point of Passage of the Axis of Rotation
As an optional supplement, step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 360 of determining a point of passage u0 of the axis of rotation L, on the basis of the symmetrization time or times t(s). Preferably, the point of passage u0 chosen as being the point of intersection between the axis of rotation L and the straight line perpendicular to the XY plane and passing through the point y0. The point of passage u0 is in this case given by the following relation:
Determination of the Series of Perturbation Translations
Step 300 of determining the axis of rotation L and the series of perturbation translations T1 . . . Tm furthermore comprises a step 362 of determining the series of perturbation translations T1 . . . Tm, carried out in the same manner as in step 330.
More precisely, step 362 of determining the series of perturbation translations T1 . . . Tm comprises a step 364 of determining, in the same manner as in step 324, the reference translation vectors vk,k′ of the affine transformations Fk,k′ whose values minimize the cost function U, with the direction {right arrow over (a)} of the axis of rotation L and the angular rate τ both known.
By virtue of the knowledge of the direction {right arrow over (a)} of the axis of rotation, the minimization of U is greatly simplified, by independently minimizing each term χAff(Qk,k′({right arrow over (a)},τ),vk,k′,Xk), Xk′) so as to individually determine each reference translation vector vk,k′.
Step 362 of determining the series of perturbation translations T1 . . . Tm furthermore comprises a step 366 of determining the series of perturbation translations T1 . . . Tm and the point of passage u0 having the values which minimize the cost function K of step 332, knowing the reference translation vectors vk,k′.
As a variant, when the optional step 360 is carried out, the minimization of the cost function K is simplified by using the point of passage u0 determined in this step. Moreover, step 366 amounts to determining the series of perturbation translations T1 . . . Tm having the value which minimizes the cost function K, the point of passage u0 being known.
Determination of a Three-Dimensional Representation of the Object
With reference to
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 404 of determining a set Ω of points u of the volume D and a value X(u) of each of these points u at a reference instant. Hereinafter, the initial instant t0 will be chosen as reference instant. The set Ω of points u comprises, in particular, points o of the object O in its position O0 at the initial instant t0.
It will be noted that, in a very simple implementation, the set Ω of points u already forms a three-dimensional representation of the object, said representation being given by the constellation of the points of the set Ω.
Step 404 of determining the set of points Ω is carried out on the basis of the positions of the object O with respect to the section plane P at each picture capture instant t0 . . . tm, and of the sequence of sectional images X0 . . . Xm.
More precisely, step 404 of determining the set of points Ω comprises a step 406 of calculating, for each sectional image Xk, the position Ck(s) of each pixel s of the sectional image Xk at the initial instant t0, assuming that this pixel belongs to the object O. The calculation is carried out on the basis of the previously determined parameters of the motion of the object O (angular rate τ, axis of rotation L, series of perturbation translations T1 . . . Tm). The position Ck(s) of each point u of the set Ω is given for a respective original pixel s of an image Xk, by:
Ck(s)=R{right arrow over (a)},τ(t
with
Each of the points u of the set Ω is associated with the value Xk(s) of the original pixel s of the original sectional image Xk: X(u)=Xk(S).
It will be noted that the set Ω can thus comprise one and the same point u several times, each time associated with a respective value, these various values stemming from various sectional images.
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 408 of choosing a three-dimensional representation function Vβ that can be parametrized with parameters β, and an operation Op giving, on the basis of the three-dimensional representation function Vβ, an estimation function {tilde over (X)}=Op(Vβ) of the value of each point u of the set Ω.
Once the parameters β have been determined, the three-dimensional representation V is given by the three-dimensional representation function Vβ, preferably at any point of the volume D.
First Variant of Three-Dimensional Representation Function Vβ
With reference to
w=b+(a1k1,a2k2,a3k3),
with bεR3, and a1, a2 and a3 respectively the sampling increment in the directions X, Y and Z, and k1, k2, k3 integers. Each parameter of the three-dimensional representation function Vβ is associated with a respective node.
The three-dimensional representation function Vβ may then be written:
with η the central B-spline function of degree r defined on the set of real numbers R, W the set of nodes in the volume D. η is for example the indicator function on the interval
convolved r times with itself:
In particular, if r=3 (cubic B-spline function):
In this first variant, the operation Op is chosen as the identity function, so that the estimation function {tilde over (X)} for the value of each point u of the set Ω is equal to the three-dimensional representation function Vβ: {tilde over (X)}(u)=Vβ(u).
With this choice of three-dimensional representation function Vβ, step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 410 of dividing the volume D into a plurality of mutually disjoint sub-volumes Di. As a variant, the edges of the sub-volumes Di overlap. In this way, the nodes w are also divided into groups {w}, each associated with a respective sub-volume Di. Likewise, the points of the set Ω are divided into groups Ωi each associated with a respective sub-volume Di.
More precisely, each group {w}, comprises the nodes situated in the respective sub-volume Di and the parameters {β}i of these nodes {w}, are thus associated with the sub-volume Di. Likewise, the points of each group Ωi, are the points of the set Ω situated in the sub-volume Di.
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 412 of determining the parameters β, such that, for each point u of the set Ω, the estimation {tilde over (X)}(u) of the value of the point u gives substantially the value X(u) of the point u.
More precisely, step 412 of determining the parameters β comprises, for each sub-volume Di, a step 414 of determining the parameters {β}i associated with this sub-volume Di, such that, for each point u of the group Ωi and of the groups directly contiguous with the group Ωi, the estimation {tilde over (X)}(u) of the value of the point u gives substantially the value X(u) of the point u, the parameters {β}j≠i associated with the other subsets Dj≠i being fixed at a given value.
Step 414 of determining the parameters {β}i is implemented several times, in an iterative manner, each time sweeping all the sub-volumes Di: in the course of the first iteration, each group of parameters {β}i is determined successively (for the determination of a group of parameters {β}i, the given value of each of the other groups of parameters {β}j≠i is fixed at a predetermined value, for example zero); in the course of the subsequent iterations, each group of parameters {β}i is determined successively (for the determination of a group of parameters {β}i, the given value of each of the other groups of parameters {β}j≠i is the last result determined beforehand).
Preferably, the parameters {β}i are determined by minimizing the following cost function:
A is a positive definite symmetric matrix, or more generally semi-positive definite, βt Aβ is a measure of the quadratic irregularity, and λ>0 is a compromise between the fitness of the three-dimensional representation function and regularity.
Second Variant of Three-Dimensional Representation Function Vβ
With reference to
with W the set of nodes in the volume D.
The function φ(u−w) depends on the distance between the point u and the node w, but not on the direction between the point u and the node iv. For example, φ(x)=exp(−c∥x∥2) or φ(x)=η(∥x∥) with η the cubic central B-spline function.
Furthermore, the operation Op gives an estimation function {tilde over (X)}=Op(Vβ,ƒR) for the value of each point u of the set Ω on the basis of the three-dimensional representation function Vβ and a point spread function ƒR. In the example described, the operation Op is a convolution of the three-dimensional representation function Vβ with the following point spread function ƒR: ƒR(u)=ƒ(Ru), with ƒ the point spread function without rotation, which is known (for example, given by the constructor of the imaging system, or determined experimentally), ƒR the point spread function for the rotation R, and Ru the point resulting from the rotation of the point u by the rotation R.
The point spread function ƒR depends on the rotation R between the position of the object O at the instant tk of capture of the respective sectional image Xk associated with the point u, and the position of the object O at the reference instant t0: R=R{right arrow over (a)},τ(t
{tilde over (X)}(u)=Op(Vβ,ƒR)(u)=(Vβ*ƒR)(Ck(s)),
with * the convolution operation, the pixel s and the sectional image Xk (of the instant of capture tk) being respectively the original pixel and the image of the point u.
On account of the choice of radial basis functions φ, we obtain the property that, for each point u of the volume D:
Op(φ,ƒR)(u)=Op(φ,f)(Ru),
i.e.:
(φ*ƒR)(u)=(φ*ƒ)(Ru)
with * the convolution operation, R an arbitrary rotation.
Thus, step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 416 of determining the parameters β of the three-dimensional representation function Vβ by minimizing the following cost function:
where s and the sectional image Xi the instant of capture ti) are respectively the original pixel and the image of the point u, Ri=R{right arrow over (a)},τ(t
In an advantageous manner, this minimization is carried out by calculating a unique convolution (the convolution φ*ƒ) and by solving the linear system, which ensues from the calculation of the convolution φ*ƒ, on the parameters β. The parameters β are thus easily determined.
Variant for Determining the Set Ω
In this variant, step 404 of determining the set of points Ω comprises a step 420 of determining a three-dimensional representation function Vl, on a respective sub-volume Dl, for each sequence Sl. This step 420 is for example implemented according to the previous steps 408 to 416 for each sequence Sl.
Each three-dimensional representation function Vl gives a representation of the object O in a respective position, denoted Ol.
Step 404 of determining the set of points Ω furthermore comprises a step 422 of discretizing each sub-volume Dl according to a three-dimensional grid G3. A discretized sub-volume {tilde over (D)}l, grouping together the points of the sub-volume Dl that are situated on the three-dimensional grid G3, is thus obtained for each sequence Sl. We thus obtain:
∀uε{tilde over (D)}l,{tilde over (V)}l(u)=Vl(u).
Preferably, the three-dimensional grid G3 has a spacing which is less than or equal to that of the grid G of the section plane P.
Step 404 of determining the set of points Ω furthermore comprises a step 424 of determining, for each sequence Sl, a rotation Q1 and a translation hl making it possible to substantially place all the positions Ol of the representations of the object O in one and the same reference position.
Preferably, the reference position is that of one of the sequences Sl. Hereinafter, the position Ol of the object of the first sequence Sl will be the reference position. Thus, a point o of the object O of the position u in Ol is at the position Qlu+hl in Ol, with l≠1.
Step 424 of determining, for each sequence Sl, a rotation Ql and a translation hl comprises a step 426 of determining a quantile level q, such that substantially the luminous points of the object O have values {tilde over (V)}l(u) that are greater than or equal to the q-quantile ρl(q), for each discretized subset {tilde over (D)}l. For example, the quantile level q is taken between 60% and 95%.
Step 424 of determining, for each sequence Sl, a rotation Ql and a translation hl furthermore comprises a step 428 of selecting at least three groups g1 . . . gk, preferably four or more, of points of the discretized subset {tilde over (D)}l, according to a selection criterion. The selection criterion is the same for all the sequences Sl. The selection criterion applies in particular to the value of the points of the discretized subset {tilde over (D)}l.
By thus applying the same selection criterion for all the sequences Sl, it is possible to obtain substantially the same points of the object O for all the sequences Sl, even if these points do not have the same position for the various sequences Sl.
In a first variant represented in
Step 428 of selecting the groups gl . . . gk furthermore comprises a step 432 of ranking, for each sequence Sl, the n most luminous points (selected previously) according to their value, in descending order for example.
Step 428 of selecting the groups g1 . . . gk furthermore comprises a step 434 of dividing the n ranked most luminous points into k groups g1 . . . gk of substantially equal size: the points of the group g1 are more luminous than those of the group g2, which are more luminous than those of g3, etc.
In a second variant represented in
Step 428 of selecting the groups g1 . . . gk, furthermore comprises a step 437 of determining the highest distance between the barycenter and the points of all the sets {tilde over (D)}l,q. This distance will subsequently be called the radius r.
Preferably, the radius r is given by:
r=min(max{∥u−b1∥:uε{tilde over (D)}l,q}, . . . , max{∥u−bl∥:uε{tilde over (D)}l,q})
Step 428 of selecting the groups g1 . . . gk, furthermore comprises a step 438 of dividing the radius r (that is to say of the segment [0,r]) into k segments of equal sizes (segi=[(k−i)r/k, (k−i+1)r/k], with 1≦i≦k), each group g1 . . . gk being associated with a respective segment.
More precisely, for each sequence Sl, each group gi comprises the points u of {tilde over (D)}l,q whose distance from the barycenter bl lies in the associated segment segi.
Returning to
Step 424 of determining, for each sequence Sl, a rotation Ql and a translation hl furthermore comprises a step 442 of determining the rotation Ql and the translation hl on the basis of the barycenters ωl,i.
Preferably, the rotations Ql and the translations hl are determined through the minimization of a cost function:
with O(3) the set of 3-by-3 orthogonal matrices.
Preferably, the solution of the previous minimization is obtained by calculating:
and P1 and Pl obtained by singular value decomposition (SVD) of the matrix
that is to say M=P1ΛPli with P1 and Pl 3-by-3 orthogonal matrices, and Λ a diagonal matrix with non-negative numbers on the diagonal.
Step 404 of determining the set of points Ω furthermore comprises a step 444 of determining the points u of Ω and a value X(u) of each of these points u, on the basis of the sequences of sectional images Sl with l=1 . . . I, the rotation matrices Ql and the translations hl being known: the set Ω consists of the points u of the volume D with position
QltR{right arrow over (a)}
for each pixel s of each sectional image Xkl of each sequence Sl, with τl, {right arrow over (a)}l, u0l and Tkl which are respectively the parameters of the motion for the sequence Sl, Q1=I3 the 3-by-3 identity matrix, h1=0,
Each of the points u of the set Ω is associated with the value Xkl(s) of the pixel s of the sectional image Xkl of the sequence Sl: X(u)=Xkl(s) with s, Xkl and Sl being respectively the original pixel, the image and the sequence of the point u.
Taking Account of the Duration of Acquisition
In the course of the capture of the sectional images, the object O moves during the time of exposure to create an image on the focal plane. This engenders a non-negligible additional motion fuzziness (supplementing the fuzziness defined by the point spread function).
This motion fuzziness is, in one embodiment of the invention, taken into account in step 400 of the three-dimensional representation V of the object O, preferably when the exposure time is relatively long with respect to the time necessary to pass from one sectional image Xk to the next sectional image Xk+1.
Thus, with reference to
In the example described, the start-of-acquisition instant δ0 and the duration of acquisition δ are the same for all the sectional images. Nonetheless, the procedure easily extends to the case where the start-of-acquisition instant δ0 and the duration of acquisition δ vary according to the sectional images.
During exposure, the luminosity level of each point of the focal plane evolves progressively by adding the luminosity level of the points of the route that it travels.
The position of the object O at each instant tk being known (or estimated), step 400 of the three-dimensional representation V of the object O furthermore comprises a step 452 of determining the continuous position of the object O, as a function of time, between the successive instants tk and tk+1, and more particularly during the acquisition intervals Ik.
Thus, step 452 of determining the continuous position of the object O comprises a step 454 of determining a relation between the position ψk,t(u) at the instant tk+t (between the successive instants tk and tk+1) of a point of the object, which is situated at the position u at the instant tk, and the object's motion parameters: angular rate τ, axis of rotation L and series of perturbation translations T1 . . . Tm.
Given that the duration between the instants tk and tk+1 is short, we consider that the motion is composed approximately of the stable rotation and of a translation, a linear fraction (proportional to time) of the perturbation translation between the instants tk and tk+1.
Thus, the position ψk,t(u) is given by:
with Tm+1=0.
It will be noted that ψk,0(u)=u and ψk,t
Step 452 of determining the continuous position of the object O furthermore comprises a step 456 of determining a relation between the position Ck,t(s) at the initial instant t0 of the point o of the object, whose position at the instant tk+t is on the pixel s of the section plane P, on the basis of the previous function ψk,j. This position Ck,t(s) is given by:
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 460 of choosing the operator Op as being the integral over the acquisition interval Ik of the convolution of the three-dimensional representation function Vβ with the point spread function ƒR.
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 462 of calculating, for each point u of the set Ω, an estimation {tilde over (X)}(u) of the value of this point u, on the basis of the operator Op. The estimation {tilde over (X)}(u) is given by:
where s and the sectional image Xk (of the instant of capture tk) are respectively the original pixel and the image of the point u.
Just as for the second variant, step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 464 of choosing the three-dimensional representation function Vβ as a decomposition into radial basis functions φ:
with W the set of nodes in the volume D.
Step 400 of determining the three-dimensional representation V of the object O furthermore comprises a step 466 of determining the coefficients β(w).
More precisely, by replacing Vβ by its decomposition into radial basis functions, we obtain, for each point u of the set Ω:
where s and the sectional image Xk (of the instant of capture tk) are respectively the original pixel and the image of the point u, and γ=φ*ƒ.
We write
We therefore have, for each point u of the set Ω:
where s and the sectional image Xk (of the instant of capture tk) are respectively the original pixel and the image of the point u.
Just as for the second variant y=φ*ƒ is preferably calculated analytically or numerically by approximate calculations.
Thus, step 466 of determining the coefficients β(w) comprises a step of calculating the values γk,w.
If the analytical calculation of γk,w is unwieldy or impossible, γk,w is approximated by a discrete sum, for example the Riemann sum:
with J a fairly large integer, for example J≈20.
More generally, in the case where several sequences Sl, l=1, . . . , I are used, the rotations Ql and the translations hl being known, step 466 of determining the coefficients β(w) comprises a step consisting in substantially placing all the positions Ol of the representations of the object O in one and the same reference position. Recall that by choosing for example the first sequence as the reference sequence, Q1=I3 (with I3 the 3-by-3 identity matrix) and h1=0, it is possible to decompose, in the reference frame of the reference sequence, for each point u of the set Ω, the estimation {tilde over (X)}(u) of the value of this point u into a linear combination associated with the coefficients β(w):
where s, the sectional image Xkl (of the instant of capture tkl) and Sl are respectively the original pixel, the image and the sequence of the point u, τl, {right arrow over (a)}l, u0l and Tkl are the parameters of the motion for the sequence Sl, Tm
Thus, in this case, step 466 comprises a step of calculating the values γk,wl.
Like γk,w(x), γk,wl(x) can also be approximated by a discrete sum (Riemann sum for example).
Preferably, D is chosen sufficiently large such that D contains all the points u with position
QltR{right arrow over (a)}
for each pixel s of each sectional image Xkl of each sequence Sl, with l=1 . . . I. The parameters β of the three-dimensional representation function Vβ are determined by minimizing the following quadratic cost function:
where A is a semi-positive definite matrix, β′ Aβ measures the irregularity of the coefficients β(w), for example A is chosen in the same manner as previously, λ>0 is the parameter of compromise between the fitness of the three-dimensional representation function and the regularity of the coefficients. E(β) may be written in the following matrix form:
E(β)=νy−Kβ∥2+λβtAβ,
where β is the vector of coefficients, the elements of the vector y are the values Xkl(s), and the matrix K is composed of the elements γk,wl(π3s).
The result of minimizing E(β) is the solution of the following linear system:
(KtK+λA)β=Kty.
To calculate the coefficients β(w), it is possible to use numerical optimization procedures, for example the conjugate gradient procedure, or the block-wise optimization procedure presented previously.
Adjustment of the Position of the Section Plane
It is desirable that the largest part of the object O passes within the section plane P. In an optimal configuration, the axis of rotation L is substantially contained in the section plane P. Thus, in one embodiment of the invention, the method comprises a step 53, inserted between steps 52 and 54, of adjusting the position of the section plane P with respect to the axis of rotation L. Quite obviously, the adjustment step can also be implemented independently of steps 50, 52, 54 and 56.
Provision is made for three ways of carrying out the adjustment step 53, so as to obtain substantially the optimal configuration, or else, by default, an appropriate configuration.
First Adjustment Variant
In a first variant, the adjustment step 53 comprises the displacement and the tilting of the optical microscope so as to place the axis of rotation L in the focal plane P. This variant makes it possible to obtain the optimal configuration.
This variant comprises the determination of the axis of rotation L in the same manner as in steps 54 and 56.
Second Adjustment Variant
In a second variant, the adjustment step 53 comprises the modification of the electric or electromagnetic field so as to place the axis of rotation L in the focal plane P. This variant also makes it possible to obtain the optimal configuration.
This variant comprises the determination of the axis of rotation L in the same manner as in steps 54 and 56.
Third Adjustment Variant
With reference to
In the example described, the middle of the object O is taken as being the barycenter of the object O.
Thus, with reference to
The adjustment step 53 furthermore comprises a step 53C of determining the set of points Ω in the same manner as in step 404.
The adjustment step 53 furthermore comprises a step 53D of determining a barycenter b of the luminous points of the set Ω. The barycenter b is preferably determined by the relation:
with X0 . . . Xn, n≦m the part of the sectional images X0 . . . Xm, which have been acquired during the time interval in the course of which the object carries out a maximum number of complete revolutions by revolving about the axis of rotation, lB>A=1 when B is greater than A and 0 otherwise, and α is for example the q-quantile of gray level of the sectional images X0 . . . Xn (thereby signifying that the proportion of the pixels which have a gray level less than or equal to α is substantially equal to q). Generally, q equals between 60% and 95%.
The adjustment step 53 furthermore comprises a step 53E of calculating the projection
The adjustment step 53 furthermore comprises a step 53F of adjusting the imaging system 10 so as to bring the section plane P onto the projection
Let φ be a radial basis function. For any rotation matrix R, φ(Rx)=φ(x). We then have:
Number | Date | Country | Kind |
---|---|---|---|
08 51985 | Mar 2008 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FR2009/050512 | 3/25/2009 | WO | 00 | 10/26/2010 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2009/125131 | 10/15/2009 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5652831 | Huang et al. | Jul 1997 | A |
5892691 | Fowler | Apr 1999 | A |
6253164 | Rohm et al. | Jun 2001 | B1 |
6377865 | Edelsbrunner et al. | Apr 2002 | B1 |
6996505 | Edelsbrunner et al. | Feb 2006 | B1 |
8004517 | Edelsbrunner et al. | Aug 2011 | B1 |
20020041717 | Murata et al. | Apr 2002 | A1 |
20030068079 | Park | Apr 2003 | A1 |
20040021876 | De Jonge et al. | Feb 2004 | A1 |
20040108999 | Martin | Jun 2004 | A1 |
20040228529 | Jerebko et al. | Nov 2004 | A1 |
20040249303 | Serra | Dec 2004 | A1 |
20050168460 | Razdan et al. | Aug 2005 | A1 |
20050246130 | Spicer et al. | Nov 2005 | A1 |
20050259882 | Dewaele | Nov 2005 | A1 |
20060109277 | Fenney et al. | May 2006 | A1 |
20060235666 | Assa et al. | Oct 2006 | A1 |
20090080747 | Lu et al. | Mar 2009 | A1 |
Number | Date | Country |
---|---|---|
1 413 911 | Apr 2004 | EP |
Entry |
---|
Bindiganavle, Parametric B-splines, pp. 1-24. |
The University of Texas at Austin, BB-splines, A-Splines and B-Splines, Fall 2005, Department of Computer Sciences, pp. 39. |
Thevenaz et al., Interpolation Reviisited, Jul. 2000, IEEE Transactions, vol. 19, No. 7, pp. 20. |
Yong et al. “A bayesian 3D volume reconstruction for confocal micro-rotation cell imaging.” Medical Image Computing and Computer-Assisted Intervention A Miccai, vol. 4792, Oct. 29, 2007, pp. 685-692. |
Number | Date | Country | |
---|---|---|---|
20110037831 A1 | Feb 2011 | US |