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;
	}
相关推荐
新新学长搞科研2 小时前
【最新】2026年能源方向学术会议征稿/交流资讯
人工智能·功能测试·计算机视觉·自动化·能源·新能源·材料工程
Hua-Jay2 小时前
OpenCV联合C++/Qt 学习笔记(十五)----形态学操作及应用
c++·笔记·qt·opencv·学习·计算机视觉
Coovally AI模型快速验证2 小时前
多校联合提出LLM-as-Judge:大模型评判无人机电力线分割,无真值场景下守护安全
人工智能·计算机视觉·电力巡检
Hua-Jay3 小时前
OpenCV联合C++/Qt 学习笔记(十六)----图像细化、轮廓检测、轮廓信息统计及轮廓外接多边形
c++·笔记·qt·opencv·学习·计算机视觉
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章69-圆弧测量
图像处理·人工智能·opencv·算法·计算机视觉
人工智能培训3 小时前
集中式与分布式智能:单个复杂智能体 vs. 多个简单智能体协同
大数据·人工智能·机器学习·计算机视觉·知识图谱
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章70-轮廓点距
图像处理·人工智能·opencv·算法·计算机视觉
ZPC82104 小时前
Linux / Ubuntu 隔离 CPU 核心 + ROS2 线程绑定
人工智能·算法·计算机视觉
kay_54515 小时前
YOLO26改进| 特征融合 | 小波变换的多尺度特征融合
人工智能·目标检测·计算机视觉·目标跟踪·论文·yolo26·yolo26改进