代数与逻辑:作业一 线性模型

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: 代数与逻辑作业一,了解学习有关线性模型相关知识。

一、作业要求

  1. 简述线性回归模型的数学表达与物理意义,举例说明。
  2. 编程实现线性回归模型的求解(最小二乘法与梯度下降法)。
  3. 选择公开数据集,编程实现利用线性回归模型进行预测建模。注:数据集选择回归问题数据集,先对数据进行规范化处理,然后选择部分数据训练模型,剩余数据对模型进行测试,重复20次数据集划分,输出平均预测精度。

二、回归模型的数学表达式与物理意义

1、什么是线性回归?

线性回归是一种算法,它提供自变量和因变量之间的线性关系来预测未来事件的结果。它是一种在数据科学和机器学习中用于预测分析的统计方法。

自变量也是由于其他变量的变化而保持不变的预测变量或解释变量。但是,因变量会随着自变量的波动而变化。回归模型预测因变量的值,即被分析或研究的响应或结果变量。

因此,线性回归是一种监督学习算法,它模拟变量之间的数学关系,并对销售、工资、年龄、产品价格等连续或数值变量进行预测。

当数据中至少有两个变量可用时,这种分析方法是有利的,如在股票市场预测、投资组合管理、科学分析等中所观察到的。

倾斜的直线代表线性回归模型。

image-20221019112332371.png

在上图中,x轴是自变量,y轴是输出/因变量,回归线是模型的最佳拟合线,在这里,为适合所有问题的给定数据点绘制了一条线。因此,它被称为“最佳拟合线”。线性回归算法的目标是找到上图中看到的最佳拟合线。

2、线性回归方程

线性回归线具有Y = a + bX形式的方程,其中X是解释变量,Y是因变量。直线的斜率为ba是截距( x = 0 时y的值)。

举个例子,我们考虑一个涵盖RAM 大小及其相应成本的数据集。

在这种情况下,数据集包含两个不同的特征:内存(容量)和成本。RAM 越多,RAM 的购买成本就越高。

Ram Capacity Cost
2 GB $12
4 GB $16
8 GB $28
16 GB $62

如果我们在 X 轴上绘制 RAM,在 Y 轴上绘制其成本,则从图表的左下角到右上角的线表示 X 和 Y 之间的关系。在散点图上绘制这些数据点,我们得到下图:

散点图.png

内存成本比可能会根据不同的制造商和RAM版本而有所不同,但数据趋势显示出规律。左下角的数据显示内存更小且价格更低的 RAM,这条线一直延伸到图表的右上角,其中 RAM 容量更大且成本更高)。

回归模型定义了 X 和 Y 变量之间的线性函数,可以最好地展示两者之间的关系。它由上图中的斜线表示,其目标是确定最适合所有单个数据点的最佳“回归线”。

三、线性回归模型的求解

1、最小二乘法

我们定义一个数据集,其中每个特征x都有一个响应值y。

python-linear-regression.png

回归方程表示:

h(xi)=β01xi

其中h(x_i)表示第i个观察的预测响应值,b_0和b_1是回归系数,分别代表回归线的y截距和斜率。

使用最小二乘法原理我们需要考虑

image-20221019192320981.png

这里,e_i 是第 i 个观察中的残差。 因此,我们的目标是最小化总残差。我们将平方误差或成本函数 J 定义为:

image-20221019192343547.png

我们的任务是找到 b_0 和 b_1 的值,其中 J(b_0,b_1) 最小。

image-20221019192419469.png

其中 SS_xy 是 y 和 x 的交叉偏差之和:

image-20221019192437085.png

SS_xx 是 x 的平方偏差之和:

image-20221019192455138.png

上述问题用python实现:

importnumpyasnpimportmatplotlib.pyplotaspltdefestimate_coef(x, y):
# 观察次数/点数n=np.size(x)
# x 和 y 向量的平均值m_x=np.mean(x)
m_y=np.mean(y)
# 计算关于 x 的交叉偏差和偏差SS_xy=np.sum(y*x) -n*m_y*m_xSS_xx=np.sum(x*x) -n*m_x*m_x# 计算回归系数b_1=SS_xy/SS_xxb_0=m_y-b_1*m_xreturn (b_0, b_1)
defplot_regression_line(x, y, b):
# 将实际点绘制为散点图plt.scatter(x, y, color="m",
marker="o", s=30)
# 预测响应向量y_pred=b[0] +b[1]*xplt.plot(x, y_pred, color="g")
plt.xlabel('x')
plt.ylabel('y')
plt.show()
defmain():
# 观察/数据x=np.array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
y=np.array([1, 3, 2, 5, 7, 8, 8, 9, 10, 12])
# 估计系数b=estimate_coef(x, y)
print("估计系数:\nb_0 = {} \        \nb_1 = {}".format(b[0], b[1]))
# 绘制回归线plot_regression_line(x, y, b)
if__name__=="__main__":
main()

