成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)

OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)

熱門標(biāo)簽:聊城語(yǔ)音外呼系統(tǒng) 海外網(wǎng)吧地圖標(biāo)注注冊(cè) 南陽(yáng)打電話機(jī)器人 地圖標(biāo)注自己和別人標(biāo)注區(qū)別 孝感營(yíng)銷電話機(jī)器人效果怎么樣 打電話機(jī)器人營(yíng)銷 ai電銷機(jī)器人的優(yōu)勢(shì) 騰訊地圖標(biāo)注沒(méi)法顯示 商家地圖標(biāo)注海報(bào)

最新版OpenCV2.4.7中,cv::resize函數(shù)有五種插值算法:最近鄰、雙線性、雙三次、基于像素區(qū)域關(guān)系、蘭索斯插值。下面用for循環(huán)代替cv::resize函數(shù)來(lái)說(shuō)明其詳細(xì)的插值實(shí)現(xiàn)過(guò)程,其中部分代碼摘自于cv::resize函數(shù)中的源代碼。

每種插值算法的前部分代碼是相同的,如下:

	cv::Mat matSrc, matDst1, matDst2;
 
	matSrc = cv::imread("lena.jpg", 2 | 4);
	matDst1 = cv::Mat(cv::Size(800, 1000), matSrc.type(), cv::Scalar::all(0));
	matDst2 = cv::Mat(matDst1.size(), matSrc.type(), cv::Scalar::all(0));
 
	double scale_x = (double)matSrc.cols / matDst1.cols;
	double scale_y = (double)matSrc.rows / matDst1.rows;

1、最近鄰:公式,

	for (int i = 0; i  matDst1.cols; ++i)
	{
		int sx = cvFloor(i * scale_x);
		sx = std::min(sx, matSrc.cols - 1);
		for (int j = 0; j  matDst1.rows; ++j)
		{
			int sy = cvFloor(j * scale_y);
			sy = std::min(sy, matSrc.rows - 1);
			matDst1.atcv::Vec3b>(j, i) = matSrc.atcv::Vec3b>(sy, sx);
		}
	}
	cv::imwrite("nearest_1.jpg", matDst1);
 
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 0);
	cv::imwrite("nearest_2.jpg", matDst2);

2、雙線性:由相鄰的四像素(2*2)計(jì)算得出,公式,

	uchar* dataDst = matDst1.data;
	int stepDst = matDst1.step;
	uchar* dataSrc = matSrc.data;
	int stepSrc = matSrc.step;
	int iWidthSrc = matSrc.cols;
	int iHiehgtSrc = matSrc.rows;
 
	for (int j = 0; j  matDst1.rows; ++j)
	{
		float fy = (float)((j + 0.5) * scale_y - 0.5);
		int sy = cvFloor(fy);
		fy -= sy;
		sy = std::min(sy, iHiehgtSrc - 2);
		sy = std::max(0, sy);
 
		short cbufy[2];
		cbufy[0] = cv::saturate_castshort>((1.f - fy) * 2048);
		cbufy[1] = 2048 - cbufy[0];
 
		for (int i = 0; i  matDst1.cols; ++i)
		{
			float fx = (float)((i + 0.5) * scale_x - 0.5);
			int sx = cvFloor(fx);
			fx -= sx;
 
			if (sx  0) {
				fx = 0, sx = 0;
			}
			if (sx >= iWidthSrc - 1) {
				fx = 0, sx = iWidthSrc - 2;
			}
 
			short cbufx[2];
			cbufx[0] = cv::saturate_castshort>((1.f - fx) * 2048);
			cbufx[1] = 2048 - cbufx[0];
 
			for (int k = 0; k  matSrc.channels(); ++k)
			{
				*(dataDst+ j*stepDst + 3*i + k) = (*(dataSrc + sy*stepSrc + 3*sx + k) * cbufx[0] * cbufy[0] + 
					*(dataSrc + (sy+1)*stepSrc + 3*sx + k) * cbufx[0] * cbufy[1] + 
					*(dataSrc + sy*stepSrc + 3*(sx+1) + k) * cbufx[1] * cbufy[0] + 
					*(dataSrc + (sy+1)*stepSrc + 3*(sx+1) + k) * cbufx[1] * cbufy[1]) >> 22;
			}
		}
	}
	cv::imwrite("linear_1.jpg", matDst1);
 
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 1);
	cv::imwrite("linear_2.jpg", matDst2);

