【ITK库学习】使用itk库进行图像滤波ImageFilter:几何变换:翻转、重采样(未完)

目录

  • 1、itkFlipImageFilter 图像翻转滤波器
  • 2、itkResampleImageFilter 重采样图像滤波器

1、itkFlipImageFilter 图像翻转滤波器

该类的主要功能是使输入数据在用户指定的轴上进行翻转。

翻转轴通过函数SetFlipAxes(array) 设置,其中输入是FixArray<bool,ImageDimension>。 图像在 array[i] 为 true 的轴上翻转。

就网格坐标而言,图像在输入图像的最大可能区域内翻转,因此,输出图像的 LargestPossibleRegion与输入图像相同。

就几何坐标而言,输出原点是图像相对于坐标轴翻转的。

常用的成员函数

  • Set/GetFlipAxes():设置/获取要翻转的轴, 图像沿着array[i]为true的轴翻转,默认为 false
  • Set/GetFlipAboutOrigin():设置/获取计算的输出原点,如果FlipAboutOrigin为“On”,则翻转将围绕轴的原点发生,如为“false”则翻转将围绕轴的中心发生,默认为“On”
  • FlipAboutOriginOn/Off():同上

示例代码

#include "itkImage.h"
#include "itkFlipImageFilter.h"typedef itk::Image<short, 3> ShortImageType;bool flipImageFilter(ShortImageType* image, ShortImageType* outImage)
{typename FlipFilterType::FlipAxesArrayType flipArray;flipArray[0] = true;      //沿x轴翻转flipArray[1] = false;flipArray[2] = false;typedef itk::FlipImageFilter<ShortImageType>  FlipFilterType;typename FlipFilterType::Pointer flipFilter = FlipFilterType::New();flipFilter->SetInput(image);flipFilter->SetFlipAxes(flipArray);flipFilter->SetFlipAboutOrigin(false);   //On:围绕圆点进行翻转,false:围绕轴中心进行翻转,默认为“On”//flipFilter->FlipAboutOriginOn();       //与SetFlipAboutOrigin功能一样//flipFilter->FlipAboutOriginOff();try{flipFilter->Update();}catch (itk::ExceptionObject& ex){//读取过程发生错误std::cerr << "Error: " << ex << std::endl;return false;}outImage = flipFilter->GetOutput();return true;
}

2、itkResampleImageFilter 重采样图像滤波器

该类通过坐标变换对图像进行重新采样,并通过插值函数对图像进行插值

该类是根据输入和输出图像的类型进行模板化的,

请注意,插值器函数的选择可能很重要,该函数通过**SetInterpolator()**进行设置。 默认为 LinearInterpolateImageFunction<InputImageType, TInterpolatorPrecisionType>,这对于普通医学图像来说是合理的。 然而,一些合成图像的像素是从有限的指定集合中提取的, 比如一个掩模,它指示将大脑分割成少量的组织类型,对于这样的图像,一般不在不同的像素值之间进行插值,NearestNeighborInterpolateImageFunction<InputImageType, TCoordRep> 会是更好的选择。

如果样本是从图像域外部获取的,则默认行为是使用默认像素值。 如果需要不同的行为,可以使用 SetExtrapolator() 设置外推器函数

应设置输出图像的输出信息(间距、大小和方向),该信息具有单位间距、零原点和同一方向的正常默认值,输出信息可以从参考图像获取;如果提供了参考图像并且UseReferenceImage 为“On”,则将使用参考图像的间距、原点和方向。重采样是在空间坐标中执行,而不是像素/网格坐标。

由于此过滤器生成的图像与其输入的大小不同,因此它需要重写ProcessObject中定义的多个方法,以便正确管理管道执行模型。 特别是,此过滤器重写 ProcessObject::GenerateInputRequestedRegion() 和 ProcessObject::GenerateOutputInformation()。

此过滤器亦可实现多线程过滤器,使用DynamicThreadedGenerateData() 方法来实现。