运行的结果是:

估计系数:
b_0=1.2363636363636363b_1=1.1696969696969697

image-20221019192953015.png

2、梯度下降法

我们将逐步迭代以达到最佳点。W 从任意的权重值开始,并检查该点的梯度。我们的目标是达到谷底的最小值。所以我们的梯度应该总是负的。

1HrFZV7pKPcc5dzLaWvngtQ.png

接下来,我们需要更新权重以使它们更接近最小值。我们有以下等式:

image-20221019222237644.png

这意味着下一次迭代中的权重将是上一次迭代中的权重减去更新。现在这个更新有两个组成部分:方向——斜率或梯度,以及——步长。渐变将是:

image-20221019222301679.png

我们需要考虑的第二个组成部分是步长——α。这是一个超参数,我们需要在算法开始之前决定它。如果 α 太大,那么我们的优化器将大跃进,永远找不到最小值。相反,如果将它设置得太小,优化器将永远达到最小值。因此,我们需要事先为 α 设置一个最佳值。

因此,我们的权重更新方程变为:

image-20221019222408007.png

总的步骤就是:

  1. 初始化权重 W0、W1 的值——可以是任意值,步长 α——需要一个好的值。
  2. 找到所有 X 的目标 Ŷ = W0 + W1.X 的预测。
  3. 计算误差值 (Ŷ-Y) 和 MSE。
  4. 根据梯度下降更新规则更新权重。
  5. 重复 2-4。

上述工作我们用Python来实现一下:

importnumpyasnpimportmatplotlib.pyplotasplt# 定义数据集x=np.array([1, 3, 5])
y=np.array([5, 12, 18])
# 初始化权重和选择步长W0_new=0W1_new=0a=0.04MSE=np.array([])
# 对数据集进行多次迭代,计算每次迭代的均方误差并更新权重foriterationinrange(1, 11):
y_pred=np.array([])   # 预测目标error=np.array([])    # 每次迭代的误差值:(Ŷ-Y)error_x=np.array([])
# 分配更新的权重W0=W0_newW1=W1_new# 逐行迭代x,以计算Ŷ和错误foriinx:
# Ŷ = W0 + W*Xy_pred=np.append(y_pred, (W0+W1*i))
error=np.append(error, y_pred-y)      # 计算每个样本的误差error_x=np.append(error_x, error*x)
MSE_val= (error**2).mean()     # 计算MSE值MSE=np.append(MSE, MSE_val)
W0_new=W0-a*np.sum(error)       # 计算更新W0W1_new=W1-a*np.sum(error_x)     # 计算更新W1# 查看最终权重   print("W0=", W0_new)
print("W1=", W1_new)
# 检查预测的目标变量Ŷ和误差print("y_pred:", y_pred)
print("error:", error)
# 绘制每次迭代的均方误差值print("MSE:", MSE)
plt.plot(MSE, "b-o")
plt.title("每次迭代的均方误差")
plt.xlabel("迭代")
plt.ylabel("MSE 值")
plt.show()

运行的结果是:

image-20221019223816083.png

W0=1.1474479185822484W1=3.448230314024035y_pred: [ 4.592384411.5179494918.44351457]
error: [-0.4076156-0.482050510.44351457]
MSE: [164.3333333340.3546666710.054223362.643047650.82490950.373717240.256870490.22205110.207591940.19840945]

四、利用线性回归模型进行预测建模

我们将使用 scikit-learn 中提供的加利福尼亚房价集。这记录了加州住房市场的 8 个属性以及中位价格的测量值。

1、导入依赖项

importpandasaspdfromsklearnimportdatasets, linear_modelfromsklearn.model_selectionimporttrain_test_splitfrommatplotlibimportpyplotasplt

2、加载数据集,将其转换为数据框并定义列名

# 加载糖尿病数据集columns="age sex bmi map tc ldl hdl tch ltg glu".split() # 声明列名diabetes=datasets.load_diabetes() # 从 sklearn 调用糖尿病数据集df=pd.DataFrame(diabetes.data, columns=columns) # 将数据集加载为 pandas 数据框y=diabetes.target# 将目标变量(因变量)定义为 y

