一、介绍

  获取DRR图像是医疗图像配准里面的一个重要的前置步骤:它的主要目的是,通过CT三维图像,获取模拟X射线影像,这个过程也被称为数字影响重建。

  在2D/3D的配准流程里面,需要首先通过CT三维图像,能够获取任意位置的DRR图像,然后去与已经获取的X光平面图像配准。

  配准过程如下(下面的描述是不准确的,我只是描述了一种情况,即基于灰度的图像配准算法的过程,并且可能会有纰漏):

  1- 定义一个评价函数:即相似性测度函数,通过这个函数评价当前是否已经达到了配准的要求。

  2- 不断通过调整输入参数得到不同角度下的DRR图像。

  3-通过1里面的评价函数判断是否停止搜索

  实际上这是一个循环,终止条件就是是否满足相似性测度函数。

  具体流程可以参考下面的流程图:

  

二、DRR例子运行

  在ITK5.0里面有一个相关的例子,我也是跑了好久才把程序跑通的,跑通以后就觉得做了许多的无用功......

  说到底还是菜,跑一个程序就要两周,醉了(好吧,吐槽完毕^-^)

  1-找到例子,构建工程

  按照之前第一个博客的过程安装ITK之后,我们找到这个例子所在的位置:

  ITK-5.0/Examples/Filtering/DigitallyReconstructedRadiograph1.cxx

       例子的代码也可以在这里找到:

  https://itk.org/Doxygen/html/Examples_2Filtering_2DigitallyReconstructedRadiograph1_8cxx-example.html

  把这个代码复制出来单独的构建一个工程(也是按照第一个博客里面的方法),但是这个时候的工程是无法运行的。

  2- 代码第一个问题

  当我们运行程序的时候,程序无法运行, 提示说是因为没有定义一个IOFactory

  那么现在问题来了,IOFactory是和要写入的图像类型绑定的,

  我们要把这个当做什么类型的文件写入呢?

  这个时候的writer是三维图像,所以我们是不能够写成 bmp, jpg, 等等图像的,我就是在这里尝试很很多遍。

  后来我们经过观察发现,在程序里面有一个写入到文件的一个代码。

  1. #ifdef WRITE_CUBE_IMAGE_TO_FILE
  2. const char *filename = "body.gipl";
  3. using WriterType = itk::ImageFileWriter< InputImageType >;
  4. WriterType::Pointer writer = WriterType::New();
  5. itk::GiplImageIOFactory::RegisterOneFactory();
  6. writer->SetFileName( filename );
  7. writer->SetInput( image );
  8.  
  9. try
  10. {
  11. std::cout << "Writing image: " << filename << std::endl;
  12. writer->Update();
  13. }
  14. catch( itk::ExceptionObject & err )
  15. {
  16.  
  17. std::cerr << "ERROR: ExceptionObject caught !" << std::endl;
  18. std::cerr << err << std::endl;
  19. return EXIT_FAILURE;
  20. }
  21. #endif

  最开始我根本没有观察过这个,但是后来发现是存在GiplIOFactory的,于是尝试了一下,发现就可以了。

  2.1 解决方法:

  也就是说,我们需要做两件事情:

  <1>声明一个GiplIOFactory

  1. #include "itkGiplImageIOFactory.h"
    itk::GiplImageIOFactory::RegisterOneFactory();

  <2>传入文件的写入参数,比如我传入的是 "1.gipl"  (注意这里的后缀需要时 .gipl, 需要注意如何在VS里面如何传入参数。)

  这个时候程序已经可以成功运行了,并且DRR图像被写入到了工程所在的文件夹。

2.2-图像观察

  这个时候我们已经可以观察一下这个文件到底生成了一个什么东西:

  我们通过3D  slicer打开这个gipl文件,可以观察到这个三维图像和生成的DRR图像:

  <1> 三维图像

  

  <2>DRR图像

  

  可以看到,例子自己建立的图像其实是一个中空的正方体。

  3-第二个问题

   但是我希望实现的是读取的DRR图像,所以需要读取自己的CT图像。

  目前我拥有的是一系列的CT图像,他们只是2D图像,而历程里面的reader则是读取的三维图像。

  所以需要添加代码,读取自己的CT图像,然后转换为3D图像。

  添加代码如下:

  1. //定义像素类型,图像类型,三维有符号数,定义指针
  2. typedef signed short PixelType;
  3. const unsigned int Dimension = ;
  4. typedef itk::Image< PixelType, Dimension > ImageType;
  5. typedef itk::ImageSeriesReader< ImageType > ReaderType;
  6.  
  7. //声明读、写 DICOM 图 像 的 itk::GDCMImageIO对象
  8. //itk::GDCMSeriesFileNames对象将生成并将构成所有体数据的切片的文件名进行排序
  9. typedef itk::GDCMImageIO ImageIOType;
  10. typedef itk::GDCMSeriesFileNames NamesGeneratorType;
  11. ImageIOType::Pointer gdcmIO = ImageIOType::New();
  12. NamesGeneratorType::Pointer namesGenerator = NamesGeneratorType::New();
  13.  
  14. //设置读取路径
  15. //用文件名发生器生成被读的文件名和被写的文件名
  16. namesGenerator->SetInputDirectory("D:\\Files\\Data\\3219032438350584179-8\\DICOM\\S258070\\S20");
  17. const ReaderType::FileNamesContainer& filenames = namesGenerator->GetInputFileNames();
  18.  
  19. //设置DICOM图像IO对象和被读的文件名的列表
  20. ReaderType::Pointer reader = ReaderType::New();
  21. reader->SetImageIO(gdcmIO);
  22. reader->SetFileNames(filenames);

  这个就是第三个博客里面的读取程序,唉,伤心,浪费这么久。

  具体对于这个程序的参数讲解参加下一个博客六

