Keras损失函数:categorical_crossentropy和sparse_categorical_crossentropy的区别

按照keras之父的书中所写:
  • 如果 labels 是 one-hot 编码,用 categorical_crossentropy
      one-hot 编码:
      [[0, 1, 0],
       [1, 0, 0],
       [0, 0, 1]]
       每条每一行是一个label的编码,1所在的位置代表label
  • 如果你的 tagets 是 数字编码 ,用 sparse_categorical_crossentropy
      数字编码:[2, 0, 1, 5, 19]
      每个数字就是label
书中写道:这两个函数在数学上没有本质区别,只是接口不一样,那么如何取舍呢?
  • 可以看到sparse,是稀疏的意思,所谓labels稀疏就是:假如你label有好几百类,上千类,那么one-hot编码出来的矩阵,绝大多数数据就是0,毕竟每行中只有一个1。这就是稀疏数据,所以这样的数据就干脆不要one-hot了

  • 而对于类别比较少的数据,就可以选用one-hot

更具体的参考keras文档https://keras-cn-docs.readthedocs.io/zh_CN/latest/other/metrices/

  • 14
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值