3、定义训练集和测试集

# 创建训练和测试变量X_train, X_test, y_train, y_test=train_test_split(df, y, test_size=0.2)
print(X_train.shape, y_train.shape)
print(X_test.shape, y_test.shape)
(353, 10) (353,)
(89, 10) (89,)

4、拟合模型

# 拟合模型lm=linear_model.LinearRegression()
model=lm.fit(X_train, y_train)
predictions=lm.predict(X_test)

5、预测

print(predictions[0:5])
[181.69402001151.31483349159.42134908188.13122001168.83426575]

6、绘制模型

plt.scatter(y_test, predictions)
plt.xlabel("True Values")
plt.ylabel("Predictions")

image-20221019235542937.png

7、打印准确度

print("Score:", model.score(X_test, y_test))

8、计算平均预测精度

我们运行20次然后记录每次的精度然后求平均值。

fromnumpyimport*score= [0.5435576684039353, 0.5278223090263431, 0.5428586295068993, 0.48953519457408035, 0.4249912062254072, 0.42650991893500434, 0.5787191615733711, 0.37981926356039364, 0.4170187886884227, 0.5082912328753193/0.5202580979798506, 0.532535890174009, 0.3087861414400682, 0.4466007206335131, 0.460212035904611, 0.40788387790519776, 0.5631222570259837, 0.5183668561533962, 0.4256938089725384, 0.4183517892689459]
mean_score=mean(score)
print(mean_score)

平均值是:

0.49417809118980843


相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
8月前
【代数学作业5】理想的分解:高斯整数环中理想的结构,并根据其范数和素数的性质进行分解
【代数学作业5】理想的分解:高斯整数环中理想的结构,并根据其范数和素数的性质进行分解
119 0
|
8月前
|
机器学习/深度学习 人工智能 算法
【代数学作业1-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
【代数学作业1-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
144 0
|
8月前
【视频】什么是非线性模型与R语言多项式回归、局部平滑样条、 广义相加GAM分析工资数据|数据分享(上)
【视频】什么是非线性模型与R语言多项式回归、局部平滑样条、 广义相加GAM分析工资数据|数据分享
|
5月前
【随机过程】课后作业 1-条件概率期望密度
本文提供了随机过程课后作业的解答示例,涉及泊松分布、卡方分布等概率论概念的计算题。
51 3
|
2月前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。
|
5月前
|
机器学习/深度学习 数据处理 Python
深入理解双变量(二元)正态投影:理论基础、直观解释与应用实例
本文探讨了统计学与机器学习中的二元投影技术,它基于二元正态分布,用于预测一个变量在给定另一变量值时的期望值。文章分为三部分:首先介绍了二元正态投影的基本公式及其在回归中的应用;接着通过直观解释和模拟展示了不同相关性下变量间的关系;最后运用投影公式推导出线性回归的参数估计,并通过实例说明其在预测房屋价格等场景中的应用。附录中详细推导了二元线性投影的过程。二元投影作为一种强大工具,在数据分析中帮助简化复杂问题并揭示数据背后的规律。
70 1
深入理解双变量(二元)正态投影:理论基础、直观解释与应用实例
|
7月前
|
算法 调度
基于PPNSA+扰动算子的车间调度最优化matlab仿真,可以任意调整工件数和机器数,输出甘特图
`MATLAB2022a`仿真实现PPNSA+扰动算子的车间调度优化,支持工件和机器数量调整,输出甘特图与收敛曲线。算法针对JSSP,采用启发式策略应对NP难问题,最小化最大完工时间。[图:算法流程示意图]
|
8月前
【视频】什么是非线性模型与R语言多项式回归、局部平滑样条、 广义相加GAM分析工资数据|数据分享(下)
【视频】什么是非线性模型与R语言多项式回归、局部平滑样条、 广义相加GAM分析工资数据|数据分享
|
算法 调度 决策智能
【两阶段鲁棒优化】利用列-约束生成方法求解两阶段鲁棒优化问题(Python代码实现)
【两阶段鲁棒优化】利用列-约束生成方法求解两阶段鲁棒优化问题(Python代码实现)
368 0
【两阶段鲁棒优化】利用列-约束生成方法求解两阶段鲁棒优化问题(Python代码实现)
|
8月前
R语言工具变量与两阶段最小二乘法
R语言工具变量与两阶段最小二乘法

热门文章

最新文章

下一篇
开通oss服务