时间序列损失函数大综述!

 作者:Spectato,文章摘自算法进阶

简介

531f9ca3a3784207847a8e9873f3ab5c.png

论文标题:

A Comprehensive Survey of Regression Based Loss Functions for Time Series Forecasting

论文链接:

https://arxiv.org/abs/2211.02989

代码链接:

https://github.com/aryan-jadon/Regression-Loss-Functions-in-Time-Series-Forecasting-Tensorflow


摘要

时间序列预测方法包括使用一组历史时间序列进行预测,在信号处理、模式识别、计量经济学、数学金融、天气预报、地震预测等领域都有广泛应用。过去时间序列预测方法以线性方法为主,然而在许多最新的应用中已经尝试使用机器学习、深度学习、高斯过程和人工神经网络等技术来进行时间序列预测。

在处理时间序列预测问任务时,损失函数的选择非常重要,因为它会驱动算法的学习过程。以往的工作提出了不同的损失函数,以解决数据存在偏差、需要长期预测、存在多重共线性特征等问题。


本文工作总结了常用的的 14 个损失函数并对它们的优缺点进行分析,这些损失函数已被证明在不同领域提供了最先进的结果。本文在在各种时间序列基准任务上对它们的表现进行分析,希望能助行业专业人士和研究人员快速的为任务选取合适的损失函数,避免过多的实验尝试。

53ed024c8793a316c72446625971ea28.png

问题背景

回归是一种常见的预测建模技术,用于估计两个或多个变量之间的关系。它是一种监督学习技术,可以定义为用于对相关实数变量之间的关系建模的统计技术和自变量。


时间序列数据与一般基于回归的数据略有不同,因为在特征中添加了时间信息,使目标更加复杂。时间序列数据具有以下组成部分

  • level:每个时间序列都有一个 base level,简单的 base level 的计算可以直接通过对历史数据进行平均/中位数计算得到;

  • 周期性:时间序列数据也有一种称为周期性的模式,它不定期重复,这意味着它不会以相同的固定间隔出现;

  • 趋势:表示时间序列在一段时间内是增加还是减少。也就是说,它有上升(增加)或下降(减少)的趋势;

  • 季节性:在一段时间内重复出现的模式称为季节性;

  • 噪声:在提取水平、周期性、趋势和季节性之后,剩下的就是噪声,噪声是数据中完全随机的变化。

每个机器学习模型的基本目标都是改进模型的选定指标并减少与之相关的损失。用于时间序列预测的机器学习或深度学习模型的一个重要组成部分是损失函数,模型的性能是根据损失函数来衡量的,促使了模型参数的更新。

14种损失函数分析

3.1 Mean Absolute Error (MAE)

MAE,也称为 L1 损失,是预测值与实际值之间的绝对误差:

3a1af4c7aaffed1ee32882546bce28af.png

所有样本值的绝对误差的均值就称为 MAE:

bd353d105265550448edf9cdacd4013f.png

fab08a2683b0d31c1d45dcbc99e9aa8e.png

▲ MAE Loss与Predictions的性能图


MAE 是回归模型中经常使用的一种简单有效的损失函数。但是由于异常值,回归问题中的变量可能不是严格的高斯变量会带来一些问题。

7398e786db9165ed4011180d4d84250a.png

3.2 Mean Squared Error (MSE)

MSE,也称为 L2 损失,是预测值与实际值之间的平方误差:

36c0e70919b754da302d957fa3bf1a80.png

所有样本值的平方误差的均值就称为 MSE,也称作均方误差:

59f8417a302bbbcde5226e2cd75ea1e1.png

MSE 也称为二次损失,因为惩罚是平方而不是与误差成正比。当误差被平方时,离群值被赋予更多的权重,为较小的误差创建一个平滑的梯度。受益于这种对巨大错误的惩罚,有助于优化算法获得参数的最佳值。鉴于错误是平方的,MSE 永远不会是负数,错误的值可以是 0 到无穷大之间的任何值。随着错误的增加,MSE 呈指数增长,好的模型的 MSE 值将接近于 0。

c529332e88fb3573ffd5d650ef18247c.png

c28c5ac938212fc075f901c230d62c3f.png

3.3 Mean Bias Error (MBE)

高估或低估参数值的倾向称为偏差或平均偏差误差。偏差的唯一可能方向是正向或负向。正偏差表示数据误差被高估,而负偏差表示误差被低估。


实际值和预期值之间的差异被测量为平均偏差误差(MBE)。预测中的平均偏差由 MBE 量化。除了不考虑绝对值外,它实际上与 MAE 相同。应谨慎对待 MBE,因为正向误差和负向误差可能会相互抵消。

49c1cc2f9f6e029d91e24a9ffe0c1351.png

ff8436b586131219714cd8a03793d669.png

▲ MBE Loss与Predictions的性能图

ed700dbe0076adda90c616d95b0ff28d.png

3.4 Relative Absolute Error (RAE)

