VARMA模型的原理与实现

news2025/1/25 9:17:27

文章目录

    • 1.多变量模型的基本思想
    • 2.VAR模型与VARMA模型
    • 3.VARMA模型的实现

1.多变量模型的基本思想

​ 在现实和竞赛中,时序数据往往是多变量时间序列,我们往往需要借助除了时间之外的变量的帮助来完成预测。比如,如果我们需要预测居民消费支出的情况,除了和时间相关的季节变化、节日变化、文化影响等因素,销售还可能受到居民收入情况的显著影响。因此如果将居民收入也纳入研究范围,那就能够得到更精准的预测数据。可见,多变量时间序列会比较常见,也是因为实现问题更为复杂、影响因素更多的缘故。
​ ARIMA系列模型能不能直接被用于多变量时间序列数据呢?从数值上来说是有可能的,但从应用角度来说却非常困难,有两点原因:
①ARIMA系列模型的数学过程是基于单变量时间序列设计的,单变量时间序列中唯一的影响因素就是时间,但多变量时间序列数据会同时受到时间和其他重要因子的影响,因此ARIMA系列模型很有可能会忽略掉时间之外的重要因子,从而导致模型效果很糟糕。
​ ②ARIMA模型要求时间序列数据必须是按时间顺序排列、时间不能有重复、时间间隔一致的,但多变量时间序列数据从逻辑上明显无法满足这个要求,因为多变量数据是由多个索引共同决定唯一标签值的,因此时间索引必然有重复,也不能按顺序排列。

img

转换思路让多变量时间序列数据被转变成ARIMA模型可以处理的形式,例如,如果将用户的购买数据拆开、将每个用户的消费额按时间顺序整理出一列,那这每列数据都满足单变量时间序列的基本要求(时间顺序从前向后、没有重复的时间、时间间隔均匀等等)。如此,多变量时间序列就变为了多个单变量时间序列,而SARIMAX系列模型就可以被用于该数据的每一列来进行建模了。

img

​ 在统计学中,常常以上图右侧的方式来理解多变量时间序列数据。在这种数据形式下,任意一列都是单变量的时间序列,每个列就是一个变量,而这些列的组合共同构建了多变量时间序列数据。现在的情况中涉及到99个用户,因此在这个多变量时间序列中变量的数量为99,即在一个时间点下需要求解99个值。
​ 在单变量时间序列中,一个时间点下只需要求解一个值,而在多变量时间序列中,一个时间点下会需要求解多个值,并且,不同变量之间的值应该是会互相影响的,否则没有必要强行组成多变量时序数据,但单变量时序模型只能处理一个变量和自己历史数据的关系,却不能处理变量与变量之间的联系。可见,多变量时序数据之间的联系更复杂,拟合策略需要更多深度。
​ 如何拟合这些更复杂的关系呢?不同的模型可能采用不同的策略,最经典、同时也最容易理解的两种策略如下:
策略1:模型融合。将多变量时间序列变形为多个单变量时间序列,再拟合这些单变量时间序列模型之间的关系。现在我们有99个变量,那我们可以针对每个变量在9月9日-9月30日之内的数据进行建模,最终获得99个模型。在此基础上,我们只需要再针对99个模型之间的关系进行建模,对这99个横型的结果进行融合,就可以对多变量时间序列进行训纺和预测了。这种傻瓜式的方法很简单也很有效,但是计算压力巨大,并且最终用于融合的模型可能变得异常复杂。
第路2:拓展ARIMA系列模型的假设,直接跨变量建立当前时间点上的值与所有历史时间点上的值的关联。如下图所示,ARIMA模型假设一个变量的未来是由该变量的历史决定的,而我们可以将该假设拓展至所有变量:一个变量的未来是由该变量自己和所有其他变量的历史共同决定的。只要求解出未来的值和多个变量上的历史值之间的系数,就可以拟合变量与自身关系的同时、也拟合出变量之间的关系。大部分统计学模型使用了这样的思路。

img

