【刘二大人】pytorch深度学习实践(一):线性模型y=w*x和y=w*x+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的使用

猜你喜欢

转载自blog.csdn.net/weixin_45662399/article/details/134031644
今日推荐