C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

在拍摄脊柱或胸片时,经常会遇到因设备高度不够需要分段拍摄的情况,

对于影像科诊断查阅影像时希望将分段影像合并成一张影像,有助于更直观的观察病灶,

以下图为例的两个分段影像:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像     C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

我们使用OpenCVSharp中的Stitcher类的Stitch方法,导入两张图像并拼接:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 但结果却失败了,返回错误结果:ERR_NEED_MORE_IMGS,是由于医学影像的特征点匹配不够,导致无法确定对接点。

一幅图中总存在着一些独特的像素点,这些点我们可以认为就是这幅图的特征,即为特征点

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

获取一幅图中存在的一些独特的像素点,需要解决两个问题:

  • 解决尺度不变性问题,不同大小的图片获取到的特征是一样的
  • 提取到的特征点要稳定,能被精确定位 

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像 C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

可参考本系列文章:C#处理医学影像(三):基于漫水边界自动选取病灶范围的实现思路

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 

根据算法原理得到如下结果:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 

Sobel算子:

根据算法原理得到如下结果:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 

其中直观区别是canny算子计算的结果清晰,但不连续,容易受噪点影响,而sobel算子线条相对柔和,连续性强。

 

⑤背景降噪

进行一次手动背景降噪,使得展现的无用边缘更少,结果更清晰:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 

经过上述的一系列处理步骤后我们再次合并拼接:

            Mat srcImg1 = imgList1[0];
                    Mat srcImg2 = imgList1[1];
                  

                    Mat[] images = new Mat[] { srcImg1, srcImg2};

                    Stitcher stitcher = Stitcher.Create(Stitcher.Mode.Panorama);
                    Mat pano = new Mat();
                    var status = stitcher.Stitch(images, pano);
                    if (status != Stitcher.Status.OK)
                    {
                        ShowMsg.Box("拼接异常(" + status.ToString() + "),请重试。", BoxType.Msg, 120, this);
                        return;
                    }

得到了正确的结果:

C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像

 

 

原文链接:https://www.cnblogs.com/Uncle-Joker/archive/2023/05/05/17373754.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C#处理医学影像(四):基于Stitcher算法拼接人体全景脊柱骨骼影像 - Python技术站

(0)
上一篇 2023年5月5日
下一篇 2023年5月5日

相关文章

  • C# 常用协议实现模版及FixedSizeReceiveFilter示例(SuperSocket入门)

    C# 常用协议实现模版及FixedSizeReceiveFilter示例(SuperSocket入门) 简介 SuperSocket是一款开源的基于.NET平台的高性能Socket服务器框架,支持多种协议(如TCP、UDP、WebSocket等),并提供了基于协议的使用模板,便于快速开发网络应用程序。 本文将介绍使用SuperSocket实现通信协议的方法,…

    C# 2023年6月1日
    00
  • C#四舍五入用法实例

    C#四舍五入用法实例攻略 本文将详细讲解C#中四舍五入的使用方法及应用场景。 四舍五入的用途 在实际开发中,我们需要处理浮点数,但是由于计算机的机器精度限制,运算中可能会产生精度误差。因此需要对浮点数进行四舍五入运算,以保证结果的精度。 Math.Round的用法 在C#中,我们可以使用Math.Round方法进行四舍五入运算。其语法如下: public s…

    C# 2023年6月7日
    00
  • C#读写Config配置文件案例

    下面我会详细讲解“C#读写Config配置文件案例”的完整攻略。 什么是Config配置文件 Config配置文件是一种XML格式的配置文件,用于在应用程序中保存一些常见的配置数据。在C#中读写Config文件是一种常见的应用场景。 一个Config配置文件通常包含以下三种节点: configuration:root节点,表示当前文件是一个配置文件; con…

    C# 2023年6月1日
    00
  • C#十六进制字符串转十进制int的方法

    我们来讲解“C#十六进制字符串转十进制int的方法”的攻略。 文字说明 要将一个十六进制字符串转换成十进制int数值,在C#中可以使用Convert.ToInt32方法。该方法有两个参数:第一个参数是十六进制字符串,第二个参数是用于指定转换进制的整数值,常用进制参数是16。 下面我们来看一下具体的代码实现: string hexStr = "1AC…

    C# 2023年6月8日
    00
  • 结合Visual C#开发环境讲解C#中事件的订阅和取消订阅

    本攻略将为你详细介绍如何在Visual C#开发环境中讲解C#中事件的订阅和取消订阅。 理解事件 在开始介绍事件的订阅和取消订阅之前,我们需要先理解事件的概念。在C#中,事件是用来描述当某种情况发生时应该采取的操作。事件由事件源和事件处理程序组成。 事件源是指导致事件发生的对象,其类型必须继承自System.Delegate类,可以将事件源看作一个发布者。事…

    C# 2023年6月1日
    00
  • C# WPF数据绑定方法以及重写数据模板后数据绑定

    写在前面 本文将会介绍WPF如何实现前后端数据绑定和在进行数据绑定时常用的方法和类以及对于DataGrid、ListView这样的控件重写数据模板后控件如何进行数据绑定。 本文主要针对于数据绑定的基础实现进行介绍,通过此博文你将会有能力编写一个MVVM设计模式的C#、WPF项目。如果您是C#及WPF的资深开发人员本文可能对您没有太大的帮助,但如果你是一个正在…

    C# 2023年4月22日
    00
  • C#将Sql数据保存到Excel文件中的方法

    关于“C#将Sql数据保存到Excel文件中的方法”,我可以提供以下攻略: 1.使用Microsoft.Office.Interop.Excel库保存 步骤1:安装Microsoft.Office.Interop.Excel库 在Visual Studio中安装Microsoft.Office.Interop.Excel库。 步骤2:引用命名空间 在文件头部…

    C# 2023年5月31日
    00
  • 一个进程间通讯同步的C#框架引荐

    一个进程间通讯同步的C#框架是为了解决进程间通讯的问题而产生的。在多线程编程中,线程之间是可以共享数据的,但是如果要实现不同进程之间的数据共享,就需要进程间通讯(IPC)技术了。同时,为了保证数据的正确性和同步性,需要使用同步机制。 C# 提供了多种进程间通信的方式,包括共享内存、管道、消息队列、socket等,但是要实现同步机制需要花费较多的时间和精力。在…

    C# 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部