MRiLab v1.0a User Guide
MRiLab v1.0a User Guide
0a User Guide
Fang Liu (leoliuf@gmail.com) July 20, 2013
ii
Contents
1 Introduction 1.1 What is MRiLab . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.2 Obtaining MRiLab . . . . . . . . . . . . . . . . . . . . . . . . . . 1.3 Installing and Running MRiLab . . . . . . . . . . . . . . . . . . . 2 Platform Overview 2.1 MRiLab Simulation Platform . . . . . . . . . . . . . . . . . . . . 2.2 Simulation Workow . . . . . . . . . . . . . . . . . . . . . . . . . 2.3 Gradient Echo: Starting A Simple Scan . . . . . . . . . . . . . . 3 Simulation Settings 3.1 Loading Virtual Object . . . . . . . 3.2 Loading Sequence . . . . . . . . . . . 3.2.1 Loading Predened Sequence 3.2.2 Predened Sequences . . . . . 3.3 Loading Coil . . . . . . . . . . . . . 3.3.1 Loading Predened Coil . . . 3.3.2 Predened Coil . . . . . . . . 3.4 Loading Magnet . . . . . . . . . . . 3.4.1 Loading Predened Magnet . 3.4.2 Predened Magnet . . . . . . 3.5 Loading Gradient . . . . . . . . . . . 3.5.1 Loading Predened Gradient 3.5.2 Predened Gradient . . . . . 3.6 Loading Motion . . . . . . . . . . . . 3.6.1 Loading Predened Motion . 3.6.2 Predened Motion . . . . . . 3.7 Setting Scan Parameters . . . . . . . 3.8 Parameter List . . . . . . . . . . . . 3.8.1 Imaging . . . . . . . . . . . . 3.8.2 Advanced . . . . . . . . . . . 3.8.3 Hardware . . . . . . . . . . . 3.8.4 Recon . . . . . . . . . . . . . 3.8.5 CVs . . . . . . . . . . . . . . iii 1 1 1 2 5 5 7 9 11 11 13 13 15 16 16 18 18 19 20 20 20 21 22 22 23 23 23 24 25 25 26 26
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
iv
3.9
4 Simulation 31 4.1 Running Simulation . . . . . . . . . . . . . . . . . . . . . . . . . 31 4.2 Image, SNR and SAR . . . . . . . . . . . . . . . . . . . . . . . . 32 5 MRiLab Toolboxes 5.1 RF Pulse Design . . . . . . . . . . . . . 5.1.1 RF Design GUI . . . . . . . . . . 5.1.2 RF Macro Library . . . . . . . . 5.1.3 Make Your Own RF Macro . . . 5.2 MR Sequence Design . . . . . . . . . . . 5.2.1 Sequence Design GUI . . . . . . 5.2.2 Virtual Structure . . . . . . . . . 5.2.3 GzSS Macro Library . . . . . . . 5.2.4 GyPE Macro Library . . . . . . 5.2.5 GxR Macro Library . . . . . . . 5.2.6 ADC Macro Library . . . . . . . 5.2.7 Ext Macro Library . . . . . . . . 5.2.8 Make Your Own Ext Plugin . . . 5.2.9 Make Your Own Gradient Macro 5.2.10 Make Your Own MR Sequence . 5.2.11 Make Your Own Virtual Object . 5.3 Coil B1 Design . . . . . . . . . . . . . . 5.3.1 Coil Design GUI . . . . . . . . . 5.3.2 Coil Element Macro Library . . . 5.3.3 Make Your Own Coil . . . . . . . 5.4 Magnet dB0 Design . . . . . . . . . . . 5.4.1 Magnet Design GUI . . . . . . . 5.4.2 Magnet Element Macro Library . 5.4.3 Make Your Own Magnet . . . . . 5.5 Gradient Design . . . . . . . . . . . . . 5.5.1 Gradient Design GUI . . . . . . 5.5.2 Gradient Element Macro Library 5.5.3 Make Your Own Gradient . . . . 5.6 Motion Design . . . . . . . . . . . . . . 5.6.1 Motion Design GUI . . . . . . . 5.6.2 Motion Element Macro Library . 5.6.3 Make Your Own Motion . . . . . 5.7 Image Reconstruction . . . . . . . . . . 5.7.1 Default Engine . . . . . . . . . . 5.7.2 External Engine . . . . . . . . . 5.8 Simulation Output . . . . . . . . . . . . 35 35 35 41 52 55 55 62 63 68 73 79 81 83 86 88 88 90 90 93 94 94 95 97 98 98 99 101 102 102 103 104 105 106 106 106 108
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
CONTENTS 6 Image Display and Analysis 6.1 MatrixUser . . . . . . . . . 6.1.1 MatrixUser Display 6.1.2 MatrixUser More . . 6.2 arrayShow . . . . . . . . . . 6.3 SpinWatcher . . . . . . . . 6.4 SARWatcher . . . . . . . .
v 109 109 109 117 122 122 125 127 127 127 129 130 130 131 133 137 139
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
7 MRiLab Applications 7.1 bSSFP with Non-uniform B0 7.2 Fat Chemical Shift . . . . . . 7.3 Multi RF Transmitting . . . . 7.4 Multi Receiving Coil . . . . . 7.5 Image Gradient . . . . . . . . 7.6 Motion Artifact . . . . . . . . 8 FAQs Acknowledgment Afterword
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
vi
CONTENTS
Preface
Numerical MRI simulation can dramatically speed the understanding and development of new MR imaging methods. In this work, I have developed a new simulation package named MRiLab for performing fast 3D parallel MRI numerical simulation on a simple desktop computer. This simulation package is aimed to provide a fast, comprehensive and eective numerical MRI simulation solution with minimum computation hardware requirement. This manual is aimed to provide a comprehensive introduction for various functionality included in MRiLab, through the workow of simulation, to detailed toolboxes that assist customizing dierent aspects of MR simulation experiment. You should be able to perform all the functions available in MRiLab after reading this User Guide. Its my greatest pleasure to know that MRiLab can help you in your MR research or education. Please dont hesitate to leave me feedback about any aspect of MRiLab and/or about this User Guide. All the eects for improving MRiLab will hopefully help MR researchers including myself for better understanding and improving future MR techniques.
vii
viii
CONTENTS
Chapter 1
Introduction
1.1 What is MRiLab
The MRiLab is a numerical MRI simulation package. It has been developed to simulate factors that aect MR signal formation, acquisition and image reconstruction. The simulation package features highly interactive graphic user interface (GUI) for various simulation purposes. MRiLab provides several toolboxes for MR researchers to analyze RF pulse, design MR sequence, congure multiple transmitting and receiving coils, investigate B0 in-homogeneity and object motion sensitivity et.al. The main simulation platform combined with these toolboxes can be applied for customizing various virtual MR experiments which can serve as a prior stage for prototyping and testing new MR technique and application. The MRiLab provides high computation accuracy by simulating multiple spin evolution within small time interval using discrete Bloch-equation. In order to manipulate large multidimensional spin matrix, MRiLab employs parallel computation by incorporating latest GPU technique and multi-threading CPU technique. With the accelerated computation, MRiLab can accomplish multidimensional multiple spin species MR simulation with high accuracy within short time and under low computation hardware requirements.
1.2
Obtaining MRiLab
The current version of MRiLab is made available and can be downloaded from SourceForge website. MRiLab is released as free software. This means that you are free to use and modify this software as your needs, as long as you acknowledge the original author in any future work. If you nd MRiLab useful for the publication of any scientic results, including a line in your acknowledgments section referencing to MRiLab and this belowing address is requested. MRiLab downloading address: 1
1.3
In order to run MRiLab, the Matlab core is required. Simulink 3D Animation relevant packages are required for analyzing object motion in MRiLab. The current version of MRiLab has been tested under the following Matlab versions: Matlab R2011a 64-bit Windows Matlab R2012b 64-bit Unix Installing and running MRiLab is easy, you only need to download MRiLab source code in a compressed le, then uncompress the MRiLab root folder, put the folder to any location in you computer. To run MRiLab, you need open Matlab, then simple run the MRiLab.m script that is under the MRiLab root folder. The graphic interface of MRiLab is developed using Matlab GUIDE environment. Majority of the conguration code is written using pure Matlab language and XML, however, the computation intensive functions are optimized and written using Matlab C MEX. This includes the computation kernel working with GPU using NVIDIA CUDA and multi-threaded CPU using OpenMP. Some 3D rendering functions are also coded using Visualization Toolkit (VTK). I have compiled these MEX library les for 64-bit Windows and Linux OS system and shipped them with MRiLab source code, so that the user should be able to use these les under 64-bit Windows and Linux without compiling. However, if these MEX les are incompatible with your OS system for any reason or if you wish to modify these MEX les, you have to recompile them using the source code. Before compiling these MEX les, the following dependent packages are required. 1. CMake (required) The MRiLab uses CMake for cross platform building for these MEX les. CMake : http://www.cmake.org/cmake/resources/software.html
2. IPP or Framewave (required) The current version of MRiLab uses matrix manipulation libraries from either Intel IPP or AMD Framewave. Please notice that Intel IPP is the only MRiLab dependency that is not free open source, however if you are planning to use MRiLab IPP version (i), you can download Intel C Studio XE by following Intel non-commercial license. As an alternative, MRiLab
provides Framewave version (f), and Framewave is a free open source library. Intel IPP : http://software.intel.com/en-us/intel-ipp AMD Framewave : http://framewave.sourceforge.net 3. CUDA (optional) The NVIDIA driver is required for driving GPU and for MRiLab to work with GPU parallel computation. The current version of MRiLab only supports GPU which supports NVIDIA CUDA technique. And the libraries from CUDA 5.0 are used in the current version of MRiLab. NVIDIA : http://www.nvidia.com/page/home.html CUDA : http://www.nvidia.com/object/cuda_home_new.html Although GPU acceleration can dramatically improve computation eciency for MRiLab, the GPU is also optional. Parallel computation can be accomplished by using multi-threaded CPU which requires no additional package to be installed on todays regular computer. 4. VTK (optional) The VTK is required for rendering 3D K-Space trajectory. The current version of MRiLab uses libraries from VTK 5.10. However, VTK is optional since Matlab based rendering is also provided. VTK : http://www.vtk.org 5. ISMRMRD (optional) MRiLab supports data conversion from MAT to ISMRMRD which is used as a default data storage format by Gadgetron MRI image reconstruction framework. The interested user needs to install ISMRMRD required packages in order to compile data conversion MEX. ISMRMRD : http://ismrmrd.sourceforge.net/#obtaining-and-installing If you nish installing the necessary dependent packages for MRiLab, you also need to set a few necessary environment variables in your system : MATLAB ROOT : Matlab root folder path IPP ROOT : IPP root folder path if IPP is used FRAMEWAVE ROOT : Framewave root folder path if Framewave is used
CHAPTER 1. INTRODUCTION
Notice that the C source code for these MEX les is in /MRiLab/Lib/src folder. To compile and install MEX les 1. Linux Installation The command line that compiles the MEX les is mkdir build cd build cmake MRiLab/Lib/src make sudo make install You can also use CMake GUI for building and other graphic compiling tools (e.g. Eclipse) for compiling. 2. Windows Installation It is recommended to use CMake GUI for building a Visual Studio project. Then you can compile by using Visual Studio. If installation problems do occur to you, feel free to let me know and I may help you out. For your information, I provide here my development environment (Table 1.1) for the current version of MRiLab. Environment Machine CPU GPU OS Matlab C Compiler VTK CUDA IPP Framewave Desktop Dell Precision T3500 Intel Xeon W3530 NVIDIA Quadro 4000 Windows 7 64-bit Matlab R2011b 64-bit Visual Studio 10 Win64 VTK 5.10 CUDA 5.0 Intel IPP 7.0 AMD Framewave 1.3 Laptop Lenovo Thinkpad R61 Intel Core2 Duo T8100 Null Linux Fedora 16 64-bit Matlab R2012b 64-bit GCC 4.6.3 VTK 5.10 Null Intel IPP 7.0 AMD Framewave 1.3
Chapter 2
Platform Overview
2.1 MRiLab Simulation Platform
The MRiLab consists of 1. A Main Simulation Control Console The main simulation control console (Figure 2.1) functions like a MR scanner console for graphically adjusting imaging setup and conducting simulation control. Simulation feedback are dynamically reected on corresponding information windows based on simulation process. 2. Function Toolboxes The function toolboxes (Figure 2.2) provide independent panels for designing RF pulse (e.g. SLR, non-adiabatic and adiabatic pulse etc.), for constructing arbitrary pulse sequence (e.g. SPGR, SSFP and FSE etc.), for conguring RF coil prole and main magnet eld (i.e. B1 and B0 eld) and for designing motion track. Additional image display and analysis tools (SpinWatcher, MatrixUser and arrayShow) are also developed and tailored to work with MRiLab reconstructed high dimensional images. 3. A Discrete Bloch-equation Solving Kernel The solving kernel simulates spin evolution in tissue within small discrete time interval for accurately capturing spin behavior given the running pulse sequence. This kernel is accelerated using Matlab MEX functions that are optimized for running GPU and multi-threaded CPU parallel computation. Also, this kernel is taking charge of virtual signal acquisition followed by image reconstruction with saved K-Space data in the reconstruction module. 4. Macro Library MRiLab uses the concept of macros for simplifying experiment design. The macro in MRiLab is dened as a programming-free module that can 5
Figure 2.1: The MRiLab Main Simulation Control Console. This control console functions like a MR scanner console for graphically adjusting imaging setup and conducting simulation control.
Figure 2.2: The Shortcut for Function Toolbox on Simulation Control Console. Each icon is associated with individual toolbox for specic functions.
be added, deducted and modied in constructing MR sequences, coil prole, eld inhomogeneity and motion track. For instance, a Sinc RF pulse (rfSinc) is considered as a simple macro that can be used for constructing a gradient echo sequence, and the attributes of this macro include pulse starting time (tStart), pulse ending time (tEnd) and the time bandwidth product (TBP) et.al. MRiLab provides a macro library (Figure 2.3) covering a wide range of macros. Using these predened macros, you should be able to accomplish most of your design work. However, if special macros are needed, MRiLab also provides interfaces for communicating with userdened macros. More detailed description for macros will be provided in separate sections in Chapter 5.
Figure 2.3: The Macro Library Tree Structure in MRiLab. Individual tree nodes under SeqElem root are functional macros that can be used for designing MR sequences. Notice that only RF nodes are unfolded here for display purpose. MRiLab uses XML les for storing simulation information, which simplies simulation transition across dierent studies. MRiLab also supports external plugins written with either Matlab or C language for creating extendable simulation system.
2.2
Simulation Workow
The workow diagram of MRiLab simulation is shown in Figure 2.4. One typical simulation requires input of : Virtual object with specic tissue properties including Rho, T1 and T2 etc.
Figure 2.4: MRiLab Workow Diagram MR sequence that provides desired tissue contrast in reconstructed images B1 eld for RF transmitting and receiving dB0 eld for describing main static eld inhomogeneity Gradient eld for signal spatial encoding Motion pattern for describing object movement during real time simulation All the input information gets congured at the MRiLab main control console where the user can graphically customize any aspect of the simulation experiment. The main console preprocesses the input information then converts them into kernel signal. The discrete solving kernel executes each voxel based on the kernel signal with either GPU or multi-threading CPU acceleration. The acquired MR signal and K-Space information from the kernel then passes to image reconstruction module where either default recon code or external recon tool (e.g. Gadgetron) is applied. The reconstructed image can be analyzed using MRiLab image display tools including : MatrixUser : An image display and analysis tool for manipulating multidimensional real value matrix
SpinWatcher : An analysis tool for analyzing spin evolution behavior of single voxel SARWatcher : An analysis tool for analyzing local spatial SAR distribution arrayShow : A Matlab image viewer for the evaluation of multidimensional complex images
2.3
Up to this point, you may wonder how I can start to use MRiLab for my simulation. Here is a simple example for you to get some basic feelings of using MRiLab. A 3D Gradient Echo (GRE) sequence will be used for simulating images. Lets get it started! Open MRiLab by running MRiLab.m under the root folder. MRiLab will try to detect your CPU and GPU, and initialize the simulation environment. After initialization (typically in couple seconds), MRiLab Main Simulation Control Console will pop-up. Empty Axial, Sagittal, Coronal and Preview views show up. Notice that on the console, several push buttons are disabled at this point, it means more inputs are needed for enabling them. To simulate images, the virtual object or digital phantom is needed. Go to Load, Load Phantom Example, choose one of the predened digital phantoms for the experiment. Several digital phantoms that are suitable for dierent experiment purposes are already provided. Here, lets choose Brain (Standard Resolution 108x90x90). After loading this phantom, you will notice the preview image showing up at the top right corner under VObj Spin Map and the basic information about this phantom are also shown in Virtual Object Property. Lets choose T2 map from the popup box, and click Localizer button for showing image details. At this point, Axial, Sagittal and Coronal views are lled with this 3D digital phantom. Then click Update button to accept your phantom loading. Notice that after updating, all push buttons are enabled. Since we want to simulate 3D GRE sequence, we need to load 3D GRE sequence rst. Click the Sequence button located at the center portion of the main control console. The SeqList will pop-up where you can choose and load your sequences. Lets click Dimension pop-up box and choose 3D. The Category list will show a full list of sequence type. Click GradientEcho, then click PSD GRE3D from the Sequence list. Click Accept button to accept and load this 3D GRE sequence. Notice that the Simulation Settings tabs update and change to the setting for the current GRE sequence. Then click Update button to accept your sequence loading.
10
CHAPTER 2. PLATFORM OVERVIEW Under Imaging tab, there are several imaging setting parameters you can play with, for instance, Field-of-View in frequency encoding direction (FOVFreq). We can simply accept the default setting at this moment, however, if you do make any changes, you need to click Update button to accept your changes before proceeding to Scan. The nal step is to click Scan button and wait for the simulation to be performed. After simulation nishes in a short period of time, the reconstructed image will be shown in the Preview view.
The nal looks for this 3D GRE experiment should be somewhat like this (Figure 2.5).
Figure 2.5: The Final Simulation Result for 3D GRE Experiment If you managed to get this simulated gradient echo image, congratulations! You have successfully performed your rst MRiLab experiment. So you should be prepared for deeper understanding of MRiLab by following the rest of this manual.
Chapter 3
Simulation Settings
3.1 Loading Virtual Object
Before performing any simulation in MRiLab, the virtual object has to be loaded rst. To load the virtual object, the user can go to menu Load and Load Phantom to load the user customized phantom or Load Phantom Example to load MRiLab default phantoms. MRiLab provides a wide range of phantoms that cover several tissue types in human. After the virtual object being loaded, the phantom will show as a preview thumbnail at the top right corner of the main control console (Figure 3.1). The user can switch among T1, T2 and Rho et.al. using the pop-up menu above the thumbnail. If multiple spin species exist in the phantom, the user can also switch the spin type by using Spin Type popup menu below the thumbnail image. In addition, the virtual object properties will be provided at the Virtual Object Property list, the user can check them by clicking the name of certain property. The properties of one virtual object typically include: Gyro (rad/s/T) : The gyromagnetic ratio of the spin ChemShift (Hz/T) : The chemical shift of the spin XDim : The number of voxels in X direction YDim : The number of voxels in Y direction ZDim : The number of voxels in Z direction XDimRes (m) : The voxel size in X direction YDimRes (m) : The voxel size in Y direction ZDimRes (m) : The voxel size in Z direction Type : The type of the spin 11
12
CHAPTER 3. SIMULATION SETTINGS TypeNum : The number of spin species Rho : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing spin density T1 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T1 relaxation time T2 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T2 relaxation time T2Star (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T2* relaxation time
Figure 3.1: The Virtual Object Preview The user can press the Localizer button to push the thumbnail image to the main control console image display panel. MRiLab provides three image axes to hold axial, sagittal and coronal view section for the three dimensional virtual object. The scroll bar beside each axes allows changing the image slice in corresponding direction. This serves as an anatomical reference for further
13
image parameter setup. For example, the green box in each axes that indicates the current imaging eld of view can be adjusted using free hand dragging, and the eld of view information is updated at Field of View panel when dragging.
3.2
Loading Sequence
One of the central roles of MRiLab is to enable simulation of a wide range of MR sequences and be able to manipulate sequence parameters in order to investigate and optimize desired MR contrast. In order to simulate those sequences, MRiLab provides an sequence loading interface for users to choose predened sequences from default library or choose user customized sequences. MRiLab reads the chosen sequence and translates the sequence into specic signal that triggers the simulation kernel. Of course, the generated signal depends on imaging and other parameters that are adjustable on the simulation control console. The sequence loading interface provides functions to load MR sequence. The MR sequence design module is separate from loading interface and will be explained in detail in Chapter 5.
3.2.1
To open the sequence loading interface (Figure 3.2), you need to click the Sequence button located at the center portion of the main control console. Once the interface is open, the Dimension species the sequence spatial encoding scheme (2D or 3D). By default, 3D sequences are rst recognized and provided. Category provides a wide list of sequence classes including Gradient Echo, Spin Echo, Inversion Recovery, Fast Spin Echo, Others and User. After clicking one sequence category, the sequences belonging to chosen category will show up in the sequence list on the right. By clicking the specic sequence, the sequence will be highlighted and chosen. Then pressing Accept will load the chosen sequence and this sequence loading interface will close. However, pressing Cancel button will close the interface without loading any sequence. Notice that there is a Special Setting panel down below the sequence list. When a specic sequence is chosen, and if this sequence uses special techniques, the corresponding checkboxes beside the special techniques will be chosen. For example, by default PSD FIESTA3D uses the special techniques called DummyPulse, therefore, by clicking PSD FIESTA3D, the DummyPulse will be chosen accordingly. However, you can uncheck the checkbox for enforcing not loading DummyPulse module, but this may cause incomplete simulation for PSD FIESTA3D. It is recommended to keep default loading therefore much more sequence control is preserved. On the other hand, for the sequences that have no special techniques, you can also add special technique module by checking corresponding checkbox. This will load parameter tabs of special techniques on the simulation control console for further conguration. The special technique strategy enables the ability for reusing capsulized module for dierent
14
Figure 3.2: The Sequence Loading Interface. A sequence named PSD FIESTA3D from 3D GradientEcho Category is chosen, and DummyPulse special technique is checked by default.
15
MRiLab provides several default sequences under the folder /PSD, notice the /PSD folder shares the same hierarchic structure scheme as the loading interface. Typically a new sequence can be put anywhere in the computer, however it is recommended to put the sequence under these predened categories under /PSD therefore they are visible to the loading interface. However, if a customized sequence is not directly visible to the loading interface, it can also be loaded using the PSD loading button marked as o at the bottom. If the PSD loading button is used, loading interface will ignore other ordinary loading.
3.2.2
Predened Sequences
MRiLab provides several predened MR sequences including 1. Fast Spin Echo PSD FSE3D Three dimensional multishot Fast Spin Echo (FSE) sequence with interleaved K-Space sampling in Kx-Ky and conventional phase-encoding along Kz. 2. Gradient Echo PSD FIESTA3D Three dimensional balanced Steady State Free Precession (bSSFP) sequence. PSD SPGR3D Three dimensional Spoiled Gradient Echo (SPGR) sequence. PSD GRE3D Three dimensional gradient echo sequence with Cartesian readout. PSD GRE3DEPI Three dimensional gradient echo sequence with multishot Echo Planar Imaging (EPI) readout using interleaved K-Space sampling in Kx-Ky and conventional phase-encoding along Kz. PSD GRE3DRadial Three dimensional gradient echo sequence with radial readout in KxKy and conventional phase-encoding along Kz, usually referred to as stack-of-stars sequence. PSD GRE3DSpiral Three dimensional gradient echo sequence with multishot spiral readout in Kx-Ky and conventional phase-encoding along Kz. 3. Inversion Recovery
16
CHAPTER 3. SIMULATION SETTINGS PSD IR3D Three dimensional Inversion Recovery (IR) sequence with Cartesian readout. 4. SpinEcho PSD SE3D Three dimensional Spin Echo (SE) sequence with Cartesian readout. 5. User PSD SPGR3DMT Three dimensional SPGR sequence with MT saturation. 6. Others PSD AFI Three dimensional SPGR sequence for performing ip angle mapping using Actual Flip Angle Imaging (AFI) [1].
3.3
Loading Coil
In order to simulate multi-transmitting and receiving coil behavior, MRiLab provides a coil loading interface that allows users to choose dierent coil congurations for Tx (i.e. Transmitting) and/or Rx (i.e. Receiving). MRiLab translates the coil conguration and calculates the B1+/B1- eld accordingly. For multi-transmitting coil, each coil element could be treated separately and receives individual RF signal source. This allows users to investigate B1 shimming and multiple RF excitation et.al. For multi-receiving coil, each coil element also connects to an individual signal channel and produces signal according to its specic coil sensitivity. This allows users to investigate coil encoding methods including parallel imaging. The coil loading interface provides function to load coil conguration. The coil design module is separate from loading interface and will be explained in detail in Chapter 5.
3.3.1
To open the coil loading interface (Figure 3.3), you need to click the Coil button located at the center portion of the main control console. The Category list species dierent coil conguration category corresponding to anatomical structure. The Coils list beside the Category list provides coil conguration belonging to chosen category. By clicking the coil conguration name, the interface will calculate the coil sensitivity map and display in the preview axes. The user can specify displayed spatial resolution using the Precision with the highest spatial resolution as the same as that of digital phantom, the lowest one as one of the sixteenth. Also the user can specify displayed color map from Jet,Gray or Hot. Then pressing Accept will load the chosen coil conguration and this coil loading interface will close. However, pressing Cancel button
17
Figure 3.3: The Coil Loading Interface. An eight channel coil conguration named Coil 8ChHead from Head Category is chosen, preview image shows the total coil sensitivity with the same spatial resolution as that of the chosen digital phantom.
18
will close the interface without loading any coil conguration. If the uniform unit coil sensitivity is desired, the user can press Uniform button to load that. By default, MRiLab uses the uniform unit coil sensitivity for both RF transmitting and receiving. To indicate the usage of the coil conguration, the user has to specify Coil Type to be either Tx for transmitting or Rx for receiving. MRiLab provides several default coil conguration under the folder /Coil, notice the /Coil folder shares the same hierarchic structure scheme as the loading interface. Typically a new coil conguration can be put anywhere in the computer, however it is recommended to put the coil conguration folder under these predened categories under /Coil therefore they are visible to the loading interface. However, if a customized coil conguration is not directly visible to the loading interface, it can also be loaded using the Coil loading button marked as o at the bottom. If the Coil loading button is used, loading interface will ignore other ordinary loading.
3.3.2
Predened Coil
MRiLab provides several predened coil conguration including 1. Head Coil 1ChHead A coil conguration consists of one single Biot-Savart circle, primarily used for testing purpose. Coil 8ChHead A coil conguration consists of 8 Biot-Savart circles, which produces relative at B1 eld in X-Y plane along X direction. 2. Chest Coil 9ChSurfChest A coil conguration consists of 9 Biot-Savart circles, which produces relative at B1 eld in X-Y plane along Y direction at the surface region.
3.4
Loading Magnet
Although in practical situation, the main eld inhomogeneity is aimed to be alleviated as much as possible for better eld performance, there are also cases that eld inhomogeneity are required for particular purposes, such as investigating susceptibility artifact near metallic implant or developing sequences that are less sensitive to eld inhomogeneity. To satisfy those developing intention, MRiLab provides the magnet loading interface allowing users to load customized B0 eld inhomogeneity map (i.e. dB0). The magnet loading interface provides functions to load dB0 map. The magnet design module is separate from loading interface and will be explained in detail in Chapter 5.
19
3.4.1
Figure 3.4: The Magnet Loading Interface. A magnet named Mag GaussianHead from Head Category is chosen, preview image shows the dB0 map in the X-Y plane with the same spatial resolution as that of the chosen digital phantom. To open the magnet loading interface (Figure 3.4), you need to click the Magnet button located at the center portion of the main control console. The Category list species dierent magnet category corresponding to anatomical structure. The Magnet list beside the Category list provides magnet belonging to chosen category. By clicking the magnet name, the interface will calculate the dB0 map (i.e. a map for indicating main eld variation) and display in the preview axes. Then pressing Accept will load the chosen and this loading interface will close. However, pressing Cancel button will close the interface without loading any . If the uniform B0 eld (i.e. zero dB0) is desired, the user can press Uniform button to load that. By default, MRiLab uses the uniform B0 eld for simulation. That is to say there is no eld inhomogeneity across the
MRiLab provides several default magnet under the folder /Mag, notice the /Mag folder shares the same hierarchic structure scheme as the loading interface. Typically a new can be put anywhere in the computer, however it is recommended to put the folder under these predened categories under /Mag therefore they are visible to the loading interface. However, if a customized is not directly visible to the loading interface, it can also be loaded using the Magnet loading button marked as o at the bottom. If the loading button is used, loading interface will ignore other ordinary loading.
3.4.2
Predened Magnet
MRiLab provides two predened magnet conguration including 1. Head Mag GaussianHead A produces Gaussian dB0 eld in three dimensional space. Mag LinearHead A magnet produces linear dB0 eld in three dimensional space.
3.5
Loading Gradient
Regular MR spatial encoding is performed in a linear (at) sense. Recently encoding in a nonlinear (curved) sense becomes interesting and challenging. MRiLab provides gradient loading interface to load customized 3D nonlinear gradient eld. This function can help users investigate any arbitrary curved gradient eld and use it directly for image simulation. Along with the powerful functions for MR sequence design, nonlinear gradient encoding techniques such as PatLoc can be simulated with minimal eorts in MRiLab. The gradient loading interface provides functions to load nonlinear gradient. The gradient design module is separate from loading interface and will be explained in detail in Chapter 5.
3.5.1
To open the gradient loading interface (Figure 3.5), you need to click the Gradient button located at the center portion of the main control console. The Category list species dierent gradient category corresponding to anatomical structure. The Gradient list beside the Category list provides gradient prole belonging to chosen category. After clicking the gradient name, pressing Accept will load the chosen gradient prole and this gradient loading interface will close. However, pressing Cancel button will close the interface without loading any gradient prole. If the constant unit gradient is desired, the user can press Constant Unit button to load that. By default, MRiLab uses the
21
Figure 3.5: The Gradient Loading Interface. Grad LinearHead from Head Category is chosen.
constant unit gradient prole in X, Y and Z direction for simulation. This will maintain the conventional linear spatial encoding in all three dimensions. MRiLab provides gradient proles under the folder /Grad, notice the /Grad folder shares the same hierarchic structure scheme as the loading interface. Typically a new gradient prole can be put anywhere in the computer, however it is recommended to put the gradient prole under these predened categories under /Grad therefore they are visible to the loading interface. However, if a customized gradient is not directly visible to the loading interface, it can also be loaded using the Gradient loading button marked as o at the bottom. If the Gradient loading button is used, loading interface will ignore other ordinary loading.
3.5.2
Predened Gradient
MRiLab provides one predened gradient prole 1. Head Grad LinearHead A gradient prole produces constant gradient eld with varying gradient value in three dimensions, which can cause image contraction, expansion or shearing et.al.
22
3.6
Loading Motion
MRiLab provides a motion loading interface that implements the functions for simulating object motion in three dimensional space. Motion simulation implementation in MRiLab is helpful in the sense that it enables an approach for simulating four dimensional imaging (+ time) techniques such as k-t blast and enables the development for real time image reconstruction algorithms. It also helps investigate motion insensitive sequence and observe motion artifact behavior in various types of sequences and conditions. The motion loading interface provides functions to load motion trajectory. The motion design module however is separate from loading interface and will be used for designing motion in three dimensional space.
3.6.1
Figure 3.6: The Motion Loading Interface. A motion prole named Mot RotateHead from Head Category is chosen. This motion prole create object rotation in three dimensions along any user dened axis. To open the motion loading interface (Figure 3.6), you need to click the Motion button located at the center portion of the main control console. The Category list species dierent motion category corresponding to anatomical structure. The Motion list beside the Category list provides motion prole belonging to chosen category. After clicking the motion name, pressing Accept will load the chosen motion prole and this motion loading interface will close. However, pressing Cancel button will close the interface without loading any
23
motion prole. If motion isnt desired, the user can press Stationary button. By default, no motion is assumed in MRiLab simulation. MRiLab provides motion proles under the folder /Mot, notice the /Mot folder shares the same hierarchic structure scheme as the loading interface. Typically a new motion prole can be put anywhere in the computer, however it is recommended to put the motion prole under these predened categories under /Mot therefore they are visible to the loading interface. However, if a customized motion is not directly visible to the loading interface, it can also be loaded using the Motion loading button marked as o at the bottom. If the Motion loading button is used, loading interface will ignore other ordinary loading.
3.6.2
Predened Motion
MRiLab provides two predened motion prole 1. Head Mot RotateHead A motion prole produces object rotation in three dimensional space along any user dened axis. Mot ShiftHead A motion prole produces object translation in any user dened direction.
3.7
These loading interfaces provide a mechanism to interpret and convert conguration le to MRiLab readable parameters. After loading, the loaded information is present at corresponding elds at the main simulation control console. The Coil Selection, Magnet Selection,Gradient Selection and Motion Selection show the current chosen conguration. The user can change these conguration by reloading new conguration le from above. If any of these elds are empty, the default setting will be used. Like real scanner system, MRiLab categorizes the scanning parameters into dierent groups and present them within dierent tabs in the Simulation Settings panel (Figure 3.7). There are ve tabs that are common to all sequences, including Imaging, Advanced, Hardware, Recon and CVs. Additional tabs for one or more special techniques can also be present if loaded. Below are detailed explanation for each of these parameters.
3.8
Parameter List
Below are the full list of parameters that are supported by current version of MRiLab. Notice that MRiLab uses SI units for all the parameters unless otherwise specied.
24
Figure 3.7: The Simulation Settings Panel. The panel includes Imaging, Advanced, Hardware, Recon and CVs tabs, two additional special technique DummyPulse and MT are also added for this sequence.
3.8.1
Imaging
The Imaging tab contains parameters relevant to image resolution, eld of view and timing setting et.al. BandWidth (Hz) : Full receiver bandwidth FOVFreq (m) : Field of view in the frequency encoding direction FOVPhase (m) : Field of view in the rst phase encoding direction FlipAng (Degree) : Flip angle of excitation pulse FreqDir : Frequency encoding direction ResFreq : Number of voxels in frequency encoding direction ResPhase : Number of voxels in the rst phase encoding direction ScanPlane : The scanning plane SliceNum : The number of encoding slice SliceThick (m) : The thickness of one slice TE (s) : The time of echo TEPerTR : The number of echoes in multi echo mode, default one uses single echo, use a value above one requires MultiEcho tab to be loaded TR (s) : The time of repetition
25
3.8.2
Advanced
The Advanced tab contains other further imaging parameters. MasterTxCoil : The master transmitting coil in multi RF transmitting mode MultiTransmit : The ag for turning on and o multi RF transmitting mode, default mode is o for single RF transmitting NEX : The number of excitation NoFreqAlias : The ag for preventing aliasing in frequency encoding direction, default on truncates object outside eld of view in frequency encoding direction NoPhaseAlias : The ag for preventing aliasing in the rst phase encoding direction, default on truncates object outside eld of view in the rst phase encoding direction NoSliceAlias : The ag for preventing aliasing in the second phase encoding (i.e. slice encoding) direction, default on truncates object outside eld of view in slice encoding direction Shim : The ag for choosing shimming mode TEAnchor : The ag for choosing TE time oset with respect to the RF pulse width
3.8.3
Hardware
The Hardware tab contains parameters relevant to system hardware setup. B0 (T) : Main static magnetic eld strength B1Level (T) : The reference B1 eld which produces prescribed ip angle MaxGrad (T/m) : Maximum allowable gradient strength MaxSlewRate (T/m/s) : Maximum allowable slew rate MinUpdRate (s) : Minimum update rate for producing sequence signal Model : System model with the closest setting to the real scanner system NoiseLevel : The level of adjustable noise, the higher the number, the more noise SpinPerVoxel : The number of spins in each voxel, default one for treating T2* equal to T2, use a value above one for simulating T2* eect
26
3.8.4
Recon
The Recon tab contains parameters relevant to image reconstruction. AutoRecon : The ag for turning on and o automatic image reconstruction after signal acquisition ExternalEng : The script for doing image reconstruction using user customized external method OutputType : The type of output data including both image and signal, choosing options include MAT and ISMRMRD, the latter requires ISMRMRD dependency packages to be installed ReconEng : The image reconstruction engine, choosing Default uses MRiLab default reconstruction code, choosing External uses external engine which requires ExternalEng to be provided ReconType : The type of image reconstruction
3.8.5
CVs
The CVs tab contains Controllable Variable (CV) that can be freely referenced in the sequence and adjusted at the simulation control console. They are designed for conveniently transferring values among multiple sequence modules. The user can use them for customized purpose. CV1 : Controllable variable 1 CV2 : Controllable variable 2 CV3 : Controllable variable 3 CV4 : Controllable variable 4 CV5 : Controllable variable 5 CV6 : Controllable variable 6 CV7 : Controllable variable 7 CV8 : Controllable variable 8 CV9 : Controllable variable 9 CV10 : Controllable variable 10 CV11 : Controllable variable 11 CV12 : Controllable variable 12 CV13 : Controllable variable 13 CV14 : Controllable variable 14
27
3.8.6
SpecialTech
The SpecialTech contains multiple tabs from which one or more are loaded during sequence loading according to sequence conguration and user choice. 1. DummyPulse The DummyPulse tab are designed for adding dummy pulse section before image acquisition section. It can be used for skipping transient steady state signal. DP Flag : The ag for turning on and o dummy pulse DP FlipAng (Degree) : The ip angle of excitation pulse for dummy pulse DP Num : The number of TRs for dummy pulse DP TR (s) : The time of repetition for dummy pulse 2. EPI The EPI tab contains parameters for performing multi shot interleaved EPI readout. EPI ESP (s) : The echo spacing for EPI EPI ETL : The echo train length for EPI EPI EchoShifting : The ag for turning on and o echo shifting EPI ShotNum : The number of EPI shots, multi shot EPI uses interleave mode 3. FSE The FSE tab contains parameters for performing multi shot interleaved FSE readout. FSE ESP (s) : The echo spacing for FSE FSE ETL : The echo train length for FSE FSE ShotNum : The number of FSE shots, multi shot FSE uses interleave mode 4. GRAPPA (:TODO) The GRAPPA tab contains parameters for performing parallel imaging using GRAPPA. 5. Gridding The Gridding tab contains parameters for controlling gridding process in default Non-Cartesian reconstruction. MRiLab uses Voronoi diagram for K-Space density compensation, and uses Kaiser-Bessel kernel for gridding. Detailed explanation is beyond the scope of this manual, users who are interested are referred to [2, 3, 4].
28
CHAPTER 3. SIMULATION SETTINGS G Deapodization : The ag for turning on and o kernel deapodization (i.e. dividing reconstructed image with the iFFT of the gridding kernel) G KernelSample : The number of kernel sample point, the more sample points, the better kernel approximation G KernelWidth : The full width of kernel in the unit of gridding grid G OverGrid : The over gridding factor G Truncation : The ag for turning on and o image truncation for reconstructed image 6. IRPrep The IRPrep tab contains parameters for inversion recovery sequence. TI (s) : The time of inversion recovery 7. MT The MT tab contains parameters for Magnetization Transfer (MT) sequence. In order to perform MT experiment, particular MT phantom are required. MT Flag : The ag for turning on and o MT simulation 8. MultiEcho The MultiEcho tab contains parameters for performing multi echo experiment, the number of echoes much match TEPerTR. ME TEs (s) : The array of multiple echo values 9. PartialEcho (:TODO) The PartialEcho tab contains parameters for performing partial echo in readout.
10. Radial The Radial tab contains parameters for performing 2D radial readout sampling. R AngPattern : The pattern for sampling the angle in K-Space R AngRange : The range of sampling angle R SampPerSpoke : The number of sampling points in each spoke R SpokeNum : The number of sampling spokes 11. SENSE (:TODO) The SENSE tab contains parameters for performing parallel imaging using SENSE. 12. Shim The Shim tab contains parameters for performing manual B0 shimming.
3.9. PARALLEL COMPUTATION Sh X : The constant for X term Sh Y : The constant for Y term Sh Z : The constant for Z term Sh ZX : The constant for ZX term Sh ZY : The constant for ZY term Sh Z2 : The constant for Z2 term Sh XYZ : The constant for XYZ term Sh X2 Y2 : The constant for X2 Y2 term
29
13. Spiral The Spiral tab contains parameters for performing multi shot spiral readout. The 2D spiral design uses the method described in [5]. S Gradient (T/m) : The desired gradient amplitude S Lamda (1/m/rad) : A constant aecting radial sampling interval in the spiral trajectory S ShotNum : The number of spiral interleaves S SlewRate (T/m/s) : The desired slew rate. Notice that in this approximation, slew rate overshoots the desired value for part of the slew-rate-limited region S SlewRate0 (T/m/s) : The slew rate at the beginning 14. T2Prep (:TODO) The T2Prep tab contains parameters for T2 preparation sequence. 15. VIPR (:TODO) The VIPR tab contains parameters for performing Vastly Undersampled Isotropic Projection Reconstruction (VIPR) sequence. 16. ZeroFilling The ZeroFilling tab contains parameters for performing image interpolation in the K-Space using zero lling. ZF Kz : The zero lling factor in Kz ZF Ky : The number of point in Ky after zero lling ZF Kx : The number of point in Kx after zero lling
3.9
Parallel Computation
The current version of MRiLab supports two types of parallel computation mechanism: GPU based parallel computation by using CUDA and multi-threaded CPU based parallel computation by using OpenMP. As mentioned before, the GPU support requires NVIDIA GPU with CUDA capability and the properly
30
installed GPU driver. The OpenMP is, on the other hand, less of hardware constraint and natively supported by most of modern multi core CPU. If both GPU and CPU are available in users system, the user can choose to use any of these two methods. To switch parallel computation methods, go to Parallel menu and Select Processing Unit and choose available GPU or CPU.
Chapter 4
Simulation
4.1 Running Simulation
Once the simulation parameters are loaded and adjusted according to the experiment design, in order to make the changes eective, the user has to press Update button located below Simulation Settings panel. The user can also check the initially loaded value of each parameter by putting the mouse cursor on top of it. MRiLab converts the parameters from conguration les into temporary conguration structures during loading process, and uses these structures to categorize and organize the simulation settings. The Update button not only updates these structures, but also performs a series of pre-scan processes including checking incompatibility error and initializing other necessary simulation variables. On the left of Update button, there is a Save button which can save back the updated conguration structure into corresponding conguration les for later use. One particular case is that CVs has to be updated rst and then saved in order to make changes eective. This is because CVs is one part of the sequence le which needs to be interpreted at the sequence signal generation module. The sequence memo is also provided at the PSD Memo panel. Its editable and will be saved once Save button is pressed. On the right of Update button, there is a Scan button which activates sequence signal generation, actual scan process and post-scan process including image reconstruction and data saving. The MRiLab will automatically detect any parameter changes and set Scan button disabled. To enable Scan button, simply press Update button. Notice that the update process may take some time when large numbers of initialization is needed, so be patient and wait it to be nished before proceeding. The Simulation Info Log is helpful for checking log information about each simulation step. Once simulation setting is congured properly, the user can press Scan button to start scanning. 31
32
CHAPTER 4. SIMULATION
4.2
Figure 4.1: The Preview of A Simulated Image. The preview is one slice of simulated image using gradient echo sequence with radial readout and reconstructed without deapodization. Figure 4.1 demonstrates an example of a series of simulation operated with dierent sequences. Each sequence is labeled with an unique series number, and shows in the list at Scan Series panel. This series number is also a reference for the saved image and data in the output database which will be introduced in the Chapter 5. There is also status label on the left of each sequence name. The status labels include: Dx : parameter setting and sequence loading ... : scanning V : scan complete successfully X : scan incomplete or fail The example shows a series of successful simulation by using PSD GRE3D, PSD GRE3DRadial and PSD FIESTA3D sequences, but incomplete simulation
33
using PSD FIESTA3D at the second time. The preview axes is displaying the image preview for the series 2 simulated with PSD GRE3DRadial sequence. The user can switch the preview for successful simulation by clicking the scan series. In addition, the series name is also editable although in this example the series name is kept the same as the name of the sequence, which is not absolutely necessary. If the multiple channel coil for multiple receiving is performed (Figure 4.2), the user can specify displayed image to any channel with Channel # popup menu, or choose SumofMagn for summation of image magnitude of all channels or SumofCplx for summation of complex image of all channels. If multiple echo is enabled in the sequence, the user can also specify displayed image to any echo with Echo # popup menu. Default value of 1 is used for single echo. The preview image provides a quick overview of the simulated images, the further image analysis can be performed with image display and analysis tools in Chapter 6.
Figure 4.2: The Preview of A Simulated Image with Multiple Receiving. The preview is one slice of simulated image using FIESTA sequence with 8 channel head coil. The image is from the fth coil channel. Below the preview axes, there are information for the current running sequence, estimated remaining scan time in real time and the scan progress bar. The global relative SNR and SAR (:TODO) are also provided and automatic
34
CHAPTER 4. SIMULATION
updated in real time. The relative SNR is dened as the ratio of current SNR to the initial SNR when loading the sequence. The SNR value is calculated using Equation 4.1. SN R = B 0RF req RP haseRSlice where F OV F req ; ResF req F OV P hase RP hase = ; ResP hase RSlice = SliceT hick. RF req = ResF req ResP hase SliceN um N EX N oiseLevel BandW idth (4.1)
(4.2)
In order to simulate image noise, MRiLab performs the noise adding process after the signal acquisition in K-Space. The Gaussian noise with zero mean and certain standard deviation is added to the complex signal. The standard deviation is determined using Equation 4.3. If no noise is desired, the user can set NoiseLevel to zero to get innite SNR.
N oiseLevel N oiseRef B0 B 0Ref
N oise =
N EX N EXRef
(4.3) where these reference values are given as: BW Ref = 1e3; N oiseRef = 1; B 0Ref = 1.5; V olRef = 1e 9; N EXRef = 1; ADCRef = 1e4.
(4.4)
Chapter 5
MRiLab Toolboxes
MRiLab toolboxes consists of several separate GUIs for conducting RF pulse design, MR sequence design and Coil design et.al. These toolboxes provided by MRiLab enable the user to customize and build their own specic MR experiment. This chapter covers the introduction for each toolbox and its associated macro libraries.
5.1
RF Pulse Design
The RF pulse Design toolbox can be activated by pressing RF Design Panel toolbar icon located at the top of the main simulation console.
5.1.1
RF Design GUI
Figure 5.2 demonstrates the overview of the RF Pulse Design interface. This interface consists of 1. RF and Gradient Macro Library The user can use this interface to analyze the slice prole for the chosen RF pulse. To select a RF pulse macro, the user needs to click the macro library tree to unfold the tree structure and then click the desired RF macro. The properties of the chosen RF macro will show up on the left panel under rf:rf name tab. The RF memo information is also shown at the rf Memo panel below the tree structure. The user can press Execute button to start calculation. MRiLab assumes a gradient is applied 35
36
Figure 5.2: RF Design GUI. An example of one Shinnar-Le Roux RF pulse and its slice prole is shown. in the Z direction, therefore a constant gradient will be applied if Gz tab is empty (Figure 5.3). To select a Gz gradient, the user needs to choose the gradient macro under GzSS. For example the GzSelective is a recommended gradient macro that is normally used in MRiLab for performing slice selection. Once the user selected a gradient macro, the Gz:gradient name tab will be activated and the properties of the gradient macro is accessible and editable. The user can modify macro attributes to meet their own needs. To make the modication eective, the user must press Update button before executing the slice selection prole analysis. Although the library tree contains macros for another gradient line (e.g. GyPE), they are typically inaccessible here.
Figure 5.3: A Warning Window for Using Constant Gradient 2. Slice Prole
37
38
CHAPTER 5. MRILAB TOOLBOXES MRiLab provides three slice prole gures (Figure 5.4) on the Slice Prole panel under dierent tabs. These gures include slice prole in terms of Mx My Mz : three independent spin component |M xy | Mz : transverse and longitudinal component Mg Pe : transverse component magnitude and phase The horizontal axis is the spin position in meters, and the vertical axis is the value of the components in normalized units. MRiLab also plots the RF and gradient waveform below the slice prole. In MRiLab, the RF pulse is dened using RF amplitude (T), RF phase (rad) and RF frequency (Hz). The RF frequency is dened as the spin Larmor frequency minus the laboratory frequency of the RF pulse. Notice that in the gures, the gradient amplitude is in G/cm and RF amplitude is in G. Both time axes are in units of milliseconds. At the bottom of this interface, there is a group of buttons (Figure 5.5) that enable the user to investigate the intermediate slice prole during the applied RF and gradient (Figure 5.6).
Figure 5.5: The Playback Control Group for Slice Prole Scroll Bar : Drag the scroll bar to any intermediate time point between beginning and end | < : Move to the beginning X : Pause playing, notice that the interface can only be closed when playing is paused O : Resume playing > : Play at normal speed >> : Play at double normal speed > | : Move to the end 3. Spin Response MRiLab also presents the spin response in Spin Rotation panel as a three dimensional representation of the slice prole. The user can inspect the behavior of spins at specic location with the chosen RF pulse and gradient. Notice that the Z axis is applied with the gradient and is in units of meters. The X-axis and Y-axis are in normalized units. The user can use Matlab default graphic tools for interactively changing display view and size.
39
The user can modify the spin properties and environment to meet their own needs. The editable properties provided in this interface include: (a) Spin Center : The index of the center spin ChemShift (Hz/T): The chemical shift of the spin Gyro (rad/s/T): The gyromagnetic ratio of the spin Rho : The density of the spin Spin : The number of the spins SpinGap (m): The distance between adjacent spins T1 (s): The longitudinal relaxation time T2 (s): The transverse relaxation time TypeNum : The number of spin species
(b) Gradient ConstantGrad (T/m): The constant gradient applied when Gz tab is empty (c) Magnet dB0 (T): The main magnetic eld oset
Figure 5.8: A Slice Proles for Two Spin Species Figure 5.8 demonstrates a slice prole for two dierent spin species at the same RF pulse and gradient. To enable slice prole analysis for multiple spin species, the user needs to provide multiple values for T1, T2, Rho and ChemShift, and give the correct number of spin species. The values must be separated with space. For example
5.1. RF PULSE DESIGN ChemShift = 0 -210 Rho = 1.0 0.5 T1 = 1.2 1.0 T2 = 0.02 0.03 TypeNum = 2
41
5.1.2
RF Macro Library
MRiLab uses the concept of macros for simplifying experiment design. A RF macro is a predened module for a RF pulse. The macro is programming-free and the attributes of the macro can be easily adjusted using the RF Design interface. MRiLab RF macro library is a collection of RF macros covering from simple RF pulses such as hard pulse, to complex RF pulses such as those adiabatic pulses. There is also specic RF macro provided to interact with external RF pulse le to create more extensible pulse design environment. This section will give an introduction for each of the RF macros provided in MRiLab. rfSinc A RF macro that creates a Sinc type RF pulse. This macro contains attributes including: Apod : Apodization methods including Non, Hamming and Hanning FA (Degree) : Prescribed ip angle TBP : The time bandwidth product dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting
42
CHAPTER 5. MRILAB TOOLBOXES Notes : The notes of the RF pulse The time dependence of the Sinc RF pulse is given by [6]: { sin( t ) At0 tt0 NL t0 t NR t0 B1 (t) = 0 elsewhere
(5.1)
where A is the peak RF amplitude automatically calculated and scaled according to ip angle, t0 is one-half the width of the central lobe, and the NL and NR are the number of zero-crossings to the left and right of the central peak, respectively. In MRiLab, the NL NR , thus the Sinc RF pulse is always symmetric. Notice that the The time bandwidth product of a Sinc pulse equals the number of zero-crossings including the start and end. In order to address the discontinuity at the start and end, apodization can be applied using Hamming or Hanning window as described by: { t (1 ) + cos( N t0 ) Apodization(t) = 0 NL t0 t NR t0 elsewhere
(5.2)
where N equals NL and NR . Hamming window uses = 0.46, and Hanning window uses = 0.5. If Non is used, apodization is disabled. rfRect A RF macro that creates a hard RF pulse. This macro contains attributes including: FA (Degree) : Prescribed ip angle dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates
43
CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse The time dependence of the hard RF pulse is given by [6]: { A |t| T 2 B1 (t) = 0 |t| > T 2
(5.3)
where A is the peak RF amplitude automatically calculated and scaled according to ip angle, T is the width of RF pulse that equals tEnd-tStart. rfGaussian A RF macro that creates a Gaussian type RF pulse. This macro contains attributes including: FA (Degree) : Prescribed ip angle dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse The time dependence of the Gaussian RF pulse is given by [6]: B1 (t) = Ae 22
t2
pulse centered at t = 0
(5.4)
where A is the peak RF amplitude automatically calculated and scaled according to ip angle, is linearly proportional to the pulse width. Also the Gaussian RF pulse is terminated with a 60-dB attenuation.
44 rfFermi
A RF macro that creates a Fermi RF pulse. This macro contains attributes including: PW : The measure of the pulse width FA (Degree) : Prescribed ip angle dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse The time dependence of the Fermi RF pulse is given by [6]: pulse centered at t = 0 (5.5) |t|t0 1+e where A is the peak RF amplitude automatically calculated and scaled according to ip angle, t0 is a measure of the pulse width that corresponds to PW, is a measure of the transition width. The Fermi pulse approximates more to a rectangle pulse with larger t0 value. Also the Fermi RF pulse is terminated with a 60-dB attenuation. B1 (t) = rfSLR A RF macro that creates a RF pulse using Shinnar-Le Roux algorithm. This macro contains attributes including: PulseType : The type of this SLR pulse, including st (small tip angle pulse), ex (excitation pulse), se (spin-echo pulse), sat (saturation pulse) and inv (inversion pulse) A
45
FilterType : The type of the applied lter design method, including ls (least squares), min (minimum phase), max (maximum phase), pm (Parks-McClellan equal ripple), and ms (Hamming windowed sinc) PRipple : The ripple factor at passband SRipple : The ripple factor at stopband FA (Degree) : Prescribed ip angle TBP : The time bandwidth product dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse MRiLab implements a library of Matlab routines for designing SLR algorithm that is developed originally by John Pauly and published online at http://rsl.stanford.edu/research/software.html. Thorough explanation of the algorithm is beyond the scope of this manual, users who are interested in the SLR algorithm are referred to [6, 7]. rfHyperbolicSecant A RF macro that creates an adiabatic inversion RF pulse based on hyperbolic secant modulation. This macro contains attributes including: Adiab : The adiabatic factor MaxB1 (T) : The maximum B1 eld
46
CHAPTER 5. MRILAB TOOLBOXES TBP : The time bandwidth product dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse The time dependence of the hyperbolic secant RF pulse is given by [6]:
A(t) = A0 sech(t) amplitude modulation (5.6) F (t) = tanh(t) frequency modulation 2 where A0 is the maximum B1 eld corresponding to MaxB1, is a dimensionless adiabatic factor corresponding to Adiab, is an modulation angular frequency. It can be shown that TBP has the relationship with and as T BP = T (5.7)
where T is the pulse width. To satisfy the Adiabatic Condition, the parameter setting has to meet (5.8) A0 rfTanhTan A RF macro that creates an adiabatic inversion RF pulse based on tanh/tan modulation. This macro contains attributes including: MaxB1 (T) : The maximum B1 eld TBP : The time bandwidth product
5.1. RF PULSE DESIGN dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time
47
Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse The tanh/tan RF pulse is constructed from an adiabatic half passage and its time-reversed adiabatic half passage. The time dependence of the rst adiabatic half passage is given by [8]: 2t T ) 0t T 2 t tan((1 2 )) T T F (t) = A 0t 2tan() 2 A(t) = A0 tanh(
where A0 is the maximum B1 eld corresponding to MaxB1, = 10, tan() = 20, T is the pulse width. The TBP can be estimated using T BP = rfBIR A RF macro that creates an adiabatic B1 Independent Rotation (BIR) RF pulse. This macro contains attributes including: MaxB1 (T) : The maximum B1 eld MaxFreq (Hz) : The maximum RF frequency Lambda : The adiabatic factor Beta : The adiabatic factor AT (5.10)
48
CHAPTER 5. MRILAB TOOLBOXES BIRFlag : The type of BIR pulse, including BIR-1, BIR-2 and BIR-4 dt (s) : The time interval of RF pulse sample points tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse
The time dependence of the BIR-1 RF pulse is given by [6]: Amplitude modulation: { x A0 cos(t) 0 t < T 2 A(t) = y A0 cos(t) T t T 2 Frequency modulation: { F0 sin(t) 0t< T 2 F (t) = F0 sin(t) T 2 tT
(5.11)
(5.12)
where A0 is the maximum B1 eld corresponding to MaxB1, F0 is the maximum RF frequency corresponding to MaxFreq. The RF pulse width is T = , and x and y are unit vectors for indicating RF phase. The time dependence of the BIR-2 RF pulse is given by [6]: Amplitude modulation: |A0 cos(t)| 0t< T x 2 T A(t) = y |A0 cos(t)| t < T 2 y |A0 cos(t)| T t 2T Frequency modulation: F (t) = |F0 sin(t)| (5.14)
(5.13)
49
where A0 is the maximum B1 eld corresponding to MaxB1, F0 is the maximum RF frequency corresponding to MaxFreq. The RF pulse width is T = , and x and y are unit vectors for indicating RF phase. The time dependence of the BIR-4 RF pulse is given by [6]: Amplitude modulation: T t A0 tanh[(1 4 T )] 0 t < 4 A tanh[( 4t 1)] T t < T 0 T 4 2 A(t) = 4t T 3T A tanh [ (3 )] t < 0 T 2 4 t 3T A0 tanh[( 4 3)] t T T 4 Frequency modulation: t ) tan( 4T tan ( ) t tan[ ( 4 T 2)] F (t) =
tan( ) t tan[ ( 4 T 2)] tan( ) t tan[ ( 4 T 4)] tan( )
(5.15)
0t<
T 4 t T 2 t 3T 4 t
T 4 <T 2 T < 34
(5.16)
where A0 is the maximum B1 eld corresponding to MaxB1. The RF pulse width is T . The and are dimensionless constants that describe the degree to which extent the RF pulse satises the adiabatic condition. rfBIREF A RF macro that creates an adiabatic B1 Independent Refocusing (BIREF) RF pulse. This macro contains attributes including: MaxB1 (T) : The maximum B1 eld MaxFreq (Hz) : The maximum RF frequency BIREFFlag : The type of BIREF pulse, including BIREF-1, BIREF-2a and BIREF-2b dt (s) : The time interval of RF pulse sample points tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape
50
CHAPTER 5. MRILAB TOOLBOXES DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse
The time dependence of the BIREF-1 RF pulse is given by [6]: Amplitude modulation: { x A0 sin(t) 0t< T 2 A(t) = x A0 sin(t) T 2 tT Frequency modulation: F (t) = F0 |cos(t)|
(5.17)
(5.18)
where A0 is the maximum B1 eld corresponding to MaxB1, F0 is the maximum RF frequency corresponding to MaxFreq. The RF pulse width is T = , and x is an unit vector for indicating RF phase along the x axis. The time dependence of the BIREF-2a RF pulse is given by [6]: Amplitude modulation: A(t) = x A0 |cos(t)| Frequency modulation: { F0 sin(t) 0t< T 2 F (t) = F0 sin(t) T 2 tT
(5.19)
(5.20)
where A0 is the maximum B1 eld corresponding to MaxB1, F0 is the maximum RF frequency corresponding to MaxFreq. The RF pulse width is T = , and x is an unit vector for indicating RF phase along the x axis. The time dependence of the BIREF-2b RF pulse is given by [6]: Amplitude modulation: { x A0 |cos(t)| 0 t < T 2 A(t) = x A0 cos(t) T t T 2 Frequency modulation: 0t< T F0 sin(t) 4 T F (t) = F0 sin(t) T t < 34 4 3T F0 sin(t) 4 tT
(5.21)
(5.22)
where A0 is the maximum B1 eld corresponding to MaxB1, F0 is the maxi mum RF frequency corresponding to MaxFreq. The RF pulse width is T = 2 , and x is an unit vector for indicating RF phase along the x axis.
51
A RF macro that creates a RF pulse with normally distributed pseudo-random amplitude. This macro is used for program testing purpose, however it shows that almost any arbitrary RF pulse is supported by MRiLab. This macro contains attributes including: rfGain : The standard deviation of the normal distribution dt (s) : The time interval of RF pulse sample points rfPhase (rad) : RF pulse phase rfFreq (Hz) : RF pulse frequency tStart (s) : RF pulse starting time tEnd (s) : RF pulse ending time Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse rfUser If the user has the RF pulse data saved in a MAT le, the user can easily import the RF le into MRiLab pulse design interface by using rfUser macro. The RF pulse MAT le needs to contain four matrices including rfTime (i.e. RF time points) , rfAmp (i.e. RF amplitude), rfPhase (i.e. RF phase) and rfFreq (i.e. RF frequency). All four matrices must have the same size as m-by-n, where m is the number of TR sections and n is the number of RF waveform points. In typical MR sequence, the entire sequence is composed of multiple TR sections. The ith TR section uses the ith RF pulse stored in the ith row of these four matrices. If the number of row is less than the number of TR sections, the last RF pulse will be used for all the remaining TR sections. Notice that if rfPhase and/or rfFreq are not provided, MRiLab initializes them as the value of 0. However, rfTime and rfAmp must be provided. MRiLab only uses the rst RF pulse in the MAT le for analysis in the RF pulse design interface. The rfUser macro contains attributes including:
52
CHAPTER 5. MRILAB TOOLBOXES rfFile : The path to the le that stores the RF pulse data, quoted using single quotes Switch : The ag for turning on and o RF pulse in the RF sequence line AnchorTE : The ag for turning on and o TE reference, TE is calculated from this RF pulse if this ag is turned on Duplicates : The number of the RF pulse duplicates, used for creating multiple RF pulses with the same shape DupSpacing : The time spacing between RF pulse duplicates CoilID : The ID of the coil element used with this RF pulse, applied for multiple RF transmitting Notes : The notes of the RF pulse
5.1.3
The RF pulse macro library covers several common types of RF pulse waveform in current MRI eld. However, due to the extremely enriched novel RF pulse types that are under development, comprehensive coverage of those RF pulses is nearly impossible for almost any pulse sequence design tools. To somehow address this problem in MRiLab, the user can use the rfUser to import RF pulses from les that are generated by other programs. Another way to import RF pulse is to simply write a RF macro. To create a RF macro, the user should follow the following steps : 1. Write RF macro code It is strongly recommended to write your own RF macro code based on the closest RF macros in the MRiLab macro library, for example, the rfRect macro is coded as: function [rfAmp,rfPhase,rfFreq,rfCoil,rfTime]=rfRect(p) %Create a hard RF pulse starting from tStart and ending at tEnd %tStart RF start time %tEnd RF end time %FA RF actual flip angle %dt RF sample time %rfPhase RF phase %rfFreq RF off-res freq tStart=p.tStart; tEnd=p.tEnd; FA=p.FA; dt=p.dt;
5.1. RF PULSE DESIGN rfPhase=p.rfPhase; rfFreq=p.rfFreq; rfCoil=p.CoilID; Duplicates=max(1,p.Duplicates); DupSpacing=max(0,p.DupSpacing); rfTime=linspace(tStart,tEnd,ceil((tEnd-tStart)/dt)+1); rfAmp=ones(size(rfTime)); % Rectangle rfAmp(1)=0; rfAmp(end)=0; rfAmp=DoB1Scaling(rfAmp,dt,FA)*rfAmp; %B1 Scaling rfPhase=(rfPhase)*ones(size(rfTime)); rfFreq=(rfFreq)*ones(size(rfTime)); rfCoil=(rfCoil)*ones(size(rfTime)); rfPhase(1)=0; rfPhase(end)=0; rfFreq(1)=0; rfFreq(end)=0;
53
% Create Duplicates if Duplicates~=1 & DupSpacing ~=0 rfAmp=repmat(rfAmp,[1 Duplicates]); rfFreq=repmat(rfFreq,[1 Duplicates]); rfPhase=repmat(rfPhase,[1 Duplicates]); rfCoil=repmat(rfCoil,[1 Duplicates]); TimeOffset = repmat(0:DupSpacing:(Duplicates-1)*DupSpacing, ... [length(rfTime) 1]); rfTime=repmat(rfTime,[1 Duplicates]) + (TimeOffset(:)); end end Your macro must start from the function declaration at the beginning, then followed by attribute input section. The tStart and tEnd need to be added for indicating the time scale. Its also strongly recommended to add attribute input rfCoil,Duplicates and DupSpacing for multitransmitting and multi-echo support. function [rfAmp,rfPhase,rfFreq,rfCoil,rfTime]=rfMacroName(p) %Create a RF pulse based on your code tStart=p.tStart; tEnd=p.tEnd; rfCoil=p.CoilID; Duplicates=max(1,p.Duplicates);
54
CHAPTER 5. MRILAB TOOLBOXES DupSpacing=max(0,p.DupSpacing); ... attribute1=p.attribute1; attribute2=p.attribute2; attribute3=p.attribute3; ... The main code should deal with calculation for rfAmp, rfPhase, rfFreq and rfTime. Notice that they all should have the same size as 1-by-m where m is the number of RF waveform points. % The main code for your macro ... rfTime = ...; rfAmp = ...; rfPhase = ...; rfFreq = ...; ... Then you should add several lines of code to end your macro, % Avoid baseline offset rfAmp(1)=0; rfAmp(end)=0; rfPhase(1)=0; rfPhase(end)=0; rfFreq(1)=0; rfFreq(end)=0; % Assign coil element index number rfCoil=(rfCoil)*ones(size(rfTime)); % Create Duplicates if Duplicates~=1 & DupSpacing ~=0 rfAmp=repmat(rfAmp,[1 Duplicates]); rfFreq=repmat(rfFreq,[1 Duplicates]); rfPhase=repmat(rfPhase,[1 Duplicates]); rfCoil=repmat(rfCoil,[1 Duplicates]); TimeOffset=repmat(0:DupSpacing:(Duplicates-1)*DupSpacing, ... [length(rfTime) 1]); rfTime=repmat(rfTime,[1 Duplicates]) + (TimeOffset(:)); end
2. Register RF macro
55
The RF macro le can be put anywhere in the computer as long as the le is included in Matlab searching path, however it is recommended to put the le under /SeqElem/rf for consistent le organization. Besides the RF macro le that performs the main function, MRiLab also requires a memo .txt le that accompanies the RF macro with the name rfMacroName Memo. This le contains information about RF pulse description if necessary. The customized RF macro needs to be registered in the macro library before using. To register the macro, the user need to open le SeqElem.xml under /SeqElem, then add one entry under <rf> category with the proper attribute list. One example could be <rfMacroName AnchorTE="$2on,off" CoilID="1" DupSpacing="0" Duplicates="1" Switch="$1on,off" tEnd="1e-3" tStart="0" Notes="A new RF macro" attribute1="0" attribute2="0" attribute3="0" /> Notice that in the above example, the rst 7 attributes are required for MRiLab, The remaining attributes are optional based on the macro itself. Once the RF macro is coded and registered to the library, the user can use this customized RF macro just like those default RF macros in the library.
5.2
MR Sequence Design
The MR Sequence Design toolbox can be activated by pressing Sequence Design Panel toolbar icon located at the top of the main simulation console. The loaded sequence will show in the MR Sequence Design interface.
5.2.1
Figure 5.10 demonstrates the overview of the MR Sequence Design interface. This interface consists of
56
Figure 5.10: Sequence Design GUI. A bSSFP sequence is shown. 1. Macro Library The MRiLab Macro Library contains a full set of pulse macros for constructing MR sequence in MRiLab. It covers not only RF macro library as described in above section, but also GzSS, GyPE and GxR gradient macro library, ADC macro library and Ext macro library. The latter libraries will be introduced in the following sections in this chapter. The user needs to click the SeqElem root and then the subsequent nodes to unfold these macros. 2. Sequence Structure In MRiLab, a MR sequence consists of the following parts : CVs : The controllable variables, linked to the CVs tab on the main control console Specials : The applied special techniques, determining the default loading special techniques SE : The starting (tS) and ending (tE) time, determining time scale for each TR section, support varying TR value Pulse RF : RF sequence line GzSS : GzSS sequence line GyPE : GyPE sequence line
57
Figure 5.11: An Example of A Typical MR Sequence Structure in MRiLab GxR : GxR sequence line ADC : Signal acquisition sequence line Ext : Extended process sequence line The user can construct wanted MR sequence by changing the content within the MR sequence structure. To add a macro into the sequence structure, the user needs to click one macro in the macro library, then click on the sequence line root (e.g. rf) to which this macro is inserted, then click + macro operation button. To delete a macro from the sequence structure, the user needs to click the unwanted macro at the sequence line, then click - macro operation button. To duplicate an existing macro, the user needs to rst click the source macro, then click C macro operation button for copying, click on the sequence line root, then click P macro operation button for pasting. MRiLab requires that the pulse macro is operated within its belonging category for proper conguration. And MRiLab doesnt allow empty sequence lines.
58
When clicking on the pulse macro within the MR sequence structure, the corresponding macro attributes will be updated at the pulse attribute panel down below the sequence structure. The user can edit those attributes to modify the MR sequence waveform. To make the modication eective, the user must press Update button to update the sequence le. Pressing Execute button will update and redraw the MR sequence waveform on this interface. 4. Sequence Waveform The sequence waveform associated with the sequence structure is displayed on the Sequence Diagram panel on the right side of this interface. The user can use the waveform diagram to inspect sequence details and layout. The sequence diagram consists of individual sequence lines corresponding to RF, GzSS, GyPE, GxR, ADC and Ext. To accommodate multiple RF transmitting, MRiLab provides separate RF sequence lines for each RF source. When MultiTransmit ag is turned on in the main control console and the chosen sequence structure contains multiple RF pulses for dierent RF sources (i.e. assign RF pulses to dierent coil channels by using CoilID attribute), the multi-tab will be activated on the rf Source panel (Figure 5.13). The user can switch between these tabs for checking individual RF source.
Figure 5.13: An Example of Multiple RF Source. The MultiTransmit is turned on and this sequence contains total 4 RF sources. The RF source 2 is chosen and the corresponding RF pulse waveform for coil channel 2 is shown. Notice that the vertical axes for all sequence lines are normalized and the horizontal axes are in units of milliseconds. MRiLab provides a group of sequence display button (Figure 5.14) to help inspecting the sequence waveform details. The sequence display button group consists of :
59
Figure 5.14: The Sequence Display Button. Checker : The time checker toggle button Time Ruler : Display current time point according to the time checker | <<: Move sequence waveform to the beginning <<< : Move sequence waveform backwards > || < : Zoom out TR : Display a sequence waveform section with a time interval of TR ALL : Display all sequence waveform < || > : Zoom in >>>: Move sequence waveform forwards >> | : Move sequence waveform to the end To display a sequence waveform with any arbitrary time interval (Figure 5.15), the user can use the Checker toggle button. First press the Checker button, move the mouse cursor into the axes. Notice that the mouse cursor changes to a cross-hair. Move the cross-hair in the axes, the amplitude value for each sequence line will be displayed accordingly on right side of each line with their default units. The user can click on the axes for choosing one side of the time slot, then click on the another side. MRiLab will change the sequence view between the chosen time points, and also save time point information in the list at the bottom of this interface. To disable Checker function, simple press this button again. 5. Display Control The Display tab on the Sequence Display contains parameters for controlling sequence display and K-Space rendering. TRStart : The rst TR to be displayed TREnd : The last TR to be displayed Moments (:TODO) : The ag for turning on and o the zeroth moment display for the gradient RenderMode : The K-Space rendering mode, including Matlab (Figure 5.16) and VTK (Figure 5.17) RenderPoint : The ag for turning on and o K-Space point rendering Notice that the K-Space line color starts from green and ends to red in VTK rendering. If the user uses VTK for K-Space rendering, please press
60
Figure 5.16: Matlab Rendered K-Space Trajectory for A Spiral Readout with 5 Interleaves. The left gure is without K-Space point rendering. The right gure is with K-Space point rendering with the arrows indicating K-Space traversing direction.
61
Figure 5.17: VTK Rendered K-Space Trajectory Examples. The top left gure shows a typical single slice Cartesian readout. The top right gure shows a single slice multishot EPI readout. The bottom left gure shows a single slice multishot spiral readout. The bottom right gure shows a 3D Stack-of-Stars radial readout.
62
CHAPTER 5. MRILAB TOOLBOXES keyboard q to quit the VTK window before any subsequent simulation. Pressing the quit button on the VTK window under Linux system will force the entire Matlab to close, this is believed to be a compatibility bug between Matlab and OpenGL which is used by VTK.
5.2.2
Virtual Structure
For the convenience of transferring data and conguration information across dierent modules, MRiLab dened several Matlab structure variables in the global scope. These structures start with V standing for Virtual Structure. Understanding what these structures are and how they are working is important to work with MRiLab and to customize specic experiment design. There are at least two virtual structures that are useful for designing MR sequences. VCtl : Virtual Control VCtl encapsules all the simulation setting parameters in the main control console. For example, the user can use VCtl.TE to reference TE value in the main control console; use VCtl.FlipAng to reference FlipAng value in the main control console. VCtl also allows the user to reference parameters in special techniques if loaded. Another example is that MRiLab uses VCtl.TR in the SE for determining time interval for each TR section. The user can use any legal Matlab syntax combined with VCtl to create desired eect, such as use 2 * VCtl.TR to indicate twice of TR value. VVar : Virtual Variable VVar encapsules the loop index variables that MRiLab uses for generating MR sequence signal. A section of code for generating MR sequence is shown: % MR Sequence Generating Loop VVar.SliceCount=0; VVar.PhaseCount=0; VVar.TRCount=0; s=1; j=1; while s<=VCtl.SecondPhNum VVar.SliceCount=s; while j<=VCtl.FirstPhNum VVar.PhaseCount=j; VVar.TRCount=VVar.TRCount+1; ... Sequence Generating Code ...
63
j=j+1; end j=1; s=s+1; end The user can use the loop index variables in VVar VVar.TRCount : The TR section index VVar.PhaseCount : The rst phase encoding index VVar.SliceCount : The second (i.e. slice) phase encoding index VCtl.FirstPhNum : The total number of rst phase encoding steps VCtl.SecondPhNum : The total number of second phase encoding steps For example, to create 180 RF phase cycling in bSSFP sequence, the user can set the attributes for the excitation RF pulse as CV3 : 2*pi/2 CV4 : 2 rfPhase : rem(VVar.TRCount-1,CV4)*CV3
5.2.3
A GzSS macro is a predened module for a gradient pulse on the GzSS sequence line. MRiLab GzSS macro library is a collection of GzSS macros covering dierent gradient pulse types including slice selection and slice phase encoding pulses. Notice that by default the area under the gradient ramp is ignored. This section will give an introduction for each of the GzSS macros provided in MRiLab. GzSelective A GzSS macro that creates a typical slice selective gradient pulse (Figure 5.18). This macro contains attributes including: t2Start (s) : Slice selection gradient pulse starting time t2End (s) : Slice selection gradient pulse ending time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side GzAmp (T) : The amplitude of the gradient Gz1Sign : The polarity of the prephasing gradient, set 0 for nulling
64
CHAPTER 5. MRILAB TOOLBOXES Gz2Sign : The polarity of the slice selection gradient, set 0 for nulling Gz3Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
Notice that both the prephasing gradient and rephasing gradient have half of the area of the slice selection gradient.
GzSelective2 A GzSS macro that creates a slice selective gradient pulse straddled with crusher gradient (Figure 5.19). This macro contains attributes including: t2Start (s) : Slice selection gradient pulse starting time t2End (s) : Slice selection gradient pulse ending time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side tGz1 (s) : The duration of the left crusher tGz3 (s) : The duration of the right crusher Gz1Amp (T) : The amplitude of the left crusher Gz2Amp (T) : The amplitude of the slice selective gradient Gz3Amp (T) : The amplitude of the right crusher Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
65
Figure 5.19: GzSelective2 Waveform GzTrapezoid A GzSS macro that creates a trapezoid gradient pulse (Figure 5.20) on GzSS sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time tRamp (s) : The trapezoid pulse ramp time, assume symmetric ramp on both side sRamp : The sample points on the ramp, use the value of 2 for ignoring the area under the ramp, use above 2 for counting the ramp area GzAmp (T) : The amplitude of the gradient Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
GzAreaTrapezoid A GzSS macro that creates a trapezoid gradient pulse of specied area (Figure 5.21) on GzSS sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time Area (1/m) : The area under this gradient pulse
66
CHAPTER 5. MRILAB TOOLBOXES Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
GzAreaTrapezoid2 A GzSS macro that creates a trapezoid gradient pulse of specied area with highest system performance (Figure 5.22) on GzSS sequence line. This macro creates a gradient pulse with nearly shortest pulse width for the given system hardware constraint. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time Area (1/m) : The area under this gradient pulse Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
67
A GzSS macro that creates a Cartesian phase encoding gradient pulse (Figure 5.23) along the slice direction. This macro contains attributes including: t1Start (s) : The phase encoding gradient pulse starting time t1End (s) : The phase encoding gradient pulse ending time t2Start (s) : The rephasing gradient pulse starting time t2End (s) : The rephasing gradient pulse ending time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side Gz1Sign : The polarity of the phase encoding gradient, set 0 for nulling Gz2Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse Notice that the phase encoding gradient and the rephasing gradient have the same area that is automatically calculated based on the imaging parameters in the main control console.
GzUser If the user has the gradient pulse data saved in a MAT le, the user can easily import the gradient le into MRiLab by using GzUser macro. The gradient pulse MAT le needs to contain two matrices including GTime (i.e. gradient time points) and GAmp (i.e. gradient amplitude). Both matrices must have the same size as m-by-n, where m is the number of TR sections and n is the number of gradient waveform points. In typical MR sequence, the entire sequence is composed of multiple TR sections. The ith TR section uses the ith gradient pulse stored in the ith row of these two matrices. If the number of row is less than the number of TR sections, the last gradient pulse will be used for all the remaining TR sections. The GzUser macro contains attributes including:
68
CHAPTER 5. MRILAB TOOLBOXES GzFile : The path to the le that stores the gradient pulse data, quoted using single quotes Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
5.2.4
A GyPE macro is a predened module for a gradient pulse on the GyPE sequence line. MRiLab GyPE macro library is a collection of GyPE macros covering dierent gradient pulse types for performing phase encoding. Notice that by default the area under the gradient ramp is ignored. This section will give an introduction for each of the GyPE macros provided in MRiLab. GyTrapezoid Similar to GzTrapezoid (Figure 5.20), GyTrapezoid creates a trapezoid gradient pulse on GyPE sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time tRamp (s) : The trapezoid pulse ramp time, assume symmetric ramp on both side sRamp : The sample points on the ramp, use the value of 2 for ignoring the area under the ramp, use above 2 for counting the ramp area GyAmp (T) : The amplitude of the gradient Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
69
Similar to GzAreaTrapezoid (Figure 5.21), GyAreaTrapezoid creates a trapezoid gradient pulse of specied area on GyPE sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time Area (1/m) : The area under this gradient pulse Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse GyAreaTrapezoid2 Similar to GzAreaTrapezoid2 (Figure 5.22), GyAreaTrapezoid2 creates a trapezoid gradient pulse of specied area with highest system performance on GyPE sequence line. This macro creates a gradient pulse with nearly shortest pulse width for the given system hardware constraint. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time Area (1/m) : The area under this gradient pulse Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse GyCartesian Similar to GzCartesian (Figure 5.23), GyCartesian creates a Cartesian phase encoding gradient pulse on GyPE sequence line. This macro contains attributes including: t1Start (s) : The phase encoding gradient pulse starting time
70
CHAPTER 5. MRILAB TOOLBOXES t1End (s) : The phase encoding gradient pulse ending time t2Start (s) : The rephasing gradient pulse starting time t2End (s) : The rephasing gradient pulse ending time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side Gy1Sign : The polarity of the phase encoding gradient, set 0 for nulling Gy2Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
Notice that the phase encoding gradient and the rephasing gradient have the same area that is automatically calculated based on the imaging parameters in the main control console. GyRadial A GyPE macro that creates a phase encoding gradient pulse for radial K-Space trajectory (Figure 5.24) on GyPE sequence line. This macro contains attributes including: t1Start (s) : The prephasing gradient pulse starting time t2Middle (s) : The phase encoding gradient pulse middle time t3Start (s) : The rephasing gradient pulse starting time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side Gy1Sign : The polarity of the prephasing gradient, set 0 for nulling Gy2Sign : The polarity of the phase encoding gradient, set 0 for nulling Gy3Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse
71
Notice that both the prephasing gradient and rephasing gradient have half of the area of the phase encoding gradient that is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the Radial special technique tab to be loaded for properly conguring the GyRadial, GxRadial and ADCRadial macro. The user can set t2Middle value as VCtl.TE to acquire the echo signal.
GySpiral A GyPE macro that creates a phase encoding gradient pulse for spiral K-Space trajectory (Figure 5.25) on GyPE sequence line. This macro contains attributes including: tStart (s) : The phase encoding gradient pulse starting time dt (s) : The time interval of gradient pulse sample points Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse Notice that the area of the phase encoding gradient is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the Spiral special technique tab to be loaded for properly conguring the GySpiral, GxSpiral and ADCSpiral macro. The user can set tStart value as VCtl.TE to acquire the echo signal.
GyFSE A GyPE macro that creates a FSE phase encoding gradient pulse train (Figure 5.26) on GyPE sequence line. This macro contains attributes including: tMiddle (s) : The middle time of the gradient pulse train tOset (s) : The time oset of the gradient pulse
72
CHAPTER 5. MRILAB TOOLBOXES tGy1 (s) : The duration of the phase encoding gradient tGy2 (s) : The duration of the rephasing gradient Gy1Sign : The polarity of the phase encoding gradient, set 0 for nulling Gy2Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse
Notice that the phase encoding gradient and the rephasing gradient have the same area that is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the FSE special technique tab to be loaded for properly conguring the GyFSE, GxFSE and ADCFSE macro. To satisfy Carr Purcell Meiboom Gill (CPMG) condition and acquire echo signal at the center between two consecutive refocusing RF pulse, the eective TE value must equal (oor(FSE ETL/2)+1)*FSE ESP. The user can set tMiddle value as VCtl.TE to acquire the echo signal, where the VCtl.TE becomes the eective TE value.
GyEPI A GyPE macro that creates an EPI phase encoding gradient pulse train (Figure 5.27) on GyPE sequence line. This macro contains attributes including: t2Middle (s) : The middle time of the blip gradient pulse train t1Start (s) : The prephasing gradient starting time Gy1Sign : The polarity of the prephasing gradient, set 0 for nulling Gy2Sign : The polarity of the blip gradient train, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse
73
Notice that the area of the prephasing gradient and the blip gradient are automatically calculated based on the imaging parameters in the main control console. MRiLab requires the EPI special technique tab to be loaded for properly conguring the GyEPI, GxEPI and ADCEPI macro. The user can set t2Middle value as VCtl.TE to acquire the echo signal, where the VCtl.TE becomes the eective TE value.
GyUser If the user has the gradient pulse data saved in a MAT le, the user can easily import the gradient le into MRiLab by using GyUser macro. The gradient pulse MAT le needs to contain two matrices including GTime (i.e. gradient time points) and GAmp (i.e. gradient amplitude). Both matrices must have the same size as m-by-n, where m is the number of TR sections and n is the number of gradient waveform points. In typical MR sequence, the entire sequence is composed of multiple TR sections. The ith TR section uses the ith gradient pulse stored in the ith row of these two matrices. If the number of row is less than the number of TR sections, the last gradient pulse will be used for all the remaining TR sections. The GyUser macro contains attributes including: GyFile : The path to the le that stores the gradient pulse data, quoted using single quotes Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
5.2.5
A GxR macro is a predened module for a gradient pulse on the GxR sequence line. MRiLab GxR macro library is a collection of GxR macros covering different gradient pulse types for performing frequency encoding. Notice that by default the area under the gradient ramp is ignored. This section will give an introduction for each of the GxR macros provided in MRiLab.
74 GxTrapezoid
Similar to GzTrapezoid (Figure 5.20), GxTrapezoid creates a trapezoid gradient pulse on GxR sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time tRamp (s) : The trapezoid pulse ramp time, assume symmetric ramp on both side sRamp : The sample points on the ramp, use the value of 2 for ignoring the area under the ramp, use above 2 for counting the ramp area GxAmp (T) : The amplitude of the gradient Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse GxAreaTrapezoid Similar to GzAreaTrapezoid (Figure 5.21), GxAreaTrapezoid creates a trapezoid gradient pulse of specied area on GxR sequence line. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time tEnd (s) : The trapezoid gradient pulse ending time Area (1/m) : The area under this gradient pulse Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
75
Similar to GzAreaTrapezoid2 (Figure 5.22), GxAreaTrapezoid2 creates a trapezoid gradient pulse of specied area with highest system performance on GxR sequence line. This macro creates a gradient pulse with nearly shortest pulse width for the given system hardware constraint. This macro contains attributes including: tStart (s) : The trapezoid gradient pulse starting time Area (1/m) : The area under this gradient pulse Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse GxCartesian A GxR macro that creates a Cartesian frequency encoding gradient pulse (Figure 5.28) on GxR sequence line. This macro contains attributes including: t1Start (s) : The prephasing gradient pulse starting time t2Middle (s) : The frequency encoding gradient pulse middle time t3Start (s) : The rephasing gradient pulse starting time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side Gx1Sign : The polarity of the prephasing gradient, set 0 for nulling Gx2Sign : The polarity of the frequency encoding gradient, set 0 for nulling Gx3Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse Notice that both the prephasing gradient and rephasing gradient have half of the area of the frequency encoding gradient.
76
Figure 5.28: GxCartesian Waveform GxRadial Similar to GyRadial (Figure 5.24), GxRadial creates a phase encoding gradient pulse for radial K-Space trajectory on GxR sequence line. This macro contains attributes including: t1Start (s) : The prephasing gradient pulse starting time t2Middle (s) : The phase encoding gradient pulse middle time t3Start (s) : The rephasing gradient pulse starting time tRamp (s) : Gradient pulse ramp time, assume symmetric ramp on both side Gx1Sign : The polarity of the prephasing gradient, set 0 for nulling Gx2Sign : The polarity of the phase encoding gradient, set 0 for nulling Gx3Sign : The polarity of the rephasing gradient, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse Notice that both the prephasing gradient and rephasing gradient have half of the area of the phase encoding gradient that is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the Radial special technique tab to be loaded for properly conguring the GyRadial, GxRadial and ADCRadial macro. The user can set t2Middle value as VCtl.TE to acquire the echo signal. GxSpiral Similar to GySpiral (Figure 5.25), GxSpiral creates a phase encoding gradient pulse for spiral K-Space trajectory on GxR sequence line. This macro contains attributes including: tStart (s) : The phase encoding gradient pulse starting time dt (s) : The time interval of gradient pulse sample points Switch : The ag for turning on and o gradient pulse in the sequence line
77
Notice that the area of the phase encoding gradient is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the Spiral special technique tab to be loaded for properly conguring the GySpiral, GxSpiral and ADCSpiral macro. The user can set tStart value as VCtl.TE to acquire the echo signal. GxFSE A GxR macro that creates a FSE frequency encoding gradient pulse train (Figure 5.29) on GxR sequence line. This macro contains attributes including: t2Middle (s) : The middle time of the gradient pulse train t1Start (s) : The prephasing gradient starting time Gx1Sign : The polarity of the prephasing gradient, set 0 for nulling Gx2Sign : The polarity of the frequency encoding gradient train, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse Notice that the prephasing gradient has half of the area of the frequency encoding gradient that is automatically calculated based on the imaging parameters in the main control console. MRiLab requires the FSE special technique tab to be loaded for properly conguring the GyFSE, GxFSE and ADCFSE macro. To satisfy CPMG condition and acquire echo signal at the center between two consecutive refocusing RF pulse, the eective TE value must equal (oor(FSE ETL/2)+1)*FSE ESP. The user can set t2Middle value as VCtl.TE to acquire the echo signal, where the VCtl.TE becomes the eective TE value.
GxEPI A GxR macro that creates an EPI frequency encoding gradient pulse train (Figure 5.30) on GxR sequence line. This macro contains attributes including:
78
CHAPTER 5. MRILAB TOOLBOXES t2Middle (s) : The middle time of the frequency encoding gradient pulse train t1Start (s) : The prephasing gradient starting time Gx1Sign : The polarity of the prephasing gradient, set 0 for nulling Gx2Sign : The polarity of the frequency encoding gradient train, set 0 for nulling Switch : The ag for turning on and o gradient pulse in the sequence line Notes : The notes of the gradient pulse
Notice that the area of the prephasing gradient and the frequency encoding gradient are automatically calculated based on the imaging parameters in the main control console. MRiLab requires the EPI special technique tab to be loaded for properly conguring the GyEPI, GxEPI and ADCEPI macro. The user can set t2Middle value as VCtl.TE to acquire the echo signal, where the VCtl.TE becomes the eective TE value.
GxUser If the user has the gradient pulse data saved in a MAT le, the user can easily import the gradient le into MRiLab by using GxUser macro. The gradient pulse MAT le needs to contain two matrices including GTime (i.e. gradient time points) and GAmp (i.e. gradient amplitude). Both matrices must have the same size as m-by-n, where m is the number of TR sections and n is the number of gradient waveform points. In typical MR sequence, the entire sequence is composed of multiple TR sections. The ith TR section uses the ith gradient pulse stored in the ith row of these two matrices. If the number of row is less than the number of TR sections, the last gradient pulse will be used for all the remaining TR sections. The GxUser macro contains attributes including: GxFile : The path to the le that stores the gradient pulse data, quoted using single quotes Switch : The ag for turning on and o gradient pulse in the sequence line Duplicates : The number of the gradient pulse duplicates, used for creating multiple gradient pulses with the same shape
5.2. MR SEQUENCE DESIGN DupSpacing : The time spacing between gradient pulse duplicates Notes : The notes of the gradient pulse
79
5.2.6
An ADC macro is a predened module for an ADC ag pulse on the ADC sequence line. Signal acquisition starts when ADC ag is 1 and stops when ADC ag is 0. The ADC ag pulse is sampled at certain sampling rate that is determined by the imaging parameters (default by using BandWidth) in the main control console. MRiLab ADC macro library is a collection of ADC macros covering dierent pulse types for performing signal acquisition. This section will give an introduction for each of the ADC macros provided in MRiLab. ADCBlock An ADC macro that creates an ADC ag pulse with user dened sampling rate on ADC sequence line. This macro contains attributes including: tStart (s) : The ADC starting time tEnd (s) : The ADC ending time sSample : The number of linear sample points when ADC ag is 1 Switch : The ag for turning on and o ADC pulse in the sequence line Duplicates : The number of the ADC pulse duplicates, used for creating multiple ADC pulses with the same shape DupSpacing : The time spacing between ADC pulse duplicates Notes : The notes of the ADC pulse
ADCCartesian An ADC macro that creates an ADC ag pulse for Cartesian readout on ADC sequence line. This macro contains attributes including: tMiddle (s) : The ADC middle time, typically set VCtl.TE for acquiring echo signal Switch : The ag for turning on and o ADC pulse in the sequence line
80
CHAPTER 5. MRILAB TOOLBOXES Duplicates : The number of the ADC pulse duplicates, used for creating multiple ADC pulses with the same shape DupSpacing : The time spacing between ADC pulse duplicates Notes : The notes of the ADC pulse
ADCRadial An ADC macro that creates an ADC ag pulse for radial readout on ADC sequence line. This macro needs Radial tab to be loaded. This macro contains attributes including: tMiddle (s) : The ADC middle time, typically set VCtl.TE for acquiring echo signal Switch : The ag for turning on and o ADC pulse in the sequence line Notes : The notes of the ADC pulse ADCSpiral An ADC macro that creates an ADC ag pulse for spiral readout on ADC sequence line. This macro needs Spiral tab to be loaded. This macro contains attributes including: tStart (s) : The ADC starting time, typically set VCtl.TE for acquiring echo signal Switch : The ag for turning on and o ADC pulse in the sequence line Notes : The notes of the ADC pulse ADCFSE An ADC macro that creates an ADC ag pulse train for FSE readout on ADC sequence line. This macro needs FSE tab to be loaded. This macro contains attributes including: tMiddle (s) : The ADC pulse train middle time, typically set VCtl.TE for acquiring echo signal Switch : The ag for turning on and o ADC pulse in the sequence line Notes : The notes of the ADC pulse
81
An ADC macro that creates an ADC ag pulse train for EPI readout on ADC sequence line. This macro needs EPI tab to be loaded. This macro contains attributes including: tMiddle (s) : The ADC pulse train middle time, typically set VCtl.TE for acquiring echo signal Switch : The ag for turning on and o ADC pulse in the sequence line Notes : The notes of the ADC pulse ADCUser If the user has the ADC pulse data saved in a MAT le, the user can easily import the ADC le into MRiLab by using ADCUser macro. The ADC pulse MAT le needs to contain two matrices including GTime (i.e. ADC time points) and GAmp (i.e. ADC amplitude, use 1 for signal acquisition, 0 for no signal acquisition). Both matrices must have the same size as m-by-n, where m is the number of TR sections and n is the number of ADC sample points. In typical MR sequence, the entire sequence is composed of multiple TR sections. The ith TR section uses the ith ADC pulse stored in the ith row of these two matrices. If the number of row is less than the number of TR sections, the last ADC pulse will be used for all the remaining TR sections. The ADCUser macro contains attributes including: ADCFile : The path to the le that stores the ADC pulse data, quoted using single quotes Switch : The ag for turning on and o ADC pulse in the sequence line Duplicates : The number of the ADC pulse duplicates, used for creating multiple ADC pulses with the same shape DupSpacing : The time spacing between ADC pulse duplicates Notes : The notes of the ADC pulse Notice that ADCUser macro sets the rst and last ADC sample points to 0 regardless of their original value, therefore the signal is not acquired at the rst and last time points.
5.2.7
An Ext macro is a predened module for an Ext ag pulse on the Ext sequence line. MRiLab species Ext signal for performing extended real time processes including calculating remaining scan time, manipulating K-Space location and triggering object motion etc. Ext macro library only contains ExtBit macro, however the Ext attribute in this macro triggers dierent processes.
82 ExtBit
The ExtBit macro (Figure 5.32) creates a triangle blip pulse on Ext sequence line. This macro contains attributes including: tStart (s) : The Ext starting time Ext : The Ext ag Switch : The ag for turning on and o Ext pulse in the sequence line Duplicates : The number of the Ext pulse duplicates, used for creating multiple Ext pulses with the same shape DupSpacing : The time spacing between Ext pulse duplicates Notes : The notes of the Ext pulse
Figure 5.32: ExtBit Waveform Dierent Ext ags execute dierent extended real time processes during runtime scan. These extended processes are implemented using Plugin code in the /Plugin folder. MRiLab reserved several Ext ags for particular purposes. 1 : Plugin ResetK, reset Kx, Ky and Kz to zero 2 : Plugin ReverseK, reverse Kx, Ky and Kz 3 : Plugin LockK, remember current K space location 4 : Plugin ReleaseK, set K space location to the latest remembered one, used after Plugin LockK 5 : Plugin Timer, calculate remaining scan time, display it on the main control console 6 : Plugin IdealCrusher, dephase transverse magnetization of all the spins, set them to zero 7 : Plugin rfRef, remember current rfPhase value and demodulate signal phase according to this value 8 : Plugin ExecuteMotion, trigger object motion
83
5.2.8
The user can dene Ext ags and use Ext Plugin to create extended real time process. To make your own Ext ag and Plugin code, you should follow the following steps : 1. Write Ext Plugin code It is strongly recommended to write your Plugin code based on a template like :
function Plugin_YourPluginName %Create a Ext Plugin based on your code global VCtl % use VCtl structure, read global VVar % use VVar structure, read global VObj % use VObj structure, read global VMag % use VMag structure, read global VCoi % use VCoi structure, read ... % The main code for your Ext Plugin ... end
As mentioned before, VCtl encapsules all the simulation setting parameters in the main control console. VVar not only encapsules the loop index variables that MRiLab uses for generating MR sequence signal, but also contains variables for temporarily buering instant sequence line values during runtime. Do keep in mind, VCtl and VVar are read only, changing values inside these two structures may cause MRiLab crash. VVar.rfAmp (T) : A array with the size of T xCoilN um 1 for storing current RF amplitude VVar.rfPhase (rad) : A array with the size of T xCoilN um 1 for storing current RF phase VVar.rfFreq (Hz) : A array with the size of T xCoilN um 1 for storing current RF frequency VVar.rfCoil : The CoilID of current working coil channel, used in multiple RF transmitting
84
CHAPTER 5. MRILAB TOOLBOXES VVar.rfRef (rad) : The remembered RF phase, used for demodulating signal phase at ADC VVar.GzAmp (T/m) : The current GzSS gradient amplitude VVar.GyAmp (T/m) : The current GyPE gradient amplitude VVar.GxAmp (T/m) : The current GXR gradient amplitude VVar.ADC : The current ADC ag VVar.Ext : The current Ext ag VVar.t (s) : The current time VVar.Kz (1/m) : The current Kz value VVar.Ky (1/m) : The current Ky value VVar.Kx (1/m) : The current Kx value VVar.TRCount : The current TR section index Notice that there are three new Virtual Structures (VObj, VMag and VCoi) in this template, they store the variables about the virtual object, B0 eld and coil B1 eld which are accessible and editable in Plugin code. Do keep in mind, do not change the size of the matrices inside these three structures. VObj.Rho : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing spin density VObj.T1 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T1 relaxation time VObj.T2 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T2 relaxation time VObj.Mx : A matrix with the size of Y Dim XDim ZDim SpinP erV oxel T ypeN um for describing magnetization in x direction VObj.My : A matrix with the size of Y Dim XDim ZDim SpinP erV oxel T ypeN um for describing magnetization in y direction VObj.Mz : A matrix with the size of Y Dim XDim ZDim SpinP erV oxel T ypeN um for describing magnetization in z direction VMag.dWRnd (rad/s) : A matrix with the size of Y Dim XDim ZDim SpinP erV oxel T ypeN um for describing microscopic resonance frequency variation caused by T2* eect VMag.dB0 (T) : A matrix with the size of Y Dim XDim ZDim for describing local B0 eld variation VMag.Gxgrid (m) : A matrix with the size of Y DimXDimZDim for describing spatial grid in X direction
85
VMag.Gygrid (m) : A matrix with the size of Y DimXDimZDim for describing spatial grid in Y direction VMag.Gzgrid (m) : A matrix with the size of Y DimXDimZDim for describing spatial grid in Z direction VCoi.TxCoilmg (T) : A matrix with the size of Y Dim XDim ZDim T xCoilN um for describing the magnitude of transmitting B1+ eld VCoi.TxCoilpe (rad) : A matrix with the size of Y Dim XDim ZDim T xCoilN um for describing the phase of transmitting B1+ eld VCoi.RxCoilx (T) : A matrix with the size of Y Dim XDim ZDim RxCoilN um for describing the x component of receiving B1- eld VCoi.RxCoily (T) : A matrix with the size of Y Dim XDim ZDim RxCoilN um for describing the y component of receiving B1- eld where TxCoilNum is the number of transmitting coil channels, RxCoilNum is the number of receiving coil channels. 2. Register Ext Plugin The user needs to register customized Plugins before MRiLab can use it. To register Plugins and assign Ext ags to them, simply open DoExtPlugin.m under /Src folder. function DoExtPlugin % entry function for extended plugin based on Ext flag global VVar switch VVar.Ext %% System Reserved Ext Flags (Positive) case 0 % normal status % do nothing case 1 % reset K space location Plugin_ResetK; case 2 % reverse K space location Plugin_ReverseK; case 3 % lock K space location Plugin_LockK; case 4 % release K space location Plugin_ReleaseK; case 5 % calculate remaining scan time Plugin_Timer;
86
CHAPTER 5. MRILAB TOOLBOXES case 6 % ideal crusher, dephase Mxy Plugin_IdealCrusher; % wrapper for mex function case 7 % rfRef, demodulate signal phase referring to RF phase at ADC Plugin_rfRef; case 8 % trigger object motion Plugin_ExecuteMotion; %% User Defined Ext Flags (Negative)
end end Add one more Switch case line, assign a distinct Ext ag, then add your Plugin function name under the case line. It is recommended to use negative Ext ag for user dened Plugin to make dierences from system reserved ones.
5.2.9
Besides using macros to import gradient pulse from external les, the user can make customized gradient macros and use them to create desired K-Space trajectory. To make your own gradient macro, you should follow the following steps : 1. Write gradient macro code It is strongly recommended to write your own gradient macro code based on the closest gradient macros in the MRiLab macro library. One template is like : function [GAmp,GTime]=GYourGradientMacroName(p) %Create a gradient macro based on your code global VCtl global VObj % use VCtl structure, read only % use VObj structure, read only
% Create attribute list Duplicates=max(1,p.Duplicates); DupSpacing=max(0,p.DupSpacing); ... attribute1=p.attribute1; attribute2=p.attribute2; attribute3=p.attribute3; ... % The main code for your macro
5.2. MR SEQUENCE DESIGN ... GTime = ...; GAmp = ...; ... % Avoid baseline offset GAmp(1)=0; GAmp(end)=0;
87
% Create Duplicates if Duplicates~=1 & DupSpacing ~=0 GAmp=repmat(GAmp,[1 Duplicates]); TimeOffset = repmat(0:DupSpacing:(Duplicates-1)*DupSpacing, ... [length(GTime) 1]); GTime=repmat(GTime,[1 Duplicates]) + (TimeOffset(:)); end end 2. Register gradient macro The gradient macro le can be put anywhere in the computer as long as the le is included in Matlab searching path, however it is recommended to put the the le under corresponding gradient folder under /SeqElem folder for consistent le organization. The customized gradient macro needs to be registered in the macro library before using. To register the macro, the user need to open le SeqElem.xml under /SeqElem, then add one entry under gradient category with the proper attribute list. One example could be <GzGradientMacroName Switch="$1on,off" DupSpacing="0" Duplicates="1" Notes="A new Gz gradient macro" attribute1="$1on,off" attribute2="0" attribute3="0" />
Notice that in the above example, the rst 3 attributes are required for MRiLab, The remaining attributes are optional based on the macro itself. Once the gradient macro is coded and registered to the library, the user can use this customized gradient macro just like those default gradient macros in the library.
88
5.2.10
To load a sequence into the MR Sequence Design interface, it is recommended to load the sequence into the main control console rst and then click toolbar icon to activate the MR Sequence Design interface. This is mainly because the associated imaging parameters that are necessary for conguring sequence will also be loaded during the sequence loading process at the main control console. However, if the interface has already been activated, the user can also use the sequence loading function to load another sequence with current imaging parameters. To load a sequence, click Load menu then click Load Sequence File, choose a sequence XML le. The user can create a new MR sequence in the MR Sequence Design interface. To create a new sequence, click New then click Create Sequence File. A sequence creation window (Figure 5.33) will show up and ask for new sequence name and notes. To follow MRiLab naming convention, the user is recommended to use PSD followed by a legal name string that is distinct to the remaining sequences in MRiLab. Then click OK to select a path for storing the sequence XML le. Its strongly recommended to put the sequence under the MRiLab sequence root folder /PSD according to the sequence type so that the sequence is visible to MRiLab. Finally, MRiLab will create a new sequence XML le based on the content of PSD GRE3D.
5.2.11
To design and optimize MR sequence, the user may need virtual objects with specic geometry and properties according to their experiment purpose. Although MRiLab provides a wide range of phantoms that cover several tissue types in human, the user may still need to dene customized virtual object. To make your own virtual object, you should follow the following steps : 1. Make Regular Virtual Object Create a Matlab structure VObj. VObj must contains variables including:
5.2. MR SEQUENCE DESIGN Gyro (rad/s/T) : The gyromagnetic ratio of the spin
89
ChemShift (Hz/T) : A array with the size of 1 T ypeN um for describing the chemical shift of the spins XDim : The number of voxels in X direction YDim : The number of voxels in Y direction ZDim : The number of voxels in Z direction XDimRes (m) : The voxel size in X direction YDimRes (m) : The voxel size in Y direction ZDimRes (m) : The voxel size in Z direction Type : A string for describing the type of the spin TypeNum : The number of spin species Rho : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing spin density T1 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T1 relaxation time T2 (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T2 relaxation time T2Star (s) : A matrix with the size of Y Dim XDim ZDim T ypeN um for describing T2* relaxation time Then save the VObj structure as a MAT le. 2. Make Virtual Object with Magnetization Transfer Properties The current version of MRiLab only supports two-pool MT model [9] with GPU acceleration. So the VObj must have the structure like: Gyro (rad/s/T) : The gyromagnetic ratio of the spin ChemShift (Hz/T) : A array with the size of 1 2 for describing the chemical shift of the spins, free pool rst, bound pool second XDim : The number of voxels in X direction YDim : The number of voxels in Y direction ZDim : The number of voxels in Z direction XDimRes (m) : The voxel size in X direction YDimRes (m) : The voxel size in Y direction ZDimRes (m) : The voxel size in Z direction Type : A string for describing the type of the spin TypeNum : 2
90
CHAPTER 5. MRILAB TOOLBOXES Rho : A matrix with the size of Y Dim XDim ZDim 2 for describing spin density, Rhof (free pool) rst, Rhob (bound pool) second T1 (s) : A matrix with the size of Y Dim XDim ZDim 2 for describing T1 relaxation time, free pool rst, bound pool second T2 (s) : A matrix with the size of Y Dim XDim ZDim 2 for describing T2 relaxation time, free pool rst, bound pool second T2Star (s) : A matrix with the size of Y Dim XDim ZDim 2 for describing T2* relaxation time, free pool rst, bound pool second K (1/s) : A matrix with the size of Y Dim XDim ZDim 2 for describing MT cross-relaxation rate, Kf b (free pool to bound pool) rst, Kbf (bound pool to free pool) second Notice that the two-pool MT model needs to satisfy chemical equilibrium described as Rhof Kf b = Rhob Kbf . After making VObj, then save the VObj structure as a MAT le. In MRiLab, the Bloch-equation solving kernel is only executed when the value of any sequence line needs to be updated. The time point at which this updating is happening is referred to as execution point. To accurately model MT exchange during scan, the user needs to create execution points on the entire RF sequence line. A typical method is to insert a long RF pulse with zero amplitude at the empty portion of the RF sequence line. The interested users are referred to PSD SPGR3DMT for more information.
5.3
Coil B1 Design
The Coil B1 Design toolbox can be activated by pressing Coil Design Panel toolbar icon located at the top of the main simulation console. Depending on Tx or Rx is selected on the Coil Selection panel, the loaded coil will show in the Coil B1 Design interface.
5.3.1
Figure 5.35 demonstrates the overview of the Coil B1 Design interface. This interface consists of 1. Coil Element Macro Library
91
Figure 5.35: Coil B1 Design GUI. An eight channel coil is shown. The Coil Element Macro Library contains coil element macros for constructing coil structure in MRiLab. The user needs to click the CoilElem root to unfold subsequent macros. 2. Coil Structure In MRiLab, a coil structure consists of arbitrary number of coil elements that are combined to create desired B1 eld. The user can construct wanted B1 eld by changing the content within the coil structure. To add a macro into the coil structure, the user needs to click one macro in the macro library, then click on the coil structure root (i.e. MRiLabCoil) to which this macro is inserted, then click + macro operation button. To delete a macro from the coil structure, the user needs to click the unwanted macro, then click - macro operation button. To duplicate an existing macro, the user needs to rst click the source macro, then click C macro operation button for copying, click on the coil structure root, then click P macro operation button for pasting. MRiLab doesnt allow empty coil structure. 3. Coil Element Attribute When clicking on the coil element macro within the coil structure, the cor-
92
CHAPTER 5. MRILAB TOOLBOXES responding macro attributes will be updated at the coil element attribute panel down below the coil structure. The user can edit those attributes to modify the coil element so as to change generated B1 eld. To make the modication eective, the user must press Update button to update the coil le. Pressing Execute button will update and redraw the B1 eld map on this interface. 4. Coil B1 Field The coil conguration and B1 eld (T) associated with the coil structure is displayed on the Coil Sensitivity panel on the right side of this interface. 5. Coil Simulation Control The Display and Grid tab on the Coil Simulation panel contains parameters for controlling B1 eld display. Colormap : The colormap for the B1 eld, includes Jet, Gray and Hot CLimDown (T) : The lower bound of color limits CLimUp (T) : The upper bound of color limits CoilDisplay : The ag for turning on and o coil display CoilShow : The ag for choosing active coil for B1 eld display Mode : The B1 eld display mode, includes Magnitude, Phase, Real and Imaginary Plane : The ag for activating B1 eld slicing plane, includes XY, XZ and YZ XDimRes (m) : The displayed spatial resolution in X direction YDimRes (m) : The displayed spatial resolution in Y direction ZDimRes (m) : The displayed spatial resolution in Z direction
MRiLab provides a group of B1 eld display button (Figure 5.36) to help inspecting the B1 eld details.
Figure 5.36: The B1 Field Display Button. The B1 eld display button group consists of: : Undock B1 eld on active B1 slicing plane (Figure 5.37) S+ : Move active B1 slicing plane forwards S- : Move active B1 slicing plane backwards
93
5.3.2
A coil element macro is a predened module for creating a coil element that generates B1 eld in three dimensional space. MRiLab coil element macro library is a collection of coil element macros covering simple coil geometries. This section will give an introduction for each of the coil element macro provided in MRiLab. CoilCircle A coil element macro that creates a Biot-Savart coil circle. This macro contains attributes including: Azimuth (rad) : The azimuth angle of the circle plane Elevation (rad) : The elevation angle of the circle plane Radius (m) : The coil circle radius PosZ (m) : The Z position of coil circle center PosY (m) : The Y position of coil circle center PosX (m) : The X position of coil circle center CurrentDir : The current direction in the coil circle, 1 for clockwise, -1 for counterclockwise Scale : The scale factor for the B1 eld amplitude
94
CHAPTER 5. MRILAB TOOLBOXES Segment : The number of line segments for approximating circle, MRiLab requires the same Segment for each coil circle CoilID : The assigned coil ID, each coil element must have distinct ID
CoilUser If the user has the B1 eld data saved in a MAT le, the user can easily import the B1 eld into MRiLab coil design interface by using CoilUser macro. The B1 eld MAT le needs to contain two matrices including B1x (i.e. x component of B1 eld) and B1y (i.e. y component of B1 eld). Both of the two matrices must have the same size. The CoilUser macro contains attributes including: B1File : The path to the le that stores the B1 eld data, quoted using single quotes Interp : The interpolation method, includes linear, nearest, spline and cubic PosZ (m) : The Z position of coil center PosY (m) : The Y position of coil center PosX (m) : The X position of coil center CoilID : The assigned coil ID, each coil element must have distinct ID
5.3.3
The user can also use the coil loading function to load another coil. To load a coil, click Load menu then click Load Coil File, choose a coil XML le. When the coil is loaded, press Execute to display eld. The user can create a new coil conguration in the Coil Design interface. To create a new coil, click New then click Create Coil File. A coil creation window (Figure 5.38) will show up and ask for new coil name and notes. To follow MRiLab naming convention, the user is recommended to use Coil followed by the number of coil elements and applied anatomy (e.g. Coil 16ChChest), make sure that the new coil name is distinct to the remaining coil names in MRiLab. Then click OK to select a path for storing the coil XML le. Its strongly recommended to put the coil under the MRiLab coil root folder /Coil according to the coil type so that the coil is visible to MRiLab. Finally, MRiLab will create a new coil XML le based on the content of Coil 1ChHead.
5.4
The Magnet dB0 Design toolbox can be activated by pressing Magnet Design Panel toolbar icon located at the top of the main simulation console. The loaded magnet will show in the Magnet dB0 Design interface.
95
5.4.1
Figure 5.40 demonstrates the overview of the Magnet dB0 Design interface. This interface consists of 1. Magnet Element Macro Library The Magnet Element Macro Library contains magnet element macros for constructing magnet structure in MRiLab. The user needs to click the MagElem root to unfold subsequent macros. 2. Magnet Structure In MRiLab, a magnet structure consists of arbitrary number of magnet elements that are combined to create desired dB0 eld. The user can construct desired dB0 eld by changing the content within the magnet structure. To add a macro into the magnet structure, the user needs to click one macro in the macro library, then click on the magnet structure root (i.e. MRiLabMag) to which this macro is inserted, then click + macro operation button. To delete a macro from the magnet structure, the user needs to click the unwanted macro, then click - macro operation button. To duplicate an existing macro, the user needs to rst click the source macro, then click C macro operation button for copying, click on the magnet structure root, then click P macro operation button for pasting. MRiLab doesnt allow empty magnet structure. 3. Magnet Element Attribute When clicking on the magnet element macro within the magnet structure, the corresponding macro attributes will be updated at the magnet element
96
Figure 5.40: Magnet dB0 Design GUI attribute panel down below the magnet structure. The user can edit those attributes to modify the magnet element so as to change generated dB0 eld. To make the modication eective, the user must press Update button to update the magnet le. Pressing Execute button will update and redraw the dB0 eld map on this interface. 4. Magnet Field The dB0 eld (T) associated with the magnet structure is displayed on the Magnet Field panel on the right side of this interface. 5. Magnet Simulation Control The Display and Grid tab on the Magnet Simulation panel contains parameters for controlling dB0 eld display. Colormap : The colormap for the dB0 eld, includes Jet, Gray and Hot Plane : The ag for activating dB0 eld slicing plane, includes XY, XZ and YZ XDimRes (m) : The displayed spatial resolution in X direction
5.4. MAGNET DB0 DESIGN YDimRes (m) : The displayed spatial resolution in Y direction ZDimRes (m) : The displayed spatial resolution in Z direction
97
MRiLab provides a group of dB0 eld display button to help inspecting the dB0 eld details. The dB0 eld display button group consists of: S+ : Move active dB0 eld slicing plane forwards S- : Move active dB0 eld slicing plane backwards
5.4.2
A magnet element macro is a predened module for creating a magnet element that generates dB0 eld in three dimensional space. MRiLab magnet element macro library is a collection of magnet element macros. This section will give an introduction for each of the magnet element macro provided in MRiLab. MagLinear A magnet element macro that creates a linear dB0 eld. This macro contains attributes including: GradZ (T/m) : The linear gradient of dB0 eld in Z direction GradY (T/m) : The linear gradient of dB0 eld in Y direction GradX (T/m) : The linear gradient of dB0 eld in X direction Scale : The scale factor for the dB0 eld MagGaussian A magnet element macro that creates a 3D Gaussian dB0 eld. This macro contains attributes including: PosZ (m) : The Z position of the center PosY (m) : The Y position of the center PosX (m) : The X position of the center DeltaZ (m) : The width of Gaussian function in Z direction DeltaY (m) : The width of Gaussian function in Y direction DeltaX (m) : The width of Gaussian function in X direction Scale : The scale factor for the dB0 eld
98 MagSymbolic
A magnet element macro that creates a dB0 eld based on symbolic equation. This macro contains attributes including: Equation : An dB0 eld equation The symbolic equation could be any legal Matlab equation using variables X, Y and Z. For example, X+Y, 2*X.*Y and 2*sin(X) etc. Notice that use element operations for variables in the equation. And the user needs to ll the equation between a pair of single quotes. MagUser If the user has the dB0 eld data saved in a MAT le, the user can easily import the dB0 eld into MRiLab magnet design interface by using MagUser macro. The dB0 eld MAT le needs to contain one matrix dB0. The MagUser macro contains attributes including: MagFile : The path to the le that stores the dB0 eld data, quoted using single quotes Interp : The interpolation method, includes linear, nearest, spline and cubic
5.4.3
The user can also use the magnet loading function to load another magnet. To load a magnet, click Load menu then click Load Magnet File, choose a magnet XML le. The user can create a new magnet in the Magnet Design interface. To create a new magnet, click New then click Create Magnet File. A magnet creation window will show up and ask for new magnet name and notes. To follow MRiLab naming convention, the user is recommended to use Mag followed by a legal string and applied anatomy (e.g. Mag CustomHead), make sure that the new magnet name is distinct to the remaining magnet names in MRiLab. Then click OK to select a path for storing the magnet XML le. Its strongly recommended to put the magnet under the MRiLab magnet root folder /Mag according to the magnet type so that the magnet is visible to MRiLab. Finally, MRiLab will create a new magnet XML le based on the content of Mag LinearHead.
5.5
Gradient Design
The Gradient Design toolbox can be activated by pressing Gradient Design Panel toolbar icon located at the top of the main simulation console. The loaded gradient will show in the Gradient Design interface.
99
5.5.1
Figure 5.42: Gradient Design GUI Figure 5.42 demonstrates the overview of the Gradient Design interface. This interface consists of 1. Gradient Element Macro Library The Gradient Element Macro Library contains gradient element macros for constructing gradient structure in MRiLab. The user needs to click the GradElem root to unfold subsequent macros. 2. Gradient Structure In MRiLab, a gradient structure consists of three gradient elements that are combined to create gradient eld for GzSS, GyPE and GxR. The user can construct desired gradient eld by changing the content within the gradient structure. To add a macro into the gradient structure, the user needs to click one macro in the macro library, then click on the gradient
100
CHAPTER 5. MRILAB TOOLBOXES structure root (i.e. MRiLabGrad) to which this macro is inserted, then click + macro operation button. To delete a macro from the gradient structure, the user needs to click the unwanted macro, then click - macro operation button. To duplicate an existing macro, the user needs to rst click the source macro, then click C macro operation button for copying, click on the gradient structure root, then click P macro operation button for pasting. MRiLab doesnt allow empty gradient structure, and requires that one gradient eld must be assigned to each of the gradient sequence line.
3. Gradient Element Attribute When clicking on the gradient element macro within the gradient structure, the corresponding macro attributes will be updated at the gradient element attribute panel down below the gradient structure. The user can edit those attributes to modify the gradient element so as to change generated gradient eld. To make the modication eective, the user must press Update button to update the gradient le. Pressing Execute button will update and redraw the gradient eld map on this interface. 4. Gradient Field The gradient eld is represented as a three-dimensional quiver plot on the Gradient Field panel. If the constant unit gradient is used, the regular linear spatial location is applied. However, for example if nonunit gradient is used, the spatial location may be either dilated or shrunk along the applied direction. This means the original spatial location will be mapped to a new location in the spatial grid. The transformed spatial grid is represented as three slicing planes on the Gradient Field panel. The value (color) of the spatial grid equals to the spatial location in the direction that is indicated by GradLine in Gradient Simulation panel. 5. Gradient Simulation Control The Display and Grid tab on the Gradient Simulation panel contains parameters for controlling gradient eld display. Colormap : The colormap for the spatial grid, includes Jet, Gray and Hot Plane : The ag for activating grid slicing plane, includes XY, XZ and YZ GradLine : The ag for activating gradient sequence line, includes GzSS, GyPE and GxR DispMode : The display mode, includes Gradient, Grid and Both XDimRes (m) : The displayed spatial resolution in X direction
5.5. GRADIENT DESIGN YDimRes (m) : The displayed spatial resolution in Y direction ZDimRes (m) : The displayed spatial resolution in Z direction
101
MRiLab provides a group of grid display button to help inspecting the grid details. The grid display button group consists of: S+ : Move active grid slicing plane forwards S- : Move active grid slicing plane backwards
5.5.2
A gradient element macro is a predened module for creating a gradient element that generates gradient eld in three dimensional space. MRiLab gradient element macro library is a collection of gradient element macros. This section will give an introduction for each of the gradient element macro provided in MRiLab. GradLinear A gradient element macro that creates a linear gradient eld. This macro contains attributes including: GradZ : A constant of gradient eld vector in Z direction, 1 for unit gradient GradY : A constant of gradient eld vector in Y direction, 1 for unit gradient GradX : A constant of gradient eld vector in X direction, 1 for unit gradient GradLine : The gradient sequence line that is assigned to this gradient eld GradSymbolic A gradient element macro that creates a gradient eld based on symbolic equation. This macro contains attributes including: GradZEqu : An equation for gradient eld vector in Z direction GradYEqu : An equation for gradient eld vector in Y direction GradXEqu : An equation for gradient eld vector in X direction GradLine : The gradient sequence line that is assigned to this gradient eld The symbolic equation could be any legal Matlab equation using variables X, Y and Z. For example, X+Y, 2*X.*Y and 2*sin(X) etc. Notice that use element operations for variables in the equation. And the user needs to ll the equation between a pair of single quotes.
102 GradUser
If the user has the gradient eld data saved in a MAT le, the user can easily import the gradient eld into MRiLab gradient design interface by using GradUser macro. The gradient eld MAT le needs to contain one four dimensional matrix G with the size of the fourth dimension to be 3. G(:,:,:,1) is the x component of the gradient vector, G(:,:,:,2) is the y component of the gradient vector and G(:,:,:,3) is the z component of the gradient vector. The GradUser macro contains attributes including: GradFile : The path to the le that stores the gradient eld data, quoted using single quotes Interp : The interpolation method, includes linear, nearest, spline and cubic GradLine : The gradient sequence line that is assigned to this gradient eld
5.5.3
The user can also use the gradient loading function to load another gradient. To load a gradient, click Load menu then click Load Gradient File, choose a gradient XML le. The user can create a new gradient in the Gradient Design interface. To create a new gradient, click New then click Create Gradient File. A gradient creation window will show up and ask for new gradient name and notes. To follow MRiLab naming convention, the user is recommended to use Grad followed by a legal string and applied anatomy (e.g. Grad CustomHead), make sure that the new gradient name is distinct to the remaining gradient names in MRiLab. Then click OK to select a path for storing the gradient XML le. Its strongly recommended to put the gradient under the MRiLab gradient root folder /Grad according to the gradient type so that the gradient is visible to MRiLab. Finally, MRiLab will create a new gradient XML le based on the content of Grad LinearHead.
5.6
Motion Design
The Motion Design toolbox can be activated by pressing Motion Design Panel toolbar icon located at the top of the main simulation console.
103
5.6.1
Figure 5.44: Motion Design GUI Figure 5.44 demonstrates the overview of the Motion Design interface. This interface consists of 1. Motion Element Macro Library The Motion Element Macro Library contains motion element macros for constructing motion structure in MRiLab. The user needs to click the MotElem root to unfold subsequent macros. 2. Motion Structure In MRiLab, a motion structure consists of arbitrary number of motion elements that are combined to create desired motion pattern. The user can construct wanted motion pattern by changing the content within the motion structure. To add a macro into the motion structure, the user needs to click one macro in the macro library, then click on the motion structure root (i.e. MRiLabMot) to which this macro is inserted, then click + macro operation button. To delete a macro from the motion structure, the user needs to click the unwanted macro, then click - macro operation button. To duplicate an existing macro, the user needs to rst click the source macro, then click C macro operation button for copying,
104
CHAPTER 5. MRILAB TOOLBOXES click on the motion structure root, then click P macro operation button for pasting. MRiLab doesnt allow empty motion structure.
3. Motion Element Attribute When clicking on the motion element macro within the motion structure, the corresponding macro attributes will be updated at the motion element attribute panel down below the motion structure. The user can edit those attributes to modify the motion element so as to change generated motion pattern. To make the modication eective, the user must press Update button to update the motion le. Pressing Execute button will update and recalculate the motion track. 4. Motion Tracker MRiLab uses Matlab Simulink 3D Animation toolbox to investigate the motion track of the object in the motion tracker window. To open this window, the user needs to press 3D Play button. In the 3D animation, the image object is represented using a sphere, the three attached small spheres indicating axis directions (red for x axis, green for y axis and blue for z axis). 5. Motion Simulation Control The Display and Replay tab on the Motion Simulation panel contains parameters for controlling 3D animation. Object : The object model, currently only supports Sphere ViewPoint : The default view point, includes ZPos, YPos and XPos ZoomOut : The factor for view zoom out Sample : The sample steps between two adjacent positions during motion Repeat : The repeat time for playback
5.6.2
A motion element macro is a predened module for creating a motion element that generates a motion track in three dimensional space. MRiLab motion element macro library is a collection of motion element macros. This section will give an introduction for each of the motion element macro provided in MRiLab.
105
A motion element macro that creates translation motion. This macro contains attributes including: tStart (s) : The motion starting time tEnd (s) : The motion ending time dt (s) : The time interval of the motion track sample steps Direction : A vector describing translation direction in 3D space Displacement (m) : An equation of translation displacement pattern with respect to time The displacement equation could be any legal Matlab equation using variables t. For example, 2*t, t+200e-3 and 0.05*sin(0.1*t) etc. Notice that the user needs to ll the equation between a pair of single quotes. MotRotate A motion element macro that creates rotation motion. This macro contains attributes including: tStart (s) : The motion starting time tEnd (s) : The motion ending time dt (s) : The time interval of the motion track sample steps Axis : A vector describing rotation axis in 3D space Angle (rad) : An equation of rotation angle with respect to time The rotation angle equation could be any legal Matlab equation using variables t. For example, 2*t, t+200e-3 and sin(0.1*t) etc. Notice that the user needs to ll the equation between a pair of single quotes.
5.6.3
The user can also use the motion loading function to load another motion. To load a motion, click Load menu then click Load Motion File, choose a motion XML le. The user can create a new motion in the Motion Design interface. To create a new motion, click New then click Create Motion File. A motion creation window will show up and ask for new motion name and notes. To follow MRiLab naming convention, the user is recommended to use Mot followed by a legal string and applied anatomy (e.g. Mot CustomHead), make sure that the
106
new motion name is distinct to the remaining motion names in MRiLab. Then click OK to select a path for storing the motion XML le. Its strongly recommended to put the motion under the MRiLab motion root folder /Mot according to the motion type so that the motion is visible to MRiLab. Finally, MRiLab will create a new motion XML le based on the content of Mot ShiftHead. The user needs to notice that adding a motion pattern is not guaranteed to stimulate motion, the user also needs to use the extended real time process to trigger motion at the Ext sequence line. To trigger motion, one or more Ext ag 8 needs to be inserted into Ext line. A better motion tracking can be achieved with both small time interval of the motion track sample steps and frequent motion triggering, but requires more simulation computation and time. The interested users are referred to PSD GRE3D for more information.
5.7
Image Reconstruction
MRiLab provides default image reconstruction code for a few types of Cartesian and Non-Cartesian reconstruction. External reconstruction code is also acceptable.
5.7.1
Default Engine
To choose default reconstruction for Cartesian readout, the user needs to choose Cartesian for ReconType under the Recon tab. The Cartesian reconstruction can be applied to typical Cartesian readout, FSE readout and EPI readout that are performed using default gradient macros. To choose default reconstruction for Non-Cartesian readout, the user needs to choose NonCart for ReconType. The corresponding Non-Cartesian reconstruction code can be applied to radial readout and spiral readout. Notice that the Non-Cartesian reconstruction performs 2D gridding process for the Non-Cartesian K-Space trajectory using a Kaiser-Bessel kernel, followed by a regular iFFT. The 2D gridding process should also in theory be able to be applied to other Non-Cartesian readout. In order to perform Non-Cartesian reconstruction, the gridding tab is also required in MRiLab.
5.7.2
External Engine
If the user designed a special K-Space trajectory that requires particular reconstruction code, the user needs to indicate using external reconstruction by changing ReconEng to External, and then provides a reconstruction function quoted with a pair of single quotes for ExternalEng. It is recommended to put the external code under /Recon/External, if not, make sure the reconstruction code is in Matlab searching path. This setting will simply ignore default reconstruction code and apply external code. It is strongly recommended to write your own reconstruction code based on the template :
5.7. IMAGE RECONSTRUCTION function DoCustomRecon %Create an external reconstruction based on your code global VCtl global VSig global VImg % use VCtl structure, read only % use VSig structure, read only % use VImg structure, read and write
107
... % The main code for your reconstruction VImg.Real = ...; VImg.Imag = ...; VImg.Mag = ...; VImg.Phase = ...; VImg.Sx = ...; VImg.Sy = ...; ... end Notice that there are two new Virtual Structures (VSig and VImg) in this template, VSig encapsules acquired MR signal. VImg is declared to store reconstructed images. For the structure VSig, MRiLab provides : VSig.Sx : A array storing x component of acquired MR signal VSig.Sy : A array storing y component of acquired MR signal VSig.Kz (1/m) : A array storing Kz location of K-Space trajectory VSig.Ky (1/m) : A array storing Ky location of K-Space trajectory VSig.Kx (1/m) : A array storing Kx location of K-Space trajectory The sample points in these arrays are organized in the order of Sample points in one readout < Multiple echos < First phase encoding < Second phase encoding < Coil channel < Spin species For the structure VImg, MRiLab provides : VImg.Real : A matrix for real component of reconstructed complex image with a size of RY Dim RXDim RZDim RxCoilN um T EP erT R VImg.Imag : A matrix for imaginary component of reconstructed complex image with a size of RY Dim RXDim RZDim RxCoilN um T EP erT R VImg.Mag : A matrix for magnitude of reconstructed complex image with a size of RY Dim RXDim RZDim RxCoilN um T EP erT R
108
VImg.Phase : A matrix for phase of reconstructed complex image with a size of RY Dim RXDim RZDim RxCoilN um T EP erT R VImg.Sx : A matrix for x component of sorted complex MR signal in Cartesian grid VImg.Sy : A matrix for y component of sorted complex MR signal in Cartesian grid where RXDim, RY Dim and RZDim are reconstructed image resolution in three spatial space. Gadgetron If the user are interested to use Gadgetron for image reconstruction, MRiLab also provides a simple MEX code to convert the acquired data into ISMRMRD le that can be used in Gadgetron process. To activate this function, the user needs to install ISMRMRD dependency packages to enable properly compiling MEX. I am working on improving MRiLab support for Gadgetron since Gadgetron is a very promising generic image reconstruction framework. I will be very pleased to talk with the interested users who are willing to contribute to improving MRiLab Gadgetron support. Please dont hesitate to contact me. The ISMRMRD relevant code is DoToHDF5.m under /Src and DoMatToHDF5 under /Lib/src/interface.
5.8
Simulation Output
MRiLab can save simulation output into two le formats including MAT and ISMRMRD. The user can choose OutputType under Recon tab. If the user choose ISMRMRD format, the DoMatToHDF5 MEX has to be functional, if not, MAT le will be saved instead. MRiLab saves simulation output of each series into a folder named by the MRiLab startup time under /Output folder. For MAT le, MRiLab saves: SeqXMLFile : Applied sequence XML le SeriesName : Series name on the main control console VCtl : Virtual Control structure VImg : Virtual Image structure VSig : Virtual Signal structure
Chapter 6
6.1
MatrixUser
MRiLab adapted a toolbox named MatrixUser for performing image display and analysis. MatrixUser is originally designed to let users interactively manipulating multiple dimensional matrix in Matlab in a graphic way. This toolbox can be activated by pressing MatrixUser toolbar icon located at the top of the main simulation console.
Figure 6.1: MatrixUser Toolbar Icon MatrixUser will search through the current output folder and load all image series from this folder into MatrixUser workspace. The MatrixUser main window (Figure 6.2) opens up as a matrix manager for loaded images.
6.1.1
MatrixUser Display
The user can choose to display the image series by using the popup menu. The matrix size, type and value range are calculated and provided on the right side. The user can press MatrixUser button to activate MatrixUser display panel. Current version of MatrixUser supports displaying 1D, 2D, 3D and 4D real value matrix and Matlab structure variable. 109
110
6.1. MATRIXUSER
111
Figure 6.3 demonstrates the overview of the MatrixUser display panel interface for a 3D image. This interface consists of 1. Matrix Display Axes The 3D image is displayed slice by slice on the matrix display axes. The user can move the mouse cursor to a single voxel to inspect the coordinate and value that are shown below the image. 2. Matrix Display Control The matrix display control provides a set of sliders and popup menu that help control image display. This group consists of Colormap Popup Menu: Choose dierent colormap scheme Slice Slider : Slide to move to another slice Slice EditText : Edit to move to another slice Time Slider : Slide to move to another time point or image phase, used for 4D image matrix Time EditText : Edit to move to another time point or image phase, used for 4D image matrix C Upper Slider : Slide to control the upper bound of color limits C Upper EditText : Edit to control the upper bound of color limits C Lower Slider : Slide to control the lower bound of color limits C Lower EditText : Edit to control the lower bound of color limits 3. Display Assist MatrixUser also provides a set of buttons that help manipulate image matrix, This group consists of : Reset image matrix : Turn on and o grid line on the image : Upsample or downsample image matrix by using various interpolation methods (Figure 6.4) : Create a montage image for multiple slices (Figure 6.5)
4. ROI Control MatrixUser provides a set of buttons for performing Region of Interest (ROI) analysis (Figure 6.6). The statistics for voxels (i.e. mean, standard
112
Figure 6.4: Resolution Window. An example for doubling in-plane resolution by using linear interpolation
Figure 6.5: Montage Image. An example for creating a 3-by-4 montage image using multiple image slices starting from slice 20
6.1. MATRIXUSER
113
deviation and relative standard deviation) in delineated ROI is calculated and updated when moving the ROI position or changing the ROI shape. To create a ROI, the user needs to click ROI button rst, then draw a ROI on the image axes. The ROI buttons consists of : Draw a free hand ROI : Draw a rectangle or square ROI : Draw a circle or ellipse ROI : Draw a polygon ROI : Draw a straight line for measuring distance in units of pixels
Figure 6.6: Multiple ROIs 5. Segmentation Control MatrixUser currently supports functions for performing manual segmentation, editing, saving and loading segmented ROIs for multiple slices. To create a segmentation ROI, the user needs to click segmentation button rst, then draw a ROI on the image axes. After nishing the ROI, the user can still modify the ROI detail before double clicking the ROI to conrm segmentation. The segmentation buttons consists of : Do a free hand segmentation : Do a rectangle or square segmentation
114
CHAPTER 6. IMAGE DISPLAY AND ANALYSIS : Do a circle or ellipse segmentation : Edit segmentation : Save segmentation into a MAT le : Load segmentation from a MAT le
Figure 6.7: Editing Segmentation To edit segmented ROI (Figure 6.7), the user needs to move to the slice where the wanted ROIs exist, then press to open segmentation manager. The manager will automatically detect the type and location of segmented ROIs. The user can click any ROI item to inspect the location of the ROI. To edit chosen segmentation ROI, the user must click Edit button to activate ROI outline. Both the shape and mask ag are editable for segmented ROI. After editing, the user must click Update to conform modication. Notice that the user can press to remove segmentation ROIs from overlapping with background image. The user can press to save all segmentation ROIs into a MAT le. The le contains a mask matrix with the same size of the original image and a cell array for storing segmentation location information. 6. Other Tools
: Plot histogram for current slice (Figure 6.8), if ROIs exist, plot histogram for latest ROI
6.1. MATRIXUSER
115
: Create a 3D graph for rendering Non-zero object in current 3D image matrix (Figure 6.9) : Perform Maximum Intensity Projection (MIP) along slice direction : Overlap two image matrices that have the same matrix size (Figure 6.10), notice that the user can press to remove foreground matrix from overlapping with background image.
Figure 6.8: Histogram for One Image Slice 7. Matrix Control Matrix Control group consists of Matrix Equation EditText : Accept legal Matlab syntax for manipulate matrices which are in Matlab base workspace (Figure 6.12) : Press to execute matrix equation from the EditText : Save temporary matrix, for example, interpolated matrix
8. 4D Support MatrixUser supports to display 4D matrix with a second window showing the fourth dimension as a curve (Figure 6.13). The user can move the
116
Figure 6.10: An Example of Overlapping Two Matrices. The foreground matrix is a arbitrary label matrix in this example.
6.1. MATRIXUSER
117
Figure 6.11: An Example of 1D Prole. The user can relocate and resize the prole checking line on the image. mouse cursor to interactively inspect curve shape for a single voxel. The second window opens up when a 4D matrix is selected. 9. 3D Slice If the 3D Slice checkbox on the MatrixUser main window is checked when displaying matrix, a second window will open with images on another two orthogonal orientation (Figure 6.14). The operation buttons consists of : Activate and deactivate localizer line on main display : Activate and deactivate localizer line on main display : Flip left and right : Flip up and down : Switch images between main display and secondary display
To change localizer line, the user needs to activate localizer and then click on main image axes.
6.1.2
MatrixUser More
MatrixUser not only supports image data that are generated in MRiLab, but also supports any Matlab matrix from either Matlab base workspace or external data le. There are several dierent approaches to import data into MatrixUser, including:
118
Figure 6.12: An Example of Showing Two Image Series Side-by-Side. Notice the equation in the Matrix Equation EditText and these two matrices are in Matlab base workspace.
6.1. MATRIXUSER
119
Figure 6.14: 3D Slicer Load from workspace MatrixUser protects data by isolating matrices from Matlab base workspace. If the user wants to import matrices from Matlab base workspace into MatrixUser workspace, this option if very helpful. A matrix selection window will open (Figure 6.15), and allow the user to choose wanted matrices. The operation buttons consists of || >>> : choose all matrices from available matrix list >>>>>> : choose chosen matrices from available matrix list <<<<<< : remove chosen matrices from selected matrix list <<< || : remove all matrices from selected matrix list Save : save a copy of matrices in selected matrix list from base workspace to MatrixUser workspace Load from DICOM le MatrixUser supports loading multiple DICOM les by using a le lter interface (Figure 6.16) The user needs to load DICOM les into the loading interface by selecting wanted DICOM les (multiple selection supported) from data folder. The selected les are listed in the DICOM le list. The user can click a single le to read its DICOM header and image preview. To manually create a matrix using DICOM les, the user needs to choose les from the left list, then press >>>>>> to push the les into selected DICOM le list. A matrix name must also be provided. Then pressing Convert button will
120
Figure 6.15: Matrix Selection Window. The system multiple selection hotkey is supported for choosing multiple matrices at once.
6.1. MATRIXUSER
121
create a matrix based on chosen DICOM les if these les are compatible. The user can load these created matrices by pressing Load matrix button. Load from DICOM le (Batch) MatrixUser also supports loading DICOM les from a folder. This function requires the folder path is provided. MatrixUser will try to create separate matrices for DICOM les that may come from dierent image series. Load from Mat le Mat le is natively supported by MatrixUser. Load from NIFTI le NIFTI le with .nii sux is supported by MatrixUser. Load from Binary le Binary data le is supported by MatrixUser. The user is responsible for conguring the loading parameters (Figure 6.17).
Figure 6.17: MatrixUser Binary File Loading Interface Link Space If the Link Space checkbox on the MatrixUser main window is checked when displaying matrix, the selected matrix will be replaced by the matrix of the same name in base workspace if exists. If there is no such a matrix in base workspace, MatrixUser will copy the selected matrix into base workspace. There are two approaches of saving matrices from MatrixUser workspace.
122
Save to Workspace : Save all matrices from MatrixUser workspace to Matlab base workspace Save to Mat le : Save matrices to MAT le
6.2
arrayShow
The arrayShow tool is a Matlab image viewer which has been designed for the evaluation of multidimensional complex images. It is originally designed by Tilman Johannes Sumpf at Biomedizinische NMR Forschungs GmbH. I have made some modication for making it work with image data directly from MRiLab. The user can press arrayShow button to activate this viewer. Detailed information about arrayShow can be found at http://www.biomednmr.mpg.de/ index.php?option=com_content&task=view&id=137&Itemid=43;
6.3
SpinWatcher
The SpinWatcher is designed for monitoring spin evolution behavior of a single voxel at given MR sequence and eld environment. This function can be activated by pressing SpinWatcher toolbar icon located at the top of the main simulation console.
6.3. SPINWATCHER
123
Figure 6.19 demonstrates the overview of the SpinWatcher main interface. This interface consists of 1. Voxel Locator The default voxel is chosen as the one at the isocenter which is indicated with a red isocenter marker. However, the user can select any voxel within . The slider beside the image can help the virtual object by using change image slices. 2. Spin Property and Environment When one voxel is selected, the spin properties will be automatically updated. The user can also modify the spin properties and environment to meet their own needs. The editable properties provided in this interface include: (a) Spin ChemShift (Hz/T): The chemical shift of the spin Gyro (rad/s/T): The gyromagnetic ratio of the spin Rho : The density of the spin T1 (s): The longitudinal relaxation time T2 (s): The transverse relaxation time T2Star (s): The T2* relaxation time SpinPerVoxel : The number of spins in each voxel, default one for treating T2* equal to T2, use a value above one for simulating T2* eect TypeNum : The number of spin species LocZ : The Z location of the selected voxel LocY : The Y location of the selected voxel LocX : The X location of the selected voxel
(b) Display WindowSize : The window width of the spin evolution plot ISOHighlight : The ag for turning on and o isocenter mark Grid : The ag for turning on and o grid line Axes : The ag for turning on and o axes label
The SpinWatcher supports monitoring multiple spin species. The user needs to provide multiple values for T1, T2, T2*, Rho and ChemShift, and give the correct number of spin species. The values must be separated with space. For example
124
CHAPTER 6. IMAGE DISPLAY AND ANALYSIS ChemShift = 0 -210 Rho = 1.0 0.5 T1 = 1.2 1.0 T2 = 0.02 0.03 T2Star = 0.002 0.003 TypeNum = 2
3. Spin Watcher Window The 3D spin evolution animation is displayed in the spin watcher window. The 3D animation can be controlled using a set of control buttons and slidebar Scroll Bar : Drag the scroll bar to any intermediate time point between beginning and end | < : Move to the beginning X : Pause playing, notice that the interface can only be closed when playing is paused O : Resume playing > : Play at normal speed >> : Play at double normal speed > | : Move to the end 4. Spin Evolution Plot SpinWatcher provides two plots for capturing the spin evolution (i.e. |Mxy| and Mz) with respect to time. The user can press Execute button to recalculate the spin evolution plot after making changes to spin property and environment. The settings can be saved into a le by pressing Update. To export temporary variables of spin evolution into Matlab base workspace, press Export, the exported variables include : Muts : A array for time points MxySum : A array for |Mxy| MzSum : A array for Mz Mx : x component of magnetization My : y component of magnetization Mz : z component of magnetization The user can also undock the spin evolution plot by pressing .
6.4. SARWATCHER
125
6.4
SARWatcher
(:TODO) SARWatcher is a graphic toolbox for monitoring real time spatial Specic Absorption Rate (SAR) of the virtual object with given experiment design. This toolbox is still under development.
126
Chapter 7
MRiLab Applications
This chapter shows more examples for demonstrating the applications of MRiLab simulation
7.1
This example (Figure 7.1) simulates the dark banding artifact in bSSFP images arisen from non-uniform B0 eld. To perform this simulation, the following steps are needed: 1. Load Brain (Standard Resolution 108 90 90) 2. Load PSD FIESTA3D 3. Load Mag GaussianHead The user can adjust the FlipAng, TR and TE to modify the pattern of the banding artifact.
7.2
This example (Figure 7.2) simulates chemical shift artifact at the interface of water and fat in a GRE sequence. To perform this simulation, the following steps are needed: 1. Load Water Fat Phantom (256 256 32 2) 2. Load PSD GRE3D The user can adjust the BandWidth and FreqDir to modify the appearance of the chemical shift. 127
128
Figure 7.1: Simulated 3D bSSFP brain image of matrix size of 100 80 20. The circular banding artifact is due to added Gaussian eld simulating the main magnet eld inhomogeneity. Left: TR/TE=16/8ms, FA=40 ; Middle: TR/TE=16/8ms, FA=40 , Gaussian B0 applied; Right: TR/TE=32/16ms, FA=40 , Gaussian B0 applied
Figure 7.2: Simulated 3D gradient echo image at 3.0T using cartilage-fat phantom showing water fat chemical shift at dierent readout bandwidth. The simulated in-plane matrix size is 100 100, TR/TE = 10s/50ms, Axial plane, A/P readout. Left: BW=400Hz/pixel; Right: BW=100Hz/pixel.
129
7.3
Multi RF Transmitting
This example (Figure 7.3) simulates multiple RF transmitting using a bSSFP sequence. To perform this simulation, the following steps are needed: 1. Load Brain (Standard Resolution 108 90 90) 2. Load PSD FIESTA3D 3. Load Coil 8ChHead to Tx 4. Set MultiTransmit to on The user can adjust the B1Level to modify the actual ip angle, modify the RF pulse using MR sequence Design Toolbox for individual RF source, or modify the coil conguration for generating desired B1+ eld.
Figure 7.3: Simulated 3D bSSFP brain image of matrix size of 100 80 4 with dierent Tx coil conguration. The simulated image uses FA=40 , TR/TE = 16/8ms. Left: uniform unit B1+ eld, RF transmitting from MasterTxCoil; Middle: multi RF transmitting from Coil1 and Coil3; Right: multi RF transmitting from all coil channels
130
7.4
This example (Figure 7.4) simulates multiple receiving using a SE sequence. To perform this simulation, the following steps are needed: 1. Load Brain (Standard Resolution 108 90 90) 2. Load PSD SE3D 3. Load Coil 8ChHead to Rx The user can adjust the coil conguration for generating desired B1- eld. All eight channels will be receiving MR signal from the virtual object individually.
Figure 7.4: Simulated brain spin echo image of matrix size of 100 80 with multi receiving Rx coil. The simulated image uses FA=90 , TR/TE = 10s/10ms. Left: the combined image using SumofMagn; Right: individual image for each coil channel, notice that Coil2 and Coil4 receive no signal due to zero B1- eld.
7.5
Image Gradient
This example (Figure 7.5) simulates applying non-unit gradient with a 3D SPGR sequence. To perform this simulation, the following steps are needed: 1. Load Brain (Standard Resolution 108 90 90) 2. Load PSD SPGR3D 3. Load Grad LinearHead The user can adjust the gradient structure for generating desired gradient eld. Notice that this applied gradient in GyPE GradLine has a factor of 0.5 in the Y direction. This will cause image contraction in the Y direction.
131
Figure 7.5: Simulated brain 3D SPGR image of matrix size of 100 80 2 with non-unit gradient. The simulated image uses FA=20 , TR/TE = 60/8ms. Left: unit gradient applied; Right: non-unit gradient applied in Y direction.
7.6
Motion Artifact
This example (Figure 7.6) simulates motion artifact with a 3D GRE sequence. To perform this simulation, the following steps are needed: 1. Load Brain (Standard Resolution 108 90 90) 2. Load PSD GRE3D 3. Load Mot ShiftHead The user can adjust the motion structure to generate dierent motion track patterns, and/or modify motion triggering in the Ext sequence line to sample object movement.
132
Figure 7.6: Simulated brain GRE image of matrix size of 100 80 with translation motion. The simulated image uses FA=90 , TR/TE = 10s/50ms, Axial plane, A/P readout. Motion triggering happens one time per TR, and motion lasts for 400s. Left: no motion; Right: translation motion applied.
Chapter 8
FAQs
Waiting for questions...
133
134
CHAPTER 8. FAQS
Bibliography
[1] V.L. Yarnykh: Actual Flip-Angle Imaging in the Pulsed Steady State: A Method for Rapid Three-Dimensional Mapping of the Transmitted Radiofrequency Field , Magn. Reson. Med., 57, (2007), 192-200. [2] J.I. Jackson, C.H. Meyer, D.G. Nishimura, and A. Macovski: Selection of a Convolution Function for Fourier Inversion Using Gridding , IEEE Trans. Med. Imag., vol. 10, no. 3, pp 473-478, 1991. [3] V. Rasche, R. Proska, R. Sinkus, P. Boernert, and H. Eggers: Resampling of Data Between Arbitrary Grids Using Convolution Interpolation , IEEE Trans. Med. Imag., vol. 18, no. 5, pp 385-392, 1999. [4] P.J. Beatty, D.G. Nishimura, and J.M. Pauly: Rapid gridding reconstruction with a minimal oversampling ratio , IEEE Trans. Med. Imag., vol. 24, no. 6, pp 799-808, 2005. [5] G.H. Glover: Simple Analytic Spiral K-Space Algorithm , Magn. Reson. Med., 42, (2005), 412-415. [6] M.A. Bernstein, K.F. King, X.J. Zhou: Handbook of MRI Pulse Sequences , Elsevier Academic Press, 2004. [7] J. Pauly, P. Le Roux, D.G. Nishimura, and A. Macovski: Parameter relations for the Shinnar-Le Roux selective excitation pulse design algorithm , IEEE Trans. Med. Imag., vol. 10, no. 1, pp 53-65, 1991. [8] T. Hwang, P.C.M. van Zijl and M. Garwood: Fast Broadband Inversion by Adiabatic Pulses , J. Magn. Reson., 133, pp 200-203, 1998. [9] V.L. Yarnykh: Pulsed Z-Spectroscopic Imaging of Cross-Relaxation Parameters in Tissues for Human MRI: Theory and Clinical Applications , Magn. Reson. Med., 47, (2002), 929-939.
135
136
BIBLIOGRAPHY
Acknowledgment
I am indebted to all my teachers and mentors. I would like to thank Dr. Neil Gelman for introducing me into the MRI eld and inspiring me for developing the MatrixUser project. I would also like to thank Drs. Wally Block and Richard Kijowski who guide me to acquire knowledge of MR sequence design and medical image application. My gratitude is owed to Dr. Alexey Samsonov for inspiring me developing MT relevant functions. Many people also contribute signicantly to the MRiLab project through publishing free code online which largely extends MRiLab functionality, in particular, Tilman Johannes Sumpf, Dr. John Pauly and Dr. Brian Hargreaves. Finally, my appreciation goes to my wife Zhaoye Zhou who never gets bored of my talking about MRiLab and supports me for nishing the whole project.
137
138
ACKNOWLEDGMENT
Afterword
Although MRiLab has been very carefully designed and tuned for performing best versatile MRI simulation, there may also exist bugs and misfunctions that may cause problems. In addition, several important parts are still missing in MRiLab, including multi-pool water exchange simulation, water diusion and Eddy-Current simulation et.al. I am also working to further optimize solving kernel for better performance and to enhance the compatibility with Gadgetron. The MRiLab project is open to the whole MRI community, any user who are interested to improve MRiLab is very welcome to do so. I will be very pleased if you can leave me feedback and ideas for better enhancing MRiLab functionality. I will also be very happy to talk about any kinds of collaboration for future MRiLab development. Please dont hesitate to contact me (leoliuf@gmail.com).
139