opencv的NORM_MINMAX参数

NORM_MINMAX参数在OpenCV的normalize函数中用于调整图像的灰度范围。该参数使得输出图像的像素值根据原图计算得出,确保最大值和最小值分别对应指定的最大和最小值。计算公式简单,通过该参数可以实现图像的标准化处理。实际应用中,此参数常被使用来规范化图像数据。给出的normalize函数计算结果与手动根据公式计算的结果一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

cv::NormTypes::NORM_MINMAX

这个参数在normalize函数里面用到。

void cv::normalize(InputArray src,
  InputOutputArray dst,
  double alpha = 1,
  double beta = 0,
  int norm_type = NORM_L2,
  int dtype = -1,
  InputArray mask = noArray() 
 )

通常情况下用到这个参数比较多。

那这个参数是要怎么样根据原图计算输出图像的呢?

下面是计算的公式,蛮简单的。

dst(i,j)=\left ( \frac{beta-alpha}{max(src)-min(src)} \right )*(src(i,j)-min(src))

 

	Mat dst1;
	float beta = 10.0f;
	float alpha = 0.0f;
	Mat img = (Mat_<float>(3, 3) << 1.2, 3.4, 5.6,
									7.8, 9.1, 2.3,
									4.5, 6.7, 8.9);
	normalize(img, dst1, alpha, beta, NORM_MINMAX);
	Mat dst2 = Mat::zeros(img.size(), img.type());
	double minval, maxval;
	minMaxLoc(img, &minval, &maxval);
	for (int row = 0; row < img.rows; row++)
	{
		for (int col = 0; col < img.cols; col++)
		{
            //公式实现
			dst2.at<float>(row, col) = ((beta - alpha) / (float(maxval) - float(minval))) * (img.at<float>(row, col) - float(minval));
		}
	}

以下是上面的两种方式的计算结果:

normalize函数的计算结果dst1:

0 2.78481 5.56962 8.35443 10 1.3924 4.17721 6.96202 9.74683

根据公式的计算结果dst2:
0 2.78481 5.56962 8.35443 10 1.3924 4.17721 6.96202 9.74683

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值