三、参考链接

  1-博客:https://blog.csdn.net/inter_peng/article/details/52155073

  2-第一个图来源:基于灰度的二维三维图像配准方法及其在骨科导航手术中的应用

  

五、如何通过CT三维图像得到DRR图像的更多相关文章

  1. [HeadFrist-HTMLCSS学习笔记]第五章认识媒体:给网页添加图像

    [HeadFrist-HTMLCSS学习笔记]第五章认识媒体:给网页添加图像 干货 JPEG.PNG.GIF有何不同 JPEG适合连续色调图像,如照片:不支持透明度:不支持动画:有损格式 PNG适合单 ...

  2. 学习 opencv---(3) ROI 区域图像叠加&初级图像混合

    在这篇文章里,我们一起学习了在OpenCV中如何定义感兴趣区域ROI,如何使用addWeighted函数进行图像混合操作,以及将ROI和addWeighted函数结合起来使用,对指定区域进行图像混合操 ...

  3. Opencv-Python:图像尺寸、图像的读取、显示、保存与复制

    Opencv-Python:图像尺寸.图像的读取.显示.保存与复制 原创 2017年11月23日 21:30:49 4440 在使用opencv的方法时,首先必须导入opencv包.新的opencv导 ...

  4. 14、OpenCV实现图像的空间滤波——图像锐化及边缘检测

    1.图像锐化理论基础 1.锐化的概念 图像锐化的目的是使模糊的图像变得清晰起来,主要用于增强图像的灰度跳变部分,这一点与图像平滑对灰度跳变的抑制正好相反.而且从算子可以看出来,平滑是基于对图像领域的加 ...

  5. 本图片处理类功能非常之强大可以实现几乎所有WEB开发中对图像的处理功能都集成了,包括有缩放图像、切割图像、图像类型转换、彩色转黑白、文字水印、图片水印等功能

    import java.awt.AlphaComposite; import java.awt.Color; import java.awt.Font; import java.awt.Graphic ...

  6. Ubuntu使用dense_flow提取视频图像的光流图像

    使用dense_flow求取图像的光流图像,原项目地址: https://github.com/wanglimin/dense_flow 该方法使用的是opecnv最基本的光流图像计算方法,输出为 f ...

  7. OpenCV --- 修改图像的对比度、亮度 、RGB转Gray图像、修改图像的尺寸

    #include <opencv2/core.hpp> #include <opencv2/imgcodecs.hpp> #include <opencv2/highgu ...

  8. Windows 10 取消桌面右键“图像属性”、“图像选项”

    Windows 10 取消桌面右键"图像属性"."图像选项" 桌面右键 说明:在windows 10中,桌面右键出现"图像属性"." ...

  9. [实例]ROS使用OpenCV读取图像并发布图像消息在rviz中显示

    思路: (1)使用opencv读取本地图像 (2)调用cv_bridge::CvImage().toImageMsg()将本地图像发送给rviz显示 一.使用opencv读取本地图像并发布图像消息 ( ...

随机推荐

  1. MDS 多活配置

    CephFS 介绍及使用经验分享 阅读 1179 收藏 2 2019-01-14 原文链接:www.jianshu.com WebRTC SFU中发送数据包的丢失反馈juejin.im 目录 Ceph ...

  2. Spring整合Shiro 权限 角色 用户关系分析

    Spring整合Shiro 权限 角色 用户关系分析 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 前置内容 之前我们学习了,使用注解的方式去完成权限的控制,当然,也是静态的,也就 ...

  3. 用FPGA设计LCD 转 VGA

    这个东西其实是在上一个冬天就做完了,而且似乎已经产业化了,当时是为一位朋友做的,这个朋友再卖给产业化的人,就像流于俗套的故事一样,这个朋友拿到了钱,不过不像项目开始时说的那样与我有关.想想多年前一起吃 ...

  4. Python流程控制之分支结构

    目录 if/else结构 多重if结构 嵌套if结构 练习 if/else结构 if如果,else否则 # java if(){ }else{ } # python if 条件: 语句 else: 语 ...

  5. js中promise解决callback回调地狱以及使用async+await异步处理的方法

    1.callback回调地狱 function ajax(fn) { setTimeout(()=> { console.log('你好') fn() }, 1000) } ajax(() =& ...

  6. hikari连接池属性详解

    hikari连接池属性详解 一.主要配置 1.dataSourceClassName 这是DataSourceJDBC驱动程序提供的类的名称.请查阅您的特定JDBC驱动程序的文档以获取此类名称,或参阅 ...

  7. 《Java基础知识》Java IO流详解

    Java IO概念 1. 用于设备之间的数据传输. 2. Java 将操作数据流的功能封装到了IO包中. 3. 数据流流向分:输入流和输出流,操作对象为文件. 4. 流按照操作数据分:字节流(通用)和 ...

  8. 从头实现一个WPF条形图

    时间如流水,只能流去不流回! 点赞再看,养成习惯,这是您给我创作的动力! 本文 Dotnet9 https://dotnet9.com 已收录,站长乐于分享dotnet相关技术,比如Winform.W ...

  9. SAP Business One对象清单

    中文描述 对象号 表名 主键 英文描述 总账科目 1 OACT AcctCode G/L Accounts 业务伙伴 2 OCRD CardCode Business Partner 银行代码 3 O ...

  10. 数据安全管理:RSA加密算法,签名验签流程详解

    本文源码:GitHub·点这里 || GitEE·点这里 一.RSA算法简介 1.加密解密 RSA加密是一种非对称加密,在公开密钥加密和电子商业中RSA被广泛使用.可以在不直接传递密钥的情况下,完成加 ...