最小二乘法——线性回归

最小二乘法——线性回归

一、模型

y = k\cdot x+b

二、推理步骤

第一步:计算预测值与实际值之间的差异

e=y-(k\cdot x+b)

第二步:推广到多点,为了考虑计算的简便性,采用残差平方和作为模型的评价函数

E=\sum (y_{i}-k\cdot x_{i}-b)^{^{2}}

第三步:当E取最小值时,表示预测值与实际值最接近。凸函数的最小值通常在导数等于0处取得,因此,可以转换为:

\frac{dE}{db}=2*\sum (y_{i}-k\cdot x{_{i}}-b)(-1)

\frac{dE}{db}=-2*(n\bar{y}-nk\bar{x}-nb)

\frac{dE}{dk}=2*\sum (y_{i}-k\cdot x{_{i}}-b)(-x{_{i}})

\frac{dE}{dk}=-2*\sum (y_{i}x{_{i}}-kx_{i}^{2}-b{x_{i}})

\frac{dE}{db}=0\frac{dE}{dk}=0

\bar{y}-k\bar{x}=b      公式①

\sum y_{i}x{_{i}}-nk\sum x_{i}^{2}-nb\bar{x}=0      公式②

第四步:将公式①代入公式②得

k =\frac{\sum x_{i}y_{i}-n\bar{x}\bar{y}}{\sum x_{i}^{2}-n\bar{x}^{2}}

b=\bar{y}-k\bar{x}

三、C++实现

#include<Eigen\eigen>
#include<vector>
using namespace std;

/*Eigen*/
using Point2F = Eigen::Vector2f;
using Points2F = std::vector<Eigen::Vector2f>;
using Point3F = Eigen::Vector3f;
using Points3F = std::vector<Eigen::Vector3f>;
using Point2D = Eigen::Vector2d;
using Points2D = std::vector<Eigen::Vector2d>;
using Point3D = Eigen::Vector3d;
using Points3D = std::vector<Eigen::Vector3d>;

/*
Autor:Mosquitor
Date:2021-1-14
Function:2-D linear fit

k = (D0-D1)/(D2 - D3)
D0 = sum(x*y)
D1 = sum(x_mean*y_mean)
D2 = sum(x*x)
D3 = sum(x_mean*x_mean)

ParaInput[0]:2-D data,each row include(x,y)
ParaInput[1]:output result k;
ParaInput[2]:output result b;
*/
bool mosRM::linearFit2D(Points2D& inputData, double& k, double& b)
{
	if (inputData.size() < 2)
		return false;
	double D0(0.0), D1(0.0), D2(0.0), D3(0.0);
	double x_mean(0.0), y_mean(0.0);
	for (auto pt : inputData)
	{
		x_mean += pt[0];
		y_mean += pt[1];
		D0 += pt[0] * pt[1];
		D2 += pt[0] * pt[0];
	}
	x_mean /= inputData.size();
	D1 = x_mean*y_mean;
	D3 = x_mean*x_mean*inputData.size();
	y_mean /= inputData.size();
	if (D2 == D3)
	{
		k = 1;
		b = 0;
	}
	k = (D0 - D1) / (D2 - D3);
	b = y_mean - k*x_mean;
	return true;
}

 

 

 

 

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

点云登山者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值