特征提取 - 骨架、中轴和距离变换

news2025/1/11 7:57:12

目录

1. 介绍

骨架 skeleton

中轴变换 Medial axis transformation

距离变换 distance transform

2. 距离变换的代码实现

distanceTransform 函数介绍

normalize 函数介绍

取局部最大值

完整代码

3. comparation


1. 介绍

骨架 skeleton

骨架的定义:就是目标的前景像素点集合内部最大的内切圆盘,将所有的内切圆盘的圆心连起来就是骨架

 一个骨架的区域就是这个 区域中与区域边界 等距 的集合,

骨架的实现可以参考这篇文章:形态学 - 骨架 和 形态学 - 细化

中轴变换 Medial axis transformation

中轴变换可以计算前景区域的中轴,一个区域的骨架就定义为这个区域的中轴

它的中轴定义如下:R 是前景区域 , B 是前景区域的边界 。如果 前景区域 R 中的每个点p,在边界B中找到最近的点。如果这个最近的点不是唯一的,那么点p定义为前景区域R的中轴

骨架其实就是物品最中间的那根轴,因此这个轴到周围边界的距离应该是相等的

查看源图像

 

中轴的概念可以用 '草原大火' 的概念去理解:

  • 把图像处理成二值图像,在前景区域的边界处点火
  • 火焰会以同样的速度向前景区域蔓延,
  • 那么中轴就是火焰接触的集合

距离变换 distance transform

中轴变换需要计算大量的点到边界的距离,可以通过距离变换去代替

距离变换的意思是,对于一副二值图像而言。前景区域(非0)到最近的背景区域(0值)的距离

 

 

因此,距离变换后的图像是一副灰度图像,灰度值的大小与前景像素点距离背景区域的远近成正相关。也就是说,图像越亮--->灰度值越大--->距离背景越远,那么骨架就是定义为距离变换后的局部极大值的区域

这里书上的介绍是 '脊' ,也就是局部极大值的集合。因为没有介绍局部极大值的范围,下面代码的实现是 4邻域

2. 距离变换的代码实现

因为形态学的骨架提取之前已经介绍过了,这里不再介绍

而中轴变换等效于距离变换,因此这里只介绍距离变换的代码

如上述代码,首先将图像进行 OTSU 二值化,然后对二值图像进行距离变换

distanceTransform 函数介绍

第二个参数计算距离的方法,常用的有下面几种

第三个参数为 maskSize:距离变换掩码矩阵的大小

  • 当选择使用街区距离时,掩码尺寸选择3×3还是5×5对计算结果都没有影响,因此为了加快函数运算速度,默认选择掩码尺寸为3×3
  • 当选择欧式距离时,掩码尺寸为3×3时是粗略的计算两个像素之间的距离,而当掩码尺寸为5×5时是精确的计算两个像素之间的距离,精确计算与粗略计算两者之间存在着较大的差异,因此在使用欧式距离时推荐使用5×5掩码
  • 当选择棋盘距离时,掩码的尺寸对计算结果也没有影响,因此可以随意选择

normalize 函数介绍

因为图像的返回是浮点型的数据或者灰度值往往不大,是一副几乎全黑的图像,因此这里对图像进行了放缩 normalize

这里只对下面这串代码介绍:

img_dst = cv2.normalize(img_dst, None, 0, 255, norm_type=cv2.NORM_MINMAX, dtype=cv2.CV_8U)  

0,255 代表缩放后图像的灰度值在 0-255之间

cv2.NORM_MINMAX 代表:

 

取局部最大值

距离变换后,取最大值的代码为

其实就是二维矩阵求取局部最大值,但是需要注意的是,我们是不对背景区域求取局部极值的

注:这里局部的范围是 4邻域

完整代码

import cv2
import numpy as np


def local_maximum(x):   # 取局部最大值

    dst = np.zeros(x.shape, dtype=np.uint8)     # 处理的结果
    height,width = x.shape[:2]

    for i in range(1, height - 1):
        for j in range(1, width - 1):
            if x[i][j] != 0:
                if (x[i][j] >= x[i - 1][j]) and (x[i][j] >= x[i + 1][j]) and (x[i][j] >= x[i][j - 1]) and (x[i][j] >= x[i][j + 1]):
                    dst[i][j] = 255
    return dst


