Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/networks-learning/counterfactual-tpp
Code and real data for "Counterfactual Temporal Point Processes", NeurIPS 2022
https://github.com/networks-learning/counterfactual-tpp
counterfactual explainable-ai explainable-ml gumbel-max point-process structural-causal-model temporal-point-process
Last synced: about 6 hours ago
JSON representation
Code and real data for "Counterfactual Temporal Point Processes", NeurIPS 2022
- Host: GitHub
- URL: https://github.com/networks-learning/counterfactual-tpp
- Owner: Networks-Learning
- License: mit
- Created: 2021-08-02T10:37:35.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-09-26T09:10:07.000Z (about 2 years ago)
- Last Synced: 2024-04-16T02:14:54.253Z (7 months ago)
- Topics: counterfactual, explainable-ai, explainable-ml, gumbel-max, point-process, structural-causal-model, temporal-point-process
- Language: Jupyter Notebook
- Homepage: https://arxiv.org/abs/2111.07603
- Size: 6.84 MB
- Stars: 15
- Watchers: 3
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# counterfactual-tpp
This is a repository containing code and real data for the paper [Counterfactual Temporal Point Processes](https://arxiv.org/abs/2111.07603), published at NeurIPS 2022.
## Pre-requisitesThis code depends on the following packages:
1. [`networkx`](https://networkx.org/)
2. `numpy`
3. `pandas`
4. `matplotlib`
to generate map plots:
5. [`GeoPandas`](https://geopandas.org/)
6. `geoplot`In order to install the project dependencies you can run the following command:
```bash
pip install -r requirements.txt
```
## Code structure- [src/counterfactual_tpp.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/counterfactual_tpp.py) Contains the code to sample rejected events using the superposition property and the algorithm to calculate the counterfactuals.
- [src/gumbel.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/gumbel.py) Contains the utility functions for the Gumbel-Max SCM.
- [src/sampling_utils.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/sampling_utils.py) Contains the code for the Lewis' thinning algorithm (`thinning_T` function) and some other sampling utilities.
- [src/hawkes/hawkes.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/hawkes/hawkes.py) Contains the code for sampling from the hawkes process using the superposition property of tpps. It also includes the algorithm for sampling a counterfactual sequence of events given a sequence of observed events for a Hawkes process.
- [src/hawkes/hawkes_example.ipynb:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/hawkes/hawkes_example.ipynb) Contains an example of running algorithm 3 (in the paper) for both cases where we have (1) both observed and un-observed events, and (2) the case that we have only the observed events.
- [ebola/graph_generation.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/ebola/graph_generation.py) Contains code to build the Ebola network based on the network of connected
districts. This code is adopted from the [disease-control](https://github.com/Networks-Learning/disease-control) project.
- [ebola/dynamics.py:](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/ebola/dynamics.py) Contains code for sampling counterfactual sequence of infections given a sequence of observed infections from the SIR porcess (the ` calculate_counterfactual` function). The rest of the code is adopted from the [disease-control](https://github.com/Networks-Learning/disease-control) project, which simulates continuous-time SIR epidemics with exponentially distributed
inter-event times.The directory [ebola/data/ebola](https://github.com/Networks-Learning/counterfactual-tpp/tree/main/ebola/data/ebola) contains the information about the Ebola network adjanceny matrix and the cleaned ebola outbreak data adopted from the [disease-control](https://github.com/Networks-Learning/disease-control) project.
The directory [ebola/map/geojson](https://github.com/Networks-Learning/counterfactual-tpp/tree/main/ebola/map/geojson) contains the geographical information of the districts studied in the Ebola outbreak dataset. The geojson files are obtained from [Nominatim](https://nominatim.openstreetmap.org/ui/search.html).
The directory [ebola/map/overall_data](https://github.com/Networks-Learning/counterfactual-tpp/tree/main/ebola/map/overall_data) contains data for generating the geographical maps in the paper, and includs the overall number of infection under applying different interventions.
The directories [src/data_hawkes](https://github.com/Networks-Learning/counterfactual-tpp/tree/main/src/data_hawkes) and [src/data_inhomogeneous](https://github.com/Networks-Learning/counterfactual-tpp/tree/main/src/data_inhomogeneous) contain observational data used to generate Synthetic plots in the paper. You can use this data to re-generate paper's plots. Otherwise, you can simply generate new random samples by the code.
## Experiments
### Synthetic
- [Inhomogeneous Poisson Processes](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/inhomogeneous_experiments.ipynb)
- [Hawkes Processes](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/src/hawkes_experiments.ipynb)### Epidemiological
- [Ebola Epidemic Simulation and Counterfactual Calculations](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/ebola/ebola_experiments.ipynb)
- [Generate Geographical Distribution of infections](https://github.com/Networks-Learning/counterfactual-tpp/blob/main/ebola/map/generate_geopands_data.ipynb)## Citation
If you use parts of the code in this repository for your own research, please consider citing:```
@inproceedings{noorbakhsh2022counterfactual,
title={Counterfactual Temporal Point Processes},
author={Noorbakhsh, Kimia and Gomez-Rodriguez, Manuel},
booktitle={Advances in Neural Information Processing Systems},
year={2022}
}
```