统计:多变量时间序列分析 — VMA、VAR、VARMA

news2025/1/12 10:52:31

统计:多变量时间序列分析 — VMA、VAR、VARMA

一、说明

        多变量时间序列是一个在大学课堂上经常被忽视的话题。然而,真实世界的数据通常具有多个维度,我们需要多变量时间序列分析技术。在这篇博客中,我们将通过可视化和 Python 实现 [1] 了解多变量时间序列概念。我假设读者已经知道单变量时间序列分析。如果没有,你可以参考我之前的博客[2]。

目录

  1. 什么是多变量时间序列?
  2. 矢量移动平均过程 (VMA)
  3. 向量自回归过程 (VAR)
  4. 向量自回归移动平均过程 (VARMA)
  5. 应用:美国月度零售销售收入

二. 什么是多元时间序列?

        顾名思义,多元时间序列是与时间相关的多维数据。我们可以在数学公式中定义多变量时间序列数据,如下所示:

多变量时间序列表示法

其中 Zi,t 是时间 t 的第 i 个分量变量,请注意它是每个 i 和 t 的随机变量。Zt 具有 (m, t) 维数。当我们分析多变量时间序列时,我们不能应用标准的统计理论。这是什么意思?请记住多元线性回归。

多元线性回归公式

在计算多元线性回归的可能性 (1) 时,我们假设样本的每个观测值 (=) 都独立于其他观测值。因此,我们可以很容易地通过单个观测值的概率密度的乘积来计算可能性。通常,我们假设观测值遵循正态分布,参数如下 (2)。

多元线性回归的高斯分布及其最大似然估计

然而,在多变量时间序列中,Zt 依赖于 i 和 t。因此,我们不能将相同的假设应用于多元线性回归。要分析多变量时间序列,我们需要了解一些基本概念。让我们深入了解一下。

平稳性

在单变量时间序列中,当时间序列随时间变化具有相同的均值和方差,并且协方差取决于时间滞后时,它具有较弱的平稳性。同样,如果每个分量序列都是弱平稳的,并且其均值和方差是时间不变的,则 m 维多元时间序列也具有平稳性。下图说明了这种情况,以便直观理解。

多元时间序列的平稳性图示

协方差和相关矩阵

现在,让我们考虑一下关于平稳多元时间序列过程 Zt 的统计量。m 维多元时间序列过程的平均值可以写为:

m 维多元时间序列的期望值

平均向量具有 (m, 1) 维。另一方面,滞后 k 协方差矩阵将如下所示:

m 维多元时间序列的协方差矩阵

这是证据:

多元时间序列的协方差矩阵的证明

当 k = 0 时,矩阵 Γ(0) 可以很容易地看作是其他变量之间的方差-协方差矩阵。当 k > 0 时,矩阵 Γ(k) 是单变量时间序列的自协方差的展开。我们不仅计算同一变量之间的自协方差,还计算一个变量与其他变量之间的自协方差。

对于相关矩阵,我们只需使用方差矩阵对协方差矩阵进行归一化。

多元时间序列的相关矩阵

其中 D 是对角线矩阵,每个元素是第 i 个分量级数方差。因此,ρ(k) 的第 i 个对角线元素是第 i 个分量序列 Zi,t 的自相关函数,而 ρ(k) 的第 (i, j)个非对角线元素是分量系列 Zi,t 和 Zj,t 之间的互相关函数。

矢量白噪声处理

如果 m 维向量过程 at 具有以下参数,则称为向量白噪声过程。

矢量白噪声处理 (VWN)

其中 Σ 是 (m x m) 对称协方差矩阵。它是白噪声在单变量时间序列中的扩展。白噪声过程的分量在不同时间是不相关的,就像单变量白噪声过程一样。因此,一个向量与其时间滞后向量之间的协方差变为零。请注意,它可能在白噪声过程的各个分量之间同时相关。通常,我们假设高斯白噪声,这意味着 at 遵循多元高斯分布。我们可以将高斯白噪声称为 VWN(0, Σ)。

现在,我们理解了多元时间序列的基本概念。在下一节中,我们将探讨具有代表性的向量时间序列过程,例如 VMA、VAR 和 VARMA。