常用的成员函数

  • Set/GetInterpolator():设置/获取插值器函数,默认值为 LinearInterpolateImageFunction,其他选项:NearestNeighborInterpolateImageFunction(对于二进制蒙版和其他具有少量可能像素值的图像很有用)和 BSplineInterpolateImageFunction(提供更高阶的插值)
  • SetExtrapolator():设置/获取外推器函数,默认值为 DefaultPixelValue,其他选项:NearestNeighborExtrapolateImageFunction
  • SetDefaultPixelValue():当设置/获取变换后的像素位于图像外部的像素值,默认为 0
  • GetOutputStartIndex():获取输出最大可能区域的起始索引
  • Set/GetSize():设置/获取输出图像的大小
  • Set/GetOutputDirection():设置/获取输出方向余弦矩阵
  • Set/GetOutputOrigin():设置/获取输出图像的原点
  • Set/GetOutputSpacing():设置/获取输出图像的像素间距
  • SetOutputParametersFromImage():根据此图像设置输出参数的辅助方法
  • Set/GetTransformInput():设置/获取用于重采样的坐标变换,注意,这必须在物理坐标中,并且它是输出到输入的变换,默认情况下,过滤器使用身份转换,如果不想使用默认的Identity转换,则在尝试运行过滤器之前,必须在此处提供不同的转换
  • UseReferenceImageOn/Off():打开/关闭是否应使用指定的参考图像来定义输出信息
  • Set/GetUseReferenceImage():同上true:On,false:Off
  • Set/GetReferenceImage():设置用于定义输出信息的参考图像,默认情况下,输出信息通过 SetOutputSpacing、SetOutputOrigin 和 SetOutputDirection 或 SetOutputParametersFromImage 方法指定,此方法可用于指定要从中复制像素信息的图像,必须设置UseReferenceImageOn才能使用参考图像

坐标变换
恒等变换:输出图像点(x,y,x)的像素值 = 输入图像点(x,y,z)的像素值,点坐标均为同一个空间坐标。

非恒等:当输入输出图像的原点Orign和间距Space相同时,从输出空间到输入空间的点映射,(-30,-50,-10)的变换,指输出图像点(x,y,x)的像素值=输入图像点(x-30,y-50,z-10)的像素值。

恒等变换计算公式

输出图像参数:
原点 orignOut = {orignOut0,orignOut1,orignOut2}
间距 spaceOut = {spaceOut0,spaceOut1,spaceOut2}
尺寸大小 size= {sizeOut0,sizeOut1,sizeOut2}

输出图像参数:
原点 orignIn = {orignIn0,orignIn1,orignIn2}
间距 spaceIn={spaceIn0,space1In,spaceIn2}
尺寸大小sizeIn ={sizeIn0,sizeIn1,sizeIn2}

求像素值:
输出图像点I[3] = {X, Y, Z}的像素将于空间坐标点 P 相关联

P 的坐标值:P[3] = {X*spaceOut0+orignOut0, Y*spaceOut1+orignOut1, Z*spaceOut2+orignOut2}

P 点在输入图像对应的点 Q 坐标值为:Q[3] = {(P[0]-orignIn0)/spaceIn0, (P[1]-orignIn1)/spaceIn1, (P[1]-orignIn1)/spaceIn1}

如果Q不是整数坐标,那么输出图像点 I 的像素值 = 输入图像中围绕非整数标记 Q 插入值来计算的。

示例代码