RAE 的计算将总绝对误差除以平均值与实际值之间的绝对差值:

10a37c8a7e184594db2e061c652138aa.png

f5d56fd41e10499e0fe2cf1e042192a2.png

RAE 是一种基于比率的指标,用于评估预测模型的有效性。RAE 的可能值介于 0 和 1 之间。接近零的值(零是最佳值)是良好模型的特征。

a6efd2ebda761b83cc135e9620d066d2.png

▲ RAE Loss与Predictions的性能图

94cf58a687666524416538f681a35a01.png

3.5 Relative Squared Error (RSE)

RSE 衡量在没有简单预测器的情况下结果的不准确程度。这个简单的预测变量仅代表实际值的平均值。结果,相对平方误差将总平方误差除以简单预测变量的总平方误差以对其进行归一化。可以在以不同单位计算误差的模型之间进行比较。

633ff6053307007855679fb6ee824bcc.png

11648be0fb0e3515ea57e6abe9af3aa4.png

db25971d5853bf8607e589669d4d6d5a.png

▲ RSE Loss与Predictions的性能图

ffc3f50be8f9278ccdb577c02c67a419.png

3.6 Mean Absolute Percentage Error (MAPE)

平均绝对百分比误差(MAPE),也称为平均绝对百分比偏差(MAPD),是用于评估预测系统准确性的指标。它通过从实际值减去预测值的绝对值除以实际值来计算每个时间段的平均绝对百分比误差百分比。由于变量的单位缩放为百分比单位,因此平均绝对百分比误差(MAPE)广泛用于预测误差。当数据中没有异常值时,它效果很好,常用于回归分析和模型评估。

b18026d1c0f2842966a09d140bddbfef.png

4a8a6f2113d093d1f0921b3bf048cdfe.png

▲ MAPE Loss与Predictions的性能图

01ee7ee6c4ce4bbc1395ca42ccb901bc.png

3.7 Root Mean Squared Error (RMSE)


MSE 的平方根用于计算 RMSE。均方根偏差是 RMSE 的另一个名称。它考虑了实际值的变化并测量误差的平均幅度。RMSE 可以应用于各种特征,因为它有助于确定特征是否增强模型预测。当非常不希望出现巨大错误时,RMSE 最有用。

aaffd80a7443a35c64bda559415dcff0.png

e40766430f21fef3858a069a105d9e28.png

▲ RMSE Loss与Predictions的性能图

4af686129fdebe9cfeafe6172de1698f.png

3.8 Mean Squared Logarithmic Error (MSLE)


均方对数误差(MSLE)衡量实际值与预期值之间的差异。添加对数减少了 MSLE 对实际值和预测值之间的百分比差异以及两者之间的相对差异的关注。MSLE 将粗略地处理小的实际值和预期值之间的微小差异以及大的真实值和预测值之间的巨大差异。

a0fd65a65b127bac52d5cffe27717982.png

这种损失可以解释为真实值和预测值之间比率的度量:

bb2512365d32eb68520fea6b92b08f40.png

9f675729509de88be6d45464962bfcfa.png

▲ MSLE Loss与Predictions的性能图

43061377204131ffe515c53b5b8ac3e8.png

3.9 Root Mean Squared Logarithmic Error (RMSLE)

RMSLE 通过应用 log 到实际和预测的值,然后进行相减。当同时考虑小误差和大误差时,RMSLE 可以避免异常值的影响。

d06c7bf4fc876f59509d8e72ef41575c.png

88975592c502e87dda0d0c1129063a67.png

▲ RMSLE Loss与Predictions的性能图

d485d0dbe6a65caee3cc2366231dd6a0.png

3.10 Normalized Root Mean Squared Error (NRMSE)

归一化均方根误差(NRMSE)RMSE 有助于不同尺度模型之间的比较。该变量具有观测范围的归一化 RMSE(NRMSE),它将 RMSE 连接到观测范围。

0ea9fb4fb12d39ff10d05f1c1e8ead3e.png

f8671ab8451aee4c325844483f99f10f.png

▲ NRMSE Loss与Predictions的性能图

c0e1e1b6e6a9bbf990b61952d3fc1b3a.png

3.11 Relative Root Mean Squared Error (RRMSE)

RRMSE 是没有维度的 RMSE 变体。相对均方根误差(RRMSE)是一种均方根误差度量,它已根据实际值进行缩放,然后由均方根值归一化。虽然原始测量的尺度限制了 RMSE,但 RRMSE 可用于比较各种测量方法。当您的预测被证明是错误的时,会出现增强的 RRMSE,并且该错误由 RRMSE 相对或以百分比表示。

e436af3ef859b025657802720913583d.png

4cf9771d19ce482abb2a52345ff9694c.png

▲ RRMSE Loss与Predictions的性能图

1649429523cae652ba1b42147d0e6eb0.png

3.12 Huber Loss

