我是张乐 2024-07-02 01:12 采纳率: 100%
浏览 4
已结题

逻辑回归训练集与测试集的accurac都为None

逻辑回归做二分类时,训练模型时显示Loss after iteration 0: nan,最后训练集和测试集的accuracy显示为None,求解答

img

img

  • 写回答

2条回答 默认 最新

  • 阿里嘎多学长 2024-07-02 01:12
    关注

    以下内容由CHATGPT及阿里嘎多学长共同生成、有用望采纳:


    从你提供的图片内容来看,逻辑回归模型在训练过程中遇到了几个问题。以下是一些可能的原因和解决方案:

    1. 初始损失值显示为NaN

      • 这通常发生在模型的参数初始化不正确或者模型的输入数据存在问题时。例如,如果输入特征(X)或目标变量(y)包含NaN或无穷大(Inf)的值,这可能导致损失函数在迭代开始时就返回NaN。
    2. 损失值突然跳转

      • 这可能是由于模型的参数更新过大导致的数值不稳定。在逻辑回归中,如果学习率(learning_rate)设置得过高,可能会导致模型在迭代过程中损失值出现剧烈波动。
    3. 运行时警告:除零错误

      • 这个警告表明在计算损失函数时,模型预测的概率(y_hat)可能为0或1,导致对数函数log(y_hat)或log(1 - y_hat)计算时出现除零的情况。
    4. 准确度(accuracy)显示为None

      • 这可能是因为模型的预测结果与实际标签不匹配,或者在调用score方法时出现了错误。通常,如果模型能够正确预测,score方法应该返回一个介于0和1之间的值,表示准确度。

    解决方案

    • 检查数据:确保输入特征和目标变量没有NaN或无穷大的值。可以使用pandas库的isnull()isfinite()方法来检查数据。
    • 调整学习率:如果学习率过高,尝试降低学习率,比如从0.005开始逐步调整。
    • 模型参数初始化:确保模型参数初始化正确,可以尝试使用不同的初始化方法或参数。
    • 检查模型预测:确保模型的预测结果(y_train_pred和y_test_pred)是正确的,可以通过打印出一些预测结果来检查。
    • 检查评分函数调用:确保评分函数model.score()被正确调用,并且传入了正确的参数。

    如果上述方法仍然无法解决问题,可能需要进一步检查模型的实现细节或寻求专业的帮助。

    至于参考链接,以下是一些可能有用的资源:

    希望这些信息能帮助你解决问题。如果需要更具体的帮助,请随时告诉我。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 7月13日
  • 已采纳回答 7月13日
  • 创建了问题 7月2日

悬赏问题

  • ¥20 c语言写的8051单片机存储器mt29的模块程序
  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大