三、矢量移动平均过程 (VMA)

        矢量移动平均 (VMA) 过程是移动平均 (MA) 过程的多维变量版本。让我们快速回顾一下 MA 过程。移动平均线 (MA) 过程由当前冲击和先前冲击的总和 Ut 组成。MA(q)过程可以写在下面的公式中。

        MA(q) 过程

        在许多情况下,Ut被认为是白噪声。直观地说,MA(q) 过程具有由前一个 q 步冲击组成的时间序列 {Yt}。请注意,MA(q) 过程是弱平稳的,这意味着均值和方差是恒定的,协方差取决于时间滞后。当我们使用后移运算符 B 时,我们可以按如下方式重写公式:

        MA(q) 进程由后移算子编写

        如您所见,我们可以以有组织的方式重写它。许多教科书都使用这种表达方式。MA(q) 进程具有以下属性。

MA(q) 工艺特性

回到 VMA 的话题,它只是 MA 过程的向量形式(=多变量)版本!为了直观地理解 VMA 过程,我们来看一下 m 维 VMA(1) 示例。

VMA(1) 流程

其中 Zt、μ 和 at 具有 (m, 1) 维,Θ 具有 (m, m) 维。请注意,Θ₀ 是一个单位矩阵。at 是 m 维高斯白噪声过程 VWN(0, Σ) 的序列。VMA(1) 进程具有以下属性。

VMA(1) 进程

VMA(1) 过程的均值始终为 μ,因为它由高斯白噪声的和组成,其平均值为 0。另一方面,协方差矩阵似乎有点棘手。让我们通过详细的推导来弄清楚。首先,Γ(0)等价于方差,可以推导如下:

VMA(1) 过程的方差矩阵

可以使用相同的过程来计算以下内容。

VMA(1) 过程的滞后 1 协方差矩阵

为方便起见,我们在Γ(1)中将负号添加到Θ中。

VMA(1) 过程的滞后 k 协方差矩阵

如您所见,均值和自协方差几乎是相似的,但区别在于 VMA 具有 MA 过程参数的矩阵形式。到目前为止,如此模棱两可。让我们用可视化来检查一下具体的例子。我们假设我们满足以下条件。

VMA(1) 进程示例

为简单起见,我们将均值向量设置为零。我们尝试了四个示例系数情况(B1 ~ B4)。下图显示了每个系数情况下 100 个样本的结果。

每个系数矩阵的 VMA(1) 过程

在 B1 系数情况下,它们是独立的 MA(1) 过程。在 B2 和 B3 系数情况下,一个序列是独立的 MA(1) 过程,但另一个序列与独立的 MA(1) 过程之一相关。在 B4 系数情况下,这两个序列彼此相关。同样,VMA 过程只是 MA 过程的多变量版本,但由于变量更多,我们必须考虑组件之间的相关性。

现在,让我们将主题扩展到 VMA(q) 过程。m 维 VMA(q) 过程由下式给出:

VMA(q)流程的制定

at 是 m 维高斯白噪声过程 VWN(0, Σ) 的序列。VMA(q) 进程具有以下属性。

VMA(q) 进程的属性

VMA(q) 过程均值始终为 μ,因为 VMA(q) 由均值为 0 的 VWN 过程组成。另一方面,我们可以按如下方式计算 VMA(q) 过程的协方差矩阵函数。

VMA(q) 过程的协方差矩阵

因此,VMA(q) 过程在任何时候都具有平稳性,并且协方差矩阵将在滞后 q 之后被切断。与 MA 过程类似,我们可以利用相关矩阵或 AIC 来确定 q 的顺序。AIC 在定义订单方面更方便,但请注意,AIC 需要计算订单的所有模式,因此需要大量的计算。

在 VMA 部分的最后一部分,有一个重要的概念称为可逆性。如果我们可以将 VMA(q) 过程编写为自回归表示,则它是可逆的,如下所示:

VMA(q) 过程的可逆性

请注意,Θ+(B) 是一个伴随矩阵。我们可以推导出等式(4)如下:

MA 过程的 AR 表示

因此,如果随机过程 (Zt) 是可逆的,则它具有无限自回归表示 (AR(∞))。如果行列式方程的所有根 |Θq(B)|= 0 对单位圆的外侧感到满意,则级数是可逆的。