​ 在统计学、机器学习和深度学习领域中存在大量能够解决多变量时序问题的算法,包括下面这些常见的时间序列模:
◒向量自回归模型(VAR)
◒向量自回归移动平均模型(VARMA)
◒向量自回归移动平均与外生变量模型(VARMAX)
◒向量误差校正模型(VECM)
◒联合ARIMA-VAR楼型
◒贝叶斯结构时间序列模型
◒动态因子模型
◒状态空间模型(卡尔曼滤波)
◒深度学习模型,如LSTM,GRU和卷积神经网络(CNN)等
​ 在这之中,VAR模型是从AR模型改造而来,VARMA模型是从ARMA横型改造而来,他们通过拓展AR和ARMA模型来进行建模。具体地来说,这两个模型能够跨变量建立联系,直接假设当前时间点上的值不止与自己过去的值有关,也与其他变量过去的值有关,从而能够一次性建立跨变量跨序列的模型。

2.VAR模型与VARMA模型

VAR模型是在AR模型基础上拓展出的模型,它的本质是可以对多变量时间序列进行预测的AR模型。因此VAR模型满足AR模型的一切前提假设,同时也与AR模型共享大部分数学公式和运算方法,并在此基础上发展出了三类VAR模型: 精简型VAR (Reduced VAR models),递归性VAR (ecursive VARmodels)以及结构型VAR (Structural VAR models),下面将以精简型VAR为例来了解VAR模型。
AR模型相信一个时间点上的标签值可以由过去某个时间段内的所有时间点上的标签值线性组合后构成(实际就是加权求和),因此对于一个AR§模型,有如下公式:
y t = c + β 1 y t − 1 + β 2 y t − 2 + . . . + β p y t − p y_{t}=c+\beta_{1}y_{t-1}+\beta_{2}y_{t-2}+...+\beta_{p}y_{t-p} yt=c+β1yt1+β2yt2+...+βpytp
在该公式当中, y t y_{t} yt是时间点 t t t上的标签, y t − 1 y_{t-1} yt1是时间点 t − 1 t-1 t1上的标签, c c c是常数项, z t z_{t} zt则表示时间点 t t t上的白噪音。
假设现在有一个多变量时间序列,除了时间之外还涉及到k个变量(假设,是k个用户),一个用户和一个时间点共同决定了该时间点上的值,那此时一个精简型VAR§模型的数学公式为:
y t = c + B 1 y t − 1 + B 2 y t − 2 + . . . + B p y t − p \pmb{y_{t}=c+B{1}y_{t-1}+B{2}y_{t-2}+...+B{p}y_{t-p}} yt=c+B1yt1+B2yt2+...+Bpytp
其中, y t \pmb{y_{t}} yt是k个变量在时间点时的标签组成的向量,一般结构为(k,),一般可表示为 [ y ( t , 1 ) , y ( t , 2 ) , y ( t , 3 ) . . . y ( t , k ) ] . T [y_{(t,1)},y_{(t,2)},y_{(t,3)}...y_{(t,k)}].T [y(t,1),y(t,2),y(t,3)...y(t,k)].T

很明显,该公式可以一次性求解出时间 t t t下的k个值。在该公式中, c c c z t z_{t} zt也都是形如(k,)的向量,而$$则是系数矩阵,每个矩阵中包合变量与变量自身、变量与变量之间的系数,一般形状为(k.k)。

在这里插入图片描述

假设现在VAR模型中的p为1,即 y t y_{t} yt只与历史前一天的值有关,并且现在变量的数目为2,则 y t y_{t} yt为可表示为:
y t = c + B 1 ∗ y t − 1 + z t [ y ( t , 1 ) y ( t , 2 ) ] = [ c ( 1 ) c ( 2 ) ] + [ β 1 ( 11 ) β 1 ( 12 ) β 1 ( 21 ) β 1 ( 22 ) ] ∗ [ y ( t − 1 , 1 ) y ( t − 1 , 2 ) ] + [ z ( t , 1 ) z ( t , 2 ) ] \pmb{y_{t}=c+B{1}*y_{t-1}+z_{t}}\\ \begin{bmatrix} y_{(t,1)} \\ y_{(t,2)} \\ \end{bmatrix}=\begin{bmatrix} c_{(1)} \\ c_{(2)} \\ \end{bmatrix}+ \begin{bmatrix} \beta1_{(11)} & \beta1_{(12)} \\ \beta1_{(21)} & \beta1_{(22)} \\ \end{bmatrix}* \begin{bmatrix} y_{(t-1,1)} \\ y_{(t-1,2)} \\ \end{bmatrix}+ \begin{bmatrix} z_{(t,1)} \\ z_{(t,2)} \\ \end{bmatrix} yt=c+B1yt1+zt[y(t,1)y(t,2)]=[c(1)c(2)]+[β1(11)β1(21)β1(12)β1(22)][y(t1,1)y(t1,2)]+[z(t,1)z(t,2)]
其中, β \beta β后的大数字1指向的是时间间隔,而小数字(11)和(12)等则代表变量的序号,因此 β 1 ( 11 ) \beta1_{(11)} β1(11)展示了变量1与上一个时间点上的自己之间的关系, β 1 ( 12 ) \beta1_{(12)} β1(12)展示了变量1与上一个时间点上的变量2之间的关系。假设模型变得更加复杂,那 y t − 2 y_{t-2} yt2前的 β \beta β就不再是 β 1 \beta_{1} β1,而是 β 2 \beta_{2} β2了。

