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

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

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

相关文章

  • C# 通过同步和异步实现优化做早餐的时间

    C# 通过同步和异步实现优化做早餐的时间攻略 在进行优化做早餐时间的过程中,可以使用同步和异步的方式来实现,从而提高效率。下面是其中两种实现方式: 同步实现 同步实现是顺序执行代码,并且在上一个任务执行完毕后才能开始执行下一个任务的方式。对于做早餐的过程来说,就是必须一个一个步骤地完成才能继续下一步。 public void MakeBreakfastSyn…

    C# 2023年5月15日
    00
  • 在.NET中扫描局域网服务的实现方法

    下面是关于“在.NET中扫描局域网服务的实现方法”的完整攻略,包含两个示例。 1. 局域网服务扫描简介 在局域网中,我们可能需要扫描网络中的服务,以便找到可用的服务。在.NET中,我们可以使用Socket类和UDP协议来实现局域网服务扫描。以下是.NET中局域网服务扫描的详细介绍。 2. 局域网服务扫描全攻略 以下是使用.NET中Socket类和UDP协议实…

    C# 2023年5月15日
    00
  • ASP.NET Core 过滤器中使用依赖注入知识点总结

    ASP.NET Core 过滤器中使用依赖注入知识点总结 ASP.NET Core是一个跨平台的Web应用程序框架,它可以帮助我们构建高性能的Web应用程序。过滤器是ASP.NET Core中的一个重要概念,它可以帮助我们在请求管道中添加逻辑。本攻略将详细介绍如何在ASP.NET Core过滤器中使用依赖注入。 环境要求 在进行ASP.NET Core过滤器…

    C# 2023年5月17日
    00
  • C#中DataTable和List互转的示例代码

    下面我将详细讲解“C#中DataTable和List互转的示例代码”的完整攻略。 目录 DataTable转List 1.1 使用ToList扩展方法 1.2 使用反射自动映射 List转DataTable 2.1 使用数据表生成方式 2.2 使用反射自动映射 1. DataTable转List 1.1 使用ToList扩展方法 public static …

    C# 2023年5月31日
    00
  • c#窗体传值用法实例详解

    下面我就详细讲解一下”C#窗体传值用法实例详解”。 一、什么是窗体传值? 在C#中,我们经常需要在不同的窗体之间传递数据。比如,在一个窗体中填写了某些信息,需要在另一个窗体中使用这些信息。这个过程就叫做窗体传值。通俗地来说,就是将数据从一个窗体传递到另一个窗体。 二、窗体传值的方法 C#中实现窗体传值的方法有很多种,常用的有以下三种: 1. 构造函数传值 通…

    C# 2023年5月31日
    00
  • C#从数据库读取图片并保存的两种方法

    首先我们需要了解以下两种从数据库读取图片并保存的方法: 将图片转换为二进制保存到数据库中,读取时再将二进制转换为图片; 在服务器本地保存图片,将本地图片路径保存到数据库中,读取时根据路径从本地读取图片。 下面我们逐一介绍这两种方法。 方法一:将图片转换为二进制保存到数据库中 1.1 保存图片到数据库 首先,我们需要将读取到的图片转换成二进制,然后将二进制数据…

    C# 2023年6月2日
    00
  • windows mysql 自动备份的几种方法汇总

    Windows MySQL 自动备份的几种方法汇总 为什么需要自动备份 在使用 MySQL 数据库时,为了保护数据的安全性,我们需要进行备份操作。但是,手动备份数据是非常繁琐的,而且容易出现遗漏的情况。因此,使用自动备份工具可以提高备份的效率,也可以保证备份的全面性。 几种自动备份方法 1. 使用 mysqldump 命令进行备份 使用 mysqldump …

    C# 2023年5月31日
    00
  • unity scrollRect实现按页码翻页效果

    下面是Unity中ScrollRect实现按页码翻页效果的攻略: 1. 需求分析 首先,我们需要明确我们的需求:利用ScrollRect制作一个翻页效果,实现按页码进行翻页操作。这意味着我们需要按照固定的大小拆分显示内容,每个页面的大小应该相同,并且在翻页时应该有一个平滑的过渡动画。 2. 设置ScrollRect参数 首先,我们需要在Unity中创建一个S…

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