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

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

3天內不再提示

一文簡析OpenCV中的直線擬合方法

OpenCV學堂 ? 來源:OpenCV學堂 ? 作者:gloomyfish ? 2022-08-26 10:33 ? 次閱讀

直線擬合原理

給出多個點,然后根據(jù)這些點擬合出一條直線,這個最常見的算法是多約束方程的最小二乘擬合,如下圖所示:

553374ee-247e-11ed-ba43-dac502259ad0.png

但是當這些點當中有一個或者幾個離群點(outlier)時候,最小二乘擬合出來的直線就直接翻車成這樣了:

5540a952-247e-11ed-ba43-dac502259ad0.png

原因是最小二乘無法在估算擬合的時候剔除或者降低離群點的影響,于是一個聰明的家伙出現(xiàn)了,提出了基于權重的最小二乘擬合估算方法,這樣就避免了翻車。根據(jù)高斯分布,離群點權重應該盡可能的小,這樣就可以降低它的影響,OpenCV中的直線擬合就是就權重最小二乘完成的,在生成權重時候OpenCV支持幾種不同的距離計算方法,分別如下:

554ee292-247e-11ed-ba43-dac502259ad0.png

其中DIST_L2是最原始的最小二乘,最容易翻車的一種擬合方式,雖然速度快點。然后用基于權重的最小二乘估算擬合結果如下:

5562bae2-247e-11ed-ba43-dac502259ad0.png

函數(shù)與實現(xiàn)源碼分析

OpenCV中直線擬合函數(shù)支持上述六種距離計算方式,函數(shù)與參數(shù)解釋如下:

points是輸入點集合

line是輸出的擬合參數(shù),支持2D與3D

distType是選擇距離計算方式

param 是某些距離計算時生成權重需要的參數(shù)

reps 是前后兩次原點到直線的距離差值,可以看成擬合精度高低

aeps是前后兩次角度差值,表示的是擬合精度

六種權重的計算更新實現(xiàn)如下:

staticvoidweightL1(float*d,intcount,float*w)
{
inti;


for(i=0;i

擬合計算的代碼實現(xiàn):

staticvoidfitLine2D_wods(constPoint2f*points,intcount,float*weights,float*line)
{
CV_Assert(count>0);
doublex=0,y=0,x2=0,y2=0,xy=0,w=0;
doubledx2,dy2,dxy;
inti;
floatt;

//Calculatingtheaverageofxandy...
if(weights==0)
{
for(i=0;i

案例:直線擬合

有如下的原圖:

55781784-247e-11ed-ba43-dac502259ad0.png

通過OpenCV的距離變換,骨架提取,然后再直線擬合,使用DIST_L1得到的結果如下:

558a2ad2-247e-11ed-ba43-dac502259ad0.png




審核編輯:劉清

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

    關注

    23

    文章

    4588

    瀏覽量

    92511
  • 最小二乘法
    +關注

    關注

    0

    文章

    22

    瀏覽量

    8432
  • OpenCV
    +關注

    關注

    29

    文章

    625

    瀏覽量

    41215
收藏 人收藏

    評論

    相關推薦

    matlab直線擬合案例的尋找

    由于短時間內要用matlab進行直線擬合,可是我不會,而且就算編好程序后,這種界面我也不會。希望好心人指點!
    發(fā)表于 12-16 13:27

    【每周練】擬合公式

    使用方法:根據(jù)data.xlsxX與Y求出最佳直線,僅限于直線。用途:比如PT100傳感器,氣壓傳感器,位移傳感器等線性傳感器,測出電壓或電阻與真實值的關系,寫入data.xlsx
    發(fā)表于 12-24 00:17

    為什么用線性擬合出來的最佳線性擬合的的波形圖與原來直線的斜率不樣?

    我用線性擬合擬合一直線,線性擬合VI的最佳線性擬合形成的波形圖的斜率和它所產生的斜率不
    發(fā)表于 06-07 00:33

    Labview線性擬合時如何指定最終擬合直線的斜率?

    如題,使用線性擬合VI時為何設定的斜率上下限沒有起到作用?我想用組已知數(shù)據(jù)擬合一條斜率固定的直線,該如何實現(xiàn)?求大神指點?也可用Matlab程式實現(xiàn)。以下是我自己寫的
    發(fā)表于 04-03 20:09

    ransac擬合直線擬合平面

    ransac擬合直線和平面(matlab版本)
    發(fā)表于 03-26 07:48

    【設計技巧】rtos的核心原理

    rtos的核心原理rtos全稱real-time operating system(實時操作系統(tǒng)),我來簡單分析下:我們都知道,c語句中調用個函數(shù)后,該函數(shù)的返回地址都是放在堆棧
    發(fā)表于 07-23 08:00

    使用MXNet擬合直線簡潔實現(xiàn)

    [MXNet逐夢之旅]練習二·使用MXNet擬合直線簡潔實現(xiàn)
    發(fā)表于 05-26 14:46

    練習·使用MXNet擬合直線手動實現(xiàn)

    [MXNet逐夢之旅]練習·使用MXNet擬合直線手動實現(xiàn)
    發(fā)表于 06-10 15:39

    直線擬合求解的推導過程

    (1)求解的推導過程:最小二乘擬合直線的推導過程如下:假設直線方程為:設有n對觀測值(xi,yi),則列出如下方程:整理得:其中A、EA、L的表達式如下:最后解算直線
    發(fā)表于 08-18 08:04

    EPON技術

    EPON技術 EPON是個新技術,用于保證提供個高品質與高帶寬利用率的應用。   EPON在日本、韓國、中國大陸、中國臺灣及其它以以太網絡為基礎的地區(qū)都
    發(fā)表于 01-22 10:43 ?852次閱讀

    鼠標HID例程()

    鼠標 HID 例程 緊接《鼠標 HID 例程(上)》,繼續(xù)向大家介紹鼠 標 HID
    發(fā)表于 07-26 15:18 ?0次下載

    OpenCV進行橢圓擬合的程序免費下載

    本文檔的主要內容詳細介紹的是OpenCV進行橢圓擬合的程序免費下載。
    發(fā)表于 10-12 14:58 ?4次下載

    OpenCV直線擬合

    給出多個點,然后根據(jù)這些點擬合直線,這個最常見的算法是多約束方程的最小二乘擬合,如下圖所示:
    的頭像 發(fā)表于 08-26 10:36 ?3141次閱讀

    5G AAU 功放控制和監(jiān)測模塊

    5G AAU 功放控制和監(jiān)測模塊
    發(fā)表于 10-28 12:00 ?2次下載
    5G AAU 功放控制和監(jiān)測模塊<b class='flag-5'>簡</b><b class='flag-5'>析</b>

    AFE8092幀同步特性

    AFE8092幀同步特性
    的頭像 發(fā)表于 08-24 13:37 ?615次閱讀
    AFE8092幀同步特性<b class='flag-5'>簡</b><b class='flag-5'>析</b>