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

相关推荐
VB.Net2 分钟前
EmguCV学习笔记 C# 12.3 OCR
opencv·计算机视觉·c#·ocr·vb.net·emgucv
AI完全体4 分钟前
【AI战略思考1】如何更高效地了解AI行业的最新动态和商业应用以及我的时间分配
人工智能·机器学习·ai·商业应用·ai行业动态·技术趋势·信息渠道
#include<菜鸡>16 分钟前
动手学深度学习(pytorch土堆)-06损失函数与反向传播、模型训练、GPU训练
人工智能·pytorch·深度学习
o(╯□╰)o亚比囧囧囧2 小时前
李沐 过拟合和欠拟合【动手学深度学习v2】
人工智能·深度学习
钡铼技术2 小时前
通过MCGS在ARMxy边缘计算网关上实现物流自动化
人工智能·自动化·边缘计算·钡铼技术·armxy边缘计算网关
OpenTiny社区3 小时前
茶思屋直播|TinyEngine+AI:聚焦主航道,在实践中探索低代码技术黑土地
人工智能·低代码
chenkangck503 小时前
AI大模型之旅--milvus向量库安装
人工智能·aigc·milvus
学习前端的小z4 小时前
【AI视频】Runway:Gen-2 图文生视频与运动模式详解
人工智能·aigc·音视频
SpikeKing5 小时前
LLM - 理解 多模态大语言模型(MLLM) 的 指令微调(Instruction-Tuning) 与相关技术 (四)
人工智能·语言模型·指令微调·数据调整·自指令·数据混合·instruction
开MINI的工科男5 小时前
【笔记】自动驾驶预测与决策规划_Part3_路径与轨迹规划
人工智能·笔记·自动驾驶·预测与决策