ITPub博客

首页 > IT职业 > IT生活 > 最小二乘法直线拟合 (转)

最小二乘法直线拟合 (转)

原创 IT生活 作者:worldblog 时间:2007-12-03 10:48:40 0 删除 编辑
最小二乘法直线拟合 (转)[@more@]

//最小二乘法直线拟合
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;
}


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-987576/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
  • 博文量
    6241
  • 访问量
    2404239