Halcon基于laws纹理特征的SVM分类

        与基于区域特征的 SVM 分类不同,针对图像特征的 SVM 分类的算子不需要直接提取

特征,下面介绍基于 Laws 纹理特征的 SVM 分类。

       纹理在计算机视觉领域的图像分割、模式识别等方面都有着重要的意义和广泛的应

用。纹理是指由于物体表面的物理属性不同所引起的灰度或颜色变化,不同的物体表面会

产生不同的纹理图像,所以纹理是图像的一种十分重要的属性。

       纹理虽然很容易从直观上查看,但却很难用精准的数学公式来表述,它是由非单一颜

色或明暗度所呈现出来的某种规律性特征。纹理包含物体表面组织结构排列的重要信息及其与周围环境的联系。纹理基元是基本的纹理元素,它可以是一个像素的灰度,也可以是具有特定性质的连通像素集合。准确而高效的纹理特征提取是成功进行图像纹理描述、分类与分割的前提,因为提取的纹理特征直接影响后续处理的图像质量

 a )墙类纹理

( b )金属纹理

( c )木质纹理

( d )布花纹纹理

       1、纹理分析法

       在涉及具体的纹理特征提取时,研究学者们总是习惯于先寻找更多的能够反映纹理特征的度量方式,然后通过分析或者变换提取有效的特征,以用于纹理的描述和分类。提取的目标纹理特征应满足:特征维数小,鉴别能力强,稳健性好,提取过程消耗时间短,空间复杂度小,易于实际应用等,常用的纹理分析法主要有以下四类:

       1)统计法

       统计法是目前研究最多,应用最早且占主导的一种纹理分析法。纹理特征在局部上表现出很大的随机性,但从整体和统计意义上看存在某种规律性。从区域统计方面分析纹理图像的方法称为基于统计的分析方法,简称统计法。统计法主要利用图像的统计特性求出某种特征值,再基于图像特征的一致性进行分析。典型的统计法包括灰度共生矩阵、滤波模板、随机模型等。

       2)结构法

       结构法是建立在纹理基元理论基础上的一种纹理特征分析方法。纹理基元理论认为,复杂的纹理可以由若干简单的纹理基元以一定的有规律的形式重复排列组合构成。若纹理基元能够单独被分割和描述,则要使用结构法,即首先确定纹理基元的形状,然后确定控制这些纹理基元位置的规则。

       结构法大致可以分为以下两步:

       第一步,确定图像中纹理基元的位置并提取图像中的纹理基元;

       第二步,确定纹理基元的排列方式,即研究纹理基元间的结构关系。

       其中,第一步描述了图像的局部纹理特征,第二步将整幅图像中的不同纹理基元进行统计分析,得到纹理基元的排列规律,也就获得了整幅图像全面的纹理信息。结构法中比较有影响的算法是 Voronoi 棋盘格特征分析法。

       结构法的优点是纹理构成易理解,适合于高层检索以及描述规则的人工纹理。但对于不规则的自然纹理,由于纹理基元本身提取困难以及纹理基元之间的排布规则复杂,因此结构法受到很大的限制。

       3)模型法

       模型法以图像模型为基础,通过构造图像模型,利用模型的参数作为其纹理特征。模型法的关键在于构造模型,使模型表示出来的纹理图像能最接近原来的图像。最典型的模型法是随机场模型法,如马尔可夫( Markov )随机场模型法和 Gibbs 随机场模型法。

       4)频谱法

       频谱法是依赖图像的频谱特性来描述纹理特征的方法。常用的频谱法主要包括傅里叶功率频谱法、塔式小波变换法、 Gabor 变换法等。

       在图像处理中,一种生成纹理特征的方案是利用局部模板来检测不同类型的纹理。 Laws 纹理掩膜就是一种典型的基于模板卷积的纹理描述方法。

       对于滤波模板, Laws 进行了深入研究,首先定义一维滤波模板,然后通过卷积运算形成了用于检测和度量纹理结构信息的一系列一维和二维滤波模板。

        Laws 选定了三组一维滤波模板,分别用于检测灰度、边缘、点特征,模板如下:

       1=[121]

        e =[-101]

        s =[-12-1]

       两个一维滤波模板经过卷积形成长度为5的五组一维向量,分别检测灰度、边缘、点、波、涟漪特征,模板如下:

       1=[1  4  6  4  1]

        e =[-1  -2  0  2  1]

        s =[-1  0  2  0  -1]

        w =[-1  2  0  -2  1]

        r =[1  -4  6  -4  1]

       由滤波模板与图像卷积运算可以得到不同的纹理能量信息。利用 Laws 纹理提取纹理信息,结合 SVM 分类器可进行纹理缺陷检测。由于 Laws 纹理滤波模板少,所以可将纹理图组合成多通道纹理图以便得到准确的检测结果。

       2.基于 Laws 纹理特征的相关算子

      1), texture _ laws ( Image : ImageTexture ; FilterTypes , Shift , FilterSize ;)

       功能:使用 Laws 纹理滤波模板对图像进行纹理滤波处理。

        Image :准备进行纹理滤波处理的图像。

        ImageTexture :滤波后得到的纹理图像。

        FilterTypes :滤波形式,包括' el '、'' es '、' Is '等。

        Shift :灰度值放缩因子。

        FilterSize :滤波大小。

      2), add _ samples _ image _ class _ svm ( Image , ClassRegions :: SVMHandle :)

       功能:增加训练样本图像到支持向量机。

       Image :训练图像。

        ClassRegions :图像中用于训练的区域。

        SVMHandle :支持向量机句柄。

      3), reduce _ class _ svm (:: SVMHandle , Method , MinRemainingSV , MaxError :

 SVMHandleReduced )

       功能:通过简化支持向量机实现支持向量机的近似,从而进行更快地分类。

        SVMHandle :原始的支持向量机句柄。

        Method :处理后类型,以减少支持向量的数量。

        MinRemainingSV :剩余支持向量的最小数量。

        MaxError :减少误差的最大允许值。

        SVMHandleReduced :简化后的支持向量机句柄。

       4), classify _ image _ class _ svm ( Image : ClassRegions : SVMHandle :)

       功能:使用支持向量机对图像进行分类。

        Image :待分类的图像(多通道)。

        ClassRegions :待分类的各个区域。

        SVMHandle : SVM 句柄。

