色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

OpenCV中積分圖函數(shù)與應用

OpenCV學堂 ? 來源:OpenCV學堂 ? 作者:OpenCV學堂 ? 2022-06-29 10:26 ? 次閱讀

OpenCV中積分圖函數(shù)與應用

一:圖像積分圖概念

積分圖像是Crow在1984年首次提出,是為了在多尺度透視投影中提高渲染速度。隨后這種技術(shù)被應用到基于NCC的快速匹配、對象檢測和SURF變換中、基于統(tǒng)計學的快速濾波器等方面。積分圖像是一種在圖像中快速計算矩形區(qū)域和的方法,這種算法主要優(yōu)點是一旦積分圖像首先被計算出來我們可以計算圖像中任意大小矩形區(qū)域的和而且是在常量時間內(nèi)。這樣在圖像模糊、邊緣提取、對象檢測的時候極大降低計算量、提高計算速度。第一個應用積分圖像技術(shù)的應用是在Viola-Jones的對象檢測框架中出現(xiàn)。

35f9e682-f6f5-11ec-ba43-dac502259ad0.jpg

36181fe4-f6f5-11ec-ba43-dac502259ad0.png

上圖左側(cè)四個點的矩形區(qū)域像素求和,只要根據(jù)每個點左上方所有像素和表值,進行兩次減法與一次加法即可=》46 – 22 – 20 + 10 = 14

二:OpenCV中積分圖函數(shù)

OpenCV中通過integral()函數(shù)可以很容易的計算圖像的積分圖,該函數(shù)支持和表積分圖、平方和表積分圖、瓦塊和表積分圖計算。integral函數(shù)與參數(shù)解釋如下:


	
  1. void cv::integral(

  2. InputArray src, // 輸入圖像

  3. OutputArray sum, // 和表

  4. OutputArray sqsum, // 平方和表

  5. OutputArray tilted, // 瓦塊和表

  6. int sdepth = -1, // 和表數(shù)據(jù)深度常見CV_32S

  7. int sqdepth = -1 // 平方和表數(shù)據(jù)深度 常見 CV_32F

  8. )

三:使用積分圖函數(shù)

