# Template project using torch geometric pool

Contains scripts to perform:
- Graph-level tasks (graph classification, regression)
- Node clustering
- Node classification with an autoencoder architecture

## Repository structure

The repository is structured as follows:

```
.
├── config/
│   ├── architecture/       # hyperparams of the torch model
│   ├── logger/             # config for neptune etc...
│   ├── lr_scheduler/
│   ├── optimizer/          # specifies the oprimizer (Adam, etc..), learning rate, etc...
│   ├── pooler/             # hyperparameters of the pooling operators
│   ├── profiler/           # code profiler to measure exec time 
├── data/                   # dataset files
├── logs/
├── source/
│   ├── data/               # data loaders
│   ├── models/             # pytorch models
│   ├── pl_modules/         # lightning modules
│   └── utils/ 
├── run_classification.py
├── run_clustering.py
└── run_node_classification.py

```

## Hydra usage examples

Perform a multirun:
```
python run_clustering.py optimizer.hparams.lr=0.1,0.005,0.001 -m 
```

Use a config different from the default one:
```
python run_clustering.py --config-name=sweep -m
```

Do **not** log on Neptune:
```
python run_clustering.py logger=none
```

Use another pooler and dataset
```
python run_clustering.py pooler=dmon dataset=ring
```