最小二乘法直线拟合
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;
}
如图(要拟合的点)
如图(拟合后的直线)
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;
}
如图(要拟合的点)
如图(拟合后的直线)
相关文章推荐
- 最小二乘法拟合直线 c++程序
- 最小二乘法直线拟合
- 最小二乘法直线拟合
- 基于opencv的直线和曲线拟合与绘制(最小二乘法) (待测试)
- 最小二乘法直线拟合、圆拟合
- 最小二乘法直线拟合
- 最小二乘法拟合直线
- 算法+OpenCV】基于opencv的直线和曲线拟合与绘制(最小二乘法)
- 最小二乘法用于直线,多项式,圆,椭圆的拟合及程序实现(资料整理的非常全)
- 最小二乘法 拟合平面直线
- 最小二乘法拟合直线c++代码
- 拟合直线 二次函数曲线 最小二乘法 javascript(p5.js)
- 最小二乘法拟合直线公式推导及vc实现[转]
- 最小二乘法直线拟合
- C#最小二乘法直线拟合算法
- 【算法研究与实现】最小二乘法直线拟合
- 最小二乘法拟合直线
- python最小二乘法拟合直线
- 牛顿迭代法和最小二乘法直线拟合代码
- 最小二乘法拟合直线