那曲檬骨新材料有限公司

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

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

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

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

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

直線擬合原理

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

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

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

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

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

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

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

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

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

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

points是輸入點集合

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

distType是選擇距離計算方式

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

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

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

六種權(quán)重的計算更新實現(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得到的結(jié)果如下:

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




審核編輯:劉清

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

    關(guān)注

    23

    文章

    4630

    瀏覽量

    93365
  • 最小二乘法
    +關(guān)注

    關(guān)注

    0

    文章

    22

    瀏覽量

    8478
  • OpenCV
    +關(guān)注

    關(guān)注

    31

    文章

    635

    瀏覽量

    41563
收藏 人收藏

    評論

    相關(guān)推薦

    matlab直線擬合案例的尋找

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

    【每周練】擬合公式

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

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

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

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

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

    ransac擬合直線擬合平面

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

    【設(shè)計技巧】rtos的核心原理

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

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

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

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

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

    直線擬合求解的推導(dǎo)過程

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

    EPON技術(shù)

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

    鼠標(biāo)HID例程()

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

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

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

    OpenCV直線擬合

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

    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 ?701次閱讀
    AFE8092幀同步特性<b class='flag-5'>簡</b><b class='flag-5'>析</b>
    A8百家乐官网娱乐| 百家乐博彩优惠论坛| 百家乐的奥秘| 大发888在线| 霍邱县| 任你博百家乐官网的玩法技巧和规则| 百家乐设备电子路| 网上百家| 百家乐官网赌博规| 哪家百家乐最好| 长治县| 做生意门面朝向风水| 威尼斯人娱乐欢迎您| 奉贤区| 百家乐咋个玩的| 现金网系统出租| 百家乐官网赌场论坛博客| 百家乐真钱游戏下载| 大发888游戏下载投注| 百家乐官网玩法开户彩公司| 澳门百家乐赌技术| 云博国际| 八大胜百家乐官网的玩法技巧和规则 | 百家乐官网顺序| 百家乐投住系统| 太阳城在线| 百家乐稳赢赌法| 香港六合彩网址| 新世纪百家乐官网的玩法技巧和规则| 威尼斯人娱乐代理注册| 百家乐官网最好打法与投注| 玩百家乐输澳门百家乐现场| 新全讯网网址112| 百家乐官网赌博破解方法| 环球百家乐娱乐城| 百家乐官网真人游戏网上投注 | 足球百家乐官网投注网出租| 大发888赢钱技巧| 百家乐官网大娱乐场开户注册 | 九州百家乐官网的玩法技巧和规则 | 湖南省|