3、雙三次:由相鄰的4*4像素計(jì)算得出,公式類似于雙線性

	int iscale_x = cv::saturate_castint>(scale_x);
	int iscale_y = cv::saturate_castint>(scale_y);
 
	for (int j = 0; j  matDst1.rows; ++j)
	{
		float fy = (float)((j + 0.5) * scale_y - 0.5);
		int sy = cvFloor(fy);
		fy -= sy;
		sy = std::min(sy, matSrc.rows - 3);
		sy = std::max(1, sy);
 
		const float A = -0.75f;
 
		float coeffsY[4];
		coeffsY[0] = ((A*(fy + 1) - 5*A)*(fy + 1) + 8*A)*(fy + 1) - 4*A;
		coeffsY[1] = ((A + 2)*fy - (A + 3))*fy*fy + 1;
		coeffsY[2] = ((A + 2)*(1 - fy) - (A + 3))*(1 - fy)*(1 - fy) + 1;
		coeffsY[3] = 1.f - coeffsY[0] - coeffsY[1] - coeffsY[2];
 
		short cbufY[4];
		cbufY[0] = cv::saturate_castshort>(coeffsY[0] * 2048);
		cbufY[1] = cv::saturate_castshort>(coeffsY[1] * 2048);
		cbufY[2] = cv::saturate_castshort>(coeffsY[2] * 2048);
		cbufY[3] = cv::saturate_castshort>(coeffsY[3] * 2048);
 
		for (int i = 0; i  matDst1.cols; ++i)
		{
			float fx = (float)((i + 0.5) * scale_x - 0.5);
			int sx = cvFloor(fx);
			fx -= sx;
 
			if (sx  1) {
				fx = 0, sx = 1;
			}
			if (sx >= matSrc.cols - 3) {
				fx = 0, sx = matSrc.cols - 3;
			}
 
			float coeffsX[4];
			coeffsX[0] = ((A*(fx + 1) - 5*A)*(fx + 1) + 8*A)*(fx + 1) - 4*A;
			coeffsX[1] = ((A + 2)*fx - (A + 3))*fx*fx + 1;
			coeffsX[2] = ((A + 2)*(1 - fx) - (A + 3))*(1 - fx)*(1 - fx) + 1;
			coeffsX[3] = 1.f - coeffsX[0] - coeffsX[1] - coeffsX[2];
 
			short cbufX[4];
			cbufX[0] = cv::saturate_castshort>(coeffsX[0] * 2048);
			cbufX[1] = cv::saturate_castshort>(coeffsX[1] * 2048);
			cbufX[2] = cv::saturate_castshort>(coeffsX[2] * 2048);
			cbufX[3] = cv::saturate_castshort>(coeffsX[3] * 2048);
 
			for (int k = 0; k  matSrc.channels(); ++k)
			{
				matDst1.atcv::Vec3b>(j, i)[k] = abs((matSrc.atcv::Vec3b>(sy-1, sx-1)[k] * cbufX[0] * cbufY[0] + matSrc.atcv::Vec3b>(sy, sx-1)[k] * cbufX[0] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy+1, sx-1)[k] * cbufX[0] * cbufY[2] + matSrc.atcv::Vec3b>(sy+2, sx-1)[k] * cbufX[0] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy-1, sx)[k] * cbufX[1] * cbufY[0] + matSrc.atcv::Vec3b>(sy, sx)[k] * cbufX[1] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy+1, sx)[k] * cbufX[1] * cbufY[2] + matSrc.atcv::Vec3b>(sy+2, sx)[k] * cbufX[1] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy-1, sx+1)[k] * cbufX[2] * cbufY[0] + matSrc.atcv::Vec3b>(sy, sx+1)[k] * cbufX[2] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy+1, sx+1)[k] * cbufX[2] * cbufY[2] + matSrc.atcv::Vec3b>(sy+2, sx+1)[k] * cbufX[2] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy-1, sx+2)[k] * cbufX[3] * cbufY[0] + matSrc.atcv::Vec3b>(sy, sx+2)[k] * cbufX[3] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy+1, sx+2)[k] * cbufX[3] * cbufY[2] + matSrc.atcv::Vec3b>(sy+2, sx+2)[k] * cbufX[3] * cbufY[3] ) >> 22);
			}
		}
	}
	cv::imwrite("cubic_1.jpg", matDst1);
 
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 2);
	cv::imwrite("cubic_2.jpg", matDst2);