案例分析

1,创建,训练SVM模型

read_image (Image, 'plastic_mesh/plastic_mesh_01')
get_image_size (Image, Width, Height)
dev_close_window ()
dev_open_window (0, 0, Width, Height, 'black', WindowHandle)
dev_set_color ('red')
set_display_font (WindowHandle, 16, 'mono', 'true', 'false')
*用于分类的纹理过滤器将返回图像边界处的伪影,因为待检查的塑料网格图像不包含整数网格单元。由于这\
将导致在图像边界处被错误地检测到错误,因此我们必须将靠近图像边界的区域排除在训练和分类之外。这是\
用下面的矩形完成的。注意,该图像随后被按2倍的比例缩小。
gen_rectangle1 (Rectangle, 10, 10, Height / 2 - 11, Width / 2 - 11)
*创建SVM分类器模型
create_class_svm (5, 'rbf', 0.01, 0.0005, 1, 'novelty-detection', 'normalization', 5, SVMHandle)
* 循环读取图像冰利用SVM进行训练
for J := 1 to 5 by 1read_image (Image, 'plastic_mesh/plastic_mesh_' + J$'02')* 由于网格的分辨率非常高,图像被缩小了。可以节省了大量的处理时间。zoom_image_factor (Image, ImageZoomed, 0.5, 0.5, 'constant')dev_display (ImageZoomed)disp_message (WindowHandle, 'Adding training samples...', 'window', 12, 12, 'black', 'true')*生成纹理图像*‘el’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageEL, 'el', 5, 5)*‘le’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageLE, 'le', 5, 5)*‘es’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageES, 'es', 1, 5)*‘se’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageSE, 'se', 1, 5)*‘ee’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageEE, 'ee', 2, 5)compose5 (ImageEL, ImageLE, ImageES, ImageSE, ImageEE, ImageLaws)smooth_image (ImageLaws, ImageTexture, 'gauss', 5)*将样本添加到分类器中add_samples_image_class_svm (ImageTexture, Rectangle, SVMHandle)
endfor
dev_display (ImageZoomed)
disp_message (WindowHandle, 'Training SVM...', 'window', 12, 12, 'black', 'true')
* 训练支持向量机。这将生成相当多的支持向量。
train_class_svm (SVMHandle, 0.001, 'default')

2,推断验证模型

