chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

OpenCV學(xué)堂 ? 來(lái)源:OpenCV學(xué)堂 ? 作者:OpenCV學(xué)堂 ? 2022-06-29 10:26 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

一:圖像積分圖概念

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

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

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

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

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

OpenCV中通過(guò)integral()函數(shù)可以很容易的計(jì)算圖像的積分圖,該函數(shù)支持和表積分圖、平方和表積分圖、瓦塊和表積分圖計(jì)算。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ù)深度常見(jiàn)CV_32S

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

  8. )

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

通過(guò)代碼演示計(jì)算積分圖實(shí)現(xiàn)任意窗口大小的盒子模糊與垂直邊緣提取,完整的代碼實(shí)現(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. // 計(jì)算積分圖

  18. Mat sum, sqrsum;

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

  20. // 積分圖應(yīng)用

  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. // 積分圖查找和表,計(jì)算卷積

  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 垂直邊緣檢測(cè)演示

  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; // 算子大小,可以修改,越大邊緣效應(yīng)越明顯

  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. // 積分圖查找和表,計(jì)算卷積

  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. }

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

原圖:

模糊效果

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

邊緣效果

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

審核編輯 :李倩


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

    關(guān)注

    2

    文章

    1096

    瀏覽量

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

    關(guān)注

    3

    文章

    4406

    瀏覽量

    66859
  • OpenCV
    +關(guān)注

    關(guān)注

    33

    文章

    651

    瀏覽量

    44436