需要注意的是,当 B 1 ∗ y t − 1 \pmb{B_{1}*y_{t-1}} B1yt1的部分相乘后可以得到:
[ β 1 ( 11 ) β 1 ( 12 ) β 1 ( 21 ) β 1 ( 22 ) ] ∗ [ y ( t − 1 , 1 ) y ( t − 1 , 2 ) ] = [ β 1 ( 11 ) y ( t − 1 , 1 ) + β 1 ( 12 ) y ( t − 1 , 2 ) β 1 ( 21 ) y ( t − 1 , 1 ) + β 1 ( 22 ) y ( t − 1 , 2 ) ] \begin{bmatrix} \beta1_{(11)} & \beta1_{(12)} \\ \beta1_{(21)} & \beta1_{(22)} \\ \end{bmatrix}* \begin{bmatrix} y_{(t-1,1)} \\ y_{(t-1,2)} \\ \end{bmatrix}= \begin{bmatrix} \beta1_{(11)}y_{(t-1,1)} + \beta1_{(12)}y_{(t-1,2)} \\ \beta1_{(21)}y_{(t-1,1)} +\beta1_{(22)}y_{(t-1,2)} \\ \end{bmatrix} [β1(11)β1(21)β1(12)β1(22)][y(t1,1)y(t1,2)]=[β1(11)y(t1,1)+β1(12)y(t1,2)β1(21)y(t1,1)+β1(22)y(t1,2)]
所以实际上的 y t \pmb{y_{t}} yt等于:
y t = c + B 1 ∗ y t − 1 + z t [ y ( t , 1 ) y ( t , 2 ) ] = [ c ( 1 ) + β 1 ( 11 ) y ( t − 1 , 1 ) + β 1 ( 12 ) y ( t − 1 , 2 ) + z ( t , 1 ) c ( 2 ) + β 1 ( 21 ) y ( t − 1 , 1 ) + β 1 ( 22 ) y ( t − 1 , 2 ) + z ( t , 2 ) ] \pmb{y_{t}=c+B{1}*y_{t-1}+z_{t}}\\ \begin{bmatrix} y_{(t,1)} \\ y_{(t,2)} \\ \end{bmatrix}= \begin{bmatrix} c_{(1)}+\beta1_{(11)}y_{(t-1,1)} + \beta1_{(12)}y_{(t-1,2)}+z_{(t,1)} \\ c_{(2)}+\beta1_{(21)}y_{(t-1,1)} +\beta1_{(22)}y_{(t-1,2)}+z_{(t,2)} \\ \end{bmatrix} yt=c+B1yt1+zt[y(t,1)y(t,2)]=[c(1)+β1(11)y(t1,1)+β1(12)y(t1,2)+z(t,1)c(2)+β1(21)y(t1,1)+β1(22)y(t1,2)+z(t,2)]
​ 这种形式也可以被理解为建立了两个跨变量的AR模型,再共同组合形成最终的大模型。在现在的情况下,每个AR模型中影响未来的不是只有当前变量过去的值,也有其他变量过去的值,这就让拟合多变量时间序列成为可能。
​ 基于VAR模型的理解,VARMA模型是在ARMA模型的基础上改进而来,在VARMA模型中,当前的值会受当前变量过去的值影响、也会受到其他变最过去的值影响。
y t = μ + B 1 y t − 1 + . . . + B p y t − p + ϵ t + θ 1 ϵ t − 1 + . . . + θ q ϵ t − q \pmb{y_{t}=\mu+B{1}y_{t-1}+...+B{p}y_{t-p}+\epsilon_{t}+\theta1\epsilon_{t-1}+...+\theta{q}\epsilon_{t-q}} yt=μ+B1yt1+...+Bpytp+ϵt+θ1ϵt1+...+θqϵtq
​ 很明显,当p=0时实现VMA模型,当q =0时实现VAR模型,当p和q都不为0时实现的就是VARMA模型。值得一提的是,VARIMA模型比较少见,常见的是VARMA和VARMAX等模型,这主要是因为ARIMA模型中的字母I其实代表用于处理非平稳数据的差分技术,但这一技术很难被应用到多变量时间序列当中。如果我们希望多变量时序数据具有平稳性,那就需要一次性对所有变量的数据都进行不同程度的差分,并最终保证所有变量的联合概率分布处于平稳状态。这一状态在实际使用算法时几平不可能达到,因此大部分现实情况下我们可能会忽略不平稳性在多变量时序数据中带来的影响。也因此,多变量时序数据下我们就很少使用差分技术,也就很少使用字母i了。
​ 在统计学领域,VAR和VARMA模型是应用最广泛的多变量时序模型,这两个模型思路清晰简单、并且直接在原本的AR和ARMA模型上改进,因此他们的使用方式、注意事项、缺点改善等也都可借鉴AR和ARMA模型经验。同时,交叉组合不同变量并拟合他们之间的关系可以找出远超人工想象的奇妙联系,因此VAR和VARMA模型在许多场合下都可以提升模型表现。不过,这一系类模型也有明显的缺点,包括:

