sklearn -- 梯度下降法

梯度下降法

梯度下降法的基本思想可以类比为一个下山的过程。假设这样一个场景:一个人被困在山上,需要从山上下来(i.e. 找到山的最低点,也就是山谷)。但此时山上的浓雾很大,导致可视度很低。因此,下山的路径就无法确定,他必须利用自己周围的信息去找到下山的路径。这个时候,他就可以利用梯度下降算法来帮助自己下山。具体来说就是,以他当前的所处的位置为基准,寻找这个位置最陡峭的地方,然后朝着山的高度下降的地方走,同理,如果我们的目标是上山,也就是爬到山顶,那么此时应该是朝着最陡峭的方向往上走。然后每走一段距离,都反复采用同一个方法,最后就能成功的抵达山谷。

在这里插入图片描述

多元线性回归模型

在这里插入图片描述

损失函数

在这里插入图片描述

批量梯度下降法

在将训练数据集代入损失函数f 中,得到 参数变量 W 和 损失函数f的函数关系,在迭代过程中 使用 f在 W处的梯度 和W = W - ▽ · ε 公式,不断减小损失函数,直至找到最小的损失函数所对应的参数 W。

批量梯度下降法梯度

在这里插入图片描述

随机梯度下降法

将训练数据集中随机一条数据代入损失函数f 中,得到 参数变量 W 和 损失函数f的函数关系,在迭代过程中 使用 f在 W处的梯度 和W = W - ▽ · ε 公式,不断减小损失函数,直至找到最小的损失函数所对应的参数 W。

随机梯度

在这里插入图片描述

随机批量梯度下降法

为了进一步提升收敛速度。每次从数据集中随机选取一批数据训练模型,克服随机梯度下降法中模型对异常数据过度敏感。

python 代码
from sklearn.linear_model import SGDRegressor
from sklearn.preprocessing import StandardScaler
standardScaler = StandardScaler()
X_train_sta = standardScaler.transform(X_train)
X_test_sta = standardScaler.transform(X_test)
sgd_reg = SGDRegressor(n_iter=100000)
sgd_reg.fit(X_train_sta,y_train)
sgd_reg.score(X_test_sta,y_test)
#0.7102320877365798
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,我们需要准备数据集。这里我们使用sklearn中的波士顿房价数据集。代码如下: ```python from sklearn.datasets import load_boston import numpy as np data = load_boston() X = data["data"] y = data["target"] ``` 其中,`X`是13个特征的向量,`y`是相应的房价。下一步是对数据进行归一化处理,保证特征权重的一致性。 ```python from sklearn.preprocessing import StandardScaler scaler = StandardScaler() X = scaler.fit_transform(X) ``` 接下来,我们构建线性回归模型,使用梯度下降法进行训练。具体实现过程如下: ```python class LinearRegression: def __init__(self, alpha=0.01, iterations=1000): self.alpha = alpha # 学习率 self.iterations = iterations # 迭代次数 def fit(self, X, y): m, n = X.shape self.theta = np.zeros(n+1) # 初始化权重 X = np.insert(X, 0, 1, axis=1) # 添加截距项 for i in range(self.iterations): h = np.dot(X, self.theta) # 计算预测值 loss = h - y # 计算误差 gradient = np.dot(X.T, loss) / m # 计算梯度 self.theta -= self.alpha * gradient # 更新权重 def predict(self, X): X = np.insert(X, 0, 1, axis=1) # 添加截距项 return np.dot(X, self.theta) # 返回预测值 ``` 在以上代码中,`fit`方用来训练模型,`predict`方用来进行预测。使用该模型对波士顿房价数据进行训练和预测,代码如下: ```python from sklearn.model_selection import train_test_split X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42) lr = LinearRegression(alpha=0.01, iterations=10000) lr.fit(X_train, y_train) y_pred = lr.predict(X_test) from sklearn.metrics import mean_squared_error print("Mean squared error: %.2f" % mean_squared_error(y_test, y_pred)) ``` 最终,我们可以得到预测结果的均方误差(Mean squared error)。通过不断调整学习率等超参数,就可以得到更好的模型预测效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值