iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何在OpenCV中使用resize函数插值算法
  • 625
分享到

如何在OpenCV中使用resize函数插值算法

2023-06-15 09:06:13 625人浏览 安东尼
摘要

这篇文章给大家介绍如何在OpenCV中使用resize函数插值算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。最新版OpenCV2.4.7中,cv::resize函数有五种插值算法:最近邻、双线性、双三次、基于像素区

这篇文章给大家介绍如何在OpenCV中使用resize函数插值算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

最新版OpenCV2.4.7中,cv::resize函数有五种插值算法:最近邻、双线性、双三次、基于像素区域关系、兰索斯插值。下面用for循环代替cv::resize函数来说明其详细的插值实现过程,其中部分代码摘自于cv::resize函数中的源代码。

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

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;

最近邻:公式,

如何在OpenCV中使用resize函数插值算法

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.at<cv::Vec3b>(j, i) = matSrc.at<cv::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)计算得出,公式,

如何在OpenCV中使用resize函数插值算法

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_cast<short>((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_cast<short>((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);

双三次:由相邻的4*4像素计算得出,公式类似于双线性

int iscale_x = cv::saturate_cast<int>(scale_x);int iscale_y = cv::saturate_cast<int>(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_cast<short>(coeffsY[0] * 2048);cbufY[1] = cv::saturate_cast<short>(coeffsY[1] * 2048);cbufY[2] = cv::saturate_cast<short>(coeffsY[2] * 2048);cbufY[3] = cv::saturate_cast<short>(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_cast<short>(coeffsX[0] * 2048);cbufX[1] = cv::saturate_cast<short>(coeffsX[1] * 2048);cbufX[2] = cv::saturate_cast<short>(coeffsX[2] * 2048);cbufX[3] = cv::saturate_cast<short>(coeffsX[3] * 2048); for (int k = 0; k < matSrc.channels(); ++k){matDst1.at<cv::Vec3b>(j, i)[k] = abs((matSrc.at<cv::Vec3b>(sy-1, sx-1)[k] * cbufX[0] * cbufY[0] + matSrc.at<cv::Vec3b>(sy, sx-1)[k] * cbufX[0] * cbufY[1] +matSrc.at<cv::Vec3b>(sy+1, sx-1)[k] * cbufX[0] * cbufY[2] + matSrc.at<cv::Vec3b>(sy+2, sx-1)[k] * cbufX[0] * cbufY[3] +matSrc.at<cv::Vec3b>(sy-1, sx)[k] * cbufX[1] * cbufY[0] + matSrc.at<cv::Vec3b>(sy, sx)[k] * cbufX[1] * cbufY[1] +matSrc.at<cv::Vec3b>(sy+1, sx)[k] * cbufX[1] * cbufY[2] + matSrc.at<cv::Vec3b>(sy+2, sx)[k] * cbufX[1] * cbufY[3] +matSrc.at<cv::Vec3b>(sy-1, sx+1)[k] * cbufX[2] * cbufY[0] + matSrc.at<cv::Vec3b>(sy, sx+1)[k] * cbufX[2] * cbufY[1] +matSrc.at<cv::Vec3b>(sy+1, sx+1)[k] * cbufX[2] * cbufY[2] + matSrc.at<cv::Vec3b>(sy+2, sx+1)[k] * cbufX[2] * cbufY[3] +matSrc.at<cv::Vec3b>(sy-1, sx+2)[k] * cbufX[3] * cbufY[0] + matSrc.at<cv::Vec3b>(sy, sx+2)[k] * cbufX[3] * cbufY[1] +matSrc.at<cv::Vec3b>(sy+1, sx+2)[k] * cbufX[3] * cbufY[2] + matSrc.at<cv::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);

基于像素区域关系:共分三种情况,图像放大时类似于双线性插值,图像缩小(x轴、y轴同时缩小)又分两种情况,此情况下可以避免波纹出现。

#ifdef _MSC_VERcv::resize(matSrc, matDst2, matDst1.size(), 0, 0, 3);cv::imwrite("E:/gitCode/OpenCV_Test/test_images/area_2.jpg", matDst2);#elsecv::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_cast<int>(scale_x);int iscale_y = cv::saturate_cast<int>(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 outif (is_area_fast)  { // integer multiplesfor (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.at<cv::Vec3b>(j, i) = matSrc.at<cv::Vec3b>(sy, sx);}}#ifdef _MSC_VERcv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);#elsecv::imwrite("area_1.jpg", matDst1);#endifreturn 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.at<cv::Vec3b>(j, i)[k] = (uchar)(matSrc.at<cv::Vec3b>(sy1, sx1)[k] * cbufx[0] * cbufy[0] +matSrc.at<cv::Vec3b>(sy1 + 1, sx1)[k] * cbufx[0] * cbufy[1] +matSrc.at<cv::Vec3b>(sy1, sx1 + 1)[k] * cbufx[1] * cbufy[0] +matSrc.at<cv::Vec3b>(sy1 + 1, sx1 + 1)[k] * cbufx[1] * cbufy[1]);}}}#ifdef _MSC_VERcv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);#elsecv::imwrite("area_1.jpg", matDst1);#endif return 0;} //zoom in,it is emulated using some variant of bilinear interpolationfor (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_cast<short>((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_cast<short>((1.f - fx) * 2048);cbufx[1] = 2048 - cbufx[0]; for (int k = 0; k < matSrc.channels(); ++k) {matDst1.at<cv::Vec3b>(j, i)[k] = (matSrc.at<cv::Vec3b>(sy, sx)[k] * cbufx[0] * cbufy[0] +matSrc.at<cv::Vec3b>(sy + 1, sx)[k] * cbufx[0] * cbufy[1] +matSrc.at<cv::Vec3b>(sy, sx + 1)[k] * cbufx[1] * cbufy[0] +matSrc.at<cv::Vec3b>(sy + 1, sx + 1)[k] * cbufx[1] * cbufy[1]) >> 22;}}}fprintf(stdout, "==== end area ====\n"); #ifdef _MSC_VERcv::imwrite("E:/GitCode/OpenCV_Test/test_images/area_1.jpg", matDst1);#elsecv::imwrite("area_1.jpg", matDst1);#endif

注:以上基于area进行图像缩小的代码有问题,具体实现代码可以参考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);

兰索斯插值:由相邻的8*8像素计算得出,公式类似于双线性

int iscale_x = cv::saturate_cast<int>(scale_x);int iscale_y = cv::saturate_cast<int>(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_cast<short>(coeffsY[0] * 2048);cbufY[1] = cv::saturate_cast<short>(coeffsY[1] * 2048);cbufY[2] = cv::saturate_cast<short>(coeffsY[2] * 2048);cbufY[3] = cv::saturate_cast<short>(coeffsY[3] * 2048);cbufY[4] = cv::saturate_cast<short>(coeffsY[4] * 2048);cbufY[5] = cv::saturate_cast<short>(coeffsY[5] * 2048);cbufY[6] = cv::saturate_cast<short>(coeffsY[6] * 2048);cbufY[7] = cv::saturate_cast<short>(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_cast<short>(coeffsX[0] * 2048);cbufX[1] = cv::saturate_cast<short>(coeffsX[1] * 2048);cbufX[2] = cv::saturate_cast<short>(coeffsX[2] * 2048);cbufX[3] = cv::saturate_cast<short>(coeffsX[3] * 2048);cbufX[4] = cv::saturate_cast<short>(coeffsX[4] * 2048);cbufX[5] = cv::saturate_cast<short>(coeffsX[5] * 2048);cbufX[6] = cv::saturate_cast<short>(coeffsX[6] * 2048);cbufX[7] = cv::saturate_cast<short>(coeffsX[7] * 2048); for (int k = 0; k < matSrc.channels(); ++k){matDst1.at<cv::Vec3b>(j, i)[k] = abs((matSrc.at<cv::Vec3b>(sy-3, sx-3)[k] * cbufX[0] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx-3)[k] * cbufX[0] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx-3)[k] * cbufX[0] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx-3)[k] * cbufX[0] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx-3)[k] * cbufX[0] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx-3)[k] * cbufX[0] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx-3)[k] * cbufX[0] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx-3)[k] * cbufX[0] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx-2)[k] * cbufX[1] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx-2)[k] * cbufX[1] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx-2)[k] * cbufX[1] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx-2)[k] * cbufX[1] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx-2)[k] * cbufX[1] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx-2)[k] * cbufX[1] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx-2)[k] * cbufX[1] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx-2)[k] * cbufX[1] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx-1)[k] * cbufX[2] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx-1)[k] * cbufX[2] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx-1)[k] * cbufX[2] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx-1)[k] * cbufX[2] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx-1)[k] * cbufX[2] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx-1)[k] * cbufX[2] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx-1)[k] * cbufX[2] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx-1)[k] * cbufX[2] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx)[k] * cbufX[3] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx)[k] * cbufX[3] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx)[k] * cbufX[3] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx)[k] * cbufX[3] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx)[k] * cbufX[3] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx)[k] * cbufX[3] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx)[k] * cbufX[3] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx)[k] * cbufX[3] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx+1)[k] * cbufX[4] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx+1)[k] * cbufX[4] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx+1)[k] * cbufX[4] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx+1)[k] * cbufX[4] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx+1)[k] * cbufX[4] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx+1)[k] * cbufX[4] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx+1)[k] * cbufX[4] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx+1)[k] * cbufX[4] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx+2)[k] * cbufX[5] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx+2)[k] * cbufX[5] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx+2)[k] * cbufX[5] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx+2)[k] * cbufX[5] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx+2)[k] * cbufX[5] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx+2)[k] * cbufX[5] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx+2)[k] * cbufX[5] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx+2)[k] * cbufX[5] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx+3)[k] * cbufX[6] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx+3)[k] * cbufX[6] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx+3)[k] * cbufX[6] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx+3)[k] * cbufX[6] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx+3)[k] * cbufX[6] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx+3)[k] * cbufX[6] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx+3)[k] * cbufX[6] * cbufY[6] + matSrc.at<cv::Vec3b>(sy+4, sx+3)[k] * cbufX[6] * cbufY[7] + matSrc.at<cv::Vec3b>(sy-3, sx+4)[k] * cbufX[7] * cbufY[0] + matSrc.at<cv::Vec3b>(sy-2, sx+4)[k] * cbufX[7] * cbufY[1] +matSrc.at<cv::Vec3b>(sy-1, sx+4)[k] * cbufX[7] * cbufY[2] + matSrc.at<cv::Vec3b>(sy, sx+4)[k] * cbufX[7] * cbufY[3] +matSrc.at<cv::Vec3b>(sy+1, sx+4)[k] * cbufX[7] * cbufY[4] + matSrc.at<cv::Vec3b>(sy+2, sx+4)[k] * cbufX[7] * cbufY[5] +matSrc.at<cv::Vec3b>(sy+3, sx+4)[k] * cbufX[7] * cbufY[6] + matSrc.at<cv::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);

