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

相关推荐
数据与后端架构提升之路21 小时前
小鹏VLA 2.0的“神秘涌现”:从痛苦到突破,自动驾驶与机器人如何突然“开窍”?
人工智能·机器人·自动驾驶
fruge21 小时前
CANN核心特性深度解析:简化AI开发的技术优势
人工智能
沛沛老爹21 小时前
AI入门知识之RAFT方法:基于微调的RAG优化技术详解
人工智能·llm·sft·raft·rag
zskj_zhyl21 小时前
科技助老与智慧养老的国家级政策与地方实践探索
大数据·人工智能·科技
YangYang9YangYan21 小时前
职业本科发展路径与规划指南
大数据·人工智能·学习·数据分析
牛客企业服务1 天前
2025年AI面试防作弊指南:技术笔试如何识别异常行为
人工智能·面试·职场和发展
shayudiandian1 天前
CNN详解:卷积神经网络是如何识别图像的?
人工智能·深度学习·cnn
V_156560272191 天前
2025年蚌埠市“三首产品”、市级服务型制造示范、市级企业技术中心等5个项目认定申报指南大全
大数据·人工智能·制造
盘古信息IMS1 天前
AI算力时代,PCB制造如何借助盘古信息MOM构建数字化新范式?
人工智能·制造
集成显卡1 天前
AI取名大师 | uni-app + Wot UI 跟随设备自动切换明暗主题
人工智能·ui·uni-app·外观配色