Project for the "Machine Learning Algorithms and Applications" course at TU Wien 2023W.
Advisors: Tamara Drucks, Pascal Welke, TU-Wien.
The aim of this project is to identify whether distance preserving embeddings for graphs can be obtained. To investigate this, a Siamese Network architecture is used, and Graph Neural Networks (GNNs) are used to handle graph data. This approach could be exploited as a self-supervised step to perform on a GNN before using it for some other downstream task.
To obtain a distance between graphs these are represented through their vectors of expectation-complete homomorphism counts, as proposed in Welke et al. (2023) [1] and the associated code that can be found at pwelke/homcount is used to obtain the vectors of homomorphism counts.
The base layer consists of
To train the network, standard contrastive learning ideas are exploited and adapted to try and preserve distance. To be more specific, the network can be trained using either one of two losses:
- Contrastive loss idea (CL): the network takes as input a pair of graphs which are fed through the same layers to obtain graph embeddings. Afterwards, the distance between those is computed, and the network is penalised if this distance is different from the one computed on the vector of homomorphism counts or densities of the two graphs.
- Triplet loss idea (TL): the network takes as input a triple of graphs
$(a, p, n)$ , where$a$ is the anchor,$p$ is a positive example (i.e. should be similar to the anchor) and$n$ is a negative example (i.e. should be different from the anchor). To try and preserve the distance the following adjustement to a standard Triplet Loss is made. Denote as$d_p$ the distance between the anchor and positive graph embeddings and$d_n$ that between the anchor and the negative graph embedding. The network is penalised when the difference$d_p - d_n$ is smaller in the embedding space (in absolute terms) than when computed on the initial vectors of homomorphism counts.
To run the code call main.py
as shown below. Ensure that the file containing the desired homomorphism counts is present in data/homcounts
and is named <dataset>_<nhoms>.homson
:
python main.py --loss <loss> --dataset <dataset> --nhoms <number_of_homomorphisms> --n_conv_layers <num_GCN_layers> --n_lin_layers <num_Linear_layers> --distance <distance> --hom_types <hom_types>
where:
loss
: is one of [contrastive
,triplet
] specifies whether training should be performed using the CL or TL approach.dataset
: dataset to be used. For the experiments onlyMUTAG
andENZYMES
were considered.number_of_homomorphisms
: specifies the number of patterns used to obtain homomorphism counts.num_GCN_layers
: specifies the number of GCN layers to use in the architecture.num_Linear_layers
: specifies the number of Linear layers to use in the architecture.distance
: is one of [L1
,L2
,cosine
] and specifies the distance to use both for the vectors of homomorphism counts and the embeddings.hom_types
: is one of [counts
,counts_density
] and specifies whether vectors of homomorphism counts or homomorphism densities should be used.
Note that additional parameters to control training are also available (learning rate, batch size, ...). Check file
main.py
for further information.
main.py
: contains the code to train-validate the model with the specified options as described above.Utilities.py
: contains utility functions for plotting and preparing dataloaders.models.py
: contains the implementation of the architecture described above.training.py
: contains the functions used for training and validation.exploration_MUTAG.ipynb
,exploration_ENZYMES.ipynb
: contain an exploratory analysis of the distances obtained using homomorphism counts.analyze_patterns
: contains the analysis of the patterns which caused issues when computing homomorphism densities.data
: contains the json format files storing homomorphism counts indata/homomorphism_counts
and patterns files which were analyzed.results
: contains the results for the analysis.results/actual_vs_predicted
: contains the actual-vs-predicted plots.results/train_val_loss
: contains the losses obtained during training on both training and validation split.results/hyperparameter_tuning
: contains the results of the hyper-parameter tuning performed when working with CL approach.results/triplet_jaccard
: contains the average Jaccard similarities obtained when working with the TL approach.
[1] Welke, P., & Thiessen, M., & Jogl, F., & Gärtner, T. (2023). Expectation-complete graph representations with homomorphisms. In International Conference on Machine Learning.
[2] Kipf, T.N., & Welling, M. (2017). Semi-Supervised Classification with Graph Convolutional Networks. In Proceedings of the 5th International Conference on Learning Representations.