matlab 读写磁共振影像.nii 数据

2023-10-19 12:52

本文主要是介绍matlab 读写磁共振影像.nii 数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:

  参考LEiDA方法和周昌松老师的large-scale network 的分离整合的划分[1],脑区划分结束后需要把脑区的结果用脑图的形式呈现出来,但是因为我划分脑区的结果都是保存在mat文件里,Brainnet Viewer 则需要使用 .nii 类型的文件。因此,研究了一下如何将数据写入.nii文件。

在这里插入图片描述

加载BrainNet Viewer的样例数据

nifti_data = load_nii('D:\Program Files\ThirdTools\BrainNetViewer_20191031\Data\ExampleFiles\AAL90\aal.nii');

数据结构

nifti_data = load_nii('D:\Program Files\ThirdTools\BrainNetViewer_20191031\Data\ExampleFiles\AAL90\aal.nii');% Extract the voxel values
voxel_values = nifti_data.img(:);% Filter out zero values
non_zero_values = voxel_values(voxel_values ~= 0);% Calculate basic statistics
mean_value = mean(non_zero_values);
median_value = median(non_zero_values);
min_value = min(non_zero_values);
max_value = max(non_zero_values);

通过代码,也可以判断数据存储在nifti_data.img中,1表示的是脑区1,2表示脑区2,3表示脑区3…,以此类推。

如果只是划分脑网络,那么就只需要将脑区x的值x替换为所属的脑区y,就可以实现脑区划分,

如果需要达到参考文献C图的效果,以参考文献中的第4层8个网络为例,我们需要将img中保存的116个脑区的所属的脑区id替换为该脑区对应的特征向量。

实际操作过程中遇到了数据无法保存的问题,原因是样例aal.nii文件的.img 格式为unit8,表示无符号,因此,我们写入的负数、小数值会被强制转换为无符号整数,因此,修改数据前需要先修改数据类型,数据类型的具体描述在save_nii.m 文件中有详细说明。

%%----*** 保存每个不同level的network***---
function write_tonii(level)disp(level);% Load the original NIfTI filenifti_data = load_nii('D:\Program Files\ThirdTools\BrainNetViewer_20191031\Data\ExampleFiles\AAL90\aal.nii');% 设置数据格式,数据格式在save_nii.m文件中有详细说明,此处选则浮点型,代码为16nifti_data.hdr.dime.datatype=16;nifti_data.hdr.dime.bitpix=16;%将模板文件中的unit8改成浮点型,然后写入数据modified_data = double(nifti_data.img);%加载我的数据,脑区与特征向量值的对照表,这个表格的数据是从mat文件中读取后整理成csv格式了,也可以直接整理成mat格式保存dataTable = readtable(['F:\projects\LEiDA-BD\df_sorted_desc_',num2str(level),'.csv'], 'Delimiter', ',');% 写代码,将相应的脑区的数据更改为对应的值然后保存。for i = 1:116indices = find(modified_data ==i);% 根据脑区值获得对应的特征向量值保存到 nii.img 中eigen_value =  dataTable.eigen_value(dataTable.region_id == i);modified_data(indices) =eigen_value;end% Update the data in the NIfTI structurenifti_data.img = double(modified_data);% Save the modified NIfTI file with the same format and informationsave_file = ['aal_level',num2str(level),'_eigen_network.nii'];save_nii(nifti_data, save_file);

然后,使用BrainNet Viewer查看结果,如下图所示。
在这里插入图片描述

参考文献:
[1] Wang, et al. (2021). Segregation, integration, and balance of large-scale resting brain networks configure different cognitive abilities. Proc Natl Acad Sci U S A, 118(23). doi:10.1073/pnas.2022288118

这篇关于matlab 读写磁共振影像.nii 数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/239929

相关文章

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南

《在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南》在SpringBoot和MyBatis项目中实现MySQL读写分离,主要有两种思路:一种是在应用层通过代码和配置手动控制... 目录如何选择实现方案核心实现:应用层手动分离实施中的关键问题与解决方案总结在Spring Boot和

使用MyBatis TypeHandler实现数据加密与解密的具体方案

《使用MyBatisTypeHandler实现数据加密与解密的具体方案》在我们日常的开发工作中,经常会遇到一些敏感数据需要存储,比如用户的手机号、身份证号、银行卡号等,为了保障数据安全,我们通常会对... 目录1. 核心概念:什么是 TypeHandler?2. 实战场景3. 代码实现步骤步骤 1:定义 E

使用C#导出Excel数据并保存多种格式的完整示例

《使用C#导出Excel数据并保存多种格式的完整示例》在现代企业信息化管理中,Excel已经成为最常用的数据存储和分析工具,从员工信息表、销售数据报表到财务分析表,几乎所有部门都离不开Excel,本文... 目录引言1. 安装 Spire.XLS2. 创建工作簿和填充数据3. 保存为不同格式4. 效果展示5

Python多任务爬虫实现爬取图片和GDP数据

《Python多任务爬虫实现爬取图片和GDP数据》本文主要介绍了基于FastAPI开发Web站点的方法,包括搭建Web服务器、处理图片资源、实现多任务爬虫和数据可视化,同时,还简要介绍了Python爬... 目录一. 基于FastAPI之Web站点开发1. 基于FastAPI搭建Web服务器2. Web服务

MySQL 批量插入的原理和实战方法(快速提升大数据导入效率)

《MySQL批量插入的原理和实战方法(快速提升大数据导入效率)》在日常开发中,我们经常需要将大量数据批量插入到MySQL数据库中,本文将介绍批量插入的原理、实现方法,并结合Python和PyMySQ... 目录一、批量插入的优势二、mysql 表的创建示例三、python 实现批量插入1. 安装 PyMyS