Huber 损失是二次和线性评分算法的理想组合。还有超参数 delta. 对于小于 delta 的损失值,应该使用 MSE;对于大于 delta 的损失值,应使用 MAE。这成功地结合了两种损失函数的最大特点。

77007ae750027a63a77c8fbfe12b2a74.png

abe9285c5e64b9ba26209366dbc545af.png

▲ Huber Loss与Predictions的性能图

dc07e78b8e1aacfce580ca8f46ed5997.png

3.13 LogCosh Loss

LogCosh 计算误差的双曲余弦的对数。这个函数比二次损失更平滑。它的功能类似于 MSE,但不受重大预测误差的影响。鉴于它使用线性和二次评分技术,它非常接近 Huber 损失。

2b67a2de036060eeb8b7cf64d99fdafb.png

6dd16fb32778c709b488b862976de739.png

▲ LogCosh Loss与Predictions的性能图

6ea5472ae37e545fdc599d345e46dd05.png

3.14 Quantile Loss

分位数回归损失函数用于预测分位数。分位数是指示组中有多少值低于或高于特定阈值的值。它计算跨预测变量(独立)变量值的响应(因)变量的条件中位数或分位数。除了第 50 个百分位数是 MAE,损失函数是 MAE 的扩展。它不对响应的参数分布做出任何假设,甚至为具有非常量方差的残差提供预测区间。

fc929c7b183d28f68fef4ff9e65948aa.png

74abea3e4b2e391f1ad7c68e77e3f1d6.png

▲ Quantile Loss与Predictions的性能图

43ff48d353bd99ae34d16732212b648d.png

实验分析各种损失函数在时间序列任务上的表现

数据集

  • 电力负荷数据集-数据集包含 370 点/客户端的电力消耗。

  • 交通数据集-数据集包含 15 个月的每日数据(440 条每日记录),描述了旧金山湾区高速公路不同车道随时间变化的占用率,数值介于 0 和 1 之间。

  • Favorita 数据集-包含日期、商店和商品信息、该商品是否正在促销以及单位销售额的杂货数据集。

  • 波动率数据集-数据集包含衡量金融资产或指数过去波动性。

评估指标


实验使用 P10、P50 和 P90 度量评估了所有损失函数的性能。预测的上限和下限可以通过分位数提供。80% 置信区间是可以获得的值范围,例如,通过使用预测类型 0.1(P10)和 0.9(P90)。在 10% 的情况下,观测值应小于 P10 值,在 90% 的情况下 P90 值应更高。

总的来说:

  • 在电力数据集的任务上,Quantile Loss、MSE 和 RRMSE 损失表现良好。

  • 在交通数据集任务上,Log Cosh Loss、Quantile Loss 和 MAE 表现更好。

  • 在 Favorita 数据集任务上,RAE、LogCosh Loss 和 Quantile Loss 表现更好。

  • 在波动率数据集任务上,Quantile Loss、MAE 和 Huber Loss 表现更好。

c94cee12ea460048a3a4a2d12c47e841.png

4fb2fc31d1698de83c0f0e46d83a2eca.png

e10c8aa5f799cebb9dd00ac02ba01ecc.png

fb24d6295a99638a90f5692f46c565e3.png


总结展望

损失函数在确定给定目标的良好拟合模型中起着关键作用。对于时间序列预测等复杂目标,不可能确定通用损失函数。有很多因素,如异常值、数据分布的偏差、ML 模型要求、计算要求和性能要求。没有适用于所有类型数据的单一损失函数。在主要关注模型架构和数据类型的学术环境中,损失函数可以通过用于训练的数据集属性(如分布、边界等)来确定。

这项工作试图构建特定损失函数可能有用的情况,例如在数据集中出现异常值的情况下,均方误差是最佳策略;然而,如果有更少的异常值,则平均绝对误差将是比 MSE 更好的选择。同样,如果我们希望保持平衡,并且我们的目标基于百分位数损失,那么使用 LogCosh 是更好的方法。本文总结了用于时间序列预测的 14 个著名损失函数,并开发了一种易于处理的损失函数形式,用于改进和更准确的优化。

outside_default.png

参考文献

outside_default.png

[1] P10,P50,P90和方差:

https://imepisode.top/2020/03/p10p50p90%E5%92%8C%E6%96%B9%E5%B7%AE/

推荐阅读:

我的2022届互联网校招分享

我的2021总结

浅谈算法岗和开发岗的区别

互联网校招研发薪资汇总

2022届互联网求职现状,金9银10快变成铜9铁10!!

公众号:AI蜗牛车

保持谦逊、保持自律、保持进步

7a1e235f2043ec5d899962be72b16d71.jpeg

发送【蜗牛】获取一份《手把手AI项目》(AI蜗牛车著)

发送【1222】获取一份不错的leetcode刷题笔记

发送【AI四大名著】获取四本经典AI电子书

猜你喜欢

转载自blog.csdn.net/qq_33431368/article/details/132398847
今日推荐