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;
}
相关推荐
yiersansiwu123d3 分钟前
AI伦理风险:技术狂奔下的隐忧
人工智能
潮际好麦8 分钟前
AI 工具推荐:AI绘图、AI助力学习
人工智能·学习
徐小夕@趣谈前端10 分钟前
LuckyFlow:用Vue3实现的一款AI可视化工作流编辑器
vue.js·人工智能·编辑器
weiwuxian22 分钟前
🚀 拒绝“人工智障”:如何写出一份高质量的 agent.md?
人工智能
Yeats_Liao36 分钟前
CANN Samples(十一):媒体处理接口V1与V2的取舍与迁移
人工智能·媒体
汤姆yu43 分钟前
基于srpingboot心情治愈调整系统
人工智能
国科安芯1 小时前
航天医疗领域AS32S601芯片的性能分析与适配性探讨
大数据·网络·人工智能·单片机·嵌入式硬件·fpga开发·性能优化
咚咚王者1 小时前
人工智能之数据分析 Pandas:第五章 文件处理
人工智能·数据分析·pandas
zhaodiandiandian1 小时前
人工智能与就业重构:机遇、挑战与政策应对
人工智能·百度·重构
浔川python社1 小时前
浔川社团:技术创作与社区运营的双重成功
人工智能