一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

OpenCV中的直線擬合

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

掃碼添加小助手

加入工程師交流群

直線擬合原理

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

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

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

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

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

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

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

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

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

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

void cv::fitLine(         InputArray    points,         OutputArray   line,         int   distType,         double    param,         double    reps,         double    aeps)

points是輸入點(diǎn)集合

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

distType是選擇距離計(jì)算方式

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

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

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

六種權(quán)重的計(jì)算更新實(shí)現(xiàn)如下:

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


for(i=0;i

擬合計(jì)算的代碼實(shí)現(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

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

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

審核編輯:彭靜
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)注

    8

    文章

    671

    瀏覽量

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

    關(guān)注

    3

    文章

    4380

    瀏覽量

    64844
  • OpenCV
    +關(guān)注

    關(guān)注

    32

    文章

    642

    瀏覽量

    42872

原文標(biāo)題:OpenCV中直線擬合方法解密

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    一文簡(jiǎn)析OpenCV直線擬合方法

    其中DIST_L2是最原始的最小二乘,最容易翻車的一種擬合方式,雖然速度快點(diǎn)。
    的頭像 發(fā)表于 08-26 10:33 ?6557次閱讀

    matlab直線擬合案例的尋找

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

    FPGA怎么實(shí)現(xiàn)最小二乘法擬合直線呢?

    特權(quán)老師你好用數(shù)字電路去實(shí)現(xiàn)最小二乘法的擬合直線‘缺少這方面的設(shè)計(jì)經(jīng)驗(yàn)’有沒(méi)有相關(guān)的思路推薦‘或者相關(guān)資料介紹’謝謝!
    發(fā)表于 05-18 20:04

    【每周一練】擬合公式

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

    請(qǐng)問(wèn)如何對(duì)數(shù)組的數(shù)求擬合直線

    `求數(shù)組的數(shù)最靠近的那個(gè)值,也就是這條直線,該用哪種工具呢?`
    發(fā)表于 01-26 13:31

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

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

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

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

    求教三維離散點(diǎn)的直線擬合,請(qǐng)問(wèn)擬合三維的數(shù)據(jù)xyz成一條空間直線?

    本帖最后由 一只耳朵怪 于 2018-6-4 09:09 編輯 怎么像圖片那樣擬合三維的數(shù)據(jù)xyz成一條空間直線希望數(shù)據(jù)是給定的額 就通過(guò)控件輸入求大神幫幫忙啊 萬(wàn)分感謝!??!
    發(fā)表于 06-04 08:51

    ransac擬合直線擬合平面

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

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

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

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

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

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

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

    怎樣去實(shí)現(xiàn)基于MATLAB的最小二乘直線擬合的代碼呢

    最小二乘直線擬合的推導(dǎo)過(guò)程是怎樣的?怎樣去實(shí)現(xiàn)基于MATLAB的最小二乘直線擬合的代碼呢?
    發(fā)表于 11-22 06:43

    對(duì)于形狀近似矩形但邊緣有規(guī)則起伏的情況,可以使用OpenCV庫(kù)的approxPolyDP函數(shù)進(jìn)行多邊形擬合和矩形檢測(cè)。

    對(duì)于形狀近似矩形但邊緣有規(guī)則起伏的情況,可以使用OpenCV庫(kù)的approxPolyDP函數(shù)進(jìn)行多邊形擬合和矩形檢測(cè)。 approxPolyDP函數(shù)通過(guò)在給定的點(diǎn)集上使用動(dòng)態(tài)規(guī)劃算法,計(jì)算出近似
    發(fā)表于 11-01 09:23

    OpenCV進(jìn)行橢圓擬合的程序免費(fèi)下載

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