四、向量自回归过程(VAR)

        向量自回归 (VAR) 过程是自回归 (AR) 过程的多维变量版本,类似于 VMA 过程。让我们快速回顾一下 AR 过程。自回归 (AR) 过程使用前一步的值来预测未来值。AR(p)过程可以写在下面的公式中。

        AR(p)过程

        假设Ut是白噪声。第二个方程使用后移算子来表示 AR(p) 过程。如果行列式方程的所有根的模量为 |Φ(B)|= 0 表示对单位圆的外侧感到满意。

回到VAR的话题,它又只是AR过程的向量形式(=多变量)版本!为了直观地理解 VAR 过程,让我们考虑 m 维 VAR(1) 示例。

        VAR(1)工艺制定

        其中 Zt 和 at 具有 (m, 1) 维数,Φ 具有 (m, m) 维数。at 是 m 维高斯白噪声过程 VWN(0, Σ) 的序列。第二个方程使用后移运算符来引用 VAR(1) 方程。显然,该模型是可逆的,因为它是 VAR 模型。如果行列式方程的所有根 |I — 𝚽₁B|= 0 位于单位圆外,VAR(1) 过程是静止的。此外,我们还可以按如下方式转换方程式:

VAR(1) 过程的稳态公式

现在,让我们用可视化来检查具体的例子。我们假设我们满足以下条件。

每个系数矩阵的 VAR(1) 过程

每个系数矩阵的 VAR(1) 过程

在 B1 系数情况下,它们是独立的 AR(1) 过程。同时,在其他系数情况下,一个序列跟随另一个序列。显然,最后一种情况不是静止的。为确保时间序列正确平稳,您需要计算公式 (6) 的特征值。结果如下所示。

<span style="color:rgba(0, 0, 0, 0.8)"><span style="background-color:#ffffff"><span style="background-color:#f9f9f9"><span style="color:#242424"><span style="color:#007400"># sample coefficients of VAR(1) process</span>
B1 = np.array([[<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.0</span>], [<span style="color:#1c00cf">0.0</span>, <span style="color:#1c00cf">0.5</span>]])
B2 = np.array([[<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.5</span>], [<span style="color:#1c00cf">0.0</span>, <span style="color:#1c00cf">0.5</span>]])
B3 = np.array([[<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.0</span>], [<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.5</span>]])
B4 = np.array([[<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.5</span>], [<span style="color:#1c00cf">0.5</span>, <span style="color:#1c00cf">0.5</span>]])

<span style="color:#007400"># calculate the eigenvalue</span>
<span style="color:#aa0d91">for</span> i, B <span style="color:#aa0d91">in</span> <span style="color:#5c2699">enumerate</span>([B1, B2, B3, B4]):
    X = np.eye(<span style="color:#1c00cf">2</span>) - B
    w, v = np.linalg.eig(X)
    
    <span style="color:#5c2699">print</span>(w)</span></span></span></span>

每个系数矩阵的特征值

现在,我们可以验证 B1、B2 和 B3 是静止的,但 B4 是非静止的。您还可以使用增强的 Dicky Fuller 检验(如单变量时间序列)检查每个时间序列是否是平稳的。但是,请注意,仅仅检查 VAR 过程的平稳性是不够的。

同样,VAR 过程只是 AR 过程(同样是 VMA 过程)的多变量版本,但由于变量更多,我们必须考虑组件之间的相关性。

现在,让我们将话题扩展到 VAR(p) 过程。m 维 VAR(p) 过程由下式给出:

VAR(p)工艺制定

其中 Zt 和 at 具有 (m, 1) 维度,Φ 具有 (m, m) 维度。at 是 m 维高斯白噪声过程 VWN0, Σ) 的序列。由于AR(p)过程是可逆的,并且如果|Φp(B)|= 0 位于单位圆外,过程是静止的。它与 AR(p) 过程相同,但 VAR(p) 是矢量化版本。

当 AR(p) 过程是平稳的时,它具有以下均值和协方差。

AR(p)过程的特性

首先,我们可以按如下方式推导出平均值:

AR(p) 过程均值的推导

