Matlab-写入mhd和raw医学图像处理格式文件

作者:翟天保Steven
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

mhd和raw是什么?

       MHD(MetaImage)和RAW(Raw Image Data)是用于医学图像处理和分析的常见文件格式之一。

  1. MHD (MetaImage) 文件格式

    • 描述:MHD 文件是一种元数据文件,用于描述与医学图像相关的数据。通常与 RAW 格式文件一起使用,MHD 文件包含有关图像数据的元信息,如图像尺寸、像素类型、数据间隔等。
    • 特点:MHD 文件不存储图像本身的像素数据,而是提供关于数据的描述信息。
    • 元信息:MHD 文件通常包含有关图像的描述信息,例如像素类型(如无符号字节型、有符号字节型、无符号短整型、有符号短整型等)、像素尺寸(如宽度、高度、深度)、数据间隔(指数据在内存中的存储方式)等。
    • 扩展名:通常的 MHD 文件扩展名为 .mhd。
  2. RAW (Raw Image Data) 文件格式

    • 描述:RAW 文件是包含原始像素数据的文件格式,通常不包含任何元信息或者包含极少的元信息。
    • 特点:RAW 文件通常存储医学图像的原始像素数据,这些数据未经过处理或解码。
    • 像素数据:RAW 文件包含图像的原始像素数据,通常以二进制形式存储。这些数据可能是未经过任何压缩或编码的原始数据。
    • 用途:通常需要与 MHD 文件一起使用,通过 MHD 文件提供的元信息,可以解释 RAW 文件中的原始像素数据。
    • 扩展名:RAW 文件可以使用各种扩展名,如 .raw、.bin、.dat 等。

       在医学图像处理中,通常使用 MHD 文件来描述图像的属性和结构,而使用 RAW 文件来存储图像的原始像素数据。这种结合使得图像处理软件能够准确解释图像数据,并进行进一步的处理、分析或可视化。

Matlab代码

% 写入Mhd和Raw文件
function writeMhdAndRaw(filename, data, element_spacing, data_type)
% 创建mhd和raw
mhd = strcat(filename, '.mhd');
raw = strcat(filename, '.raw');
% 写入mhd文件
fid = fopen(mhd, 'w');
assert(fid > 0, 'Open MHD File Error.');
% 类型
fprintf(fid, 'ObjectType = Image\n');
% 维度
fprintf(fid, 'NDims = %d\n', ndims(data));
% 不同维度的尺寸和元素间距
dims = ndims(data);
if(dims == 2)fprintf(fid, 'DimSize = %d %d \n', size(data,1), size(data,2));fprintf(fid, 'ElementSpacing = %1.4f %1.4f\n', element_spacing(1), element_spacing(2));
elseif(dims == 3)fprintf(fid, 'DimSize = %d %d %d\n', size(data,1), size(data,2), size(data,3));fprintf(fid, 'ElementSpacing = %1.4f %1.4f %1.4f\n', element_spacing(1), element_spacing(2), element_spacing(3));
elseif(dims == 4)fprintf(fid, 'DimSize = %d %d %d %d\n', size(data,1), size(data,2), size(data,3), size(data,4));fprintf(fid, 'ElementSpacing = %1.4f %1.4f %1.4f %1.4f\n', element_spacing(1), element_spacing(2), element_spacing(3), element_spacing(4));
end
% 数据类型
if(strcmp(data_type,'char') || strcmp(data_type,'uint8'))fprintf(fid, 'ElementType = MET_UCHAR\n');
elseif(strcmp(data_type,'short'))fprintf(fid, 'ElementType = MET_SHORT\n');
elseif(strcmp(data_type,'float32'))fprintf(fid, 'ElementType = MET_FLOAT\n');
end
% 元素字节顺序
% MSB(又名big-endian)排序在SPARC和摩托罗拉处理器(例如Macintoshes)中很常见。
% LSB(又名little-endian)排序在英特尔处理器(例如PC兼容机)中很常见。
fprintf(fid, 'ElementByteOrderMSB = False\n');
% 设置raw文件
fprintf(fid, 'ElementDataFile = %s\n', raw);
% 关闭mhd
fclose(fid);
% 写入raw文件
fid = fopen(raw, 'w');
assert(fid > 0, 'Open RAW File Error.');
% 写入数据
fwrite(fid, data, data_type);
% 关闭raw
fclose(fid);
end

