The subject matter disclosed herein relates generally to diagnostic ultrasound systems, and more particularly, to a method and system for displaying on a three-dimensional (3D) ultrasound image an intersection with a surface.
When displaying two-dimensional (2D) renderings of 3D volume data, such as in a 3D ultrasound dataset, it may be desirable to visualize one or more surfaces together with the volume data in a manner to allow a visual determination of where the surfaces intersect the volume. For example, it may be desirable to visualize intersections between volume data and planes, intersections between volume data and spheres and other quadric surfaces. In 3D cardiac ultrasound, where it is common to display one or more 2D slice planes reconstructed from a 3D ultrasound data volume, it is important to be able to determine from the displayed information how the 2D slice planes are positioned with respect to the volume rendering to identify the relationship between the two visualization techniques.
Conventional techniques for associating the slice planes with the intersection with the data volume include rendering the plane as a rectangle in space together with the volume. However, with this rectangular plane representation, it can be difficult for the observer to understand precisely where the plane intersects the volume data, which can lead to difficulty in subsequent analysis, such as properly locating smaller anomalies, for example, in the heart valves. Other conventional techniques include displaying an opaque or semi-transparent polygon plane. However, this technique, in addition to the problems described above, also may hide or obscure portions of the volume.
Thus, conventional techniques for identifying the location of a slice plane in an image volume rely on the observer's ability to mentally reconstruct the spatial orientation of the plane based on the shape of the displayed rectangle or plane.
In one embodiment, a method for rendering an ultrasound volume for display is provided. The method includes accessing ultrasound information corresponding to a volume dataset and identifying a location of one or more surfaces intersecting the volume dataset. The method further includes colorizing a rendered image of the volume dataset based on the identified locations of the intersection of the one or more surfaces and displaying a rendered volume dataset with one or more colorized intersections.
In another embodiment, an ultrasound display is provided that includes an image slice display portion displaying one or more two-dimensional (2D) ultrasound image slices. The ultrasound display further includes a volume rendering display portion displaying a rendered three-dimensional (3D) ultrasound image volume having modified visible pixels corresponding to voxels associated with slice planes identified along a surface of the rendered 3D ultrasound image volume. The slice planes correspond to the location of the 2D ultrasound images slices within the 3D ultrasound image volume.
In a further embodiment, an ultrasound system is provided that includes an ultrasound probe configured to acquire a three-dimensional (3D) ultrasound dataset and a signal processor having a surface colorizing module configured to colorize a rendered image of the 3D ultrasound dataset based on identified locations of an intersection of one or more surfaces with the 3D ultrasound dataset. The ultrasound system further includes a display for displaying a rendered volume dataset with one or more colorized intersections.
The foregoing summary, as well as the following detailed description of certain embodiments of the present invention, will be better understood when read in conjunction with the appended drawings. The figures illustrate diagrams of the functional blocks of various embodiments. The functional blocks are not necessarily indicative of the division between hardware circuitry. Thus, for example, one or more of the functional blocks (e.g., processors or memories) may be implemented in a single piece of hardware (e.g., a general purpose signal processor or a block or random access memory, hard disk, or the like) or multiple pieces of hardware. Similarly, the programs may be stand alone programs, may be incorporated as subroutines in an operating system, may be functions in an installed imaging software package, and the like. It should be understood that the various embodiments are not limited to the arrangements and instrumentality shown in the drawings.
Accordingly, by colorizing only the visible voxels, the result is a colored intersection curve (e.g., colored line or trace) that appears to be on the surface of the rendered 3D volume dataset 110. Additionally, one or more 2D images 122 corresponding to the one or more slice planes 116 also may be displayed on the display 108. In operation, the colorized intersections may be used, for example, in 3D echocardiography to visualize where a reconstructed 2D ultrasound slice image is positioned in the 3D volume.
At least one technical effect of the various embodiments is providing a visualization of the intersection of a surface with a rendered 3D ultrasound volume. The visualization may be any type of colorizing that is along the surface of the 3D ultrasound volume.
Various embodiments provide a method 200 as shown in the flowchart of
The method 200 includes acquiring at 202 ultrasound information of a region of interest (ROI), such as for example the ROI 104 (shown in
At 204, one or more surfaces are identified that intersect the rendered 3D volume. For example, based on one or more user selected or marked planes, which may be selected image views, a determination is made as to the coordinates of the plane(s) through the 3D volume dataset corresponding to the location in the rendered 3D volume. For example, the operator may manually move or position virtual slices on the screen to selected different views to display. The selection of the one or more slices and the determination of the location of each may be performed using any suitable process or user interface. Thus, in various embodiments, the voxels within the 3D volume dataset corresponding to the user selected plane(s) are determined. The planes may also be located at fixed pre-determined positions relative to the data volume or ultrasound probe. For example, two orthogonal slice planes corresponding to the azimuth and elevation planes of the acquired ultrasound ROI may be positioned such that the planes intersect the center of the data volume. As another example, three slice planes may be rotated about a common axis (such as the probe axis) where the planes are default oriented to provide visualization of a four chamber view, a two chamber view, and a long axis view of the left ventricle of the heart. In these examples, a volume rendering shows the volume data along with the slice intersection curves. The user may or may not modify the position and orientation of these planes.
Thereafter, at 206 the rendered image, for example, the rendered 3D ultrasound volume is colorized based on the identified intersection of the surfaces with the 3D ultrasound volume dataset, which is then displayed with colorized intersection curves at 208. In particular, a parameter of the visible pixels corresponding to the identified voxels is changed such that in various embodiment the selected plane(s) are visible along the surface of the rendered 3D volume, for example, as a curve on the displayed image volume. Any parameter may be changed to identify or highlight the intersection along the surface. For example, the color, transparency, intensity and/or value of the pixels corresponding to the identified intersection voxels may be changed.
In various embodiments, one or more rendering techniques are used for changing a parameter of the pixels in a volume rendering according to where the one or more surfaces intersect the rendered ultrasound data. It should be noted that although the parameter may be described as color, any parameter may be changed or adjusted.
The various embodiments, including the method 200 or the rendering technique 300 described below may be implemented in software, hardware or a combination thereof. For example, the various embodiments for displaying the intersections may be provide on any tangible non-transitory computer readable medium and operate on any suitable computer or processing machine. For example, although the various embodiments may be described in connection with an ultrasound imaging system, the various embodiments may be implemented, on a workstation that does not have ultrasound scanning capabilities. As another example, the various embodiments may be implemented on a system (e.g., an ultrasound system), having a server application that processes data in the background and that can be retrieved or accessed later for display on a client machine. In one embodiment, data is received from an ultrasound scanner and the raw data is converted to rendered Digital Imaging and Communications in Medicine (DICOM) images and stored on a Picture Archiving and Communication System (PACS) device. A user may then retrieve the DICOM images from the device later without use of the various embodiments at that time.
In one embodiment, a rendering technique 300 as shown in
In particular, as shown in
ax+by+cz+d=0 Equation 1
The signed plane-to-sample distance between the plane 404 and the sample si can be computed from the coordinate ci, and the plane equation is then defined as follows:
Thus, the value V(xi,yi,zi) of each sample (voxel 402) si is then set in one embodiment based on or according to the distance D between the plane 404 (or other surface) and the sample. For example, every sample having a distance of less than 2 millimeters to the plane 404 can be set to a color, such as red. In some embodiments, the original color of the sample can be modulated using a color transfer function given as M(V(xi,yi,zi), D(xi,yi,zi,p)), which changes the color of the sample depending on the plane-to-sample distance.
Thereafter modified voxels are provided as the input to a volume rendering process 304, which may be any suitable volume rendering process. For example, the input data to the rendering algorithm can be modified by the following (that takes into account multiple planes):
Thus, these modified sample values may be provided to any suitable volume rendering algorithm, with the pixels that represent visible voxels closest to the plane colored accordingly. For example, a rendered 3D volume with colorized pixels may be displayed at 306, such as illustrated in
In particular,
In another embodiment, a rendering technique 600 as shown in
The rendering algorithm operates by casting rays from a view plane through the data volume, and the volume is sampled at regular intervals along the ray. The rendering is computed as follows:
Thereafter, the output values are mapped to a color using a color transfer function C, and then displayed on a screen at 604 as a rendered 3D volume with colored pixels, such as illustrated in
In various embodiments, another step is added to the algorithm above where the plane distance is accumulated similarly for the regular sample values as follows:
In this embodiment, F is the transfer function that specifies how fast the color fades away from the plane, such as F(x)=(1−x)3. The color function C has two inputs, namely the render value, and the distance value, and modifies the color depending on the distance value. Thus, in the modified rendering algorithm of this embodiment, the distance values are accumulated the same way as the rendering values, while taking the opacity into account.
In another embodiment, a rendering technique 700 as shown in
Specifically, in this embodiment, the rendering depth buffer from the rendering algorithm is used for colorization of the rendered image I of volume V after the volume rendering has been performed. The depth buffer (B) 704 is a 2D matrix, or image, wherein the value of each pixel is the depth of each corresponding pixel in the rendered image I. Accordingly, given the coordinates (x,y) of the pixels in I, the depth z of the corresponding pixel is computed from B. The coordinates are then used to calculate the position (x,y,z) of the corresponding sample s in the volume V, such that the sample's distance to the plane is computed to allow for colorization of the rendered image. The depth buffer may be subject to pre-processing steps such as spatial smoothing before computing the sample positions.
In one embodiment, the process or algorithm may be implemented according to the following pseudo-code:
It should be noted that M is a function that modifies the color of the rendered image I based on or according to the distance between the corresponding sample-to-plane distance D and the original value of the rendered image color I(x,y).
It also should be noted that in various embodiments the colorization of the volume rendering may be performed in different ways. For example, a single color may be used to colorize the rendered image according to where the plane intersects the volume rendering. As another example, the color may fade away from the line depending on the distance between the corresponding voxel and the plane. Additionally, the color also may be blended with the original color of the volume rendering to provide a semi-transparent appearance for the line.
Thus, in various embodiments, the color transfer function, which may be of the form M(V(xi,yi,zi), d), and which is a function of the value V(xi,yi,zi) of the volume sample s, and the distance d between the plane and the sample, or of the form M(I(x,y), d), which is a function of the value I(x,y) of a rendered image, are used to achieve the colorized rendering that may be modified to provide a desired or required display output.
It should be noted that the color transfer function depends on the representation of the sample color, and is application specific in some embodiments. For example, M may just modulate the red channel depending on the plane-to-sample distance, to modify the sample color. In various embodiments, M is a function of D in all color channels, for example, as illustrated in the transfer functions shown in
It further should be noted that the color transfer function may also be different for each surface, such as each intersecting plane, such that each plane is colorized in different colors. For example, as illustrated in exemplary display 910 and 912 in
Thus, various embodiments may provide 3D visualization and navigation having a simplified means to determine the connection or relationship between reconstructed 2D image slices and the corresponding 3D volume rendering.
The various embodiments described herein may be implemented in connection with the imaging system shown in
The ultrasound system 1000 also includes a signal processor, such as the signal processor 106 that includes the surface colorizing module 112. The signal processor 106 processes the acquired ultrasound information (i.e., RF signal data or IQ data pairs) and prepares frames of ultrasound information for display on a display 1022. The signal processor 106 is adapted to perform one or more processing operations according to a plurality of selectable ultrasound modalities on the acquired ultrasound information. Moreover, the surface colorizing module 112 is configured to perform the various measurement embodiments described herein. Acquired ultrasound information may be processed in real-time during a scanning session as the echo signals are received. Additionally or alternatively, the ultrasound information may be stored temporarily in the RF/IQ buffer 1014 during a scanning session and processed in less than real-time in a live or off-line operation. A user interface, such as user interface 1024, allows an operator to enter data, enter and change scanning parameters, access protocols, select image slices, and the like. The user interface 1024 may be a rotating knob, switch, keyboard keys, mouse, touch screen, light pen, or any other suitable interface device. The user interface 1024 also enables the operator to reposition or translate the slice planes used to perform measurements as described above.
The ultrasound system 1000 may continuously acquire ultrasound information at a frame rate that exceeds 50 frames per second—the approximate perception rate of the human eye. The acquired ultrasound information, which may be the 3D volume dataset, is displayed on the display 1022. The ultrasound information may be displayed as B-mode images, M-mode, volumes of data (3D), volumes of data over time (4D), or other desired representation. An image buffer (e.g., memory) 1020 is included for storing processed frames of acquired ultrasound information that are not scheduled to be displayed immediately. Preferably, the image buffer 1020 is of sufficient capacity to store at least several seconds worth of frames of ultrasound information. The frames of ultrasound information are stored in a manner to facilitate retrieval thereof according to its order or time of acquisition. The image buffer 1020 may comprise any known data storage medium.
The operations of the sub-modules illustrated in
Each of sub-modules 1252-1264 are configured to process the I,Q data pairs in a corresponding manner to generate color-flow data 1272, power Doppler data 1274, B-mode data 1276, spectral Doppler data 1278, M-mode data 1280, ARFI data 1282, and tissue Doppler data 1284, all of which may be stored in a memory 1290 (or memory 1014 or memory 1020 shown in
The data 1272-1284 may be stored, for example, as sets of vector data values, where each set defines an individual ultrasound image frame. The vector data values are generally organized based on the polar coordinate system.
A scan converter sub-module 1292 accesses and obtains from the memory 1290 the vector data values associated with an image frame and converts the set of vector data values to Cartesian coordinates to generate an ultrasound image frame 1295 formatted for display. The ultrasound image frames 1295 generated by the scan converter module 1292 may be provided back to the memory 190 for subsequent processing or may be provided to the memory 1014 or the memory 1020.
Once the scan converter sub-module 1292 generates the ultrasound image frames 1295 associated with, for example, B-mode image data, and the like, the image frames may be restored in the memory 1290 or communicated over a bus 1296 to a database (not shown), the memory 1014, the memory 1020 and/or to other processors.
The scan converted data may be converted into an X,Y format for video display to produce ultrasound image frames. The scan converted ultrasound image frames are provided to a display controller (not shown) that may include a video processor that maps the video to a grey-scale mapping for video display. The grey-scale map may represent a transfer function of the raw image data to displayed grey levels. Once the video data is mapped to the grey-scale values, the display controller controls the display 1022 (shown in
Referring again to
A 3D processor sub-module 1300 is also controlled by the user interface 1224 and accesses the memory 1290 to obtain 3D ultrasound image data and to generate three dimensional images, such as through volume rendering or surface rendering algorithms as are known. The three dimensional images may be generated utilizing various imaging techniques, such as ray-casting, maximum intensity pixel projection and the like.
The ultrasound system 1000 of
The ultrasonic data may be sent to an external device 1318 via a wired or wireless network 1320 (or direct connection, for example, via a serial or parallel cable or USB port). In some embodiments, the external device 1318 may be a computer or a workstation having a display, or the DVR of the various embodiments. Alternatively, the external device 1318 may be a separate external display or a printer capable of receiving image data from the hand carried ultrasound system 1310 and of displaying or printing images that may have greater resolution than the integrated display 1316.
Multi-function controls 1384 may each be assigned functions in accordance with the mode of system operation (e.g., displaying different views). Therefore, each of the multi-function controls 384 may be configured to provide a plurality of different actions. Label display areas 1386 associated with the multi-function controls 1384 may be included as necessary on the display 1352. The system 1350 may also have additional keys and/or controls 388 for special purpose functions, which may include, but are not limited to “freeze,” “depth control,” “gain control,” “color-mode,” “print,” and “store.”
One or more of the label display areas 1386 may include labels 1392 to indicate the view being displayed or allow a user to select a different view of the imaged object to display. The selection of different views also may be provided through the associated multi-function control 1384. The display 1352 may also have a textual display area 1394 for displaying information relating to the displayed image view (e.g., a label associated with the displayed image).
It should be noted that the various embodiments may be implemented in connection with miniaturized or small-sized ultrasound systems having different dimensions, weights, and power consumption. For example, the pocket-sized ultrasound imaging system 1350 and the miniaturized ultrasound system 1310 may provide the same scanning and processing functionality as the system 1000 (shown in
The user interface 1406 also includes control buttons 1408 that may be used to control the portable ultrasound imaging system 1400 as desired or needed, and/or as typically provided. The user interface 1406 provides multiple interface options that the user may physically manipulate to interact with ultrasound data and other data that may be displayed, as well as to input information and set and change scanning parameters and viewing angles, etc. For example, a keyboard 1410, trackball 1412 and/or multi-function controls 1414 may be provided.
Exemplary embodiments of an ultrasound system are described above in detail. The ultrasound system components illustrated are not limited to the specific embodiments described herein, but rather, components of each ultrasound system may be utilized independently and separately from other components described herein. For example, the ultrasound system components described above may also be used in combination with other imaging systems.
It should be noted that the various embodiments may be implemented in hardware, software or a combination thereof. The various embodiments and/or components, for example, the modules, or components and controllers therein, also may be implemented as part of one or more computers or processors. The computer or processor may include a computing device, an input device, a display unit and an interface, for example, for accessing the Internet. The computer or processor may include a microprocessor. The microprocessor may be connected to a communication bus. The computer or processor may also include a memory. The memory may include Random Access Memory (RAM) and Read Only Memory (ROM). The computer or processor further may include a storage device, which may be a hard disk drive or a removable storage drive such as a floppy disk drive, optical disk drive, solid state disk drive (e.g., flash drive of flash RAM) and the like. The storage device may also be other similar means for loading computer programs or other instructions into the computer or processor.
As used herein, the term “computer” or “module” may include any processor-based or microprocessor-based system including systems using microcontrollers, reduced instruction set computers (RISC), application specific integrated circuits (ASICs), logic circuits, and any other circuit or processor capable of executing the functions described herein. The above examples are exemplary only, and are thus not intended to limit in any way the definition and/or meaning of the term “computer”.
The computer or processor executes a set of instructions that are stored in one or more storage elements, in order to process input data. The storage elements may also store data or other information as desired or needed. The storage element may be in the form of an information source or a physical memory element within a processing machine.
The set of instructions may include various commands that instruct the computer or processor as a processing machine to perform specific operations such as the methods and processes of the various embodiments of the invention. The set of instructions may be in the form of a software program. The software may be in various forms such as system software or application software. Further, the software may be in the form of a collection of separate programs, a program module within a larger program or a portion of a program module. The software also may include modular programming in the form of object-oriented programming. The processing of input data by the processing machine may be in response to user commands, or in response to results of previous processing, or in response to a request made by another processing machine.
As used herein, the terms “software” and “firmware” are interchangeable, and include any computer program stored in memory for execution by a computer, including RAM memory, ROM memory, EPROM memory, EEPROM memory, and non-volatile RAM (NVRAM) memory. The above memory types are exemplary only, and are thus not limiting as to the types of memory usable for storage of a computer program.
It is to be understood that the above description is intended to be illustrative, and not restrictive. For example, the above-described embodiments (and/or aspects thereof) may be used in combination with each other. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from its scope. While the dimensions and types of materials described herein are intended to define the parameters of the invention, they are by no means limiting and are exemplary embodiments. Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. The scope of the invention should, therefore, be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein.” Moreover, in the following claims, the terms “first,” “second,” and “third,” etc. are used merely as labels, and are not intended to impose numerical requirements on their objects. Further, the limitations of the following claims are not written in means-plus-function format and are not intended to be interpreted based on 35 U.S.C. §112, sixth paragraph, unless and until such claim limitations expressly use the phrase “means for” followed by a statement of function void of further structure.
This written description uses examples to disclose the various embodiments, including the best mode, and also to enable any person skilled in the art to practice the various embodiments, including making and using any devices or systems and performing any incorporated methods. The patentable scope of the various embodiments is defined by the claims, and may include other examples that occur to those skilled in the art. Such other examples are intended to be within the scope of the claims if the examples have structural elements that do not differ from the literal language of the claims, or if the examples include equivalent structural elements with insubstantial differences from the literal languages of the claims.