推导协方差很棘手。第一步,我们需要推导出 θ 值。

偏倚项的推导

我们可以推导出第二个方程,因为μ总是恒定的。接下来,我们需要转换 VAR(p) 方程。

你不是已经看过类似于最后一个方程式的公式了吗?我们已经在 VMA 部分看到了这一点。如果 VAR(p) 过程是静止的,则可以将其编写为 VMA 表示。

VAR 过程的 VMA 表示

然后,协方差矩阵的计算公式为:

VAR(p) 过程的协方差矩阵

在公式中,它由广义 Yule-Walker 矩阵方程推导而来。虽然我跳过了这篇博客中的解释,但你可以参考这个讲座pdf [3]。综上所述,如果VAR或VMA满足特定条件,它们可以相互转换。

与 AR 过程类似,我们可以利用偏相关矩阵来找到顺序。同样,AIC也可以使用,并且更方便。请注意,AIC需要计算订单的所有模式,因此需要大量的计算。因此,如果有很多变量并且似乎有很多滞后,那么使用相关矩阵仍然是一个很好的方法。

到目前为止,我们已经了解了 VMA 和 VAR 流程。在单变量时间序列中,有 ARMA 过程,它与 AR 和 MA 过程相结合。是的,我们也有用于多变量时间序列的 VARMA。在最后的理论部分,我们将学习 VARMA 过程。

五、向量自回归移动平均过程 (VARMA)

        VARMA 过程是 VAR 和 VMA 过程的组合。m 维向量自回归移动平均 (VARMA) 过程有阶数 p 和 q,分别对应 VAR 和 VMA 过程,可以描述为:

        VARMA(p,q)工艺配方

        我们称之为 VARMA(p, q)。我们可以将这个方程式重新表述为:

        同样,其中 Zt 和 at 具有 (m, 1) 维,Φ 和 Θ 具有 (m, m) 维。at 是 m 维高斯白噪声过程 VWN0, Σ) 的序列。

        由于 VMA 过程是平稳的,因此平稳性取决于 VAR 项。因此,当 |Φp(B)|= 0 位于单位圆外,VARMA 过程是静止的。同时,可逆性取决于 VMA 项。如果行列式多项式的所有根 |Θq(B)|= 0 位于单位圆外,VARMA 过程是可逆的。

        让我们回顾一下 VMA、VAR 和 VARMA 过程。它们具有类似于单变量时间序列的想法,但它们在多变量时间序列中具有多维数据。因此,我们不仅需要考虑当前时间步长与上一个时间步长之间的相关性,还需要考虑变量之间的相关性。多变量时间序列的理论部分到此结束。现在,让我们使用具体的例子来实现它们!

六、应用:美国月度零售销售收入

        在最后一节中,我们将在 Python 中实现多变量时间序列。对于第一个示例,我们将使用 [1] 中引用的美国月度零售销售收入。它包含2009年6月至2016年11月的AUT(汽车)、BUM(建材)、GEM(日用百货)、COM(消费品)和HOA(家用电器)五个行业,其中n=90。每个时间序列数据如下所示:

        每个时间序列的图形

        显然,它们是非静止的。因此,让我们试着对它们进行差分。

        每个时间序列的图表取差异

        现在,情况好多了。似乎存在季节性,这是一种定期的数据集变化,但为了简单起见,我将在此博客中忽略它。此外,该系列不是完全静止的,因此我将使用 VAR 和 VARMA 模型。在 Python 中,你可以使用 statsmodels 轻松实现 VAR 和 VARMA 建模(如果你想构建 VMA,也可以使用 statsmodels)。

VAR建模

        对于 VAR 建模,我们可以选择要计算的最大阶数,模型会根据给定的标准(例如 AIC)自动选择最佳模型。在以下示例中,我选择 5 作为最大延迟。

var = sm.tsa.VAR(diff_df)
result = var.fit(maxlags=5, ic='aic')
result.summary()

        VAR 估计结果的一部分

        残差的相关矩阵

在这种情况下,最好的模型是五滞后的模型。结果图如下图。相关矩阵显示变量(如 COM 和 GRO)之间的相关性。因此,它仍然不是静止的。残差自相关函数的结果图如下图。

