Skip to content

Latest commit

 

History

History
115 lines (88 loc) · 7.86 KB

README.md

File metadata and controls

115 lines (88 loc) · 7.86 KB

Jacobian Regularizer-based Neural Granger Causality [ICML 2024]

arXiv

Official implementation of the paper "Jacobian Regularizer-based Neural Granger Causality".

Authors: Wanqi Zhou, Shuanghao Bai, Shujian Yu, Qibin Zhao, Badong Chen.


Highlights

main figure

Abstract: With the advancement of neural networks, diverse methods for neural Granger causality have emerged, which demonstrate proficiency in handling complex data, and nonlinear relationships. However, the existing framework of neural Granger causality has several limitations. It requires the construction of separate predictive models for each target variable, and the relationship depends on the sparsity on the weights of the first layer, resulting in challenges in effectively modeling complex relationships between variables as well as unsatisfied estimation accuracy of Granger causality. Moreover, most of them cannot grasp full-time Granger causality. To address these drawbacks, we propose a Jacobian Regularizer-based Neural Granger Causality (JRNGC) approach, a straightforward yet highly effective method for learning multivariate summary Granger causality and full-time Granger causality by constructing a single model for all target variables. Specifically, our method eliminates the sparsity constraints of weights by leveraging an input-output Jacobian matrix regularizer, which can be subsequently represented as the weighted causal matrix in the post-hoc analysis. Extensive experiments show that our proposed approach achieves competitive performance with the state-of-the-art methods for learning summary Granger causality and full-time Granger causality while maintaining lower model complexity and high scalability.

Main Contributions
  • To our best knowledge, this is the first work to harness a single NN model with shared hidden layers for multivariate Granger causality analysis.
  • We propose a novel neural network framework to learn Granger causality by incorporating an input-output Jacobian regularizer in the training objective.
  • Our method can not only obtain the summary Granger causality but also the full-time Granger causality.
  • An efficient Jacobian regularizer algorithm is developed to solve the computational issue that occurred in ${L_1}$ loss on input-output Jacobian matrix.
  • We evaluate our method on commonly used benchmark datasets with extensive experiments. Our method can outperform state-of-the-art baselines and show an excellent ability to discover Granger causality, especially for sparse causality.

Performance on the benchmark CausalTime datasets.

Table. Performance benchmarking of baseline TSCD algorithms on the CausalTime datasets. We highlight the best and the second best in bold and with underlining, respectively.