原文標(biāo)題:OpenCV中積分圖介紹與應(yīng)用

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    零成本鋼鐵俠手套!樹(shù)莓派+OpenCV 秒變手勢(shì)遙控器!

    大家好,這是一個(gè)樹(shù)莓派和OpenCV的連載專(zhuān)題。使用樹(shù)莓派與OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)使用樹(shù)莓派和OpenCV實(shí)現(xiàn)手部
    的頭像 發(fā)表于 08-16 16:16 ?893次閱讀
    零成本鋼鐵俠手套!樹(shù)莓派+<b class='flag-5'>OpenCV</b> 秒變手勢(shì)遙控器!

    如何使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)?

    大家好,這是一個(gè)樹(shù)莓派和OpenCV的連載專(zhuān)題。使用樹(shù)莓派與OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)使用樹(shù)莓派和OpenCV實(shí)現(xiàn)手部
    的頭像 發(fā)表于 08-14 17:45 ?983次閱讀
    如何使用樹(shù)莓派與<b class='flag-5'>OpenCV</b>實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)?

    如何使用樹(shù)莓派+OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤?

    大家好,這是一個(gè)樹(shù)莓派和OpenCV的連載專(zhuān)題。使用樹(shù)莓派與OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)使用樹(shù)莓派和OpenCV實(shí)現(xiàn)手部
    的頭像 發(fā)表于 08-13 17:44 ?991次閱讀
    如何使用樹(shù)莓派+<b class='flag-5'>OpenCV</b>實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤?

    如何板端編譯OpenCV并搭建應(yīng)用--基于瑞芯微米爾RK3576開(kāi)發(fā)板

    .. make-j8 可以首先測(cè)試下opencv環(huán)境是否正常 輸入 ./example_opencv即可打開(kāi)如上命令,證明系統(tǒng)的cv環(huán)境沒(méi)有問(wèn)題 性能測(cè)試 在hog測(cè)試dnn加速平均幀率10fps左右 8cpu已經(jīng)接近
    發(fā)表于 08-08 17:14

    ElfBoard技術(shù)貼|如何在【RK3588】ELF 2開(kāi)發(fā)板安裝openCV4以及第三方庫(kù)contrib

    應(yīng)用,不同項(xiàng)目對(duì)功能、性能等方面常有特定需求,開(kāi)發(fā)者可能需要使用其他版本的OpenCV,此時(shí)便需替換Buildroot的默認(rèn)配置。同時(shí),為滿足更復(fù)雜場(chǎng)景需求并擴(kuò)展功能,添加OpenCV的contrib
    的頭像 發(fā)表于 08-05 11:03 ?4316次閱讀
    ElfBoard技術(shù)貼|如何在【RK3588】ELF 2開(kāi)發(fā)板<b class='flag-5'>中</b>安裝<b class='flag-5'>openCV</b>4以及第三方庫(kù)contrib

    【Milk-V Duo S 開(kāi)發(fā)板免費(fèi)體驗(yàn)】SDK編譯、人臉檢測(cè)、OpenCV測(cè)試

    【Milk-V Duo S 開(kāi)發(fā)板免費(fèi)體驗(yàn)】SDK編譯、人臉檢測(cè)、OpenCV測(cè)試 本文介紹了 Milk-V Duo S 開(kāi)發(fā)板實(shí)現(xiàn) Buildroot SDK 鏡像編譯、基于 TDL 模型的人
    發(fā)表于 07-11 13:48

    itop-3568開(kāi)發(fā)板機(jī)器視覺(jué)opencv開(kāi)發(fā)手冊(cè)-圖像繪制-畫(huà)線

    demo11_line.py 然后向該文件添加以下內(nèi)容: 第 1 行和第 2 行分別導(dǎo)入了 opencv 和 numpy 庫(kù); 第 3 行使用 zeros()函數(shù)創(chuàng)建一個(gè) 512x512 的黑色圖片; 第 4 行使
    發(fā)表于 06-04 10:38

    在matlab如何計(jì)算含有第一類(lèi)修正的貝塞爾函數(shù)積分算不出的問(wèn)題?

    問(wèn)題摘要: 在matlab中計(jì)算含有第一類(lèi)修正的貝塞爾函數(shù)積分時(shí),出現(xiàn)了在部分值能計(jì)算出結(jié)果,部分值無(wú)法計(jì)算出結(jié)果的問(wèn)題。 一、變量定義: syms x y=1.0+1i*x; %積分
    發(fā)表于 05-19 16:53

    快速部署!米爾全志T527開(kāi)發(fā)板的OpenCV行人檢測(cè)方案指南

    本文將介紹基于米爾電子MYD-LT527開(kāi)發(fā)板(米爾基于全志T527開(kāi)發(fā)板)的OpenCV行人檢測(cè)方案測(cè)試。摘自?xún)?yōu)秀創(chuàng)作者-小火苗 一、軟件環(huán)境安裝1.在全志T527開(kāi)發(fā)板安裝OpenCV
    發(fā)表于 04-11 18:14

    為L(zhǎng)SDK構(gòu)建opencv時(shí)遇到的問(wèn)題求解

    我正在嘗試使用 flex-builder 來(lái)運(yùn)行 bld -c opencv -r ubuntu:桌面 我想要最新版本的 OpenCV。在我的 sdk.yml 文件,我將 opencv
    發(fā)表于 03-26 08:26

    詳解RTOS的Hook函數(shù)

    Hook函數(shù)是RTOS的一個(gè)關(guān)鍵特性,通過(guò)該函數(shù),用戶可以增強(qiáng)對(duì)任務(wù)管理的控制,定義系統(tǒng)行為。
    的頭像 發(fā)表于 03-24 16:14 ?844次閱讀

    運(yùn)算放大器積分電路分析

    的。 當(dāng)輸入信號(hào)是階躍直流電壓么時(shí),電容將以近似恒流的方式進(jìn)行充電,輸出電壓與時(shí)間成線性關(guān)系。即 例:在1的積分器的輸入端加入2給定輸入波形,畫(huà)出在此輸入波形作用下
    發(fā)表于 03-11 14:36

    使用OpenVINO?模型的OpenCV進(jìn)行人臉檢測(cè),檢測(cè)到多張人臉時(shí),伺服電機(jī)和步入器電機(jī)都發(fā)生移動(dòng)是為什么?

    使用OpenVINO?模型的 OpenCV* 進(jìn)行人臉檢測(cè)。 使用 cv2.矩形 函數(shù),能夠獲取檢測(cè)到的面部的坐標(biāo)。 檢測(cè)到多張人臉時(shí),多個(gè)坐標(biāo)被捕獲到,伺服電機(jī)和步入器電機(jī)都發(fā)生移動(dòng)。
    發(fā)表于 03-07 06:35

    運(yùn)放反相放大電路與積分電路反饋電阻和電容的作用

    詳細(xì)探討了運(yùn)放反相放大電路與積分電路反饋電阻和電容的作用。在反相放大電路,電容主要用于穩(wěn)定電路,減少高頻干擾,而電阻是主要的放大元件。在積分電路
    的頭像 發(fā)表于 03-01 14:55 ?5637次閱讀
    運(yùn)放反相放大電路與<b class='flag-5'>積分</b>電路<b class='flag-5'>中</b>反饋電阻和電容的作用

    AI模型部署邊緣設(shè)備的奇妙之旅:如何在邊緣端部署OpenCV

    () 函數(shù)加載圖像。 目的:為后續(xù)處理和分析準(zhǔn)備圖像數(shù)據(jù)。 轉(zhuǎn)換色彩空間 使用 cv2.cvtColor() 進(jìn)行色彩空間轉(zhuǎn)換。 目的:適應(yīng)不同算法的需求,例如灰度用于簡(jiǎn)化計(jì)算,HSV用于顏色分割等
    發(fā)表于 12-14 09:31