Skip to content

Scripts and functions to calculate and investigate Granger causality in neuroscience

Notifications You must be signed in to change notification settings

bewantbe/GC_clean

Repository files navigation

GC_clean

A collection of GNU Octave (also Matlab compatible) scripts and functions that calculate and investigate Granger Causality(GC). We developed these code for the study of neuroscience (See References).

The code in this package is capable to compute conditional GC of one thousand variables within an hour (10 min, if correlations are known) in a usual PC. There are code to compute both time domain and frequency domain GC. Statistical test (i.e. p-value, confidence interval) can also be obtained (so far time domain only).

Note that these code are mainly for research purposes. While the correctness is of our main concern, the robustness for all input cases is not guaranteed, expecially when the input violate basic assumption of GC, see also Function overview.

Function overview

There are various ways to calculate GC, some are fast, some are more robust to ill-condition problem (but slow and maybe consume a lots memory).

The calculation of GC usually can be divided into three steps (time domain calculation):

  1. Compute multivariate autocorrelation (also called correlation function) of input time series.
  2. Use the autocorrelation to solve the vector autoregression problem, and get residual variances.
  3. Use the residual variances obtained above to calculate GC.

Or, perform the calculation in frequency domain:

  1. Estimate the spectral density of input time series.
  2. Perform the (minimum phase) spectral factorization to get the transfer function and residual variances.
  3. Use the residual variance obtained above to calculate GC.

Both time domain and frequency domain method can be used to calculate frequency domain GC.

Here "ill-condition" time series means that some variables in it (possibly with different time shifts) are nearly linearly dependent or correlation almost equals one. e.g. the data after a low/high/band pass filter will be ill-conditioned in general. Resampling the band passed signal to the pass band (so called "critically sampled") can turn it to "good-condition" problem.

