国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

python使用nibabel和sitk讀取保存nii.gz文件實(shí)例

瀏覽:84日期:2022-07-19 10:19:50

nii.gz格式是醫(yī)學(xué)圖像常用的壓縮格式,python中可用nibabel和sitk來讀取保存。

使用nibabel

由于使用nibabel圖像會(huì)旋轉(zhuǎn)90度,所以讀取保存的時(shí)候還得保存映射信息,3維圖像格式為(z, y, x)

讀取nii.gz文件

img = nib.load(’xxxxx.nii.gz’)img_affine = img.affineimg = img.get_data()

保存nii.gz文件

nib.Nifti1Image(img,img_affine).to_filename(’xxxxx.nii.gz’)

使用sitk

使用sitk讀取nii時(shí),讀取出來的還是圖片格式,可以使用他自帶的函數(shù)進(jìn)行處理,不過速度比較慢,建議使用GetArrayFromImage轉(zhuǎn)換成numpy格式再處理,3維圖像格式為(x, y, z)

讀取nii.gz文件

img = sitk.ReadImage(’xxxxx.nii.gz’)

img = sitk.GetArrayFromImage(img)

保存nii.gz文件

out = sitk.GetImageFromArray(img)

sitk.WriteImage(out,’xxxxx.nii.gz’)

在numpy數(shù)組和nibabel或sitk中相互轉(zhuǎn)換時(shí),要注意數(shù)據(jù)的格式,一般保存為int或uint類型。比如輸入nii為16位有符號整型時(shí),我們可能需要轉(zhuǎn)換成0~255灰度圖,可用如下代碼:

img = sitk.ReadImage(’xxxxx.nii.gz’)img = sitk.Cast(sitk.RescaleIntensity(img),sitk.sitkUInt8)img = sitk.GetArrayFromImage(img)

補(bǔ)充知識(shí):SimpleITK保存Nii文件與錯(cuò)誤處理方式

Reason:

把處理好的分割結(jié)果保存為nii文件,用ITKsnap讀取時(shí)出現(xiàn)了如下錯(cuò)誤。

python使用nibabel和sitk讀取保存nii.gz文件實(shí)例

SimpleITK讀取和保存Nii文件

1. 讀取

import SimpleITK as sitkfilename = ’./xxx.nii’ct = sitk.ReadImage(filename)ct_array = sitk.GetArrayFromImage(ct)origin =ct.GetOrigin()direction = ct.GetDirection()space = ct.GetSpacing()

2. 保存

savedImg = sitk.GetImageFromArray(ct_array)savedImg.SetOrigin(origin)savedImg.SetDirection(direction)savedImg.SetSpacing(space)sitk.WriteImage(savedImg, saved_name)

Note:被保存的ct_array數(shù)組一定是ndarray,float類型的才能被ITKsnap正確讀取,如果是int類型的,就會(huì)出現(xiàn)上圖中的錯(cuò)誤。

以上這篇python使用nibabel和sitk讀取保存nii.gz文件實(shí)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 沁源县| 赣榆县| 绥棱县| 涿鹿县| 靖远县| 东兴市| 蒲江县| 迁西县| 庆城县| 雷山县| 宁城县| 蓬安县| 铁力市| 长沙市| 西充县| 曲周县| 泰兴市| 诸暨市| 广饶县| 栖霞市| 德州市| 齐齐哈尔市| 江永县| 淮阳县| 吉林市| 南丹县| 台州市| 屯留县| 邵阳市| 上虞市| 师宗县| 佛冈县| 曲周县| 嫩江县| 商水县| 巴塘县| 志丹县| 松溪县| 伊金霍洛旗| 黄浦区| 榆树市|