通過代碼演示計算積分圖實現(xiàn)任意窗口大小的盒子模糊與垂直邊緣提取,完整的代碼實現(xiàn)如下:


	
  1. #include

  2. #include

  3. using namespace cv;

  4. using namespace std;

  5. void blur_demo(Mat &image, Mat &sum);

  6. void edge_demo(Mat &image, Mat &sum);

  7. int getblockSum(Mat &sum, int x1, int y1, int x2, int y2, int i);

  8. int main(int argc, char** argv) {

  9. Mat src = imread("D:/vcprojects/images/yuan_test.png");

  10. if (src.empty()) {

  11. printf("could not load image... ");

  12. return -1;

  13. }

  14. namedWindow("input", CV_WINDOW_AUTOSIZE);

  15. imshow("input", src);

  16. namedWindow("output", CV_WINDOW_AUTOSIZE);

  17. // 計算積分圖

  18. Mat sum, sqrsum;

  19. integral(src, sum, sqrsum, CV_32S, CV_32F);

  20. // 積分圖應用

  21. int type = 0;

  22. while (true) {

  23. char c = waitKey(100);

  24. if (c > 0) {

  25. type = (int)c;

  26. printf("c : %d ", type);

  27. }

  28. if (c == 27) {

  29. break; // ESC

  30. }

  31. if (type == 49) { // 數(shù)字鍵 1

  32. blur_demo(src, sum);

  33. }

  34. else if (type == 50) { // 數(shù)字鍵 2

  35. edge_demo(src, sum);

  36. }

  37. else {

  38. blur_demo(src, sum);

  39. }

  40. }

  41. waitKey(0);

  42. return 0;

  43. }

  44. void blur_demo(Mat &image, Mat &sum) {

  45. int w = image.cols;

  46. int h = image.rows;

  47. Mat result = Mat::zeros(image.size(), image.type());

  48. int x2 = 0, y2 = 0;

  49. int x1 = 0, y1 = 0;

  50. int ksize = 5;

  51. int radius = ksize / 2;

  52. int ch = image.channels();

  53. int cx = 0, cy = 0;

  54. for (int row = 0; row < h + radius; row++) {

  55. y2 = (row + 1)>h ? h : (row + 1);

  56. y1 = (row - ksize) < 0 ? 0 : (row - ksize);

  57. for (int col = 0; col < w + radius; col++) {

  58. x2 = (col + 1)>w ? w : (col + 1);

  59. x1 = (col - ksize) < 0 ? 0 : (col - ksize);

  60. cx = (col - radius) < 0 ? 0 : col - radius;

  61. cy = (row - radius) < 0 ? 0 : row - radius;

  62. int num = (x2 - x1)*(y2 - y1);

  63. for (int i = 0; i < ch; i++) {

  64. // 積分圖查找和表,計算卷積

  65. int s = getblockSum(sum, x1, y1, x2, y2, i);

  66. result.at<Vec3b>(cy, cx)[i] = saturate_cast(s / num);

  67. }

  68. }

  69. }

  70. imshow("output", result);

  71. imwrite("D:/result.png", result);

  72. }

  73. /**

  74. * 3x3 sobel 垂直邊緣檢測演示

  75. */

  76. void edge_demo(Mat &image, Mat &sum) {

  77. int w = image.cols;

  78. int h = image.rows;

  79. Mat result = Mat::zeros(image.size(), CV_32SC3);

  80. int x2 = 0, y2 = 0;

  81. int x1 = 0, y1 = 0;

  82. int ksize = 3; // 算子大小,可以修改,越大邊緣效應越明顯

  83. int radius = ksize / 2;

  84. int ch = image.channels();

  85. int cx = 0, cy = 0;

  86. for (int row = 0; row < h + radius; row++) {

  87. y2 = (row + 1)>h ? h : (row + 1);

  88. y1 = (row - ksize) < 0 ? 0 : (row - ksize);

  89. for (int col = 0; col < w + radius; col++) {

  90. x2 = (col + 1)>w ? w : (col + 1);

  91. x1 = (col - ksize) < 0 ? 0 : (col - ksize);

  92. cx = (col - radius) < 0 ? 0 : col - radius;

  93. cy = (row - radius) < 0 ? 0 : row - radius;

  94. int num = (x2 - x1)*(y2 - y1);

  95. for (int i = 0; i < ch; i++) {

  96. // 積分圖查找和表,計算卷積

  97. int s1 = getblockSum(sum, x1, y1, cx, y2, i);

  98. int s2 = getblockSum(sum, cx, y1, x2, y2, i);

  99. result.at<Vec3i>(cy, cx)[i] = saturate_cast(s2 - s1);

  100. }

  101. }

  102. }

  103. Mat dst, gray;

  104. convertScaleAbs(result, dst);

  105. normalize(dst, dst, 0, 255, NORM_MINMAX);

  106. cvtColor(dst, gray, COLOR_BGR2GRAY);

  107. imshow("output", gray);

  108. imwrite("D:/edge_result.png", gray);

  109. }

  110. int getblockSum(Mat &sum, int x1, int y1, int x2, int y2, int i) {

  111. int tl = sum.at<Vec3i>(y1, x1)[i];

  112. int tr = sum.at<Vec3i>(y2, x1)[i];

  113. int bl = sum.at<Vec3i>(y1, x2)[i];

  114. int br = sum.at<Vec3i>(y2, x2)[i];

  115. int s = (br - bl - tr + tl);

  116. return s;

  117. }

這里最重要的是要注意到上面的圖示,積分圖對象的Mat(1,1)對應實際圖像Mat(0,0),如果不加處理的話會導致結(jié)果有明顯的中心遷移。edge_demo實現(xiàn)了積分圖查找提取圖像邊緣、blur_demo函數(shù)實現(xiàn)積分圖查找圖像均值模糊,getblockSum函數(shù)實現(xiàn)和表查找功能,運行顯示:

原圖:

模糊效果

36546d64-f6f5-11ec-ba43-dac502259ad0.jpg

邊緣效果

