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;
}
相关推荐
SEO_juper9 分钟前
AI SEO实战:利用人工智能提升网站排名与流量的完整策略
人工智能·搜索引擎·百度·ai·seo·数字营销
暖阳之下10 分钟前
学习周报二十
人工智能·深度学习·学习
Doc.S20 分钟前
【保姆级教程】在AutoDL容器中部署EGO-Planner,实现无人机动态避障规划
人工智能·python·信息可视化·机器人
乌恩大侠21 分钟前
【东枫电子】AI-RAN 开发者套件,适用于6G科研与教学
人工智能·usrp
A_SKYLINE21 分钟前
低空无人机“一网统飞”深度解构:从技术内核到产业落地,重构低空经济操作系统
人工智能·重构·无人机·产品经理·低空经济
IT_陈寒21 分钟前
React性能优化:10个90%开发者不知道的useEffect正确使用姿势
前端·人工智能·后端
蒋星熠43 分钟前
多模态技术深度探索:融合视觉与语言的AI新范式
人工智能·python·深度学习·机器学习·分类·数据挖掘·多分类
Francek Chen1 小时前
【自然语言处理】预训练04:预训练word2vec
人工智能·pytorch·深度学习·自然语言处理·word2vec
元宇宙时间1 小时前
Nine.fun:连接现实娱乐与Web3经济的全新生态
人工智能·金融·web3·区块链
甄心爱学习1 小时前
数据挖掘6-AI总结
人工智能·数据挖掘