基于MATLAB NIFTI工具包的醫學影像MRI序列插值

一、實驗背景

實驗使用的DCE序列(動態增強序列)數據層厚不一致,為了最后實驗結果的準確性,需要把使用MRI數據的層厚統一成一樣的;有兩種層厚的數據分別是1.2mm和2.4mm,需要把2.4mm的影像數據插值成1.2mm。

二、實驗環境

1.Windows 64操作系統 CPU i5-8500 @3.00GHz 內存16.0GB
2.Linux 64位操作系統 CPU Intel(R) Xeon(R) CPU E5-2640 v4 @ 2.40GHz 內存62.64GB
3.Windows10操作系統上安裝matlab 2018a及其以上版本
4.nii格式的MRI影像數據

三、實驗過程(一)—— 插值

3.1 MRI nii格式的數據(896x896x72 )

image.png

3.2 插值之后的nii格式數據(896x923x162)
插值后的數據明顯比插值前數據大

image.png

3.3 實驗用的Matlab代碼
代碼可以修改路徑后在服務器上運行,執行速度會比本地快很多。
shell命令:matlab -nodesktop -nosplash -r DCE_reslice_Linux
(DCE_reslice_Linux為.m文件的名字,這行命令就是在服務器上執行腳步,前提是數據先上傳服務器)

%插值reslice,就用reslice_nii這個函數就可以了
%比如要采樣到1mm就用reslice_nii('orginal.nii','new.nii',[1 1 1]);
clc
root = ['G:\ResearchData\DCE90_NiiDATA','\'];
save_root = ['G:\ResearchData\DCE_ResliceNiiDATA','\'];
patients=dir(root);%獲取病例目錄
for i=3%:length(patients) %i=3只取第一個文件
    disp(strcat('Processing--->',patients(i).name,'-->',num2str(i-2),'/',num2str(length(patients)-2)));
    temp_nii= [root,patients(i).name,'\MR2Nii\'];%MRI nii格式文件夾
    MRIs=dir(temp_nii);%有幾次MRI
    for k=3
        Nii_path = [root,patients(i).name,'\MR2Nii\',MRIs(k).name,'\'];
        save_Re_dir = [save_root,patients(i).name,'\',MRIs(k).name,'\'];
        if ~exist(save_Re_dir,'dir')%判斷文件夾是否存在,如果不存在則創建文件夾
            mkdir(save_Re_dir)
        end
        Niis = dir(Nii_path);%對應某次MRI下有幾個nii文件
        for j=3:length(Niis)
            orginal_nii = [Nii_path,Niis(j).name];
            new_nii = [save_Re_dir,'r',Niis(j).name];%reslice后的文件名價加個r
            %插值原理Trilinear interpolation三線性插值  x y z 分辨率 單位mm
            reslice_nii(orginal_nii,new_nii,[0.3795 0.3795 1.2])
            disp(['save-->',new_nii,'-->successfully'])
        end
    end
end

代碼輸出結果:

image.png

3.4 實驗(一)結果分析

插值之后的MRI序列的維度為(896x923x162),和原始影像數據的二維圖像(896x896)不一樣,所以需要把影像數據二維圖像裁剪成(896x896),這一步需要在服務器上用fslroi函數進行校準(裁剪)
MATLAB代碼中用到了reslice_nii函數,其插值原理是Trilinear interpolation三線性插值, 常用線性插值的介紹和應用(雙線性插值,三線性插值,平滑曲線插值)

四、實驗過程(二)—— 裁剪

4.1 利用fslroi對插值后的影像數據進行裁剪

shell命令:fslroi rDCE00000.nii test 0 896 0 896 0 144

image.png

可以把shell命令寫成批處理命令
批量的對影像數據進行裁剪

image.png

針對單個病例可以執行--在xshell 下執行下面的命令

path_nii = "/DATA/102/nick/DCE_ResliceNiiDATA/00226023/"
for file in `ls ${path_nii} `
  do
    echo "NIi_file:$file"
    fslroi $file "co$file" 0 896 0 896 0 144
  done

命令行窗口輸出結果

image.png

遞歸調用遍歷文件夾中的所有病例--在xshell 下執行下面的命令

function travFolder(){ 
    echo "travFolder"
    flist=`ls $1`
    cd $1
    #echo $flist
    for f in $flist
    do
        if test -f $f
        then
            echo "file:$f"
            fslroi $f "co$f" 0 896 0 896 0 144
        else
            echo "dir:$f"
            travFolder $f
        fi
    done
   cd ../
}
dir="/DATA/102/nick/DCE_ResliceNiiDATA"
travFolder $dir

命令行窗口輸出結果

image.png

4.2 查看裁剪后的結果

方法一:利用ITK_SNAP軟件查看圖像
方法二:自己寫python腳本查看圖像

python代碼

import os
import SimpleITK as sitk
import numpy as np
import matplotlib.pyplot as plt
import pydicom as dicom

folderPath = r"G:\ResearchData\DCE_ResliceNiiDATA\00226023\20120608\corDCE00003.nii.gz"
print("reslice后的nii文件的大小:",float(os.path.getsize(folderPath)/1000000),"MB")
itk_img = sitk.ReadImage(folderPath)#讀取nii圖像
img = sitk.GetArrayFromImage(itk_img)#獲取圖像array
print("img.shape:",img.shape)#查看圖像形狀 (112, 896, 896)
#獲取圖像頭信息
keys = itk_img.GetMetaDataKeys()
for key in keys:#輸出dicom頭文件信息
    print (key,':', itk_img.GetMetaData(key))
  
img_3Dndarray = sitk.GetArrayFromImage(itk_img)#得到圖像矩陣
print(type(img_3Dndarray),"shape:",img_3Dndarray[48,:,:].shape,img_3Dndarray[48,:,:].dtype)
plt.imshow(img_3Dndarray[48,:,:],cmap="gray")
plt.axis('off')
plt.show()

裁剪后的圖像為倒置的


image.png

對圖像進行180°的旋轉操作

arr = img_3Dndarray[48,:,:]
arr2 =arr.copy()
print(arr.size,arr.size/2)
arr2= arr.reshape(int(arr.size/2),2)
arr2 =np.array(arr2[::-1])#進行行逆置
arr2 = arr2.reshape(arr.shape[0],arr.shape[1])#對圖像進行一次變換,變成 源圖像的維度
plt.subplot(121)
plt.imshow(arr,cmap="gray")
plt.subplot(122)
plt.imshow(arr2,cmap="gray")
image.png

五、實驗過程(三)—— 對插值裁剪后的結果重新保存成dicom文件

具體過程請參考之前的文章:python醫學影像3Dnii文件轉成2Ddicom文件(保留原始dicom信息)

Matlab NIfTI工具包:百度網盤-提取碼:nosr
參考文章1: 常用線性插值的介紹和應用(雙線性插值,三線性插值,平滑曲線插值)
參考文章2:雙線性插值(Bilinear Interpol)原理及應用
參考文章3:FSL工具介紹及安裝——FSL-Introduction

特別說明:本文為原創文章,參考或轉發本文需注明本文鏈接,有問題請聯系:nick.yu.jd@qq.com
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,333評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,491評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,263評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,946評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,708評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,409評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,939評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,774評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,209評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,641評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,872評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,650評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內容