Methods AQI (AUROC) Traffic (AUROC) Medical (AUROC) AQI (AUPRC) Traffic (AUPRC) Medical (AUPRC)
GC 0.4538 ± 0.0377 0.4191 ± 0.0310 0.5737 ± 0.0338 0.6347 ± 0.0158 0.2789 ± 0.0018 0.4213 ± 0.0281
SVAR 0.6225 ± 0.0406 0.6329 ± 0.0047 0.7130 ± 0.0188 0.7903 ± 0.0175 0.5845 ± 0.0021 0.6774 ± 0.0358
N.NTS 0.5729 ± 0.0229 0.6329 ± 0.0335 0.5019 ± 0.0682 0.7100 ± 0.0228 0.5770 ± 0.0542 0.4567 ± 0.0162
PCMCI 0.5272 ± 0.0744 0.5422 ± 0.0737 0.6991 ± 0.0111 0.6734 ± 0.0372 0.3474 ± 0.0581 0.5082 ± 0.0177
Rhino 0.6700 ± 0.0983 0.6274 ± 0.0185 0.6520 ± 0.0212 0.7593 ± 0.0755 0.3772 ± 0.0093 0.4897 ± 0.0321
CUTS 0.6013 ± 0.0038 0.6238 ± 0.0179 0.3739 ± 0.0297 0.5096 ± 0.0362 0.1525 ± 0.0226 0.1537 ± 0.0039
CUTS+ 0.8928 ± 0.0213 0.6175 ± 0.0752 0.8202 ± 0.0173 0.7983 ± 0.0875 0.6367 ± 0.1197 0.5481 ± 0.1349
NGC 0.7172 ± 0.0076 0.6032 ± 0.0056 0.5744 ± 0.0096 0.7177 ± 0.0069 0.3583 ± 0.0495 0.4637 ± 0.0121
NGM 0.6728 ± 0.0164 0.4660 ± 0.0144 0.5551 ± 0.0154 0.4786 ± 0.0196 0.2826 ± 0.0098 0.4697 ± 0.0166
LCCM 0.8565 ± 0.0653 0.5545 ± 0.0254 0.8013 ± 0.0218 0.9260 ± 0.0246 0.5907 ± 0.0475 0.7554 ± 0.0235
eSRU 0.8229 ± 0.0317 0.5987 ± 0.0192 0.7559 ± 0.0365 0.7223 ± 0.0317 0.4886 ± 0.0338 0.7352 ± 0.0600
SCGL 0.4915 ± 0.0476 0.5927 ± 0.0553 0.5019 ± 0.0224 0.3584 ± 0.0281 0.4544 ± 0.0315 0.4833 ± 0.0185
TCDF 0.4148 ± 0.0207 0.5029 ± 0.0041 0.6329 ± 0.0384 0.6527 ± 0.0087 0.3637 ± 0.0048 0.5544 ± 0.0313
JRNGC-F (ours) 0.9279 ± 0.0011 0.7294± 0.0046 0.7540± 0.0040 0.7828± 0.0020 0.5940± 0.0067 0.7261± 0.0016

Running the demo code

# pip environment
   conda create -n jrngc python=3.8
   conda activate jrngc
# pip according to the requirement.txt
   pip install -r requirement.txt
# run the demo.py
   python demo.py --yaml_dir $yamlpath --data_type $data_type

Remark 1: you can also run the demo.py directly. The details of hyperparameters can be seen in appendix.

Remark 2: if you are interested in DAG regularization on the input-output Jacobian matrix, you can add the following part to our model. Regarding as the trace_expm function, please refer to to code Notears.

def h_func(self,Jacobian_matrix):
    "Constrain 2-norm-squared of the Jacobian matrix along m1 dim to be a DAG"
    h = trace_expm(Jacobian_matrix) - self.d  #DAG-regularizer
    return h
def compute_jacobian_DAG_loss(self,x):
    """
    x: [batch, d, T=lag]
    """
    if 2 == len(x.shape): x.unsqueeze_(0)
    x = x.transpose(1, 2).unfold(1, self.lag, 1)
    x = x.reshape(x.shape[0] * x.shape[1], x.shape[2], x.shape[3])
    jac = self.jacobian_causal_train(x)
    
    variable_jac = torch.mean(jac,dim=2)
    h = self.h_func(variable_jac) #[effect,cause]
    jac_loss = h *self.jacobian_lam
    return jac_loss

## Please add the following code to tgc/model/jrngc.py (please go to line 186)
## If you need the DAG regularizer on the input-output Jacobian matrix.
elif model.struct_loss_choice =="JR_DAG":
        struct_loss = model.compute_jacobian_DAG_loss(x)

Citation

If you think our work is useful, please consider citing:

@inproceedings{zhou2024jacobian,
title={Jacobian Regularizer-based Neural Granger Causality},
author={Zhou, Wanqi and Bai, Shuanghao and Yu, Shujian and Zhao, Qibin and Chen, Badong},
booktitle={International Conference on Machine Learning},
year={2024},
organization={PMLR}
}

Contact

If you have any questions or feedback, please create an issue on this repository or feel free to contact us at Zhouwanqistu@163.com.

Acknowledgments

We would like to thank DREAM3 and DREAM4 organizers for their tireless efforts. Please download the dataset following the webpage and cite them if you use the dataset!