直线拟合 矩阵实现

转一篇矩阵做最小二乘法的贴子:https://blog.csdn.net/wuan584974722/article/details/53670878


对于我们孤立的点的集合,我们可以使用矩阵求最小二乘法最优解。

 //对于我们孤立的点的集合,我们可以使用矩阵求最小二乘法最优解。
    create_matrix(|ColumnEdageArr|,2,1,MatrixIDA)
    create_matrix(|ColumnEdageArr|,1,ColumnEdageArr,MatrixIDACol1)
    create_matrix(|ColumnEdageArr|,1,1,MatrixIDACol2)
    set_sub_matrix(MatrixIDA, MatrixIDACol1, 0, 0)
    set_sub_matrix(MatrixIDA, MatrixIDACol2, 0, 1)
    create_matrix(|ColumnEdageArr|,1,RowEdageArr,MatrixIDB)
    solve_matrix(MatrixIDA, 'general', 0, MatrixIDB, MatrixResultID)
    get_value_matrix(MatrixResultID,0, 0, linek)
    get_value_matrix(MatrixResultID,1, 0, lineb)
    create_matrix(|ColumnEdageArr|,1,ColumnEdageArr,MatrixIDACol1)
    create_matrix(|ColumnEdageArr|,1,1,MatrixIDACol2)
    set_sub_matrix(MatrixIDA, MatrixIDACol1, 0, 0)
    set_sub_matrix(MatrixIDA, MatrixIDACol2, 0, 1)
    create_matrix(|ColumnEdageArr|,1,RowEdageArr,MatrixIDB)
    solve_matrix(MatrixIDA, 'general', 0, MatrixIDB, MatrixResultID)
    get_value_matrix(MatrixResultID,0, 0, linek)
    get_value_matrix(MatrixResultID,1, 0, lineb)
    rowBegin:=ColBegin*linek+lineb
    rowEnd:=ColEnd*linek+lineb
   gen_contour_polygon_xld( ContourLine,[rowBegin,rowEnd],[ ColBegin,ColEnd])


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864