如何更改轴 SimpleITK::ImageSeriesWriter 使用?

How Do I Change the Axis SimpleITK::ImageSeriesWriter Using?

SimpleITK::ImageSeriesWriter 默认沿 Z 轴对给定的 3D 体积进行切片,并在 XY 视图中写入 2D 图像的切片。

如何更改轴以使输出处于 XZ 或 YZ 视图?

换句话说,如果默认的Z轴切片是Axial view,如何获取Coronal view和Sagittal view的切片?

我尝试了 GitHub:FNNDSC/med2image 的输出 xyz 函数。 但是图像数组是盲写的,所以有时 X 和 Y 会被调换,或者其中一个轴被反转(翻转)。 所以我觉得有必要编写自己的代码来完全控制。

def slice(dcm_folder, output_stem):
    print('Reading Dicom directory:', path.abspath(dcm_folder))
    reader = sitk.ImageSeriesReader()

    dicom_names = reader.GetGDCMSeriesFileNames(dcm_folder)
    reader.SetFileNames(dicom_names)

    image = reader.Execute()

    # cast the bit depth to PNG compatible "unsigned char"
    image = sitk.Cast(sitk.RescaleIntensity(image), sitk.sitkUInt8)

    size = image.GetSize()
    print( "Image size:", size[0], size[1], size[2] )

    # need Z filenames to write
    series_filenames = list([output_stem + '-slice' + str(i).zfill(3) + '.png' for i in range(size[2])])

    print('Writing {} image slices'.format(size[2]))
    writer = sitk.ImageSeriesWriter()
    writer.SetFileNames( series_filenames )
    writer.Execute(image)

上面的代码将成功写出Z轴的切片。 如何修改代码,以便我可以获得另外 2 个视图的切片?

您应该能够使用 PermuteAxesImageFilter 来交换体积的轴。这是该过滤器的文档:

https://itk.org/SimpleITKDoxygen/html/classitk_1_1simple_1_1PermuteAxesImageFilter.html

或者,如果您更喜欢程序界面(就像我一样),您可以使用 PermuteAxes 函数。

好吧,我想你已经解决了你的问题。但我所做的只是导入一个 .mha 文件(或简单 ITK 支持的另一个扩展名)并将其转换为 3D 数组。然后你需要做的就是一次在不同的轴上切片这个数组。看一看(python代码):

import SimpleITK as sitk #importing package
path = '/current/folder/mha/file'
ct = sitk.ReadImage(path) #var_type is SimpleITK.Image
ndarray = sitk.GetArrayFromImage(ct) #converting from SimpleITK.Image to numpy ndarray
# Axial view:
plt.imshow(ndarray[100,:,:], cmap='gray') # plotting 100º image from axial view
#Coronal view:
plt.imshow(ndarray[:,100,:], cmap='gray') # plotting 100º image from coronal view
#Sagittal view:
plt.imshow(ndarray[:,:,100], cmap='gray') # plotting 100º image from sagittal view