Functions:

  • Variable name convention and data structure

    len: length of data (number of time points).
    p : number of variables.
    m : fitting order, also denoted as od.

    X: p × len, matrix, multi-dimensional time series data.
    R: p × p*(m+1), matrix, covariance function in 2d form. i.e. R = [R(0) R(1) ... R(m)]. R(k) = E[X(t)*X(t)'].
    A: p × p*m, matrix, Auto-Regression coefficients in 2d form. i.e. A = [A(1) A(2) ... A(m)]. In LSM eqn

    X(t) + A(1)*X(t-1) + ... + A(m)*X(t-m) = E(t)

    S: p × p × fftlen, array, spectrum of X. Some code might use fftlen × p × p array, read the code for actual format.
    covz: p*(m+1) × p*(m+1), matrix, the big covariance matrix: covz = E[Z(t)*Z(t)'], Z(t) = [X(t); ... ; X(t-m)].
    GC: p × p, matrix, the GC values, GC(i,j) means GC from j to i.

  • Calculate GC in time domain (under GCcal/).

    • Usage suggestion:

      • Use nGrangerTfast.m for general purpose GC calculation.
      • Use pos_nGrangerT_qrm.m for ill-condition data.
      • Use RGrangerTLevinson.m for hundreds or more variables case.
    • nGrangerT.m

      Use Yule-Walker equation for the 2nd step. It's simple and fast (for fewer than hundred variables). Not stable for short data (e.g. <1e4) and ill-condition data.

    • pos_nGrangerT.m, pos_nGrangerT2.m, pos_nGrangerT_qr.m, pos_nGrangerT_qrm.m

      Solve the finite data point linear least square problem in the 2nd step. Essentially solving the normal equation "X'*X*A =X'*Y". The robustness relies on the '/' operator in Octave (or Matlab) and accumulation round-off error in the 1st step.

      pos_nGrangerT.m calculate as the definition. More stable than nGrangerT.m.

      pos_nGrangerT2.m calculate as its definition, but use some trick to do it fast (as fast as nGrangerT.m) and use much less memory. Slightly more Round-off error than pos_nGrangerT.m.

      pos_nGrangerT_qr.m solve the linear least square problem by QR decomposition in "X*A=Y" (performed by the operator "/"). Effectively square rooted the condition number.

      pos_nGrangerT_qrm.m A variation of pos_nGrangerT_qr.m, which also put mean value into least square problem (instead of simply subtract it). This is the most stable (most slow) and accurate method in this package.

    • nGrangerTfast.m

      Almost as stable as pos_nGrangerT2.m, and mathematically equivalent to pos_nGrangerT2.m. It is fast (even faster than nGrangerT.m) for case of tens and hundreds of variables.

    • RGrangerTLevinson.m

      Same method as nGrangerTfast.m, but use Levinson recursion to perform the matrix inversion. Much faster than even nGrangerTfast.m for the case of hundreds and a thousand variables. Use it as GC = RGrangerTLevinson( getcovpd(X, m) );. Stability is worse than nGrangerT.m, but still enough for non-ill-condition problem (e.g. cond<1e6). Note: to overcome the ill-condition problem, one may whiten the time series fist (see WhiteningFilter.m).

    • pairGrangerT.m

      Calculate pairwise GC. Same stability as nGrangerT.m.

  • Calculate frequency domain GC (under GCcal/).

    • nGrangerF.m

      As not stable as nGrangerT.m. And very slow for large variables (not speed optimized, but should be easy to read and understand following John Geweke (1984)).

  • Related functions

    • GCcal/gc_prob_nonzero.m

      Get p-value ("probability" of nonzero) for the corresponding GC. Used for significance test.

    • GCcal/gc_prob_intv.m

      Get confidence interval of GC value.

    • GCcal/chooseOrderAuto.m, GCcal/chooseROrderFull.m

      Get suitable regression order for GC. Based on Akaike information criterion (AIC) or Bayesian information criterion (BIC).

      chooseOrderAuto.m is a fully automatic routine that use Levinson recursion for "good-condition" problem, and use method like pos_nGrangerT2.m for ill-condition problem.

      chooseROrderFull.m can also return autoregression order.

    • GCcal_spectrum/mX2S_wnd.m

      Estimate spectral density with window function applied.

    • GCcal_spectrum/mX2S_nuft.m

      Estimate spectral density for non-uniformly sampled data.

  • IFsimu_release_2.1.1.zip, prj_neuron_gc/raster_tuning

    An Integrate-and-Fire model neuron simulator. See the readme in IFsimu_release_2.1.1.zip/exec/Readme.txt for details. The latest version can be found in https://bitbucket.org/bewantbe/ifsimu or an alternative simulator https://github.com/bewantbe/point-neuron-network-simulator (faster, but currently in experimental state).

Usage example

% GC_clean usage example.

% Addpath and check compilation of mex file.
% You may put it in startup.m
run('~/matcode/GC_clean/startup.m'); 

% Generate X(t) based on linear model (vector AutoRegression)
%   X(t) + A1*X(t-1) + A2*X(t-2) +...+ Am*X(t-m) = noise(t)

% Variance of noise(t)
De = diag([0.3 1.0 0.2]);

% Coefficients (always in concatenated form) A = [A1, A2]
A = [-0.8  0.0 -0.4  0.5 -0.2  0.0;
      0.0 -0.9  0.0  0.0  0.8  0.0;
      0.0 -0.5 -0.5  0.0  0.0  0.2];

len = 1e5;
X = gendata_linear(A, De, len);

% Choose a fitting order for GC.
od_max = 100;
[od_joint, od_vec] = chooseOrderFull(X, 'AICc', od_max);
m = max([od_joint, od_vec]);
% For a fast schematic test, use:
% m = chooseOrderAuto(X, 'AICc')

% The Granger Causality value (in matrix form).
GC = nGrangerTfast(X, m)

% Significance test: Non-zero probably based on 0-hypothesis (GC==0).
p_nonzero = gc_prob_nonzero(GC, m, len)

% The connectivity matrix.
p_value = 0.0001;
net_adjacency = p_nonzero > 1 - p_value

% This should give the same result.
gc_zero_line = chi2inv(1-p_value, m)/len;
net_adjacency2 = GC > gc_zero_line;

% Frequency domain GC.
fftlen = 1024;
wGC = nGrangerF(X, m, fftlen);
w = (0:fftlen-1)/fftlen;

figure(1);
p = size(X, 1);
for ii = 1 : p
  for jj = 1 : p
    if ii == jj continue; end
    subplot(p, p, (ii-1)*p + jj);
    plot(w, squeeze(wGC(ii, jj, :)), 'b', ...
         w, gc_zero_line*ones(size(w)), 'r');
  end
end

Speed

(Machine: i5-2400, 8GB)

len: length of data (number of time points).
p : number of variables.
m : fitting order, also denoted as od.

Speed of the 1st step

Function getcovpd.m, getcovzpd.m.

O(p^2 * m * L)

len=1e5, sec p=100 200 500 1000
od=20 1.339 3.96 17.0 59.7
od=40 2.67 7.71 32.1 118.1

(In many cases, you will need 10 times longer data, which the time above will be 10 times higher)

Speed of the 2nd and 3rd step

Function RGrangerT.m (similarly the 2nd step of pos_nGrangerT2.m).

O(p^4 * m^3)

sec p=100 200 500
od=20 24.2 243.6 6870.3
od=40 120.4 1358.2 oom

Function RGrangerTfast.m.

O(p^3 * m^3)

sec p=100 200 500
od=20 0.721 4.06 52.1
od=40 4.63 27.2 oom

Function RGrangerTLevinson.m.

O( p^3 * m^2 * log(m) )

sec p=100 200 500 1000
od=20 0.434 1.98 19.5 110.5
od=40 1.662 8.35 76.9 433.9

Function pairRGrangerT.m.

(this is pairwise GC)

O( p^2 * m^3 )

sec p=100 200 500 1000
od=20 1.32 5.08 31.9 127.0
od=40 2.49 10.0 62.6 252.9

Note:

  • oom = out of memory

  • Time complexity are theoretical results. Actual time may vary due to e.g. cache effect and multi-threading.

References

  • John Geweke (1982) Measurement of Linear Dependence and Feedback Between Multiple Time Series. Journal of the American Statistical Association, Vol. 77, No. 378, pp. 304-313. doi:10.2307/2287238

  • John Geweke (1984) Measures of Conditional Linear Dependence and Feedback Between Time Series. Journal of the American Statistical Association, Vol. 79, No. 388, pp. 907-915. doi:10.2307/2288723

  • Ding, M., Chen, Y., & Bressler, S. L. (2006). 17 Granger Causality: Basic Theory and Application to Neuroscience. Handbook of time series analysis: recent theoretical developments and applications, 437.

  • Zhou D, Xiao Y, Zhang Y, Xu Z, Cai D (2013) Causal and structural connectivity of pulse-coupled nonlinear networks. Physical Review Letters 111: 054102

  • Zhou D, Xiao Y, Zhang Y, Xu Z, Cai D (2014) Granger Causality Network Reconstruction of Conductance-Based Integrate-and-Fire Neuronal Systems. PLoS ONE 9(2): e87636. doi:10.1371/journal.pone.0087636

  • Zhou D, Zhang Y, Xiao Y, Cai D (2014) Reliability of the Granger causality inference. New J. Phys. 16 043016. doi:10.1088/1367-2630/16/4/043016

  • Zhang, Y., Xiao, Y., Zhou, D., & Cai, D. (2016). Granger causality analysis with nonuniform sampling and its application to pulse-coupled nonlinear dynamics. Physical Review E, 93(4), 042217. doi:10.1103/PhysRevE.93.042217

About

Scripts and functions to calculate and investigate Granger causality in neuroscience

Resources

Stars

Watchers

Forks

Packages

No packages published