opencv dots_image_kernel

1,opencv dots_image_kernel

cpp 复制代码
// halcon dots_image kernel估算(d=5)
cv::Mat getDotKernel(int d = 5){
	// 保证d为正的奇数
	d |= 0x01;

	cv::Mat kernel = cv::Mat::zeros(d + 2, d + 2, CV_8UC1);
	int cx = kernel.cols / 2;
	int cy = kernel.rows / 2;
	int cnt255 = 0, cnt128 = 0, cnt0 = 0;
	for (int row = 0; row < kernel.rows; ++row) {
		for (int col = 0; col < kernel.cols; ++col)	{
			float dis = std::sqrt(std::pow(col - cx, 2) + std::pow(row - cy, 2));
			if (dis < d / 2.0){
				kernel.at<uchar>(row, col) = 255;
				cnt255++;
			}
			else if (dis < d / 2.0 + 1.0){
				kernel.at<uchar>(row, col) = 128;
				cnt128++;
			}
			else {
				kernel.at<uchar>(row, col) = 0;
				cnt0++;
			}
		}
	}
	//
	cv::imwrite("kernel8u.0.png", kernel);
	//
	for (int row = 0; row < kernel.rows; ++row) {
		for (int col = 0; col < kernel.cols; ++col){
			switch (kernel.at<uchar>(row, col))
			{
			case 255:
				kernel.at<uchar>(row, col) = cnt128;
				break;
			case 128:
				kernel.at<uchar>(row, col) = -cnt255;
			default:
				break;
			}
		}
	}
	cv::imwrite("kernel8u.1.png", kernel);
	//
	if (cnt255 *cnt128){
		kernel.convertTo(kernel, CV_32F, 1.0 / (cnt255*cnt128));
	}
	
	return kernel;
}

2,单元测试

3,结果

相关推荐
测试员周周2 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
K姐研究社4 小时前
怎么用AI制作电商口播视频,开拍APP一键生成
人工智能·音视频
LaughingZhu4 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
传说故事5 小时前
【论文阅读】MotuBrain: An Advanced World Action Model for Robot Control
论文阅读·人工智能·具身智能·wam
北京耐用通信5 小时前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
火山引擎开发者社区5 小时前
TRAE × 火山引擎 Supabase:为你的 AI 应用装上“数据引擎”
人工智能
小a彤6 小时前
GE 在 CANN 五层架构中的位置
人工智能·深度学习·transformer
前端若水6 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Upsy-Daisy6 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
企学宝6 小时前
企学宝5月专题课程丨《OpenClaw AI 智能体实战营:从零基础部署到全场景自动化落地》
人工智能·ai·企业培训