血管分割算法总结

之前有5篇涉及眼底血管分割的博文,包括基于Hessian矩阵的Frangi算法基于PCA的算法匹配滤波算法自适应对比度增强算法,当然还有其他的方法,目前来看,并没有一种完美的算法,即适应于所有不同成像方式,不同部位血管的分割方法,本篇结合一篇博士论文:<<冠状动脉造影图像的分割方法研究>>进行总结。

血管分割技术分类 :



阈值分割

阈值分割是最常见的并行的直接检测区域的分割方法,同时也是最简单的分割方法。这种方法一般都对图像有一定的假设,假设图像的目标和背景占据不同的灰度级范围,在目标和背景内部的相邻像素间的灰度值差异较小,但在目标和背景交界处两边的像素在灰度值上有较大的差别。如果选取一个适当的灰度阈值T ,然后将图像中每个像素的灰度值与该阈值T 相比较,根据比较结果可以将像素分为两类:像素的灰度值大于阈值的为一类,它们被赋值 1;像素的灰度值小于阈值的为另一类,它们被赋值 0,这样就得到了一幅二值图像,并把目标从背景中提取出来.通常根据先验知识确定分割门限,也可以利用灰度直方图特征和统计判决方法确定。
图像的灰度直方图会呈现双峰一谷状。两个峰值分别对应于目标的中心灰度和背景的中心灰度,边界点位于目标周围,其灰度介于目标灰度和背景灰度之间,因此边界的灰度对应着双峰之间的谷点。为了使像素错分的概率达到最小,将谷点的灰度作为分割门限。由于直方图的参差性,直方图的谷值很难确定,需要设计特定的方法进行搜索。目前,有很多的方法可以确定最优阈值(谷底),如求取高斯模型参数的方法、对直方图曲线拟合求极值的方法等。
如果分割阈值仅依据像素的灰度级确定,则得到的阈值是基于点相关的;如果分割阈值是由每个像素的局部邻域特性所决定,则得到的门限是基于区域相关的。基于点相关的常用阈值分割方法有最大类间方差法、直方图凹形分析法、矩不变门限法及最大熵法等.基于区域相关的阈值分割方法有松弛法、基于二阶灰度统计的方法、直方图转换法及基于过渡区提取的方法等。
基于阈值的分割方法具有计算简单、运算效率高的优点。但是这类方法没有考虑空间特性,对噪声和灰度多样性敏感,对目标和背景灰度差异不明显的图像很难得到准确的分割阈值。在实际应用中,通常与其他图像分割方法配合使用,才能取得满意的效果。文献[55]由时飞磁共振血管造影图像中提取血管时,提出一个基于血流物理模型的统计模型。为了提高血管的分割能力,将 PCA 的速度和相位信息进行融合,分别采用自适应局部阈值方法和单一全局阈值方法分割两种不同的统计模型,使其附近信号非常低的动脉瘤取得较好的分割效果。文献[56]将局部阈值和全局阈值结合起来,对脑血管图像进行三维重建,使用局部阈值可以增强小血管的对比度,使用全局阈值可以将目标血管从背景中提取出来。

边缘检测

边缘检测是一种基于灰度不连续性的并行边界分割技术,是所有基于边界分割方法的第一步。因为边缘是目标和背景的分界线,提取出边缘才能将目标和背景区分开来。边缘检测一般利用目标和背景在某种特性上存在差异来实现,如灰度、颜色、纹理等特征。检测边缘一般常用一阶或二阶导数来完成,但在实际的数字图像中求导是利用差分运算近似代替微分运算.图像中处于边缘两侧的点,其灰度值发生突变,所以这些点将具有较大的微分值,当微分的方向和边界垂直时,微分值最大。可见,微分是有方向性的运算,用于测量微分方向上灰度级的变化。

梯度算子

梯度对应一阶导数,在边缘灰度值过渡比较尖锐.且图像中噪声比较小时,梯度算子工作效果较好。公式中的偏导数需要对图像中每个像素位置计算,在实际应用中,常用小区域模板卷积来计算梯度。构成一个梯度算子需要两个模板。根据模板的大小以及系数值的不同,人们提出不同的算子.其中 Sobel 算子是先对灰度做加权平均然后再微分,所以它的效果最好。

拉普拉斯算子