残差的自相关图

正如你所看到的,存在一些相关性。因此,通过调整参数来改进模型是有改进空间的。

VARMA 建模

对于 VARMA 建模,没有内置函数来为我们选择最佳顺序。因此,我们需要迭代订单的组合。

# modeling
results = pd.DataFrame(columns=['p', 'q', 'AIC'])

for p in range(1, 5):
    for q in range(1, 5):
        model = sm.tsa.VARMAX(diff_df, order=(p, q))
        result = model.fit(maxiter=1000, disp=False)
        
        results = results.append({'p': p, 'q': q, 'AIC': result.aic})
        
res_df = pd.DataFrame(results, columns=['p', 'q', 'AIC'])
res_df.sort_values(by=['AIC']).head()

这需要几分钟才能完成。请注意,VARMA 计算通常不稳定,因此 VAR 模型在实践中更好。这是结果。

VARMA 模型的结果

如您所见,VARMA(4, 1) 是本例中的最佳模型,它与 VAR 模型的顺序相同。根据 VAR 和 VARMA 结果,阶数 q 越小越好。如果我们想创建一个更拟合的模型,我们需要考虑季节性分量。Meta 的 Prophet 库似乎可以方便地构建模型,也是一个不错的选择。让我们试一次。

我使用的代码在这里:

from copy import deepcopy

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from statsmodels.tsa.arima_process import ArmaProcess
from statsmodels.tsa.stattools import acovf, acf
import statsmodels.api as sm

VMA(1) process

# VMA(1) process simulated data

sample_num = 100

mean = np.array([0, 0])
cov = np.array([[1, 0], [0, 1]])

error_vec = np.random.multivariate_normal(mean, cov, sample_num).T
print(error_vec.shape)

# sample coefficients of VMA(1) process
B1 = np.array([[0.5, 0.0], [0.0, 0.5]])
B2 = np.array([[0.5, 0.5], [0.0, 0.5]])
B3 = np.array([[0.5, 0.0], [0.5, 0.5]])
B4 = np.array([[0.5, 0.5], [0.5, 0.5]])
def generate_VMA(error_vec: np.array, B: np.array) -> np.array:
    """
    Generate the VMA process
    """
    res = np.zeros((sample_num, 2))
    
    for j in range(1, sample_num):
        e_current = error_vec[:, j].reshape(2, 1)
        e_previous = error_vec[:, j-1].reshape(2, 1)
        res[j] = calculate_VMA(e_current, e_previous, B).T
    
    return res

def calculate_VMA(e_current: np.array, e_previous: np.array, B: np.array) -> np.array:
    """
    Calculate VMA(1) process value
    args:
        e_current [np.array] : the error term at the current step
        e_previous [np.array] : the error term at the previous step
        B [np.array] : the coefficient matrix of the VMA(1) process 
    return:
        y_current [np.array] : the calculation result of the VMA(1) process
    """
    
    y_current = e_current + np.dot(B, e_previous).reshape(2, 1)
    
    return y_current
fig, ax = plt.subplots(2, 2, figsize=(10, 10))

for i, B in enumerate([B1, B2, B3, B4]):
    x = i // 2
    y = i % 2
    
    res = generate_VMA(error_vec, B)
        
    ax[x, y].plot(res, label=['series 1', 'series 2'])
    ax[x, y].set_title(f'example B{str(i+1)}')
    ax[x, y].legend()
    
plt.legend()
plt.show()

VAR(1)

# VAR(1) process simulated data

sample_num = 100

mean = np.array([0, 0])
cov = np.array([[1, 0], [0, 1]])

error_vec = np.random.multivariate_normal(mean, cov, sample_num).T
print(error_vec.shape)

# sample coefficients of VAR(1) process
B1 = np.array([[0.5, 0.0], [0.0, 0.5]])
B2 = np.array([[0.5, 0.5], [0.0, 0.5]])
B3 = np.array([[0.5, 0.0], [0.5, 0.5]])
B4 = np.array([[0.5, 0.5], [0.5, 0.5]])
fig, ax = plt.subplots(2, 2, figsize=(10, 10))

