{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "from analyzer import Analyzer\n",
    "\n",
    "WANDB_ID = \"abcdefgh\" # The id of your weights and biases run. This should be a GCN model for GCExplainer. Otherwise, it should be a HELP or DiffPool model to explain as defined in all other sections (except GCExplainer)\n",
    "SAVE_PATH = \"where/to/save/figure.svg\"\n",
    "\n",
    "# batch_size is an arbitrary large number that should be bigger than the size of the whole dataset\n",
    "analyzer = Analyzer(WANDB_ID, resume_last=False, device=\"cpu\", batch_size=6000)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Synthetic Hierarchical, Mutagenicity and BBBP"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [
    "\n",
    "# For efficiency inference_with_train can be set to false. Using true means that the clustering will be performed on train and test set together. This can be useful e.g. when visualizing decision trees used for concept completeness as it allows to visualize the exact same concepts used in the decision tree.\n",
    "\n",
    "MERGE_CONCEPTS = True  # Merges small bars if they contain similar subgraphs to create a slightly easier to read visualization. Used for Mutagenicity and BBBP in the paper\n",
    "POOL_STEP = 0 # Which pool block to analyze. Can be 0 or 1 for the configurations described in README.md as they have exactly 2 pool blocks\n",
    "\n",
    "analyzer.count_subgraphs(pool_step=POOL_STEP, load_part=1, use_k_hop=False, inference_with_train=True, use_only_test = True, plot_num_subgraphs=False, plot_num_nodes=True, save_path=SAVE_PATH, max_neighborhoods_to_store=10, min_occs_to_store=0, horizontal=True, max_occs_to_merge=1000, min_nodes_to_merge=2, merge_concepts=MERGE_CONCEPTS, num_hops=None, min_nodes_for_legend=1000, plot_example_graphs=True, example_scale=0.7, example_width_scale=0.5)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### REDDIT-BINARY"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [
    "POOL_STEP = 0 # Which pool block to analyze. Can be 0 or 1 for the configurations described in README.md as they have exactly 2 pool blocks\n",
    "\n",
    "analyzer.count_subgraphs(pool_step=POOL_STEP, load_part=0.5, use_k_hop=False, inference_with_train=False, use_only_test = True, plot_num_subgraphs=False, plot_num_nodes=True, save_path=SAVE_PATH, max_neighborhoods_to_store=10, min_occs_to_store=0, horizontal=True, max_occs_to_merge=1000, min_nodes_to_merge=2, merge_concepts=False, num_hops=None, min_nodes_for_legend=1000, plot_example_graphs=True, example_scale=0.7, example_width_scale=1.0)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### GCExplainer"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [
    "NUM_HOPS = None # k for k-hop neighborhood of GCExplainer. Number of GCN layers by default (None)\n",
    "NUM_GCEXPLAINER_CLUSTERS = 10 # Number of clusters/concepts to use for GCExplainer\n",
    "\n",
    "analyzer.count_subgraphs(pool_step=0, load_part=1, use_k_hop=True, inference_with_train=True, use_only_test = True, plot_num_subgraphs=False, plot_num_nodes=True, save_path=SAVE_PATH, max_neighborhoods_to_store=10, min_occs_to_store=0, horizontal=True, max_occs_to_merge=1000, min_nodes_to_merge=2, merge_concepts=False, num_hops=NUM_HOPS, num_gcexplainer_clusters=NUM_GCEXPLAINER_CLUSTERS, min_nodes_for_legend=1000, plot_example_graphs=True, example_scale=0.7, example_width_scale=1.0)"
   ],
   "metadata": {
    "collapsed": false
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
