{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6e4cfbc5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n",
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import os\n",
    "import dgl\n",
    "from dgl import function as fn\n",
    "from dataset import load_graph_dataset\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork, fast_hess, fast_hess_cuda, fast_get_inv_hvp_cuda\n",
    "from model_node_influence import NodeInfluenceSGC\n",
    "from gcn_with_node_flipping import gcn_with_node_flipping\n",
    "import tensorflow.compat.v1 as tf\n",
    "from graph_neural_networks import SGC_layer1, SGC_layer2\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "from sklearn.metrics import log_loss\n",
    "from scipy.special import softmax, log_softmax\n",
    "from scipy.linalg import cho_solve, cho_factor\n",
    "from tqdm import tqdm\n",
    "import cupy as cp\n",
    "from random import choice\n",
    "import heapq\n",
    "from sklearnex import patch_sklearn, config_context\n",
    "patch_sklearn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "72c069e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataname = 'cora'\n",
    "l2_regularlization_term = 0.01\n",
    "num_layer = 2\n",
    "\n",
    "# dataname = 'pubmed'\n",
    "# l2_regularlization_term = 0.004\n",
    "# num_layer = 2\n",
    "\n",
    "# dataname = 'citeseer'\n",
    "# l2_regularlization_term = 0.003\n",
    "# num_layer = 2\n",
    "\n",
    "\"\"\"set up random seed, perturb ratio\"\"\"\n",
    "perturb_ratio_list = [0.05, 0.1, 0.15, 0.2]\n",
    "some_seed_list = [1, 11, 15, 42, 100]\n",
    "num_times_running = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b9314002",
   "metadata": {},
   "outputs": [],
   "source": [
    "def index_to_mask(index, size):\n",
    "    mask = torch.zeros(size, dtype=torch.bool, device=index.device)\n",
    "    mask[index] = 1\n",
    "    return mask\n",
    "def random_splits_label_flip_attack(graph, labels, num_classes, seed):\n",
    "    # Set new random planetoid splits:\n",
    "    # * 20 * num_classes labels for training\n",
    "    # * 500 labels for validation\n",
    "    # * 1000 labels for testing\n",
    "    torch.manual_seed(seed)\n",
    "    \n",
    "    indices = []\n",
    "\n",
    "    for i in range(num_classes):\n",
    "        index = (labels == i).nonzero().view(-1)\n",
    "        index = index[torch.randperm(index.size(0))]\n",
    "        indices.append(index)\n",
    "\n",
    "    train_index = torch.cat([i[:20] for i in indices], dim=0)\n",
    "\n",
    "    rest_index = torch.cat([i[20:] for i in indices], dim=0)\n",
    "    rest_index = rest_index[torch.randperm(rest_index.size(0))]\n",
    "    \n",
    "    train_mask = index_to_mask(train_index, size=graph.num_nodes())\n",
    "    val_mask = index_to_mask(rest_index[:500], size=graph.num_nodes())\n",
    "    test_mask = index_to_mask(rest_index[500:1500], size=graph.num_nodes())\n",
    "\n",
    "    return train_mask, val_mask, test_mask\n",
    "\n",
    "def get_first_two_frequent(labels):\n",
    "    class_counts = np.bincount(labels)\n",
    "    a = np.argsort(class_counts)[-1]\n",
    "    b = np.argsort(class_counts)[-2]\n",
    "    return a, b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "35d21801",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_remove_index_train_all(from_indexes, to_indexes, train_mask):\n",
    "    train_index = torch.where(train_mask == 1)[0]\n",
    "    remove_from_list = []\n",
    "    remove_to_list = []\n",
    "    for i in tqdm(range(len(train_index))):\n",
    "        f_index = train_index[i]\n",
    "        to_index_list = torch.where(from_indexes == f_index)[0]\n",
    "        for to_index_e in to_index_list:\n",
    "            j = to_index_e\n",
    "            t_index = to_indexes[j]\n",
    "\n",
    "            remove_from_list.append(f_index)\n",
    "            remove_to_list.append(t_index)\n",
    "\n",
    "    return torch.tensor(remove_from_list), torch.tensor(remove_to_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "71aad88f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def node_flipping_attack_rev(dataname = dataname, l2_regularlization_term = 0.01, perturb_ratio = 0.05, \n",
    "                             num_layer = 2, some_seed = 42):\n",
    "    \n",
    "\n",
    "    graph, feat, labels, _, _, _, number_classes = load_graph_dataset(dataname)\n",
    "    train_mask, val_mask, test_mask = random_splits_label_flip_attack(graph, labels, number_classes, seed=some_seed)\n",
    "\n",
    "    lr = SimplifiedGraphNeuralNetwork(l2_reg=l2_regularlization_term, fit_intercept=True)\n",
    "\n",
    "    feat0 = feat.clone()\n",
    "    degs = graph.in_degrees().float().clamp(min = 1)\n",
    "    norm = torch.pow(degs, -0.5)\n",
    "    norm = norm.to(feat0.device).unsqueeze(1)\n",
    "\n",
    "    for _ in range(num_layer):\n",
    "        feat0 = feat0 * norm\n",
    "        graph.ndata['h'] = feat0\n",
    "        graph.update_all(fn.copy_u('h', 'm'),\n",
    "                         fn.sum('m', 'h'))\n",
    "        feat0 = graph.ndata.pop('h')\n",
    "        feat0 = feat0 * norm\n",
    "\n",
    "    train_x = feat0[train_mask].numpy().astype(np.float32)\n",
    "    train_y = labels[train_mask].numpy().astype(np.float32)\n",
    "\n",
    "    val_x = feat0[test_mask].numpy().astype(np.float32)\n",
    "    val_y = labels[test_mask].numpy().astype(np.float32)\n",
    "\n",
    "    train_node_idx = torch.where(train_mask == 1)[0]\n",
    "\n",
    "    enc = OneHotEncoder(handle_unknown='ignore')\n",
    "    enc.fit(train_y.reshape(-1, 1))\n",
    "\n",
    "    one_hot_labels_train = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "    one_hot_labels_val = enc.transform(val_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "    \"\"\" Train Logistic Regression \"\"\"\n",
    "    \n",
    "    lr_origin = SimplifiedGraphNeuralNetwork(l2_reg=l2_regularlization_term, fit_intercept=True)\n",
    "\n",
    "    lr_origin.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "\n",
    "    logits_val_y_origin = val_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    logits_train_y_origin = train_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    ori_val_loss, ave_ori_val_loss = lr_origin.log_loss(logits_val_y_origin, one_hot_labels_val, l2_reg=True)\n",
    "\n",
    "    # numpy_theoritic_loss = log_loss(val_y, softmax(logits_val_y_origin, axis=1))\n",
    "    # # set l2_reg to False, verify the correctness of calculations\n",
    "    # assert np.allclose(numpy_theoritic_loss, ave_ori_val_loss)\n",
    "\n",
    "    val_loss_total_grad_orig, val_loss_indiv_grad_orig = lr_origin.grad(val_x, \n",
    "                                                                        logits_val_y_origin,\n",
    "                                                                        one_hot_labels_val, l2_reg = True)\n",
    "\n",
    "    hess = lr_origin.hess_cuda(train_x, logits_train_y_origin, l2_reg = True)\n",
    "\n",
    "    loss_grad_hvp = fast_get_inv_hvp_cuda(hess, val_loss_total_grad_orig.T, cholskey=True)\n",
    "\n",
    "    loss_grad_hvp = cp.asnumpy(loss_grad_hvp)\n",
    "    del hess\n",
    "\n",
    "    acctual_influence_1 = []\n",
    "    acctual_influence_2 = []\n",
    "\n",
    "    predict_influence_1 = []\n",
    "    predict_influence_2 = []\n",
    "\n",
    "    for k in tqdm(range(len(train_node_idx))):\n",
    "\n",
    "        node_id = train_node_idx.numpy()[k]\n",
    "        nis = NodeInfluenceSGC(graph = graph, feature=feat, node_index=node_id)\n",
    "\n",
    "        # 2, remove the edges, calculate the perturbated feature\n",
    "        nis.remove_edges_sgc()\n",
    "        feat_removed1 = nis.calculate_modified_features()\n",
    "\n",
    "        extra_index = torch.unique(torch.where(feat0 != feat_removed1)[0])\n",
    "\n",
    "\n",
    "        extra_index_train = torch.tensor(\n",
    "            [extra_index[i] for i in range(len(extra_index)) if extra_index[i] in train_node_idx]).numpy()\n",
    "\n",
    "        extra_index_train_in_train = [\n",
    "            np.where(train_node_idx.numpy() == extra_index_train[j])[0][0] for j in range(len(extra_index_train))]\n",
    "\n",
    "        # 1, we need to remove the changed node feature from the perturbated feature, \n",
    "        # let it not added to the original feature\n",
    "\n",
    "\n",
    "        \"\"\"modified node features\"\"\"\n",
    "        extra_index_train_remove_node = extra_index_train.copy()\n",
    "        relative_node_id = np.where(extra_index_train_remove_node == node_id)[0]\n",
    "        extra_index_train_remove_node = np.delete(extra_index_train_remove_node, relative_node_id)\n",
    "        feat_to_be_added = feat_removed1[extra_index_train_remove_node].numpy()\n",
    "\n",
    "        \"\"\"index corresponding to modified node features\"\"\"\n",
    "        perturb_index = extra_index_train_in_train\n",
    "        added_index = perturb_index.copy()\n",
    "        added_index.remove(k)\n",
    "\n",
    "\n",
    "\n",
    "        train_x_new = feat_to_be_added\n",
    "        train_y_new = train_y[added_index]\n",
    "\n",
    "        train_x_orig = np.concatenate([train_x, train_x_new])\n",
    "        train_y_orig = np.concatenate([train_y, train_y_new])\n",
    "\n",
    "        one_hot_labels_train_0 = enc.transform(train_y_orig.reshape(-1, 1)).toarray()\n",
    "        logits_train_y_origin_0 = train_x_orig @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "        train_total_grad_orig, train_indiv_grad_orig = lr_origin.grad(train_x_orig, \n",
    "                                                logits_train_y_origin_0, \n",
    "                                                one_hot_labels_train_0, l2_reg = True)\n",
    "\n",
    "\n",
    "\n",
    "        pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "        \n",
    "        weight_3 = np.ones(len(train_x_orig))\n",
    "        weight_3[perturb_index] = 0 # 1...0...11\n",
    "\n",
    "        lr_new_2 = SimplifiedGraphNeuralNetwork(l2_reg=l2_regularlization_term, fit_intercept=True)\n",
    "        train_x_delete_2 = train_x_orig[weight_3 == 1]\n",
    "        train_y_delete_2 = train_y_orig[weight_3 == 1]\n",
    "\n",
    "\n",
    "        lr_new_2.fit(train_x_delete_2, train_y_delete_2)\n",
    "\n",
    "\n",
    "        logits_val_y_new_2 = val_x @ lr_new_2.model.coef_.T + lr_new_2.model.intercept_\n",
    "        new_ori_val_loss_2, _ = lr_new_2.log_loss(logits_val_y_new_2, one_hot_labels_val, l2_reg = True)\n",
    "\n",
    "        predict_influence_1.append(np.sum(pred_infl[perturb_index]) - np.sum(pred_infl[len(train_x):]))\n",
    "        acctual_influence_1.append(new_ori_val_loss_2 - ori_val_loss)\n",
    "\n",
    "\n",
    "    df = pd.DataFrame([predict_influence_1, acctual_influence_1]).T\n",
    "    df.columns = ['predicted influence', 'actual influence']\n",
    "    df.to_csv('result_flip_attack/'+ dataname + '/'+ '_pred_infl' +'.csv', index = False)\n",
    "    predicted_influence = np.array(predict_influence_1)\n",
    "\n",
    "    a, b = get_first_two_frequent(labels[test_mask])\n",
    "    idx1 = np.where(labels[train_mask].numpy() == a)[0]\n",
    "    idx2 = np.where(labels[train_mask].numpy() == b)[0]\n",
    "\n",
    "\n",
    "\n",
    "    num_train = np.sum(train_mask.numpy() == 1)\n",
    "    num_perturb = int(perturb_ratio * len(idx2) * 2)\n",
    "    predicted_influence_combined = np.concatenate([predicted_influence[idx1], predicted_influence[idx2]])\n",
    "    \n",
    "    predicted_influence_combined_sorted = np.sort(predicted_influence_combined)[::-1]\n",
    "\n",
    "    threshold = predicted_influence_combined_sorted[num_perturb]\n",
    "\n",
    "    \n",
    "    threshold_a = np.sort(predicted_influence[idx1])[::-1][int(num_perturb / 2)]\n",
    "    threshold_b = np.sort(predicted_influence[idx2])[::-1][int(num_perturb / 2)]\n",
    "    \n",
    "    \n",
    "    perturbed_train_y = train_y.copy()\n",
    "    new_labels_a = np.repeat(a, len(idx1))\n",
    "    new_labels_b = np.repeat(b, len(idx2))\n",
    "    assert(len(idx1) == len(idx2))\n",
    "\n",
    "    predicted_influence_combined_sorted\n",
    "\n",
    "    idx_a_to_b = np.where(predicted_influence[idx1] > threshold_a)[0]\n",
    "    \n",
    "    idx_b_to_a = np.where(predicted_influence[idx2] > threshold_b)[0]\n",
    "    \n",
    "\n",
    "    new_labels_a[idx_a_to_b] = b\n",
    "    new_labels_b[idx_b_to_a] = a\n",
    "\n",
    "    perturbed_train_y[idx1] = new_labels_a\n",
    "    perturbed_train_y[idx2] = new_labels_b\n",
    "\n",
    "    new_labels = labels.numpy().copy()\n",
    "    new_labels[train_mask] = perturbed_train_y\n",
    "    new_labels = torch.tensor(new_labels)\n",
    "\n",
    "    gcn_with_node_flip = gcn_with_node_flipping(graph= graph, features=feat, new_labels=new_labels, \n",
    "                                                train_mask=train_mask, val_mask=val_mask, test_mask=test_mask,\n",
    "                                               num_classes=number_classes,  dropout=0.5)\n",
    "\n",
    "    gcn_without_node_flip = gcn_with_node_flipping(graph= graph, features=feat, new_labels=labels, \n",
    "                                                train_mask=train_mask, val_mask=val_mask, test_mask=test_mask,\n",
    "                                               num_classes=number_classes)\n",
    "\n",
    "    acc_flip = gcn_with_node_flip.train_evaluate()\n",
    "    acc_no_flip = gcn_without_node_flip.train_evaluate()\n",
    "    \n",
    "    return acc_flip, acc_no_flip, predicted_influence_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3c1fa1e0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2, 3, 4])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sort([4, 2, 3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "41692975",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.77it/s]\n",
      "100%|█████████████████████████████████████████| 140/140 [00:13<00:00, 10.17it/s]\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3419: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/_methods.py:188: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00000 | Time(s) nan | Loss 1.9461 | Accuracy 0.3720 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9417 | Accuracy 0.3600 | number of edges 13264.00\n",
      "Epoch 00002 | Time(s) nan | Loss 1.9350 | Accuracy 0.4140 | number of edges 13264.00\n",
      "Epoch 00003 | Time(s) 0.0057 | Loss 1.9293 | Accuracy 0.4100 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0051 | Loss 1.9218 | Accuracy 0.4540 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0049 | Loss 1.9132 | Accuracy 0.5040 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0050 | Loss 1.9041 | Accuracy 0.5480 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0050 | Loss 1.9007 | Accuracy 0.6260 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0049 | Loss 1.8884 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0049 | Loss 1.8758 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0048 | Loss 1.8679 | Accuracy 0.6840 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0048 | Loss 1.8643 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0048 | Loss 1.8476 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0048 | Loss 1.8328 | Accuracy 0.6660 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0047 | Loss 1.8347 | Accuracy 0.6640 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0047 | Loss 1.8287 | Accuracy 0.6660 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0047 | Loss 1.8009 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0047 | Loss 1.7934 | Accuracy 0.6840 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0047 | Loss 1.7841 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0047 | Loss 1.7568 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0047 | Loss 1.7613 | Accuracy 0.6860 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0046 | Loss 1.7415 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0046 | Loss 1.7346 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0046 | Loss 1.7155 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0046 | Loss 1.7025 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0046 | Loss 1.6633 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0047 | Loss 1.6627 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0047 | Loss 1.6719 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0048 | Loss 1.6356 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0048 | Loss 1.6193 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0048 | Loss 1.5909 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0047 | Loss 1.5797 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0048 | Loss 1.5830 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0048 | Loss 1.5628 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0047 | Loss 1.5536 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0047 | Loss 1.5249 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0047 | Loss 1.5028 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0047 | Loss 1.4898 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0047 | Loss 1.4804 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0047 | Loss 1.4656 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0047 | Loss 1.4242 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0047 | Loss 1.4043 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0047 | Loss 1.4138 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0047 | Loss 1.3876 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0047 | Loss 1.3897 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0047 | Loss 1.3229 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0047 | Loss 1.3344 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0047 | Loss 1.3527 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0047 | Loss 1.2765 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0047 | Loss 1.2867 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0047 | Loss 1.2633 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0047 | Loss 1.2738 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0047 | Loss 1.2248 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0048 | Loss 1.2325 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0048 | Loss 1.2533 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0048 | Loss 1.1509 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0048 | Loss 1.1729 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0048 | Loss 1.1524 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0048 | Loss 1.1224 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0048 | Loss 1.1391 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0048 | Loss 1.1303 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0048 | Loss 1.0995 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0048 | Loss 1.0995 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0048 | Loss 1.0568 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0048 | Loss 1.0702 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0048 | Loss 1.0431 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0048 | Loss 0.9923 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0047 | Loss 1.0006 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0047 | Loss 1.0338 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0047 | Loss 0.9501 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0047 | Loss 0.9697 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0047 | Loss 1.0034 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0047 | Loss 0.9303 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0047 | Loss 0.9832 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0047 | Loss 0.9283 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0047 | Loss 0.9332 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0047 | Loss 0.9125 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0047 | Loss 0.9180 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0047 | Loss 0.9236 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0047 | Loss 0.9236 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0048 | Loss 0.8641 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0048 | Loss 0.8440 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0048 | Loss 0.8581 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0048 | Loss 0.8541 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0048 | Loss 0.7972 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0048 | Loss 0.8820 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0047 | Loss 0.7487 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0047 | Loss 0.8622 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0047 | Loss 0.8101 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0047 | Loss 0.8492 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0047 | Loss 0.8197 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0048 | Loss 0.7731 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0048 | Loss 0.7345 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0048 | Loss 0.7822 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0048 | Loss 0.7948 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0048 | Loss 0.7612 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0048 | Loss 0.7496 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0048 | Loss 0.7154 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00098 | Time(s) 0.0048 | Loss 0.7546 | Accuracy 0.7340 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00099 | Time(s) 0.0048 | Loss 0.7143 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00100 | Time(s) 0.0048 | Loss 0.7585 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00101 | Time(s) 0.0048 | Loss 0.7434 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0048 | Loss 0.7037 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00103 | Time(s) 0.0048 | Loss 0.7283 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00104 | Time(s) 0.0048 | Loss 0.7224 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0048 | Loss 0.6943 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0048 | Loss 0.7065 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0048 | Loss 0.6511 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0048 | Loss 0.6987 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0048 | Loss 0.6693 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0048 | Loss 0.6387 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0048 | Loss 0.7280 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0048 | Loss 0.6686 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0048 | Loss 0.6167 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0048 | Loss 0.6194 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0048 | Loss 0.6520 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0048 | Loss 0.6079 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0048 | Loss 0.6216 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0048 | Loss 0.6465 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0048 | Loss 0.6491 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0048 | Loss 0.6254 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0048 | Loss 0.6533 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0048 | Loss 0.6382 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0048 | Loss 0.6087 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0048 | Loss 0.6487 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0048 | Loss 0.6043 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0048 | Loss 0.5834 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0048 | Loss 0.6084 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0048 | Loss 0.6178 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0048 | Loss 0.5395 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0048 | Loss 0.5928 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0048 | Loss 0.5683 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0048 | Loss 0.5559 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0048 | Loss 0.6230 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0048 | Loss 0.5881 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0048 | Loss 0.5853 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0048 | Loss 0.5809 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0048 | Loss 0.5678 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0048 | Loss 0.5133 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0048 | Loss 0.5572 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0048 | Loss 0.5513 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0047 | Loss 0.5301 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0047 | Loss 0.5098 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0047 | Loss 0.5533 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0047 | Loss 0.5495 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0047 | Loss 0.5712 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0047 | Loss 0.5478 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0047 | Loss 0.5777 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0047 | Loss 0.5513 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0047 | Loss 0.5499 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0048 | Loss 0.5117 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0048 | Loss 0.5305 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0048 | Loss 0.4939 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0048 | Loss 0.5433 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0048 | Loss 0.5330 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0048 | Loss 0.5777 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0048 | Loss 0.5297 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0048 | Loss 0.4915 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0048 | Loss 0.5037 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0048 | Loss 0.5300 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0048 | Loss 0.4926 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0048 | Loss 0.4939 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0048 | Loss 0.5143 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0048 | Loss 0.5240 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0048 | Loss 0.5265 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0048 | Loss 0.4962 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0048 | Loss 0.5375 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0048 | Loss 0.5478 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0048 | Loss 0.5298 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0048 | Loss 0.5057 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0048 | Loss 0.4753 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0048 | Loss 0.4572 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0048 | Loss 0.5091 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0048 | Loss 0.5000 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0048 | Loss 0.5096 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0048 | Loss 0.4849 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0048 | Loss 0.5025 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0048 | Loss 0.5199 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0048 | Loss 0.4591 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0048 | Loss 0.4715 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0048 | Loss 0.4713 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0048 | Loss 0.4740 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0048 | Loss 0.4778 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0048 | Loss 0.4866 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0048 | Loss 0.4712 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0048 | Loss 0.4635 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0048 | Loss 0.4729 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0048 | Loss 0.4654 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0048 | Loss 0.4843 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0048 | Loss 0.4339 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0048 | Loss 0.4323 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0048 | Loss 0.4691 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0048 | Loss 0.4755 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0048 | Loss 0.4275 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0048 | Loss 0.4704 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0048 | Loss 0.4571 | Accuracy 0.7460 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00196 | Time(s) 0.0048 | Loss 0.4642 | Accuracy 0.7480 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0048 | Loss 0.4601 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0048 | Loss 0.4724 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0048 | Loss 0.4599 | Accuracy 0.7460 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 75.30%\n",
      "Epoch 00000 | Time(s) nan | Loss 1.9460 | Accuracy 0.3820 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9389 | Accuracy 0.2400 | number of edges 13264.00\n",
      "Epoch 00002 | Time(s) nan | Loss 1.9317 | Accuracy 0.2540 | number of edges 13264.00\n",
      "Epoch 00003 | Time(s) 0.0046 | Loss 1.9236 | Accuracy 0.3360 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0044 | Loss 1.9144 | Accuracy 0.4120 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0044 | Loss 1.9049 | Accuracy 0.4700 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0046 | Loss 1.8948 | Accuracy 0.5240 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0045 | Loss 1.8836 | Accuracy 0.6020 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0046 | Loss 1.8716 | Accuracy 0.6380 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0046 | Loss 1.8593 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0046 | Loss 1.8467 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0046 | Loss 1.8335 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0046 | Loss 1.8197 | Accuracy 0.6540 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0046 | Loss 1.8054 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0046 | Loss 1.7905 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0046 | Loss 1.7752 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0046 | Loss 1.7593 | Accuracy 0.6580 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0046 | Loss 1.7427 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0046 | Loss 1.7256 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0045 | Loss 1.7080 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0045 | Loss 1.6899 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0045 | Loss 1.6712 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0046 | Loss 1.6521 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0046 | Loss 1.6324 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0046 | Loss 1.6122 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0046 | Loss 1.5916 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0046 | Loss 1.5704 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0046 | Loss 1.5487 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0046 | Loss 1.5266 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0046 | Loss 1.5041 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0046 | Loss 1.4813 | Accuracy 0.7560 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0046 | Loss 1.4580 | Accuracy 0.7600 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0045 | Loss 1.4344 | Accuracy 0.7660 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0046 | Loss 1.4104 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0046 | Loss 1.3863 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0046 | Loss 1.3618 | Accuracy 0.7720 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0046 | Loss 1.3372 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0046 | Loss 1.3125 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0045 | Loss 1.2877 | Accuracy 0.7780 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0045 | Loss 1.2628 | Accuracy 0.7800 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0045 | Loss 1.2380 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0045 | Loss 1.2132 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0045 | Loss 1.1885 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0046 | Loss 1.1639 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0046 | Loss 1.1394 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0045 | Loss 1.1152 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0046 | Loss 1.0912 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0046 | Loss 1.0674 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0046 | Loss 1.0439 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0046 | Loss 1.0207 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0046 | Loss 0.9979 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0046 | Loss 0.9755 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0046 | Loss 0.9535 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0046 | Loss 0.9319 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0046 | Loss 0.9108 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0046 | Loss 0.8901 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0046 | Loss 0.8699 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0046 | Loss 0.8501 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0046 | Loss 0.8309 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0046 | Loss 0.8122 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0046 | Loss 0.7940 | Accuracy 0.7960 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0046 | Loss 0.7763 | Accuracy 0.7980 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0046 | Loss 0.7591 | Accuracy 0.8020 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0046 | Loss 0.7425 | Accuracy 0.8040 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0046 | Loss 0.7264 | Accuracy 0.8080 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0047 | Loss 0.7108 | Accuracy 0.8100 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0047 | Loss 0.6957 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0046 | Loss 0.6812 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0046 | Loss 0.6671 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0046 | Loss 0.6535 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0046 | Loss 0.6404 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0046 | Loss 0.6278 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0046 | Loss 0.6156 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0047 | Loss 0.6038 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0047 | Loss 0.5924 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0047 | Loss 0.5815 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0047 | Loss 0.5710 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0047 | Loss 0.5608 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0047 | Loss 0.5510 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0047 | Loss 0.5416 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0047 | Loss 0.5325 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0047 | Loss 0.5237 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0047 | Loss 0.5153 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0047 | Loss 0.5072 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0047 | Loss 0.4993 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0047 | Loss 0.4917 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0047 | Loss 0.4844 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0047 | Loss 0.4773 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0047 | Loss 0.4705 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0047 | Loss 0.4639 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0047 | Loss 0.4575 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0047 | Loss 0.4513 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0047 | Loss 0.4453 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0047 | Loss 0.4395 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0047 | Loss 0.4339 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0047 | Loss 0.4284 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0046 | Loss 0.4231 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0046 | Loss 0.4180 | Accuracy 0.8240 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00098 | Time(s) 0.0047 | Loss 0.4130 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00099 | Time(s) 0.0047 | Loss 0.4081 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00100 | Time(s) 0.0047 | Loss 0.4034 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00101 | Time(s) 0.0047 | Loss 0.3989 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0047 | Loss 0.3944 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00103 | Time(s) 0.0047 | Loss 0.3901 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00104 | Time(s) 0.0047 | Loss 0.3859 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0047 | Loss 0.3818 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0047 | Loss 0.3778 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0047 | Loss 0.3739 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0047 | Loss 0.3701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0046 | Loss 0.3664 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0046 | Loss 0.3628 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0047 | Loss 0.3593 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0047 | Loss 0.3559 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0047 | Loss 0.3525 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0046 | Loss 0.3493 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0047 | Loss 0.3461 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0046 | Loss 0.3430 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0046 | Loss 0.3399 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0046 | Loss 0.3369 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0046 | Loss 0.3340 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0047 | Loss 0.3311 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0047 | Loss 0.3283 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0047 | Loss 0.3256 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0047 | Loss 0.3229 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0047 | Loss 0.3203 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0047 | Loss 0.3177 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0047 | Loss 0.3152 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0047 | Loss 0.3127 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0047 | Loss 0.3103 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0047 | Loss 0.3079 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0047 | Loss 0.3056 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0047 | Loss 0.3033 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0046 | Loss 0.3010 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0046 | Loss 0.2988 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0046 | Loss 0.2967 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0046 | Loss 0.2945 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0046 | Loss 0.2925 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0046 | Loss 0.2904 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0046 | Loss 0.2884 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0046 | Loss 0.2864 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0046 | Loss 0.2845 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0046 | Loss 0.2826 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0046 | Loss 0.2807 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0046 | Loss 0.2789 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0046 | Loss 0.2771 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0046 | Loss 0.2753 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0046 | Loss 0.2735 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0046 | Loss 0.2718 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0046 | Loss 0.2701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0046 | Loss 0.2684 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0046 | Loss 0.2668 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0046 | Loss 0.2652 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0046 | Loss 0.2636 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0046 | Loss 0.2620 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0046 | Loss 0.2605 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0046 | Loss 0.2590 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0046 | Loss 0.2575 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0046 | Loss 0.2560 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0046 | Loss 0.2546 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0046 | Loss 0.2531 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0046 | Loss 0.2517 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0046 | Loss 0.2503 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0046 | Loss 0.2490 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0046 | Loss 0.2476 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0046 | Loss 0.2463 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0046 | Loss 0.2450 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0046 | Loss 0.2437 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0046 | Loss 0.2425 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0046 | Loss 0.2412 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0046 | Loss 0.2400 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0046 | Loss 0.2387 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0046 | Loss 0.2375 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0046 | Loss 0.2364 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0046 | Loss 0.2352 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0046 | Loss 0.2341 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0046 | Loss 0.2329 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0046 | Loss 0.2318 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0046 | Loss 0.2307 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0046 | Loss 0.2296 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0046 | Loss 0.2285 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0046 | Loss 0.2275 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0046 | Loss 0.2264 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0046 | Loss 0.2254 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0046 | Loss 0.2244 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0046 | Loss 0.2234 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0046 | Loss 0.2224 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0046 | Loss 0.2214 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0046 | Loss 0.2204 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0046 | Loss 0.2194 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0046 | Loss 0.2185 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0046 | Loss 0.2176 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0046 | Loss 0.2166 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0046 | Loss 0.2157 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0046 | Loss 0.2148 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0046 | Loss 0.2139 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0046 | Loss 0.2131 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00196 | Time(s) 0.0046 | Loss 0.2122 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0046 | Loss 0.2113 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0046 | Loss 0.2105 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0046 | Loss 0.2096 | Accuracy 0.8180 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 80.90%\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.55it/s]\n",
      "100%|█████████████████████████████████████████| 140/140 [00:14<00:00,  9.96it/s]\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3419: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/_methods.py:188: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00000 | Time(s) nan | Loss 1.9461 | Accuracy 0.3660 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9417 | Accuracy 0.3300 | number of edges 13264.00\n",
      "Epoch 00002 | Time(s) nan | Loss 1.9358 | Accuracy 0.4600 | number of edges 13264.00\n",
      "Epoch 00003 | Time(s) 0.0045 | Loss 1.9294 | Accuracy 0.3500 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0045 | Loss 1.9220 | Accuracy 0.3540 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0047 | Loss 1.9140 | Accuracy 0.3900 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0046 | Loss 1.9048 | Accuracy 0.4480 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0045 | Loss 1.9015 | Accuracy 0.5100 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0046 | Loss 1.8888 | Accuracy 0.6120 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0046 | Loss 1.8758 | Accuracy 0.6460 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0046 | Loss 1.8684 | Accuracy 0.6680 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0046 | Loss 1.8645 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0046 | Loss 1.8479 | Accuracy 0.6780 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0046 | Loss 1.8330 | Accuracy 0.6660 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0047 | Loss 1.8353 | Accuracy 0.6680 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0047 | Loss 1.8293 | Accuracy 0.6780 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0046 | Loss 1.8022 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0046 | Loss 1.7941 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0046 | Loss 1.7844 | Accuracy 0.6800 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0046 | Loss 1.7569 | Accuracy 0.6780 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0047 | Loss 1.7641 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0047 | Loss 1.7414 | Accuracy 0.6860 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0047 | Loss 1.7363 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0047 | Loss 1.7194 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0047 | Loss 1.7044 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0047 | Loss 1.6632 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0047 | Loss 1.6620 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0047 | Loss 1.6737 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0047 | Loss 1.6364 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0047 | Loss 1.6217 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0047 | Loss 1.5924 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0047 | Loss 1.5799 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0047 | Loss 1.5841 | Accuracy 0.6860 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0047 | Loss 1.5636 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0047 | Loss 1.5551 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0047 | Loss 1.5276 | Accuracy 0.6860 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0047 | Loss 1.5027 | Accuracy 0.6860 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0047 | Loss 1.4895 | Accuracy 0.6800 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0047 | Loss 1.4802 | Accuracy 0.6840 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0047 | Loss 1.4660 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0047 | Loss 1.4236 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0047 | Loss 1.4056 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0046 | Loss 1.4118 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0046 | Loss 1.3872 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0046 | Loss 1.3908 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0046 | Loss 1.3223 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0046 | Loss 1.3360 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0046 | Loss 1.3494 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0046 | Loss 1.2772 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0046 | Loss 1.2839 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0046 | Loss 1.2663 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0046 | Loss 1.2754 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0046 | Loss 1.2230 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0046 | Loss 1.2297 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0046 | Loss 1.2529 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0047 | Loss 1.1537 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0047 | Loss 1.1700 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0046 | Loss 1.1532 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0046 | Loss 1.1221 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0046 | Loss 1.1350 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0046 | Loss 1.1318 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0046 | Loss 1.1025 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0046 | Loss 1.0932 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0046 | Loss 1.0538 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0046 | Loss 1.0731 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0046 | Loss 1.0414 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0046 | Loss 0.9906 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0046 | Loss 1.0012 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0046 | Loss 1.0350 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0046 | Loss 0.9477 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0046 | Loss 0.9684 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0046 | Loss 1.0004 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0046 | Loss 0.9347 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0046 | Loss 0.9822 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0046 | Loss 0.9296 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0046 | Loss 0.9339 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0046 | Loss 0.9099 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0046 | Loss 0.9181 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0047 | Loss 0.9268 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0047 | Loss 0.9233 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0047 | Loss 0.8642 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0047 | Loss 0.8466 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0047 | Loss 0.8540 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0047 | Loss 0.8549 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0047 | Loss 0.8001 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0047 | Loss 0.8747 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0047 | Loss 0.7485 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0047 | Loss 0.8584 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0047 | Loss 0.8082 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0047 | Loss 0.8455 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0047 | Loss 0.8124 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0047 | Loss 0.7691 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0047 | Loss 0.7410 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0047 | Loss 0.7831 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0047 | Loss 0.7899 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0047 | Loss 0.7628 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0047 | Loss 0.7467 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0047 | Loss 0.7095 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00098 | Time(s) 0.0047 | Loss 0.7459 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00099 | Time(s) 0.0047 | Loss 0.7094 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00100 | Time(s) 0.0047 | Loss 0.7560 | Accuracy 0.7260 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00101 | Time(s) 0.0047 | Loss 0.7354 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0047 | Loss 0.7047 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00103 | Time(s) 0.0047 | Loss 0.7241 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00104 | Time(s) 0.0047 | Loss 0.7245 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0047 | Loss 0.7010 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0047 | Loss 0.7013 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0047 | Loss 0.6486 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0047 | Loss 0.6953 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0047 | Loss 0.6689 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0047 | Loss 0.6285 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0047 | Loss 0.7168 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0047 | Loss 0.6614 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0047 | Loss 0.6110 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0046 | Loss 0.6099 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0046 | Loss 0.6408 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0046 | Loss 0.6081 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0046 | Loss 0.6245 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0046 | Loss 0.6441 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0046 | Loss 0.6428 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0046 | Loss 0.6210 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0046 | Loss 0.6460 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0046 | Loss 0.6303 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0046 | Loss 0.6094 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0046 | Loss 0.6363 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0046 | Loss 0.5924 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0046 | Loss 0.5745 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0046 | Loss 0.6044 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0046 | Loss 0.6096 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0046 | Loss 0.5357 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0047 | Loss 0.5848 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0046 | Loss 0.5599 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0046 | Loss 0.5488 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0046 | Loss 0.6205 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0046 | Loss 0.5784 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0046 | Loss 0.5786 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0046 | Loss 0.5781 | Accuracy 0.7160 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0046 | Loss 0.5621 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0046 | Loss 0.5158 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0046 | Loss 0.5529 | Accuracy 0.7140 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0046 | Loss 0.5511 | Accuracy 0.7180 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0046 | Loss 0.5243 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0046 | Loss 0.5051 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0046 | Loss 0.5514 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0046 | Loss 0.5381 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0046 | Loss 0.5658 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0046 | Loss 0.5445 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0046 | Loss 0.5774 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0046 | Loss 0.5466 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0046 | Loss 0.5457 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0046 | Loss 0.5186 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0046 | Loss 0.5273 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0046 | Loss 0.4885 | Accuracy 0.7240 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0046 | Loss 0.5336 | Accuracy 0.7280 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0046 | Loss 0.5385 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0046 | Loss 0.5618 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0046 | Loss 0.5223 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0046 | Loss 0.4798 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0046 | Loss 0.5084 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0046 | Loss 0.5201 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0046 | Loss 0.4798 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0046 | Loss 0.4825 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0046 | Loss 0.5087 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0046 | Loss 0.5257 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0046 | Loss 0.5282 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0046 | Loss 0.4964 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0046 | Loss 0.5299 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0046 | Loss 0.5354 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0046 | Loss 0.5249 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0046 | Loss 0.4884 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0046 | Loss 0.4813 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0046 | Loss 0.4533 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0046 | Loss 0.4931 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0046 | Loss 0.5046 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0046 | Loss 0.5059 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0046 | Loss 0.4710 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0046 | Loss 0.5003 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0046 | Loss 0.5191 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0046 | Loss 0.4577 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0046 | Loss 0.4597 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0046 | Loss 0.4689 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0046 | Loss 0.4720 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0046 | Loss 0.4692 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0046 | Loss 0.4879 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0046 | Loss 0.4688 | Accuracy 0.7220 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0046 | Loss 0.4562 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0046 | Loss 0.4696 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0046 | Loss 0.4519 | Accuracy 0.7260 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0046 | Loss 0.4737 | Accuracy 0.7320 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0046 | Loss 0.4301 | Accuracy 0.7360 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0046 | Loss 0.4325 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0046 | Loss 0.4577 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0046 | Loss 0.4725 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0046 | Loss 0.4224 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0046 | Loss 0.4670 | Accuracy 0.7380 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0046 | Loss 0.4593 | Accuracy 0.7400 | number of edges 13264.00\n",
      "Epoch 00196 | Time(s) 0.0046 | Loss 0.4498 | Accuracy 0.7440 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0046 | Loss 0.4619 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0046 | Loss 0.4587 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0046 | Loss 0.4439 | Accuracy 0.7420 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 73.50%\n",
      "Epoch 00000 | Time(s) nan | Loss 1.9460 | Accuracy 0.3820 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9389 | Accuracy 0.2400 | number of edges 13264.00\n",
      "Epoch 00002 | Time(s) nan | Loss 1.9317 | Accuracy 0.2540 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00003 | Time(s) 0.0047 | Loss 1.9236 | Accuracy 0.3360 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0053 | Loss 1.9144 | Accuracy 0.4120 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0054 | Loss 1.9049 | Accuracy 0.4700 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0054 | Loss 1.8948 | Accuracy 0.5240 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0054 | Loss 1.8836 | Accuracy 0.6020 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0053 | Loss 1.8716 | Accuracy 0.6380 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0052 | Loss 1.8593 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0052 | Loss 1.8467 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0051 | Loss 1.8335 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0051 | Loss 1.8197 | Accuracy 0.6540 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0051 | Loss 1.8054 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0050 | Loss 1.7905 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0051 | Loss 1.7752 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0050 | Loss 1.7593 | Accuracy 0.6580 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0050 | Loss 1.7427 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0050 | Loss 1.7256 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0050 | Loss 1.7080 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0050 | Loss 1.6899 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0050 | Loss 1.6712 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0050 | Loss 1.6521 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0050 | Loss 1.6324 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0050 | Loss 1.6122 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0050 | Loss 1.5916 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0050 | Loss 1.5704 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0050 | Loss 1.5487 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0050 | Loss 1.5266 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0050 | Loss 1.5041 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0050 | Loss 1.4813 | Accuracy 0.7560 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0050 | Loss 1.4580 | Accuracy 0.7600 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0050 | Loss 1.4344 | Accuracy 0.7660 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0050 | Loss 1.4104 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0050 | Loss 1.3863 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0050 | Loss 1.3618 | Accuracy 0.7720 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0050 | Loss 1.3372 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0050 | Loss 1.3125 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0050 | Loss 1.2877 | Accuracy 0.7780 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0050 | Loss 1.2628 | Accuracy 0.7800 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0050 | Loss 1.2380 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0050 | Loss 1.2132 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0049 | Loss 1.1885 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0049 | Loss 1.1639 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0049 | Loss 1.1394 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0049 | Loss 1.1152 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0049 | Loss 1.0912 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0049 | Loss 1.0674 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0049 | Loss 1.0439 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0049 | Loss 1.0207 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0049 | Loss 0.9979 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0048 | Loss 0.9755 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0048 | Loss 0.9535 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0049 | Loss 0.9319 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0048 | Loss 0.9108 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0048 | Loss 0.8901 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0048 | Loss 0.8699 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0048 | Loss 0.8501 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0048 | Loss 0.8309 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0048 | Loss 0.8122 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0048 | Loss 0.7940 | Accuracy 0.7960 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0048 | Loss 0.7763 | Accuracy 0.7980 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0048 | Loss 0.7591 | Accuracy 0.8020 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0048 | Loss 0.7425 | Accuracy 0.8040 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0048 | Loss 0.7264 | Accuracy 0.8080 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0048 | Loss 0.7108 | Accuracy 0.8100 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0048 | Loss 0.6957 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0048 | Loss 0.6812 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0048 | Loss 0.6671 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0048 | Loss 0.6535 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0048 | Loss 0.6404 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0047 | Loss 0.6278 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0048 | Loss 0.6156 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0048 | Loss 0.6038 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0048 | Loss 0.5924 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0048 | Loss 0.5815 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0048 | Loss 0.5710 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0048 | Loss 0.5608 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0048 | Loss 0.5510 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0048 | Loss 0.5416 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0048 | Loss 0.5325 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0048 | Loss 0.5237 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0048 | Loss 0.5153 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0048 | Loss 0.5072 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0048 | Loss 0.4993 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0048 | Loss 0.4917 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0048 | Loss 0.4844 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0048 | Loss 0.4773 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0048 | Loss 0.4705 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0048 | Loss 0.4639 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0048 | Loss 0.4575 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0048 | Loss 0.4513 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0048 | Loss 0.4453 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0048 | Loss 0.4395 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0048 | Loss 0.4339 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0048 | Loss 0.4284 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0048 | Loss 0.4231 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0048 | Loss 0.4180 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00098 | Time(s) 0.0048 | Loss 0.4130 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00099 | Time(s) 0.0048 | Loss 0.4081 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00100 | Time(s) 0.0048 | Loss 0.4034 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00101 | Time(s) 0.0048 | Loss 0.3989 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0048 | Loss 0.3944 | Accuracy 0.8220 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00103 | Time(s) 0.0048 | Loss 0.3901 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00104 | Time(s) 0.0048 | Loss 0.3859 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0048 | Loss 0.3818 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0048 | Loss 0.3778 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0048 | Loss 0.3739 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0048 | Loss 0.3701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0048 | Loss 0.3664 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0048 | Loss 0.3628 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0048 | Loss 0.3593 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0048 | Loss 0.3559 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0048 | Loss 0.3525 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0048 | Loss 0.3493 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0048 | Loss 0.3461 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0048 | Loss 0.3430 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0048 | Loss 0.3399 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0048 | Loss 0.3369 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0048 | Loss 0.3340 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0048 | Loss 0.3311 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0048 | Loss 0.3283 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0048 | Loss 0.3256 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0048 | Loss 0.3229 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0048 | Loss 0.3203 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0048 | Loss 0.3177 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0048 | Loss 0.3152 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0048 | Loss 0.3127 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0048 | Loss 0.3103 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0048 | Loss 0.3079 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0048 | Loss 0.3056 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0048 | Loss 0.3033 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0048 | Loss 0.3010 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0049 | Loss 0.2988 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0048 | Loss 0.2967 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0049 | Loss 0.2945 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0048 | Loss 0.2925 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0049 | Loss 0.2904 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0048 | Loss 0.2884 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0049 | Loss 0.2864 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0049 | Loss 0.2845 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0049 | Loss 0.2826 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0048 | Loss 0.2807 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0049 | Loss 0.2789 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0049 | Loss 0.2771 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0049 | Loss 0.2753 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0049 | Loss 0.2735 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0049 | Loss 0.2718 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0049 | Loss 0.2701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0049 | Loss 0.2684 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0049 | Loss 0.2668 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0049 | Loss 0.2652 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0049 | Loss 0.2636 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0049 | Loss 0.2620 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0049 | Loss 0.2605 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0049 | Loss 0.2590 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0049 | Loss 0.2575 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0049 | Loss 0.2560 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0049 | Loss 0.2546 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0049 | Loss 0.2531 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0048 | Loss 0.2517 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0048 | Loss 0.2503 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0048 | Loss 0.2490 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0048 | Loss 0.2476 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0048 | Loss 0.2463 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0048 | Loss 0.2450 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0048 | Loss 0.2437 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0048 | Loss 0.2425 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0048 | Loss 0.2412 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0048 | Loss 0.2400 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0048 | Loss 0.2387 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0048 | Loss 0.2375 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0048 | Loss 0.2364 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0048 | Loss 0.2352 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0048 | Loss 0.2341 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0048 | Loss 0.2329 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0048 | Loss 0.2318 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0048 | Loss 0.2307 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0048 | Loss 0.2296 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0048 | Loss 0.2285 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0048 | Loss 0.2275 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0048 | Loss 0.2264 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0048 | Loss 0.2254 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0048 | Loss 0.2244 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0048 | Loss 0.2234 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0048 | Loss 0.2224 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0048 | Loss 0.2214 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0048 | Loss 0.2204 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0048 | Loss 0.2194 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0048 | Loss 0.2185 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0048 | Loss 0.2176 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0048 | Loss 0.2166 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0048 | Loss 0.2157 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0048 | Loss 0.2148 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0048 | Loss 0.2139 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0048 | Loss 0.2131 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00196 | Time(s) 0.0048 | Loss 0.2122 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0048 | Loss 0.2113 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0048 | Loss 0.2105 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0048 | Loss 0.2096 | Accuracy 0.8180 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 80.90%\n",
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 208.15it/s]\n",
      "100%|█████████████████████████████████████████| 140/140 [00:13<00:00, 10.16it/s]\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3419: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/numpy/core/_methods.py:188: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00000 | Time(s) nan | Loss 1.9461 | Accuracy 0.3540 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9417 | Accuracy 0.3200 | number of edges 13264.00\n",
      "Epoch 00002 | Time(s) nan | Loss 1.9357 | Accuracy 0.4400 | number of edges 13264.00\n",
      "Epoch 00003 | Time(s) 0.0046 | Loss 1.9295 | Accuracy 0.3580 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0045 | Loss 1.9223 | Accuracy 0.3780 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0047 | Loss 1.9141 | Accuracy 0.4220 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0046 | Loss 1.9051 | Accuracy 0.4480 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0047 | Loss 1.9018 | Accuracy 0.5280 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0047 | Loss 1.8888 | Accuracy 0.6020 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0048 | Loss 1.8764 | Accuracy 0.6420 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0048 | Loss 1.8692 | Accuracy 0.6620 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0049 | Loss 1.8653 | Accuracy 0.6580 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0048 | Loss 1.8487 | Accuracy 0.6640 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0049 | Loss 1.8338 | Accuracy 0.6640 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0049 | Loss 1.8358 | Accuracy 0.6580 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0049 | Loss 1.8299 | Accuracy 0.6660 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0049 | Loss 1.8037 | Accuracy 0.6720 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0049 | Loss 1.7949 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0049 | Loss 1.7858 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0049 | Loss 1.7586 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0049 | Loss 1.7649 | Accuracy 0.6640 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0049 | Loss 1.7423 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0049 | Loss 1.7386 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0049 | Loss 1.7210 | Accuracy 0.6800 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0049 | Loss 1.7064 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0049 | Loss 1.6652 | Accuracy 0.6720 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0049 | Loss 1.6648 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0049 | Loss 1.6753 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0049 | Loss 1.6384 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0049 | Loss 1.6224 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0049 | Loss 1.5942 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0049 | Loss 1.5819 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0049 | Loss 1.5850 | Accuracy 0.6820 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0049 | Loss 1.5651 | Accuracy 0.6780 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0049 | Loss 1.5571 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0049 | Loss 1.5292 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0048 | Loss 1.5051 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0048 | Loss 1.4921 | Accuracy 0.6740 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0048 | Loss 1.4816 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0048 | Loss 1.4692 | Accuracy 0.6700 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0048 | Loss 1.4254 | Accuracy 0.6800 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0048 | Loss 1.4083 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0048 | Loss 1.4130 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0048 | Loss 1.3876 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0048 | Loss 1.3941 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0048 | Loss 1.3255 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0048 | Loss 1.3387 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0048 | Loss 1.3537 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0048 | Loss 1.2812 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0048 | Loss 1.2861 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0048 | Loss 1.2703 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0048 | Loss 1.2749 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0048 | Loss 1.2238 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0048 | Loss 1.2322 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0048 | Loss 1.2535 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0048 | Loss 1.1558 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0048 | Loss 1.1717 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0048 | Loss 1.1530 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0048 | Loss 1.1242 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0048 | Loss 1.1364 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0048 | Loss 1.1331 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0048 | Loss 1.1060 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0048 | Loss 1.0963 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0048 | Loss 1.0540 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0048 | Loss 1.0772 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0048 | Loss 1.0426 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0048 | Loss 0.9903 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0048 | Loss 1.0033 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0048 | Loss 1.0366 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0048 | Loss 0.9515 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0048 | Loss 0.9695 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0048 | Loss 1.0019 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0048 | Loss 0.9348 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0048 | Loss 0.9875 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0048 | Loss 0.9347 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0048 | Loss 0.9382 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0048 | Loss 0.9138 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0048 | Loss 0.9225 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0048 | Loss 0.9318 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0048 | Loss 0.9282 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0048 | Loss 0.8740 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0048 | Loss 0.8499 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0048 | Loss 0.8592 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0048 | Loss 0.8616 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0048 | Loss 0.8051 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0048 | Loss 0.8827 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0048 | Loss 0.7602 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0048 | Loss 0.8585 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0048 | Loss 0.8080 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0048 | Loss 0.8495 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0048 | Loss 0.8145 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0048 | Loss 0.7703 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0048 | Loss 0.7469 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0048 | Loss 0.7912 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0048 | Loss 0.7935 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0048 | Loss 0.7687 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0048 | Loss 0.7556 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0047 | Loss 0.7131 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00098 | Time(s) 0.0047 | Loss 0.7525 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00099 | Time(s) 0.0047 | Loss 0.7151 | Accuracy 0.6960 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00100 | Time(s) 0.0048 | Loss 0.7592 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00101 | Time(s) 0.0047 | Loss 0.7426 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0048 | Loss 0.7128 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00103 | Time(s) 0.0048 | Loss 0.7325 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00104 | Time(s) 0.0048 | Loss 0.7335 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0048 | Loss 0.7053 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0048 | Loss 0.7091 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0048 | Loss 0.6568 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0048 | Loss 0.6996 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0047 | Loss 0.6775 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0047 | Loss 0.6358 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0047 | Loss 0.7202 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0047 | Loss 0.6635 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0047 | Loss 0.6167 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0047 | Loss 0.6152 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0047 | Loss 0.6499 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0047 | Loss 0.6207 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0047 | Loss 0.6311 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0047 | Loss 0.6557 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0047 | Loss 0.6522 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0047 | Loss 0.6275 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0047 | Loss 0.6547 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0047 | Loss 0.6373 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0047 | Loss 0.6123 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0047 | Loss 0.6460 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0047 | Loss 0.5985 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0047 | Loss 0.5812 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0047 | Loss 0.6106 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0047 | Loss 0.6199 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0048 | Loss 0.5452 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0047 | Loss 0.5872 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0047 | Loss 0.5739 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0047 | Loss 0.5541 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0047 | Loss 0.6325 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0047 | Loss 0.5931 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0047 | Loss 0.5879 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0047 | Loss 0.5882 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0047 | Loss 0.5715 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0047 | Loss 0.5241 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0047 | Loss 0.5613 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0047 | Loss 0.5628 | Accuracy 0.6880 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0047 | Loss 0.5380 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0047 | Loss 0.5164 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0047 | Loss 0.5587 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0047 | Loss 0.5455 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0047 | Loss 0.5714 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0047 | Loss 0.5568 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0047 | Loss 0.5886 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0047 | Loss 0.5569 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0047 | Loss 0.5587 | Accuracy 0.6900 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0047 | Loss 0.5216 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0047 | Loss 0.5357 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0047 | Loss 0.4972 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0047 | Loss 0.5358 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0047 | Loss 0.5440 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0047 | Loss 0.5779 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0047 | Loss 0.5237 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0047 | Loss 0.4903 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0047 | Loss 0.5132 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0047 | Loss 0.5270 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0047 | Loss 0.4919 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0047 | Loss 0.4910 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0047 | Loss 0.5208 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0047 | Loss 0.5351 | Accuracy 0.6920 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0047 | Loss 0.5297 | Accuracy 0.6940 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0047 | Loss 0.5010 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0047 | Loss 0.5363 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0047 | Loss 0.5386 | Accuracy 0.6980 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0047 | Loss 0.5237 | Accuracy 0.7000 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0047 | Loss 0.4938 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0047 | Loss 0.4940 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0047 | Loss 0.4601 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0047 | Loss 0.5037 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0047 | Loss 0.5174 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0047 | Loss 0.5168 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0047 | Loss 0.4733 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0047 | Loss 0.5062 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0047 | Loss 0.5264 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0047 | Loss 0.4711 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0047 | Loss 0.4702 | Accuracy 0.7120 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0047 | Loss 0.4775 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0047 | Loss 0.4783 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0047 | Loss 0.4743 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0047 | Loss 0.5033 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0047 | Loss 0.4758 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0047 | Loss 0.4643 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0047 | Loss 0.4760 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0047 | Loss 0.4686 | Accuracy 0.7040 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0047 | Loss 0.4848 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0047 | Loss 0.4316 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0047 | Loss 0.4411 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0047 | Loss 0.4669 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0047 | Loss 0.4801 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0047 | Loss 0.4349 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0047 | Loss 0.4810 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0047 | Loss 0.4588 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00196 | Time(s) 0.0047 | Loss 0.4600 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0047 | Loss 0.4664 | Accuracy 0.7080 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0047 | Loss 0.4722 | Accuracy 0.7100 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0047 | Loss 0.4499 | Accuracy 0.7100 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 71.20%\n",
      "Epoch 00000 | Time(s) nan | Loss 1.9460 | Accuracy 0.3820 | number of edges 13264.00\n",
      "Epoch 00001 | Time(s) nan | Loss 1.9389 | Accuracy 0.2400 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00002 | Time(s) nan | Loss 1.9317 | Accuracy 0.2540 | number of edges 13264.00\n",
      "Epoch 00003 | Time(s) 0.0050 | Loss 1.9236 | Accuracy 0.3360 | number of edges 13264.00\n",
      "Epoch 00004 | Time(s) 0.0053 | Loss 1.9144 | Accuracy 0.4120 | number of edges 13264.00\n",
      "Epoch 00005 | Time(s) 0.0053 | Loss 1.9049 | Accuracy 0.4700 | number of edges 13264.00\n",
      "Epoch 00006 | Time(s) 0.0051 | Loss 1.8948 | Accuracy 0.5240 | number of edges 13264.00\n",
      "Epoch 00007 | Time(s) 0.0051 | Loss 1.8836 | Accuracy 0.6020 | number of edges 13264.00\n",
      "Epoch 00008 | Time(s) 0.0050 | Loss 1.8716 | Accuracy 0.6380 | number of edges 13264.00\n",
      "Epoch 00009 | Time(s) 0.0049 | Loss 1.8593 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00010 | Time(s) 0.0049 | Loss 1.8467 | Accuracy 0.6400 | number of edges 13264.00\n",
      "Epoch 00011 | Time(s) 0.0050 | Loss 1.8335 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00012 | Time(s) 0.0049 | Loss 1.8197 | Accuracy 0.6540 | number of edges 13264.00\n",
      "Epoch 00013 | Time(s) 0.0050 | Loss 1.8054 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00014 | Time(s) 0.0049 | Loss 1.7905 | Accuracy 0.6500 | number of edges 13264.00\n",
      "Epoch 00015 | Time(s) 0.0050 | Loss 1.7752 | Accuracy 0.6520 | number of edges 13264.00\n",
      "Epoch 00016 | Time(s) 0.0050 | Loss 1.7593 | Accuracy 0.6580 | number of edges 13264.00\n",
      "Epoch 00017 | Time(s) 0.0049 | Loss 1.7427 | Accuracy 0.6760 | number of edges 13264.00\n",
      "Epoch 00018 | Time(s) 0.0049 | Loss 1.7256 | Accuracy 0.6960 | number of edges 13264.00\n",
      "Epoch 00019 | Time(s) 0.0049 | Loss 1.7080 | Accuracy 0.7020 | number of edges 13264.00\n",
      "Epoch 00020 | Time(s) 0.0049 | Loss 1.6899 | Accuracy 0.7060 | number of edges 13264.00\n",
      "Epoch 00021 | Time(s) 0.0049 | Loss 1.6712 | Accuracy 0.7200 | number of edges 13264.00\n",
      "Epoch 00022 | Time(s) 0.0049 | Loss 1.6521 | Accuracy 0.7300 | number of edges 13264.00\n",
      "Epoch 00023 | Time(s) 0.0049 | Loss 1.6324 | Accuracy 0.7340 | number of edges 13264.00\n",
      "Epoch 00024 | Time(s) 0.0049 | Loss 1.6122 | Accuracy 0.7420 | number of edges 13264.00\n",
      "Epoch 00025 | Time(s) 0.0049 | Loss 1.5916 | Accuracy 0.7460 | number of edges 13264.00\n",
      "Epoch 00026 | Time(s) 0.0049 | Loss 1.5704 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00027 | Time(s) 0.0049 | Loss 1.5487 | Accuracy 0.7500 | number of edges 13264.00\n",
      "Epoch 00028 | Time(s) 0.0049 | Loss 1.5266 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00029 | Time(s) 0.0049 | Loss 1.5041 | Accuracy 0.7520 | number of edges 13264.00\n",
      "Epoch 00030 | Time(s) 0.0049 | Loss 1.4813 | Accuracy 0.7560 | number of edges 13264.00\n",
      "Epoch 00031 | Time(s) 0.0049 | Loss 1.4580 | Accuracy 0.7600 | number of edges 13264.00\n",
      "Epoch 00032 | Time(s) 0.0049 | Loss 1.4344 | Accuracy 0.7660 | number of edges 13264.00\n",
      "Epoch 00033 | Time(s) 0.0049 | Loss 1.4104 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00034 | Time(s) 0.0049 | Loss 1.3863 | Accuracy 0.7680 | number of edges 13264.00\n",
      "Epoch 00035 | Time(s) 0.0049 | Loss 1.3618 | Accuracy 0.7720 | number of edges 13264.00\n",
      "Epoch 00036 | Time(s) 0.0049 | Loss 1.3372 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00037 | Time(s) 0.0049 | Loss 1.3125 | Accuracy 0.7740 | number of edges 13264.00\n",
      "Epoch 00038 | Time(s) 0.0049 | Loss 1.2877 | Accuracy 0.7780 | number of edges 13264.00\n",
      "Epoch 00039 | Time(s) 0.0049 | Loss 1.2628 | Accuracy 0.7800 | number of edges 13264.00\n",
      "Epoch 00040 | Time(s) 0.0049 | Loss 1.2380 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00041 | Time(s) 0.0049 | Loss 1.2132 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00042 | Time(s) 0.0049 | Loss 1.1885 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00043 | Time(s) 0.0049 | Loss 1.1639 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00044 | Time(s) 0.0049 | Loss 1.1394 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00045 | Time(s) 0.0049 | Loss 1.1152 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00046 | Time(s) 0.0049 | Loss 1.0912 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00047 | Time(s) 0.0049 | Loss 1.0674 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00048 | Time(s) 0.0048 | Loss 1.0439 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00049 | Time(s) 0.0048 | Loss 1.0207 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00050 | Time(s) 0.0048 | Loss 0.9979 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00051 | Time(s) 0.0048 | Loss 0.9755 | Accuracy 0.7820 | number of edges 13264.00\n",
      "Epoch 00052 | Time(s) 0.0048 | Loss 0.9535 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00053 | Time(s) 0.0048 | Loss 0.9319 | Accuracy 0.7840 | number of edges 13264.00\n",
      "Epoch 00054 | Time(s) 0.0048 | Loss 0.9108 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00055 | Time(s) 0.0048 | Loss 0.8901 | Accuracy 0.7860 | number of edges 13264.00\n",
      "Epoch 00056 | Time(s) 0.0048 | Loss 0.8699 | Accuracy 0.7880 | number of edges 13264.00\n",
      "Epoch 00057 | Time(s) 0.0048 | Loss 0.8501 | Accuracy 0.7920 | number of edges 13264.00\n",
      "Epoch 00058 | Time(s) 0.0048 | Loss 0.8309 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00059 | Time(s) 0.0048 | Loss 0.8122 | Accuracy 0.7940 | number of edges 13264.00\n",
      "Epoch 00060 | Time(s) 0.0048 | Loss 0.7940 | Accuracy 0.7960 | number of edges 13264.00\n",
      "Epoch 00061 | Time(s) 0.0048 | Loss 0.7763 | Accuracy 0.7980 | number of edges 13264.00\n",
      "Epoch 00062 | Time(s) 0.0048 | Loss 0.7591 | Accuracy 0.8020 | number of edges 13264.00\n",
      "Epoch 00063 | Time(s) 0.0048 | Loss 0.7425 | Accuracy 0.8040 | number of edges 13264.00\n",
      "Epoch 00064 | Time(s) 0.0048 | Loss 0.7264 | Accuracy 0.8080 | number of edges 13264.00\n",
      "Epoch 00065 | Time(s) 0.0048 | Loss 0.7108 | Accuracy 0.8100 | number of edges 13264.00\n",
      "Epoch 00066 | Time(s) 0.0048 | Loss 0.6957 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00067 | Time(s) 0.0048 | Loss 0.6812 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00068 | Time(s) 0.0048 | Loss 0.6671 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00069 | Time(s) 0.0048 | Loss 0.6535 | Accuracy 0.8120 | number of edges 13264.00\n",
      "Epoch 00070 | Time(s) 0.0048 | Loss 0.6404 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00071 | Time(s) 0.0048 | Loss 0.6278 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00072 | Time(s) 0.0048 | Loss 0.6156 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00073 | Time(s) 0.0048 | Loss 0.6038 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00074 | Time(s) 0.0048 | Loss 0.5924 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00075 | Time(s) 0.0048 | Loss 0.5815 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00076 | Time(s) 0.0048 | Loss 0.5710 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00077 | Time(s) 0.0048 | Loss 0.5608 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00078 | Time(s) 0.0048 | Loss 0.5510 | Accuracy 0.8140 | number of edges 13264.00\n",
      "Epoch 00079 | Time(s) 0.0048 | Loss 0.5416 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00080 | Time(s) 0.0048 | Loss 0.5325 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00081 | Time(s) 0.0048 | Loss 0.5237 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00082 | Time(s) 0.0048 | Loss 0.5153 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00083 | Time(s) 0.0048 | Loss 0.5072 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00084 | Time(s) 0.0048 | Loss 0.4993 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00085 | Time(s) 0.0048 | Loss 0.4917 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00086 | Time(s) 0.0048 | Loss 0.4844 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00087 | Time(s) 0.0048 | Loss 0.4773 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00088 | Time(s) 0.0048 | Loss 0.4705 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00089 | Time(s) 0.0048 | Loss 0.4639 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00090 | Time(s) 0.0048 | Loss 0.4575 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00091 | Time(s) 0.0048 | Loss 0.4513 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00092 | Time(s) 0.0048 | Loss 0.4453 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00093 | Time(s) 0.0048 | Loss 0.4395 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00094 | Time(s) 0.0048 | Loss 0.4339 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00095 | Time(s) 0.0048 | Loss 0.4284 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00096 | Time(s) 0.0047 | Loss 0.4231 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00097 | Time(s) 0.0048 | Loss 0.4180 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00098 | Time(s) 0.0047 | Loss 0.4130 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00099 | Time(s) 0.0047 | Loss 0.4081 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00100 | Time(s) 0.0047 | Loss 0.4034 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00101 | Time(s) 0.0047 | Loss 0.3989 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00102 | Time(s) 0.0047 | Loss 0.3944 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00103 | Time(s) 0.0047 | Loss 0.3901 | Accuracy 0.8220 | number of edges 13264.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00104 | Time(s) 0.0047 | Loss 0.3859 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00105 | Time(s) 0.0047 | Loss 0.3818 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00106 | Time(s) 0.0047 | Loss 0.3778 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00107 | Time(s) 0.0047 | Loss 0.3739 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00108 | Time(s) 0.0047 | Loss 0.3701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00109 | Time(s) 0.0047 | Loss 0.3664 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00110 | Time(s) 0.0047 | Loss 0.3628 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00111 | Time(s) 0.0047 | Loss 0.3593 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00112 | Time(s) 0.0047 | Loss 0.3559 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00113 | Time(s) 0.0047 | Loss 0.3525 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00114 | Time(s) 0.0047 | Loss 0.3493 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00115 | Time(s) 0.0047 | Loss 0.3461 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00116 | Time(s) 0.0047 | Loss 0.3430 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00117 | Time(s) 0.0047 | Loss 0.3399 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00118 | Time(s) 0.0047 | Loss 0.3369 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00119 | Time(s) 0.0047 | Loss 0.3340 | Accuracy 0.8240 | number of edges 13264.00\n",
      "Epoch 00120 | Time(s) 0.0047 | Loss 0.3311 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00121 | Time(s) 0.0047 | Loss 0.3283 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00122 | Time(s) 0.0047 | Loss 0.3256 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00123 | Time(s) 0.0047 | Loss 0.3229 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00124 | Time(s) 0.0047 | Loss 0.3203 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00125 | Time(s) 0.0047 | Loss 0.3177 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00126 | Time(s) 0.0047 | Loss 0.3152 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00127 | Time(s) 0.0047 | Loss 0.3127 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00128 | Time(s) 0.0047 | Loss 0.3103 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00129 | Time(s) 0.0047 | Loss 0.3079 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00130 | Time(s) 0.0047 | Loss 0.3056 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00131 | Time(s) 0.0047 | Loss 0.3033 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00132 | Time(s) 0.0047 | Loss 0.3010 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00133 | Time(s) 0.0047 | Loss 0.2988 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00134 | Time(s) 0.0047 | Loss 0.2967 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00135 | Time(s) 0.0047 | Loss 0.2945 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00136 | Time(s) 0.0047 | Loss 0.2925 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00137 | Time(s) 0.0047 | Loss 0.2904 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00138 | Time(s) 0.0047 | Loss 0.2884 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00139 | Time(s) 0.0047 | Loss 0.2864 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00140 | Time(s) 0.0047 | Loss 0.2845 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00141 | Time(s) 0.0047 | Loss 0.2826 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00142 | Time(s) 0.0047 | Loss 0.2807 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00143 | Time(s) 0.0047 | Loss 0.2789 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00144 | Time(s) 0.0047 | Loss 0.2771 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00145 | Time(s) 0.0047 | Loss 0.2753 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00146 | Time(s) 0.0047 | Loss 0.2735 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00147 | Time(s) 0.0047 | Loss 0.2718 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00148 | Time(s) 0.0047 | Loss 0.2701 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00149 | Time(s) 0.0047 | Loss 0.2684 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00150 | Time(s) 0.0047 | Loss 0.2668 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00151 | Time(s) 0.0047 | Loss 0.2652 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00152 | Time(s) 0.0047 | Loss 0.2636 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00153 | Time(s) 0.0047 | Loss 0.2620 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00154 | Time(s) 0.0047 | Loss 0.2605 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00155 | Time(s) 0.0047 | Loss 0.2590 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00156 | Time(s) 0.0047 | Loss 0.2575 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00157 | Time(s) 0.0047 | Loss 0.2560 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00158 | Time(s) 0.0047 | Loss 0.2546 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00159 | Time(s) 0.0047 | Loss 0.2531 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00160 | Time(s) 0.0047 | Loss 0.2517 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00161 | Time(s) 0.0047 | Loss 0.2503 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00162 | Time(s) 0.0047 | Loss 0.2490 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00163 | Time(s) 0.0047 | Loss 0.2476 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00164 | Time(s) 0.0047 | Loss 0.2463 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00165 | Time(s) 0.0047 | Loss 0.2450 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00166 | Time(s) 0.0047 | Loss 0.2437 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00167 | Time(s) 0.0047 | Loss 0.2425 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00168 | Time(s) 0.0047 | Loss 0.2412 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00169 | Time(s) 0.0047 | Loss 0.2400 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00170 | Time(s) 0.0047 | Loss 0.2387 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00171 | Time(s) 0.0047 | Loss 0.2375 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00172 | Time(s) 0.0047 | Loss 0.2364 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00173 | Time(s) 0.0047 | Loss 0.2352 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00174 | Time(s) 0.0047 | Loss 0.2341 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00175 | Time(s) 0.0047 | Loss 0.2329 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00176 | Time(s) 0.0047 | Loss 0.2318 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00177 | Time(s) 0.0047 | Loss 0.2307 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00178 | Time(s) 0.0047 | Loss 0.2296 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00179 | Time(s) 0.0047 | Loss 0.2285 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00180 | Time(s) 0.0047 | Loss 0.2275 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00181 | Time(s) 0.0046 | Loss 0.2264 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00182 | Time(s) 0.0046 | Loss 0.2254 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00183 | Time(s) 0.0047 | Loss 0.2244 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00184 | Time(s) 0.0047 | Loss 0.2234 | Accuracy 0.8220 | number of edges 13264.00\n",
      "Epoch 00185 | Time(s) 0.0046 | Loss 0.2224 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00186 | Time(s) 0.0046 | Loss 0.2214 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00187 | Time(s) 0.0047 | Loss 0.2204 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00188 | Time(s) 0.0046 | Loss 0.2194 | Accuracy 0.8200 | number of edges 13264.00\n",
      "Epoch 00189 | Time(s) 0.0046 | Loss 0.2185 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00190 | Time(s) 0.0046 | Loss 0.2176 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00191 | Time(s) 0.0046 | Loss 0.2166 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00192 | Time(s) 0.0046 | Loss 0.2157 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00193 | Time(s) 0.0046 | Loss 0.2148 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00194 | Time(s) 0.0046 | Loss 0.2139 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00195 | Time(s) 0.0046 | Loss 0.2131 | Accuracy 0.8180 | number of edges 13264.00\n",
      "Epoch 00196 | Time(s) 0.0046 | Loss 0.2122 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00197 | Time(s) 0.0046 | Loss 0.2113 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00198 | Time(s) 0.0046 | Loss 0.2105 | Accuracy 0.8160 | number of edges 13264.00\n",
      "Epoch 00199 | Time(s) 0.0046 | Loss 0.2096 | Accuracy 0.8180 | number of edges 13264.00\n",
      "\n",
      "Test accuracy 80.90%\n"
     ]
    }
   ],
   "source": [
    "dataname = 'cora'\n",
    "l2_regularlization_term = 0.01\n",
    "num_layer = 2\n",
    "\n",
    "# dataname = 'pubmed'\n",
    "# l2_regularlization_term = 0.004\n",
    "# num_layer = 2\n",
    "\n",
    "# dataname = 'citeseer'\n",
    "# l2_regularlization_term = 0.003\n",
    "# num_layer = 2\n",
    "\n",
    "\n",
    "perturb_ratio_list = [0.1, 0.15, 0.2]\n",
    "# some_seed_list = [1, 11, 15, 42, 100]\n",
    "some_seed_list = [15]\n",
    "num_times_running = 1\n",
    "\n",
    "for perturb_ratio in perturb_ratio_list:\n",
    "    temp_acc_flip_list = []\n",
    "    temp_acc_no_flip_list = []\n",
    "    for s in some_seed_list:\n",
    "        \n",
    "        for _ in range(num_times_running):\n",
    "            acc_flip, acc_no_flip, p_comb = node_flipping_attack_rev(dataname = dataname, l2_regularlization_term = l2_regularlization_term, \n",
    "                                                             perturb_ratio = perturb_ratio, num_layer = num_layer, \n",
    "                                                             some_seed = s)\n",
    "\n",
    "            temp_acc_flip_list.append(acc_flip)\n",
    "            temp_acc_no_flip_list.append(acc_no_flip)\n",
    "    \n",
    "    flip_df = pd.DataFrame([temp_acc_flip_list, temp_acc_no_flip_list]).T\n",
    "    flip_df.columns = ['filped accuracy', 'original accuracy']\n",
    "    flip_df.to_csv('result_flip_attack/'+ dataname + '/'+ 'new_perturb_ratio_' + str(perturb_ratio)+'.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4f23fe03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 4.20899065,  5.07756198,  2.45574764,  7.86979518,  4.27951433,\n",
       "        2.70956831,  2.49475571,  6.9646085 , 10.53136653, 10.6841704 ,\n",
       "        8.77212056, 12.49917943,  2.46027833,  8.31714146,  6.36620909,\n",
       "        4.3311958 ,  5.71953997,  8.02817157, 10.47147914, 10.82608802,\n",
       "        1.60416056,  0.84538108,  0.89429613,  0.22458214,  0.98612881,\n",
       "        0.9406435 ,  1.25640607, -2.09369098,  3.54836787,  0.57469911,\n",
       "        0.62760354,  1.19025312,  2.42907601,  3.84717   , -0.04640378,\n",
       "        3.15590686,  0.8684864 ,  4.7664334 , -0.48794365,  1.33010092])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_comb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "39d4c0cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The mean acc. of flipped acc at ratio 0.05 is: 0.625\n",
      "The mean acc. of origin is: 0.8001999999999999\n",
      "The mean acc. of flipped acc at ratio 0.1 is: 0.578\n",
      "The mean acc. of origin is: 0.8001999999999999\n",
      "The mean acc. of flipped acc at ratio 0.15 is: 0.5678\n",
      "The mean acc. of origin is: 0.8001999999999999\n",
      "The mean acc. of flipped acc at ratio 0.20 is: 0.5257999999999999\n",
      "The mean acc. of origin is: 0.8001999999999999\n"
     ]
    }
   ],
   "source": [
    "df_cora_acc_005 = pd.read_csv('result_flip_attack/cora/perturb_ratio_0.05.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.05 is:', np.mean(df_cora_acc_005['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_005['original accuracy'].values))\n",
    "\n",
    "df_cora_acc_010 = pd.read_csv('result_flip_attack/cora/perturb_ratio_0.1.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.1 is:', np.mean(df_cora_acc_010['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_010['original accuracy'].values))\n",
    "\n",
    "df_cora_acc_015 = pd.read_csv('result_flip_attack/cora/perturb_ratio_0.15.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.15 is:', np.mean(df_cora_acc_015['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_015['original accuracy'].values))\n",
    "\n",
    "df_cora_acc_020 = pd.read_csv('result_flip_attack/cora/perturb_ratio_0.2.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.20 is:', np.mean(df_cora_acc_020['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_020['original accuracy'].values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "33f9c411",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The mean acc. of flipped acc at ratio 0.1 is: 0.753\n",
      "The mean acc. of origin is: 0.809\n",
      "The mean acc. of flipped acc at ratio 0.15 is: 0.735\n",
      "The mean acc. of origin is: 0.809\n",
      "The mean acc. of flipped acc at ratio 0.20 is: 0.712\n",
      "The mean acc. of origin is: 0.809\n"
     ]
    }
   ],
   "source": [
    "df_cora_acc_010 = pd.read_csv('result_flip_attack/cora/new_perturb_ratio_0.1.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.1 is:', np.mean(df_cora_acc_010['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_010['original accuracy'].values))\n",
    "\n",
    "df_cora_acc_015 = pd.read_csv('result_flip_attack/cora/new_perturb_ratio_0.15.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.15 is:', np.mean(df_cora_acc_015['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_015['original accuracy'].values))\n",
    "\n",
    "df_cora_acc_020 = pd.read_csv('result_flip_attack/cora/new_perturb_ratio_0.2.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.20 is:', np.mean(df_cora_acc_020['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_cora_acc_020['original accuracy'].values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "35ba5851",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The mean acc. of flipped acc at ratio 0.05 is: 0.676\n",
      "The mean acc. of origin is: 0.7768\n",
      "The mean acc. of flipped acc at ratio 0.1 is: 0.617\n",
      "The mean acc. of origin is: 0.7768\n",
      "The mean acc. of flipped acc at ratio 0.15 is: 0.5592\n",
      "The mean acc. of origin is: 0.7768\n",
      "The mean acc. of flipped acc at ratio 0.20 is: 0.5110000000000001\n",
      "The mean acc. of origin is: 0.7768\n"
     ]
    }
   ],
   "source": [
    "df_pubmed_acc_005 = pd.read_csv('result_flip_attack/pubmed/perturb_ratio_0.05.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.05 is:', np.mean(df_pubmed_acc_005['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_pubmed_acc_005['original accuracy'].values))\n",
    "\n",
    "df_pubmed_acc_010 = pd.read_csv('result_flip_attack/pubmed/perturb_ratio_0.1.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.1 is:', np.mean(df_pubmed_acc_010['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_pubmed_acc_010['original accuracy'].values))\n",
    "\n",
    "df_pubmed_acc_015 = pd.read_csv('result_flip_attack/pubmed/perturb_ratio_0.15.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.15 is:', np.mean(df_pubmed_acc_015['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_pubmed_acc_015['original accuracy'].values))\n",
    "\n",
    "df_pubmed_acc_020 = pd.read_csv('result_flip_attack/pubmed/perturb_ratio_0.2.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.20 is:', np.mean(df_pubmed_acc_020['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_pubmed_acc_020['original accuracy'].values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "44859062",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The mean acc. of flipped acc at ratio 0.05 is: 0.5781999999999999\n",
      "The mean acc. of origin is: 0.662\n",
      "The mean acc. of flipped acc at ratio 0.1 is: 0.5218\n",
      "The mean acc. of origin is: 0.662\n",
      "The mean acc. of flipped acc at ratio 0.15 is: 0.4704\n",
      "The mean acc. of origin is: 0.662\n",
      "The mean acc. of flipped acc at ratio 0.20 is: 0.4464\n",
      "The mean acc. of origin is: 0.662\n"
     ]
    }
   ],
   "source": [
    "df_citeseer_acc_005 = pd.read_csv('result_flip_attack/citeseer/perturb_ratio_0.05.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.05 is:', np.mean(df_citeseer_acc_005['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_citeseer_acc_005['original accuracy'].values))\n",
    "\n",
    "df_citeseer_acc_010 = pd.read_csv('result_flip_attack/citeseer/perturb_ratio_0.1.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.1 is:', np.mean(df_citeseer_acc_010['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_citeseer_acc_010['original accuracy'].values))\n",
    "\n",
    "df_citeseer_acc_015 = pd.read_csv('result_flip_attack/citeseer/perturb_ratio_0.15.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.15 is:', np.mean(df_citeseer_acc_015['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_citeseer_acc_015['original accuracy'].values))\n",
    "\n",
    "df_citeseer_acc_020 = pd.read_csv('result_flip_attack/citeseer/perturb_ratio_0.2.csv')\n",
    "print('The mean acc. of flipped acc at ratio 0.20 is:', np.mean(df_citeseer_acc_020['filped accuracy'].values))\n",
    "print('The mean acc. of origin is:', np.mean(df_citeseer_acc_020['original accuracy'].values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "d805a9d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "# graph, feat, labels, _, _, _, number_classes = load_graph_dataset(dataname)\n",
    "# train_mask, val_mask, test_mask = random_splits_label_flip_attack(graph, labels, number_classes)\n",
    "\n",
    "# lr = SimplifiedGraphNeuralNetwork(l2_reg=l2_regularlization_term, fit_intercept=True)\n",
    "\n",
    "# feat0 = feat.clone()\n",
    "# degs = graph.in_degrees().float().clamp(min = 1)\n",
    "# norm = torch.pow(degs, -0.5)\n",
    "# norm = norm.to(feat0.device).unsqueeze(1)\n",
    "\n",
    "# for _ in range(2):\n",
    "#     feat0 = feat0 * norm\n",
    "#     graph.ndata['h'] = feat0\n",
    "#     graph.update_all(fn.copy_u('h', 'm'),\n",
    "#                      fn.sum('m', 'h'))\n",
    "#     feat0 = graph.ndata.pop('h')\n",
    "#     feat0 = feat0 * norm\n",
    "    \n",
    "# train_x = feat0[train_mask].numpy().astype(np.float32)\n",
    "# train_y = labels[train_mask].numpy().astype(np.float32)\n",
    "\n",
    "# test_x = feat0[test_mask].numpy().astype(np.float32)\n",
    "# test_y = labels[test_mask].numpy().astype(np.float32)\n",
    "\n",
    "# enc = OneHotEncoder(handle_unknown='ignore')\n",
    "# enc.fit(train_y.reshape(-1, 1))\n",
    "\n",
    "# one_hot_labels_train = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "# one_hot_labels_test = enc.transform(test_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "# \"\"\" Train Logistic Regression \"\"\"\n",
    "# lr = SimplifiedGraphNeuralNetwork(l2_reg = l2_regularlization_term, fit_intercept=True)\n",
    "# lr.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "# logits_test_y = test_x @ lr.model.coef_.T + lr.model.intercept_\n",
    "# logits_train_y = train_x @ lr.model.coef_.T + lr.model.intercept_\n",
    "\n",
    "# ori_val_loss, ave_ori_val_loss = lr.log_loss(logits_test_y, one_hot_labels_test, l2_reg = True)\n",
    "\n",
    "# numpy_theoritic_loss = log_loss(test_y, softmax(logits_test_y, axis=1))\n",
    "\n",
    "# train_total_grad, train_indiv_grad = lr.grad(train_x, logits_train_y, \n",
    "#                                              one_hot_labels_train, l2_reg=True)\n",
    "# val_loss_total_grad, val_loss_indiv_grad = lr.grad(test_x, logits_test_y, \n",
    "#                                                    one_hot_labels_test, l2_reg=True)\n",
    "\n",
    "# # hessian_no_reg, hess, hessian_reg_term = lr.hess(train_x, logits_train_y)\n",
    "# # hess = fast_hess_cuda(train_x, logits_train_y)\n",
    "# hess = lr.hess_cuda(train_x, logits_train_y)\n",
    "\n",
    "\n",
    "# loss_grad_hvp = fast_get_inv_hvp_cuda(hess, val_loss_total_grad.T, cholskey=True)\n",
    "# # loss_grad_hvp = fast_get_inv_hvp_cuda(hess, val_loss_total_grad.T, cholskey=False)\n",
    "# loss_grad_hvp = cp.asnumpy(loss_grad_hvp)\n",
    "\n",
    "# pred_infl = train_indiv_grad.dot(loss_grad_hvp)\n",
    "\n",
    "# pred_infl = list(pred_infl.reshape(-1))\n",
    "# #\n",
    "# num_train = len(train_x)\n",
    "# act_infl = []\n",
    "\n",
    "# for i in tqdm(range(num_train)):\n",
    "#     lr_new = SimplifiedGraphNeuralNetwork(l2_reg=l2_regularlization_term, fit_intercept=True)\n",
    "#     train_x_new = np.delete(train_x, i, axis = 0)\n",
    "#     train_y_new = np.delete(train_y, i)\n",
    "#     lr_new.fit(train_x_new, train_y_new)\n",
    "    \n",
    "#     logits_test_y_new = test_x @ lr_new.model.coef_.T + lr_new.model.intercept_\n",
    "    \n",
    "    \n",
    "#     new_ori_val_loss, new_ave_ori_val_loss = lr_new.log_loss(logits_test_y_new, one_hot_labels_test, l2_reg = True)\n",
    "#     act_infl.append(new_ori_val_loss - ori_val_loss)\n",
    "    \n",
    "    \n",
    "# df = pd.DataFrame([pred_infl, act_infl]).T\n",
    "# df.columns = ['predicted influence', 'actual influence']\n",
    "# predicted_influence = np.array(pred_infl)\n",
    "\n",
    "# a, b = get_first_two_frequent(labels)\n",
    "# idx1 = np.where(labels[train_mask].numpy() == a)[0]\n",
    "# idx2 = np.where(labels[train_mask].numpy() == b)[0]\n",
    "\n",
    "\n",
    "\n",
    "# num_train = np.sum(train_mask.numpy() == 1)\n",
    "# num_perturb = int(perturb_ratio * num_train)\n",
    "# predicted_influence_combined = np.concatenate([predicted_influence[idx1], predicted_influence[idx2]])\n",
    "# predicted_influence_combined_sorted = np.sort(predicted_influence_combined)[::-1]\n",
    "# threshold = predicted_influence_combined_sorted[num_perturb]\n",
    "\n",
    "# perturbed_train_y = train_y.copy()\n",
    "# new_labels_a = np.repeat(a, len(idx1))\n",
    "# new_labels_b = np.repeat(b, len(idx2))\n",
    "# assert(len(idx1) == len(idx2))\n",
    "\n",
    "# predicted_influence_combined_sorted\n",
    "\n",
    "# idx_a_to_b = np.where(predicted_influence[idx1] > threshold)[0]\n",
    "# idx_b_to_a = np.where(predicted_influence[idx2] > threshold)[0]\n",
    "\n",
    "# new_labels_a[idx_a_to_b] = b\n",
    "# new_labels_b[idx_b_to_a] = a\n",
    "\n",
    "# perturbed_train_y[idx1] = new_labels_a\n",
    "# perturbed_train_y[idx2] = new_labels_b\n",
    "\n",
    "# new_labels = labels.numpy().copy()\n",
    "# new_labels[train_mask] = perturbed_train_y\n",
    "# new_labels = torch.tensor(new_labels)\n",
    "\n",
    "# gcn_with_node_flip = gcn_with_node_flipping(graph= graph, features=feat, new_labels=new_labels, \n",
    "#                                             train_mask=train_mask, val_mask=val_mask, test_mask=test_mask,\n",
    "#                                            num_classes=number_classes)\n",
    "\n",
    "# gcn_without_node_flip = gcn_with_node_flipping(graph= graph, features=feat, new_labels=labels, \n",
    "#                                             train_mask=train_mask, val_mask=val_mask, test_mask=test_mask,\n",
    "#                                            num_classes=number_classes)\n",
    "\n",
    "# acc_flip = gcn_with_node_flip.train_evaluate()\n",
    "# acc_no_flip = gcn_without_node_flip.train_evaluate()\n",
    "\n",
    "# temp_acc_flip_list.append(acc_flip)\n",
    "# temp_acc_no_flip_list.append(acc_no_flip)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b2c9b10a",
   "metadata": {},
   "outputs": [],
   "source": [
    "temp_acc_flip_list = []\n",
    "temp_acc_no_flip_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82667165",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0047def6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7623fbd2",
   "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
}
