机器学习笔记一

摘要

本周回顾了线性模型的基本概念以及训练方法,并进行代码实操。从设立模型开始并进行optimization,经过50轮的运行得到最终结果。

abstract

This week, we reviewed the basic concepts of linear models and training methods, and conducted hands-on coding practice. We started by setting up the model and performing optimization, and after 50 rounds of running, we obtained the final results.

一、线性模型

线性模型是一种假设输出与输入特征之间存在线性关系的机器学习模型。就是用一条直线来拟合数据。模型的训练方法如下图所示

本次的数据集为学习时长1, 2, 3, 4, 5, 6, 7, 8, 9, 10与考试分数50, 55, 60, 68, 72, 75, 80, 85, 88, 95

python 复制代码
# X:学习时长
X = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
# y:考试分数
y = np.array([50, 55, 60, 68, 72, 75, 80, 85, 88, 95])

二、训练

二.1 、初始化参数

根据数据集的数据分布情况可以初步推断学习时长与考试分数之间存在线性关系因此设:**y=wX+b。**初始斜率以及截距为0,每次更新的步幅为0.1,训练50次停止。选择MSE用于计算loss

python 复制代码
w = 0.0    # 斜率:初始=0
b = 0.0    # 截距:初始=0
lr = 0.1   # 学习率:每次更新的步长
epochs = 50  # 训练 50 次

二.2、训练

1step,将X带入到模型中得到预测值y_pred

python 复制代码
y_pred = w * X_norm + b

2step,计算loss =

python 复制代码
loss = np.mean((y_pred - y_norm) ** 2)

3step,optimization

首先求解loss对w的偏微分及及对(y-y_pred)^2进行求导,其中y视为常数。同理可得db

python 复制代码
dw = np.mean(2 * X_norm * (y_pred - y_norm))
db = np.mean(2 * (y_pred - y_norm))

进行更新

python 复制代码
w = w - lr * dw
b = b - lr * db

三,实验结果

经过50轮的更新得到:y = 4.85 × X + 46.13

相关推荐
KaMeidebaby1 天前
卡梅德生物技术快报|PD1 单克隆抗体定制配套 N 糖全谱质控开发
前端·人工智能·算法·数据挖掘·数据分析
8Qi81 天前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
bIo7lyA8v1 天前
算法稳定性分析中的随机扰动建模的技术8
算法
科研online1 天前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy1 天前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯1 天前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
疯狂打码的少年1 天前
中断处理过程与中断优先级
笔记
VkN2X2X4b1 天前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术1 天前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi81 天前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包