目录
- 题目描述
- 1. y=w*x
- 2. y=w*x+b
- 代码
- 第一题: y = w*x
- 第二题:y = wx+b
- 绘图工具
学习视频: 刘二大人pytorch1-线性模型
题目描述
1. y=w*x
使用线性模型y = w*x计算模型的损失值并且使用matplotlib给出cost function图像。
2. y=w*x+b
使用线性模型y = w*x+b给出cost function图像,使用3d图来绘制图像。
代码
第一题: y = w*x
import numpy as np
import matplotlib.pyplot as plt
# 训练数据
x_data = [1.0,2.0,3.0]
y_data = [2.0,4.0,6.0]
# 前向传播计算预测值
def forward(x):
return x*w
# 计算损失值的平方
def loss(x,y):
y_pred = forward(x)
return (y-y_pred)*(y-y_pred)
# 记录画图的x值和y值
w_list = []
loss_mse_list = []
# 计算数据集中数据个数
n = len(x_data)
for w in np.arange(0.0,4.1,0.1):
w_list.append(w)
print("w=",w)
# 存储每一个数据对的loss值的和
loss_sum = 0
for x,y in zip(x_data,y_data):
y_pred = forward(x)
# 一个数据对的loss值
loss1 = loss(x,y)
loss_sum += loss1
print('\t',x,y,y_pred,loss1)
# 对loss和求平均
loss_mse_list.append(loss_sum/n)
print('MSE=',loss_sum/n)
plt.plot(w_list,loss_mse_list)
plt.xlabel("w")
plt.ylabel("mse loss")
plt.show()
为什么要打印过程信息?
记录日志,防止训练过程中程序异常停止时丢失训练数据。
第二题:y = wx+b
绘图:matplotlib-3d图画法
import numpy as np
import matplotlib.pyplot as plt
# 训练数据
x_data = [1.0,2.0,3.0]
y_data = [3.0,5.0,7.0]
# 前向传播计算预测值
def forward(x):
return x*w+b
# 计算损失值的平方
def loss(x,y):
y_pred = forward(x)
return (y-y_pred)*(y-y_pred)
# 记录画图的x值和y值
w_list = np.arange(0.0,4.1,0.1)
b_list = np.arange(-2.0,2.1,0.1)
loss_mse_list = []
# 计算数据集中数据个数
n = len(x_data)
for w in w_list:
for b in b_list:
l_sum = 0
for x,y in zip(x_data,y_data):
l_sum+=loss(x,y)
loss_mse_list.append(l_sum/n)
w_list, b_list=np.meshgrid(w_list, b_list)
mse_list=np.array(loss_mse_list).reshape(len(w_list),-1)
fig = plt.figure() # 创建图片
sub = fig.add_subplot(111, projection='3d') # 添加子图,
surf = sub.plot_surface(w_list, b_list, mse_list, cmap=plt.cm.brg) # 绘制曲面,并设置颜色cmap
cb = fig.colorbar(surf, shrink=0.8, aspect=15) # 设置颜色棒
sub.set_xlabel(r"$w$")
sub.set_ylabel(r"$b$")
sub.set_zlabel(r"$loss$")
plt.show()
绘图工具
visdom :visdom的使用