- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
data <-c(88, 84, 85, 85, 84, 85, 83, 85, 88, 89, 91, 99, 104, 112, 126, 138, 146,151, 150, 148, 147, 149, 143, 132, 131, 139, 147, 150, 148, 145, 140, 134, 131, 131, 129, 126, 126, 132, 137, 140, 142, 150, 159, 167, 170, 171, 172, 172, 174, 175, 172, 172, 174, 174, 169, 165, 156, 142, 131, 121, 112, 104, 102, 99, 99, 95, 88, 84, 84, 87, 89, 88, 85, 86, 89, 91, 91, 94, 101, 110, 121, 135, 145, 149, 156, 165, 171, 175, 177, 182, 193, 204, 208, 210, 215, 222, 228, 226, 222, 220)
为什么作用于数据一阶差分的 ARMA 模型与对应的 ARIMA 模型不同?
for (p in 0:5)
{
for (q in 0:5)
{
#data.arma = arima(diff(data), order = c(p, 0, q));cat("p =", p, ", q =", q, "AIC =", data.arma$aic, "\n");
data.arma = arima(data, order = c(p, 1, q));cat("p =", p, ", q =", q, "AIC =", data.arma$aic, "\n");
}
}
与 Arima(data,c(5,1,4))
和 Arima(diff(data),c(5,0,4))
相同预测包。我可以通过
auto.arima(diff(data),max.p=5,max.q=5,d=0,approximation=FALSE, stepwise=FALSE, ic ="aic", trace=TRUE);
auto.arima(data,max.p=5,max.q=5,d=1,approximation=FALSE, stepwise=FALSE, ic ="aic", trace=TRUE);
但是 auto.arima 背后的算法似乎没有考虑这些数据的最小 AIC 估计值的持有者;因此,次优选择 ARMA(3,0) 而不是 ARMA(5,4) 作用于第一个差异。一个相关的问题是,在一个人认为一个模型比另一个模型更好之前,两个 AIC 估计值应该相差多少与编程无关 - 至少应该考虑/报告最小的 AIC 持有者,即使 9 个系数可能有点太多了根据 100 次观测进行预测。
我的 R 问题是:
1) 双循环的矢量化版本,所以它更快?
2) 为什么 arima(5,1,4)
作用于数据和 arma(5,4)
作用于数据的一阶差分?举报哪一个?
3) 如何对 AIC 输出进行排序,以便较小的优先?
谢谢。
最佳答案
这里提出了很多问题和问题。我会尽量一一回复。
Arima()
只是 arima()
的包装,所以它会给出相同的模型。
arima() 通过使用扩散先验来处理具有差异的模型。这与在拟合模型之前仅对数据进行差分不同。因此,您会从 arima(x,order=c(p,1,q))
和 arima(diff(x),order=c(p,0, q))
.
auto.arima()
直接处理差分,在拟合时不使用扩散先验。因此,您将从 auto.arima(x,d=1,...)
和 auto.arima(diff(x),d=0,...) 获得相同的结果
auto.arima()
有一个参数 max.order
指定 p+q 的最大值。默认情况下,max.order=5
,因此不会考虑您的 arima(5,1,4)
。如果你想考虑这么大的模型,增加 max.order
(虽然我不推荐它)。
您不能在每次迭代时对涉及非线性优化的循环进行矢量化。
如果您想对输出进行排序,您需要将其保存到 data.frame 中,然后对相关列进行排序。代码目前只是在运行时吐出结果,除了最新拟合的模型外,什么都没有保存。
关于r - ARIMA、ARMA 和 AIC?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1664473/
code (m); arma::umat a=trans(M)>M; arma::mat N=a; return Rcpp::wrap(N); ' coxFunc ::from(var)你想要
我有一个矩阵 X,它由 arma::vectorise 函数矢量化。在对转换后的向量 x 进行一些计算后,我想将其整形为 arma::mat。我尝试在 Armadillo 中使用 .reshape 函
我有一个矩阵 X,它由 arma::vectorise 函数矢量化。在对转换后的向量 x 进行一些计算后,我想将其整形为 arma::mat。我尝试在 Armadillo 中使用 .reshape 函
我正在尝试测试 ARMA 模型,并完成此处提供的示例: http://www.statsmodels.org/dev/examples/notebooks/generated/tsa_arma_0.h
时间序列的 ARMA 预测摘要 ( print arma_mod.summary() ) 显示了一些关于置信区间的数字。是否可以将这些数字用作显示预测值的图中的预测区间? ax = indexed_d
开始有 R 经验,但完全是 C++ 新手,我用 RcppArmadillo 编写了一些函数,并且对它的可用性和速度非常热情。我现在想使用函数 RcppArmadillo.package.skeleto
我有大约五年的一年期利率数据。我想为此利率创建一个模型,并且得出的结论是 ARMA(3,2) 和 GARCH(1,1) 是合适的。因此,我使用下面的代码来获得我的估计。 > stibor1ydarma
当尝试将带有 statsmodels 的 ARMA(1,2) 拟合到股票数据时间序列的对数返回时,我收到错误“计算的初始 AR 系数不是平稳的”我认为我尝试分析的时间序列本身是平稳的,并且与白噪声非常
我想预测一个时间序列的返回,我首先拟合了数据集,但当我预测明天的返回时它不起作用。我的代码是 date = datetime.datetime(2014,12,31) todayDat
我正在使用 arma::find_unique,我认为它返回了 vector 中每个唯一值第一次出现的索引,但它似乎返回了其他内容。 这是一个玩具函数: // [[Rcpp::export]] arm
我正在做这个作业,我试图运行这个程序 5000 次,并对模型进行 AR(1) 和 AR(2) 拟合。首先,我定义了一个生成时间序列的函数,如下所示: def ts_gen_ar1(size,sigma
这里有点新,但试图让 statsmodel ARMA 预测工具起作用。我从 Yahoo 导入了一些股票数据,并让 ARMA 给我拟合参数。然而,当我使用预测代码时,我收到的只是一个我似乎无法弄清楚的错
我想预测时间序列数据。我在之前的帖子中读到模块 statsmodels 具有使用 ARMA 方法进行预测所需的工具,这正是我一直在寻找的工具。尽管如此,我在预测数据时遇到了麻烦。有人可以解释模型中使用
data <-c(88, 84, 85, 85, 84, 85, 83, 85, 88, 89, 91, 99, 104, 112, 126, 138, 146,151, 150, 148, 14
我正在尝试设置 arma::mat 的值元素方面,每个元素的值取决于每个元素的多索引(行、列)。 有没有办法在迭代期间检索元素的当前位置? 基本上,我想做点什么like in the sparse m
vector y_long_name 有 100 个成员,我打算只操作它的一个由前三个成员组成的子 vector 。 subvector 函数在我的代码中用作左值: y_long_name.subve
如何将 arma::cx_mat 转换为数组数组? 转换的动机是使用 C 库 libmatio 来输出 .mat 文件。 到目前为止,我已经创建了一个函数来将 arma:cx_mat 转换为 vect
我的问题相当简单:我想使用 statsmodels 定义 ARMA 建模过程中的特定顺序滞后。 假设我有一个时间序列 TS,我想估计以下模型作为示例: TS(t)= c + TS(t-2) + TS(
我想要将 ARMA(p,q) 模型拟合到模拟数据 y,并检查不同估计方法对结果的影响。但是,像这样将模型拟合到同一对象 model = tsa.ARMA(y,(1,1)) results_mle =
是否有任何 C++ 库允许计算时间序列的 ARMA?经过多次搜索尝试后,我一直找不到任何内容。 谢谢! 最佳答案 Cronos是一个用 C++ 编写的支持 ARMA 模型的开源库。虽然它没有任何文档,
我是一名优秀的程序员,十分优秀!