* 为了提高分类速度,减少支持向量的数量。
reduce_class_svm (SVMHandle, 'bottom_up', 2, 0.001, SVMHandleReduced)
* 推断
dev_set_draw ('margin')
dev_set_line_width (3)
for J := 1 to 14 by 1read_image (Image, 'plastic_mesh/plastic_mesh_' + J$'02')zoom_image_factor (Image, ImageZoomed, 0.5, 0.5, 'constant')dev_display (ImageZoomed)dev_set_color ('white')dev_display (Rectangle)*‘el’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageEL, 'el', 5, 5)*‘le’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageLE, 'le', 5, 5)*‘es’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageES, 'es', 1, 5)*‘se’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageSE, 'se', 1, 5)*‘ee’模板Laws纹理滤波卷积texture_laws (ImageZoomed, ImageEE, 'ee', 2, 5)compose5 (ImageEL, ImageLE, ImageES, ImageSE, ImageEE, ImageLaws)smooth_image (ImageLaws, ImageTexture, 'gauss', 5)reduce_domain (ImageTexture, Rectangle, ImageTextureReduced)* 使用支持向量机进行分类classify_image_class_svm (ImageTextureReduced, Errors, SVMHandleReduced)* 通过开运算和闭运算去掉干扰部分opening_circle (Errors, ErrorsOpening, 3.5)closing_circle (ErrorsOpening, ErrorsClosing, 10.5)connection (ErrorsClosing, ErrorsConnected)select_shape (ErrorsConnected, FinalErrors, 'area', 'and', 300, 1000000)count_obj (FinalErrors, NumErrors)dev_set_color ('red')dev_display (FinalErrors)if (NumErrors > 0)disp_message (WindowHandle, 'Mesh NG', 'window', 12, 12, 'red', 'true')elsedisp_message (WindowHandle, 'Mesh OK', 'window', 12, 12, 'forest green', 'true')endifstop ()
endfor

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

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

相关文章

Netty篇(入门编程)

目录 一、Hello World 1. 目标 2. 服务器端 3. 客户端 4. 流程梳理 💡 提示 5. 运行结果截图 二、Netty执行流程 1. 流程分析 2. 代码案例 2.1. 引入依赖 2.2. 服务端 服务端 服务端处理器 2.3. 客户端 客户端 客户端处理器 2.4. 代码截图 一、Hel…

从0开始学习机器学习--Day14--如何优化神经网络的代价函数

在上一篇文章中,解析了神经网络处理分类问题的过程,类似的,在处理多元分类问题时,神经网络会按照类型分成多个输出层的神经元来表示,如下: 处理4个分类问题时的神经网络 我们可以看到,相较于之…

除草机器人算法以及技术详解!

算法详解 图像识别与目标检测算法 Yolo算法:这是目标检测领域的一种常用算法,通过卷积神经网络对输入图像进行处理,将图像划分为多个网格,每个网格生成预测框,并通过非极大值抑制(NMS)筛选出最…

Android MavenCentral 仓库更新问题

MavenCentral 仓库更新问题 前言正文一、Maven central repository的账户迁移二、获取加密账户信息三、问题和解决方式① 问题1② 解决1③ 问题2④ 解决2 前言 在去年的3、4月份的时候我发布了一个开源库EasyView,在MavenCentral上,可以说当时发布的时候…

腾讯为什么支持开源?

今天看到一条新闻,感觉腾讯在 AI 大模型方面确实挺厉害的,符合它低调务实的风格,在不知不觉中一天竟然开源了两个核心的,重要的 AI 大模型。 据新闻报道,11月 5 日,腾讯混元宣布最新的 MoE 模型“混元 Larg…

学习了,踩到一个坑!

前言 踩坑了啊,最近踩了一个 lombok 的坑,有点意思,给你分享一波。 我之前写过一个公共的服务接口,这个接口已经有好几个系统对接并稳定运行了很长一段时间了,长到这个接口都已经交接给别的同事一年多了。 因为是基…

『Django』APIView基于类的用法

点赞 关注 收藏 学会了 本文简介 上一篇文章介绍了如何使用APIView创建各种请求方法,介绍的是通过函数的方式写接口。 本文要介绍 Django 提供的基于类(Class)来实现的 APIView 用法,代码写起来更简单。 APIView基于类的基…

CentOS系统查看CPU、内存、操作系统等信息

Linux系统提供了一系列命令可以用来查看系统硬件信息,如CPU的物理个数、核数、逻辑CPU数量、内存信息和操作系统版本。 查看物理CPU、核数和逻辑CPU 在多核、多线程的系统中,了解物理CPU个数、每个物理CPU的核数和逻辑CPU个数至关重要。超线程技术进一步…

DNS配置

1.搭建dns服务器能够对自定义的正向或者反向域完成数据解析查询。 2.配置从DNS服务器,对主dns服务器进行数据备份。 options {listen-on port 53 { 192.168.111.130; };directory "/var/named";allow-query { any;};zone "openlab.com&qu…

【WebRTC】WebRTC的简单使用

目录 1.下载2.官网上的使用3.本地的使用 参考: 【webRTC】一、windows编译webrtc Windows下WebRTC编译 1.下载 下载时需要注意更新python的版本和网络连接,可以先试试ping google。比较关键的步骤是 cd webrtc-checkout set https_proxy127.0.0.1:123…

使用axois自定义基础路径,自动拼接前端服务器地址怎么办

请求路径: http://localhost:5173/http://pcapi-xiaotuxian-front-devtest.itheima.net/home/category/head 很明显多拼接了路径地址 查看基础路径文件发现: //axios基础封装 import axios from axiosconst httpInstance axios.create({baseURL: /h…

第J5周:DenseNet+SE-Net实战

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 任务: ●1. 在DenseNet系列算法中插入SE-Net通道注意力机制,并完成猴痘病识别 ●2. 改进思路是否可以迁移到其他地方呢 ●3. 测试集acc…

力扣最热一百题——杨辉三角

目录 题目链接:118. 杨辉三角 - 力扣(LeetCode) 题目描述 示例 提示: 解法一:利用特性构建杨辉三角 1. 结果存储结构: 2. 初始化和循环遍历每一层: 3. 构建每一层: 4. 填充中间的元素&…

道品科技智慧农业中的自动气象检测站

随着科技的进步,智慧农业已经成为现代农业发展的重要方向。农业自动气象检测站作为智慧农业的一个关键组成部分,发挥着不可或缺的作用。本文将从工作原理、功能特点、应用场景以及主要作用等方面对农业自动气象检测站进行深入探讨。 ## 一、工作原理 农…

Android——多线程、线程通信、handler机制

Android——多线程、线程通信、handler机制 模拟网络请求&#xff0c;会阻塞主线程 private String getStringForNet() {StringBuilder stringBuilder new StringBuilder();for (int i 0; i < 100; i) {stringBuilder.append("字符串" i);}try {Thread.sleep(…

练习LabVIEW第三十三题

学习目标&#xff1a; 刚学了LabVIEW&#xff0c;在网上找了些题&#xff0c;练习一下LabVIEW&#xff0c;有不对不好不足的地方欢迎指正&#xff01; 第三十三题&#xff1a; 用labview编写一个判断素数的程序 开始编写&#xff1a; LabVIEW判断素数&#xff0c;首先要搞…

我要精通前端-布局方式理解总结

一、浮动 1、传统网页布局的三种方式 ​CSS 提供了三种传统布局方式(简单说,就是盒子如何进行排列顺序)&#xff1a; 1.普通流&#xff08;标准流&#xff09; 2.浮动 3.定位 这三种布局方式都是用来摆放盒子的&#xff0c;盒子摆放到合适位置&#xff0c;布局自然就完成了…

C-DTL698电表 转 IEC61850 协议项目案例

目录 1 案例说明 2 VFBOX网关工作原理 3 准备工作 4 配置VFBOX网关 5 用IEC61850协议转发数据 6 网关使用多个逻辑设备和逻辑节点的方法 7 其他说明 8 案例总结 1 案例说明 设置网关采集DLT698电表数据数据把采集的数据转成IEC61850协议转发给其他系统。 2 VFBOX网关…

斗破QT编程入门系列之二:GUI应用程序设计基础:UI文件(四星斗师)

斗破Qt目录&#xff1a; 斗破Qt编程入门系列之前言&#xff1a;认识Qt&#xff1a;Qt的获取与安装&#xff08;四星斗师&#xff09; 斗破QT编程入门系列之一&#xff1a;认识Qt&#xff1a;初步使用&#xff08;四星斗师&#xff09; 斗破QT编程入门系列之二&#xff1a;认识…

机器学习4_支持向量机_核函数——MOOC

核函数的定义 引入了映射 后 最小化&#xff1a; 或 限制条件&#xff1a; &#xff08;1&#xff09; &#xff08;2&#xff09; 具体研究 引入 核函数&#xff08;Kernel Function&#xff09; Vladimir Naumovich Vapnik 指出&#xff0c;可以不用知道 的具体…