The present invention relates to the field of three-dimensional (3-D) image rendering, and more particularly to fast volume rendering using shear warp factorization.
Real-time rendering of 3-D images in volume visualization applications has become increasingly important. This is particularly useful in clinical applications for the display and analysis of volumetric data sets acquired by imaging methods such as Computed Tomography (CT), Magnetic Resonance Imaging (MRI) or Ultrasonic imaging. Benefits of volume visualization include the ability to obtain oblique views for the increased understanding of complex geometric structures within organs, and the ability to measure volumes, areas, and distances. Volume visualization also provides the ability to explore the spatial relationship between an organ and its surrounding structures or tissues. In general, generation of 3-D images includes the steps of data acquisition, volume reconstruction, and image visualization. Volume rendering is a technique that generates a two-dimensional (2-D) projection directly from the 3-D volume data without requiring any intermediate geometrical data structure.
Unfortunately, the application of volume rendering to medical imaging and scientific visualization is limited because it is computationally expensive to generate acceptable frame rates. In order for rendering to be effective it is important that it is interactive, that is a user can make certain requests of the image and expect a real-lime response. High quality images would take tens of seconds or even minutes to generate using typical workstation technology.
Various approaches have been tried in an attempt to improve the response time. One approach is to trade quality for speed. This approach is ineffective because many perceptual components of the image are obscured from the view of the user. A more costly approach is to rely on special-purpose hardware, which drastically reduces the flexibility of the system. Another approach relies on brute force and simply attempts to render an image by utilizing large multiprocessor computers to perform the rendering in parallel. These types of computers, however, are very expensive and require a large number of processors to achieve acceptable frame rates.
A further approach is to provide better, faster volume rendering algorithms. Several existing volume-rendering algorithms operate by sampling the 2-D slices of the 3-D volume data (also known as factorization), at a fixed resolution; shearing the sampled slices to form an intermediate but distorted image; and warping the intermediate image in 2D to form an undistorted final image. An example of such a technique is described in U.S. Pat. No. 5,787,889 titled “Ultrasound imaging with real-time 3d image reconstruction and visualization”.
The image visualization process derives 2D image projections of the 3D image. The stack of 2D images is known as the “stack space”. A shear warp factorization process is used to derive the new 2D projection for one or more video frames of the image. For each change in viewing angle, the processor factorizes the necessary viewing transformation matrix into a 3D shear, which is parallel to slices of the volume data. A projection of the shear forms a 2D intermediate image. A 2D warp is implemented to produce the final image, (that is, a 2D projection of the 3D volume at a desired viewing angle).
During the process of re-visualizing the volume at a different viewing angle, the reconstructed volume is sheared by transforming the reference coordinate system to an intermediate coordinate system. This simplifies mapping of the data. The intermediate coordinate system also is referred to as “sheared object space”. The sheared object space is selected so that all viewing rays are parallel to one of the axes of the original coordinate system for the volume (e.g., the reference coordinate system).
The slices 16 then are translated and resampled to achieve image projection rays 19 which are perpendicular to the sheared slices 18. The intermediate image projection plane is parallel to the slices of the volume. Since all the projection rays 19 are perpendicular to both the projection plane 14 and the slices 18, an imaging process for the projection causes the image data to be accessed in storage order. Because the shearing occurs only on two axes, a simple translation operation is used which does not use a lot of computation. The result of the shear factorization is a distorted image projection. Such distorted projection is not displayed. Before the volume is displayed, the projection undergoes a 2D geometric image warping operation to create a final 2D image projection of the volume.
b) illustrates perspective projection and is represented by the numeral 20. For a perspective transformation, the slices 16 are scaled in addition to being sheared to achieve sheared object space slices 24. The scaling produces an effect that allows an observer to perceive the volume with perspective. Such a method is best described in a paper titled “Fast Volume Rendering Using a Shear-Warp Factorization of the Viewing Transformation”, Technical Report CSL-TR-95-678, Departments of Electrical Engineering and Computer Science, Stanford University, September 1995.
However, the current implementations of shear warp factorization are limited in several aspects. First of all, the major axis is not unique for all the rays in the viewing frustum. As previously mentioned, the major axis is used for factorization. Therefore, since there are three coordinate axes, there are three possible major axes, and a scene may be rendered in as many as three different factorizations. Each rendering process produces an image patch and joining, or stitching, the patches together create the final scene.
It has been found that the stitching process is computationally not trivial and furthermore, some distortion is created along the border of the patches. The distortion occurs since the factorizations are only mathematical models and, therefore, the results may differ slightly between factorizations. Additionally, using two or more factorizations is expensive in terms of memory access and computation.
Furthermore, current implementations also do not allow the observer to view the image from a position within the data set, a position, which can provide valuable information to the observer.
It is an object of the present invention to obviate or mitigate at least some of the above mentioned disadvantages.
An advantage of the present invention is a method for generating a 2-D image with perspective using shear-warp factorization that uses one copy of the volume data.
A further advantage of the invention is the volume data may be accessed in storage order and which has the further advantage of accessing memory once for every slice.
In accordance with this invention there is provided a method for generating an 2-D projection directly from an 3-D volume data, the method comprising the steps of:
These and other embodiments of the invention will now be described by way of example only, with reference to the accompanying drawings in which:
a) is an illustration of shear warp factorization with parallel projection according to the prior art;
b) is an illustration of shear warp factorization with perspective projection according to the prior art;
a) and (b) are schematic diagram showing the coordinate systems used in an embodiment of the present invention;
a) and (b) is a schematic diagram of a cross-section of a scene to be rendered and its associated viewing frustum;
In the following description, like numerals refer to like structures in the drawings. Referring to
To reconstruct an image on the display in substantially realtime, in response to a user selected view of the dataset, the processing system performs a transformation by shear factorization To create a distorted image projection. Such distorted projection is not displayed. Before the volume is displayed, the projection undergoes a 2D geometric image warping operation to create a final 2D-image projection of the volume. Thus given a scene defined by a volume, a viewing position, a viewing direct ion and a viewing frustum, the method selects an axis to use in the factorization, by ensuring that it is the one with the biggest component in the viewing direction or major axis. This is achieved by resampling the volume slices with a finer grid along this major axis and then rendering the image as above.
This may be illustrated geometrically by referring to
Thus, data indicating the viewpoint in V in the 3D workspace includes coordinate data indicating the viewpoint's position. Data indicating the viewpoint in a 3D workspace may also include data indicating the viewpoint's “direction of orientation” in the workspace. The direction of orientation is the direction from the viewpoint into the field of view along the axis at the center of the field of view. Each viewpoint into a 3D workspace provides a view into the workspace that is delineated by a truncated pyramid structure called the viewing frustrum as shown in
As may be seen in
Referring to
The viewing direction D is determined by
In the present invention the major axis is selected by using the axis that has the largest component in the viewing direction. For example, the vector D in
x=2, y=1
Since the x component of D is greater than the y component, the x-axis is selected as the major axis.
Once the major axis is selected, a sample step size is calculated. The volume is resampled with a higher resolution along the major axis. The step size indicates the extent of the resampling. For example, a step size of six implies that the major axis will be sampled with a resolution increased by a factor of six.
A shear warp transformation is applied to the volume in stack space, that is the stack of sliced 2-D images. The shear warp transformation transforms the image to one that can be displayed. The matrices used in the transformation, Mshear and Mwarp, are defined in accordance with the paper “Fast Volume rendering of a Shear Warp Factorization of the Viewing Transformation” by Philippe Lacroute and Marc Levoy, and the major direction is determined as described above. Thus, referring to
In some instances all the viewing rays in the viewing frustum are not guaranteed to have the same major axis and therefore it may not be possible to use only one factorization. Referring to
However, the situation appears quite different in object space. From Lacroute et. Al. above the general equation for a 2D-shear matrix Mshear is given by:
where s is the ratio of the component of the vector in the viewing direction that is not along the major axis to the component that is along the major axis. Therefore s=−0.2 and the shear matrix is:
The vectors in shear space are:
D′=MshearD=(0,1)
r′0=Mshearr0=(1.04, 0.2)
r′1=Mshearr1=(−0.96, 0.2)
The sheared image is shown in
However, if the volume is resampled with a higher resolution along the major axis it is guaranteed that, under certain conditions, all the rays in the viewing frustum will have the same major axis. Therefore it is desirable to resample the image along the y-axis with resampling step size r. The resampled volume Y′ is related to the original volume Y by:
As shown schematically in
O=Mview′Y′ (1)
and
O=MviewY=MviewR−1RY=MviewR−1Y′ (2)
By comparing equation 1 with equation 2 it can be determined that:
It is necessary to calculate the viewer position in stack space as:
since |M′view|=|MviewR−1|=|Mview∥R−1|. Also
Following the same rule e′o,z and e′o,w are:
If the viewer is located outside the volume, vectors are constructed from the viewer position to each one of the corners of the volume. These vectors represent the boundary of the viewing frustum and all the rays are included in it. If points p′i for i=0 . . . 6 are the corners of a volume in Y′ then the major direction for each vector is defined as:
c=max(|p′i,x−e′o,x|,|p′l,y−e′o,y|,|p′l,z−e′o,z|)=max(|pi,x−eo,x|,r|pi,y−eo,y|,|pi,z−eo,z|) (3)
From equation 3 it can be determined that as long as
|pl,y−eo,y|≠0∀i (4)
there exists an integer r that, when used as the sample step size, ensures all rays in the viewing frustum have the same major axis. Since all the rays in the frustum have the same major axis, they are all rendered with the same factorization. Therefore, the image displayed does not have the visual defects that may arise if the image is rendered with multiple factorizations and then patched together. The image is also rendered faster than if multiple factorizations are used.
Referring once again to the 2D scene in
The vectors in shear space are:
D′=MshearD=(0,6);
r′0=Mshearr0=(1.004, 1.2);
r′1=Mshearr1=(−0.996, 1.2).
The sheared image is shown in
If the position of the viewer is located within the volume, a different procedure is used to determine the value for r. In this case it is necessary to form a ray to each of the voxels in the viewing frustum. If vi′ is a voxel in the viewing frustum then the vector from the observer to this voxel is v′i−e′o. The major direction is determined by:
c=max(|v′i,x−e′o,x|,|v′l,y−e′o,y|,|v′l,z−e′o,z|)=max(|vi,x−eo,x|,r|vi,y−eo,y|,|vi,z−eo,z|) (5)
In this situation, however, there is no guarantee that there can be a value for r such that
|vi,y−eo,y|≠0∀i (6)
In fact, if the viewing angle is wide enough, it may be required to trace rays parallel to all three axes. This results in at least one ray with a zero co-ordinate for each axis and therefore it is not possible to use the same factorization. Therefore, the limit that this imposes is that the viewing angle must be less than a 90° solid angle.
It is important to note that although the case for resampling along the y-axis has been explained, it can be shown in a very similar manner for all the other axes.
In the case in which the observer is outside the stack, one axis that satisfies equation (4) can always be found.
In a second embodiment, it is possible to improve the performance of the algorithm. The sample step size r is calculated in the same manner as it was in the previous embodiment. Although, resampling the image improves the performance of the algorithm there is still an overhead associated with it. Therefore, if the amount of resampling to be done is minimized a further performance enhancement can be realized. As it can be seen in
An important aspect of this method is the fact that the addition of a resampling step does not change the warp matrix. As is illustrated schematically in
If Mview and M′view, are two matrices with different resampling steps and the resampling occurs in the x direction:
The warp matrix is really a 2-D matrix since it is applied to the baseline image in shear space in which the slices have been composed. The first row of this matrix can be compressed because the x-axis is used in the factorization:
and M′warp,2D=Mwarp,2D. This property allows the use of different sample step sizes in shear space along the major axis.
Since the warp matrix to be used is the same regardless of the value of r, and all the major axes are the same, there is still only one factorization and the image will not have to be patched together. Also, as previously mentioned, the speed of the algorithm is a further improvement to the previous embodiment.
As in the previous embodiment, it is important to note that although the case for resampling along the x-axis has been explained, it can be shown in a very similar manner for all the other axes.
Also, the examples given for all embodiments have related to 2D scenes for simplicity only. In reality, the scenes that are rendered are 3D and the methods described herein are simply extended to the 3D application.
Although the invention has been described with reference to certain specific embodiments, various modifications thereof will be apparent to those skilled in the art without departing from the spirit and scope of the invention as outlined in the claims appended hereto.
Number | Date | Country | Kind |
---|---|---|---|
2286447 | Oct 1999 | CA | national |
This is a continuation of U.S. patent application Ser. No. 10/122,148 filed Apr. 15, 2002 now abandoned which is a continuation of PCT/CA00/01184 filed Oct. 13, 2000 which claims priority from Canadian Patent Application No. 2,286,447, filed Oct. 15, 1999.
Number | Name | Date | Kind |
---|---|---|---|
5787889 | Edwards et al. | Aug 1998 | A |
5803082 | Stapleton et al. | Sep 1998 | A |
5956418 | Aiger et al. | Sep 1999 | A |
6002738 | Cabral et al. | Dec 1999 | A |
6167297 | Benaron | Dec 2000 | A |
6330356 | Sundareswaran et al. | Dec 2001 | B1 |
6553152 | Miller et al. | Apr 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20040170311 A1 | Sep 2004 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10122148 | Apr 2002 | US |
Child | 10792126 | US | |
Parent | PCT/CA00/01184 | Oct 2000 | US |
Child | 10122148 | US |