Wolfram Language

Matrices aléatoires

Simulez un processus de vecteur autorégressif

Utlisez MatrixNormalDistribution pour simuler le processus autorégressif vectoriel.

In[1]:=
Click for copyable input
sigR = Covariance[ARProcess[{a}, 1][Range[0, 100]]]; sigC = {{s11, s12}, {s12, s22}};
In[2]:=
Click for copyable input
rules = {a -> 1/2, s11 -> 1, s12 -> 1/2, s22 -> 3};
In[3]:=
Click for copyable input
\[ScriptCapitalD] = MatrixNormalDistribution[sigR, sigC] /. rules;

Simulez un échantillon aléatoire à partir de la distribution matricielle.

In[4]:=
Click for copyable input
vals = RandomVariate[\[ScriptCapitalD], 10^4];

Construisez TemporalData à partir des valeurs échantillonnées.

In[5]:=
Click for copyable input
td = TemporalData[vals, {0, Length[sigR] - 1, 1}, ValueDimensions -> 2]
Out[5]=

Estimez le processus vectoriel autorégressif diagonal.

In[6]:=
Click for copyable input
proc = ARProcess[{a IdentityMatrix[2]}, sigC];
In[7]:=
Click for copyable input
sol = FindProcessParameters[td, proc]
Out[7]=

Comparez-le aux valeurs d'origine.

In[8]:=
Click for copyable input
sol[[All, 2]] - rules[[All, 2]]
Out[8]=

Exemples connexes

de en es ja ko pt-br ru zh