opencv學習筆記霍夫變換——直線檢測

来源:http://www.cnblogs.com/feifanrensheng/archive/2017/12/16/8047594.html
-Advertisement-
Play Games

參考大佬博文:blog.csdn.net/jia20003/article/details/7724530 lps-683.iteye.com/blog/2254368 openCV里有兩個函數(比較常用)處理霍夫變換直線檢測,有什麼區別呢。 CvHoughLine:是用於標準的霍夫變換方法 CvH ...


參考大佬博文:blog.csdn.net/jia20003/article/details/7724530

lps-683.iteye.com/blog/2254368

openCV里有兩個函數(比較常用)處理霍夫變換直線檢測,有什麼區別呢。

      CvHoughLine:是用於標準的霍夫變換方法

      CvHoughLine2:可以使用三種霍夫變換的方法,分別是標準霍夫變換(SHT)、多尺度標準霍夫變換(MSHT)、累計概率霍夫變換(PPHT)。

函數原型:

CvSeq* cvHoughLines2( CvArr* image, void* line_storage, int mehtod, double rho, double theta, int threshold, double param1 =0, double param2 =0 );

 

image 輸入 8-比特、單通道 (二值) 圖像,當用CV_HOUGH_PROBABILISTIC方法檢測的時候其內容會被函數改變。 line_storage 檢測到的線段存儲倉. 可以是記憶體存儲倉 (此種情況下,一個線段序列在存儲倉中被創建,並且由函數返回),或者是包含線段參數的特殊類型(見下麵)的具有單行/單列的矩陣(CvMat*)。矩陣頭為函數所修改,使得它的 cols/rows 將包含一組檢測到的線段。如果 line_storage 是矩陣,而實際線段的數目超過矩陣尺寸,那麼最大可能數目的線段被返回(線段沒有按照長度、可信度或其它指標排序). method Hough 變換變數,是下麵變數的其中之一: CV_HOUGH_STANDARD - 傳統或標準 Hough 變換. 每一個線段由兩個浮點數 (ρ, θ) 表示,其中 ρ 是直線與原點 (0,0) 之間的距離,θ 線段與 x-軸之間的夾角。因此,矩陣類型必須是 CV_32FC2 type. CV_HOUGH_PROBABILISTIC - 概率 Hough 變換(如果圖像包含一些長的線性分割,則效率更高). 它返回線段分割而不是整個線段。每個分割用起點和終點來表示,所以矩陣(或創建的序列)類型是 CV_32SC4. CV_HOUGH_MULTI_SCALE - 傳統 Hough 變換的多尺度變種。線段的編碼方式與 CV_HOUGH_STANDARD 的一致。 rho 與像素相關單位的距離精度 theta 弧度測量的角度精度 threshold 閾值參數。如果相應的累計值大於 threshold, 則函數返回這條線段. param1 第一個方法相關的參數: 對傳統 Hough 變換,不使用(0). 對概率 Hough 變換,它是最小線段長度. 對多尺度 Hough 變換,它是距離精度 rho 的分母 (大致的距離精度是 rho 而精確的應該是 rho / param1 ). param2 第二個方法相關參數: 對傳統 Hough 變換,不使用 (0). 對概率 Hough 變換,這個參數表示在同一條直線上進行碎線段連接的最大間隔值(gap), 即當同一條直線上的兩條碎線段之間的間隔小於param2時,將其合二為一。 對多尺度 Hough 變換,它是角度精度 theta 的分母 (大致的角度精度是 theta 而精確的角度應該是 theta / param2).
 1     #include <highgui.h>  
 2     #include <cv.h>  
 3     #include <math.h>  
 4       
 5     int main(int argc, char** argv)  
 6     {  
 7         IplImage* src;  
 8         src = cvLoadImage( argv[1], 0 ); //載入灰度圖  
 9         IplImage* dst = cvCreateImage( cvGetSize( src ), IPL_DEPTH_8U, 1 );  
10         IplImage* color_dst = cvCreateImage( cvGetSize( src ), IPL_DEPTH_8U, 3 );  //創建三通道圖像  
11         CvMemStorage* storage = cvCreateMemStorage(0);  
12         CvSeq* lines = 0;  
13         cvCanny( src, dst, 50, 100, 3 );  //首先運行邊緣檢測,結果以灰度圖顯示(只有邊緣)  
14         cvCvtColor( dst, color_dst, CV_GRAY2BGR ); //色彩空間轉換,將dst轉換到另外一個色彩空間即3通道圖像  
15         lines = cvHoughLines2( dst, storage, CV_HOUGH_PROBABILISTIC, 1, CV_PI/180, 80, 30, 10 ); //直接得到直線序列  
16       
17         //迴圈直線序列  
18         for( int i = 0; i < lines ->total; i++ )  //lines存儲的是直線  
19         {  
20             CvPoint* line = ( CvPoint* )cvGetSeqElem( lines, i );  //lines序列裡面存儲的是像素點坐標  
21             cvLine( color_dst, line[0], line[1], CV_RGB( 0, 255, 0 ) );  //將找到的直線標記為紅色  
22             //color_dst是三通道圖像用來存直線圖像  
23         }  
24         cvNamedWindow( "src", 1 );  
25         cvShowImage( "src", src );  
26         cvNamedWindow( "Hough", 1 );  
27         cvShowImage( "Hough", color_dst );  
28         cvWaitKey(0);  
29       
30         return 0;  
31     }  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • import queue from battle import commander # import math unit_client = commander.Client() doing_last_order = True towerid = [] towerrg = [] towerfr = [... ...
  • 一、filter()函數 filter()接收一個函數和一個序列。filter()把傳入的函數依次作用於每個元素,然後根據返回值是True還是False決定保留還是丟棄該元素。 filter()函數返回的是一個Iterator,也就是一個惰性序列,所以要強迫filter()完成計算結果,需要用lis ...
  • CSS 為了讓網頁元素的樣式更加豐富,也為了讓網頁的內容和樣式能拆分開,CSS由此思想而誕生,CSS是 Cascading Style Sheets 的首字母縮寫,意思是層疊樣式表。有了CSS,html中大部分表現樣式的標簽就廢棄不用了,html只負責文檔的結構和內容,表現形式完全交給CSS,htm ...
  • 定義: 為子系統中的一組介面提供一個一致的界面,Facade模式定義了一個高層介面,這個介面使得這一子系統更加容易使用。 角色: 1,外觀(Facade)角色 :客戶端可以調用這個角色的方法。此角色知曉相關子系統的功能和責任。在正常情況下,本角色會將所有從客戶端發來的請求委派到相應的子系統去。 2, ...
  • 一、map()函數 map()函數接收兩個參數,一個是函數,一個是Iterable,map將傳入的函數依次作用到序列的每個元素,並把結果作為新的Iterator返回。 二、reduce()函數 reduce把一個函數作用在一個序列[x1, x2, x3, ...]上,這個函數必須接收兩個參數,red ...
  • 一、2個概念: 1、變數可以指向函數本身 2、函數名也是變數 二、高階函數 一個函數可以接收另一個函數作為參數,這種函數就稱之為高階函數。 ...
  • 要求: 1.完成常識中的ATM存取款機功能 2.把ATM機故障考慮進去 3.不能直接輸入賬戶名和卡號等等信息,模擬出插銀行卡讓ATM機自動讀取卡信息 4.密碼驗證超過三次錯誤即鎖定賬戶 5.操作類型有:存款,取款,查詢,轉賬,列印憑條,退卡,一共六個選項,跟用戶輸入做出不同的反饋 6.當用戶正常進入 ...
  • 概述      java中的參數傳遞問題可以根據參數的類型大致可以分為三類:傳遞基本類型,傳遞String類型,傳遞引用類型,至於最終是否可以歸納為值傳遞和引用傳遞,根據每個人的理解不同,答案不同,此處不做強調。 傳遞基本類型 結果 :Before ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...