{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "134ca6f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "from deeprobust.graph.data import Dataset\n",
    "from deeprobust.graph.defense import GCN\n",
    "from deeprobust.graph.global_attack import PGDAttack\n",
    "from deeprobust.graph.utils import preprocess\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "from torch import optim\n",
    "from torch.nn import functional as F\n",
    "from torch.nn.parameter import Parameter\n",
    "from tqdm import tqdm\n",
    "from scipy import sparse\n",
    "from deeprobust.graph import utils\n",
    "from deeprobust.graph.global_attack import BaseAttack\n",
    "from dataset import load_graph_dataset\n",
    "from gcn_with_edge_removal import gcn_with_edge_removal\n",
    "from sgc_with_edge_removal import sgc_with_edge_removal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "58c4787f",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'data_set' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_17585/615184023.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mgraph\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeat\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtrain_mask\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mval_mask\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_mask\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnumber_classes\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mload_graph_dataset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata_set\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0madj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgraph\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0madjacency_matrix_scipy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mfeatures\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msparse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcsr_matrix\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfeat\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mlabels\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlabels\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mastype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'data_set' is not defined"
     ]
    }
   ],
   "source": [
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset(data_set)\n",
    "\n",
    "adj = graph.adjacency_matrix_scipy()\n",
    "features = sparse.csr_matrix(feat.numpy())\n",
    "labels = labels.numpy().astype(int)\n",
    "idx_train = np.where(train_mask == 1)[0]\n",
    "idx_val = np.where(val_mask == 1)[0]\n",
    "idx_test = np.where(test_mask == 1)[0]\n",
    "idx_unlabeled = np.union1d(idx_val, idx_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26fdf741",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = Dataset(root='/tmp/', name='cora')\n",
    "adj, features, labels = data.adj, data.features, data.labels\n",
    "adj, features, labels = preprocess(adj, features, labels, preprocess_adj=False) # conver to tensor\n",
    "idx_train, idx_val, idx_test = data.idx_train, data.idx_val, data.idx_test\n",
    "# Setup Victim Model\n",
    "victim_model = GCN(nfeat=features.shape[1], nclass=labels.max().item()+1,\n",
    "                    nhid=16, dropout=0.5, weight_decay=5e-4, device='cpu').to('cpu')\n",
    "victim_model.fit(features, adj, labels, idx_train)\n",
    "# Setup Attack Model\n",
    "model = PGDAttack(model=victim_model, nnodes=adj.shape[0], loss_type='CE', device='cpu').to('cpu')\n",
    "model.attack(features, adj, labels, idx_train, n_perturbations=10)\n",
    "modified_adj = model.modified_adj\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e730b5e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset(data_set)\n",
    "\n",
    "adj = graph.adjacency_matrix_scipy()\n",
    "features = sparse.csr_matrix(feat.numpy())\n",
    "labels = labels.numpy().astype(int)\n",
    "idx_train = np.where(train_mask == 1)[0]\n",
    "idx_val = np.where(val_mask == 1)[0]\n",
    "idx_test = np.where(test_mask == 1)[0]\n",
    "idx_unlabeled = np.union1d(idx_val, idx_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62e3f159",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set = 'pubmed'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ead27196",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
