当前位置: 首页 > news >正文

pytorch实现逻辑回归

pytorch实现逻辑回归

  1. 数据准备,参数初始化
  2. 前向计算
  3. 计算损失
  4. 计算梯度
  5. 更新参数

在官网上找到线性函数的公式表达式
在这里插入图片描述

在这里插入图片描述

import torch
from sklearn.datasets import load_iris
# from sklearn.model_selection import train_test_split #train_test_split是sklearn中的一个函数,作用是将数据集划分为训练集和测试集
#数据准备
X, y = load_iris(return_X_y=True) #加载数据,X,y分别为特征和标签
X = X[:100] #取前100个样本
y = y[:100] #取前100个样本#创建张量数据集
tensor_x = torch.tensor(X, dtype=torch.float32)
tensor_y = torch.tensor(y, dtype=torch.float32)#超参数设置
learning_rate = 0.001
epochs = 500#模型参数
w = torch.randn(1, 4, requires_grad=True) #requires_grad=True表示w需要求导,1表示输出维度,4表示输入维度
b = torch.randn(1, requires_grad=True) #1表示输出维度

【注】

  1. 张量是一种容器
  2. 张量也是一种计算的方法,或说操作
  3. grad属性,梯度属性,保存参数梯度值
for i in range(epochs):  #前向计算z = torch.nn.functional.linear(tensor_x, w, b) #线性函数计算#z = torch.matmul(tensor_x, w.t()) + b #线性函数计算z = torch.sigmoid(z) #线性函数转为概率函数0-1之间#损失函数loss = torch.nn.functional.binary_cross_entropy(z.reshape(-1), tensor_y,reduction='mean') #二分类交叉熵损失函数#reduction='mean'表示对每个样本的损失求均值#计算梯度loss.backward() #计算梯度、梯度保存在w.grad和b.grad中#参数更新#with torch.no_grad()表示不需要梯度跟踪,不需要计算梯度,不需要梯度更新#with关键字是上下文管理器,用于简化资源管理,确保资源被及时释放(可以理解为作用域)with torch.no_grad(): #梯度清零,关闭梯度计算跟踪,防止梯度累加w -= learning_rate * w.gradb -= learning_rate * b.grad#梯度清零                w.grad.zero_()b.grad.zero_()#训练动态损失print('train loss:' ,loss.item())
train loss: 0.9154033064842224
train loss: 0.9093276262283325
train loss: 0.9033000469207764
train loss: 0.8973206877708435
train loss: 0.891389787197113
train loss: 0.8855075240135193
train loss: 0.8796738982200623
train loss: 0.873889148235321
train loss: 0.8681536912918091......
train loss: 0.37976446747779846
train loss: 0.37959033250808716
train loss: 0.3794163167476654
train loss: 0.379242479801178
train loss: 0.3790687322616577
train loss: 0.37889519333839417
train loss: 0.378721684217453
train loss: 0.37854844331741333
train loss: 0.3783752918243408
train loss: 0.37820228934288025
w.grad #查看w的梯度
tensor([[0., 0., 0., 0.]])

二元交叉熵计算损失维度要相同,不然报错,去掉维度
z.reshape(-1).shape #将z展平
z.squeeze().shape #将z压缩(去掉维度为1的维度)


torch.Size([100])

完整代码

import torch
from sklearn.datasets import load_iris
#数据准备
X, y = load_iris(return_X_y=True) 
X = X[:100] 
y = y[:100] #创建张量数据集
tensor_x = torch.tensor(X, dtype=torch.float32)
tensor_y = torch.tensor(y, dtype=torch.float32)#超参数设置
learning_rate = 0.001
epochs = 500#模型参数
w = torch.randn(1, 4, requires_grad=True) 
b = torch.randn(1, requires_grad=True) for i in range(epochs):  #前向计算z = torch.nn.functional.linear(tensor_x, w, b) z = torch.sigmoid(z) #损失函数loss = torch.nn.functional.binary_cross_entropy(z.reshape(-1), tensor_y,reduction='mean')#计算梯度loss.backward() #参数更新with torch.no_grad(): w -= learning_rate * w.gradb -= learning_rate * b.grad#梯度清零                w.grad.zero_()b.grad.zero_()#训练动态损失print('train loss:' ,loss.item())

相关文章:

  • 提高RS-485总线稳定性办法
  • 黑马商城项目(一)MybatisPlus
  • 基于PySide6的YOLOv8/11目标检测GUI界面——智能安全帽检测系统
  • ScrollView(滚动视图)详解和按钮点击事件
  • 【Leetcode-Hot100】最小覆盖子串
  • 【链表】链表类型题目常用技巧及例题
  • Resilience4j与Spring Cloud Gateway整合指南:构建弹性的API网关
  • Stable Diffusion 图像生成 GUI 应用:图像缩放等五个优化——SD界面学习记录
  • yml文件上传并映射到实体类
  • Service生命周期
  • 微图4在《宁夏清水湾小流域治理》工程项目中的应用案例
  • Arrays.asList()的对象不能调用add/remove/clear方法
  • 力扣-hot100(最长连续序列 - Hash)
  • C++高级2 智能指针
  • CodeBuddy 焕新升级: 软件开发智能体 Craft 重磅发布
  • Function Calling 与 RAG的关系
  • [第十六届蓝桥杯 JavaB 组] 真题 + 经验分享
  • MySQL 数据库备份和恢复全指南
  • 多线程(三)
  • Python Pandas实现导出两个Excel数据集的分组记录数分析
  • 门票在“缩水”,古镇怎么办
  • 云南城投去年营收约19.29亿元,亏损4945万元
  • 国家疾控局局长沈洪兵:将逐步缩小国内免疫规划与国际差距
  • 国家卫健委:无资质机构严禁开展产前筛查
  • 中国与柬埔寨签署产供链经济合作谅解备忘录
  • 2025年度“沪惠保”将于4月22日开售,保费不变