4、基于像素區(qū)域關(guān)系:共分三種情況,圖像放大時(shí)類似于雙線性插值,圖像縮小(x軸、y軸同時(shí)縮小)又分兩種情況,此情況下可以避免波紋出現(xiàn)。

#ifdef _MSC_VER
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 3);
	cv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_2.jpg", matDst2);
#else
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 3);
	cv::imwrite("area_2.jpg", matDst2);
#endif
 
	fprintf(stdout, "==== start area ====\n");
	double inv_scale_x = 1. / scale_x;
	double inv_scale_y = 1. / scale_y;
	int iscale_x = cv::saturate_castint>(scale_x);
	int iscale_y = cv::saturate_castint>(scale_y);
	bool is_area_fast = std::abs(scale_x - iscale_x)  DBL_EPSILON  std::abs(scale_y - iscale_y)  DBL_EPSILON;
 
	if (scale_x >= 1  scale_y >= 1)  { // zoom out
		if (is_area_fast)  { // integer multiples
			for (int j = 0; j  matDst1.rows; ++j) {
				int sy = std::min(cvFloor(j * scale_y), matSrc.rows - 1);
 
				for (int i = 0; i  matDst1.cols; ++i) {
					int sx = std::min(cvFloor(i * scale_x), matSrc.cols -1);
 
					matDst1.atcv::Vec3b>(j, i) = matSrc.atcv::Vec3b>(sy, sx);
				}
			}
#ifdef _MSC_VER
			cv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);
#else
			cv::imwrite("area_1.jpg", matDst1);
#endif
			return 0;
		}
 
		for (int j = 0; j  matDst1.rows; ++j) {
			double fsy1 = j * scale_y;
			double fsy2 = fsy1 + scale_y;
			double cellHeight = cv::min(scale_y, matSrc.rows - fsy1);
 
			int sy1 = cvCeil(fsy1), sy2 = cvFloor(fsy2);
 
			sy2 = std::min(sy2, matSrc.rows - 2);
			sy1 = std::min(sy1, sy2);
 
			float cbufy[2];
			cbufy[0] = (float)((sy1 - fsy1) / cellHeight);
			cbufy[1] = (float)(std::min(std::min(fsy2 - sy2, 1.), cellHeight) / cellHeight);
 
			for (int i = 0; i  matDst1.cols; ++i) {
				double fsx1 = i * scale_x;
				double fsx2 = fsx1 + scale_x;
				double cellWidth = std::min(scale_x, matSrc.cols - fsx1);
 
				int sx1 = cvCeil(fsx1), sx2 = cvFloor(fsx2);
 
				sx2 = std::min(sx2, matSrc.cols - 2);
				sx1 = std::min(sx1, sx2);
 
				float cbufx[2];
				cbufx[0] = (float)((sx1 - fsx1) / cellWidth);
				cbufx[1] = (float)(std::min(std::min(fsx2 - sx2, 1.), cellWidth) / cellWidth);
 
				for (int k = 0; k  matSrc.channels(); ++k) {
					matDst1.atcv::Vec3b>(j, i)[k] = (uchar)(matSrc.atcv::Vec3b>(sy1, sx1)[k] * cbufx[0] * cbufy[0] +
						matSrc.atcv::Vec3b>(sy1 + 1, sx1)[k] * cbufx[0] * cbufy[1] +
						matSrc.atcv::Vec3b>(sy1, sx1 + 1)[k] * cbufx[1] * cbufy[0] +
						matSrc.atcv::Vec3b>(sy1 + 1, sx1 + 1)[k] * cbufx[1] * cbufy[1]);
				}
			}
		}
#ifdef _MSC_VER
		cv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);
#else
		cv::imwrite("area_1.jpg", matDst1);
