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,结果

相关推荐
机器之心8 小时前
飞书让表格变成「AI同事」加入群聊,不打开表就能用表
人工智能·openai
Bigfish_coding8 小时前
前端转agent-【python】-15 AI Agent 可观测性入门:LangFuse 链路追踪、Token 监控与 LLM 质量评估
人工智能
我唔知啊8 小时前
我把 Claude Code 拆成了一间餐厅:从一句话到一次回复,中间到底发生了什么
人工智能
Harry技术8 小时前
02 · Codex 核心概念:代理、沙箱、审批和项目说明书
人工智能
阿里云大数据AI技术9 小时前
Agentic Memory Extension 支持对接主流Agent - 适用于 Claude Code、CodeX等
人工智能·agent
我唔知啊9 小时前
不是让 AI 写代码,我是在指挥 AI 干活:一套打磨出来的 AI 编程工作流
人工智能
ZzT9 小时前
在 GitHub 上 @一下 claude,它自己把 issue 改成 PR
人工智能·开源
不加辣椒10 小时前
第15章 上下文窗口管理与长文本策略
人工智能
牛奶10 小时前
AI 能赚钱了——但赚的不是你
人工智能·ai编程·nvidia
凌杰11 小时前
AI 学习笔记:研究方法的演变
人工智能