打开DICOM文件需要注意到的点

2024-04-01 10:44
文章标签 需要 打开 注意 dicom

本文主要是介绍打开DICOM文件需要注意到的点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DICOM图片用来存储医学信息

我一般处理的是图像信息,总结一下踩过的坑

在这里插入图片描述

打开DICOM文件需要注意到的点
  1. DICOM图片使用python进行打开一定要注意窗口问题,dicom文件里面存储了很多其他的附加信息,不仅仅是图片,其中最重要的一个条就是要使用窗口信息。如果窗口信息不正确,由于dicom文件不是8位或者标准的浮点图片存储,它的位数很大,你直接读取,可能就是黑色的图。同时窗口信息可能不止一个,有多个,需第一组,或者最后一组就行。
  2. 进行dicom文件显示的时候,我们一般使用PIL.Image库,但是要注意dicom文件加载出来的是浮点数,直接使用Image进行存储都是黑漆漆的,Image支持uint8,float32的图片如果在不乘以255就进行数据格式的改变的话,它截取所有小于1的为0,1值,在0-255区间就是黑色,所以信息全部损失了。所以在展示保存或者其他操作之前,一定要将图片先乘以255,然后再改变数据格式,这样才能正确的显示实际的信息。

在这里插入图片描述

我在处理DICOM文件时的一些操作

def preprocess_image(self, image_path, target_height=1350, target_width=900, fill=0, change_side='right', padding_mode='constant'):dicom = pydicom.dcmread(image_path)try:window_center = dicom.WindowCenterwindow_width = dicom.WindowWidth# 如果WindowCenter和WindowWidth是列表,选择第一个值if isinstance(window_center, pydicom.multival.MultiValue):window_center = window_center[0]if isinstance(window_width, pydicom.multival.MultiValue):window_width = window_width[0]except Exception as e:print(f"文件 {image_path} {e} 没有窗口参数")dicom_image = apply_voi_lut(dicom.pixel_array, dicom)min_val = window_center - (window_width / 2)max_val = window_center + (window_width / 2)dicom_image = np.clip(dicom_image, min_val, max_val)dicom_image = (dicom_image - min_val) / (max_val - min_val)dicom_image = dicom_image.astype(np.float32)original_height, original_width = dicom_image.shapenew_height = target_height  # 保持高度不变new_width = int(original_width * (new_height / original_height))  # 根据新的高度比例调整宽度# 根据目标宽度调整图像if new_width < target_width:padding = target_width - new_widthif change_side == 'left':img_padded = cv2.copyMakeBorder(dicom_image, 0, 0, padding, 0, cv2.BORDER_CONSTANT, value=fill)else:img_padded = cv2.copyMakeBorder(dicom_image, 0, 0, 0, padding, cv2.BORDER_CONSTANT, value=fill)elif new_width > target_width:crop = int((new_width - target_width) / 2)if change_side == 'left':img_padded = dicom_image[:, crop*2:]else:img_padded = dicom_image[:, :-crop*2]else:img_padded = dicom_imageimg_resized = cv2.resize(img_padded, (target_width, target_height), interpolation=cv2.INTER_LANCZOS4)img_resized = np.clip(img_resized, 0, 1)preprocess = transforms.Compose([transforms.ToTensor(),])return preprocess(img_resized)

图片展示

在这里插入图片描述

这篇关于打开DICOM文件需要注意到的点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何提高Redis服务器的最大打开文件数限制

《如何提高Redis服务器的最大打开文件数限制》文章讨论了如何提高Redis服务器的最大打开文件数限制,以支持高并发服务,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录如何提高Redis服务器的最大打开文件数限制问题诊断解决步骤1. 修改系统级别的限制2. 为Redis进程特别设置限制

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

SpringMVC入参绑定特别注意

1.直接在controller中定义一个变量,但是此种传输方式有一个限制就是参数名和请求中的参数名必须保持一致,否则失效。 @RequestMapping("test2")@ResponseBodypublic DBHackResponse<UserInfoVo> test2(String id , String name){UserInfoVo userInfoVo = new UserInf

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

argodb自定义函数读取hdfs文件的注意点,避免FileSystem已关闭异常

一、问题描述 一位同学反馈,他写的argo存过中调用了一个自定义函数,函数会加载hdfs上的一个文件,但有些节点会报FileSystem closed异常,同时有时任务会成功,有时会失败。 二、问题分析 argodb的计算引擎是基于spark的定制化引擎,对于自定义函数的调用跟hive on spark的是一致的。udf要通过反射生成实例,然后迭代调用evaluate。通过代码分析,udf在

Vue2电商项目(二) Home模块的开发;(还需要补充js节流和防抖的回顾链接)

文章目录 一、Home模块拆分1. 三级联动组件TypeNav2. 其余组件 二、发送请求的准备工作1. axios的二次封装2. 统一管理接口API----跨域3. nprogress进度条 三、 vuex模块开发四、TypeNav三级联动组件开发1. 动态展示三级联动数据2. 三级联动 动态背景(1)、方式一:CSS样式(2)、方式二:JS 3. 控制二三级数据隐藏与显示--绑定styl

使用WebP解决网站加载速度问题,这些细节你需要了解

说到网页的图片格式,大家最常想到的可能是JPEG、PNG,毕竟这些老牌格式陪伴我们这么多年。然而,近几年,有一个格式悄悄崭露头角,那就是WebP。很多人可能听说过,但到底它好在哪?你的网站或者项目是不是也应该用WebP呢?别着急,今天咱们就来好好聊聊WebP这个图片格式的前世今生,以及它值不值得你花时间去用。 为什么会有WebP? 你有没有遇到过这样的情况?网页加载特别慢,尤其是那

插件maven-search:Maven导入依赖时,使用插件maven-search拷贝需要的依赖的GAV

然后粘贴: <dependency>    <groupId>mysql</groupId>    <artifactId>mysql-connector-java</artifactId>    <version>8.0.26</version> </dependency>