您的位置:首页 > 其它

最小二乘法直线拟合

2012-05-22 20:41 295 查看
//最小二乘法直线拟合

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;

}

如图(要拟合的点)



如图(拟合后的直线)

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  null