MRI Analysis Suite

After taking a course in biomedical signal and image processing, I took a strong interest in MRI and CT analysis techniques. As part of independent research, I have taken on an interesting project: designing an entire MRI analysis suite. Most of the project is done in MATLAB, but as development continues, I may consider rewriting it in another language so that I can distribute the binary for anyone to use.

So far, this program imports a MAYO 7.5 HDR file, and allows for several common image processing operations to be applied to it, including:

  • Filtering (eg: blurring, median, mode, mean, sharpening)
  • 3D edge detection via a 3D Sobel algorithm
  • 3d flood fill operations (this was an undertaking on its own; basic stack-based and recursion-based algorithms take minutes, even hours, on large MRI data sets; I successfully designed a fast, queue-based, algorithm that is essentially a 3D extension of the classic scanline flood fill algorithm)
  • Segmentation (via a Fuzzy C-means algorithm I designed)
  • Gamma correction
  • Noise removal (salt & pepper, Gaussian noise)
  • Statistical analysis (ie: calculating the volumes of cerebrospinal fluid, white matter, gray matter, and extracranial voxels in MRI data)

What really made this project intesting is the specialized features I’ve added. The most recent one detects the ventricles of the brain via a statistical method and an arbitrary shape detection algorithm, providing two ways to ensure accurate results. It can separate them from the rest of the brain, along with other major portions of the brain.

To make things even more interesting, the primary axis of any portion of the brain can be generated and displayed as a 3D vector. This is from a PCA algorithm I designed to allow for the brain to be oriented in RPI format.

I will continue developing and optimizing this collection of MRI analysis tools. I amy even release the source for them in the coming months too.

Some samples of the program in action are shown below.

Brain + Ventricles + PCA 3

Red - Brain Tissue; Blue/Green - Ventricles; Black - PCA/Primary-Axis Vectors

The brain (translucent, red) with the ventricles of the brain in blue.

The brain (translucent, red) with the ventricles of the brain in blue.

Ventricles and Primary Axis Vectors

Ventricles and Primary Axis Vectors

Breast Cancer Screening System via EIT

Not even two months before I completed my work designing an interface for the impedance analyzer used at the SFU Microinstrumentation Laboratory, I jumped on board with a project involving SFU and BC Cancer Agency, utilizing an impedance analysis system as a possible cancer screenin system. Taking the impedance analyzer, a small netbook, my existing interface system, and additional tools we developed, we have…

System Overview Diagram

System Overview Diagram

actual system

Actual System

With this system, we used breast phantoms composed of gelatin and saline solution, along with an electrode array with a stationary electrode placed in the center of the phantom, and multiple selectable electrodes along the circumference of the phantom, as outlined below.

limited_scan_electrodes

Inital Electrode Placements

Using this electrode array, we could generate Cole-Cole plots between electrode ‘A’ and the remaining electrodes. In the case where a small amount of lipid, calcium, and salt was placed between two electrodes (to mimic a potential breast tumor), we were able to consistenly generate Cole-Cole plots with different parameters compared to samples that had no such anomaly injected. These changes were most prounounced at lower frequencies between five to six kiloHertz (kHz).

Cole-Cole Plot

Cole-Cole Plot

One downfall to the existing system was that the electrode placement at the time only allowed for detection of foreign substances in the breast phantom that were close to the surface, indicated by the orange regions in the “Initial Electrode Placements” diagram above. We could generate basic impedance maps that show a general region where the lipid/calcium deposit was injected, but not with enough accuracy.

Simple Impedance Map (Upper Left) and Interpolated Impedance Map (Lower Right)

Simple Impedance Map (Upper Left) and Interpolated Impedance Map (Lower Right)

We changed our electrode placement to that shown below.

new electrode placement

new electrode placement

Combined with a more sophisticated  EIT image reconstruction software we designed over the course of several months (please refer to “Publications” section), we were able to generate 2D impedance maps of the breast phantom, indicating the location of the injected lipid/calcium deposit. Although the error bounds for the size of the anomaly injected into the phantom are large, the centroid is located with a reasonable degree of accurary.

2D Image Reconstructed from our EIT Software

2D Image Reconstructed from our EIT Software

We are now at the point where we are preparing to improve on this system, possibly allowing for us to extend our image reconstruction system to provide a fully 3D impedance map, indicating the precise location of the injected lipid/calcium deposit. This may demonstrate the viability of impedance analysis as a non-invasive, low-cost, and rapid means to screen for breast cancer in its early stages.

3D Extrapolation from 2D Image

3D Extrapolation from 2D Image