拉普拉斯算子是一种二阶导数算子.它通过寻找图像灰度值的二阶微分中的过零点来检测边缘点。在数字图像中,计算函数的拉普拉斯值一般也是借助各种模板实现。对模板的基本要求是对应中心像素的系数是正的,而对应中心像素邻近像素的系数是负的,而且它们的和应该是零。拉普拉斯算子一般不以其原始形式用于边缘检测,主要是由于存在以下原因:作为一个二阶导数,拉普拉斯算子对噪声具有无法接受的敏感性;拉普拉斯算子的幅值产生双边缘,这是复杂的分割不希望有的结果;另外拉普拉斯算子不能检测边缘的方向。由于以上原因,拉普拉斯算子在分割中所起的作用包括两个:一是利用它零交叉的性质进行边缘定位;二是确定一个像素是在一条边缘暗的一边还是亮的一边。
对第一类作用,拉普拉斯算子与平滑过程一起利用零交叉的性质确定边缘的位置。可以将图像与2-D 高斯函数的拉普拉斯相卷积.这个公式一般叫做高斯型的拉普拉斯算子(Laplacian of a Gaussian,LoG).高斯型的拉普拉斯算子常被称为墨西哥草帽。可以看出 LoG 函数是一个轴对称函数.可以证明这个算子的平均值为零,如果将它与图像卷积不会改变图像的整体动态范围。但它与图像卷积会模糊图像,并且其模糊程度是正比于σ 值的。

图搜索

基于边缘检测的方法得到的通常是一些不连续的点或线段,要想使这些点或线段有意义,必须采用其他方法将它们连接成连续的闭合的边界。通常可以采用霍夫变换、边界跟踪或图搜索等方法。边界跟踪的方法只利用图像的局部信息连接边界,所以受噪声的影响较大。霍夫变换虽然具有抗噪声的性能,但它只能于检测已知形状的目标,如直线或圆,对未知形状的目标无法检测。用图形方式表达边缘线段连接的方法,通常称为图搜索法.这种方法将边界点和边界段用图结构表示,通过在图中搜索对应最小代价的通道来找到闭合边界。图搜索法是一种全局的方法,它在图像受噪声影响较大时效果仍较好,其缺点是计算量较大。
一般寻找最小代价通路问题就计算来看是很重要的。实际中常用的最短路径算法是 Dijkstra 搜索算法和动态规划算法,Dijkstra 算法的搜索速度比较慢,但是可以得到最优解;动态规划算法借助了一些启发式知识,虽然加快了搜索速度,但不能保证得到最优解。

尺度空间分析

尺度空间分析的理论思想是对原始图像进行多尺度变换,得到图像多尺度下尺度空间表示序列,从粗到细提取图像的轮廓。传统的尺度空间理论将 Gaussian 基函数看作是唯一的尺度空间基函数,要求尺度空间满足两个性质:一个是因果性;另一个是均匀性和对称性。尺度空间可以通过传导方程得到,通过将 Gaussian 基函数与原始图像卷积可以得到尺度图像。
非线性尺度空间的提出使尺度空间理论得到进一步的发展,多尺度图像可以利用各向异性传导系数和传导方程来构造。利用一个局部区域内部的热传导系数和局部区域之间的热传导系数不同,就可以在保持区域边缘的同时,使局部区域的内部得到平滑.
可利用多尺度理论进行图像增强。通过多尺度滤波,血管像素的灰度值将被提升,而背景像素的灰度值将被压制,从而使图像得到增强。在多尺度滤波中,每幅图像在不同的尺度下与一系列高斯滤波模板进行卷积,然后分析每个像素的 Hessian 矩阵特征值,以此判断该像素属于血管还是背景。增强的图像可以被直接显示出来,也可以采用图像分割方法进行分割。

基于模型的方法

在基于模型的方法中,对要分割的血管结构首先要给出明确的血管模型。常用的一种模型为活动轮廓模型,这种模型是定义在图像区域中的曲线或曲面,因为曲线的移动类似于蛇,因而又叫“蛇线”模型.该模型在内力和外力的共同作用下,不断发生变形,当模型在内力和外力的作用下达到平衡时,就得到了物体的边界。物体的边界也可以通过能量最小法来确定,这种模型的能量一般包括两种类型:一种为内部能量项,另一种为外力能量项。前者描述内在势力在形变过程中产生的影响,内在势力主要指形变曲线自身的几何性质等,可以用两种不同的几何特征来描述,即曲线的弧 长和曲线的曲率参数。内力使边界分段光滑,由像素与其周围点的关系决定。后者描述的是外在势力对曲线形变的影响,外在势力指与形变曲线本身几何性质无关的图像特征等,一般用与图像本身有关的信息进行描述,主要是基于灰度分布和基于梯度的变形模型。外力使得“蛇”接近实际的图像特征,如线或边缘。变形过程就是这两种力量的彼此消长的过程,最后达到平衡或者满足约束条件。
根据给出模型方式的不同,可以分为参数变形模型和几何变形模型.在变形过程中,参数变形模型的曲线或曲面以显示参数的形式表达,这种表达方式表达紧凑,变形过程中可以与模型直接交互,利于实现模型的快速和实时。但是难于处理曲线的分裂或溶化等情况,而这些是在变形过程中常出现的拓扑结构变化。几何变形模型基于水平集和曲线演化理论,其对于拓扑结构的变化可以应对自如,利用高维标量函数的水平集以隐式方式表达曲线或曲面。两种模型的表达方式虽然不同,但所遵循的变形思想是相似的。
近几年几何变形模型在水平集框架中得到广泛的应用,由于其处理拓扑结构变化的超强能力,使其在复杂血管的自动分割方面显示了无比的优势。文献[73]利用水平集方法实现曲线的演化,与传统形变模型不同的是,该方法提出的水平集描述依赖于时间的运动界面,灵活性较大,可以很容易的描述裂缝、空洞及重叠等复杂的表面模型。为了提供复杂的外型,这些模型可以合并许多的自由度。在水平集方法中,经过重大的变形后,模型不需要重新设置参数。文献[74]在分割冠脉 DSA 图像时应用水平集理论,取得较理想的分割结果。实验表明基于边界的方法准确率为 88.38%,基于区域的方法准确率达到 94.3%。 