img = cv2.imread('./img.jpg',0)
_, img_bin = cv2.threshold(img,0,255,cv2.THRESH_OTSU+cv2.THRESH_BINARY)         # 二值化图像

img_dst = cv2.distanceTransform(img_bin,cv2.DIST_L2,5)                              # 距离变换
img_dst = cv2.normalize(img_dst, None, 0, 255, norm_type=cv2.NORM_MINMAX, dtype=cv2.CV_8U)  # 归一化,为了方便显示

ret = local_maximum(img_dst)            # 取距离变换后的局部最大值

cv2.imshow('img',np.hstack((img_bin,img_dst,ret)))
cv2.waitKey()
cv2.destroyAllWindows()

处理的结果为:二值图、距离变换图、骨架

 

3. comparation

对同一幅图像用 细化 、 骨架抽取 、距离变换 方法比较

细化的结果为:

骨架抽取的结果为:

 距离变换的结果:

 

可以发现,细化的结果会有小的毛刺。距离变换产生了不连续的骨架

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

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

相关文章

【毕业设计】33-基于单片机的直流电机的转速检测与控制设计(原理图工程+PCB工程+源代码工程+仿真工程+答辩论文)

typora-root-url: ./ 【毕业设计】33-基于单片机的直流电机的转速检测与控制设计(原理图工程PCB工程源代码工程仿真工程答辩论文) 文章目录typora-root-url: ./【毕业设计】33-基于单片机的直流电机的转速检测与控制设计(原理图工程PCB工程源…

盘点国内主流数字孪生厂商!你了解几家?

在国内,主流的数字孪生解决方案厂商包括华龙迅达、精航伟泰、羚数智能、力控科技、华力创通、同元软控、优也科技、51world、卡奥斯、摩尔元数、易知微、木棉树软件等。由于中国数字孪生市场仍处于早期发展阶段,且受限于建模、仿真和基于数据融合的数字线…

基于单RGB相机的全新三维表示方法|NeurIPS 2022

随着深度学习的发展,基于单张RGB图像的人体三维重建取得了持续进展。 但基于现有的表示方法,如参数化模型、体素栅格、三角网格和隐式神经表示,难以构筑兼顾高质量结果和实时速度的系统。 针对上述问题,天津大学团队联合清华大学…

Linux用户管理

文章目录一. 引子二. 用户管理1. 用户切换2. 注销用户3. 添加用户4. 设置用户密码5. 删除用户6. 查询用户信息三. 用户组管理1. 新增用户组2. 新增用户时添加组3. 修改用户的组四. 用户和组相关文件1. /etc/passwd2. /etc/shadow3. /etc/group一. 引子 Linux是一个多用户、多任…

【JavaScript作用域】

JavaScript作用域1 本节目标2 作用域2.1 作用域概述2.2 全局作用域2.3 局部作用域3 变量的作用域3.1 变量作用域的分类3.2 全局变量3.3 局部变量3.4 从执行效率看全局变量与局部变量3.5 JS没有块级作用域4 作用域链1 本节目标 说出JavaScript的两种作用域区分全局变量和局部变…

TinyML:是否是FPGA在人工智能方面的最佳应用?

TinyML 也是机器学习的一种,他的特点就是缩小深度学习网络可以在微型硬件中使用,主要应用在智能设备上。超低功耗嵌入式设备正在“入侵”我们的世界,借助新的嵌入式机器学习框架,它们将进一步推动人工智能驱动的物联网设备的普及。…

机器学习:一文从入门到读懂PCA(主成分分析)

深度学习:PCA白化前置知识内积的几何意义基基变换不同基下的向量变换逆矩阵不同基下的空间变换方差协方差协方差矩阵协方差矩阵对角化特征值分解、空间变换主成分分析(PCA)两个原则公式推导求解流程代码实现PCA的优缺点优点缺点前置知识 维度…

【测试沉思录】18.如何测试微信小程序?

作者:雷远缘 编辑:毕小烦 一. 先知道小程序是什么 啥是小程序? “小程序是一种不需要下载安装即可使用的应用,它实现了应用 “触手可及” 的梦想,用户扫一扫或者搜一下即可打开应用。也体现了 “用完即走” 的理念&am…

[附源码]Python计算机毕业设计SSM基于Java的民宿运营管理网站(程序+LW)

环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 Maven管理等…

详解 Spring Boot 项目中的配置文件

目录 1. Spring Boot 项目中配日文件的作用是什么 2. Spring Boot 配置文件的两种格式 3. properties 配置文件 3.1 properties 配置文件的基本语法 3.2 properties 配置文件的分类 3.3 如何读取配置文件 3.4 properties 配置文件的优缺点分析 4. yml 配置文件 4.1 yml …

【JavaSE】初识泛型

大家好!我是保护小周ღ,本期为大家带来的是 Java的泛型,会来大家初步了解什么是泛型,以及泛型的使用,感受一手泛型的思想,面向对象编程太爽了~ 目录 一、泛型是什么? 二、泛型的语法 三、包…

Java给图片增加水印,根据图片大小自适应,右下角/斜角/平铺

Hi,I’m Shendi 最近写自己的文件服务器,上传图片时需要自动增加水印,在这里记录一下 文章目录效果展示读取图片从 byte[] 读取图片获取画板绘制水印根据图片大小自适应水印大小右下角文字水印斜角水印平铺水印图片水印输出图片水印就是在图片…

《剑指 Offer 》—58 - I. 翻转单词顺序

《剑指 Offer 》—58 - I. 翻转单词顺序 注意:本题与151 题相同:https://leetcode-cn.com/problems/reverse-words-in-a-string/ 注意:此题对比原题有改动 文章目录《剑指 Offer 》—58 - I. 翻转单词顺序一、题目内容二、个人答案&#xf…

Git 打patch (打补丁)的使用

patch 的使用 一般是diff ,apply ,format-patch,am 1 生成patch git diff > test.patch 这个是打补丁(test.patch自己取的名字,这个命令可以看出没有指定修改的问题所以默认把所有修改的文件都打patch了,同时还需要注意,这里是本地修改的没有执行add缓存的) 如果想指定某…

FPGA实现图像对比度自动调整,提供2套工程源码和技术支持

目录1.算法原理介绍2.HLS算法实现3.工程1介绍:zynq7100实现4.工程2介绍:Kintex7实现5.上板调试验证6.福利:工程源码获取1.算法原理介绍 使用直方图均衡技术实现 使用直方图均衡技术将原始图像的灰度直方图从比较集中的某个灰度区间变成在全部…

学习axure都要经历哪个阶段,如何快速入门

作为初学Axure同学们,正在学习AxureRP在这个过程中,我们应该经历每个阶段,掌握每个阶段的特点,明确如何在不同阶段学习,这样我们才能快速做到axure快速掌握这个工具。还能根据自己的实际工作需要,掌握自己的…

关系抽取(二)远程监督方法总结

目录 前言 1. 远程监督关系抽取开山之作 1.1 介绍 1.2 训练过程 1.2.1 数据标注方法 1.2.2 训练方法 1.3 测试过程 1.4 思考 1.5 总结 2. PCNN 2.1 介绍 2.2 模型结构 2.2.1 文本特征表示 2.2.2 卷积 2.2.3 分段最大池化 2.2.4 softmax多分类 2.3 多实例学习的…

【elementUI样式】模态框中的el-select下拉框不跟随页面滚动问题

文章目录1.在el-select标签中设置:popper-append-to-body"false"2.样式穿透(比较普遍的写法)模态框中的el-select下拉框不跟随页面滚动问题在使用elementUI写界面的时候,偶然遇到了如下图所示bug当页面滚动的时候,el-se…

JVM之类加载子系统

JVM类加载子系统类的加载过程类加载器双亲委派机制类的加载过程 初始化阶段解读 初始化阶段就是执行构造类加载器<clinit>()的过程 该方法不需要定义&#xff0c;是javac编译器自动收集类中所有类变量的赋值动作和静态代码中的语句合并而来 构造方法中指令按照语句在源文…

学习Retrofit后,你还需要明白这些……

在学习Retrofit后&#xff0c;由于它本身就是OKHttp的封装&#xff0c;面试中也经常会被一起问到&#xff1b;单纯的解析它的源码学习难免会有点无从下手&#xff0c;往往让人抓不住重点&#xff0c;学习效率并不是很高&#xff0c;本文从提出几个问题出发&#xff0c;带着问题…