回归实战(小白版本)

一.完整代码

python 复制代码
import torch
import matplotlib.pylab as plt#画图
import random #产生随机数

def create_data(w,b,data_num):#生成数据,w系数,b截距,data_num表样本数量
     x=torch.normal(0,1,(data_num,len(w)))#注:系数个数必须等于特征数
     y=torch.matmul(x,w)+b#表矩阵相乘

     noise=torch.normal(0,0.01,(y.shape))#噪声要加到y上,生成的数据与y一样的维度
     y+=noise
     return x,y

num=500

true_w=torch.tensor([8.1,2,2,4])#四个特征系数
true_b=torch.tensor(1.1)#是一个标量张量,对应线性模型的截距

X,Y=create_data(true_w,true_b,num)

#X[:,3]表取所有行,取第四列,1表示散点大小
plt.scatter(X[:,2],Y,1)#画一个散点图,展示第四个特征与y的关系
plt.show()



# 不知道w,b来推测其值
#label特征对应的标签集(比如线性回归中的 y 值,是模型预测的目标)
def data_provider(data,label,batchsize):#每次访问函数,就会提供一批数据(即一组一组计算)
     length=len(label)
     indices=list(range(length))#样本索引

     for each in range(0,length,batchsize):#每次循环的步长为batchsize
          get_indices=indices[each:each+batchsize]#当前批次索引
          get_data=data[get_indices]
          get_label=label[get_indices]

          yield get_data,get_label#有存档点的return 暂停点

batchsize=16
# for batch_x,batch_y in data_provider(X,Y,batchsize):
#      print(batch_x,batch_y)
#      break


#定义模型
def fun(x,w,b):
     pred_y=torch.matmul(x,w)+b#预测值
     return pred_y

#损失函数
def maeLoss(pre_y,y):
     return torch.sum(abs(pre_y-y))/len(y)

#优化函数
def sgd(paras,lr):#随机梯度下降,更新参数
     with torch.no_grad():#属于这句代码的部分,不计算梯度
          for para in paras:
                  para-=para.grad*lr#往损失函数减小的方向移动
                  para.grad.zero_()#使用过的梯度,归0


lr=0.03
w_0=torch.normal(0,0.01,true_w.shape,requires_grad=True)
b_0=torch.tensor(0.01,requires_grad=True)
print(w_0,b_0)


epochs=50#训练的轮数

for epoch in range(epochs):
     data_loss=0
     for batch_x,batch_y in data_provider(X,Y,batchsize):
          pred_y=fun(batch_x,w_0,b_0)
          loss=maeLoss(pred_y,batch_y)
          loss.backward()
          sgd([w_0,b_0],lr)
          data_loss+=loss

     print("epoch %03d: loss:%.6f"%(epoch,data_loss))

print("真实的函数值是",true_w,true_b)
print("训练得到的函数值是",w_0,b_0)


#只能看某一列的y值图
#第一列
idx=0
plt.plot(X[:,idx].detach().numpy(),X[:,idx].detach().numpy()*w_0[idx].detach().numpy()+b_0.detach().numpy())
plt.scatter(X[:,idx],Y,1)
plt.show()

二.具体细节(有疑惑的部分)

python 复制代码
#优化函数
def sgd(paras,lr):#随机梯度下降,更新参数
     with torch.no_grad():#属于这句代码的部分,不计算梯度重点
          for para in paras:
                  para-=para.grad*lr#往损失函数减小的方向移动
                  para.grad.zero_()#使用过的梯度,归0

首先就是分批进行优化参数w,b;每一轮末尾要将使用过的梯度归0,防止梯度累积影响下一轮数据的参数优化更新;

但不是分批的进行吗 那么每次不是一直在覆盖之前存储的w吗?

  • 不是丢失信息 ,而是在改进参数
  • 每次批处理都让w变得更接近"正确答案"(每一批都在优化参数)
相关推荐
星越华夏4 小时前
计算机视觉:YOLOv12安装环境
人工智能·yolo·计算机视觉
Yolanda946 小时前
【人工智能】《从零搭建AI问答助手项目(九):Prompt优化》
人工智能·prompt
wj3055853786 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
小和尚同志6 小时前
深入使用 skill-creator:结合真实生产级实践
人工智能·aigc
DevSecOps选型指南6 小时前
安全419专访悬镜安全 | 穿越周期在 AI 浪潮中定义数字供应链安全新范式
人工智能
沪漂阿龙6 小时前
面试题详解:GraphRAG 全面解析——知识图谱增强 RAG、Local Search、Global Search、社区摘要、工程落地与评估指标一次讲透
人工智能·知识图谱
WangN26 小时前
Unitree RL Lab 学习笔记【通识】
人工智能·机器学习
haina20196 小时前
海纳AI亮相《科创中国》,解码招聘“智”变之路
人工智能·ai面试·ai招聘
阿星AI工作室6 小时前
刘润年中大课笔记:一句话说清AI落地之战的本质
大数据·人工智能·创业创新·商业
qingfeng154157 小时前
企业微信机器人开发:如何实现自动化与智能运营?
人工智能·python·机器人·自动化·企业微信