​ ①由于要计算不同变量之间的交叉组合关系,VAR和VARMA模型可能变得复杂度太高、计算量过大,这会导致寻找超参数、抗过拟合等问题变得更加复杂和困难。

​ ②由于是在AR和ARMA模型基础上改进,因此VAR和VARMA模型也需要满足原始模型的严格条件例如,残差需要正态分布、相互独立。例如,残差需要正态分布、相互独立。例如,各项检验需要严格通过等等。

​ ③根据实验的结果,VARMA模型对异常值和离群值极其敬感,因此也可能导致非常糟糕的结果。

3.VARMA模型的实现

import numpy as np
import pandas as pd
import statsmodels.api as sm
import matplotlib.pyplot as plt
dta=pd.read_stata(r'F:\Jupyter Files\时间序列\lutkepohl2.dta')
dta.index=dta.qtr #将时间窗口作为索引
dta.index.freq=dta.index.inferred_freq #让statsmodel认知时间的频率
dta.head()
invincconsumpqtrln_invdln_invln_incdln_incln_consumpdln_consump
qtr
1960-01-011804514151960-01-015.192957NaN6.111467NaN6.028278NaN
1960-04-011794654211960-04-015.187386-0.0055716.1420370.0305706.0426330.014355
1960-07-011854854341960-07-015.2203560.0329706.1841490.0421116.0730440.030411
1960-10-011924934481960-10-015.2574950.0371396.2005090.0163606.1047930.031749
1961-01-012115094591961-01-015.3518580.0943636.2324480.0319396.1290500.024257
# 从中取出一段时间+三列作为例子
endog=dta.loc['1960-04-01':'1978-10-01',['dln_inv','dln_inc','dln_consump']]
# 必须将数据整理成如下结构,才能输入到statsmodels的VARMA中
endog
dln_invdln_incdln_consump
qtr
1960-04-01-0.0055710.0305700.014355
1960-07-010.0329700.0421110.030411
1960-10-010.0371390.0163600.031749
1961-01-010.0943630.0319390.024257
1961-04-01-0.0435910.021381-0.002181
1977-10-010.0261880.0210320.017272
1978-01-010.0255200.0108430.012479
1978-04-010.0355800.0145990.018431
1978-07-010.0255080.0243390.013194
1978-10-010.0363670.0051730.005990

75 rows × 3 columns

#建立一个VAR(2)模型,变量数此时为3
mod=sm.tsa.VARMAX(endog #多变量
                  ,order=(2,0))#参数p,q