36721c38-f6f5-11ec-ba43-dac502259ad0.jpg

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 圖像
    +關(guān)注

    關(guān)注

    2

    文章

    1083

    瀏覽量

    40449
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4327

    瀏覽量

    62573
  • OpenCV
    +關(guān)注

    關(guān)注

    31

    文章

    634

    瀏覽量

    41338

原文標題:OpenCV中積分圖介紹與應用

文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學堂】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    基于OpenCV的拆分和合并圖像通道實驗案例分享_基于RK3568教學實驗箱

    。 在OpenCV,可以通過cv2.split()函數(shù)實現(xiàn)拆分圖像通道。這個函數(shù)接受一個彩色圖像作為輸入,并返回一個包含三個(對于RGB圖像)或四個(對于RGBA圖像,包含透明度通道
    發(fā)表于 12-03 14:27

    RK3568 + OpenCV 會碰撞出什么火花?案例詳解:2-1 基于OpenCV的畫線實驗

    一系列 C 函數(shù)和少量 C++ 類構(gòu)成,同時提供了Python、Ruby、MATLAB等語言的接口,實現(xiàn)了圖像處理和計算機視覺方面的很多通用算法。 OpenCV具有以下特點: 不管是科學研究,還是商業(yè)
    發(fā)表于 12-03 14:09

    RTOS鉤子函數(shù)的用途及用法

    在很多操作系統(tǒng),都存在這樣一類API函數(shù)接口:HOOK函數(shù)(也叫鉤子函數(shù))。
    的頭像 發(fā)表于 10-23 16:25 ?234次閱讀
    RTOS<b class='flag-5'>中</b>鉤子<b class='flag-5'>函數(shù)</b>的用途及用法

    【龍芯2K0300蜂鳥板試用】5 搭建opencv開發(fā)環(huán)境

    在官方提供的buildroot根文件系統(tǒng),不支持opencv庫,故需要自己增加,另外,在本地編譯的時候,需要在本地(ubuntu)上安裝對應opencv庫,這樣才能將編譯好的鏡像放到板子上跑起來
    發(fā)表于 08-27 15:08

    OpenCV圖像識別C++代碼

    安裝OpenCV庫 首先,您需要在您的計算機上安裝OpenCV庫。您可以從OpenCV官網(wǎng)下載預編譯的庫或從源代碼編譯。安裝完成后,確保將OpenCV的頭文件和庫文件添加到您的項目中。
    的頭像 發(fā)表于 07-16 10:42 ?1969次閱讀

    opencv-python和opencv一樣嗎

    不一樣。OpenCV(Open Source Computer Vision Library)是一個開源的計算機視覺和機器學習軟件庫,它提供了大量的圖像和視頻處理功能。OpenCV
    的頭像 發(fā)表于 07-16 10:38 ?1161次閱讀

    opencv的主要功能有哪些

    OpenCV(Open Source Computer Vision Library)是一個開源的計算機視覺庫,提供了大量的計算機視覺算法和工具。以下是OpenCV的主要功能: 圖像處理
    的頭像 發(fā)表于 07-16 10:35 ?1501次閱讀

    OpenCV攜奧比光3D相機亮相CVPR 2024

    6月17日-21日,奧比光合作伙伴OpenCV攜Orbbec 3D相機參展在美國西雅圖舉辦的CVPR 2024(即IEEE國際計算機視覺與模式識別會議),讓開發(fā)者親身體驗Orbbec 3D相機
    的頭像 發(fā)表于 06-21 09:38 ?549次閱讀

    I.MX6ULL-飛凌 ElfBoard ELF1板卡 - 如何在Ubuntu編譯OpenCV庫(X86架構(gòu))

    在之前發(fā)布的文章探討了交叉編譯OpenCV并部署至嵌入式系統(tǒng)的方法。然而,在調(diào)試階段,我們發(fā)現(xiàn)在 Ubuntu 環(huán)境下將 OpenCV 編譯為 X86 架構(gòu)可能更加方便和高效。 通過在主機上編譯并
    發(fā)表于 06-07 09:32

    嵌入式學習-飛凌ElfBoard ELF 1板卡 - 如何在Ubuntu編譯OpenCV

    在之前發(fā)布的文章探討了交叉編譯OpenCV并部署至嵌入式系統(tǒng)的方法。然而,在調(diào)試階段,我們發(fā)現(xiàn)在 Ubuntu 環(huán)境下將 OpenCV 編譯為 X86 架構(gòu)可能更加方便和高效。 通過在主機上編譯并
    發(fā)表于 06-07 09:21

    ELF 1技術(shù)貼|如何在Ubuntu編譯OpenCV

    在之前發(fā)布的文章探討了交叉編譯OpenCV并部署至嵌入式系統(tǒng)的方法。然而,在調(diào)試階段,我們發(fā)現(xiàn)在Ubuntu環(huán)境下將OpenCV編譯為X86架構(gòu)可能更加方便和高效。通過在主機上編譯并使用X86架構(gòu)
    的頭像 發(fā)表于 05-31 16:41 ?1162次閱讀
    ELF 1技術(shù)貼|如何在Ubuntu<b class='flag-5'>中</b>編譯<b class='flag-5'>OpenCV</b>庫

    labview的積分函數(shù)用哪個?

    對標準正弦加速度數(shù)據(jù)求速度,使用了積分函數(shù),但是得到的積分結(jié)果不是標準的余弦,請問是為什么
    發(fā)表于 05-30 15:13

    請問STM32_ImageProcessingLibrary中有類似于opencv的findContours函數(shù)嗎?

    STM32_ImageProcessingLibrary中有類似于opencv的findContours函數(shù)嗎?
    發(fā)表于 03-07 07:17

    verilog函數(shù)和任務對比

    在verilog函數(shù)和任務均用來描述共同的代碼段,并且在模式內(nèi)任意位置被調(diào)用,提高代碼效率,讓代碼更加的直觀,提高代碼可讀性。但是在實際使用的過程函數(shù)和任務也存在諸多的不同,下
    的頭像 發(fā)表于 02-12 18:43 ?882次閱讀

    ELF 1技術(shù)貼|如何移植OpenCV

    OpenCV擁有了豐富的常用圖像處理函數(shù)庫,采用C/C++語言編寫,可以運行在Linux、Windows、Mac等操作系統(tǒng)上流暢運行,并能夠快速實現(xiàn)一系列圖像處理和識別任
    的頭像 發(fā)表于 01-09 13:55 ?385次閱讀
    ELF 1技術(shù)貼|如何移植<b class='flag-5'>OpenCV</b>
    主站蜘蛛池模板: 尤物久久99国产综合精品| MD传媒MD0021在线观看| 国产成人亚洲精品老王| 久久亚洲伊人中字综合精品| 视频一区视频二区在线观看| 3d在线看小舞被躁视频| 国语自产拍在线视频普通话 | 情欲.美女高潮| 一本色道久久综合亚洲精品蜜桃冫| 公交车被CAO到合不拢腿| 毛片亚洲毛片亚洲毛片| 亚洲免费黄色片| 国产99RE在线观看69热| 欧美疯狂做受xxxxx喷水| 在教室轮流被澡高H林萌| 国产看午夜精品理论片| 日韩精品真人荷官无码| 99视频在线观看免费视频| 久久精品视频免费| 亚洲精品免费观看| 国产成人精品永久免费视频 | 一级毛片两人添下面| 国产亚洲高清视频| 四虎国产精品高清在线观看| 99在线精品国自产拍不卡| 老女人与小伙子露脸对白| 亚洲中文字幕永久在线 | 精品无码日本蜜桃麻豆| 无修肉动漫在线观看影片| YY8090福利午夜理论片| 男人到天堂a在538线| 真实国产乱子伦精品一区二区三区| 果冻传媒在线播放| 亚洲AV无码国产精品午夜久久| 国产精品www视频免费看| 日韩欧美一区二区三区免费看| SM调教贱屁股眼哭叫求饶H| 欧美ⅹxxxx18性欧美| 91欧洲在线视精品在亚洲| 美女被黑人巨大进入| 2017日日干|