Skip to content

Latest commit

 

History

History
20 lines (14 loc) · 1.56 KB

README.md

File metadata and controls

20 lines (14 loc) · 1.56 KB

PATCHY-SAN

Implementation of Learning Convolutional Neural Networks for Graphs by Mathias Niepert, Mohamed Ahmed, Konstantin Kutzkov, ICML 2014-2023. https://scholar.google.com.sg/scholar?oi=bibs&cluster=9917957179670149192&btnI=1&hl=en

Required Modules:

Python 3 Implementation that uses the networkx library to construct input graphs, and transform them into receptive fields, which are tensors that form the inputs into a Convolutional Neural Network(CNN) for learning of subgraph properties and approximate isomoprhisms, based on the choice of node labelling procedures(e.g Between-ness Centrality). In particular, the algorithm does the following:

  • Select node sequence according to the labelling procedure
  • Assemble local neighbourhoods from subgraphs centered on the nodes selected the node sequence
  • Perform graph normalization on neighbourhoods to form receptive fields
  • Learn subgraph properties using receptive fields as inputs

The Conv1D, Dense, Dropout and softmax layers from keras are used to construct the deep CNN that performs classification of graphs according to their respective subgraph receptive fields. This is represented in the pscn.py file that contains the module using the Patchy-San algorithm with a CNN.

Various well known graph datasets for measuring performance on graph kernels were used in evaluating the PSCN algorithm. https://ls11-www.cs.tu-dortmund.de/staff/morris/graphkerneldatasets