res=mod.fit(maxiter=1000,disp=False) #最大迭代次数
print(res.summary())
-----------------------------------------------------------------------
Statespace Model Results                                    
=================================================================================================
Dep. Variable:     ['dln_inv', 'dln_inc', 'dln_consump']   No. Observations:                   75
Model:                                            VAR(2)   Log Likelihood                 621.917
                                             + intercept   AIC                          -1189.835
Date:                                   Sat, 14 Oct 2023   BIC                          -1127.263
Time:                                           18:36:17   HQIC                         -1164.851
Sample:                                       04-01-1960                                         
                                            - 10-01-1978                                         
Covariance Type:                                     opg                                         
====================================================================================
Ljung-Box (Q):          56.81, 35.78, 21.66   Jarque-Bera (JB):    11.54, 8.00, 1.54
Prob(Q):                   0.04, 0.66, 0.99   Prob(JB):             0.00, 0.02, 0.46
Heteroskedasticity (H):    0.48, 1.21, 0.74   Skew:               0.14, -0.39, -0.33
Prob(H) (two-sided):       0.07, 0.64, 0.45   Kurtosis:             4.90, 4.40, 3.22
                           Results for equation dln_inv                           
==================================================================================
                     coef    std err          z      P>|z|      [0.025      0.975]
----------------------------------------------------------------------------------
intercept         -0.0163      0.019     -0.874      0.382      -0.053       0.020
L1.dln_inv        -0.3207      0.128     -2.498      0.012      -0.572      -0.069
L1.dln_inc         0.1513      0.911      0.166      0.868      -1.635       1.938
L1.dln_consump     0.9514      1.022      0.931      0.352      -1.051       2.954
L2.dln_inv        -0.1616      0.196     -0.825      0.409      -0.545       0.222
L2.dln_inc         0.1201      0.673      0.179      0.858      -1.198       1.438
L2.dln_consump     0.9248      0.929      0.995      0.320      -0.897       2.746
                           Results for equation dln_inc                           
==================================================================================
                     coef    std err          z      P>|z|      [0.025      0.975]
----------------------------------------------------------------------------------
intercept          0.0161      0.006      2.509      0.012       0.004       0.029
L1.dln_inv         0.0448      0.047      0.950      0.342      -0.048       0.137
L1.dln_inc        -0.1497      0.181     -0.825      0.409      -0.505       0.206
L1.dln_consump     0.2894      0.245      1.182      0.237      -0.190       0.769
L2.dln_inv         0.0515      0.060      0.861      0.389      -0.066       0.169
L2.dln_inc         0.0194      0.207      0.094      0.925      -0.386       0.425
L2.dln_consump    -0.0134      0.215     -0.062      0.950      -0.435       0.408
                         Results for equation dln_consump                         
==================================================================================
                     coef    std err          z      P>|z|      [0.025      0.975]
----------------------------------------------------------------------------------
intercept          0.0132      0.006      2.071      0.038       0.001       0.026
L1.dln_inv        -0.0027      0.044     -0.061      0.952      -0.089       0.083
L1.dln_inc         0.2211      0.152      1.451      0.147      -0.078       0.520
L1.dln_consump    -0.2653      0.183     -1.447      0.148      -0.624       0.094
L2.dln_inv         0.0339      0.049      0.686      0.493      -0.063       0.131
L2.dln_inc         0.3498      0.180      1.944      0.052      -0.003       0.703
L2.dln_consump    -0.0210      0.174     -0.121      0.904      -0.361       0.319
                                    Error covariance matrix                                     
================================================================================================
                                   coef    std err          z      P>|z|      [0.025      0.975]
------------------------------------------------------------------------------------------------
sqrt.var.dln_inv                 0.0435      0.004      9.853      0.000       0.035       0.052
sqrt.cov.dln_inv.dln_inc         0.0015      0.002      0.662      0.508      -0.003       0.006
sqrt.var.dln_inc                 0.0112      0.001      9.449      0.000       0.009       0.014
sqrt.cov.dln_inv.dln_consump     0.0026      0.002      1.532      0.125      -0.001       0.006
sqrt.cov.dln_inc.dln_consump     0.0046      0.001      4.490      0.000       0.003       0.007
sqrt.var.dln_consump             0.0072      0.001      7.950      0.000       0.005       0.009
================================================================================================

