nii格式mask映射为新的mask

server/2024/11/14 6:00:45/

在DCE图像上勾画的ROI转换为nii格式形成的mask,形状和DCE的原始图像一致,用于特征提取,形状不一致不能特征提取;
DCE图像和T2图像的形状不一致,所以mask不能用于T2的特征提取;
这个脚本根据DCE勾画的mask,和T2的图像,生成T2的mask,形状和T2一致,用于特征提取;

import glob
import os
import shutil
import numpy as np
import pandas as pd
import pydicom
import nibabel as nib
import SimpleITK as sitk
import torch
import torch.nn.functional as F
from matplotlib import pyplot as plt'''
在DCE图像上勾画的ROI转换为nii格式形成的mask,形状和DCE的原始图像一致,用于特征提取,形状不一致不能特征提取;
DCE图像和T2图像的形状不一致,所以mask不能用于T2的特征提取;
这个脚本根据DCE勾画的mask,和T2的图像,生成T2的mask,形状和T2一致,用于特征提取;将mask插值为T2图像的大小,然后与T2图像进行相乘,得到T2的mask;
nii文件不但有图像的值信息还有位置等其他信息,所以将mask插值为T2图像的大小不能用于特征提取;而是在dcm文件转化为nii过程中今替换里面的图像的值,不改变其他信心。dcms_root_path文件夹下是每一个患者的姓名,每个患者的姓名文件夹下是每张dcm文件
mask_dir_path 勾画好的mask文件夹,用DCE图像勾画的ROI,形状和DCE图像一致
savenii_path 存放新生成的nii文件'''def dcm2nii(dcmdir_path, mask_path, savenii_path):# 1.构建dicom序列文件阅读器,并执行(即将dicom序列文件“打包整合”)label_nii = sitk.ReadImage(mask_path)label_array = sitk.GetArrayFromImage(label_nii)label_array = F.interpolate(torch.tensor(label_array, dtype=torch.float32).unsqueeze(0), size=(672, 672),mode='nearest').squeeze().numpy().astype(np.uint8)reader = sitk.ImageSeriesReader()dicom_names = reader.GetGDCMSeriesFileNames(dcmdir_path)reader.SetFileNames(dicom_names)image2 = reader.Execute()# 2.将整合后的数据转为array,并获取dicom文件基本信息image_array = sitk.GetArrayFromImage(image2)  # z, y, x# 将数组中所有的数值都变为1image_array = np.ones_like(image_array)label = image_array * label_arrayorigin = image2.GetOrigin()  # x, y, zspacing = image2.GetSpacing()  # x, y, zdirection = image2.GetDirection()  # x, y, z# 3.将array转为img,并保存为.nii.gzimage3 = sitk.GetImageFromArray(label)image3.SetSpacing(spacing)image3.SetDirection(direction)image3.SetOrigin(origin)sitk.WriteImage(image3, os.path.join(savenii_path, ))dcms_root_dir_path = r"F:\300多的乳腺MR图像\良性\T2"
mask_dir_path = r"C:\Users\Administrator\Desktop\Breast\benign_label"
savenii_dir = r"C:\Users\Administrator\Desktop\Breast\lianxi"patients = os.listdir(dcms_root_dir_path)
mask_dir = os.listdir(mask_dir_path)
for mask_name in mask_dir:label_name = mask_name.split("-")[0]for i , p in enumerate(patients):name = p.split("-")[0]if name == label_name:dcms_path = os.path.join(dcms_root_dir_path, p)mask_path = os.path.join(mask_dir_path, mask_name)dcm2nii(dcms_path,mask_path, os.path.join(savenii_dir, f'{name}-T2label.nii'))print(f'正在处理第{i+1}个文件')print("finished")


http://www.ppmy.cn/server/33992.html

相关文章

基于Java,SpringBoot,Vue,Python爬虫,Hadoop大数据旅游推荐管理系统

摘要 本系统是一个基于Java, SpringBoot, Vue, Python爬虫, Hadoop大数据技术的旅游推荐管理系统。该系统旨在为用户提供个性化的旅游推荐服务,通过分析用户的旅游历史数据和行为模式,为用户推荐合适的旅游目的地、景点等。 系统采用Spring…

Easy TCP Analysis提供了四大特性,兼顾了TCP数据包分析入门学习到实战问题排查不同阶段用户对工具的需求

一款兼顾TCP数据包分析入门学习和实战不同阶段用户需求的工具 Easy TCP Analysis是一款在线TCP数据包分析工具,致力于让TCP数据包分析变得跟看聊天记录一样简单! Easy TCP Analysis提供了四大特性,兼顾了从入门学习到实战分析不同阶段用户对…

完全数计算

描述 完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。 它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。 例如:…

[Java EE] 多线程(六):线程池与定时器

🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏:🍕 Collection与数据结构 (90平均质量分)https://blog.csdn.net/2301_80050796/category_12621348.html?spm1001.2014.3001.5482 🧀Java …

【LAMMPS学习】八、基础知识(5.7)Drude感应偶极子

8. 基础知识 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语,以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和运行各…

JavaScript Array 对象

JavaScript数组是一种特殊的对象,可以用来存储多个值并按照顺序访问这些值。Array对象提供了一些方法来操作数组。 创建数组: 使用数组字面量创建数组:var arr [1, 2, 3];使用Array构造函数创建数组:var arr new Array(1, 2, …

软工导论第三章 需求分析

对软件需求的深人理解是软件开发工作获得成功的前提条件,不论人们把设计和编码工作做得如何出色,不能真正满足用户需求的程序只会令用户失望,给开发者带来烦恼。(意义) 需求分析是软件定义时期的最后一个阶段,它的基本任务是准确地回答“系统必须做什么”…

如何使用StegCracker发现恶意文件中的隐藏数据

关于StegCracker StegCracker是一款功能强大的恶意文件分析工具,该工具基于Python开发,可以帮助广大研究人员使用隐写术暴力破解功能来发现恶意文件中的隐藏数据。 工具要求 Python 3.6 Steghide库 依赖组件安装 当前版本的StegCracker需要使用到Stegh…