Giter Site home page Giter Site logo

vishalbelsare / vltimeseriescausality Goto Github PK

View Code? Open in Web Editor NEW

This project forked from darkeyes/vltimeseriescausality

0.0 0.0 0.0 5.61 MB

A framework to infer causality on a pair of time series of real numbers based on Variable-lag Granger causality and transfer entropy.

License: GNU General Public License v3.0

R 100.00%

vltimeseriescausality's Introduction

VLTimeCausality: Variable-Lag Time Series Causality Inference Framework

minimal R version CRAN Status Badge Download arXiv License

A framework to infer causality on a pair of time series of real numbers based on Variable-lag Granger causality (VL-Granger) and transfer entropy (VL-Transfer Entropy).

Typically, Granger causality and transfer entropy have an assumption of a fixed and constant time delay between the cause and effect. However, for a non-stationary time series, this assumption is not true. For example, considering two time series of velocity of person A and person B where B follows A. At some time, B stops tying his shoes, then running to catch up A. The fixed-lag assumption is not true in this case.

We propose a framework that allows variable-lags between cause and effect in Granger causality and transfer entropy to allow them to deal with variable-lag non-stationary time series.

Installation

You can install our package from CRAN

install.packages("VLTimeCausality")

For the newest version on github, please call the following command in R terminal.

remotes::install_github("DarkEyes/VLTimeSeriesCausality")

This requires a user to install the "remotes" package before installing VLTimeSeriesCausality.

Example: Inferred VL-Granger causality time series

In the first step, we generate time series TS$X and TS$Y where TS$X causes TS$Y with variable-lags.

library(VLTimeCausality)
# Generate simulation data
TS <- VLTimeCausality::SimpleSimulationVLtimeseries()

We can plot time series using the following function.

VLTimeCausality::plotTimeSeries(TS$X,TS$Y)

A sample of generated time series pair that has a causal relation is plotted below:

We use the following function to infer whether X causes Y.

# Run the function
out<-VLTimeCausality::VLGrangerFunc(Y=TS$Y,X=TS$X)

The result of VL-Granger causality is below:

out$BICDiffRatio
[1] 0.8882051

out$XgCsY
[1] TRUE

If out$XgCsY is true, then it means that X VL-Granger-causes Y. The value out$BICDiffRatio is a BIC difference ratio. If out$BICDiffRatio>0, it means that X is a good predictor of Y behaviors. The closer out$BICDiffRatio to 1, the stronger we can claim that X VL-Granger-causes Y.

For the comparison between normal Granger test with our VL-Granger test, we recommend to use the F-test decision criterion the same as typical Granger test criterion.

Below are the results of VL-Granger Causality using F-test.

library(lmtest)
data(ChickEgg)
ChickEgg <- as.data.frame(ChickEgg)

#============ The the egg causes chicken. 
out_test1 <- VLTimeCausality::VLGrangerFunc(X=ChickEgg$egg,Y=ChickEgg$chicken)
out_test1$p.val
[1] 0.004980847
out_test1$XgCsY_ftest
[1] TRUE 

#============ The reverse direction has no causal relation
out_test2 <- VLTimeCausality::VLGrangerFunc(Y=ChickEgg$egg,X=ChickEgg$chicken)
out_test2$p.val
[1] 1
out_test2$XgCsY_ftest
[1] FALSE

Citation

Chainarong Amornbunchornvej, Elena Zheleva, and Tanya Berger-Wolf (2021). Variable-lag Granger Causality and Transfer Entropy for Time Series Analysis. ACM Transactions on Knowledge Discovery from Data (TKDD), 15(4), 1-30. https://doi.org/10.1145/3441452

Contact

vltimeseriescausality's People

Contributors

darkeyes avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.