深度学习 -- 逻辑回归 PyTorch实现逻辑回归

前言

线性回归解决的是回归问题,而逻辑回归解决的是分类问题,这两种问题的区别是前者的目标属性是连续的数值类型,而后者的目标属性是离散的标称类型。

可以将逻辑回归视为神经网络的一个神经元,因此学习逻辑回归能帮助理解神经网络的工作原理。

什么是逻辑回归?

逻辑回归是一种广义的线性回归分析模型,是监督学习的一种重要方法,主要用于二分类问题,但也可以用于多分类问题。

逻辑回归的主要思想是,对于一个二分类问题,先根据样本数据计算出每个特征的概率,然后根据这些概率计算出每个样本属于每个类别的概率,最后根据这些概率来预测测试集数据属于每个类别的概率。

逻辑回归介绍

逻辑回归的推导过程与计算方式类似于回归的过程,但实际上主要是用来解决二分类问题。 在逻辑回归中,输入数据集D被分成两个部分:一类是训练集D_train,一类是测试集D_test。在每次训练时,我们使用一部分数据来训练模型,然后使用另一部分数据来评估模型的性能。 在测试时,我们使用所有的数据来评估模型的性能。

在实际使用中,逻辑回归可以使用各种不同的损失函数来最小化训练数据集和测试数据集之间的均方误差。常见的逻辑回归损失函数包括均方误差损失函数、交叉熵损失函数、对数损失函数等。

Sigmoid函数

Sigmoid函数是一个在生物学中常见的S型函数,也称为S型生长曲线。在信息科学中,由于其单增以及反函数单增等性质,Sigmoid函数常被用作神经网络的激活函数,将变量映射到0,1之间。

在神经网络中经常使用Sigmoid函数作为激活函数,因为它能够有效的输出0-1之间的概率。

代价函数

代价函数(Cost Function)是深度学习模型中用于评估模型性能的函数,它是优化算法的目标函数。代价函数通常定义为损失函数(Loss Function)的平方,这样可以简单地通过计算损失函数值来评估模型的性能。

在深度学习中,代价函数通常是指均方误差(MSE)损失函数,因为均方误差是深度学习中最常用的损失函数之一。均方误差损失函数定义为:

J(y_true, y_pred) = 1/N - ∑i=1N(yi - y_i)^2

其中,y_true是真实标签,y_pred是模型预测的标签,N是样本数量,yi是真实标签对应的样本值。

代价函数的作用是评估模型的性能,其中J(y_true, y_pred)表示真实标签和模型预测标签之间的均方误差。优化算法会在代价函数上进行最小化操作,以最小化损失函数值。

除了均方误差损失函数,还有其他类型的损失函数,如交叉熵损失函数、对数损失函数等,它们在不同的场景下可能更有效或更适合。

逻辑回归在PyTorch中的实现

1 从头开始实现一个逻辑回归

  • 首先定义一个逻辑回归模型
import torch


def sigmoid(z):
    '''s型激活函数'''
    g = 1 / (1+torch.exp(-z))
    return g

def model(x,w,b):
    '''逻辑回归模型'''
    return sigmoid(x.mv(w)+b)

# w是向量,b是标量,而x是矩阵,使用x.mv(w) 可以实现矩阵x与向量w的相乘

注意:这里w是向量,b是标量,而x是矩阵,使用x.mv(w) 可以实现矩阵x与向量w的相乘

  • 然后定义损失函数和损失函数求导
# 定义损失函数
def loss_fn(y_pred,y):
    '''损失函数'''
    loss = - y.mul(y_pred.view_as(y)) - (1-y).mul(1-y_pred.view_as(y))
    return loss.mean()

# 损失函数求导
def grad_loss_fn(y_pred,y):
    '''损失函数求导'''
    return y_pred.view_as(y)-y

  • 接着定义一个梯度函数
# 定义梯度函数
def grad_fn(x,y,y_pred):
    '''梯度函数'''
    grad_w = grad_loss_fn(y_pred,y)*x
    grad_b = grad_loss_fn(y_pred,y)
    return torch.cat((grad_w.mean(dim=0),grad_b.mean().unsqueeze(0)),0)

  • 模型训练函数
# 模型训练函数
def model_training(x,y,n_epochs,learning_rate,params,print_params=True):
    '''训练'''
    for epoch in range(1,n_epochs+1):
        w,b = params[:-1],params[-1]
        
        # 前向传播
        y_pred = model(x,w,b)
        # 计算损失
        loss = loss_fn(y_pred,y)
        # 梯度
        grad = grad_fn(x,y,y_pred)
        # 更新参数
        params -= learning_rate*grad
        
        if epoch == 1 or epoch%10 == 1:
            print('轮次:%d,\t损失:%f'%(epoch,float(loss)))
            if print_params:
                print(f'参数:{params.detach().numpy()}')
                print(f'梯度:{grad.detach().numpy()}')
                
    return params
  • 最后定义main函数
if __name__ == '__main__':
    # 随机生成数据
    x = torch.randn(2,2)
    y = torch.tensor([[1.,0.],
                      [0.,1.]])
    # 模型参数初始化
    w = torch.zeros(2)  # tensor([0., 0.])
    b = torch.zeros(1)  # tensor([0.])

    params = model_training(x=x,y=y,n_epochs=500,learning_rate=0.1,params=torch.tensor([0.0,0.0,0.0]))

    print(params.numpy())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冲鸭嘟嘟可

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值