Warnings:
[1] Covariance matrix calculated using the outer product of gradients (complex-step).

​ 这张summary表单中最后的Eror Covariance Matrix,就是列差的协方差拍阵,ARIMA模型要求残差项相互独立目满足正态分布,VARMA模型则要求多变量下的残差要满足均值向量为0的联合正态分布、且相互独立,因此才会提供协方差矩阵供我们判断不同变量的残差之间的关联程变。例如,残差协方差矩阵的第一列coef就代表了每个变量的方差,以及变量之间的协方差系数。在当前状况下办方差系数越靠近0越好。

​ 同时,在协方差短阵中执行的检验也是针对每一个方差和协方差值的单变量检验,也就展当前值息否为0的检验。
​ ◉单变量检验的原假设(H0):当前方差/协方差值coef为0
​ ◉单变量检验的备择假设(H1):当前方差/协方差值coef不为0

如果有任意项的p值大于规定的显著性水平a(0.05或0.01),就说明当前的方差/协方差值可能为0,当前项的系数没能拒绝原假设、无法通过显著性检验,模型对当前给出的非0值没有足够的信心。

​ 在VARMA模型中还可以设置“外生变量”(Exogenous series),,外生变量是会影响到时间序列数居,但是却不参与建横的变量。一个序列不参与建模,证明我们无需针对这个序列进行未来的预测,但是这个序列却会影响到我们要预测的时序数据。比如,当我们要预测标准普尔指数的变化时,典型的外生变量就是政府政策。我们并不想预测下一个时间点的政府政第会如何变化,但政府政第的变化确实会严重影响我们想要预则的标准普尔旨数。VARMA模型允许我们在建模时输入不止一个外生变量,这句以很大程度上地帮助我们提升横型的精度。

#建立带外生变量的VAR模型,此时变量数为2
exog=endog['dln_consump']
mod=sm.tsa.VARMAX(endog[['dln_inv','dln_inc']],order=(2,0),exog=exog)
res=mod.fit(maxiter=1000,disp=False) #最大迭代次数
print(res.summary())
----------------------------------------------------------------------------
  Statespace Model Results                             
==================================================================================
Dep. Variable:     ['dln_inv', 'dln_inc']   No. Observations:                   75
Model:                            VARX(2)   Log Likelihood                 366.957
                              + intercept   AIC                           -703.914
Date:                    Sat, 14 Oct 2023   BIC                           -669.152
Time:                            18:59:05   HQIC                          -690.034
Sample:                        04-01-1960                                         
                             - 10-01-1978                                         
Covariance Type:                      opg                                         
===================================================================================
Ljung-Box (Q):                57.73, 30.42   Jarque-Bera (JB):          12.23, 1.02
Prob(Q):                        0.03, 0.86   Prob(JB):                   0.00, 0.60
Heteroskedasticity (H):         0.45, 0.54   Skew:                      0.23, -0.29
Prob(H) (two-sided):            0.05, 0.13   Kurtosis:                   4.92, 3.00
                            Results for equation dln_inv                            
====================================================================================
                       coef    std err          z      P>|z|      [0.025      0.975]
------------------------------------------------------------------------------------
intercept           -0.0110      0.015     -0.723      0.470      -0.041       0.019
L1.dln_inv          -0.2414      0.099     -2.436      0.015      -0.436      -0.047
L1.dln_inc           0.4703      0.570      0.825      0.409      -0.647       1.588
L2.dln_inv          -0.1737      0.148     -1.175      0.240      -0.463       0.116
L2.dln_inc           0.2436      0.490      0.497      0.619      -0.716       1.204
beta.dln_consump     1.0875      0.691      1.573      0.116      -0.267       2.442
                            Results for equation dln_inc                            
====================================================================================
                       coef    std err          z      P>|z|      [0.025      0.975]