测试代码

       测试功能就是将test.mat中的图像矩阵A1,保存为mhd和raw格式,并用ImageJ软件加载测试。

% 加载mat文件
load('test.mat'); 
filename = 'test';
image_data = int16(A1); 
element_spacing = [1, 1];
data_type = 'short';
% 调用函数
writeMhdAndRaw(filename, image_data, element_spacing, data_type);

测试数据地址:

链接:https://pan.baidu.com/s/1xkR1lfDrCYoGYsfBXRDMIA 
提取码:p0s6 

测试效果     

源数据:

ImageJ加载保存的mhd文件:

       ImageJ中宽高对应matlab中的行列,所以显示效果是转置的。因为我刚开始用ImageJ,也可能是我没配置好,如果有问题烦请指出。

       如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/781528.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【测试工具】JMeter接口测试的简单使用

事先声明:博主的JMeter是3.3版本的,可能和最新版本的操作有些许差别 测试前的准备工作 1、先添加一个线程组:右击“测试计划”,点击“添加”—》“Threads(Users)”—》“线程组” 2、再添加一个HTTP请求,右击“线程…

基于Hive大数据分析springboot为后端以及vue为前端的的民宿系

标题基于Hive大数据分析springboot为后端以及vue为前端的的民宿系 本文介绍了如何利用Hive进行大数据分析,并结合Spring Boot和Vue构建了一个民宿管理系统。该民民宿管理系统包含用户和管理员登陆注册的功能,发布下架酒店信息,模糊搜索,酒店详情信息展示,收藏以及对收藏的…

Pillow教程03:图像处理的基本步骤+分离split+合并merge+混合blend+composite遮罩

--------------Pillow教程集合--------------- Python项目18:使用Pillow模块,随机生成4位数的图片验证码 Python教程93:初识Pillow模块(创建Image对象查看属性图片的保存与缩放) Pillow教程02:图片的裁剪…

烫烫烫手的结构体大小计算来咯,很烫哦,慢慢消化。自定义类型(一)

emmm,在这炎热的夏天在宿舍吹着空调写着博客也是一件不错的事呢,今天就来来好好盘一下C语言中的自定义类型。 常常会回顾努力的自己,所以要给自己的努力留下足迹。 为今天努力的自己打个卡,留个痕迹吧 2024.03.29 小闭 目录 …

C++项目——集群聊天服务器项目(九)客户端异常退出业务

服务器端应检测到客户端是否异常退出,因此本节来实现客户端异常退出,项目流程见后文 一、客户端异常退出业务流程 (1)在业务模块定义处理客户端异常退出的函数 (2)集群聊天服务器项目(八)提到…

为什么在Python中总是使用【字典】这种类型呢?

你好,我是安然无虞。 文章目录 创建字典新增字典元素update 方法 删除字典元素pop 方法popitem 方法 查找字典元素in 和 in not 操作符get 方法thisdict[key] 修改字典元素遍历字典元素for循环遍历keys方法values方法items方法 合并字典字典中的key 字典常用接口汇…

网际协议 - IP

文章目录 目录 文章目录 前言 1 . 网际协议IP 1.1 网络层和数据链路层的关系 2. IP基础知识 2.1 什么是IP地址? 2.2 路由控制 3. IP地址基础知识 3.1 IP地址定义 3.2 IP地址组成 3.3 IP地址分类 3.4 子网掩码 IP地址分类导致浪费? 子网与子网掩码 3.5 CIDR与…

自己动手用ESP32手搓一个智能机器人:ESP32-CAM AI Robot

目录 介绍 硬件需求 软件需求 步骤 总结 源码下载 介绍 ESP32-CAM是一款集成了Wi-Fi和蓝牙功能的微控制器模块,同时还集成了摄像头接口,使其成为一个非常适合构建智能机器人的选择。在本项目中,我将向您展示如何使用ESP32-CAM模块构建…

数据运营分析-详解