#endif
 
		return 0;
	}
 
	//zoom in,it is emulated using some variant of bilinear interpolation
	for (int j = 0; j  matDst1.rows; ++j) {
		int  sy = cvFloor(j * scale_y);
		float fy = (float)((j + 1) - (sy + 1) * inv_scale_y);
		fy = fy = 0 ? 0.f : fy - cvFloor(fy);
		sy = std::min(sy, matSrc.rows - 2);
 
		short cbufy[2];
		cbufy[0] = cv::saturate_castshort>((1.f - fy) * 2048);
		cbufy[1] = 2048 - cbufy[0];
 
		for (int i = 0; i  matDst1.cols; ++i) {
			int sx = cvFloor(i * scale_x);
			float fx = (float)((i + 1) - (sx + 1) * inv_scale_x);
			fx = fx  0 ? 0.f : fx - cvFloor(fx);
 
			if (sx  0) {
				fx = 0, sx = 0;
			}
 
			if (sx >= matSrc.cols - 1) {
				fx = 0, sx = matSrc.cols - 2;
			}
 
			short cbufx[2];
			cbufx[0] = cv::saturate_castshort>((1.f - fx) * 2048);
			cbufx[1] = 2048 - cbufx[0];
 
			for (int k = 0; k  matSrc.channels(); ++k) {
				matDst1.atcv::Vec3b>(j, i)[k] = (matSrc.atcv::Vec3b>(sy, sx)[k] * cbufx[0] * cbufy[0] +
					matSrc.atcv::Vec3b>(sy + 1, sx)[k] * cbufx[0] * cbufy[1] +
					matSrc.atcv::Vec3b>(sy, sx + 1)[k] * cbufx[1] * cbufy[0] +
					matSrc.atcv::Vec3b>(sy + 1, sx + 1)[k] * cbufx[1] * cbufy[1]) >> 22;
			}
		}
	}
	fprintf(stdout, "==== end area ====\n");
 
#ifdef _MSC_VER
	cv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);
#else
	cv::imwrite("area_1.jpg", matDst1);
#endif

注:以上基于area進(jìn)行圖像縮小的代碼有問(wèn)題,具體實(shí)現(xiàn)代碼可以參考https://github.com/fengbingchun/OpenCV_Test/blob/master/src/fbc_cv/include/resize.hpp,用法如下:

fbc::Mat3BGR src(matSrc.rows, matSrc.cols, matSrc.data);
fbc::Mat3BGR dst(matDst1.rows, matDst1.cols, matDst1.data);
fbc::resize(src, dst, 3);