#include "itkImage.h"
#include "itkAffineTransform.h"
#include "itkNearestNeighborInterpolateImageFunction.h"
#include "itkResampleImageFilter.h"typedef itk::Image<short, 3> ShortImageType;
typedef itk::Image<float, 3> FloatImageType;bool resampleImageFilter(ShortImageType* image, FloatImageType* outImage)
{double space[3] = { 1,1,1 };double orign[3] = { 0,0,0 };ShortImageType::SizeType size = { 300,300,300 };typedef itk::ResampleImageFilter<ShortImageType, FloatImageType>  ResampleFilterType;typename ResampleFilterType::Pointer resampleFilter = ResampleFilterType::New();resampleFilter->SetInput(image);//使用用来表示空间坐标类型和图像维度来定义变换类型,默认的设置变换参数来表示恒等变换typedef itk::AffineTransform<double, 3> TransformType;typename TransformType::Pointer transform = TransformType::New();//typename TransformType::OutputVectorType translation;//translation[0] = -30;//translation[1] = -50;//translation[2] = -10;//transform->Translate(translation);transform->SetIdentity();resampleFilter->SetTransform(transform);    //使用用来表示空间坐标类型和图像类型来定义校对机类型typedef itk::NearestNeighborInterpolateImageFunction<ShortImageType, double> NNInterpolateType;typename NNInterpolateType::Pointer interpolate = NNInterpolateType::New();resampleFilter->SetInterpolator(interpolate);//输出参数设置resampleFilter->SetDefaultPixelValue(0);resampleFilter->SetOutputSpacing(space);resampleFilter->SetOutputOrigin(orign);resampleFilter->SetSize(size);try{resampleFilter->Update();}catch (itk::ExceptionObject& ex){//读取过程发生错误std::cerr << "Error: " << ex << std::endl;return false;}outImage = resampleFilter->GetOutput();return true;
}

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

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

相关文章

UML图的各种类型以及软件设计师考试考察的方式

UML建模 前言 常见的UML的类型 UML 比前两题是更难的&#xff08;略高&#xff0c;但是学会就可以了。前两题是&#xff1a;数据流图&#xff0c;数据库的设计&#xff09;&#xff0c;因为UML图有很多类型&#xff1a;用例图&#xff0c;类图与对象图&#xff0c;顺序图&…

3_CSS层叠样式表基础

第3章-CSS层叠样式表基础 学习目标(Objective) 掌握标签选择器的使用掌握类选择器的使用了解id选择器和通配符选择器掌握font属性和color属性的应用 1.HTML的局限性 如果要改变下高度或者变一个颜色&#xff0c;就需要大量重复操作 总结&#xff1a; HTML满足不了设计者的需…

Emacs之dired模式重新绑定键值v(一百三十一)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

uniapp实战 —— 轮播图【数字下标】(含组件封装,点击图片放大全屏预览)

