原创 最小二乘法直线拟合收藏

新一篇: 最小二乘法曲线拟合 | 旧一篇: 优化了的过关键点的光滑曲线拟合算法

//最小二乘法直线拟合
BOOL CalculateLineKB(CFoldPointList *m_FoldList,double &k,double &b)
{
 //最小二乘法直线拟合
 //m_FoldList为关键点(x,y)的链表
 //拟合直线方程(Y=kX+b)


 if(m_FoldList==NULL)return FALSE;
 long lCount=m_FoldList->GetCount();
 if(lCount<2)return FALSE;
 CFoldPoint *pFold;
 double mX,mY,mXX,mXY,n;
 mX=mY=mXX=mXY=0;
 n=lCount;
 POSITION pos=m_FoldList->GetHeadPosition();
 while(pos != NULL)
 {
  pFold=m_FoldList->GetNext(pos);
  mX+=pFold->X;
  mY+=pFold->Y;
  mXX+=pFold->X*pFold->X;
  mXY+=pFold->X*pFold->Y;
 }
 if(mX*mX-mXX*n==0)return FALSE;
 k=(mY*mX-mXY*n)/(mX*mX-mXX*n);
 b=(mY-mX*k)/n;
 return TRUE;
}

发表于 @ 2000年12月22日 03:13:00|评论(loading...)|编辑

新一篇: 最小二乘法曲线拟合 | 旧一篇: 优化了的过关键点的光滑曲线拟合算法

评论

#zheng2002@21cn.com 发表于2005-01-10 09:20:00  IP: 202.116.134.*
如果图像提取的点中有几条直线,那么怎么用直线拟合算法呢,谢谢!
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © breath