5、蘭索斯插值:由相鄰的8*8像素計(jì)算得出,公式類似于雙線性

	int iscale_x = cv::saturate_castint>(scale_x);
	int iscale_y = cv::saturate_castint>(scale_y);
 
	for (int j = 0; j  matDst1.rows; ++j)
	{
		float fy = (float)((j + 0.5) * scale_y - 0.5);
		int sy = cvFloor(fy);
		fy -= sy;
		sy = std::min(sy, matSrc.rows - 5);
		sy = std::max(3, sy);
 
		const double s45 = 0.70710678118654752440084436210485;
		const double cs[][2] = {{1, 0}, {-s45, -s45}, {0, 1}, {s45, -s45}, {-1, 0}, {s45, s45}, {0, -1}, {-s45, s45}};
		float coeffsY[8];
 
		if (fy  FLT_EPSILON) {
			for (int t = 0; t  8; t++)
				coeffsY[t] = 0;
			coeffsY[3] = 1;
		} else {
			float sum = 0;
			double y0 = -(fy + 3) * CV_PI * 0.25, s0 = sin(y0), c0 = cos(y0);
 
			for (int t = 0; t  8; ++t)
			{
				double dy = -(fy + 3 -t) * CV_PI * 0.25;
				coeffsY[t] = (float)((cs[t][0] * s0 + cs[t][1] * c0) / (dy * dy));
				sum += coeffsY[t];
			}
 
			sum = 1.f / sum;
			for (int t = 0; t  8; ++t)
				coeffsY[t] *= sum;
		}
 
		short cbufY[8];
		cbufY[0] = cv::saturate_castshort>(coeffsY[0] * 2048);
		cbufY[1] = cv::saturate_castshort>(coeffsY[1] * 2048);
		cbufY[2] = cv::saturate_castshort>(coeffsY[2] * 2048);
		cbufY[3] = cv::saturate_castshort>(coeffsY[3] * 2048);
		cbufY[4] = cv::saturate_castshort>(coeffsY[4] * 2048);
		cbufY[5] = cv::saturate_castshort>(coeffsY[5] * 2048);
		cbufY[6] = cv::saturate_castshort>(coeffsY[6] * 2048);
		cbufY[7] = cv::saturate_castshort>(coeffsY[7] * 2048);
 
		for (int i = 0; i  matDst1.cols; ++i)
		{
			float fx = (float)((i + 0.5) * scale_x - 0.5);
			int sx = cvFloor(fx);
			fx -= sx;
 
			if (sx  3) {
				fx = 0, sx = 3;
			}
			if (sx >= matSrc.cols - 5) {
				fx = 0, sx = matSrc.cols - 5;
			}
 
			float coeffsX[8];
 
			if (fx  FLT_EPSILON) {
				for ( int t = 0; t  8; t++ )
					coeffsX[t] = 0;
				coeffsX[3] = 1;
			} else {
				float sum = 0;
				double x0 = -(fx + 3) * CV_PI * 0.25, s0 = sin(x0), c0 = cos(x0);
 
				for (int t = 0; t  8; ++t)
				{
					double dx = -(fx + 3 -t) * CV_PI * 0.25;
					coeffsX[t] = (float)((cs[t][0] * s0 + cs[t][1] * c0) / (dx * dx));
					sum += coeffsX[t];
				}
 
				sum = 1.f / sum;
				for (int t = 0; t  8; ++t)
					coeffsX[t] *= sum;
			}
 
			short cbufX[8];
			cbufX[0] = cv::saturate_castshort>(coeffsX[0] * 2048);
			cbufX[1] = cv::saturate_castshort>(coeffsX[1] * 2048);
			cbufX[2] = cv::saturate_castshort>(coeffsX[2] * 2048);
			cbufX[3] = cv::saturate_castshort>(coeffsX[3] * 2048);
			cbufX[4] = cv::saturate_castshort>(coeffsX[4] * 2048);
			cbufX[5] = cv::saturate_castshort>(coeffsX[5] * 2048);
			cbufX[6] = cv::saturate_castshort>(coeffsX[6] * 2048);
			cbufX[7] = cv::saturate_castshort>(coeffsX[7] * 2048);
 
			for (int k = 0; k  matSrc.channels(); ++k)
			{
				matDst1.atcv::Vec3b>(j, i)[k] = abs((matSrc.atcv::Vec3b>(sy-3, sx-3)[k] * cbufX[0] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx-3)[k] * cbufX[0] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx-3)[k] * cbufX[0] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx-3)[k] * cbufX[0] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx-3)[k] * cbufX[0] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx-3)[k] * cbufX[0] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx-3)[k] * cbufX[0] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx-3)[k] * cbufX[0] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx-2)[k] * cbufX[1] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx-2)[k] * cbufX[1] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx-2)[k] * cbufX[1] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx-2)[k] * cbufX[1] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx-2)[k] * cbufX[1] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx-2)[k] * cbufX[1] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx-2)[k] * cbufX[1] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx-2)[k] * cbufX[1] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx-1)[k] * cbufX[2] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx-1)[k] * cbufX[2] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx-1)[k] * cbufX[2] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx-1)[k] * cbufX[2] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx-1)[k] * cbufX[2] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx-1)[k] * cbufX[2] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx-1)[k] * cbufX[2] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx-1)[k] * cbufX[2] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx)[k] * cbufX[3] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx)[k] * cbufX[3] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx)[k] * cbufX[3] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx)[k] * cbufX[3] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx)[k] * cbufX[3] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx)[k] * cbufX[3] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx)[k] * cbufX[3] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx)[k] * cbufX[3] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx+1)[k] * cbufX[4] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx+1)[k] * cbufX[4] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx+1)[k] * cbufX[4] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx+1)[k] * cbufX[4] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx+1)[k] * cbufX[4] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx+1)[k] * cbufX[4] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx+1)[k] * cbufX[4] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx+1)[k] * cbufX[4] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx+2)[k] * cbufX[5] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx+2)[k] * cbufX[5] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx+2)[k] * cbufX[5] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx+2)[k] * cbufX[5] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx+2)[k] * cbufX[5] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx+2)[k] * cbufX[5] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx+2)[k] * cbufX[5] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx+2)[k] * cbufX[5] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx+3)[k] * cbufX[6] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx+3)[k] * cbufX[6] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx+3)[k] * cbufX[6] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx+3)[k] * cbufX[6] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx+3)[k] * cbufX[6] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx+3)[k] * cbufX[6] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx+3)[k] * cbufX[6] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx+3)[k] * cbufX[6] * cbufY[7] +
 
					matSrc.atcv::Vec3b>(sy-3, sx+4)[k] * cbufX[7] * cbufY[0] + matSrc.atcv::Vec3b>(sy-2, sx+4)[k] * cbufX[7] * cbufY[1] +
					matSrc.atcv::Vec3b>(sy-1, sx+4)[k] * cbufX[7] * cbufY[2] + matSrc.atcv::Vec3b>(sy, sx+4)[k] * cbufX[7] * cbufY[3] +
					matSrc.atcv::Vec3b>(sy+1, sx+4)[k] * cbufX[7] * cbufY[4] + matSrc.atcv::Vec3b>(sy+2, sx+4)[k] * cbufX[7] * cbufY[5] +
					matSrc.atcv::Vec3b>(sy+3, sx+4)[k] * cbufX[7] * cbufY[6] + matSrc.atcv::Vec3b>(sy+4, sx+4)[k] * cbufX[7] * cbufY[7] ) >> 22);// 4194304
			}
		}
	}
	cv::imwrite("Lanczos_1.jpg", matDst1);
 
	cv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 4);
	cv::imwrite("Lanczos_2.jpg", matDst2);