一、指标与指标体系 指标体系就是业务逻辑的框架,也是思考业务逻辑的第一步 案例: 老板,我负责的用户活跃,主要考察每天启动产品的注册用户数量,整体来看,每月活跃保持7.3%的增长,是因为渠道团队的拉新活动带来很多新增注册用户,占每月活跃用户的40%,新一年会继续沿…

消息队列的七种经典应用场景

在笔者心中,消息队列,缓存,分库分表是高并发解决方案三剑客。 在职业生涯中,笔者曾经使用过 ActiveMQ 、RabbitMQ 、Kafka 、RocketMQ 这些知名的消息队列 。 这篇文章,笔者结合自己的真实经历,和大家分享…

Linux项目自动化构建工具-make/ makefile及其应用:多文件编写第一个linux程序:进度条(懒人学习必备博文!!!)

目录 1.前言--make/makefile的引入 2.快速上手make/makefile---自动化构建 3.关于依赖关系和依赖方法 4.自动化清理 为什么我们执行编译的时候,make一下就好,清理却要使用make clean? 5. make/makefile是如何知道当前目录下可执行文件是否为最新 6.文件…

express实现用户登录和注册接口

目录 1 创建数据库2 连接数据库3 集成ORM库4 创建业务逻辑5 创建路由7 测试接口总结 我们在编写后端接口的时候操作数据库是一种常见的功能需求,express本身并不提供直接操作数据库的能力,需要借助第三方库来操作数据库,本篇讲解一下软件开发…

【二叉树】Leetcode 543. 二叉树的直径【简单】

二叉树的直径 给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。 两节点之间路径的 长度 由它们之间边数表示。 示例1: 输入:root [1,2…

基于SpringBoot + Vue实现的在线装修管理系统设计与实现+毕业论文

介绍 系统包含用户、装修队、管理员三个角色 管理员: 管理员管理:管理其他管理员的账号和权限,确保系统管理的层次化和安全性。 装修队管理:审核装修队的资质,管理装修队的人员信息,监控工程进度&#xff…

elementUI this.$msgbox msgBox自定义 样式自定义 富文本

看这个效果是不是很炫?突出重点提示内容,对于用户交互相当的棒! 下来说说具体实现: let self = this const h = self.$createElement; this.$msgbox({title: null,message: h("p", {style: "margin-top:10px"}, [h("i", {class: "el-i…

命名空间【C++】(超详细)

文章目录 命名空间的概念命名空间的定义命名空间定义的位置作用域每一个命名空间都是一个独立的域作用域符:: 编译器找一个变量/函数等的定义,寻找域的顺序为什么要有命名空间?1.解决库与程序员定义的同名的重定义问题2.解决程序员…

【氮化镓】p-GaN栅极退化的温度和结构相关性

论文总结: 本文献深入研究了带有p-GaN栅极的正常关断型(normally-off)高电子迁移率晶体管(GaN-HEMTs)在恒定电压应力下的时序退化行为。通过直流特性分析和温度依赖性分析,研究了故障时间(TTF)与应力温度和器件几何结构的依赖性。结果显示,p…

FME学习之旅---day17

我们付出一些成本,时间的或者其他,最终总能收获一些什么。 【FME-HOW-TO系列】28 栅格邻域函数 RasterConvolver转换器说明: 接受包含栅格几何对象的输入要素,并在对所有波段应用卷积滤波 器后输出要素。 本人对栅格数据处理的较…

【2023】kafka在linux和docker安装(kafka-1)

目录💻 一、linux安装kafka1. 安装jdk2. 上传解压到/usr/local目录下3、使用kafka 二、docker安装kafka1. 下载2. 安装zookeeper3. 安装kafka 一、linux安装kafka 环境主机 mac m2、虚拟机Ubuntu22.04.4 1. 安装jdk yum install -y java-1.8.0-openjdk.x86_64下载k…

11-设计模式:Go常用设计模式概述

设计模式是啥呢?简单来说,就是将软件开发中需要重复性解决的编码场景,按最佳实践的方式抽象成一个模型,模型描述的解决方法就是设计模式。使用设计模式,可以使代码更易于理解,保证代码的重用性和可靠性。 …