Edge-preserving enhancement of seismic images by nonlinear anisotropic diffusion

Information

  • Patent Grant
  • 6725174
  • Patent Number
    6,725,174
  • Date Filed
    Friday, February 7, 2003
    21 years ago
  • Date Issued
    Tuesday, April 20, 2004
    20 years ago
Abstract
A method for preserving edges in an image data set utilizing a modified anisotropic diffusion technique which can be applied multiple times to the image data to improve edge definition. The modified anisotropic diffusion technique may be applied to a filtered data set as well.
Description




PRIORITY CLAIM




The present application claims priority on European Patent Application 00306780.8, filed on Aug. 9, 2000.




BACKGROUND OF THE INVENTION




The present invention relates to a method of processing an image, for example a seismic image, applying a diffusion process. Such methods are known, see for example the thesis J. Weickert, ‘Anisotropic Diffusion in Image Processing’, Ph.D. Thesis, University of Kaiserslautem, Germany, January 1996, pages 41-44.




Known is a diffusion method that comprises the steps of




(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3;




(b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


;




(c) calculating for each point a symmetric n×n structural matrix S, wherein the elements s


pq


equal u


xp


.u


xq


;




(d) calculating for each point an n×n diffusion matrix D, wherein the elements d


ij


are a function of the elements s


pq


;




(e) calculating for each point u(m+1) from u(m) using the following equation u(m+1)=u(m)+div(Dgrad(u(m))); and




(f) repeating steps (b) through (e) M times to obtain the processed image.




Unless otherwise specified, the following holds throughout the specification and the claims:








i, j, p, q=


1, . . . ,


n ;












u




xi




=∂u/∂x




i


.






An element of the image data set is also referred to as a point of the image.




In the known method an initial image is processed to obtain successive images, wherein each image is obtained from the previous one by a diffusion process. The diffusion method can as well be described by the







diffusion





equation








u



t



=


div


(

D
·






u


)


.











There are four types of diffusion methods. At first there is the isotropic diffusion in which the diffusivity D is a scalar and the anisotropic diffusion in which D is a matrix. Then for each of these two types, the diffusion can be linear, in which D is not a function of u or the diffusion can be non linear in which D is a function of u.




This method can as well be applied to processing a seismic image, in that case the image intensity is the amplitude of the seismic signal.




An advantage of the diffusion method is that noise is suppressed. A further advantage, which is particularly relevant to processing a seismic image is that after a few cycles the geological structure is highlighted more clearly. However, a problem with this method is preserving edges.




Edge preservation is of great interest in the interpretation of seismic images, which play an important role in the study of underground formations, and in particular in the study of underground formations that contain hydrocarbons. Moreover there is a great interest in edge preserving techniques, which allow highlighting of faults while removing noise from the seismic data.




SUMMARY OF THE INVENTION




For edge preservation in combination with isotropic diffusion processing is proposed a method based on the Perona-Malik model (see the thesis of Weickert, page 10) of which the diffusion equation is










u



t


=

div


(


g


(


&LeftBracketingBar;






u

&RightBracketingBar;

2

)









u


)



,










wherein the non-linear diffusivity is g(|∇u|


2


)=(1+|∇u|


2





2


)


−1


, the scalar λ being a pre-determined edge preservation parameter.




Applicant proposes a simple addition to the known method that has proved to be an effective way of preserving edges while capable of removing noise. Moreover Applicant proposes such a method that is applicable to anisotropic diffusion.




To this end the method of processing an image according to the present invention comprises the steps of




(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3;




(b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


;




(c) calculating for each point a symmetric n×n structural matrix S, wherein the elements s


pq


equal u


xp


.u


xq


;




(d) calculating for each point an n×n diffusion matrix D, wherein the elements d


ij


are a function of the elements s


pq


;




(e) calculating for each point u(m+1) from u(m) using the following equation u(m+1)=u(m)+c.div(ε.Dgrad(u(m))), wherein c is a predetermined constant, 0≦c≦1, and wherein ε is a scalar, 0≦ε≦1, wherein ε is close to zero when near an edge and close to 1 when far away from an edge; and




(f) repeating steps (b) through (e) M times to obtain the processed image.




In this way edge preservation is introduced in anisotropic, non-linear diffusion.




Suitably step (c) comprises calculating for each point a symmetric n×n structural precursor matrix S


0


, wherein the elements s


0




pq


equal u


xp


.u


xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S.




Alternatively step (c) comprises filtering for each point the partial derivatives u


xi


by convolution with a suitable kernel to obtain regularized partial derivatives u


r




xi


; calculating for each point a symmetric n×n structural precursor matrix S


0


, wherein the elements s


0




pq


equal u


r




xp


.u


r




xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S.




The above described alternatives for step (c), wherein a precursor matrix is calculated allows defining the edge preservation parameter as follows: ε=trace(S


0


S)/(trace(S


0


).trace(S)). In this way the edge preservation parameter is calculated for each point.




The present invention also relates to a method of processing an image in order to display the edge preservation parameter. This method comprises the steps of




(a) obtaining an n-dimensional initial image data set, wherein each element u(m0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3;




(b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


;




(c) calculating for each point a symmetric n×n structural matrix S


0


, wherein the elements s


0




pq


equal u


xp


.u


xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S; and




(d) calculating for each point ε=trace(S


0


S)/(trace(S


0


).trace(S)) and attributing the calculated value of ε to each point to obtain an image in which faults are highlighted.




Alternatively, the method of processing an image comprises the steps of




(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3;




(b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


;




(c) filtering for each point the partial derivatives u


xi


by convolution with a suitable kernel to obtain regularized partial derivatives u


r




xi


; calculating for each point a symmetric n×n structural precursor matrix S


0


, wherein the elements s


0




pq


equal u


r




xp


.u


r




xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S;




(d) calculating for each point ε=trace(S


0


S)/(trace(S


0


).trace(S)) and attributing the calculated value of ε to each point to obtain an image in which faults are highlighted.




In the paper ‘Coherence-Enhancing Diffusion Filtering’ by J Weickert, International Journal of Computer Vision vol 31(2/3), pages 111-127, (1999), modifications of the method known from the abovementioned thesis are discussed. The paper discloses a method for enhancing coherence in images with flow-like structures. This method is not a method for preserving edges, and no parameter corresponding to the parameter ε of the present invention is disclosed.











BRIEF DESCRIPTION OF THE DRAWINGS




A better understanding of the invention may be had in the Detailed Description of the Preferred Embodiment, viewed in conjunction with the drawings of which:





FIG. 1

is an exemplary image set;





FIG. 2

is the exemplary image set processed with three anisotropic diffusion steps according to the method of the present invention;





FIG. 3

is the image set treated with ten anisotropic diffusion steps according to the method of the present invention;





FIG. 4

is the image set treated with three anisotropic diffusion steps with no edge preservation;





FIG. 5

is the image set treated with ten anisotropic diffusion steps with no edge preservation;





FIG. 6

is the image set treated with anisotropic diffusion without edge preservation;





FIG. 7

is the image set treated with anisotropic diffusion with edge preservation according to Perona-Malik with λ=10; and





FIG. 8

is the original image set treated to highlight faults.











DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT




The present invention will now be described by way of example in more details. At first the equations for a two-dimensional image are discussed, then for a three dimensional image and thereafter alternative embodiments.




In two dimensions, the initial image data set comprises k


1


×k


2


elements (or points) u(m=0), wherein the value of each element u is the initial image intensity of a point of the image, and wherein k


1


and k


2


are the number of points in the two directions x


1


and x


2


of the two-dimensional image. The word pixel is used to refer to such a point in two dimensions, and in three dimensions, the point is called a voxel.




The next step comprises calculating the partial derivatives of all points u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


. The first data set comprises k


1


×k


2


values of u


x1


(=∂u/∂x


1


) and the second data set comprises k


1


×k


2


values of u


x2


(=∂u/∂x


2


).




Then for each point a symmetric n×n structural matrix S is calculated, wherein the elements s


pq


equal u


xp


.u


xq


. The structural matrix S is in two dimensions







(





u
x1

·

u
x1






u
x1

·

u
x2








u
x2

·

u
x1






u
x2

·

u
x2





)

.










Then for each point an n×n diffusion matrix D is calculated, wherein the elements d


ij


are a function of the elements s


pq


, which elements s


pq


are a function of the partial derivatives u


xp


and u


xq


.




Then the image comprising the elements u(m=0) is processed in M steps to obtain a processed image comprising elements u(m=M), wherein after each step the integer m is increased with 1. The k


1


×k


2


values u(m+1) of each image are obtained from the values u(m) from a previous image by solving a diffusion type equation: u(m+1)=u(m)+c.div(ε.Dgrad(u(m))). The number of times the image is processed, M, is a predetermined value. In order to remove noise, M is suitably in the range of from 2 to 4, and when in addition thereto the image has to be simplified, M is suitably in the range of from 5 to 20.




In this equation, c is a predetermined constant, 0≦c≦1, and ε is a scalar, 0≦ε≦1, wherein ε is close to zero when near an edge and close to 1 when far away from an edge. The scalar ε can be understood to be a fault highlighter.




In two dimensions,







div


(

ε
·

Dgrad


(
u
)



)


=




i
=
1

2

















x
i






(

ε


(



d
i1



u
x1


+


d
i2



u
x2



)


)

.













In three dimensions, the image data set comprises k


1


×k


2


×k


3


image intensities u(m). The first derivative data set comprises k


1


×k


2


×k


3


values of u


x1


(=∂u/∂x


1


), the second derivative data set comprises k


1


×k


2


×k


3


values of u


x2


(=∂u/∂x


2


), and the third derivative data set comprises k


1


×k


2


×k


3


values of u


x3


(=∂u/∂x


3


). The n×n structural matrix S is







(





u
x1

·

u
x1






u
x1

·

u
x2






u
x1

·

u
x3








u
x2

·

u
x1






u
x2

·

u
x2






u
x2

·

u
x3








u
x3

·

u
x1






u
x3

·

u
x2






u
x3

·

u
x3





)

.










In three dimensions,







div


(

ε
·

Dgrad


(
u
)



)


=




i
=
1

3

















x
i






(

ε


(



d
i1



u
x1


+


d
i2



u
x2


+


d
i3



u
x3



)


)

.













In the above, the diffusion matrix is not calculated directly from the image intensities. However, suitably the diffusion matrix is calculated from filtered data. Therefore the step of calculating the structural matrix suitably comprises calculating for each point a symmetric n×n structural precursor matrix S


0


, wherein the elements s


0




pq


equal u


xp


.u


xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S.




In an alternative embodiment, the n×n structural matrix S is calculated from filtered partial derivatives. To this end, the partial derivatives u


xi


are filtered for each point by convolution with a suitable kernel to obtain regularized partial derivatives u


r




xi


. For each point a symmetric n×n structural precursor matrix S


0


is calculated, wherein the elements s


0




pq


equal u


r




xp


.u


r




xq


. Then the (½)n(n+1) data sets are created, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on. And these data sets are filtered by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S.




Suitably the edge preservation parameter ε is derived from the image data set by calculations. Applicant had found that the structural precursor matrix S


0


can be used to estimate the scalar ε, suitably ε=trace(S


0


S)/(trace(S


0


).trace(S)), wherein trace(A) is the sum of the diagonal elements a


kk


of the matrix A. In this way ε becomes a function of the partial derivatives of u(m) in the two or three directions. And the scalar ε is a fault highlighter that is calculated for each point. The scalar is about 1 in the absence of a fault and much smaller than 1 in the presence of a fault.




Suitably step (d) comprises determining the n eigenvalues λ


i


and n eigenvectors v


i


of each of the structural matrices S; sorting the eigenvalues so that λ


1


≧λ


2


(≧λ


3


) and calculating for each point an n×n diffusion matrix D, wherein the elements d


pq


equal v


2p


.v


2q


(wherein v


2


is the eigenvector pertaining to the smallest eigenvalue if n=2) or wherein the elements d


pq


equal v


2p


.v


2q


+v


3p


.v


3q


(wherein v


2


and v


3


are the eigenvectors pertaining to the smallest eigenvalues if n=3). The symbols v


ip


and v


iq


denote the p-th and q-th element of the eigenvector v


i


. As a result the eigenvector pertaining to the largest eigenvalue does not contribute to the diffusion matrix, and the eigenvector(s) pertaining to the smaller eigenvalue(s) do contribute. This inhibits diffusion of the image luminance in the direction of the eigenvector pertaining to the largest eigenvalue, which latter eigenvector is directed perpendicular to the reflection.




The suitable kernel is a kernel for low pass filtering, such a kernel is symmetric and positive everywhere. A suitable kernel is the Gaussian kernel of width σ>0, which is given by the following equation: The Gaussian kernel is used as a








K
σ



(
x
)


=


1


(

2





π






σ
2


)


n
/
2



·

exp


(


-


&LeftDoubleBracketingBar;
x
&RightDoubleBracketingBar;

2



2






σ
2



)













convolution mask, wherein x is the position of the centre of the convolution mask and is the Euclidean norm, and n is the dimension.




Reference is made to

FIG. 1

, which shows the original image. The image is 128 pixels by 128 pixels having a value in the range from 0 to 255. The picture shows reflectors


1


,


2


,


3


,


4


and


5


and faults


10


,


11


,


12


,


14


and


15


. For the sake of clarity, not all reflectors and faults have been referred to with a reference numeral.





FIGS. 2 and 3

show the original image treated according to the present invention. The structural tensor had been calculated as follows, at first for each point the partial derivatives u


xi


were filtered by convolution with a Gaussian kernel to obtain regularized partial derivatives u


r




xi


; then for each point a symmetric n×n structural precursor matrix S


0


was calculated, wherein the elements s


0




pq


equal u


r




xp


.u


r




xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on. To obtain the elements s


pq


of the n×n structural matrix S each of these data sets is filtered by convolution with a Gaussian kernel.




In order to get

FIG. 2

, three anisotropic diffusion steps were applied. The edges are made clearer whilst noise is reduced.





FIG. 3

shows a smoother picture, with less noise, obtained with the method according to the present invention after ten anisotropic diffusion steps.




In order to show the improvement obtained with the method according to the present invention, reference is made to

FIGS. 4-7

, which have been obtained with known methods.

FIG. 4

shows the image treated not according to the present invention with three anisotropic diffusion steps with no edge preservation, in which ε=1.





FIG. 5

shows the image treated not according to the present invention with ten anisotropic diffusion steps with no edge preservation, ε=1.





FIG. 6

shows the image treated not according to the invention with isotropic diffusion without edge preservation; and

FIG. 7

shows the image treated not according to the invention with isotropic diffusion with edge preservation according to Perona-Malik with λ=10.





FIG. 8

shows an image obtained from

FIG. 1

processed to highlight the faults. The method of processing the image comprised calculating for each point of the original image (

FIG. 1

) the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives u


xi


; filtering for each point the partial derivatives u


xi


by convolution with a suitable kernel to obtain regularized partial derivatives u


r




xi


; calculating for each point a symmetric n×n structural precursor matrix S


0


, wherein the elements s


0




pq


equal u


r




xp


.u


r




xq


; creating (½)n(n+1) data sets, wherein the elements of the first data set are s


0




11


pertaining to each point, the elements of the second data set are s


0




12


and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements s


pq


of the n×n structural matrix S. Then for each point ε=trace(S


0


S)/(trace(S


0


).trace(S)) was calculated, and the value of ε was attributed to each point to obtain

FIG. 8

in which faults are highlighted in black.



Claims
  • 1. A method of processing an image the steps comprising:(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3; (b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives uxi; (c) calculating for each point a symmetric n×n structural matrix S, wherein the elements spq equal uxp·uxq; (d) calculating for each point an n×n diffusion matrix D, wherein the elements dij are a function of the elements spq; (e) calculating for each point u(m+1) from u(m) using the following equation u(m+1)=u(m)+c.div(ε.Dgrad(u(m))), wherein c is a predetermined constant, 0≦c≦1, and wherein ε is a scalar, 0≦ε≦1, wherein ε is close to zero when near an edge and close to 1 when far away from an edge; and (f) repeating steps (b) through (e) M times to obtain the processed image.
  • 2. The method according to claim 1, wherein step (c) comprises calculating for each point a symmetric n×n structural precursor matrix S0, wherein the elements s0pq equal uxp·uxq; creating (½) n (n+1) data sets, wherein the elements of the first data set are s011 pertaining to each point, the elements of the second data set are s012 and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements spq of the n×n structural matrix S.
  • 3. The method according to claim 1, wherein step (c) comprises filtering for each point the parties derivatives uxi by convolution with a suitable kernel to obtain regularized partial derivatives urxi; calculating for each point a symmetric n×n structural precursor matrix S0, wherein the elements s0pq equal urxp·urxq; creating (½) n (n+1) data sets, wherein the elements of the first data set are s011 pertaining to each point, the elements of the second data set are S012 and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements spq of the n×n structural matrix S.
  • 4. The method according to claim 2, wherein ε=trace(S0S)/(trace(S0).trace(S)).
  • 5. The method according to claim 1, wherein step (d) comprises determining the n eigenvalues λi and n eigenvectors vi of each of the n×n structural matrices S; sorting the eigenvalues so that λ1≧λ2(≧λ3) and calculating for each point an n×n diffusion matrix D, wherein the elements dpq equal v2p·v2q (if n=2) or wherein the elements dpq equal v2p·v2q+v3p·v3q (if n=3).
  • 6. A method of processing an image the steps comprising:(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3; (b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives Uxi; (c) calculating for each point a symmetric n×n structural matrix S0, wherein the elements s0pq equal up·uq; creating (½)n(n+1) data sets, wherein the elements of the first data set are s011 pertaining to each point, the elements of the second data set are s012 and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements spq of the n×n structural matrix S; and (d) calculating for each point ε=trace(S0S)/(trace(S0)·trace(S)) and attributing the calculated value of ε to each point to obtain an image in which faults are highlighted.
  • 7. A method of processing an image the steps comprising:(a) obtaining an n-dimensional initial image data set, wherein each element u(m=0) of the data set is the initial image intensity of a point of the image, and wherein n=2 or n=3; (b) calculating for each point the partial derivatives of u(m) in n directions to obtain n derivative data sets of the partial derivatives uxi; (c) filtering for each point the partial derivatives uxi by convolution with a suitable kernel to obtain regularized partial derivatives urxi; calculating for each point a symmetric n×n structural precursor matrix S0, wherein the elements s0pq equal urxp·urxq; or creating (½)n(n+1) data sets, wherein the elements of the first data set are S011 pertaining to each point, the elements of the second data set are s012 and so on; and filtering each of these data sets by convolution with a suitable kernel to obtain the elements spq of the n×n structural matrix S; and (d) calculating for each point ε=trace(S0S)/(trace(S0)·trace(S)) and attributing the calculated value of ε to each point to obtain an image in which faults are highlighted.
Priority Claims (1)
Number Date Country Kind
00306780 Aug 2000 EP
PCT Information
Filing Document Filing Date Country Kind
PCT/EP01/09277 WO 00
Publishing Document Publishing Date Country Kind
WO02/13139 2/14/2002 WO A
US Referenced Citations (2)
Number Name Date Kind
6327537 Ikelle Dec 2001 B1
20020195246 Davidson Dec 2002 A1
Non-Patent Literature Citations (3)
Entry
J. Weickert, “Coherence-Enhancing Diffusion Filtering”, Image Sciences Institute, University Hospital Utrecht, The Netherlands, 1999 Kluwer Academic Publishers, pp. 111-127.
S. Guillon, et al, “Adaptive nonlinear filters for 2D and 3D image enhancement”, Signal Processing 67, 1998, pp. 237-254.
J Weickert ‘Anisotropic diffusion in image processing’ Jan. 1996, pp. 10, 41-44.