组件封装 src\components\SUI_Swiper2.vue <script setup lang"ts"> import { ref } from vue const props defineProps({config: Object, })const activeIndex ref(0) const change: UniHelper.SwiperOnChange (e) > {activeIndex.value e.detail.cur…

Python——数据容器

数据容器操作的异同点 项目列表list元组tuple字符串str集合set字典dict元素数量支持多个支持多个支持多个支持多个支持多个元素类型任意任意仅字符任意key&#xff1a;除字典外任意类型&#xff1b;value&#xff1a;任意类型下标索引支持支持支持不支持不支持重复元素支持支持…

yarn link使用(npm link)

使用场景 前端开发中&#xff0c;两个项目相互依赖时&#xff0c;使用yarn link(npm link)链接 例如&#xff1a;A项目依赖于本司自己的UI库B&#xff0c;当我们修改了UI库B中的某些代码时&#xff0c;需本地验证后再发布到私服&#xff0c;此时A项目与UI项目B通过yarn link连…

数据可视化:解锁企业经营的智慧之道

在现代企业管理中&#xff0c;数据可视化已经成为了一项重要的工具。它不仅仅是简单地展示数据&#xff0c;更是提供了深入理解数据、做出更明智决策的方法。作为一名可视化设计从业人员&#xff0c;我经手过一些企业自用的数据可视化项目&#xff0c;今天就来和大家聊聊数据可…

数字化升级,智慧医疗新时代——医院陪诊服务的技术创新

在信息技术飞速发展的今天&#xff0c;医疗服务正迎来数字化升级的新时代。本文将探讨如何通过先进技术的应用&#xff0c;为医院陪诊服务注入更多智慧元素&#xff0c;提升患者和家属的医疗体验。 1. 创新医疗预约系统 # Python代码演示医疗预约系统的简单实现 class Medic…

输入框的透明度影响placeholder的透明度怎么解决

有一个需求是需要写如上图所示的输入框。 首先想到的是调整输入的透明度 <div class"inputDiv"><img src"./images/search.png" /><input type"text" class"myInput" placeholder"请输入标题关键字"/> &…

飞天使-linux操作的一些技巧与知识点

命令行光标移动到行首行尾 ctrl a 跳到首 ctrl e 跳到尾/etc/passwd rpm 包格式 RPM&#xff08;Red Hat Package Manager&#xff09;是一种常用的Linux软件包管理系统&#xff0c;它使用特定的命名规则来标识和命名软件包。RPM包的名称格式通常遵循以下规则&#xff1a;…

Qt基础-修改Qt Creator界面字体

Qt Creator设计时字体太小,有时需要自定义一下,本文讲解如何修改Qt Creator界面字体。 一、创建样式文件 创建CSS文件,定义名称为custom-style.css 编写内容: QWidget { font: 12pt "Microsoft YaHei"; }QPlainTextEdit { font: 12pt "Microsoft YaHei&…

FPGA时序分析与约束(0)——目录与传送门

一、简介 关于时序分析和约束的学习似乎是学习FPGA的一道分水岭&#xff0c;似乎只有理解了时序约束才能算是真正入门了FPGA&#xff0c;对于FPGA从业者或者未来想要从事FPGA开发的工程师来说&#xff0c;时序约束可以说是一道躲不过去的坎&#xff0c;所以这个系列我们会详细介…

Python的sort()与sorted()排序函数的区别

文章目录 一、工具二、需求三、简单的使用例子四、原理分析Timsort算法主要特点&#xff1a;Timsort算法的工作原理&#xff1a;sort() 方法和 sorted() 函数的差异&#xff1a; 五、Python中的单例实现简单示例 一、工具 Python 3.10.0 pycharm 2022 二、需求 最近做项目的…

微服务学习:RestTemplateWebClient发起的http请求实现远程调用

http请求做远程调用是与语言无关的调用&#xff0c;只要知道对方的ip,端口&#xff0c;接口路径&#xff0c;请求参数即可 启动类中配置&#xff1a; Beanpublic RestTemplate restTemplate(){return new RestTemplate();} Sevice中书写方法 get Autowiredprivate RestTemp…

2023-2024 年重庆市职业院校技能大赛 高职组“软件测试”赛项样题

2023-2024 年重庆市职业院校技能大赛 高职组“软件测试”赛项样题 单元测试要求分析、代码设计、设计测试数据、编写测试脚本和 测试执行等&#xff1b;测试计划、测试报告文档设计与编写&#xff1b;Web 端测试用例 设计、测试执行和 Bug 记录&#xff1b; 自动化测试要求分析…

点击按住说话按钮事件有延迟

问题原因&#xff1a; 该问题原因是由于系统的某些手势 delaysTouchesBegan 属性为 YES&#xff0c;当按钮处在某些特定位置时触摸事件会先被这些系统的手势拦截&#xff0c;系统不响应才会继续分发&#xff0c;而按钮的 UIControlEventTouchDown 事件是需要立即响应的&#xf…

Python数据处理的六种方式总结,Python零基础学习

文章目录 前言1、dedup()去重并排序2、traverse()拆分嵌套数组3、filter()数据筛选4、groupby()分组运算5、select()遍历结果集6、sort()数据排序 总结 前言 在 Python 的数据处理方面经常会用到一些比较常用的数据处理方式&#xff0c;比如pandas、numpy等等。 今天介绍的这…

vue图片预览 90度旋转

要在 Vue 3 中实现点击按钮让图片旋转 90 度&#xff0c;你可以使用 CSS 转换和 Vue 的事件处理来完成。这里是一个基本的示例&#xff1a; 首先&#xff0c;在你的组件的模板中&#xff0c;添加一个按钮和一个应用转换的图像&#xff1a; <template> <div> <…

使用粗糙贴图制作粗纹皮革手提包3D模型

在线工具推荐&#xff1a; 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 当谈到游戏角色的3D模型风格时&#xff0c;有几种不同的风格&#xf…

UniGui使用CSS优化PageControl

如题直接上代码 .x-tab-bar-default-top{background-image:none!important;background-color:#FFF !important;border-color:#f0f0f0 !important;border-left:none!important;border-right:none!important}.x-tab-bar-strip-default{border-color:#f0f0f0 !important;backgrou…