IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> opencv线性插值(上采样) -> 正文阅读

[人工智能]opencv线性插值(上采样)

1、调用opencv的API

pyrUp(src, dst, Size(src.cols * 2, src.rows * 2));?

pyrUp:API详解

这里的up是指将图像的尺寸变大,所以原始图像位于图像金字塔的顶层。

首先将当前层图像的宽高扩大2倍,插入的行和列位于偶数行或偶数列,这些位置填充数值0;然后用和pyrDown一样的kernel和当前层的图像卷积,填充到刚才插入的行列中。

接口形式:

cv2.pyrUp(src[, dst[, dstsize[, borderType]]]) ->dst
  • 参数含义:
  • src:源图像;
  • dst:目标图像;
  • dstsize:缩放后目标图像的尺寸,必须满足std::abs(dsize.width – ssize.width*2) == dsize.width % 2 && std::abs(dsize.height – ssize.height*2) == dsize.height % 2
  • borderType:边界填充类型;

2、源码实现?

先对图像进行升采样(将图像尺寸行和列方向增大一倍),然后再进行高斯平滑;

Mat UpSample(Mat src)
{
	Mat dst;

	if (src.channels() != 1)
		return src;
	dst.create(src.rows * 2, src.cols * 2, src.type());
	//cout << "-- " << dst.rows << " " << dst.cols << " --" << endl;

	int m = 0, n = 0;
	for (int i = 0; i < dst.rows-2; i += 2, m++)
	{
		n = 0;
		for (int j = 0; j < dst.cols-2; j += 2, n++)
		{
			//需要防止地址越界
			pixel_t sample = *(src.data + src.step[0] * m + src.step[1] * n);
			*(dst.data + dst.step[0] * i + dst.step[1] * j) = sample;
			pixel_t sample_x = (*(src.data + src.step[0] * m + src.step[1] * n) + *(src.data + src.step[0] * m + src.step[1] * (n+1)));
			*(dst.data + dst.step[0] * (i) + dst.step[1] * (j+1)) = sample_x/2;
			pixel_t sample_y = (*(src.data + src.step[0] * m + src.step[1] * n) + *(src.data + src.step[0] * (m+1)+ src.step[1] * (n)));
			*(dst.data + dst.step[0] * (i+1) + dst.step[1] * (j)) = sample_y/2;
			pixel_t sample_center = (*(src.data + src.step[0] * m + src.step[1] * n) +
				*(src.data + src.step[0] * (m + 1) + src.step[1] * (n)) +
				*(src.data + src.step[0] * (m + 1) + src.step[1] * (n + 1)) +
				*(src.data + src.step[0] * m + src.step[1] * (n + 1)));
			*(dst.data + dst.step[0] * (i + 1) + dst.step[1] * (j + 1)) = sample_center / 4;
		}
	}

	if (dst.rows < 3 || dst.cols < 3)
		return src;

	//最后两行两列
	for (int k = dst.rows-1; k >= 0; k--)
	{
		*(dst.data + dst.step[0] * k + dst.step[1] * (dst.cols - 2)) = *(dst.data + dst.step[0] * k + dst.step[1] * (dst.cols - 3));
		*(dst.data + dst.step[0] * k + dst.step[1] * (dst.cols - 1)) = *(dst.data + dst.step[0] * k + dst.step[1] * (dst.cols - 3));
	}
	for (int k = dst.cols-1; k >= 0; k--)
	{
		*(dst.data + dst.step[0] * (dst.rows - 2) + dst.step[1] * k) = *(dst.data + dst.step[0] * (dst.rows - 3) + dst.step[1] * k);
		*(dst.data + dst.step[0] * (dst.rows - 1) + dst.step[1] * k) = *(dst.data + dst.step[0] * (dst.rows - 3) + dst.step[1] * k);
	}
	dst = guassFilter(dst, 5, 1.05);
	return dst;
}

3、结果比较

(1)调用API

(2)源码实现

?

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-30 18:23:58  更:2022-03-30 18:24:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:23:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码