以上代碼的實(shí)現(xiàn)結(jié)果與cv::resize函數(shù)相同,但是執(zhí)行效率非常低,只是為了詳細(xì)說(shuō)明插值過(guò)程。OpenCV中默認(rèn)采用C++ Concurrency進(jìn)行優(yōu)化加速,你也可以采用TBB、OpenMP等進(jìn)行優(yōu)化加速。

GitHub:https://github.com/fengbingchun/OpenCV_Test/blob/master/demo/OpenCV_Test/test_opencv_funset.cpp

到此這篇關(guān)于OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)的文章就介紹到這了,更多相關(guān)OpenCV resize插值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python使用opencv resize圖像不進(jìn)行插值的操作

標(biāo)簽:牡丹江 楊凌 南寧 撫州 揚(yáng)州 六盤水 迪慶 聊城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)》,本文關(guān)鍵詞  OpenCV,中,resize,函數(shù),插值,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于OpenCV中resize函數(shù)插值算法的實(shí)現(xiàn)過(guò)程(五種)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩精品中文字幕视频在线| 国产裸体永久免费无遮挡| 91精品国产91久久久久久最新| 亚洲先锋成人| 成人在线视频国产| 97人妻一区二区精品视频| 偷拍亚洲欧洲综合| 人妻熟女一二三区夜夜爱| 一区二区三区在线|网站| 在线视频国产日韩| 日本在线免费观看视频| 国产91色在线|免| 成人激情视频小说免费下载| 男人的天堂亚洲在线| 丝袜足控免费网站xx网站| 国产精品一区av| 国产成人一区二区三区免费看| 三级视频网站在线观看| 色天天综合久久久久综合片| 91精品国产高清一区二区三区蜜臀| 美女被黑人爆操网站| 国产伦理精品不卡| 永久免费未视频| 在线欧美日韩精品| 人与嘼交av免费| 午夜日本精品| 在线播放蜜桃麻豆| 好吊色一区二区| 国产精品成久久久久| 国产精品一区二区av交换| 精品国偷自产在线视频| 日韩乱码人妻无码中文字幕久久| 在线亚洲观看| 国产精品伦理久久久久久| 超碰91人人草人人干| 四虎永久免费在线观看| 欧美人与动xxxxz0oz| 欧美三级三级| av免费在线电影| 国产精品18在线| 免费黄色小视频在线观看| 在线观看国产91| 日韩资源在线| 成人激情午夜影院| 中文字幕一区二| 青青在线视频| 加勒比在线一区| 在线视频一区二区免费| 国产+成+人+亚洲欧洲在线| 日日日日影院| 久久久久香蕉视频| 欧美日韩亚洲一区二区三区在线观看| 久久精品99久久香蕉国产色戒| 伊人国产在线视频| 亚洲色成人一区二区三区小说| 极品白嫩丰满美女无套| 天堂俺去俺来也www久久婷婷| 色综合成人av| 亚洲色图国产精品| 清纯唯美日韩| 日韩激情视频在线| 亚洲欧美偷拍视频| 日韩一区和二区| av中文字幕在线播放| koreanbj精品视频一区| 精品久久久久久无码中文野结衣| 日本激情视频一区二区三区| 国产一卡二卡在线| 国产精品私拍pans大尺度在线| 国产三级在线观看视频| 日韩a在线播放| 久久久久久久久影视| 中文字幕第一页在线| 国产免费无遮挡吸奶头视频| 97在线观看视频| 韩国理伦片一区二区三区在线播放| 91九色在线免费视频| 国产字幕中文| 韩国三级中文字幕hd久久精品| 色欲久久久天天天综合网| 国产在线拍揄自揄拍| 日本二区视频| 国产十六处破外女视频| 欧美**vk| 国产呦精品一区二区三区网站| 色噜噜一区二区三区| 一级毛片免费高清中文字幕久久网| 国产一区二区在线观看视频| 日韩欧美亚洲一区| av在线www| 国产午夜精品久久久久久久| 国产乱码精品一区二区三区亚洲人| 国产精品二区二区三区| 国产一级二级在线观看| 日韩人体视频一二区| 99在线观看免费| 亚洲第一香蕉网| 日韩电影在线免费| 欧美日韩一级黄色片| 9797在线看片亚洲精品| 免费男女羞羞的视频网站中文字幕妖精视频| 国产一区免费观看| 美女撒尿一区二区三区| 日本三级韩国三级欧美三级| 国产精品99久久不卡二区| 亚洲精品久久久久久久久| www.日韩av| 国产欧美日韩第一页| 99在线热播| 国产日韩欧美高清| 最新天堂资源在线| 久久久久久久久免费视频| 欧美xxxx视频| 91精品国产综合久久国产大片| 国产原创欧美精品| 国产大屁股喷水视频在线观看| 亚洲乱码国产乱码精品精可以看| 综合激情成人伊人| 牛牛影视一区二区三区免费看| 成人影院在线视频| 国产国产精品人在线视| 国产欧美一区二区在线| 午夜激情在线| 青花影视在线观看免费高清| 三区四区电影在线观看| 亚洲成人精品综合在线| 国产精品99久久久久久成人| 欧美日本国产精品| 7777久久亚洲中文字幕| 免费国产在线精品一区二区三区| 激情乱色小说视频| 国产成人免费av一区二区午夜| 国产成人免费在线观看不卡| 无码av天堂一区二区三区| 国产精品777777在线播放| 最近中文字幕在线mv视频在线| 日韩欧美中文字幕一区二区三区| 久久久久久无码精品大片| 91久久精品一区二区别| 色欧美日韩亚洲| 亚洲欧美日韩精品| 自拍偷拍欧美一区| 国产亚洲在线播放| 蜜桃久久精品一区二区| 免费看av的网址| 亚洲欧美综合一区二区| 国产精品一在线观看| 国产欧美一级片| 另类视频一区二区三区| 亚洲网站在线| 亚洲丝袜一区| 91精品国产综合久久久蜜臀粉嫩| 美女一区二区三区视频| 国产精品原创巨作av| 欧美亚洲综合另类| 97超碰在线资源站| 97精品资源在线观看| 青青a在线精品免费观看| 国产毛片久久久久久| 欧美激情第一页在线观看| 天堂v视频永久在线播放| 国产精品久久网站| 亚洲午夜女主播在线直播| 午夜久久久久久久久| 免费福利视频一区| 成全电影大全在线观看| 亚洲欧美在线成人| 亚洲国产成人在线| 欧美丰满嫩嫩电影| 中文字幕中文字幕在线十八区| 四虎精品一区二区永久在线观看| 亚洲国产成人精品综合99| 免费成人深夜夜行p站| 亚洲深夜福利在线| 欧美69视频| 国产精品每日更新| 精精国产xxxx视频在线野外| 男人天堂av片| 久久7799| 在线丝袜欧美日韩制服| 精品国产伦一区二区三区观看体验| 88国产精品欧美一区二区三区| 国产视频一区二区在线观看| 国产精品无码永久免费不卡| 亚洲精品一区二区三区四区| 在线观看污污视频| 严阵以待中文社区| 日韩欧美视频免费在线观看| 香蕉97视频观看在线观看| 奇米影视一区二区三区小说| 国产高清一级片| 国产人妻互换一区二区| 国产午夜精品理论片a级探花| 2021av网| h在线观看网站| 欧美 日韩 国产一区| 九色中文视频| 日韩欧美成人网| 亚洲自拍偷拍九九九| 久久久免费看| 手机看片福利视频| 国产一区二区三区四区二区| 亚洲综合在线免费观看| 久久久噜噜噜www成人网| 九九精品在线| 非洲黑人最猛性xxxx交| 91精品国产91久久久久| 亚洲日本青草视频在线怡红院| 黄色成人av| 日本高清一二三区| 天堂va在线高清一区| 精品91一区二区三区| 亚洲va韩国va欧美va| 欧美高清在线| 999免费视频| 亚洲免费中文| 亚洲第一偷拍| 亚洲女同另类| 大桥未久恸哭の女教师| 日本v片在线免费观看| 亚洲精品福利电影| 国产成人免费精品| 国产精品的网站| 97超级碰碰人国产在线观看| 国产美女激情视频| 黄色免费在线网站| 手机看片久久| 欧美区视频在线观看| 欧美2区3区4区| 国产在线观看成人| 日韩和欧美的一区二区| 国产精彩精品视频| 在线观看日本一区二区| 91亚洲精品久久久蜜桃借种| 6699嫩草久久久精品影院| 成人在线视频中文字幕| 嫩草av久久伊人妇女超级a| 精品久久人人做人人爰| 日本在线精品视频| 欧美精品日韩| 国产a精品视频| 三级ai视频| 写真福利理论片在线播放| 一级片在线观看| 97久久伊人激情网| 天堂网.www在线资源| 黄色无遮挡网站| 日韩成人精品一区二区三区| 999国产精品亚洲77777| 精品一区二区三区在线成人| 自拍偷拍电影| 777午夜精品电影免费看| 香蕉视频911| 在线中文av| 一区二区三区欧美激情| 国产精品日韩久久久| 亚洲一区二区在线| 99在线精品观看| 综合久久2o19| 日本午夜在线视频| 欧美一区二粉嫩精品国产一线天| 日本亚洲欧美天堂免费| 一区二区在线影院| 亚洲最新合集| 久久国产免费观看| 成人在线免费视频观看| 日韩欧美一起| 国产精品久久久久久久久久精爆| 欧美一区国产一区| 天堂8在线视频| 激情五月开心婷婷| 久久精品观看| www黄色在线观看| 黄色av免费在线播放| 人妻熟妇乱又伦精品视频| 欧美一区二区三区粗大| 日韩高清第一页| 樱花草涩涩www在线播放| 欧美国产一区视频在线观看| 国产日韩亚洲欧美| 成人国产精品毛片| 国产精品7777777| 欧美成人午夜做爰视频在线观看| 蜜臀av一区二区| 亚洲自拍都市欧美小说| 日韩欧美自拍偷拍| 国产对白在线播放| 色乱码一区二区三区熟女| 欧美18 19xxx| 99视频国产精品| 色视频www在线播放| 秋霞电影网一区二区| 欧美最猛黑人xxxx黑人猛交黄| 国户精品久久久久久久久久久不卡| 国产一区二区三区免费播放| 久久综合国产精品台湾中文娱乐网| 国产精品久久久久久久久粉嫩av| 波多野结衣家庭教师| 日韩专区视频| 国产农村妇女毛片精品久久莱园子| 无码 制服 丝袜 国产 另类| 国产精品探花视频| 欧美高清一区| 久久久噜噜噜久久狠狠50岁| 欧美双性人妖o0| 尤物网站在线看| 亚洲深夜福利在线| 伊人精品一区| 91久久精品日日躁夜夜躁欧美| 日韩三级av| 最新版天堂资源中文官网| 波多野结衣中文字幕在线| 精品久久久久久久久久久国产字幕| 狠狠色噜噜狠狠狠8888米奇| 日本免费观看视| 无码国产精品一区二区高潮| 国产一区二区在线视频| 国产精彩视频一区二区| 人妻体内射精一区二区| 激情视频在线观看| 欧美性xxxxxbbbbbb精品| 黑人操亚洲女人| 成人看片人aa| 9久草视频在线视频精品| av超碰免费在线| 日本一级淫片免费放| 麻豆tv入口在线看| 一本久久综合亚洲鲁鲁五月天|