• 简单线性回归模型(复习一下前向传播和反向传播)


    案例1

    import torch
    torch.__version__
    x=torch.rand(3,4,requires_grad=True)
    x
    
    • 1
    • 2
    • 3
    • 4
    tensor([[0.9795, 0.8240, 0.6395, 0.1617],
            [0.4833, 0.4409, 0.3758, 0.7234],
            [0.9857, 0.9663, 0.5842, 0.8751]], requires_grad=True)
    
    • 1
    • 2
    • 3
    b=torch.rand(3,4,requires_grad=True)
    t=x+b
    y=t.sum()
    
    • 1
    • 2
    • 3
    y.backward()
    b.grad
    
    • 1
    • 2
    tensor([[1., 1., 1., 1.],
            [1., 1., 1., 1.],
            [1., 1., 1., 1.]])
    
    • 1
    • 2
    • 3

    案例2

    x=torch.rand(1)
    b=torch.rand(1,requires_grad=True)
    w=torch.rand(1,requires_grad=True)
    y=w*x
    z=y+b
    
    • 1
    • 2
    • 3
    • 4
    • 5
    z.backward(retain_graph=True)#保留计算图
    w.grad
    
    
    • 1
    • 2
    • 3
    tensor([0.5871])
    
    • 1
    b.grad
    
    • 1
    tensor([3.])
    
    • 1

    第一个线性回归模型

    import numpy as np
    
    • 1
    x_values=[i for i in range(11)]
    x_train= np.array(x_values, dtype=np.float32)
    x_train=x_train.reshape(-1,1)
    x_train.shape
    
    • 1
    • 2
    • 3
    • 4
    (11, 1)
    
    • 1
    y_values=[2*i+1 for i in x_values]
    y_train=np.array(y_values,dtype=np.float32)
    y_train=y_train.reshape(-1,1)
    y_train.shape
    
    • 1
    • 2
    • 3
    • 4
    (11, 1)
    
    • 1

    建立模型

    import torch.nn as nn
    
    • 1
    class linearRegressionModel(nn.Module):#定义了一个名为linearRegressionModel的类,该类继承自nn.Module类。
    
    
        def __init__(self,input_dim,output_dim):#是linearRegressionModel类的构造函数,它接受input_dim和output_dim两个参数。
            super(linearRegressionModel,self).__init__()
            self.linear=nn.Linear(input_dim,output_dim)#创建了一个全联接层对象linear,它接受输入维度input_dim和输出维度output_sum。
        def forward(self,x):
            out=self.linear(x)
            return out
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    input_dim=1
    output_dim=1
    model=linearRegressionModel(input_dim,output_dim)
    
    • 1
    • 2
    • 3

    指定好参数和损失函数

    epochs=1000
    learning_rate=0.01
    optimizer=torch.optim.SGD(model.parameters(),lr=learning_rate)#创建随机梯度下降优化器对象
    criterion=nn.MSELoss()#均方误差
    
    • 1
    • 2
    • 3
    • 4

    训练模型

    for epoch in range(epochs):
        epoch+=1
        inputs=torch.from_numpy(x_train)# numpy转tensor
        labels=torch.from_numpy(y_train)
        
        optimizer.zero_grad()#梯度清零,避免累加
        #前向传播
        outputs=model(inputs)
        #计算损失
        loss=criterion(outputs,labels)
        #反向传播
        loss.backward()
        #更新权重参数
        optimizer.step()
        if(epoch%50==0):
            print('epoch {}, loss {}'.format(epoch,loss.item()))
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    epoch 50, loss 0.04499879851937294
    epoch 100, loss 0.025665638968348503
    epoch 150, loss 0.014638797380030155
    epoch 200, loss 0.008349399082362652
    epoch 250, loss 0.004762190859764814
    epoch 300, loss 0.0027161596808582544
    epoch 350, loss 0.0015491894446313381
    epoch 400, loss 0.0008836076012812555
    epoch 450, loss 0.0005039655370637774
    epoch 500, loss 0.000287443253910169
    epoch 550, loss 0.000163945704116486
    epoch 600, loss 9.350906475447118e-05
    epoch 650, loss 5.333393710316159e-05
    epoch 700, loss 3.0422697818721645e-05
    epoch 750, loss 1.7352540453430265e-05
    epoch 800, loss 9.89796535577625e-06
    epoch 850, loss 5.644690645567607e-06
    epoch 900, loss 3.2191221635002876e-06
    epoch 950, loss 1.8363726894676802e-06
    epoch 1000, loss 1.047302703227615e-06
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    title

    模型预测结果

    predicted=model(torch.from_numpy(x_train).requires_grad_()).data.numpy()
    predicted
    
    • 1
    • 2
    array([[ 0.99809617],
           [ 2.9983704 ],
           [ 4.9986444 ],
           [ 6.9989185 ],
           [ 8.999193  ],
           [10.999468  ],
           [12.999742  ],
           [15.000015  ],
           [17.00029   ],
           [19.000565  ],
           [21.00084   ]], dtype=float32)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    模型的保存和读取(训练好的权重)

    #权重的保存
    torch.save(model.state_dict(),'model.pk1')
    
    • 1
    • 2
    #模型导入(读取权重数据)
    model.load_state_dict(torch.load('model.pk1'))
    
    • 1
    • 2
    
    
    • 1
    
    
    • 1
    
    
    • 1
  • 相关阅读:
    内网/外网实现部署nginx服务
    数据结构(C语言版)严蔚敏--->一些操作相关数据结构的题目
    REDIS上如何批量删除KEY?
    CEC2023:基于自适应启动策略的混合交叉动态约束多目标优化算法(MC-DCMOEA)求解CEC2023(提供MATLAB代码及参考文献)
    微信公众号授权登录后报redirect_uri参数错误的问题
    FPGA时序约束(七)文献时序约束实验测试
    [附源码]计算机毕业设计智能衣橱APPSpringboot程序
    回 溯 法
    使用 DDPO 在 TRL 中微调 Stable Diffusion 模型
    【Unity Texture】_MainTex的含义
  • 原文地址:https://blog.csdn.net/Che_Che_/article/details/134083841