------------------------------------------------------------------------------------
intercept            0.0117      0.004      2.788      0.005       0.003       0.020
L1.dln_inv           0.0617      0.035      1.764      0.078      -0.007       0.130
L1.dln_inc          -0.1001      0.126     -0.795      0.427      -0.347       0.147
L2.dln_inv           0.0192      0.034      0.564      0.573      -0.048       0.086
L2.dln_inc          -0.1308      0.134     -0.975      0.329      -0.394       0.132
beta.dln_consump     0.6116      0.109      5.591      0.000       0.397       0.826
                                  Error covariance matrix                                   
============================================================================================
                               coef    std err          z      P>|z|      [0.025      0.975]
--------------------------------------------------------------------------------------------
sqrt.var.dln_inv             0.0432      0.004     12.296      0.000       0.036       0.050
sqrt.cov.dln_inv.dln_inc     0.0004      0.002      0.206      0.837      -0.004       0.004
sqrt.var.dln_inc             0.0101      0.001      9.978      0.000       0.008       0.012
============================================================================================

Warnings:
[1] Covariance matrix calculated using the outer product of gradients (complex-step).

从AlC和BIC的表现来看,预测变量的数目以及外生变量存在与否会很大程度上改变模型的表现。当存在外生变量的寸候,我们还可以绘制外生变量和预测变量的图像,来观察外生变量如何影响预测变量。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1094388.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构与算法--其他算法

数据结构与算法--其他算法 1 汉诺塔问题 2 字符串的全部子序列 3 字符串的全排列 4 纸牌问题 5 逆序栈问题 6 数字和字符串转换问题 7 背包问题 8 N皇后问题 暴力递归就是尝试 1,把问题转化为规模缩小了的同类问题的子问题 2,有明确的不需要继续…

yolov5+车辆重识别【附代码】

本篇文章主要是实现的yolov5和reid结合的车辆重识别项目。是在我之前实现的yolov5_reid行人重识别的代码上修改实现的baseline模型。 目录 相关参考资料 数据集说明 环境说明 项目使用说明 vehicle reid训练 yolov5车辆重识别 从视频中获取想要检测的车(待检测车辆) 车…

Attention Is All You Need原理与代码详细解读

文章目录 前言一、Transformer结构的原理1、Transform结构2、位置编码公式3、transformer公式4、FFN结构 二、Encode模块代码解读1、编码数据2、文本Embedding编码3、位置position编码4、Attention编码5、FFN编码 三、Decode模块代码解读1、编码数据2、文本Embedding与位置编码…

centos6/7 SOCKS5 堆溢出漏洞修复(RPM方式)curl 8.4 CVE-2023-38545 CVE-2023-38546

引用 https://darkdark.top/update-curl.html centos6 rpm 升级包下载:https://download.csdn.net/download/sinat_24092079/88425840 yum update libcurl-8.4.0-1.el6.1.x86_64.rpm curl-8.4.0-1.el6.1.x86_64.rpmcentos7 rpm 升级包下载:https://down…

ELF和静态链接:为什么程序无法同时在Linux和Windows下运行?

目录 疑问 编译、链接和装载:拆解程序执行 ELF 格式和链接:理解链接过程 小结 疑问 既然我们的程序最终都被变成了一条条机器码去执行,那为什么同一个程序,在同一台计算机上,在 Linux 下可以运行,而在…

Linux | 关于入门Linux你有必要了解的指令

目录 前言 1、ls指令 2、pwd指令 3、cd指令 4、touch指令 5、stat指令 6、mkdir指令 7、rmdir 与 rm指令 8、man指令 9、cp指令 10、mv指令 11、cat指令 (1)输入重定向 (2)输出重定向与追加重定向 12、less指令 1…

多模态模型文本预处理方式

句子级别 句子级别的表征编码一整个句子到一个特征中。如果一个句子有多个短语,提取这些短语丢弃其他的单词。 缺点:这种方式会丢失句子中细粒度的信息。 单词级别 将句子中的类别提取出来,结合成一个句子。 缺点:会在类别之…

【数据结构】线性表的抽象数据类型

🦄个人主页:修修修也 🎏所属专栏:数据结构 ⚙️操作环境:Visual Studio 2022 线性表抽象数据类型(LinearListAbstractDataType,简称 ADT)是一种非常重要的抽象数据类型,它是一种使用抽象的方式表示和实现一组数据元素的集合以及与…

宝塔面板服务器内存使用率高的三招解决方法

