当前位置: 首页 > news >正文

OpenCV(三十九):积分图像

1.积分图像介绍

       积分图像中的每个像素表示了原始图像中对应位置及其左上方矩形区域内像素值的总和。如图,p0表示原始图像蓝色区域内像素值的总和。

       倾斜求和(Skewed Sum)是积分图像的一种扩展形式,用于计算图像区域内的像素和,其中区域并不是矩形而是斜边形。通过倾斜求和的积分图像,可以在常量时间内计算任意斜边形区域内的像素和。。如图,p0表示原始图像灰色区域内像素值的总和。

2.计算积分图像函数integral()

void cv::integral ( InputArray   src,

OutputArray sum,

OutputArray sqsum,

OutputArray tilted,

int  sdepth = -1,

int sqdepth = -1

)

  • src:输入图像,图像数据类型可以是CV_8U、CV_32F或者CV_64。
  • sum:输出标准求和积分图像,图像的数据类型可以是CV_32S、CV_32F或者CV_64。
  • sqsum:输出平方求和积分图像,图像的数据类型可以是CV_32F或者CV_64F。
  • tilted:输出倾斜45°的倾斜求和积分图像,其数据类型与sum相同。
  • sdepth: 输出标准求和积分图像和倾斜求和积分图像的数据类型标志,可以选择的参数为CV _32S、CV_32F或者 CV_64F,参数默认值为-1,表示满足数据存储的自适应类型。
  • sqdepth: 输出平方求和积分图像的数据类型标志,可以选择的参数为CV_32F或者 CV_64F,参数默认值为-1,表示满足数据存储的自适应类型。

3.示例代码

void  Integral_image(){//创建一个16×16全为1的矩阵,因为256=16×16Mat img=Mat::ones(16,16,CV_32FC1);//在图像中加入随机噪声RNG rng(10086);for(int y=0;y<img.rows;y++){for(int x=0;x<img.cols;x++){float d=rng.uniform(-0.5,0.5);img.at<float>(y,x)=img.at<float>(y,x)+d;}}//计算标准求和积分Mat sum;integral(img,sum);//为了便于显示,转成CV_8U格式Mat sum8U=Mat_<uchar>(sum);imwrite("/sdcard/DCIM/sum8U.png",sum8U);//计算平方求和积分Mat sqsum;integral(img,sum,sqsum);//为了便于显示,转成CV_8U格式Mat sqsum8U=Mat_<uchar>(sqsum);imwrite("/sdcard/DCIM/sqsum8U.png",sqsum8U);//计算倾斜求和积分Mat tilted;integral(img,sum,sqsum,tilted);//为了便于显示,转成CV_8U格式Mat tilted8U=Mat_<uchar>(tilted);imwrite("/sdcard/DCIM/tilted8U.png",tilted8U);
}

标准求和积分结果:

平方求和积分结果:

倾斜求和积分结果:

http://www.lryc.cn/news/170201.html

相关文章:

  • 【Electron 拦截请求实现自定义网络处理】
  • Pytest系列-内置标签skip和skipif 跳过测试用例的详细使用(5)
  • 华为云云耀云服务器L实例评测|docker 常用操作命令
  • RJ45网络信号浪涌保护器解决方案
  • SoC性能指标ARM内核运算能力
  • 注册小鲸鱼88888专用网站
  • GitHub平台 Bookget操作
  • Ag-grid实现列拖拽,将列顺序存储到本地(localStorage),加载页面时根据本地保存的顺序修改列表头顺序,避免刷新页面后列顺序恢复原样
  • 常用的linux命令简要说明以及命令全名理解
  • 《Python趣味工具》——自制emoji3
  • 怎么把录音转换成mp3格式
  • 基于遗传算法改进的BP神经网络图像分割,BP神经网络基本原理,遗传算法流程,
  • uni-app 之 文字分两行显示超出用省略号表示
  • stl_stack_queue的使用及OJ题
  • Linux下的Docker安装,以Ubuntu为例
  • 【深度学习 | LSTM】解开LSTM的秘密:门控机制如何控制信息流
  • 解决npm install遇到的问题:Error while executing:
  • 常见的内网穿透工具有 ngrok/ localtunnel/ frp
  • dvwa命令执行漏洞分析
  • 今年嵌入式行情怎么样?
  • Unity WebGL 编译 报错: emcc2: error: ‘*‘ failed: [WinError 2] ϵͳ�Ҳ���ָ�����ļ���解决办法
  • 三维模型3DTile格式轻量化压缩处理的数据质量提升方法分析
  • Pycharm2022 pycharm64.exe.Vmoptions
  • sql注入之高权限注入和文件读写
  • Java 面经
  • 无涯教程-JavaScript - ROUNDUP函数
  • 【Linux旅行记】探究操作系统是如何进行管理的!
  • 【Linux C小技巧】零长度数组的使用
  • github 网页显示不全?
  • 寄存器介绍