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

yizhihongxing

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

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

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

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/p/17373754.html

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

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

相关文章

  • C#中的递归APS和CPS模式详解

    C#中的递归APS和CPS模式详解 什么是递归APS模式 递归APS(Also Known As All-Pairs Shortest Path)模式是一种计算图中所有顶点之间最短路径的算法。我们可以使用递归APS模式在C#中找到图中所有顶点的最短路径。 在C#中,我们可以使用递归调用来实现递归APS。 递归APS模式的基本思想 递归APS模式可以被看做是动…

    C# 2023年6月7日
    00
  • C# 基础编程题集锦

    简单字符串加密 编写一个应用程序用来输入的字符串进行加密,对于字母字符串加密规则如下:’a→d’ ‘b’→’e’ ‘w’→z’ …… x’→’a’ ‘y’→b’ ‘z→c’ ‘A’→’D’ ‘B’→’E’ ‘W’→’Z’ ‘X’→’A’ ‘Y’→’B’ ‘Z’→’C’ ?对于其他字符,不进行加密。 static void Main(string[] …

    C# 2023年5月1日
    00
  • .NET Core 基于Websocket的在线聊天室实现

    .NET Core 基于 Websocket 的在线聊天室实现攻略 在 .NET Core 中,我们可以使用 Websocket 技术来实现在线聊天室。本攻略将介绍如何使用 .NET Core 实现基于 Websocket 的在线聊天室。 步骤 以下是实现基于 Websocket 的在线聊天室的步骤: 创建项目。 使用 Visual Studio 或者 .N…

    C# 2023年5月17日
    00
  • c#转换全角半角方法示例

    当我们需要对用户输入的字符或文本进行处理时,经常需要将全角字符转换为半角字符或者将半角字符转换为全角字符。c#中提供了相应的方法来实现这些功能。下面是一个完整的示例说明“c#转换全角半角方法”的攻略。 1. 转换全角到半角 使用 System.Text.RegularExpressions.Regex 类的 Replace 方法可以实现将全角字符转换为半角字…

    C# 2023年6月8日
    00
  • C#调用接口的四种方式介绍

    下面我将详细讲解“C#调用接口的四种方式介绍”。 1. 接口介绍 接口是一种特殊的类,它只包含成员函数的声明而没有实现,也不包含数据成员。通过接口可以定义一种协议,并按照这个协议来编写类。接口可以被多个类同时实现,并且可以通过接口的引用来调用这些实现。 2. 接口的定义 C# 中定义接口的语法格式如下: interface 接口名称 { 返回值类型 函数名(…

    C# 2023年5月31日
    00
  • ASP.NET 文件压缩解压类(C#)

    ASP.NET文件压缩解压类(C#)是一个可以对文件进行压缩和解压的类,可以让我们在ASP.NET项目中更方便地操作文件。下面是该类的详细攻略。 引用命名空间和类 首先,在您的ASP.NET项目中引用以下命名空间: using System.IO.Compression; 这个命名空间包含了ZipArchive类,它是我们进行文件压缩和解压的核心类。 压缩文…

    C# 2023年5月14日
    00
  • C#中static的详细用法实例

    下面是关于C#中static的详细用法实例的攻略。 一、static的概念 在C#中,static是一个关键字,用在定义类或方法时,表示这个类或方法是静态的。静态成员或方法可以被类的所有实例或对象共享,不会被实例化的对象占用内存空间。 二、static的实例 1. static成员 class MyClass { public static int Coun…

    C# 2023年5月31日
    00
  • C#并发实战记录之Parallel.ForEach使用

    C#并发实战记录之Parallel.ForEach使用 什么是 Parallel.ForEach? Parallel.ForEach 是一个并行迭代器,它允许并行执行循环。简单的说,就是可以将一个大型的循环任务拆分成多个子任务,使得多个任务可以并行执行,提高执行效率。 如何使用 Parallel.ForEach? Parallel.ForEach 的用法非常…

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