- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我构建了一个自定义的 EST(指数平滑)模型。首先,我定义了一个函数,其中包含传递给第二个函数的参数定义,该函数执行计算并返回预测错误。然后将这些平方并求和。然后,最小化器应优化参数,以便最小化平方误差的总和。
如果我让函数以起始值运行,则该模型有效。但是一旦我把它从 scipy 中抛出最小化,它就会多次给我以下两个错误:
RuntimeWarning: double_scalars 中遇到溢出
运行时警告:在 double_scalars 中遇到无效值
我检查了我的数据 (y) 并且没有零值。因此计算不应返回任何零。
此外,我尝试了边界和其他最小化方法,这也无济于事。
(这些是我从其他问题中得到的想法)
任何帮助是极大的赞赏 :)
'''
from scipy.optimize import minimize
def model(params, y):
alpha = params[0]
beta = params[1]
gamma = params[2]
omega = params[3]
l_init_HM = params[4]
b_init_HM = params[5]
s_init7_HM = params[6]
s_init6_HM = params[7]
s_init5_HM = params[8]
s_init4_HM = params[9]
s_init3_HM = params[10]
s_init2_HM = params[11]
s_init_HM = params[12]
results = ETS_M_Ad_M(alpha,beta,gamma,omega,
l_init_HM,b_init_HM,s_init7_HM,
s_init6_HM,s_init5_HM,s_init4_HM,
s_init3_HM,s_init2_HM,s_init_HM,y)
error_list = results['errors_list']
error_list = [number ** 2 for number in error_list]
#returning the sum of squared errors
#this is the ML estimate, or rather Adjusted Least Squared (ALS)
#Hyndman p. 69
error_sum = sum(error_list)
return error_sum
def ETS_M_Ad_M(alpha,beta,gamma,omega,
l_init_HM,b_init_HM,s_init7_HM,
s_init6_HM,s_init5_HM,s_init4_HM,
s_init3_HM,s_init2_HM,s_init_HM,y):
#computing the number of time points as the length of the forecasting vector
t = len(y)
errors_list = list()
point_forecast = list()
l_list = list()
b_list = list()
s_list = list()
#parameter definition
#Initilaisation
l_past = l_init_HM
b_past = b_init_HM
s_past = s_init7_HM
s_past7 = s_init6_HM
s_past6 = s_init5_HM
s_past5 = s_init4_HM
s_past4 = s_init3_HM
s_past3 = s_init2_HM
s_past2 = s_init_HM
mu = (l_past + omega * b_past) * s_past
#compute forecasting error at timepoint t
e = (y[0] - mu) / y[0]
#compute absolute errors for ML estimation
e_absolute = y[0] - mu
#save estimation error for Likelihood computation
errors_list.append(e_absolute)
point_forecast.append(mu)
l_list.append(l_past)
b_list.append(b_past)
s_list.append(s_past)
#Updating
#updating all state estimates for time point t
l = (l_past + omega * b_past) * (1 + alpha * e)
b = omega * b_past + beta * (l_past + omega * b_past) * e
s = s_past * (1 + gamma * e)
#computation loop:
for i in range(1,t): #start at 1 as the first index '0' is used in the initialization
#Prediciton
#denote updated states from t-1 as past states for time point t
l_past = l
b_past = b
s_past7 = s_past6
s_past6 = s_past5
s_past5 = s_past4
s_past4 = s_past3
s_past3 = s_past2
s_past2 = s
#Observation
#compute one step ahead forecast for timepoint t
mu = (l_past + omega * b_past) * s_past
#compute forecasting error at timepoint t
e = (y[i] - mu) / y[i]
#compute absolute errors for ML estimation
e_absolute = y[i] - mu
#save estimation error for Likelihood computation
#saving squared errors
errors_list.append(e_absolute)
point_forecast.append(mu)
l_list.append(l_past)
b_list.append(b_past)
s_list.append(s_past)
#Updating
#updating all state estimates for time point t
l = (l_past + omega * b_past) * (1 + alpha * e)
b = omega * b_past + beta * (l_past + omega * b_past) * e
s = s_past * (1 + gamma * e)
return {'errors_list' : errors_list, 'point forecast' : point_forecast,
'l_list' : l_list, 'b_list' : b_list, 's_list' : s_list}
#Defining Starting Parameters
Starting_Parameters = [0.1, #alpha
0.01, #beta
0.01, #Gamma
0.99, #omega
5556.151751807499, #l_init
92.90080519198762, #b_init
1.256185460504065, #s_init7
1.0317387565497154, #s_init6
0.8373829313978448, #s_init5
0.8220047728017161, #s_init4
0.8461049900287951, #s_init3
0.9412435736696254, #s_init2
1.2653395150482378] #s_init
# -> starting values from Hyndman 2008 p.24
minimize(model, Starting_Parameters, args=(y), method='BFGS')
'''
y 中包含的时间序列通过以下链接上传到我的 GitHub:
最佳答案
alpha、beta、gamma 和 omega 不应该限制在 0 和 1 之间吗?
此外您忘记分配 s_past
在 for 循环中。
关于Python scipy.minimize : overflow encountered in double_scalars and invalid value encountered in double_scalars,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63361339/
我构建了一个自定义的 EST(指数平滑)模型。首先,我定义了一个函数,其中包含传递给第二个函数的参数定义,该函数执行计算并返回预测错误。然后将这些平方并求和。然后,最小化器应优化参数,以便最小化平方误
无法解析模板“ASClass”错误信息: This template did not produce a Java class or an interface package com.example.
我正在尝试将我的井字游戏结果输出到数据库。但是,每当两个客户端之间的匹配完成时,我都会遇到此错误。这是我的服务器端代码和错误消息的摘录: 数据库类: import java.sql.*;
我想创建一个过程来检查记录是否存在,然后更新,否则插入。但是,有一个问题我试图解决,但无法解决。请帮助。 CREATE TABLE JOB_RUN ( DATE_KEY VARCHAR2(8), JO
这是我第一次在 derby 查询中创建存储过程。我正在尝试创建一个程序。当我尝试运行查询时,出现错误 Encountered "BEGIN" 代码 CREATE PROCEDURE show_name
当我运行 pyOpenTld 时,我得到 RuntimeWarning: overflow encountered in int_scalars从这个模块。为什么会这样? Warning (from
昨晚将一个disucz论坛进行转移后,发现打开的页面上回多一个PHP has encountered a Stack overflow 这个提示错误,进过翻译为“PHP遇到堆栈溢出”。我就感觉奇怪了
我是机器学习和 numpy 的新手,我一直在尝试在来自 sklearn 的波士顿住房数据集上运行梯度下降我的实现适用于小型随机数据集,但在波士顿数据集中它会产生这些警告 :12: RuntimeWar
我正在尝试在 Windows Server 2008 上使用 TortoiseSVN checkout SVN 存储库。我在 checkout 时收到错误消息“遇到不正确的参数”,仅此而已。知道这里可
我正在尝试使用 Parsec 在 Haskell 中编写解析器。目前我有一个可以解析的程序 test x [1,2,3] end 执行此操作的代码如下 testParser = do { rese
这个问题已经有答案了: Android 8: Cleartext HTTP traffic not permitted (37 个回答) 已关闭 3 年前。 我正在 Android Studio 上构
我在 angular.js 中定义了一个空模块: angular.module('todoList', [], function () { }) 然后我想在我的 conf.js 中测试它,我加载这些j
当使用OpenJPA在内存数据库org.apache.derby中执行select语句时,遇到以下错误: javax.ejb.EJBException: The bean encountered a
我需要开始处理外来字符,在这样做的过程中,我想我真的搞砸了文件的编码。 我得到的错误是: Lexical error at line 1, column 8. Encountered: "" (0)
我试图在 Python 中创建一个 sigmoid 函数,但是,我收到以下错误: RuntimeWarning: overflow encountered in exp 这是我的代码: def sig
我有三个耦合的常微分方程,我在 python 中使用 RK4 方法在给定的初始条件下求解它们。当我运行它们时,我收到以下错误: RuntimeWarning: overflow encountered
我是 Hadoop 和 Pig 的初学者。我检查了在cloudera虚拟镜像中证明的例子,并对其进行了修改以计算前5个常用词: Lines = LOAD '/user/hue/pig/examples
我是 Python 的新手,这是我编写脚本的第一件事,我只是想知道我能做些什么来删除这个警告: Warning (from warnings module): File "C:\Users\Lur
我正在编写一个 UNIX paste 克隆。然而,我不断收到“遇到断点”消息,但 VS 不会告诉我发生在哪一行。 #include #include #define INITALLOC 16
无论我是在 Visual Studio 2017 中同步还是只是使用 Git Bash 进行推送,我都会不断收到此错误。看起来 PUSH/PULL 命令有效,但我仍然看到此错误并希望它消失。 我的 W
我是一名优秀的程序员,十分优秀!