BrainWeb: Simulated Brain Database使用(原图以及GroundTruth切片可视化)和矢状冠状横断面

本文主要是介绍BrainWeb: Simulated Brain Database使用(原图以及GroundTruth切片可视化)和矢状冠状横断面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、BrainWeb数据集简介?
  • 二、使用步骤
    • 1.文件下载
    • 2.数据处理
    • GroundTruth


注:此篇文章参考脑图像的数据预处理
作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/
由于我在做实验时需要脑部横断面,矢状,冠状的原始图片,以及ground truth,
重新梳理BrainWeb数据集的使用。


一、BrainWeb数据集简介?

BrainWeb: Simulated Brain Database
http://brainweb.bic.mni.mcgill.ca/brainweb/
数据集选自McGill大学Montreal神经所大脑成像中心的Brain Web反震脑部MR图像数据库。该数据库包含基于两种解剖模型的模拟脑MRI数据:正常和多发性硬化(MS),并且提供了人工合成三种模态(T1-, T2-, PD-)下的三维脑MR图像。图像中包含不同的扫描厚度、噪声以及偏移场,最重要的是且该数据库对于所有脑MR图像均提供了标准分割结果
用户可对所需图片自定义进行下载:

  1. 模态 T1,T2,PD

  2. 协议 icmb

  3. 脑图像名字:正常

  4. 切片厚度 1mm,3mm,5mm,7mm,9mm

  5. 噪声水平 pn0=0%;1%,3%,5%,7%,9%

  6. 灰度不均匀水平 rf0=0%;20%,40%

二、使用步骤

1.文件下载

原始图片以ms病变脑数据库为例,模态= T1,协议= ICBM,幻像名称=正常,切片厚度= 1mm,噪声= 0%,INU = 0%:

groundtruth同样以以ms病变脑数据库为例

多发性硬化脑数据
在这里插入图片描述
在这里插入图片描述

下载好之后就可以处理数据了

2.数据处理

得到第90切片

function g = readrawb(filename, num)
%函数readrawb(filename, num)中的第一个参数filename是欲读取的rawb文件的文件名,第二个参数num就是第多少张。
fid = fopen(filename);
%连续读取181*217*181个数据,这时候temp是一个长度为181*217*181的向量。
%先将rawb中的所有数据传递给temp数组
temp = fread(fid, 181 * 217 * 181);
%然后把它变成了一个181*217*181的数组
images = reshape(temp, 181 , 217, 181);  
%获取图片大小[xrange, yrange, zrange] = size(images);
%   不同维度(切面)的图的第num张切片data_volume(1:xrange,1:yrange) = images(:,:,num);
%     data_volume(1:xrange,1:zrange) = images(:,num ,:);
%     data_volume(1:yrange,1:zrange) = images(num,:,:);
g = data_volume;
fclose(fid);
end
function init_image(filename,num)
pic_type='.png';
save_path='E:\BrainImages\Origin_MS\';
% 函数init_image(filename,num)中的第一个参数filename是欲读取的rawb文件的文件名,第二个参数num就是第多少张。输出为原始图像,未处理
%例如:init_image('t1_icbm_normal_1mm_pn0_rf0.rawb','train.txt',90)init_image('phantom_1.0mm_normal_csf.rawb','train.txt',90)
read=readrawb(filename, num);
% 旋转90°并显示出来
read=imrotate(read, 90);                                       
imshow(mat2gray(read));
imwrite(mat2gray(read),strcat(save_path,'origin_1_t3_90',pic_type));
end

命令行输入init_image('t1_ai_msles2_1mm_pn0_rf0.rawb', 90)即可获得结果
想要其他维度切片时只需将readrawb中的注释更改即可
在这里插入图片描述


GroundTruth

T1模态、icmb协议下,切片厚度为1mm,噪声水平为0,灰度不均匀水平为0的ms病变脑图像,第90层
只选取0、1、2、3、10类的数据,各类别官网有介绍
分割之后各类用以下像素值进行渲染:
0:0
1:50
2:150
3:255
10: 230

function Ground_truth(name, num)
%标准分割结果
%例如:Ground_truth('Ground truth.txt',90)
mark=Mark('phantom_1.0mm_msles2_crisp.rawb',num);
for i=1:181   %for j=1:217    %if mark(i,j)==1read_new(i,j)=50;elseif mark(i, j)==2read_new(i,j)=150;elseif mark(i, j)==3read_new(i,j)=255;elseif mark(i,j)==10;read_new(i,j)=230elseread_new(i,j)=0;endend
end
% 旋转90°并显示出来
read_new=imrotate(read_new, 90);
%mark=mark';
imshow(mat2gray(read_new));
pic_type='.png';
save_path='E:\BrainImages\GroundTruth\';
imwrite(mat2gray(read_new),strcat(save_path,'gt_1_t1_90',pic_type));
function mark=Mark(filename,num)
%将标签为12310类分出来,其余为0,mark取值:012310
%[mark_new,mark]=Mark('phantom_1.0mm_normal_crisp.rawb',90);
fp=fopen(filename);
temp=fread(fp, 181 * 217 * 181);
images=reshape(temp, 181 ,217, 181);  [xrange, yrange, zrange] = size(images);%不同方向的ground truthdata_volume(1:xrange,1:yrange) = images(:,:,num); %横截面
%     data_volume(1:xrange,1:zrange) = images(:,num ,:);%冠状
%     data_volume(1:yrange,1:zrange) = images(num,:,:);%矢状
mark_data=data_volume;
fclose(fp);
%将第012310类标签所在的坐标点拿出来,其余置0
for i=1:181for j=1:217if (mark_data(i,j)==1)||(mark_data(i,j)==2)||(mark_data(i,j)==3)||(mark_data(i,j)==10)mark(i,j)=mark_data(i,j);elsemark(i,j)=0;endend
end

运行Ground_truth('Ground truth.txt',90)
即可得到结果,同样,需要其他维度切片,更改Mask.m中的注释即可。
在这里插入图片描述

这篇关于BrainWeb: Simulated Brain Database使用(原图以及GroundTruth切片可视化)和矢状冠状横断面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE