CPU指令集——图像处理方向算子收集

阈值分割,得到二值图,高于阈值的为255

__m256i 阈值= _mm256_set1_epi8(阈值);
__m256i 图像1= _mm256_subs_epu8(原图像, 阈值); //低于阈值的都为0
__m256i 二值图 = _mm256_cmpeq_epi8(图像1, _mm256_set1_epi8(0));//低于阈值的为255,高于阈值的为0
二值图 = _mm256_andnot_si256(v, _mm256_set1_epi8(-1));//取反,低于阈值的为0,高于阈值的为255

面积,统计255的个数

int nMask = _mm256_movemask_epi8(二值图);//提取每8位的最高位组成一个32位dst
面积+= _mm_popcnt_u32(nMask);//32位中1的个数。即像素灰度为255的个数。循环完毕后就是目标面积(含噪点,越大表明噪声越多)

 

posted @   夕西行  阅读(36)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2020-07-05 Qt 异常总结(ubuntu环境)
2020-07-05 linux简单分区
2020-07-05 U盘启动盘制作工具
2020-07-05 Ubuntu常用命令
点击右上角即可分享
微信分享提示