2017-06-01 68 views
2

我想在兩個時間序列運行grangercausalitytests爲什麼我會從grangercausalitytests獲得「LinAlgError:Singular matrix」?

import numpy as np 
import pandas as pd 

from statsmodels.tsa.stattools import grangercausalitytests 

n = 1000 
ls = np.linspace(0, 2*np.pi, n) 

df1 = pd.DataFrame(np.sin(ls)) 
df2 = pd.DataFrame(2*np.sin(1+ls)) 

df = pd.concat([df1, df2], axis=1) 

df.plot() 

grangercausalitytests(df, maxlag=20) 

但是,我得到

Granger Causality 
number of lags (no zero) 1 
ssr based F test:   F=272078066917221398041264652288.0000, p=0.0000 , df_denom=996, df_num=1 
ssr based chi2 test: chi2=272897579166972095424217743360.0000, p=0.0000 , df=1 
likelihood ratio test: chi2=60811.2671, p=0.0000 , df=1 
parameter F test:   F=272078066917220553616334520320.0000, p=0.0000 , df_denom=996, df_num=1 

Granger Causality 
number of lags (no zero) 2 
ssr based F test:   F=7296.6976, p=0.0000 , df_denom=995, df_num=2 
ssr based chi2 test: chi2=14637.3954, p=0.0000 , df=2 
likelihood ratio test: chi2=2746.0362, p=0.0000 , df=2 
parameter F test:   F=13296850090491009488285469769728.0000, p=0.0000 , df_denom=995, df_num=2 
... 
/usr/local/lib/python3.5/dist-packages/numpy/linalg/linalg.py in _raise_linalgerror_singular(err, flag) 
    88 
    89 def _raise_linalgerror_singular(err, flag): 
---> 90  raise LinAlgError("Singular matrix") 
    91 
    92 def _raise_linalgerror_nonposdef(err, flag): 

LinAlgError: Singular matrix 

,我不知道爲什麼是這樣的情況。

回答

4

由於數據中兩個系列之間的完美關聯,問題就出現了。從回溯中,您可以看到,內部使用wald測試來計算滯後時間序列參數的最大似然估計值。爲此,需要估計參數協方差矩陣(其接近零)及其倒數(因爲您也可以在追蹤中的行invcov = np.linalg.inv(cov_p)中看到)。對於某個最大滯後數(> = 5),這個接近零的矩陣現在是奇異的,因此測試會崩潰。如果爲數據添加一點噪音,錯誤消失:

import numpy as np 
import pandas as pd 
import matplotlib.pyplot as plt 
from statsmodels.tsa.stattools import grangercausalitytests 

n = 1000 
ls = np.linspace(0, 2*np.pi, n) 
df1Clean = pd.DataFrame(np.sin(ls)) 
df2Clean = pd.DataFrame(2*np.sin(ls+1)) 
dfClean = pd.concat([df1Clean, df2Clean], axis=1) 
dfDirty = dfClean+0.00001*np.random.rand(n, 2) 

grangercausalitytests(dfClean, maxlag=20, verbose=False) # Raises LinAlgError 
grangercausalitytests(dfDirty, maxlag=20, verbose=False) # Runs fine 
+0

謝謝澄清! – displayname

相關問題