opencv图像金字塔

下采样:

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
	// 读取图像
	cv::Mat src = cv::imread("C:/Users/10623/Pictures/adf4d0d56444414cbeb809f0933b9214.png");
	if (src.empty()) {
		std::cout << "无法加载图像" << std::endl;
		return -1;
	}

	// 创建一个与源图像同样大小的 Mat 对象,用于存储结果
	cv::Mat dst1,dst2,dst3;

	// 使用 pyrDown 进行向下采样
	cv::pyrDown(src, dst1);
	cv::pyrDown(dst1, dst2);
	cv::pyrDown(dst2, dst3);
	// 显示原始图像和下采样后的图像
	cv::imshow("Original Image", src);
	cv::imshow("Downsampled Image", dst1);
	cv::imshow("2",dst2);
	cv::imshow("3",dst3);
	cv::waitKey(0);

	return 0;
}
cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
    // 读取图像
    cv::Mat src = cv::imread("path_to_your_image.jpg");
    if (src.empty()) {
        std::cout << "无法加载图像" << std::endl;
        return -1;
    }

    // 创建一个向量来存储多尺度金字塔的图像
    std::vector<cv::Mat> images;

    // 使用 buildPyramid 创建多尺度金字塔
    int scale = 1;
    while (src.size().width > 10 && src.size().height > 10) {
        cv::Mat image;
        cv::pyrDown(src, image);  // 使用 pyrDown 进行向下采样
        images.push_back(image);
        src = image;
        scale *= 2;
    }

    // 显示原始图像和多尺度金字塔的图像
    for (int i = images.size() - 1; i >= 0; i--) {
        std::cout << "Scale: " << scale << std::endl;
        cv::imshow("Image", images[i]);
        cv::waitKey(0);
        scale /= 2;
    }

    return 0;
}

上采样:

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
	// 读取图像
	cv::Mat src = cv::imread("C:/Users/10623/Pictures/adf4d0d56444414cbeb809f0933b9214.png");
	if (src.empty()) {
		std::cout << "无法加载图像" << std::endl;
		return -1;
	}

	// 创建金字塔参数
	int max_level = 5;  // 最大金字塔层数
	cv::Mat dst,dst1, dst2, dst3,dst4,dst5;
	// 使用 pyrDown 进行向下采样
	cv::pyrDown(src, dst1);
	cv::pyrDown(dst1, dst2);
	cv::pyrDown(dst2, dst3);
	// 构建金字塔
	cv::pyrUp(dst3, dst, cv::Size(dst3.cols * 2, dst3.rows * 2));  // 向上采样到下一层
	cv::pyrUp(dst, dst4, cv::Size(dst.cols * 2, dst.rows * 2));
	cv::pyrUp(dst4, dst5, cv::Size(dst4.cols * 2, dst4.rows * 2));
	cv::imshow("Pyramid Level 1",dst);
	cv::imshow("Pyramid Level 2", dst4);
	cv::imshow("Pyramid Level 3", dst5);
	cv::waitKey(0);
	return 0;
}
相关推荐
Elastic 中国社区官方博客15 分钟前
Elasticsearch:如何使用 Qwen3 来做向量搜索
大数据·人工智能·elasticsearch·搜索引擎·全文检索
Black_Rock_br39 分钟前
GraphRAG:AI理解复杂知识的未知领域,开启探索之旅
人工智能
失散136 小时前
深度学习——03 神经网络(2)-损失函数
人工智能·深度学习·神经网络·损失函数
商业讯6 小时前
大模型驱动的服务革命:2025智能客服机器人选型与落地路径
人工智能·机器人
mortimer8 小时前
Hugging Face 下载模型踩坑记:从符号链接到网络错误
人工智能·python·ai编程
一株月见草哇10 小时前
Matlab(4)
人工智能·算法·matlab
IMER SIMPLE10 小时前
人工智能-python-机器学习-线性回归与梯度下降:理论与实践
人工智能·python·机器学习
lxmyzzs10 小时前
【图像算法 - 12】OpenCV-Python 入门指南:图像视频处理与可视化(代码实战 + 视频教程 + 人脸识别项目讲解)
人工智能·opencv·计算机视觉
hans汉斯11 小时前
基于深度学习的苹果品质智能检测算法研究
人工智能·深度学习·算法
2401_8318960311 小时前
深度学习(5):激活函数
人工智能·深度学习