几种常见的损失函数「建议收藏」

几种常见的损失函数「建议收藏」1.损失函数、代价函数与目标函数  损失函数(LossFunction):是定义在单个样本上的,是指一个样本的误差。  代价函数(CostFun

大家好,又见面了,我是你们的朋友全栈君。

1. 损失函数、代价函数与目标函数

  损失函数(Loss Function):是定义在单个样本上的,是指一个样本的误差。
  代价函数(Cost Function):是定义在整个训练集上的,是所有样本误差的平均,也就是所有损失函数值的平均。
  目标函数(Object Function):是指最终需要优化的函数,一般来说是经验风险+结构风险,也就是(代价函数+正则化项)。

2. 常用的损失函数

  这一节转载自博客

(1)0-1损失函数(0-1 loss function)

\[L(y, f(x)) = \begin{cases} 1, & {y \neq f(x) } \\ 0, & {y = f(x)} \end{cases} \]

  也就是说,当预测错误时,损失函数为1,当预测正确时,损失函数值为0。该损失函数不考虑预测值和真实值的误差程度。只要错误,就是1。

(2)平方损失函数(quadratic loss function)

\[L(y, f(x)) = (y – f(x))^2 \]

  是指预测值与实际值差的平方。

(3)绝对值损失函数(absolute loss function)

\[L(y, f(x)) = | y -f(x) | \]

  该损失函数的意义和上面差不多,只不过是取了绝对值而不是求绝对值,差距不会被平方放大。

(4)对数损失函数(logarithmic loss function)

\[L(y, p(y|x)) = – \log p(y|x) \]

  这个损失函数就比较难理解了。事实上,该损失函数用到了极大似然估计的思想。P(Y|X)通俗的解释就是:在当前模型的基础上,对于样本X,其预测值为Y,也就是预测正确的概率。由于概率之间的同时满足需要使用乘法,为了将其转化为加法,我们将其取对数。最后由于是损失函数,所以预测正确的概率越高,其损失值应该是越小,因此再加个负号取个反。

(5)Hinge loss

  Hinge loss一般分类算法中的损失函数,尤其是SVM,其定义为:

\[L(w,b) = max \{0, 1-yf(x) \} \]

  其中 $ y = +1 或 y = -1 $ ,$ f(x) = wx+b $ ,当为SVM的线性核时。


3. 常用的代价函数

(1)均方误差(Mean Squared Error)

\[MSE = \frac{1}{N} \sum_{i=1}^N (y^{(i)} – f(x^{(i)}))^2 \]

  均方误差是指参数估计值与参数真值之差平方的期望值; MSE可以评价数据的变化程度,MSE的值越小,说明预测模型描述实验数据具有更好的精确度。( $ i $ 表示第 $ i $ 个样本,$ N $ 表示样本总数)
  通常用来做回归问题的代价函数

(2)均方根误差

\[RMSE = \sqrt{\frac{1}{N} \sum_{i=1}^N (y^{(i)} – f(x^{(i)}))^2 } \]

  均方根误差是均方误差的算术平方根,能够直观观测预测值与实际值的离散程度。
  通常用来作为回归算法的性能指标

(3)平均绝对误差(Mean Absolute Error)

\[MAE = \frac{1}{N} \sum_{i=1}^N |y^{(i)} – f(x^{(i)})| \]

  平均绝对误差是绝对误差的平均值 ,平均绝对误差能更好地反映预测值误差的实际情况。
  通常用来作为回归算法的性能指标

(4)交叉熵代价函数(Cross Entry)

\[H(p,q) = – \sum_{i=1}^{N} p(x^{(i)}) \log {q(x^{(-i)})} \]

  交叉熵是用来评估当前训练得到的概率分布与真实分布的差异情况,减少交叉熵损失就是在提高模型的预测准确率。其中 $ p(x) $ 是指真实分布的概率, q(x) 是模型通过数据计算出来的概率估计。
  比如对于二分类模型的交叉熵代价函数(可参考逻辑回归一节):

\[L(w,b) = -\frac{1}{N} \sum_{i=1}^{N} (y^{(i)} \log {f(x^{(i)})} + ( 1- y^{(i)}) \log {(1- f(x^{(i)})})) \]

  其中 $ f(x) $ 可以是sigmoid函数。或深度学习中的其它激活函数。而 $ y^{(i)} \in { 0,1 } $ 。
  通常用做分类问题的代价函数。


引用及参考:
[1] https://blog.csdn.net/reallocing1/article/details/56292877
[2] https://blog.csdn.net/m_buddy/article/details/80224409
[3] https://blog.csdn.net/chaipp0607/article/details/76037351
[4] https://blog.csdn.net/shenxiaoming77/article/details/51614601

写在最后:本文参考以上资料进行整合与总结,文章中可能出现理解不当的地方,若有所见解或异议可在下方评论,谢谢!
若需转载请注明https://www.cnblogs.com/lliuye/p/9549881.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154310.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月30日 下午10:46
下一篇 2022年6月30日 下午11:00


相关推荐

  • 说说如何搭建 HTTP 服务器

    说说如何搭建 HTTP 服务器这里使用 ApacheHTTPSe 来搭建 HTTP 服务器 1 在搜索引擎中输入 ApacheHTTPSe 下载 关键字 下载 ApacheHTTPSe 的安装包 形如 httpd 2 2 25 win32 x86 no ssl msi2 双击运行安装程序 3 在此输入域名 服务器名以及电子邮箱地址 4 在此选择自定义安装 Cust

    2026年3月18日
    1
  • c语言贪吃蛇(简易版本含完整代码)

    c语言贪吃蛇(简易版本含完整代码)这个贪吃蛇是在我学完C语言的基本部分在跟着哈工大的c语言程序设计Mooc课程完了之后做的因为学完C语言很迷茫不晓得应该学什么学校里面的题库感觉刷起来又没有实际我能看到的东西我认为在阶段性的学习过程中应该找到自己能够看得到的成果才能刺激自己继续往前进继续学习不然很枯燥的学习谁都坚持不下去这也是在看了视频教程后自己一步步敲出来的其实还是建议大家在看懂了代码后自己实现因为不要怕自己忘不忘这又不是理论知识敲出来的代码就是自己的一步步的提升加油qwq这里是head.h头文件因为

    2022年6月28日
    29
  • Gmap使用说明,通过输入经纬度查询位置

    Gmap使用说明,通过输入经纬度查询位置由于本人对于 Gmap 的使用时间不长 有很多东西不是太熟悉 所以本人的代码有借鉴的部分 如有发现侵权 还请及时联系本人 我目前已经基本实现了 地图的放大 缩小 平移的功能 完成了鼠标单击标点 输入经纬度标点 然后通过标志点连接成轨迹的功能 还可以保存正在使用的这块地图为图片 下面是本人的代码部分 注释已经很明确了 如有不明白的地方还请及时评论 Gmap 有个需要配置的部分详情可看 https

    2026年3月17日
    2
  • Linux下内网端口转发工具-rinetd

    Linux下内网端口转发工具-rinetd目录一 前言二 安装下载 rinetd 安装三 注册成系统服务及修改配置文件四 启动与关闭程序一 前言有些服务为了安全仅供内网访问 比如在阿里云中 redis 仅提供了内网的地址 在开发过程中我们需要查看 redis 中的内容 这时候就无法在开发机上直接访问 rinetd 解决了这个问题 它将 redis 端口映射出来 通过转发来实现访问 redis 在早期的版本中 rinetd 只支持 TCP 协议 最新版本已经支持 UDP 协议了 二 安装下载 rinetd 源码地址 Github

    2026年3月19日
    1
  • Pytest(6)重复运行用例pytest-repeat[通俗易懂]

    Pytest(6)重复运行用例pytest-repeat[通俗易懂]前言平常在做功能测试的时候,经常会遇到某个模块不稳定,偶然会出现一些bug,对于这种问题我们会针对此用例反复执行多次,最终复现出问题来。自动化运行用例时候,也会出现偶然的bug,可以针对单个用例,

    2022年7月28日
    10
  • Java实现 LeetCode 385 迷你语法分析器

    Java实现 LeetCode 385 迷你语法分析器385 迷你语法分析器给定一个用字符串表示的整数的嵌套列表 实现一个解析它的语法分析器 列表中的每个元素只可能是整数或整数嵌套列表提示 你可以假定这些字符串都是格式良好的 字符串非空字符串不包含空格字符串只包含数字 0 9 示例 1 给定 s 324 你应该返回一个 NestedIntege 对象 其中只包含整数值 324 示例 2 给定 s

    2026年3月17日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号