Image Processing Techniques for X-ray data

This page contains information and tutorials about Flat-field image correction and Particle Image Velocimetry (PIV), which are tools used to process images from x-ray data produced using full field imaging.

What you will need:

To follow or run the tutorials below, you will need to install Python and Jupyter Notebooks. We recommend a distribution of python contained within the Anaconda package manager. For detailed help, see our HowToInstallPython page.

Common Terms and Definitions

  • Spectroscopy: the branch of science concerned with the investigation and measurement of spectra produced when matter interacts with or emits electromagnetic radiation (source: Oxford Languages)
  • Radiography : the process of using some form of radiation other than visible light to produce an image, typically using x-rays or gamma rays (source: Merriam-Webster)
  • Phase-Contrast Imaging : a contrast-enhancing optical technique utilized to produce high-contrast images (source: miscroscopyu.com)
  • HDF5 : a "Hierarchical Data Format version 5" file type. These types of files are widely used in the scientific community to store lots of data and uses a "file directory"-like structure, making it easy to organize (source: neoscience.org)

Flat-field Image Correction

What is Flat-field image correction?

Flat-field image correction refers to the elimination of image contrast due to variations in the incident beam intensity in different regions of the image. This section provides an overview of the steps involved, as well as a step-by-step tutorial contained in a Jupyter notebook.

In the tutorial, raw images that look like this:

Flatfield uncorrected.png

are corrected to look like this:

Flatfield corrected.png

In order to run the tutorial:

  1. Make sure you have a working version of Python & Jupyter (see HowToInstallPython)
  2. Download the "Flatfield_tutorial" zipped folder (at the bottom of the page) and place files such that they can be accessed by the notebook
    1. ***Note: file structure must be the same as the image in the link below for the tutorial to work
  3. If you installed Anaconda, make sure you install the "imageio_ffmpeg" package in addition to the other packages specified within the Anaconda Prompt (found in your system apps).
FileStructure.png

imageio_ffmpeg.PNG

Overview of steps in the tutorial:

Coarse:

Flat-field correction comprises 4 steps: loading the data, processing a single image and finding appropriate crop dimensions, correcting the remaining images, and compiling an mp4 video.
Fine:
  1. Start by analyzing a single image. Load the hdf5 x-ray data and locate the image infomation within the hdf5 file using "h5py.file" command and finding the ("data") header
  2. Once image data is located in the hdf5 file, assign a variable to the path to the image data
  3. Use the image data from the location specified to plot the raw uncorrected image
  4. Crop the data to remove unused areas of the image, and save the crop dimensions in a variable to use for all other image frames
  5. Conduct a flatfield correction using the "flatfield_correction()" function. Now the flatfield correction has been done for a single image. The next step in this procces will be to repeat this procedure for the rest of the images as a batch.
  6. Load the rest of the images to be used in the video using the same file path as before, but on the "darks" and "whites" files
  7. Crop the data using the same dimensions as before
  8. Use the "flatfield_correction" function to normalize the picture
  9. Install necessary imageio pip package to compile the mp4
  10. Compile the mp4

Particle Image Velocimetry

What is Particle Image Velocimetry?

Particle Image Velocimetry (PIV) is a method of visualizing flows from radiographs by creating a vector field. It can be used to produce instantaneous velocity measurements within a flow, given there are particles in the fluid that can be used to measure displacement. By knowing the displacement of the particles between frames in combination with the time between each frame, velocity vectors can be calculated for each particle (velocity = displacement รท time). This can be helpful in determining potential causes of clogs in a pipe, for example: while 3D printing.

This section provides an overview of the steps involved, as well as a step-by-step tutorial contained in a Jupyter notebook.

Using PIV, we can create velocity fields for flows such as the one below:

PIV velocityfield.PNG

In order to run the tutorial:

  1. Make sure you have a working version of Python & Jupyter (see HowToInstallPython)
  2. Download the "PIV_tutorial" zipped folder (at the bottom of the page) and load into Jupyter Notebooks
  3. This tutorial requires images that have already been flat-field corrected. It will be helpful to run the tutorial above if you do not already have data of your own.

Overview of steps in the tutorial:

Coarse:

Particle image velocimetry comprises 4 steps: loading the data, mapping the "mask" image, measuring the displacement of particles between frames, and creating a velocity field.
Fine:
  1. Start by creating a "mask" image that outlines the area to be analyzed. This step can be done by drawing an overlay of the first image to be used, using Microsoft Paint
  2. Upload the data, and organize your files in the same fashion as described in the tutorial
  3. Map points on the "mask" image
  4. Analyze the change in position of particles in a small region of two test images to give an initial "guess" value for displacement rates
  5. Analyze the change in position between two full images, and produce the velocity field (knowing the time between frames)

-- JohnLee - 25 Jun 2020

Topic attachments
I Attachment Action Size Date Who Comment
Flatfield_tutorial.zipzip Flatfield_tutorial.zip manage 924 MB 07 Jul 2020 - 12:47 UnknownUser  
PIV_tutorial.zipzip PIV_tutorial.zip manage 239 MB 06 Aug 2020 - 23:55 UnknownUser  
This topic: CHESS/FMB > WebHome > FullField > ImageProcessingTechniques
Topic revision: 06 Aug 2020, jel355
This site is powered by FoswikiCopyright © by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding CLASSE Wiki? Send feedback