关于如何在OpenCV中使用resize函数插值算法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 如何在OpenCV中使用resize函数插值算法

本文链接: https://www.lsjlt.com/news/279273.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在OpenCV中使用resize函数插值算法
    这篇文章给大家介绍如何在OpenCV中使用resize函数插值算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。最新版OpenCV2.4.7中,cv::resize函数有五种插值算法:最近邻、双线性、双三次、基于像素区...
    99+
    2023-06-15
  • OpenCV中resize函数插值算法的实现过程(五种)
    最新版OpenCV2.4.7中,cv::resize函数有五种插值算法:最近邻、双线性、双三次、基于像素区域关系、兰索斯插值。下面用for循环代替cv::resize函数来说明其详细...
    99+
    2024-04-02
  • 如何在c#中使用opencv函数库
    这个demo用c#实现图片裁剪和半透明融合的功能演示程序。功能挺简单的,就是把一张固定大小的图片先做边缘羽化,然后贴到一个圆形泡泡形状的底图上,最后把结果半透明融合到一张背景图上。 ...
    99+
    2024-04-02
  • C++ OpenCV如何实现图像双三次插值算法
    本篇内容主要讲解“C++ OpenCV如何实现图像双三次插值算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++ OpenCV如何实现图像双三次插值算法”吧!一、图像双三...
    99+
    2023-06-21
  • 如何在编程算法中使用 JavaScript 函数?
    随着 JavaScript 的流行,越来越多的开发人员选择使用 JavaScript 来编写算法。本文将介绍如何在编程算法中使用 JavaScript 函数。 一、JavaScript 函数 JavaScript 函数是一段可重复使用的代码...
    99+
    2023-11-05
    编程算法 函数 javascript
  • 如何使用 MySQL COALESCE() 函数在列中的 NULL 位置插入值?
    为了理解它,我们使用表“Employee”中的数据,其中 ID = 5 和 6 的 Salary=NULL,如下 -mysql> Select * from Employee; +----+--------+--------...
    99+
    2023-10-22
  • 如何在Java编程中使用函数和算法?
    Java 是一门广泛使用的编程语言,具有广泛的应用领域。在 Java 编程中,函数和算法是非常重要的概念。本文将介绍如何在 Java 编程中使用函数和算法。 函数是一段可以重复使用的代码块。它们可以接受参数并返回值。Java 中的函数使用关...
    99+
    2023-11-03
    函数 编程算法 javascript
  • 如何在Java编程中使用Javascript函数和算法?
    在Java编程中,使用JavaScript函数和算法可以帮助程序员更好地完成任务和解决问题。本文将介绍如何在Java编程中使用JavaScript函数和算法,以及如何在代码中演示它们的用法。 一、使用JavaScript函数 在Java编程...
    99+
    2023-11-03
    函数 编程算法 javascript
  • 如何在PHP中使用Load函数来优化LeetCode算法?
    LeetCode算法是一个非常受欢迎的算法练习平台,它提供了许多经典的算法问题,可以帮助开发人员提高算法能力和编程技能。在解决这些问题时,我们需要编写高效的代码,以确保我们的解决方案能够在规定的时间内运行。在PHP中,我们可以使用Load...
    99+
    2023-11-02
    leetcode 教程 load
  • 我们如何使用 MySQL 自计算的任何表达式、函数等的输出来在行中插入值?
    在一行中插入值时,我们可以使用任何表达式、函数等自计算输出的值。下面是一个示例来演示它 -mysql> Insert into employee(id, emp_name)Select 1+1, Concat_ws...
    99+
    2023-10-22
  • python如何在函数声明中使用默认值
    小编给大家分享一下python如何在函数声明中使用默认值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在函数声明中使用默认值在几乎所有的Python项目中,大多数...
    99+
    2023-06-27
  • 如何在 MySQL STRCMP() 函数中使用数值作为参数?
    为了进行比较,我们可以在 STRCMP() 函数中使用数值作为参数。它们作为参数给出,不带引号。下面的示例将对其进行演示。示例mysql> Select STRCMP(10,10)As 'Equal Numbers',...
    99+
    2023-10-22
  • 如何在Java中使用Numpy来处理数值计算?
    Java是一门广泛使用的编程语言,在数值计算方面,Java本身的数值计算库已经相当强大,但是在一些特定的数值计算场景中,需要使用专业的数值计算库来进行更加高效的计算。其中,Numpy是一款专门用于数值计算的Python库,它提供了一系列高效...
    99+
    2023-06-14
    http numpy 索引
  • 你了解如何使用Python函数在编程算法中使用shell吗?
    Python是一种非常流行的编程语言,而shell则是一种用于在命令行环境下进行交互式操作的工具。许多人在编程算法时都希望能够使用shell来进行操作,这就需要使用Python函数来实现。本文将介绍如何使用Python函数在编程算法中使用s...
    99+
    2023-07-08
    shell 函数 编程算法
  • PHP中的对象编程算法:如何在函数中使用它们?
    PHP是一种功能强大的服务器端编程语言,它支持面向对象编程(OOP)的方法。在PHP中,对象是以类的形式定义的,而算法是一组指令,用于执行特定的任务。本文将介绍PHP中的对象编程算法,以及如何在函数中使用它们。 一、什么是对象编程算法? 对...
    99+
    2023-10-10
    对象 编程算法 函数
  • 如何在 MySQL DATEDIFF() 函数中使用 2 位年份值?
    我们可以在单个日期表达式或在 MySQL DATEDIFF() 函数中用作参数的两个日期表达式中使用 2 位年份值。例如,下面的查询使用 2-第一个日期表达式中的数字年份值,其他日期表达式具有 4 位数的年份值。mysql> Sele...
    99+
    2023-10-22
  • 编程算法必备技能:如何在 LeetCode 中使用 Python 函数?
    LeetCode 是一个在线的算法学习平台,它提供了大量的算法题目,涵盖了许多不同的难度级别,对于想要提高编程算法能力的人来说,是一个非常不错的选择。对于 Python 开发者来说,LeetCode 平台也提供了非常方便的 Python ...
    99+
    2023-06-27
    leetcode 函数 编程算法
  • 如何使用Python实现Newton插值法
    小编给大家分享一下如何使用Python实现Newton插值法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. n阶差商实现def diff(xi,yi...
    99+
    2023-06-14
  • PHP中如何使用函数插入数组元素
    今天就跟大家聊聊有关PHP中如何使用函数插入数组元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、array_unshift()函数在数组中插入新元素array_unshift(...
    99+
    2023-06-20
  • 如何在Python shell中使用函数编写最佳的编程算法?
    Python是一种易于学习且功能强大的编程语言,它为编写高效算法提供了很多工具和函数。在Python中,函数是一种非常有用的工具,可以帮助我们编写最佳的编程算法。在本文中,我们将探讨如何在Python shell中使用函数编写最佳的编程算法...
    99+
    2023-07-08
    shell 函数 编程算法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作