# Fast Mixture of Curvature-Aware Experts for Diverse and Dynamic Geometries
<img src="flowchart_single.png" width="70%">


## Environments

- python=3.9.18
- pytorch=2.0.1
- numpy=1.24.3
- pandas=1.5.3
- scikit-learn==1.3.0
- wandb=0.16.3
- tqdm
- tabulate





## Executing Scripts
#### Graph Properties Preprocessing
Please precompute node-level statistical summaries of graph properties before training.
* Example of the *Wikipedia* dataset:
```{bash}
cd graph_properties/
python compute_properties.py  --dataset_name wikipedia
```

#### Model Training
* Example of training *DyGMoCE* on *Wikipedia* dataset:
```{bash}
python train_link_prediction.py  --dataset_name wikipedia --model_name DyGMoCE  --num_runs 5 --gpu 0 --init_curvs -2 -1 0 1 2
```

#### Model Evaluation
Three (i.e., random, historical, and inductive) negative sampling strategies can be used for model evaluation.
* Example of evaluating *DyGMoCE* with *historical* negative sampling strategy on *Wikipedia* dataset:
```{bash}
python evaluate_link_prediction.py --dataset_name wikipedia --model_name DyGMoCE --num_runs 5 --gpu 0 --negative_sample_strategy historical --init_curvs -2 -1 0 1 2
```

## Useful Files
Please refer to `demo_on_fast_Riemannian_attention.ipynb` for a detailed demonstration of the **effectiveness and efficiency** of the Fast Riemannian Attention module.

