c++ opencv 复现 halcon算子 derivate_gauss

终于搞懂了halcon的derivate_gauss 里面的卷积核的生成逻辑了
测试 halcon算子 derivate_gauss 高斯一阶导数卷积

之前的逻辑使用的是生成高斯导数核(标准公式)

换成生成高斯导数核 (area‑integrated) 两者的结果就完全相等了

cpp 复制代码
// 高斯函数 G(x)
inline double gaussian(double x, double sigma) {
	const double sqrt2pi = std::sqrt(2.0 * CV_PI);
	return std::exp(-0.5 * x * x / (sigma * sigma)) / (sigma * sqrt2pi);
}
// 高斯累积分布函数 Φ(x) = 0.5*(1 + erf(x/(σ√2)))
inline double gaussianCDF(double x, double sigma) {
	return 0.5 * (1.0 + std::erf(x / (sigma * std::sqrt(2.0))));
}
// 生成高斯导数核 (area‑integrated)
// (order: 0 -> 平滑, 1 -> 一阶导, 2 -> 二阶导)
cv::Mat getDerivGaussianKernel(int ksize, double sigma, int order) {
	CV_Assert(ksize % 2 == 1 && ksize > 0);
		cv::Mat kernel(ksize, 1, CV_32F);
		float* k = kernel.ptr<float>(0);
		int center = (ksize - 1) / 2;

		for (int i = 0; i < ksize; ++i) {
			double x = i - center;          // 像素中心坐标
			double left = x - 0.5;          // 像素左边界
			double right = x + 0.5;         // 像素右边界

			double val = 0.0;
			switch (order) {
			case 0: // 平滑:∫ G(x) dx
				val = gaussianCDF(right, sigma) - gaussianCDF(left, sigma);
				break;
			case 1: // 一阶导:∫ dG/dx dx = G(right) - G(left)
				val = gaussian(right, sigma) - gaussian(left, sigma);
				break;
			case 2: // 二阶导:∫ d²G/dx² dx = dG/dx(right) - dG/dx(left)
				// dG/dx = -x/σ² * G(x)
			{
				double dG_left = -left / (sigma * sigma) * gaussian(left, sigma);
				double dG_right = -right / (sigma * sigma) * gaussian(right, sigma);
				val = dG_right - dG_left;
			}
			break;
			default:
				CV_Error(cv::Error::StsBadArg, "order must be 0,1,2");
			}
			k[i] = static_cast<float>(val);
		}
		return kernel;
	}
// 生成高斯导数核(标准公式)
// (order: 0->平滑, 1->一阶导, 2->二阶导)
Mat getDerivGaussianKernel_(int ksize, double sigma, int order) {
	CV_Assert(ksize % 2 == 1);
		Mat kernel(ksize, 1, CV_32F);
		float* k = kernel.ptr<float>(0);
		int center = (ksize - 1) / 2;
		double sigma2 = sigma * sigma;
		double sigma4 = sigma2 * sigma2;

		// 先计算标准高斯核 (order=0)
		for (int i = 0; i < ksize; i++) {
			double x = i - center;
			double g = exp(-x * x / (2.0 * sigma2)) / (sqrt(2.0 * CV_PI) * sigma);
			if (order == 0) {
				k[i] = (float)g;
			}
			else if (order == 1) {
				// 一阶导数核: -x / σ² * G
				k[i] = (float)(-x / sigma2 * g);
			}
			else if (order == 2) {
				// 二阶导数核: (x²/σ⁴ - 1/σ²) * G
				k[i] = (float)((x * x / sigma4 - 1.0 / sigma2) * g);
			}
		}
		return kernel;
	}
相关推荐
春日见4 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
yubo05095 小时前
计算机视觉第三课:在图像上画框、画文字、画圆点
opencv·计算机视觉·目标跟踪
yubo050911 小时前
计算机视觉第五课:给每个物体画 bounding box
人工智能·opencv·计算机视觉
AI人工智能+11 小时前
赋能智慧监管:基于深度学习的特种行业许可证全要素精准识别系统
计算机视觉·自然语言处理·ocr·特种行业许可证识别
AGV算法笔记12 小时前
OpenCV 二维码三维定位 普通摄像头也能测空间坐标
人工智能·数码相机·opencv·工业视觉· 机器人视觉
weixin_4684668513 小时前
机器学习与深度学习新手区分指南
人工智能·python·深度学习·机器学习·计算机视觉·ai·机器视觉
yubo050913 小时前
计算机视觉第四课:寻找轮廓(自动框出所有物体)
人工智能·opencv·计算机视觉
fie888913 小时前
近红外与可见光图像融合的ICA变换:原理、实现与应用
图像处理·人工智能·计算机视觉
sali-tec14 小时前
C# 基于OpenCv的视觉工作流-章79-单位转换
图像处理·人工智能·opencv·算法·计算机视觉
彭祥.14 小时前
无人考评利用旋转目标检测识别验电器
人工智能·目标检测·计算机视觉