[ISP]DCT离散余弦变换及C++代码demo

news/2024/7/21 7:25:04 标签: 算法, 图像处理, 人工智能, 计算机视觉

1.基本定义

离散余弦变换(DCT for Discrete Cosine Transform)

DCT(Discrete Cosine Transform,离散余弦变换)是一种常用的信号处理技术,广泛应用于图像处理、音频处理、视频压缩等领域。DCT将一个信号或数据序列从时域(或空域)转换为频域,可以有效地提取信号的频域特征,实现信号的压缩和特征提取。

DCT与傅里叶变换类似,但DCT仅使用实数部分,因此更适合于处理实际信号。DCT将信号分解为一系列余弦函数的加权和这些余弦函数的频率从低到高排列,能够较好地捕捉信号的频域特征

图像处理中,DCT常用于JPEG图像压缩算法中,将图像分块进行DCT变换,然后通过量化和熵编码实现图像的压缩。在音频处理中,DCT也被用于音频压缩和音频特征提取。此外,DCT还可以应用于数据压缩、信号处理、模式识别等领域。

总的来说,DCT是一种重要的信号处理技术,具有广泛的应用领域,能够帮助我们理解信号的频域特征、实现信号的压缩和特征提取。

2.demo实现代码

#include <iostream>
#include <opencv2/opencv.hpp>

void dctImage(cv::Mat& image) {
    cv::Mat imageFloat;
    image.convertTo(imageFloat, CV_32F); // 转换为32位浮点数

    cv::Mat channels[3];
    cv::split(imageFloat, channels); // 将图像拆分为RGB通道

    for (int i = 0; i < 3; ++i) {
        cv::dct(channels[i], channels[i]); // 对每个通道应用DCT
    }

    //可选,低频滤波处理
    int cutofffreq = 10;//截止频率
    for (int i = 0; i < 3; i++)
    {
        for (int row = 0; row < channels[i].rows; ++row) {
            for (int col = 0; col < channels[i].cols; col++)
            {
                if (row > cutofffreq || col > cutofffreq) {
                    channels[i].at<float>(row, col) = 0;//高频部分置零
                }
            }
        }
    }
    for (int i = 0; i < 3; ++i) {
        cv::idct(channels[i], channels[i]); // 对每个通道应用逆DCT
    }

    cv::merge(channels, 3, imageFloat); // 合并RGB通道

    imageFloat.convertTo(image, CV_8U); // 转换回8位图像
}

int main() {
    cv::Mat image = cv::imread("F:/2024/ISP_Cpp/1.DCTdemo/ISPcpp_0.jpg"); // 读取RGB图像

    if (image.empty()) {
        std::cerr << "Error: Unable to read image file." << std::endl;
        return -1;
    }

    dctImage(image); // 应用DCT处理图像
    cv::Mat resizedImage;
    cv::resize(image, resizedImage, cv::Size(), 0.5, 0.5);//调整图像大小

    //cv::imshow("DCT Image", resizedImage); // 显示处理后的图像
    cv::imwrite("F:/2024/ISP_Cpp/1.DCTdemo/processed_image.jpg", resizedImage);
    cv::waitKey(0);

    return 0;
}

3.DCT 去高频效果


http://www.niftyadmin.cn/n/5410659.html

相关文章

《C++新经典对象模型》之第2章 对象

《C新经典对象模型》之第2章 对象 2.1 类对象&#xff08;实例&#xff09;占用空间02.01.cpp 2.2 对象结构的发展和演化02.02.cpp 2.3 this指针调整02.03.cpp 2.4 分析obj&#xff08;目标文件&#xff09;与构造函数语义02.04.cpp 2.5 拷贝构造函数语义与移动构造函数语义2.5…

(自用笔记)每天一点vue3——第一天setup/defineProps

<script setup></script> setup语法糖&#xff0c;script中的所有内容相当于是在一个setup函数中执行的。并且声明的所有变量、引用的方法\组件&#xff08;组件名最好用大驼峰&#xff09;都能直接在模板字符串中使用。不再用data\method之类的方法包裹。setup引入…

Threejs着色器(GPU)编程——感温管网

管网,作为支撑现代城市运转的重要基础设施,是隐藏在地面之下的庞大工程网络。这些管网如同城市的血脉,负责输送各种必要的资源,如水源、热力、燃气等,同时排除废水和其他废弃物。然而,由于其位于地下,人们往往难以直接感知其存在和运行状态。为了保障这些地下管网的安全…

【深度学习】COCO API源码解读

COCO API 从C、cython&#xff0c;到Python API&#xff1a; 实现语义分割标注mask的解析&#xff0c;从具体实现 cocoapi/common/maskApi.h cocoapi/common/maskApi.c 到Cython封装实现 pycocotools._mask cocoapi/PythonAPI/pycocotools/_mask.pyx # distutils: language …

jsDoc(JavaScript 代码文档注释的标准格式)说明

文章目录 jsDoc&#xff08;JavaScript 代码文档注释的标准格式&#xff09;说明实例&#xff1a; jsDoc&#xff08;JavaScript 代码文档注释的标准格式&#xff09;说明 手册明地址&#xff1a;https://jsdoc.bootcss.com/tags-abstract.html 实例&#xff1a; /*** 计算两…

javaEE基于springboot民宿推荐系统springmvc+mybatis+jsp]

该民宿推荐系统应能够完成民宿推荐信息发布的需求&#xff0c;程序安全&#xff0c;操作应简单易行&#xff0c;通过简洁美观的前端页面引导即可完成操作。从多角度多方面思考理解大众用户的功能需求&#xff0c;思考系统应该具备的核心功能模块&#xff0c;并完成相应开发。民…

JavaEE+springboot教学仪器设备管理系统o9b00-springmvc

本文旨在设计一款基于Java技术的教学仪器设备销售网站&#xff0c;以提高网站性能、功能完善、用户体验等方面的优势&#xff0c;解决现有教学仪器设备销售网站的问题&#xff0c;并为广大教育工作者和学生提供便捷的教学仪器设备销售渠道。本文首先介绍了Java技术的相关基础知…

代码随想录算法训练营第三十四天|LeetCode860 柠檬水找零、LeetCode406 根据身高重建队列、LeetCode452 用最少数量的箭引爆气球

860.柠檬水找零 思路&#xff1a;只有5、10、20三种面额的纸币&#xff0c;因此每接收一种纸币对应的数量就&#xff0c;当接收10的&#xff0c;5的数量就--&#xff0c;当接收20的&#xff0c;有限消耗10的纸币&#xff08;贪心&#xff09;&#xff0c;因为10只能用于20找零…