卸载多余PHP版本。假若安装了多个PHP版本,甚至把 php 5.3、5.4、7.0、7.3 全都安装上了,就会严重增加系统负载和内存使用率。 安装memcached 缓存组件,建议在宝塔面板后台直接安装。 卸载不常用软件。如:宝塔运维、宝塔一键安装…

php如何查找地图距离

要在PHP中使用高德地图、百度地图或腾讯地图获取位置信息,您可以使用它们的相应API服务。以下是获取位置信息的一般步骤: 思路: 获取API密钥:首先,您需要注册并获取相应地图服务提供商的API密钥。这将允许您访问他们的API以获取位…

CSS的美化(文字、背景) Day02

一、文字控制属性 分为:字体样式属性 、文本样式属性 1.1 CSS字体样式属性 1.color定义元素内文字颜色2.font-size 字号大小3 font-family 字体4 font-weight 字体粗细5.font-style 字体风格6.font 字体综合属性 1.1.1 > 文字颜色 color 属性名: color color …

Yakit工具篇:简介和安装使用

简介(来自官方文档) 基于安全融合的理念,Yaklang.io 团队研发出了安全领域垂直语言Yaklang,对于一些无法原生集成在Yak平台中的产品/工具,利用Yaklang可以重新编写 他们的“高质量替代”。对于一些生态完整且认可度较高的产品,Y…

C# CodeFormer 图像修复

效果 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Imaging; using System.Windows.Forms;namespace 图像修复 {p…

高校教务系统登录页面JS分析——南京邮电大学

高校教务系统密码加密逻辑及JS逆向 本文将介绍南京邮电大学教务系统的密码加密逻辑以及使用JavaScript进行逆向分析的过程。通过本文,你将了解到密码加密的基本概念、常用加密算法以及如何通过逆向分析来破解密码。 本文仅供交流学习,勿用于非法用途。 一…

C++标准模板(STL)- 类型支持 (数值极限,min_exponent10,max_exponent,max_exponent10)

数值极限 std::numeric_limits 定义于头文件 <limits> 定义于头文件 <limits> template< class T > class numeric_limits; numeric_limits 类模板提供查询各种算术类型属性的标准化方式&#xff08;例如 int 类型的最大可能值是 std::numeric_limits&l…

多个Python包懒得import,那就一包搞定!

使用Python时&#xff0c;有的代码需要依赖多个框架或库者来完成&#xff0c;代码开头需要import多次&#xff0c;比如&#xff0c; import pandas as pd from pyspark import SparkContext from openpyxl import load_workbook import matplotlib.pyplot as plt import seabo…

Java Day2(Java基础语法)

Java基础 Java基础语法1. 注释、关键字、标识符1.1 Java中的注释1.2 关键字1.3 标识符 2. 数据类型&#xff08;1&#xff09;基本类型&#xff08;primitive type&#xff09;a.字节b.进制c. 浮点数拓展d. 字符拓展 &#xff08;2&#xff09; 引用类型(Reference type ) 3. 类…

【软件测试】总结

文章目录 一. 测试用例1. 常见设计测试用例(1)非软件题型(2)软件题型(3)代码型题(4)关于个人项目设计测试用例 2. 万能公式和具体的方法如何理解(1)万能公式(2)Fiddler实现弱网模式(3)针对公交卡设计测试用例 3. 进阶设计测试用例 二. 自动化1. 什么是自动化以及为什么要做自动…

杀死僵尸进程ZooKeeperMain

关闭Hadoop后jps发现还有个进程ZooKeeperMain没有关闭&#xff0c;使用kill -9 <>也没有用&#xff0c;这种就是僵尸进程&#xff0c;需要用父进程ID来杀死 解决方法 话不多说&#xff0c;直接上解决方案&#xff0c; 1. 第一步 清楚需要关闭的进程ID&#xff0c;我…

CentOS-7下安装及配置vsftpd详细步骤(可匿名访问)

第一步安装vsftpd&#xff1a; yum -y install vsftpd 第二步修改ftp主目录所属用户为用户ftp&#xff1a; chown ftp /var/ftp/pub 第三步备份及配置ftp&#xff1a; cp /etc/vsftpd/vsftpd.conf ~/vsftpd.conf.bakvim /etc/vsftpd/vsftpd.conf 配置如下图&#xff1a;…