Dehmeshki J, Amin H, Valdivieso M, et al. Segmentation of pulmonary nodules in thoracic CT scans: a region growing approach [J]. IEEE Transactions on Medical
Imaging, 2008, 27(4): 467-480.
Brieva J, Gonzalez E, Gonzalez F, et al. A level set method for vessel segmentation incoronary angiography [C]. Conf Proc IEEE Eng Med Biol Soc, 2005, 6: 6348-6351.
参数变形模型方法用参数表达待分割的血管模型,一般预先假定一个参数化的固定拓扑结构的表面。模型在一定的条件控制下变形,接近实际的血管结构。在血管分析中使用最多的是椭圆模型,将血管看作一系列相互重叠的椭圆曲线,通过对血管图像的估计确定血管模型的参数,血管中心线参数化的圆柱或者线形形状是经常被用到的。文献[78]在从血管造影图像中分割血管时采用改进的模拟退火算法,对图像中的正常血管和病变血管使用椭圆曲线进行模拟。实际的血管和分支利用初始血管的形变来逼近,整个血管的变形过程用改进的模拟退火算法来控制。该算法对正常血管和病变部位都取得较好的分割结果。

结合特定理论和工具的分割算法

常用的结合特定理论和工具的分割算法有:基于数学形态学、基于神经网络、基于小波理论等。

基于数学形态学的方法

基于数学形态学的分割方法,其基本原则是利用具有一定形态的结构元素对图像进行基本操作,以达到对图像分析和识别的目的。数学形态学的基本运算有膨胀(dilation)和腐蚀(erosion),以及它们组合形成的开运算(opening)和闭运算(closing).开运算是先腐蚀后膨胀,闭运算是先膨胀后腐蚀。各种运算对图像的处理都各具特点,膨胀使图像扩大而腐蚀使图像缩小。开运算和闭运算都能使图像的轮廓变得平滑,但两种运算的作用相反,开运算能断开狭窄的间断,消除细的突出物;闭运算能消除图像中小的孔洞,填补轮廓线中的断裂,并将狭窄的缺口和细长的鸿沟合并。结合图像的具体特征,可根据这些基本运算进行推导和组合不同的数学形态学算法,用于对图像形状和结构进行处理和分析,如边缘检测、图像滤波、特征提取、图像增强等。医学图像常用的处理算法有头帽变换(top-hat transformation)和分水岭变换(watershedtransformation)。

基于神经网络的方法

神经网络之所以能应用到图像分割中,是因为其具有两个优点:一是能够进行学习,二是在训练的过程中能够使用网络的非线性进行边界分割。其不足是每当有新的特征加入网络系统时,就需要重新进行学习和训练,而且其调试过程也很复杂。为了使网络系统利用其可学习性在特征中分类边界,应该尽可能多的选择物体的特征。学习过程中广泛应用的一种算法是后传播算法,由于训练数据集合决定学习,所以训练数据量的大小就决定了学习过程。

现有方法存在的缺陷

1. 有些针对某种特定成像模式提出的算法,不适用于其他成像模式。
2. 血管横截面一般被假定为是圆形。对于正常的血管来说这种假设是正确的,但对于发生病变的血管部位该假设不成立。
3. 血管的边界判断是依据像素的灰度梯度场来进行,但在血流速度低、血流复杂的区域,梯度值往往不够高。
4. 实际应用中假设每个组织的灰度分布是高斯分布。实际的情况并非完全如此,导致提出的模型和临床数据之间存在偏差。
5. 算法中涉及的参数许多都需要调整,而且参数的估计过程非常困难。
6. 有些属于交互式的算法,需要人工选择血管内的种子点或者终止点。
7. 分割方法的计算量大,计算代价昂贵。

所以,在实际项目中,遇到血管分割这样的问题时,需要具体问题具体分析,可能需要结合多种方法进行分割提取,方能取得较好的效果。后面结合具体数据,再学习和总结一下其他几种方法。~~

参考:

http://www.xzbu.com/8/view-6644265.htm

https://www.cnblogs.com/iamgoodman/archive/2013/04/23/3037483.html

冠状动脉造影图像的分割方法研究


  • 23
    点赞
  • 185
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值