ITK学习笔记——dicom读取写入

2024-05-14 00:08

本文主要是介绍ITK学习笔记——dicom读取写入,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ITK毕竟是医学图像处理专用,主要还是处理dicom医学格式的图像。dicom数据类型为signed short型。

#include "itkImageFileReader.h"
#include "itkImageFileWriter.h"
#include "itkGDCMImageIO.h"#include <list>
#include <fstream>int main(int argc, char* argv[])
{typedef signed short InputPixelType;const unsigned int   InputDimension = 2;typedef itk::Image< InputPixelType, InputDimension > InputImageType;typedef itk::ImageFileReader< InputImageType > ReaderType;ReaderType::Pointer reader = ReaderType::New();reader->SetFileName("C:/input/lung.dcm");typedef itk::GDCMImageIO           ImageIOType;ImageIOType::Pointer gdcmImageIO = ImageIOType::New();reader->SetImageIO(gdcmImageIO);try{reader->Update();}catch (itk::ExceptionObject & e){std::cerr << "exception in file reader " << std::endl;std::cerr << e << std::endl;return EXIT_FAILURE;}typedef itk::ImageFileWriter< InputImageType >  Writer1Type;Writer1Type::Pointer writer = Writer1Type::New();writer->SetFileName("C:/output/lung.dcm");writer->SetInput(reader->GetOutput());try{writer->Update();}catch (itk::ExceptionObject & e){std::cerr << "exception in file writer " << std::endl;std::cerr << e << std::endl;return EXIT_FAILURE;}return EXIT_SUCCESS;
}

一般对dicom进行处理都要将其转换为0~255单通道灰度图,这时我们需要添加#include "itkRescaleIntensityImageFilter.h"文件。

#include "itkImageFileReader.h"
#include "itkImageFileWriter.h"
#include "itkGDCMImageIO.h"
#include "itkRescaleIntensityImageFilter.h"#include <list>
#include <fstream>int main(int argc, char* argv[])
{typedef signed short InputPixelType;const unsigned int   InputDimension = 2;typedef itk::Image< InputPixelType, InputDimension > InputImageType;typedef itk::ImageFileReader< InputImageType > ReaderType;ReaderType::Pointer reader = ReaderType::New();reader->SetFileName("C:/input/lung.dcm");typedef itk::GDCMImageIO           ImageIOType;ImageIOType::Pointer gdcmImageIO = ImageIOType::New();reader->SetImageIO(gdcmImageIO);try{reader->Update();}catch (itk::ExceptionObject & e){std::cerr << "exception in file reader " << std::endl;std::cerr << e << std::endl;return EXIT_FAILURE;}typedef unsigned char WritePixelType;typedef itk::Image< WritePixelType, 2 > WriteImageType;typedef itk::RescaleIntensityImageFilter<InputImageType, WriteImageType > RescaleFilterType;RescaleFilterType::Pointer rescaler = RescaleFilterType::New();rescaler->SetOutputMinimum(0);rescaler->SetOutputMaximum(255);typedef itk::ImageFileWriter< WriteImageType >  Writer2Type;Writer2Type::Pointer writer = Writer2Type::New();writer->SetFileName("C:/output/lung.dcm");rescaler->SetInput(reader->GetOutput());writer->SetInput(rescaler->GetOutput());try{writer->Update();}catch (itk::ExceptionObject & e){std::cerr << "exception in file writer " << std::endl;std::cerr << e << std::endl;return EXIT_FAILURE;}return EXIT_SUCCESS;
}

这时候,写入的文件就变成了灰度图。

这篇关于ITK学习笔记——dicom读取写入的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati