十、切分织物起球和非起球区域以便于计算毛球对比度

news2024/11/16 8:40:42

一、通过训练的模型可以将织物的起球区域进行识别区分

原图:在这里插入图片描述
模型识别:在这里插入图片描述

二、对比度的计算

为了对织物起球等级进行评定,需要这边不同的参数特征来构建模型的评级系统
通过查阅相关文献,确定最终的特征参数为:织物起球个数、织物起球最大面积、织物起球平均面积、对比度、光学体积、密度分布
织物起球个数、织物起球最大面积、织物起球平均面积这些通过轮廓即可实现统计,详情可参考博文:十七、轮廓发现

文献中给出的定义如下:
在这里插入图片描述

①毛球区域平均灰度值

织物原图为:E:/Jupyter_notebook/pytorch/opencv/2_origin.jpg
模型预测的图片为:E:/Jupyter_notebook/pytorch/opencv/2_predict.jpg
在这里插入图片描述
此时只需要对模型预测的图片2_predict.jpg转灰度图
统计灰度图中灰度值总和、非0像素值的像素点个数,然后相除即可得到毛球区域平均灰度值

img = cv2.imread(r"E:\Jupyter_notebook\pytorch\opencv\2_predict.jpg"),读取图片
grayImage = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),转灰度图
x = cv2.countNonZero(grayImage),非0值的像素点个数
pill_gray = np.sum(grayImage),像素点之和,因为黑色像素点值为0,没有影响
aver_pill_gray = pill_gray/x,得到毛球区域平均灰度值
最终得到毛球区域平均灰度值aver_pill_gray

import cv2
import numpy as np
from matplotlib import pyplot as plt

def show_photo(name,picture):#图像显示函数
    cv2.imshow(name,picture)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
img = cv2.imread(r"E:\Jupyter_notebook\pytorch\opencv\2_predict.jpg")
grayImage = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

show_photo("origin",img)
show_photo("gray",grayImage)


x = cv2.countNonZero(grayImage) #非0值的像素点个数
pill_gray = np.sum(grayImage) #像素点之和 

aver_pill_gray = pill_gray/x

print(pill_gray)
print(x)
print(aver_pill_gray)
"""
160314
8964
17.884203480589022
"""

起球区域:在这里插入图片描述
起球区域灰度图:在这里插入图片描述

②非毛球区域平均灰度值

原图和模型预测的图片做差即可得到非毛球区域,然后转换为灰度图,求非0像素点总个数、求总像素点之和,就可以计算出非毛球区域平均灰度值

img_origin = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_origin.jpg"),读取原图
img_predict = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_predict.jpg"),读取模型预测之后的只含有起球区域的图像
img = cv2.subtract(img_origin, img_predict),原图和起球区域做差,得到非起球区域图像
grayImage = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY),非起球区域图像灰度图
x = cv2.countNonZero(grayImage),计算非起球区域图像灰度图中非0值的像素点个数
nonpill_gray = np.sum(grayImage),计算非起球区域图像灰度图像素点之和,因为黑色像素点值为0,没有影响
aver_nonpill_gray = nonpill_gray/x,计算非起球区域图像灰度图的平均值灰度值
最终得到非毛球区域平均灰度值aver_nonpill_gray

import cv2
import numpy as np
from matplotlib import pyplot as plt

def show_photo(name,picture):#图像显示函数
    cv2.imshow(name,picture)
    cv2.waitKey(0)
    cv2.destroyAllWindows()


img_origin = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_origin.jpg")
img_predict = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_predict.jpg")

img = cv2.subtract(img_origin, img_predict)
grayImage = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
x = cv2.countNonZero(grayImage) #非0值的像素点个数
nonpill_gray = np.sum(grayImage)#像素点之和 
aver_nonpill_gray = nonpill_gray/x


show_photo("origin",img_origin)
show_photo("pilling",img_predict)
show_photo("nonpilling",img)
show_photo("gray",grayImage)

print(nonpill_gray)
print(x)
print(aver_nonpill_gray)
"""
6103678
50237
121.49766108645022
"""

原图:在这里插入图片描述
起球区域:在这里插入图片描述
非起球区域:在这里插入图片描述
非起球区域灰度图:在这里插入图片描述

③对比度

根据论文中给出的公式,对比度就是aver_pill_grayaver_nonpill_gray做差
C = abs(aver_pill_gray - aver_nonpill_gray)

三、完整代码

import cv2
import numpy as np
from matplotlib import pyplot as plt

def show_photo(name,picture):#图像显示函数
    cv2.imshow(name,picture)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

img_origin = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_origin.jpg")
img_predict = cv2.imread(r"E:/Jupyter_notebook/pytorch/opencv/2_predict.jpg")
img_nonpill = cv2.subtract(img_origin, img_predict)

grayImage_pill = cv2.cvtColor(img_predict,cv2.COLOR_BGR2GRAY)
grayImage_nonpill = cv2.cvtColor(img_nonpill,cv2.COLOR_BGR2GRAY)

pill_number = cv2.countNonZero(grayImage_pill) #非0值的像素点个数
nonpill_number = cv2.countNonZero(grayImage_nonpill) #非0值的像素点个数

pill_gray = np.sum(grayImage_pill) #像素点之和 
nonpill_gray = np.sum(grayImage_nonpill) #像素点之和 

aver_pill_gray = pill_gray/pill_number
aver_nonpill_gray = nonpill_gray/nonpill_number

C = abs(aver_pill_gray - aver_nonpill_gray)

print(aver_pill_gray)
print(aver_nonpill_gray)
print(C)
"""
17.884203480589022
121.49766108645022
103.6134576058612
"""

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

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

相关文章

11.面向对象概述,类的创建,对象的创建

一.面向对象程序设计概述 1.知识点面向对象程序设计的目的 (1)从程序设计的角度来看,事物的属性就可以用变量来表示,行为则可以用方法来反映。 (2)客观世界中事物的属性和行为可以进行传递,当…

汇编与内联 x86-64

机器字长 x86是32位系统 64是64位系统 这里的32和64,指的都是机器字长 机器字长是 能直接进行整数/位运算的大小指针的大小(索引内存的范围) 8位机 由于空间大小限制,想要把集成电路做到个人主机里,只能用8位字长的 16位机 8086 IBMP…

如何破除增长的未知性?火山引擎交出了答卷

4月18日,由火山引擎主办的2023春季火山引擎“FORCE原动力”大会在上海召开。本次大会主要围绕云计算和数字化领域,全方位地展示火山引擎在云技术、云服务和云场景方面的最新探索、应用与实践,呈现创新发展的战略蓝图。 曾经,增长是…

Flink高手之路5-Table API SQL

文章目录 Flink 中的Table API & SQL一、Table API & SQL 介绍1. 为什么要Table API和SQL2. Table API & SQL的特点3. Table API& SQL发展历程3.1 架构升级3.2 查询处理器的选择3.3 了解-Blink planner和Flink Planner具体区别如下:3.4 了解-Blink …

神采PromeAI 2.0版本上线,助你释放创作超能力

上个月,我们推出神采PromeAI 1.0版本,让用户可以免费体验AI草图渲染功能。神采作为设计师的提效工具和灵感源泉,深受用户的广大好评。于是,在经过算法优化后,神采PromeAI 2.0版本终于在本周上线了! 我们提供…

【Vulnhub】之Symfonos2

一、 部署方法 在官网上下载靶机ova环境:https://download.vulnhub.com/symfonos/symfonos2.7z使用VMware搭建靶机环境攻击机使用VMware上搭建的kali靶机和攻击机之间使用NAT模式,保证靶机和攻击机放置于同一网段中。 二、 靶机下载安装 靶机下载与安…

ETCD(四)读请求处理过程

客户端通过etcdctl执行get命令 etcdctl get name --endpoints localhost:12379,192.158.00.32:12379client端 首先是client会解析这条命令,包括其中的get API方法,key值,请求server地址。解析完之后etcdctl会创建一个clientv3库对象&#xf…

Ubantu docker学习笔记(七)容器网络

文章目录 一、容器网络管理1.1查看容器网络1.2创建容器网络1.3 删除容器网络1.4 容器网络详细信息1.5 配置容器网络1.6 断开容器网络连接 二、none网络三、host网络四、bridge网络五、container网络六、容器连接外部网络6.1创建Overlay网络6.2创建Macvlan网络 一、容器网络管理…

研0进阶式学习---数据库配置

目录 最开始的问题:不同的连接名下面的数据库信息完全一样尝试新建用户名和密码,以此来建立新的连接 但这样建立的连接下面的数据库仍然是和之前的一模一样尝试改变xampp端口号,以此来建立新的连接 结论MySQL实例的数据库文件是与实例绑定的&…

完美解决丨+# TypeError: ‘dict_keys‘ object does not support indexing

结构 - 标题 - 问题描述 - 代码栗子 - 总结 目录 TypeError: dict_keys object does not support indexing 如何实现&#xff1f; python a {a: 1} b a.keys() c b[0] 异常描述 TypeError Traceback (most recent call last) <ipython-input-9-9dceb06f3f…

信号完整性分析基本概念之Retimer和Redriver

一两句话讲清楚版&#xff1a; Retimer 通过 其 Rx 端 CTLE/DFE (连续时间线性均衡/判断反馈均衡) 、CDR (时钟数据恢复) 及 Tx 端 EQ (均衡)&#xff0c;来够补偿信道损耗&#xff0c;消除信号抖动&#xff0c;提升信号完整性&#xff0c;从而增加传输距离。 Redriver 是放大…

多线程拉取+kafka推送

多线程拉取kafka推送 1 多线程 在本次需求中&#xff0c;多线程部分我主要考虑了一个点&#xff0c;就是线程池的配置如何最优。因为数据量级比较大&#xff0c;所以这个点要着重处理&#xff0c;否则拉取的时间会非常长或者是任务失败会比较频繁&#xff1b; 因为数据的量级…

Spring Security OAuth2.0(一)-----前言-授权码模式及代码实例

什么是 OAuth2 OAuth 是一个开放标准&#xff0c;该标准允许用户让第三方应用访问该用户在某一网站上存储的私密资源&#xff08;如头像、照片、视频等&#xff09;&#xff0c;而在这个过程中无需将用户名和密码提供给第三方应用。实现这一功能是通过提供一个令牌&#xff08…

如何治理“网络暴力” 在人类文明不断发展向前的进程中,大数据时代应运而来。数学建模解题步骤,愚见而已,欢迎指错和探讨呀~

题目可见文章&#xff1a;(20条消息) 如何治理“网络暴力” 在人类文明不断发展向前的进程中&#xff0c;大数据时代应运而来。 数学建模&#xff0c;90%成品论文&#xff0c;附附件、原题、代码 注&#xff0c;水平有限&#xff0c;非广告&#xff0c;仅供交流参考&#xff0c…

6、ThingsBoard使用jar包自己构建镜像部署

1、概述 这一节主要讲解你自己使用jar包构建镜像,一般在很多企业中,都是使用Jenkins配置流水线,自动打包,然后拷贝程序在target目录下生成的jar包,然后使用Dockerfile文件进行构建镜像,其实我这一节讲的也是类似,只是不使用Jenkins来实现自动,原理都一样,估计也是很多…

C++ MySQL存储二进制数据、存储照片

版权声明&#xff1a;本文为CSDN博主「intfre」的原创文章&#xff0c;遵循CC 4.0 BY-SA版权协议&#xff0c;转载请附上原文出处链接及本声明。 原文链接&#xff1a;https://blog.csdn.net/nibiru_holmes/article/details/51387047 0x01 首先MySQL支持二进制的类型有Blob: …

Doris-1.2.0升级到Doris-1.2.4

0 背景 在使用doris-1.2.0版本时发现BE节点无故宕机&#xff0c;自己尝试解决无果后再官网寻找解决方案&#xff0c;发现在doris-1.2.0版本中存在这样的隐患bug导致BE节点宕机。 而在咨询社区之后建议对doris进行升级&#xff0c;升级版本doris-1.2.4。该版本是解决1.2.x问题…

Springboot集成neo4j实现知识图谱关系图

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、neo4j是什么&#xff1f;二、安装步骤1.启动2.使用2.简单命令 二、使用springboot集成neo4j1.引入依赖2.功能实现3.查询关系节点4. 查询指定评委和指定选手…

基于matlab使用光线追踪自定义 CDL 通道模型

一、前言 此示例演示如何使用光线追踪分析的输出自定义 CDL 通道模型参数。该示例演示如何&#xff1a; 指定发射器和接收器在 3D 环境中的位置。 使用光线追踪来计算通道的几何方面&#xff1a;光线数量、角度、延迟和衰减。 使用光线追踪分析的结果配置 CDL 通道模型。 使用相…

KDYZ-YM晶闸管伏安特性测试仪

一、概述 晶闸管的伏安特性是晶闸管的基本特性&#xff0c;这项特性的好坏&#xff0c;直接影响到器件在整机上的正常使用。因此&#xff0c;检测晶闸管的伏安特性在晶闸管器件的生产、经销及使用过程中都是十分重要的。 测试方法符合国标JB/T7624-94《整流二极管测试方法》和J…