- Python深度学习:基于PyTorch
- 吴茂贵
- 538字
- 2023-07-10 16:45:34
2.7 使用Tensor及Antograd实现机器学习
2.6节可以说是纯手工完成一个机器学习任务,数据用Numpy表示,梯度及学习是自己定义并构建学习模型。这种方法适合于比较简单的情况,如果稍微复杂一些,代码量将几何级增加。那是否有更方便的方法呢?本节我们将使用PyTorch的一个自动求导的包——antograd,利用这个包及对应的Tensor,便可利用自动反向传播来求梯度,无须手工计算梯度。以下是具体实现代码。
1)导入需要的库。
import torch as t %matplotlib inline from matplotlib import pyplot as plt
2)生成训练数据,并可视化数据分布情况。
t.manual_seed(100) dtype = t.float #生成x坐标数据,x为tenor,需要把x的形状转换为100x1 x = t.unsqueeze(torch.linspace(-1, 1, 100), dim=1) #生成y坐标数据,y为tenor,形状为100x1,另加上一些噪声 y = 3*x.pow(2) +2+ 0.2*torch.rand(x.size()) # 画图,把tensor数据转换为numpy数据 plt.scatter(x.numpy(), y.numpy()) plt.show()
运行结果如图2-13所示。
图2-13 可视化输入数据
3)初始化权重参数。
# 随机初始化参数,参数w、b为需要学习的,故需requires_grad=True w = t.randn(1,1, dtype=dtype,requires_grad=True) b = t.zeros(1,1, dtype=dtype, requires_grad=True)
4)训练模型。
lr =0.001 # 学习率 for ii in range(800): # 前向传播,并定义损失函数loss y_pred = x.pow(2).mm(w) + b loss = 0.5 * (y_pred - y) ** 2 loss = loss.sum() # 自动计算梯度,梯度存放在grad属性中 loss.backward() # 手动更新参数,需要用torch.no_grad(),使上下文环境中切断自动求导的计算 with t.no_grad(): w -= lr * w.grad b -= lr * b.grad # 梯度清零 w.grad.zero_() b.grad.zero_()
5)可视化训练结果。
plt.plot(x.numpy(), y_pred.detach().numpy(),'r-',label='predict')#predict plt.scatter(x.numpy(), y.numpy(),color='blue',marker='o',label='true') # true data plt.xlim(-1,1) plt.ylim(2,6) plt.legend() plt.show() print(w, b)
运行结果如下,其可视化结果如图2-14所示。
图2-14 使用Antograd的结果
tensor([[2.9645]], requires_grad=True) tensor([[2.1146]], requires_grad=True)
这个结果与使用Numpy实现机器学习差不多。