for i, B in enumerate([B1, B2, B3, B4]):
    x = i // 2
    y = i % 2
    
    res = np.zeros((sample_num, 2))
    previous_z = np.array([0, 0]).reshape(2, 1)
    
    for j in range(sample_num):
        a_t = error_vec[:, j].reshape(2, 1)
        res[j] = (np.dot(B, previous_z) + a_t).T
        previous_z = res[j].reshape(2, 1)
        
    ax[x, y].plot(res, label=['series 1', 'series 2'])
    ax[x, y].set_title(f'example B{str(i+1)}')
    ax[x, y].legend()
    
plt.legend()
plt.show()

# sample coefficients of VAR(1) process
B1 = np.array([[0.5, 0.0], [0.0, 0.5]])
B2 = np.array([[0.5, 0.5], [0.0, 0.5]])
B3 = np.array([[0.5, 0.0], [0.5, 0.5]])
B4 = np.array([[0.5, 0.5], [0.5, 0.5]])

B_names = ["B1", "B2", "B3", "B4"]

# calculate the eigenvalue
for i, B in enumerate([B1, B2, B3, B4]):
    X = np.eye(2) - B
    w, v = np.linalg.eig(X)
    
    
    print(B_names[i], w)

B1 [0.5 0.5]

B2 [0.5 0.5]

B3 [0.5 0.5]

B4 [1.00000000e+00 1.11022302e-16]

# sample coefficients of VAR(1) process
B1 = np.array([[1.9, 1.3], [0.1, 0.8]])
B2 = np.array([[0.1, 0.0], [0.0, 0.1]])

# calculate the eigenvalue
for i, B in enumerate([B1, B2]):
    X = np.eye(2) - B
    w, v = np.linalg.eig(X)
    
    print(w)
[-1.00764732  0.30764732]
[0.9 0.9]

Application

In [94]:

df = pd.read_csv('US_monthly_retail_dataset.csv')
df.head()

PeriodAUTBUMGEMGROCOM0June 0948078263504708942146198221July 0951093240034709743838207042August 0955677215224882642994216093September 0942299213044420241537200504October 094526821263485094302021425

PeriodAUTBUMGEMGROCOM
June 094807826350470894214619822
July 095109324003470974383820704
August 095567721522488264299421609
September 094229921304442024153720050
October 094526821263485094302021425
November 094144819915534894250822439
December 094693619182699704539528782
January 104214315349438544298617570
February 104343415468447564006118443
March 105648221692486434343321649
April 105298726682477514223621126
May 105417826231504764460421913
June 105304925446482904287720688
July 105585423100486204455821650
August 108812021698493144343121904
September 105188621261456784264220841
October 105146321882490374353521568
November 104939321458555874372324094
December 105523120277717704665630297
January 114969216006443234428017698
February 115359016003458084122919364
March 116358321964496774506922481
April 115819924377504824558622302
May 115751827709514374631922251
June 115772227009509074588321925
July 115753823530806614717022490
August 115934123733512674644922951
September 115623122501482384487622379
October 115557423077808774572522324
November 115418622371571984604525196
December 116112821201739074884032555
January 125298917981456424546018740
Febuary 126034518502496354417221403
March 126879924156531144740624511
April 126176125987806014575322406
May 126706329374530914841823965
June 126333625772522794721523332
July 126336423921507334747222968
August 126842324170536794804624691
September 126083122327493264604822654
October 126129524659513984697822970
November 125977223512590134731426318
December 126480021172738024936332705
January 135991219323466164708219688
February 136307618702485034383720780
March 137152923216546504886924887
April 136882028906499554531622885
May 137295232849547744954924860
June 136950927891531794776523471
Ju1y 137305827611519584878324090
August 137554426242552274928825797
September 136430824424499104649922819
October 136707026255529234828324366
November 136489423974603754890427057
December 136834822399737985037432857
January 146066419900473194914219624
February 146439818989488864509120796
March 147768324343539674899724533
April 147460030447527894869024153
May 147911333758569005174225878
June 147322130409538724943423740
Ju1y 147768529003536465136224818
August 147996626798570505130926257
September 147129426574806634886123771
October 147232827748546255105725243
November 146845025248618435104228293
December 147604124498753135301134750
January 156815821161494365153620906
February 156855919923491004708821655
March 158223426526546865116725617
April 157907031512524245009124765
May 158241033282574415320127034
June 157926531709541355095025077
July 158284130676548295311626170
August 158387227916566745212026847
September 157750627377515885024424919
October 157713428546555445198726163
November 157250526889613975135528156
December 158086827044763915414635386
January 166898422100490505216720809
February 167665223290806614919322750
March 168461130027553035274126205
April 168144632496529605095824867
May 168242834787557225350226097
June 168143934371544815274525549
July 168408530347547105375626045
August 168822430257548595276926693
September 168102729210806705162125469
October 167899429010542215276925686
November 167738929095605205279328524

统计:多变量时间序列分析 — VMA、VAR、VARMA |由 Yuki Shizuya |直觉 |2024年8月 |中等 (medium.com)

本博客到此结束。感谢您抽出宝贵时间阅读我的博客!

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

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

相关文章

【GLM-4开发实战】Function Call进阶实战:外部函数调用回顾

系列篇章&#x1f4a5; No.文章1【GLM-4开发实战】Function Call进阶实战&#xff1a;外部函数调用回顾2【GLM-4开发实战】Function Call进阶实战&#xff1a;常见挑战之意图识别处理3【GLM-4开发实战】Function Call进阶实战&#xff1a;常见挑战之海量函数处理4【GLM-4开发实…

【STM32】GPIO和AFIO标准库使用框架

本篇博客重点在于标准库函数的理解与使用&#xff0c;搭建一个框架便于快速开发 目录 GPIO简介 GPIO时钟使能 GPIO初始化 工作模式 选择引脚 输出速度 函数应用 GPIO初始化框架 8个电平读写函数 写端口电平 读端口电平 GPIO框架汇总 AFIO简介 AFIO时钟使能 函数应…

【Material-UI】深入理解useAutocomplete Hook:自定义与高级用法

文章目录 一、什么是useAutocomplete&#xff1f;导入useAutocomplete 二、基本用法代码解析 三、高级定制1. 自定义选项渲染2. 分组和排序3. 自定义输入框行为4. 与其他组件集成 四、注意事项1. 类型安全2. 性能优化 五、总结 Material-UI提供了强大的Autocomplete组件&#x…

Stable Diffusion绘画 | 图生图-基础使用介绍—重绘幅度与缩放模式

重绘幅度 重绘幅度越大&#xff0c;出图与原图差异越大。 重绘幅度0.7 重绘幅度0.3 缩放模式 目前有以下四种缩放模式&#xff1a; 原图的宽高是1080x1440&#xff0c;当修改宽高&#xff0c;与原图不一致时&#xff0c;可选择其中一种缩放模式来处理图片。 仅调整大小 缩放…

C++入门基础(上篇)

C入门基础&#xff08;上篇&#xff09; hello everybody!经历了C语言和初阶数据结构的头脑风暴&#xff0c;相信大家对于编程的学习更加开心&#xff0c;所以说接下来我们将迎来C的学习与探索&#xff0c;话不多说让我们开始吧 namespace的价值 在C/C中&#xff0c;变量、函…

计算机毕业设计选题推荐-自习室座位预约系统-Java/Python项目实战

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

GD32 MCU硬件I2C不可靠不如软件I2C?

在一个评论中&#xff0c;看到网友对硬件I2C的讨论&#xff0c;硬件I2C Busy找不到原因、软件I2C稳得一批。 那么为什么会出现I2C BUSY&#xff1f;硬件I2C真的不如软件I2C吗&#xff1f;怎么让硬件I2C也稳得一批&#xff0c;让我们来一探究竟。 首先我们从I2C时序分析下I2C总…

基于pytorch的steam游戏评分的线性回归问题分析

前言 相信已经暑假一个月的大家肯定并不陌生上面这个学习软件()&#xff0c;面对琳琅满目的游戏总是让人不知道挑选什么&#xff0c;这时候一个游戏的评分往往便成为了一个玩家选择下载的原因&#xff0c;那么今天我们就来研究研究&#xff0c;steam上一个游戏的种种数据&…

Celery注册装饰器@app.task和@shared_task

注册装饰器 app.task和shared_task是Celery中用于定义任务的两种不同装饰器, 它们之间存在明显的区别.from celery import Celery app Celery(my_app, brokeramqp://guestlocalhost//) app.task def my_task(): # 任务逻辑 passfrom celery import shared_task shared…

数据结构——双链表详解(超详细)

前言&#xff1a; 小编在之前已经写过单链表的创建了&#xff0c;接下来要开始双链表的讲解了&#xff0c;双链表比单链表要复杂一些&#xff0c;不过确实要比单链表更好进行实现&#xff01;下面紧跟小编的步伐&#xff0c;开启今天的双链表之旅&#xff01; 目录 1.概念和结构…

Pixart LED调变开发笔记

Pixart提供基础的鼠标和键盘代码, 开发者可以基于此快速的建置自己的firmware, application, 以下介绍代码中用来控制LED的API函式. 常亮模式 (Always on) 常亮模式, 调用API "pwm_led_set_always_on" 及 channel 来设置对应LED常亮. 闪烁模式 (Flash mode) 闪烁模…

华为OD机试 - 字符串编码校验(Java 2024 D卷 100分)

华为OD机试 2024D卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;D卷C卷A卷B卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;私信哪吒&#xff0c;备注华为OD&#xff0c;加入华…

Unity3D 物体圆周运动

Unity3D 实现一个 2D 物体沿着圆周进行运动。 物体圆周运动 前段时间在开发一个小游戏时&#xff0c;需要实现火箭沿着一个圆形轨道进行圆周运动。 以前面试的时候也被问到过这类问题&#xff08;如何让一个 2D 物体做圆周运动&#xff09;&#xff0c;所以还是记录一下实现…

ICML 2024 | 矛与盾的较量!北大提出提示无关数据防御保护算法PID

文章链接&#xff1a;https://arxiv.org/pdf/2406.15305 代码地址&#xff1a;https://github.com/PKU-ML/Diffusion-PID-Protection 亮点直击 本文在实证观察中发现&#xff0c;保护阶段和利用阶段之间的提示不匹配可能会削弱当前数据保护算法的有效性。本文深入探讨了利用LDM…

【机器学习第7章——贝叶斯分类器】

机器学习第7章——贝叶斯分类器 7.贝叶斯分类器7.1贝叶斯决策论7.2 朴素贝叶斯分类器条件概率的m估计 7.3 极大似然估计优点基本原理 7.4 贝叶斯网络7.5 半朴素贝叶斯分类器7.6 EM算法7.7 EM算法实现 7.贝叶斯分类器 7.1贝叶斯决策论 一个医疗判断问题 有两个可选的假设&#…

从日常到专业,2024年必备在线翻译神器

现在全球交流越发的简单、频繁&#xff0c;很多时候外语成为了我们汲取新鲜知识的绊脚石。这时候我们就可以借助一些翻译在线的工具来解决这个问题。这次我们一起探索几款我搜集到的翻译工具。 1.福晰在线翻译 链接直通&#xff1a;https://fanyi.pdf365.cn/doc 这个工具支…

本地部署启动PmHub

文章目录 相关配置版本关系拉取代码使用Git clone下载源码 MYSQL配置Nacos配置Windows本地下载也可以Docker部署Nacos持久化配置启动Nacos访问Nacos Redis配置RocketMQ配置新建相应目录rocketmq, 然后在里面新建broker文件夹, 放broker.conf在 rocketmq 新建 data 文件夹&#…

MRAM FRAM在医疗设备场景的应用

便携式超声波扫描仪是一种检测从物体反射的声波并将其转换为实时图像的设备。通常使用配置存储器和图像/报告存储器两种类型的存储器。配置存储器存储来自外部硬件的标识和配置信息&#xff0c;图像/报告存储器存储图像和相应的报告数据。这些存储器即使在突然断电的情况下&…

MySQL介绍和安装与配置

文章目录 MySQL介绍什么是数据库什么是关系型数据库什么是非关系型数据库MySQL概述和历史 MySQL安装和配置在线安装方式MySQL5.7的安裝1.下载yum Repository2.安装yum Repository3.安装mysql5.7的服务3.后续命令 离线安装方式1、卸载已有的MySQL文件2、安装mysql3、后续命令 修…