Pytorch中分类回归常用的损失和优化器

Pytorch中分类回归常用的损失和优化器

在机器学习和深度学习中,分类任务和预测任务(回归任务)有不同的常用损失函数和优化器。下面将详细介绍这些常用的损失函数和优化器。

分类任务

1. 损失函数

  • 交叉熵损失(Cross-Entropy Loss)

    • 适用场景:多分类任务。
    • 实现nn.CrossEntropyLoss() 在 PyTorch 中自动计算 softmax 和交叉熵。
    python 复制代码
    criterion = nn.CrossEntropyLoss()
  • 二元交叉熵损失(Binary Cross-Entropy Loss)

    • 适用场景:二分类任务。
    • 实现nn.BCELoss() 需要配合 sigmoid 激活函数,nn.BCEWithLogitsLoss() 将 sigmoid 和二元交叉熵计算合二为一。
    python 复制代码
    criterion = nn.BCEWithLogitsLoss()
  • 稀疏分类交叉熵损失(Sparse Categorical Cross-Entropy Loss)

    • 适用场景:多分类任务,标签为整数索引而非 one-hot 编码。
    • 实现 :在 TensorFlow 中通常使用 tf.keras.losses.SparseCategoricalCrossentropy()
    python 复制代码
    from tensorflow.keras.losses import SparseCategoricalCrossentropy
    criterion = SparseCategoricalCrossentropy(from_logits=True)

2. 优化器

  • 随机梯度下降(SGD)

    • 优点:简单易用,适用于一般的优化问题。
    • 实现optim.SGD()
    python 复制代码
    optimizer = optim.SGD(model.parameters(), lr=0.01, momentum=0.9)
  • 自适应矩估计(Adam)

    • 优点:适应性学习率,通常能快速收敛,适用于大多数任务。
    • 实现optim.Adam()
    python 复制代码
    optimizer = optim.Adam(model.parameters(), lr=0.001)
  • 均方根传播(RMSprop)

    • 优点:适用于处理非平稳目标问题。
    • 实现optim.RMSprop()
    python 复制代码
    optimizer = optim.RMSprop(model.parameters(), lr=0.001)

回归任务

1. 损失函数

  • 均方误差(Mean Squared Error, MSE)

    • 适用场景:回归任务。
    • 实现nn.MSELoss()
    python 复制代码
    criterion = nn.MSELoss()
  • 平均绝对误差(Mean Absolute Error, MAE)

    • 适用场景:回归任务。
    • 实现:在 PyTorch 中通常需要自定义实现。
    python 复制代码
    class MAELoss(nn.Module):
        def __init__(self):
            super(MAELoss, self).__init__()
    
        def forward(self, output, target):
            return torch.mean(torch.abs(output - target))
            
    criterion = MAELoss()
  • Huber 损失

    • 优点:对异常值更鲁棒,是 MSE 和 MAE 的折中。
    • 实现nn.SmoothL1Loss()
    python 复制代码
    criterion = nn.SmoothL1Loss()

2. 优化器

  • 随机梯度下降(SGD)

    • 优点:简单易用,适用于一般的优化问题。
    • 实现optim.SGD()
    python 复制代码
    optimizer = optim.SGD(model.parameters(), lr=0.01, momentum=0.9)
  • 自适应矩估计(Adam)

    • 优点:适应性学习率,通常能快速收敛,适用于大多数任务。
    • 实现optim.Adam()
    python 复制代码
    optimizer = optim.Adam(model.parameters(), lr=0.001)
  • 均方根传播(RMSprop)

    • 优点:适用于处理非平稳目标问题。
    • 实现optim.RMSprop()
    python 复制代码
    optimizer = optim.RMSprop(model.parameters(), lr=0.001)

总结

  • 分类任务通常使用交叉熵损失(针对多分类和二分类任务),优化器可以选择 SGD、Adam 或 RMSprop。
  • 回归任务常用均方误差(MSE)和平均绝对误差(MAE),优化器也可以选择 SGD、Adam 或 RMSprop。

根据任务的具体需求和模型的表现,可以尝试不同的损失函数和优化器,选择最合适的组合。

相关推荐
DuoRuaiMiFa13 分钟前
ChatGPT全新功能Canvas上线:开启智能编程与写作新篇章
人工智能·chatgpt
DisonTangor16 分钟前
Windows 11将新增基于AI的搜索、生成式填充和其它AI功能
人工智能
soso196818 分钟前
【AI自然语言处理应用】通过API调用通义晓蜜CCAI-对话分析AIO应用
人工智能·自然语言·ccai
网安-搬运工21 分钟前
RAG再总结之如何使大模型更好使用外部数据:四个不同层级及查询-文档对齐策略
人工智能·自然语言处理·大模型·llm·大语言模型·ai大模型·rag
大模型八哥22 分钟前
大模型扫盲系列——大模型实用技术介绍(上)
人工智能·程序人生·ai·大模型·llm·llama·ai大模型
被制作时长两年半的个人练习生36 分钟前
【pytorch】权重为0的情况
人工智能·pytorch·深度学习
Elastic 中国社区官方博客1 小时前
使用 Vertex AI Gemini 模型和 Elasticsearch Playground 快速创建 RAG 应用程序
大数据·人工智能·elasticsearch·搜索引擎·全文检索
说私域1 小时前
地理定位营销与开源AI智能名片O2O商城小程序的融合与发展
人工智能·小程序
Q_w77421 小时前
计算机视觉小目标检测模型
人工智能·目标检测·计算机视觉