{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import networkx as nx\n",
    "from tqdm import tqdm\n",
    "import json\n",
    "import sys\n",
    "import torch.nn as nn\n",
    "import pandas as pd \n",
    "\n",
    "current_dir = '/gpfs/commons/home/zlin/knowles_lab/zlin/PerturbODE/src/neural_ode'\n",
    "sys.path.append(current_dir)\n",
    "\n",
    "import os\n",
    "from sklearn.metrics import auc, precision_recall_curve\n",
    "from sklearn.metrics import precision_recall_curve, average_precision_score\n",
    "\n",
    "\n",
    "\n",
    "root_dir = '/gpfs/commons/home/zlin/knowles_lab/zlin/PerturbODE/src/neural_ode/models_and_logs/SDEs/SDE'\n",
    "scale = True\n",
    "random_dags = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Gene2</th>\n",
       "      <th>Gene1</th>\n",
       "      <th>Type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>g7</td>\n",
       "      <td>g6</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>g14</td>\n",
       "      <td>g13</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>g5</td>\n",
       "      <td>g4</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>g8</td>\n",
       "      <td>g7</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>g18</td>\n",
       "      <td>g17</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>g18</td>\n",
       "      <td>g18</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>g17</td>\n",
       "      <td>g16</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>g16</td>\n",
       "      <td>g15</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>g2</td>\n",
       "      <td>g1</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>g12</td>\n",
       "      <td>g11</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>g1</td>\n",
       "      <td>g18</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>g15</td>\n",
       "      <td>g14</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>g3</td>\n",
       "      <td>g2</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>g6</td>\n",
       "      <td>g5</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>g4</td>\n",
       "      <td>g3</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>g11</td>\n",
       "      <td>g10</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>g9</td>\n",
       "      <td>g8</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>g13</td>\n",
       "      <td>g12</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>g10</td>\n",
       "      <td>g9</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Gene2 Gene1 Type\n",
       "0     g7    g6    +\n",
       "1    g14   g13    +\n",
       "2     g5    g4    +\n",
       "3     g8    g7    +\n",
       "4    g18   g17    +\n",
       "5    g18   g18    +\n",
       "6    g17   g16    +\n",
       "7    g16   g15    +\n",
       "8     g2    g1    +\n",
       "9    g12   g11    +\n",
       "10    g1   g18    -\n",
       "11   g15   g14    +\n",
       "12    g3    g2    +\n",
       "13    g6    g5    +\n",
       "14    g4    g3    +\n",
       "15   g11   g10    +\n",
       "16    g9    g8    +\n",
       "17   g13   g12    +\n",
       "18   g10    g9    +"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bool_ode = '/gpfs/commons/home/zlin/knowles_lab/zlin/PerturbODE/data/BoolODE_sim/refNetwork.csv'\n",
    "\n",
    "ref_network_csv = pd.read_csv(bool_ode) \n",
    "\n",
    "ref_network_csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "mapping = {\n",
    "    \"g1\": [\n",
    "        0\n",
    "    ],\n",
    "    \"g10\": [\n",
    "        1\n",
    "    ],\n",
    "    \"g11\": [\n",
    "        2\n",
    "    ],\n",
    "    \"g12\": [\n",
    "        3\n",
    "    ],\n",
    "    \"g13\": [\n",
    "        4\n",
    "    ],\n",
    "    \"g14\": [\n",
    "        5\n",
    "    ],\n",
    "    \"g15\": [\n",
    "        6\n",
    "    ],\n",
    "    \"g16\": [\n",
    "        7\n",
    "    ],\n",
    "    \"g17\": [\n",
    "        8\n",
    "    ],\n",
    "    \"g18\": [\n",
    "        9\n",
    "    ],\n",
    "    \"g2\": [\n",
    "        10\n",
    "    ],\n",
    "    \"g3\": [\n",
    "        11\n",
    "    ],\n",
    "    \"g4\": [\n",
    "        12\n",
    "    ],\n",
    "    \"g5\": [\n",
    "        13\n",
    "    ],\n",
    "    \"g6\": [\n",
    "        14\n",
    "    ],\n",
    "    \"g7\": [\n",
    "        15\n",
    "    ],\n",
    "    \"g8\": [\n",
    "        16\n",
    "    ],\n",
    "    \"g9\": [\n",
    "        17\n",
    "    ]\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     g1  g10  g11  g12  g13  g14  g15  g16  g17  g18  g2  g3  g4  g5  g6  g7  \\\n",
      "g1    0    0    0    0    0    0    0    0    0    0   1   0   0   0   0   0   \n",
      "g10   0    0    1    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
      "g11   0    0    0    1    0    0    0    0    0    0   0   0   0   0   0   0   \n",
      "g12   0    0    0    0    1    0    0    0    0    0   0   0   0   0   0   0   \n",
      "g13   0    0    0    0    0    1    0    0    0    0   0   0   0   0   0   0   \n",
      "g14   0    0    0    0    0    0    1    0    0    0   0   0   0   0   0   0   \n",
      "g15   0    0    0    0    0    0    0    1    0    0   0   0   0   0   0   0   \n",
      "g16   0    0    0    0    0    0    0    0    1    0   0   0   0   0   0   0   \n",
      "g17   0    0    0    0    0    0    0    0    0    1   0   0   0   0   0   0   \n",
      "g18   0    0    0    0    0    0    0    0    0    1   0   0   0   0   0   0   \n",
      "g2    0    0    0    0    0    0    0    0    0    0   0   1   0   0   0   0   \n",
      "g3    0    0    0    0    0    0    0    0    0    0   0   0   1   0   0   0   \n",
      "g4    0    0    0    0    0    0    0    0    0    0   0   0   0   1   0   0   \n",
      "g5    0    0    0    0    0    0    0    0    0    0   0   0   0   0   1   0   \n",
      "g6    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   1   \n",
      "g7    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
      "g8    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
      "g9    0    1    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
      "\n",
      "     g8  g9  \n",
      "g1    0   0  \n",
      "g10   0   0  \n",
      "g11   0   0  \n",
      "g12   0   0  \n",
      "g13   0   0  \n",
      "g14   0   0  \n",
      "g15   0   0  \n",
      "g16   0   0  \n",
      "g17   0   0  \n",
      "g18   0   0  \n",
      "g2    0   0  \n",
      "g3    0   0  \n",
      "g4    0   0  \n",
      "g5    0   0  \n",
      "g6    0   0  \n",
      "g7    1   0  \n",
      "g8    0   1  \n",
      "g9    0   0  \n",
      "[[0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0]\n",
      " [0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0]\n",
      " [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1]\n",
      " [0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]]\n"
     ]
    }
   ],
   "source": [
    "genes = list(mapping.keys())\n",
    "\n",
    "adj_matrix = pd.DataFrame(0, index=genes, columns=genes)\n",
    "\n",
    "for _, row in ref_network_csv.iterrows():\n",
    "    source_gene = row['Gene1']\n",
    "    target_gene = row['Gene2']\n",
    "    interaction = 1 if row['Type'] == '+' else 0  \n",
    "    adj_matrix.loc[source_gene, target_gene] = interaction\n",
    "\n",
    "print(adj_matrix)\n",
    "\n",
    "\n",
    "adj_matrix_np = adj_matrix.to_numpy()\n",
    "\n",
    "\n",
    "print(adj_matrix_np)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def get_results(save_dir,scale, ground_truth_adjusted):\n",
    "\n",
    "    path_parts = save_dir.split(os.sep)\n",
    "\n",
    "    timestamp = path_parts[-1]\n",
    "\n",
    "    pth_file = timestamp + '.pth'\n",
    "    pth_file_dir = os.path.join(save_dir, pth_file)\n",
    "\n",
    "    ode_func_train_W2 = torch.load(pth_file_dir, map_location=torch.device('cpu'))\n",
    "\n",
    "    ode_func_train_W2.eval()\n",
    "\n",
    "    std_cutoff = 0.1\n",
    "\n",
    "\n",
    "\n",
    "    if scale: \n",
    "        B_0_np = ode_func_train_W2.B_0.cpu().detach().numpy()\n",
    "        B_1_np = ode_func_train_W2.B_1.cpu().detach().numpy()\n",
    "        scale = ode_func_train_W2.sigmoid_scale.cpu().detach().numpy()\n",
    "\n",
    "        B_0_scaled = np.zeros(np.shape(B_0_np))\n",
    "\n",
    "\n",
    "        for i in range(np.shape(B_0_np)[1]):\n",
    "                B_0_scaled[:,i] = B_0_np[:,i] * scale[0][i]\n",
    "\n",
    "        B_Matrix_predicted = B_0_scaled @ B_1_np\n",
    "\n",
    "    else:\n",
    "        B_Matrix_predicted = ode_func_train_W2.B_0 @ ode_func_train_W2.B_1\n",
    "\n",
    "        B_Matrix_predicted = B_Matrix_predicted.cpu().detach().numpy()\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    std_dev = np.std(B_Matrix_predicted)\n",
    "\n",
    "    B_Matrix_predicted_adjusted = B_Matrix_predicted.copy()\n",
    "\n",
    "    for i, upstream_gene in enumerate(B_Matrix_predicted):\n",
    "        for j, downstream_gene in enumerate(B_Matrix_predicted[i]):\n",
    "            if B_Matrix_predicted[i][j] < std_cutoff*std_dev:\n",
    "                B_Matrix_predicted_adjusted[i][j] = 0\n",
    "            else:\n",
    "                B_Matrix_predicted_adjusted[i][j] = 1\n",
    "\n",
    "    true_positives = 0 \n",
    "    true_negatives = 0 \n",
    "\n",
    "    false_positives = 0 \n",
    "    false_negatives = 0 \n",
    "\n",
    "\n",
    "    for i, upstream_gene in enumerate(B_Matrix_predicted_adjusted):\n",
    "        for j, downstream_gene in enumerate(B_Matrix_predicted_adjusted[i]):\n",
    "            if B_Matrix_predicted_adjusted[i][j] > 0 and ground_truth_adjusted[i][j] > 0:\n",
    "                true_positives = true_positives + 1\n",
    "            elif B_Matrix_predicted_adjusted[i][j] <= 0 and ground_truth_adjusted[i][j] <= 0:\n",
    "                true_negatives = true_negatives + 1\n",
    "            elif B_Matrix_predicted_adjusted[i][j] > 0 and ground_truth_adjusted[i][j] <= 0:\n",
    "                false_positives = false_positives + 1\n",
    "            elif B_Matrix_predicted_adjusted[i][j] <= 0 and ground_truth_adjusted[i][j] > 0:\n",
    "                false_negatives = false_negatives + 1 \n",
    "            else: \n",
    "                continue\n",
    "\n",
    "    non_zero_count_pred = np.count_nonzero(B_Matrix_predicted_adjusted)\n",
    "    non_zero_count_gt = np.count_nonzero(ground_truth_adjusted)\n",
    "\n",
    "    ratio_positive = non_zero_count_pred/len(ground_truth_adjusted.flatten()) * 100\n",
    "\n",
    "\n",
    "    print(\"Prediction has \" + str(non_zero_count_pred) + \" non-zero edges.\")\n",
    "    print(\"Ground truth has \" + str(non_zero_count_gt) + \" non-zero edges.\")\n",
    "\n",
    "    formatted_percentage = \"{:.2f}\".format(ratio_positive)\n",
    "    print(formatted_percentage + \" percent of potential edges are filled.\")\n",
    "\n",
    "    precision_standard = true_positives / (true_positives + false_positives)\n",
    "\n",
    "    recall_standard = true_positives / (true_positives + false_negatives)\n",
    "\n",
    "    F_1_standard = (precision_standard + recall_standard)/2\n",
    "\n",
    "\n",
    "    recall_random_lst = []\n",
    "    precision_random_lst = []\n",
    "    F1_random_lst = []\n",
    "\n",
    "    total_elements = np.shape(ground_truth_adjusted)[0] * np.shape(ground_truth_adjusted)[1]\n",
    "\n",
    "    num_ones = non_zero_count_pred\n",
    "\n",
    "    # Create an array with the specified number of 1s\n",
    "    elements = np.array([1]*num_ones + [0]*(total_elements - num_ones))\n",
    "\n",
    "\n",
    "    for i in tqdm(range(1000)):\n",
    "\n",
    "        # Shuffle the array to randomize the distribution of 1s and 0s\n",
    "        np.random.shuffle(elements)\n",
    "\n",
    "        # Reshape the array into a NxN matrix\n",
    "        binary_matrix = elements.reshape(np.shape(ground_truth_adjusted))\n",
    "\n",
    "        true_positives_random = 0 \n",
    "        true_negatives_random = 0 \n",
    "\n",
    "        false_positives_random = 0 \n",
    "        false_negatives_random = 0 \n",
    "\n",
    "\n",
    "        for i, upstream_gene in enumerate(binary_matrix):\n",
    "            for j, downstream_gene in enumerate(binary_matrix[i]):\n",
    "                if binary_matrix[i][j] > 0 and ground_truth_adjusted[i][j]> 0:\n",
    "                    true_positives_random = true_positives_random + 1\n",
    "                elif binary_matrix[i][j] <= 0 and ground_truth_adjusted[i][j] == 0:\n",
    "                    true_negatives_random = true_negatives_random + 1\n",
    "                elif binary_matrix[i][j] > 0 and ground_truth_adjusted[i][j] == 0:\n",
    "                    false_positives_random = false_positives_random + 1\n",
    "                elif binary_matrix[i][j] <= 0 and ground_truth_adjusted[i][j] > 0:\n",
    "                    false_negatives_random = false_negatives_random + 1 \n",
    "                else: \n",
    "                    continue\n",
    "\n",
    "        if true_positives_random == 0:\n",
    "            precision_random = 0\n",
    "        else: \n",
    "            precision_random = true_positives_random / (true_positives_random + false_positives_random)\n",
    "\n",
    "        if true_positives_random == 0:\n",
    "            recall_random = 0\n",
    "        else:\n",
    "            recall_random = true_positives_random / (true_positives_random + false_negatives_random)\n",
    "\n",
    "        F_1_random = (precision_random + recall_random)/2\n",
    "\n",
    "        recall_random_lst.append(precision_random)\n",
    "        precision_random_lst.append(recall_random)\n",
    "        F1_random_lst.append(F_1_random)\n",
    "\n",
    "    random_recall = np.mean(recall_random_lst)\n",
    "    random_precision = np.mean(precision_random_lst)\n",
    "    random_F1 = np.mean(F1_random_lst)\n",
    "\n",
    "    indicator = [x > F_1_standard for x in F1_random_lst]\n",
    "    p_val = (np.sum(indicator)+1)/(len(F1_random_lst)+1)\n",
    "\n",
    "    file_name_save = save_dir + '/GRN_results_ode_sergio_simulated.txt'\n",
    "\n",
    "    test_prec, test_recall, threshold = precision_recall_curve(ground_truth_adjusted.flatten(), B_Matrix_predicted.flatten(), pos_label=1)\n",
    "    test_auprc = auc(test_recall, test_prec)\n",
    "\n",
    "    with open(file_name_save, 'w') as file:\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "        file.write(f\"With threshold set as {std_cutoff} std:\\n\")\n",
    "        print(f\"With threshold set as {std_cutoff} std:\\n\")\n",
    "\n",
    "        file.write(f\"precision: {precision_standard} \\n\")\n",
    "        print(f\"precision: {precision_standard} \\n\")\n",
    "        file.write(f\"recall: {recall_standard} \\n\")\n",
    "        print(f\"recall: {recall_standard} \\n\")\n",
    "        file.write(f\"F_1: {F_1_standard} \\n\")\n",
    "        print(f\"F_1: {F_1_standard} \\n\")\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "        file.write(f\"AUPRC: {test_auprc} \\n\")\n",
    "        print(f\"AUPRC: {test_auprc} \\n\")\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "\n",
    "        file.write(\"p-val: \" + str(p_val) + \" \\n\")\n",
    "        print(\"p-val: \" + str(p_val) + \" \\n\")\n",
    "\n",
    "\n",
    "        file.write(\"Prediction has \" + str(non_zero_count_pred) + \" non-zero edges.\\n\")\n",
    "        file.write(\"Ground truth has \" + str(non_zero_count_gt) + \" non-zero edges.\\n\")\n",
    "\n",
    "        print(\"Prediction has \" + str(non_zero_count_pred) + \" non-zero edges.\\n\")\n",
    "        print(\"Ground truth has \" + str(non_zero_count_gt) + \" non-zero edges.\\n\")\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "\n",
    "        print(f\"Recall of a random matrix is {random_recall}.\\n\")\n",
    "        file.write(f\"Recall of a random matrix is {random_recall}.\\n\")\n",
    "        print(f\"Precision of a random matrix is {random_precision}.\\n\")\n",
    "        file.write(f\"Precision of a random matrix is {random_precision}.\\n\")\n",
    "        print(f\"F1 of a random matrix is {random_F1}.\\n\")\n",
    "        file.write(f\"F1 of a random matrix is {random_F1}.\\n\")\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "\n",
    "        if random_F1 < F_1_standard:\n",
    "            print(f\"Model is predicting better than random.\\n\")\n",
    "            file.write(f\"Model is predicting better than random.\\n\")\n",
    "        else:\n",
    "            print(f\"Model is predicting worse than random.\\n\")\n",
    "            file.write(f\"Model is predicting worse than random.\\n\")\n",
    "\n",
    "        file.write(\"-------------------------------------------------------\\n\")\n",
    "        print(\"-------------------------------------------------------\\n\")\n",
    "\n",
    "\n",
    "        file_name_dict = save_dir + '/test_results.json'\n",
    "\n",
    "        dict_vals = {}\n",
    "        dict_vals['precision'] = precision_standard\n",
    "        dict_vals['recall'] = recall_standard\n",
    "        dict_vals['F_1'] = F_1_standard\n",
    "        dict_vals['auprc'] = test_auprc\n",
    "        dict_vals['relav_rand'] = int(random_F1 < F_1_standard)\n",
    "        dict_vals['permut_p_val'] = p_val\n",
    "        dict_vals['num_edges_pred'] = non_zero_count_pred\n",
    "        dict_vals['num_edges_GT'] = non_zero_count_gt\n",
    "\n",
    "\n",
    "        with open(file_name_dict, 'w') as file:\n",
    "            json.dump(dict_vals, file, indent=4)\n",
    "\n",
    "\n",
    "        # Compute precision and recall values\n",
    "        \n",
    "\n",
    "        precision, recall, thresholds = precision_recall_curve(ground_truth_adjusted.flatten(), B_Matrix_predicted.flatten())\n",
    "\n",
    "        # Compute average precision score (optional, for reference)\n",
    "        #average_precision = average_precision_score(ground_truth_adjusted.flatten(), B_Matrix_predicted.flatten())\n",
    "        test_auprc = auc(test_recall, test_prec)\n",
    "        \n",
    "        # Plot the Precision-Recall curve\n",
    "        plt.figure()\n",
    "        plt.plot(recall, precision, label=f'Precision-Recall curve (AP = {test_auprc:.2f})')\n",
    "        plt.xlabel('Recall')\n",
    "        plt.ylabel('Precision')\n",
    "        plt.title('Precision-Recall Curve')\n",
    "        plt.legend(loc='best')\n",
    "        plt.show()\n",
    "        \n",
    "\n",
    "\n",
    "        \n",
    "\n",
    "        \n",
    "                    \n",
    "            \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Gene2</th>\n",
       "      <th>Gene1</th>\n",
       "      <th>Type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>g7</td>\n",
       "      <td>g6</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>g14</td>\n",
       "      <td>g13</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>g5</td>\n",
       "      <td>g4</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>g8</td>\n",
       "      <td>g7</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>g18</td>\n",
       "      <td>g17</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>g18</td>\n",
       "      <td>g18</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>g17</td>\n",
       "      <td>g16</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>g16</td>\n",
       "      <td>g15</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>g2</td>\n",
       "      <td>g1</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>g12</td>\n",
       "      <td>g11</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>g1</td>\n",
       "      <td>g18</td>\n",
       "      <td>-</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>g15</td>\n",
       "      <td>g14</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>g3</td>\n",
       "      <td>g2</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>g6</td>\n",
       "      <td>g5</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>g4</td>\n",
       "      <td>g3</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>g11</td>\n",
       "      <td>g10</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>g9</td>\n",
       "      <td>g8</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>g13</td>\n",
       "      <td>g12</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>g10</td>\n",
       "      <td>g9</td>\n",
       "      <td>+</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Gene2 Gene1 Type\n",
       "0     g7    g6    +\n",
       "1    g14   g13    +\n",
       "2     g5    g4    +\n",
       "3     g8    g7    +\n",
       "4    g18   g17    +\n",
       "5    g18   g18    +\n",
       "6    g17   g16    +\n",
       "7    g16   g15    +\n",
       "8     g2    g1    +\n",
       "9    g12   g11    +\n",
       "10    g1   g18    -\n",
       "11   g15   g14    +\n",
       "12    g3    g2    +\n",
       "13    g6    g5    +\n",
       "14    g4    g3    +\n",
       "15   g11   g10    +\n",
       "16    g9    g8    +\n",
       "17   g13   g12    +\n",
       "18   g10    g9    +"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ref_network_csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>g1</th>\n",
       "      <th>g10</th>\n",
       "      <th>g11</th>\n",
       "      <th>g12</th>\n",
       "      <th>g13</th>\n",
       "      <th>g14</th>\n",
       "      <th>g15</th>\n",
       "      <th>g16</th>\n",
       "      <th>g17</th>\n",
       "      <th>g18</th>\n",
       "      <th>g2</th>\n",
       "      <th>g3</th>\n",
       "      <th>g4</th>\n",
       "      <th>g5</th>\n",
       "      <th>g6</th>\n",
       "      <th>g7</th>\n",
       "      <th>g8</th>\n",
       "      <th>g9</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>g1</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g10</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g11</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g12</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g13</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g14</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g15</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g16</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g17</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g18</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g2</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g3</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g4</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g5</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g6</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g7</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g8</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>g9</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     g1  g10  g11  g12  g13  g14  g15  g16  g17  g18  g2  g3  g4  g5  g6  g7  \\\n",
       "g1    0    0    0    0    0    0    0    0    0    0   1   0   0   0   0   0   \n",
       "g10   0    0    1    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
       "g11   0    0    0    1    0    0    0    0    0    0   0   0   0   0   0   0   \n",
       "g12   0    0    0    0    1    0    0    0    0    0   0   0   0   0   0   0   \n",
       "g13   0    0    0    0    0    1    0    0    0    0   0   0   0   0   0   0   \n",
       "g14   0    0    0    0    0    0    1    0    0    0   0   0   0   0   0   0   \n",
       "g15   0    0    0    0    0    0    0    1    0    0   0   0   0   0   0   0   \n",
       "g16   0    0    0    0    0    0    0    0    1    0   0   0   0   0   0   0   \n",
       "g17   0    0    0    0    0    0    0    0    0    1   0   0   0   0   0   0   \n",
       "g18   0    0    0    0    0    0    0    0    0    1   0   0   0   0   0   0   \n",
       "g2    0    0    0    0    0    0    0    0    0    0   0   1   0   0   0   0   \n",
       "g3    0    0    0    0    0    0    0    0    0    0   0   0   1   0   0   0   \n",
       "g4    0    0    0    0    0    0    0    0    0    0   0   0   0   1   0   0   \n",
       "g5    0    0    0    0    0    0    0    0    0    0   0   0   0   0   1   0   \n",
       "g6    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   1   \n",
       "g7    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
       "g8    0    0    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
       "g9    0    1    0    0    0    0    0    0    0    0   0   0   0   0   0   0   \n",
       "\n",
       "     g8  g9  \n",
       "g1    0   0  \n",
       "g10   0   0  \n",
       "g11   0   0  \n",
       "g12   0   0  \n",
       "g13   0   0  \n",
       "g14   0   0  \n",
       "g15   0   0  \n",
       "g16   0   0  \n",
       "g17   0   0  \n",
       "g18   0   0  \n",
       "g2    0   0  \n",
       "g3    0   0  \n",
       "g4    0   0  \n",
       "g5    0   0  \n",
       "g6    0   0  \n",
       "g7    1   0  \n",
       "g8    0   1  \n",
       "g9    0   0  "
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "adj_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction has 93 non-zero edges.\n",
      "Ground truth has 18 non-zero edges.\n",
      "28.70 percent of potential edges are filled.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 2036.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------\n",
      "\n",
      "With threshold set as 0.1 std:\n",
      "\n",
      "precision: 0.053763440860215055 \n",
      "\n",
      "recall: 0.2777777777777778 \n",
      "\n",
      "F_1: 0.16577060931899643 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "AUPRC: 0.04936271488323679 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "p-val: 0.4125874125874126 \n",
      "\n",
      "Prediction has 93 non-zero edges.\n",
      "\n",
      "Ground truth has 18 non-zero edges.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Recall of a random matrix is 0.055483870967741926.\n",
      "\n",
      "Precision of a random matrix is 0.2866666666666666.\n",
      "\n",
      "F1 of a random matrix is 0.17107526881720428.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Model is predicting worse than random.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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lm+//Va0b99eWFlZCVtbW/Hss8+K48ePl9pWCCH+97//iZ49ewq1Wi0cHR3FuHHjRGZmZrk1GxpuhBAiJCRE9OvXTwghREZGhnj99deFh4eHMDc3F15eXmL48OEiISFBav/TTz9Jf1g6OTmJF154QVr3/fffC29vb6FSqURgYKCIioqqUrgRQoirV6+KwYMHC1tbW2FpaSn8/f313mxnz54tXF1dhZ2dnZg2bZqYMmVKhcNNccBo1KiR0Ol0eut0Op1YvHix9G/s7OwsQkJCxP79+8ustaCgQHh4eIjo6GghhBCbN28WJiYmIikpqdT2Tz/9tJg2bdpj66wpd+7cEUOHDhXW1tbC1tZWjBkzRu93LT4+XgAQe/fulZbl5uaKSZMmCQcHB2FpaSmef/55kZiYKK3fvn27aN++vbC2thZWVlaiXbt2IjIyUgrzxfr06SMiIiLKrK26wo1CiCpeX1nPZGRkwM7ODunp6WUOPRvieMI9vLDsMBo6WuKPdyo2ZE1U1+Xl5SE+Ph6NGzcudcIkERVZunQpoqKi+In55Thz5gx69eqFCxcuwM7OrtQ25b3mVOb9u36cPCciIqrDJkyYgLS0NGRmZpb6FQxU9JUj3333XZnBpjox3BAREVWRmZkZZs6caewy6rRHv2GgJtWrTygmIiIiehyGGyIiIpIVhhsieqwn7LoDIjKS6nqtYbghojIVf9S/oZ80S0RUGcWvNQ9/zYghOKGYiMpkZmYGS0tLpKamwtzcvNJfQUBEVFE6nQ6pqamwtLQs8XUplcVwQ0RlUigUcHd3R3x8fI1/iy8RkYmJCRo2bAiFQlGl/TDcEFG5lEolfHx8eGqKiGqcUqmslhFihhsieiwTExN+QjER1Rs8gU5ERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESy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d+nSBZs3b65yUURERESGMijc3LlzB3Z2diWW29ra4vbt21UuioiIiMhQBoWbZs2aITo6usTy7du3o0mTJlUuioiIiMhQBn2IX3h4OKZMmYLU1FT06tULABATE4PPP/8cixcvrs76iIiIiCrFoHDzyiuvID8/H5988gnmzp0LAPD29sby5csxatSoai2QiIiIqDIMCjcA8Nprr+G1115DamoqLCwspO+XIiIiIjImgz/nprCwELt378bPP/8MIQQA4NatW8jKyqq24oiIiIgqy6CRm2vXrqFv375ISEhAfn4+evfuDRsbGyxYsAD5+fmIjIys7jqJiIiIKsSgkZupU6fC398f9+7dg4WFhbT8+eefR0xMTLUVR0RERFRZBo3cHDhwAIcPH4ZSqdRb7u3tjZs3b1ZLYURERESGMGjkRqfTlfrN3zdu3ICNjU2ViyIiIiIylEHhpk+fPnqfZ6NQKJCVlYU5c+agf//+1VUbERERUaUZdFpq4cKF6Nu3L1q2bIm8vDwMGzYMFy9ehJOTE3744YfqrpGIiIiowgwKN15eXjh16hQ2btyIU6dOISsrC6+++iqGDx+uN8GYiIiIqLZVOtwUFBTA19cXW7ZswfDhwzF8+PCaqIuIiIjIIJWec2Nubo68vLyaqIWIiIioygyaUDx58mQsWLAAhYWF1V0PERERUZUYNOfm2LFjiImJwc6dO9GmTRtYWVnprf/555+rpTgiIiKiyjIo3Njb22Pw4MHVXQsRERFRlVUq3Oh0Onz22We4cOECNBoNevXqhQ8++IBXSBEREVGdUak5N5988gnee+89WFtbw9PTE19++SUmT55cU7URERERVVqlws13332HZcuWYceOHfj111/x+++/Y/369dDpdDVVHxEREVGlVCrcJCQk6H29QnBwMBQKBW7dulXthREREREZolLhprCwEGq1Wm+Zubk5CgoKqlTE0qVL4e3tDbVajYCAABw9erRC223YsAEKhQKDBg2q0vGJiIhIPio1oVgIgdGjR0OlUknL8vLyMHHiRL3LwStzKfjGjRsRHh6OyMhIBAQEYPHixQgJCUFcXBxcXFzK3O7q1at466230L1798o8BSIiIpK5So3chIWFwcXFBXZ2dtJtxIgR8PDw0FtWGYsWLcK4ceMwZswYtGzZEpGRkbC0tMTq1avL3Ear1WL48OH48MMP0aRJk0odj4iIiOStUiM3a9asqdaDazQaxMbGYsaMGdIyExMTBAcH48iRI2Vu99FHH8HFxQWvvvoqDhw4UK01ERERUf1m0If4VZfbt29Dq9XC1dVVb7mrqyvOnz9f6jYHDx7EqlWrcPLkyQodIz8/H/n5+dLjjIwMg+slIiKius+g75YylszMTIwcORIrVqyAk5NThbaJiIjQO2Xm5eVVw1USERGRMRl15MbJyQmmpqZITk7WW56cnAw3N7cS7S9fvoyrV69i4MCB0rLiz9gxMzNDXFwcmjZtqrfNjBkzEB4eLj3OyMhgwCEiIpIxo4YbpVIJPz8/xMTESJdz63Q6xMTEYMqUKSXa+/r64vTp03rLZs2ahczMTCxZsqTU0KJSqfSu7iIiIiJ5M2q4AYDw8HCEhYXB398fnTt3xuLFi5GdnY0xY8YAAEaNGgVPT09ERERArVajdevWetvb29sDQInlRERE9GQyergJDQ1FamoqZs+ejaSkJLRv3x7R0dHSJOOEhASYmNSrqUFERERkRAohhDB2EbUpIyMDdnZ2SE9Ph62tbbXt93jCPbyw7DAaOlrij3d6Vtt+iYiIqHLv3xwSISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZqRPhZunSpfD29oZarUZAQACOHj1aZtsVK1age/fucHBwgIODA4KDg8ttT0RERE8Wo4ebjRs3Ijw8HHPmzMHx48fRrl07hISEICUlpdT2+/btw9ChQ7F3714cOXIEXl5e6NOnD27evFnLlRMREVFdZPRws2jRIowbNw5jxoxBy5YtERkZCUtLS6xevbrU9uvXr8ekSZPQvn17+Pr6YuXKldDpdIiJianlyomIiKguMmq40Wg0iI2NRXBwsLTMxMQEwcHBOHLkSIX2kZOTg4KCAjg6OtZUmURERFSPmBnz4Ldv34ZWq4Wrq6vecldXV5w/f75C+3j33Xfh4eGhF5Aelp+fj/z8fOlxRkaG4QUTERFRnWf001JVMX/+fGzYsAG//PIL1Gp1qW0iIiJgZ2cn3by8vGq5SiIiIqpNRg03Tk5OMDU1RXJyst7y5ORkuLm5lbvtwoULMX/+fOzcuRNt27Yts92MGTOQnp4u3a5fv14ttRMREVHdZNRwo1Qq4efnpzcZuHhycGBgYJnbffrpp5g7dy6io6Ph7+9f7jFUKhVsbW31bkRERCRfRp1zAwDh4eEICwuDv78/OnfujMWLFyM7OxtjxowBAIwaNQqenp6IiIgAACxYsACzZ8/G999/D29vbyQlJQEArK2tYW1tbbTnQURERHWD0cNNaGgoUlNTMXv2bCQlJaF9+/aIjo6WJhknJCTAxOTBANPy5cuh0Wjw4osv6u1nzpw5+OCDD2qzdCIiIqqDjB5uAGDKlCmYMmVKqev27dun9/jq1as1XxARERHVW/X6aikiIiKiRzHcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkaww3BAREZGsMNwQERGRrDDcEBERkayYGbsAovpECIHbWRpcTMnEpZQsXErJQhMnK4zu2tjYpRFRPVWg1SEnX4tCnQ4NrFU1eowCnQ5ONXSMuoThhqgUQggkpufh4v0AcyklExeTs3AxJQvpuQUl2g9o6wFn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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction has 92 non-zero edges.\n",
      "Ground truth has 18 non-zero edges.\n",
      "28.40 percent of potential edges are filled.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 2029.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------\n",
      "\n",
      "With threshold set as 0.1 std:\n",
      "\n",
      "precision: 0.05434782608695652 \n",
      "\n",
      "recall: 0.2777777777777778 \n",
      "\n",
      "F_1: 0.16606280193236717 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "AUPRC: 0.05019388158423211 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "p-val: 0.3986013986013986 \n",
      "\n",
      "Prediction has 92 non-zero edges.\n",
      "\n",
      "Ground truth has 18 non-zero edges.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Recall of a random matrix is 0.05526086956521739.\n",
      "\n",
      "Precision of a random matrix is 0.28244444444444444.\n",
      "\n",
      "F1 of a random matrix is 0.16885265700483093.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Model is predicting worse than random.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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jejQoYOwsrIStra24qmnnhJHjx4ts68QQvzvf/8TvXr1Emq1Wjg6Oorx48eLrKysCmuuargRQoiQkBDRv39/IYQQmZmZ4rXXXhMeHh7C3NxceHl5iREjRoiEhASp/88//yz9Yenk5CSef/55adoPP/wgvL29hUqlEoGBgSIyMvKRwo0QQly5ckUMHjxY2NraCktLS+Hv76/3YTtnzhzh6uoq7OzsxPTp08XUqVMrHW5KAkbjxo2FTqfTm6bT6cSSJUukf2NnZ2cREhIi/vrrr3JrLSwsFB4eHiIqKkoIIcTmzZuFiYmJSEpKKrP/E088IaZPn/7QOmvK7du3xbBhw4S1tbWwtbUVY8eO1XutXb58WQAQe/bskdry8vLE5MmThYODg7C0tBTPPfecSExMlKZv375ddOjQQVhbWwsrKyvRvn17ERERIYX5En379hXh4eHl1lZd4UYhxCN+v7KeyczMhJ2dHTIyMsodeq6KowlpeH75ITRytMS+tys3ZE1U1+Xn5+Py5cto0qRJmSdMElGxZcuWITIyklfMr8CpU6fQu3dvnD9/HnZ2dmX2qeg9x5DP7/px8JyIiKgOmzhxItLT05GVlVXmLRio+JYj3333XbnBpjox3BARET0iMzMzzJo1y9hl1GkP3mGgJtWrKxQTERERPQzDDREREckKww0RPdRj9r0DIjKS6nqvYbghonKVXOq/qleaJSIyRMl7zf23GakKnlBMROUyMzODpaUlUlNTYW5ubvAtCIiIKkun0yE1NRWWlpalbpdiKIYbIiqXQqGAu7s7Ll++XON38SUiMjExQaNGjaBQKB5pOQw3RFQhpVKJ5s2b89AUEdU4pVJZLSPEDDdE9FAmJia8QjER1Rs8gE5ERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLJi9HCzbNkyeHt7Q61WIyAgAIcPH66w/5IlS9CyZUtYWFjAy8sL06dPR35+fi1VS0RERHWdUcPNxo0bERYWhrlz5+Lo0aNo3749QkJCkJKSUmb/H374ATNmzMDcuXNx5swZrFq1Chs3bsS7775by5UTERFRXWXUcLN48WKMHz8eY8eORatWrRAREQFLS0usXr26zP6HDh1Ct27dMHz4cHh7e6Nv374YNmzYQ0d7iIiI6PFhtHCj0WgQGxuL4ODge8WYmCA4OBgxMTFlztO1a1fExsZKYebSpUvYtm0bBgwYUO56CgoKkJmZqfcgIiIi+TIz1opv3boFrVYLV1dXvXZXV1ecPXu2zHmGDx+OW7duoXv37hBCoKioCJMmTarwsFR4eDg++OCDaq2diIiI6i6jn1BsiL1792L+/PlYvnw5jh49il9++QVbt27FvHnzyp1n5syZyMjIkB7Xrl2rxYqJiIiothlt5MbJyQmmpqZITk7Wa09OToabm1uZ87z33nsYNWoUxo0bBwBo27YtcnJyMGHCBMyaNQsmJqWzmkqlgkqlqv4NICIiojrJaCM3SqUSfn5+iI6Oltp0Oh2io6MRGBhY5jy5ubmlAoypqSkAQAhRc8USERFRvWG0kRsACAsLQ2hoKPz9/dGlSxcsWbIEOTk5GDt2LABg9OjR8PT0RHh4OABg4MCBWLx4MTp27IiAgABcvHgR7733HgYOHCiFHCIiInq8GTXcDB06FKmpqZgzZw6SkpLQoUMHREVFSScZJyQk6I3UzJ49GwqFArNnz8aNGzfg7OyMgQMH4uOPPzbWJhAREVEdoxCP2fGczMxM2NnZISMjA7a2ttW23KMJaXh++SE0crTEvrd7VdtyiYiIyLDP73r1bSkiIiKih2G4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIllhuCEiIiJZYbghIiIiWWG4ISIiIlkxerhZtmwZvL29oVarERAQgMOHD1fYPz09HVOmTIG7uztUKhVatGiBbdu21VK1REREVNeZGXPlGzduRFhYGCIiIhAQEIAlS5YgJCQE586dg4uLS6n+Go0Gffr0gYuLCzZv3gxPT09cvXoV9vb2tV88ERER1UlGDTeLFy/G+PHjMXbsWABAREQEtm7ditWrV2PGjBml+q9evRp37tzBoUOHYG5uDgDw9vauzZKJiIiojjPaYSmNRoPY2FgEBwffK8bEBMHBwYiJiSlznsjISAQGBmLKlClwdXVFmzZtMH/+fGi12nLXU1BQgMzMTL0HERERyZfRws2tW7eg1Wrh6uqq1+7q6oqkpKQy57l06RI2b94MrVaLbdu24b333sNnn32Gjz76qNz1hIeHw87OTnp4eXlV63YQERFR3WL0E4oNodPp4OLigm+++QZ+fn4YOnQoZs2ahYiIiHLnmTlzJjIyMqTHtWvXarFiIiIiqm1GO+fGyckJpqamSE5O1mtPTk6Gm5tbmfO4u7vD3NwcpqamUtsTTzyBpKQkaDQaKJXKUvOoVCqoVKrqLZ6IiIjqLKON3CiVSvj5+SE6Olpq0+l0iI6ORmBgYJnzdOvWDRcvXoROp5Pazp8/D3d39zKDDRERET1+jHpYKiwsDCtXrsS6detw5swZvPrqq8jJyZG+PTV69GjMnDlT6v/qq6/izp07mDZtGs6fP4+tW7di/vz5mDJlirE2gYiIiOoYo34VfOjQoUhNTcWcOXOQlJSEDh06ICoqSjrJOCEhASYm9/KXl5cXduzYgenTp6Ndu3bw9PTEtGnT8M477xhrE4iIiKiOUQghhLGLqE2ZmZmws7NDRkYGbG1tq225RxPS8PzyQ2jkaIl9b/eqtuUSERGRYZ/fVRq50Wq1WLt2LaKjo5GSkqJ3DgwA7N69uyqLJSIiInpkVQo306ZNw9q1a/H000+jTZs2UCgU1V0XERERUZVUKdxs2LABP/30EwYMGFDd9RARERE9kip9W0qpVKJZs2bVXQsRERHRI6tSuHnjjTewdOlSPGbnIhMREVE9UKXDUgcOHMCePXuwfft2tG7dWrpDd4lffvmlWoojIiIiMlSVwo29vT2ee+656q6FiIiI6JFVKdysWbOmuusgIiIiqhaPdIXi1NRUnDt3DgDQsmVLODs7V0tRRERERFVVpROKc3Jy8PLLL8Pd3R1PPvkknnzySXh4eOCVV15Bbm5udddIREREVGlVCjdhYWH466+/8McffyA9PR3p6en4/fff8ddff+GNN96o7hqJiIiIKq1Kh6V+/vlnbN68GT179pTaBgwYAAsLCwwZMgQrVqyorvqIiIiIDFKlkZvc3Fzpzt33c3Fx4WEpIiIiMqoqhZvAwEDMnTsX+fn5UlteXh4++OADBAYGVltxRERERIaq0mGppUuXIiQkBA0bNkT79u0BAMePH4darcaOHTuqtUAiIiIiQ1Qp3LRp0wYXLlzA+vXrcfbsWQDAsGHDMGLECFhYWFRrgURERESGqPJ1biwtLTF+/PjqrIWIiIjokVU63ERGRqJ///4wNzdHZGRkhX2fffbZRy6MiIiIqCoqHW4GDRqEpKQkuLi4YNCgQeX2UygU0Gq11VEbERERkcEqHW50Ol2ZvxMRERHVJVX6KnhZ0tPTq2tRRERERFVWpXCzcOFCbNy4UXr+4osvwtHREZ6enjh+/Hi1FUdERERkqCqFm4iICHh5eQEAdu7ciV27diEqKgr9+/fHW2+9Va0FEhERERmiSl8FT0pKksLNli1bMGTIEPTt2xfe3t4ICAio1gKJiIiIDFGlkRsHBwdcu3YNABAVFYXg4GAAgBCC35QiIiIio6rSyM3zzz+P4cOHo3nz5rh9+zb69+8PADh27BiaNWtWrQUSERERGaJK4ebzzz+Ht7c3rl27hk8++QTW1tYAgMTEREyePLlaCyQiIiIyRJXCjbm5Od58881S7dOnT3/kgoiIiIgeBW+/QERERLLC2y8QERGRrPD2C0RERCQr1Xb7BSIiIqK6oErh5r///S+++OKLUu1fffUVXn/99UetiYiIiKjKqhRufv75Z3Tr1q1Ue9euXbF58+ZHLoqIiIioqqoUbm7fvg07O7tS7ba2trh169YjF0VERERUVVUKN82aNUNUVFSp9u3bt8PHx+eRiyIiIiKqqipdxC8sLAxTp05FamoqevfuDQCIjo7GZ599hiVLllRnfUREREQGqVK4efnll1FQUICPP/4Y8+bNAwB4e3tjxYoVGD16dLUWSERERGSIKoUbAHj11Vfx6quvIjU1FRYWFtL9pYiIiIiMqcrXuSkqKsKuXbvwyy+/QAgBALh58yays7OrrTgiIiIiQ1Vp5Obq1avo168fEhISUFBQgD59+sDGxgYLFy5EQUEBIiIiqrtOIiIiokqp0sjNtGnT4O/vj7S0NFhYWEjtzz33HKKjo6utOCIiIiJDVWnkZv/+/Th06BCUSqVeu7e3N27cuFEthRERERFVRZVGbnQ6XZl3/r5+/TpsbGweuSgiIiKiqqpSuOnbt6/e9WwUCgWys7Mxd+5cDBgwoLpqIyIiIjJYlQ5LLVq0CP369UOrVq2Qn5+P4cOH48KFC3BycsKPP/5Y3TUSERERVVqVwo2XlxeOHz+OjRs34vjx48jOzsYrr7yCESNG6J1gTERERFTbDA43hYWF8PX1xZYtWzBixAiMGDGiJuoiIiIiqhKDz7kxNzdHfn5+TdRCRERE9MiqdELxlClTsHDhQhQVFVV3PURERESPpErn3Bw5cgTR0dH4888/0bZtW1hZWelN/+WXX6qlOCIiIiJDVSnc2NvbY/DgwdVdCxEREdEjMyjc6HQ6fPrppzh//jw0Gg169+6N999/n9+QIiIiojrDoHNuPv74Y7z77ruwtraGp6cnvvjiC0yZMqWmaiMiIiIymEHh5rvvvsPy5cuxY8cO/Pbbb/jjjz+wfv166HS6mqqPiIiIyCAGhZuEhAS92ysEBwdDoVDg5s2b1V4YERERUVUYFG6KioqgVqv12szNzVFYWPhIRSxbtgze3t5Qq9UICAjA4cOHKzXfhg0boFAoMGjQoEdaPxEREcmHQScUCyEwZswYqFQqqS0/Px+TJk3S+zq4IV8F37hxI8LCwhAREYGAgAAsWbIEISEhOHfuHFxcXMqd78qVK3jzzTfRo0cPQzaBiIiIZM6gkZvQ0FC4uLjAzs5OeowcORIeHh56bYZYvHgxxo8fj7Fjx6JVq1aIiIiApaUlVq9eXe48Wq0WI0aMwAcffAAfHx+D1kdERETyZtDIzZo1a6p15RqNBrGxsZg5c6bUZmJiguDgYMTExJQ734cffggXFxe88sor2L9/f7XWRERERPVblS7iV11u3boFrVYLV1dXvXZXV1ecPXu2zHkOHDiAVatWIS4urlLrKCgoQEFBgfQ8MzOzyvUSERFR3Vele0sZS1ZWFkaNGoWVK1fCycmpUvOEh4frHTLz8vKq4SqJiIjImIw6cuPk5ARTU1MkJyfrtScnJ8PNza1U//j4eFy5cgUDBw6U2kqusWNmZoZz586hadOmevPMnDkTYWFh0vPMzEwGHCIiIhkzarhRKpXw8/NDdHS09HVunU6H6OhoTJ06tVR/X19fnDhxQq9t9uzZyMrKwtKlS8sMLSqVSu/bXURERCRvRg03ABAWFobQ0FD4+/ujS5cuWLJkCXJycjB27FgAwOjRo+Hp6Ynw8HCo1Wq0adNGb357e3sAKNVOREREjyejh5uhQ4ciNTUVc+bMQVJSEjp06ICoqCjpJOOEhASYmNSrU4OIiIjIiBRCCGHsImpTZmYm7OzskJGRAVtb22pb7tGENDy//BAaOVpi39u9qm25REREZNjnN4dEiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhW6kS4WbZsGby9vaFWqxEQEIDDhw+X23flypXo0aMHHBwc4ODggODg4Ar7ExER0ePF6OFm48aNCAsLw9y5c3H06FG0b98eISEhSElJKbP/3r17MWzYMOzZswcxMTHw8vJC3759cePGjVqunIiIiOoio4ebxYsXY/z48Rg7dixatWqFiIgIWFpaYvXq1WX2X79+PSZPnowOHTrA19cX3377LXQ6HaKjo2u5ciIiIqqLjBpuNBoNYmNjERwcLLWZmJggODgYMTExlVpGbm4uCgsL4ejoWFNlEhERUT1iZsyV37p1C1qtFq6urnrtrq6uOHv2bKWW8c4778DDw0MvIN2voKAABQUF0vPMzMyqF0xERER1ntEPSz2KBQsWYMOGDfj111+hVqvL7BMeHg47Ozvp4eXlVctVEhERUW0yarhxcnKCqakpkpOT9dqTk5Ph5uZW4byLFi3CggUL8Oeff6Jdu3bl9ps5cyYyMjKkx7Vr16qldiIiIqqbjBpulEol/Pz89E4GLjk5ODAwsNz5PvnkE8ybNw9RUVHw9/evcB0qlQq2trZ6DyIiIpIvo55zAwBhYWEIDQ2Fv78/unTpgiVLliAnJwdjx44FAIwePRqenp4IDw8HACxcuBBz5szBDz/8AG9vbyQlJQEArK2tYW1tbbTtICIiorrB6OFm6NChSE1NxZw5c5CUlIQOHTogKipKOsk4ISEBJib3BphWrFgBjUaDF154QW85c+fOxfvvv1+bpRMREVEdZPRwAwBTp07F1KlTy5y2d+9evedXrlyp+YKIiIio3qrX35YiIiIiehDDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJipmxCyCqTjqdQHxqNo4mpCHuWgZ83WwQ2tXb2GUREVEtYrihei0zvxBxCek4mpCGownpiEtIQ2Z+kTRdoQAG+zWEtYovdSKixwXf8ane0OkELt3KxtGrJWEmDRdSsiGEfj8Lc1O0bWiHw5fv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y2jbSEQ1h4eliKhO2LJlC6ytrVFUVISCggKYmJjgq6++QkFBAebPn49du3YhMDAQAODj44MDBw7g66+/RlBQEJYtWwY7Ozts2LAB5ubmAIAWLVpIy+7du7feur755hvY29vjr7/+wjPPPFN7G0lEtYLhhojqhF69emHFihXIycnB559/DjMzMwwePBinTp1Cbm4u+vTpo9dfo9GgY8eOAIC4uDj06NFDCjYPSk5OxuzZs7F3716kpKRAq9UiNzcXCQkJNb5dRFT7GG6IqE6wsrJCs2bNAACrV69G+/btsWrVKrRp0wYAsHXrVnh6eurNo1KpAAAWFhYVLjs0NBS3b9/G0qVL0bhxY6hUKgQGBkKj0dTAlhCRsTHcEFGdY2JignfffRdhYWE4f/48VCoVEhISEBQUVGb/du3aYd26dSgsLCxz9ObgwYNYvnw5BgwYAAC4du0abt26VaPbQETGwxOKiahOevHFF2Fqaoqvv/4ab775JqZPn45169YhPj4eR48exZdffol169YBAKZOnYrMzEy89NJL+Pfff3HhwgV8//33OHfuHACgefPm+P7773HmzBn8888/GDFixENHe4io/uLIDRHVSWZmZpg6dSo++eQTXL58Gc7OzggPD8elS5dgb2+PTp064d133wUANGjQALt378Zbb72FoKAgmJqaokOHDujWrRsAYNWqVZgwYQI6deoELy8vzJ8/H2+++aYxN4+IapBCCCGMXQQRERFRdeFhKSIiIpIVhhsiIiKSFYYbIiIikhWGGyIiIpIVhhsiIiKSFYYbIiIikhWGGyIiIpIVhhsiIiKSFYYbIiIikhWGGyIiIpIVhhsiIiKSFYYbIiIikpX/D+CdOvg6nXRWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction has 92 non-zero edges.\n",
      "Ground truth has 18 non-zero edges.\n",
      "28.40 percent of potential edges are filled.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 2787.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------\n",
      "\n",
      "With threshold set as 0.1 std:\n",
      "\n",
      "precision: 0.05434782608695652 \n",
      "\n",
      "recall: 0.2777777777777778 \n",
      "\n",
      "F_1: 0.16606280193236717 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "AUPRC: 0.05003586122504615 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "p-val: 0.41858141858141856 \n",
      "\n",
      "Prediction has 92 non-zero edges.\n",
      "\n",
      "Ground truth has 18 non-zero edges.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Recall of a random matrix is 0.05604347826086956.\n",
      "\n",
      "Precision of a random matrix is 0.28644444444444445.\n",
      "\n",
      "F1 of a random matrix is 0.17124396135265701.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Model is predicting worse than random.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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KxlYvv76a9GpUydhbW0t7OzsxBNPPCGOHz9eZl8hhPj7779Fnz59hEqlEk5OTmLixIkiKyurwpqrG26EECI0NFQMHDhQCCFEZmameOWVV4Snp6ewsLAQXl5eYtSoUSIxMVHf/8cff9R/sHR2dhbPPPOMftp3330nvL29hVKpFEFBQSI6OrpG4UYIIa5evSqeffZZYWdnJ6ysrERAQIDBm+28efOEm5ubsLe3FzNnzhTTp0+vdLgpDhjNmjUTOp3OYJpOpxPLli3T/xu7uLiI0NBQsX///nJrLSwsFJ6eniImJkYIIcSWLVuEmZmZSE5OLrP/Y489JmbOnPnQOmvLnTt3xIgRI4SNjY2ws7MT48ePN/hbS0hIEADE3r179W15eXli6tSpwtHRUVhZWYmnn35aJCUl6afv2LFDdOrUSdjY2Ahra2vRsWNHERkZqQ/zxfr37y8iIiLKrc1Y4UYmRA2vr2xgMjMzYW9vj4yMjHKHnqvjeOI9PLPyMJo6WeGPtyo3ZE1U3+Xn5yMhIQHNmzcv84RJIiqyYsUKREdH8xvzK3D69Gn07dsXFy5cgL29fZl9KnrNqcr7d8M4eE5ERFSPTZ48Genp6cjKyirzFgxUdMuRb7/9ttxgY0wMN0RERDVkbm6OOXPmmLqMeu3fdxioTQ3qG4qJiIiIHobhhoiIiCSF4YaIHuoRu+6AiEzEWK81DDdEVK7ir/qv7jfNEhFVRfFrTcnbjFQHTygmonKZm5vDysoKaWlpsLCwqPItCIiIKkun0yEtLQ1WVlalbpdSVQw3RFQumUwGDw8PJCQk1PpdfImIzMzM0LRpU8hkshoth+GGiCqkUCjg6+vLQ1NEVOsUCoVRRogZbojooczMzPgNxUTUYPAAOhEREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSYrJw82KFSvg7e0NlUqFwMBAHDlypML+y5YtQ+vWrWFpaQkvLy/MnDkT+fn5dVQtERER1XcmDTebNm1CeHg45s+fj+PHj6Njx44IDQ1Fampqmf2/++47zJo1C/Pnz8fZs2exZs0abNq0Ce+8804dV05ERET1lUnDzdKlSzFx4kSMHz8ebdq0QWRkJKysrLB27doy+x8+fBg9evTAyJEj4e3tjf79+2PEiBEPHe0hIiKiR4fJwo1arcaxY8cQEhLyoBgzM4SEhCAuLq7Mebp3745jx47pw8yVK1ewfft2DBo0qNz1FBQUIDMz0+BBRERE0mVuqhXfvn0bWq0Wbm5uBu1ubm44d+5cmfOMHDkSt2/fRs+ePSGEgEajwZQpUyo8LBUREYH333/fqLUTERFR/WXyE4qrYt++fVi4cCFWrlyJ48eP46effsK2bduwYMGCcueZPXs2MjIy9I/r16/XYcVERERU10w2cuPs7Ay5XI6UlBSD9pSUFLi7u5c5z7vvvosxY8ZgwoQJAID27dsjJycHkyZNwpw5c2BmVjqrKZVKKJVK428AERER1UsmG7lRKBTw9/dHbGysvk2n0yE2NhZBQUFlzpObm1sqwMjlcgCAEKL2iiUiIqIGw2QjNwAQHh6OsLAwBAQEoFu3bli2bBlycnIwfvx4AMDYsWPRuHFjREREAACGDBmCpUuXonPnzggMDMSlS5fw7rvvYsiQIfqQQ0RERI82k4ab4cOHIy0tDfPmzUNycjI6deqEmJgY/UnGiYmJBiM1c+fOhUwmw9y5c3Hz5k24uLhgyJAh+Oijj0y1CURERFTPyMQjdjwnMzMT9vb2yMjIgJ2dndGWezzxHp5ZeRhNnazwx1t9jLZcIiIiqtr7d4O6WoqIiIjoYRhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFJMHm5WrFgBb29vqFQqBAYG4siRIxX2T09Px7Rp0+Dh4QGlUolWrVph+/btdVQtERER1Xfmplz5pk2bEB4ejsjISAQGBmLZsmUIDQ3F+fPn4erqWqq/Wq1Gv3794Orqii1btqBx48a4du0aHBwc6r54IiIiqpdMGm6WLl2KiRMnYvz48QCAyMhIbNu2DWvXrsWsWbNK9V+7di3u3r2Lw4cPw8LCAgDg7e1dlyUTERFRPWeyw1JqtRrHjh1DSEjIg2LMzBASEoK4uLgy54mOjkZQUBCmTZsGNzc3tGvXDgsXLoRWqy13PQUFBcjMzDR4EBERkXSZLNzcvn0bWq0Wbm5uBu1ubm5ITk4uc54rV65gy5Yt0Gq12L59O9599118+umn+PDDD8tdT0REBOzt7fUPLy8vo24HERER1S8mP6G4KnQ6HVxdXfH111/D398fw4cPx5w5cxAZGVnuPLNnz0ZGRob+cf369TqsmIiIiOqayc65cXZ2hlwuR0pKikF7SkoK3N3dy5zHw8MDFhYWkMvl+rbHHnsMycnJUKvVUCgUpeZRKpVQKpXGLZ6IiIjqLZON3CgUCvj7+yM2NlbfptPpEBsbi6CgoDLn6dGjBy5dugSdTqdvu3DhAjw8PMoMNkRERPToMelhqfDwcKxevRobNmzA2bNn8fLLLyMnJ0d/9dTYsWMxe/Zsff+XX34Zd+/exYwZM3DhwgVs27YNCxcuxLRp00y1CURERFTPmPRS8OHDhyMtLQ3z5s1DcnIyOnXqhJiYGP1JxomJiTAze5C/vLy8sHPnTsycORMdOnRA48aNMWPGDLz99tum2gQiIiKqZ2RCCGHqIupSZmYm7O3tkZGRATs7O6Mt93jiPTyz8jCaOlnhj7f6GG25REREVLX372qN3Gi1Wqxfvx6xsbFITU01OAcGAPbs2VOdxRIRERHVWLXCzYwZM7B+/XoMHjwY7dq1g0wmM3ZdRERERNVSrXATFRWFH374AYMGDTJ2PUREREQ1Uq2rpRQKBVq2bGnsWoiIiIhqrFrh5vXXX8fy5cvxiJ2LTERERA1AtQ5LHTx4EHv37sWOHTvQtm1b/R26i/30009GKY6IiIioqqoVbhwcHPD0008buxYiIiKiGqtWuFm3bp2x6yAiIiIyihp9Q3FaWhrOnz8PAGjdujVcXFyMUhQRERFRdVXrhOKcnBy8+OKL8PDwwOOPP47HH38cnp6eeOmll5Cbm2vsGomIiIgqrVrhJjw8HPv378dvv/2G9PR0pKen49dff8X+/fvx+uuvG7tGIiIiokqr1mGpH3/8EVu2bEHv3r31bYMGDYKlpSWGDRuGVatWGas+IiIioiqp1shNbm6u/s7dJbm6uvKwFBEREZlUtcJNUFAQ5s+fj/z8fH1bXl4e3n//fQQFBRmtOCIiIqKqqtZhqeXLlyM0NBRNmjRBx44dAQAnT56ESqXCzp07jVogERERUVVUK9y0a9cOFy9exMaNG3Hu3DkAwIgRIzBq1ChYWloatUAiIiKiqqj299xYWVlh4sSJxqyFiIiIqMYqHW6io6MxcOBAWFhYIDo6usK+Tz31VI0LIyIiIqqOSoeboUOHIjk5Ga6urhg6dGi5/WQyGbRarTFqIyIiIqqySocbnU5X5u9ERERE9Um1LgUvS3p6urEWRURERFRt1Qo3ixcvxqZNm/TPn3/+eTg5OaFx48Y4efKk0YojIiIiqqpqhZvIyEh4eXkBAHbt2oXdu3cjJiYGAwcOxJtvvmnUAomIiIiqolqXgicnJ+vDzdatWzFs2DD0798f3t7eCAwMNGqBRERERFVRrZEbR0dHXL9+HQAQExODkJAQAIAQgldKERERkUlVa+TmmWeewciRI+Hr64s7d+5g4MCBAIATJ06gZcuWRi2QiIiIqCqqFW4+++wzeHt74/r16/j4449hY2MDAEhKSsLUqVONWiARERFRVVQr3FhYWOCNN94o1T5z5swaF0RERERUE7z9AhEREUkKb79AREREksLbLxAREZGkGO32C0RERET1QbXCzauvvorPP/+8VPuXX36J1157raY1EREREVVbtcLNjz/+iB49epRq7969O7Zs2VLjooiIiIiqq1rh5s6dO7C3ty/Vbmdnh9u3b9e4KCIiIqLqqla4admyJWJiYkq179ixAz4+PjUuioiIiKi6qvUlfuHh4Zg+fTrS0tLQt29fAEBsbCw+/fRTLFu2zJj1EREREVVJtcLNiy++iIKCAnz00UdYsGABAMDb2xurVq3C2LFjjVogERERUVVUK9wAwMsvv4yXX34ZaWlpsLS01N9fioiIiMiUqv09NxqNBrt378ZPP/0EIQQA4NatW8jOzjZacURERERVVa2Rm2vXrmHAgAFITExEQUEB+vXrB1tbWyxevBgFBQWIjIw0dp1ERERElVKtkZsZM2YgICAA9+7dg6Wlpb796aefRmxsrNGKIyIiIqqqao3cHDhwAIcPH4ZCoTBo9/b2xs2bN41SGBEREVF1VGvkRqfTlXnn7xs3bsDW1rbGRRERERFVV7XCTf/+/Q2+z0YmkyE7Oxvz58/HoEGDjFUbERERUZVV67DUkiVLMGDAALRp0wb5+fkYOXIkLl68CGdnZ3z//ffGrpGIiIio0qoVbry8vHDy5Els2rQJJ0+eRHZ2Nl566SWMGjXK4ARjIiIiorpW5XBTWFgIPz8/bN26FaNGjcKoUaNqoy4iIiKiaqnyOTcWFhbIz8+vjVqIiIiIaqxaJxRPmzYNixcvhkajMXY9RERERDVSrXNujh49itjYWPz+++9o3749rK2tDab/9NNPRimOiIiIqKqqFW4cHBzw7LPPGrsWIiIiohqrUrjR6XT45JNPcOHCBajVavTt2xfvvfcer5AiIiKieqNK59x89NFHeOedd2BjY4PGjRvj888/x7Rp02qrNiIiIqIqq1K4+fbbb7Fy5Urs3LkTv/zyC3777Tds3LgROp2utuojIiIiqpIqhZvExESD2yuEhIRAJpPh1q1bRi+MiIiIqDqqFG40Gg1UKpVBm4WFBQoLC2tUxIoVK+Dt7Q2VSoXAwEAcOXKkUvNFRUVBJpNh6NChNVo/ERERSUeVTigWQmDcuHFQKpX6tvz8fEyZMsXgcvCqXAq+adMmhIeHIzIyEoGBgVi2bBlCQ0Nx/vx5uLq6ljvf1atX8cYbb6BXr15V2QQiIiKSuCqN3ISFhcHV1RX29vb6x+jRo+Hp6WnQVhVLly7FxIkTMX78eLRp0waRkZGwsrLC2rVry51Hq9Vi1KhReP/99+Hj41Ol9REREZG0VWnkZt26dUZduVqtxrFjxzB79mx9m5mZGUJCQhAXF1fufB988AFcXV3x0ksv4cCBA0atiYiIiBq2an2Jn7Hcvn0bWq0Wbm5uBu1ubm44d+5cmfMcPHgQa9asQXx8fKXWUVBQgIKCAv3zzMzMatdLRERE9V+17i1lKllZWRgzZgxWr14NZ2fnSs0TERFhcMjMy8urlqskIiIiUzLpyI2zszPkcjlSUlIM2lNSUuDu7l6q/+XLl3H16lUMGTJE31b8HTvm5uY4f/48WrRoYTDP7NmzER4ern+emZnJgENERCRhJg03CoUC/v7+iI2N1V/OrdPpEBsbi+nTp5fq7+fnh1OnThm0zZ07F1lZWVi+fHmZoUWpVBpc3UVERETSZtJwAwDh4eEICwtDQEAAunXrhmXLliEnJwfjx48HAIwdOxaNGzdGREQEVCoV2rVrZzC/g4MDAJRqJyIiokeTycPN8OHDkZaWhnnz5iE5ORmdOnVCTEyM/iTjxMREmJk1qFODiIiIyIRkQghh6iLqUmZmJuzt7ZGRkQE7OzujLfd44j08s/IwmjpZ4Y+3+hhtuURERFS1928OiRAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpNSLcLNixQp4e3tDpVIhMDAQR44cKbfv6tWr0atXLzg6OsLR0REhISEV9iciIqJHi8nDzaZNmxAeHo758+fj+PHj6NixI0JDQ5Gamlpm/3379mHEiBHYu3cv4uLi4OXlhf79++PmzZt1XDkRERHVRyYPN0uXLsXEiRMxfvx4tGnTBpGRkbCyssLatWvL7L9x40ZMnToVnTp1gp+fH7755hvodDrExsbWceVERERUH5k03KjVahw7dgwhISH6NjMzM4SEhCAuLq5Sy8jNzUVhYSGcnJxqq0wiIiJqQMxNufLbt29Dq9XCzc3NoN3NzQ3nzp2r1DLefvtteHp6GgSkkgoKClBQUKB/npmZWf2CiYiIqN4z+WGpmli0aBGioqLw888/Q6VSldknIiIC9vb2+oeXl1cdV0lERER1yaThxtnZGXK5HCkpKQbtKSkpcHd3r3DeJUuWYNGiRfj999/RoUOHcvvNnj0bGRkZ+sf169eNUjsRERHVTyYNNwqFAv7+/gYnAxefHBwUFFTufB9//DEWLFiAmJgYBAQEVLgOpVIJOzs7gwcRERFJl0nPuQGA8PBwhIWFISAgAN26dcOyZcuQk5OD8ePHAwDGjh2Lxo0bIyIiAgCwePFizJs3D9999x28vb2RnJwMALCxsYGNjY3JtoOIiIjqB5OHm+HDhyMtLQ3z5s1DcnIyOnXqhJiYGP1JxomJiTAzezDAtGrVKqjVajz33HMGy5k/fz7ee++9uiydiIiI6iGThxsAmD59OqZPn17mtH379hk8v3r1au0XRERERA1Wg75aioiIiOjfGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUsxNXQAREdGjRAiBvEItcgq0yCnQIEetQa5aC61OoEtTRyjMOe5QUww3ZCC7QINdZ5LRxNEKXb2dTF1OvZSRW4hLadm4kpaNy2k58HGxxrAAL1OXRUS1RK3R6UNIToG2KIwUaJFdoEGuWnN/mha5BRpkF2iRq9bcn1YivOj7F80vRNnrmtCzOeY+2QbAgxCUq9Yit3i96uLlFq2neL256rKeP6g1t7DoZ6FWh7cH+mFUYDOj7BshBPILdchVa5BXqEWeWotCrUBrd1vIzWRGWUd1MNwQhBCIv56OqCPX8dvft5Cr1qKRtQLH3u1n6tJMRqsTuHkvD5fTsu8/cnD5fqC5na0u1f8JP1c0slFWe31CCGTmaXD9Xi5u3MvDDf3Pot+bOFrhqzH+Jn2xIOMr0GiRkVeIzLxCZORp7v8sRGZ+IVTmcvynsyeU5nJTl1nvCSEgkxX939DqhP4NPac4ePxrhETfdn96rrpkUNGWaivUlpNEjMBaIYeV0hxpWQUAgG8OJuDXk7eKAkqhttwQVBNLdp5HSxcb5BZqkX8/BOUWapGn1iBPrUNuoQZ599uLA0tReNEh7/4+zCueVk6Nz/k3wZLnOxq/+EpiuHmEpeeq8fOJm4g6ch3nU7IMpmUXaExUVd3KKdDgyv3gUvy4kpaDK7dzoNboyp3P3U6FFq7WiLt8BzoB5FfQF3h4eLl5Lw9ZFezzc8lZuJKWDV8322pvKxmfEAI56pIBpdDg98y8QmTma0q1Fz8KHvJ3o7Qww386NTZqvfmFOmQVFCIrXwOF3AxeTlbVWlahtmg0Iyu/aJQip0CDrAINsvOLfs++P83cTIbR/68ZHK0VBnXkFWrvz6fV98/OLwogxcvLLg4lBQ/acu6PgBQHk+wCDfILi/ajysJM/3ttUJqbwVppDiuFHDb3f1orzWGtMIeVsrjNHDZKOawU5rBWlphe3Fd5v11hDksLOczuf2DZez4V49cdBQB90CnJSiG//3iwrOK24vVbK8xhWcHzuMt38MnO87iXW4jhX/9ZK/un+G/6Slq20ZdfFQw3jxghBP68chebjiZi+z/J+jdwpbkZBrf3QHBrF8yIiq/1GpIy8uFkrYDKwrifStUaHa7eycGFlCxcSs1GazdbDGjnjqSM/FIh5nJqDpIz88tdlsLcDD7O1vBxsUYLFxv9o7mLNWyURf91Ws/dgQKNDkIIZOQWVju8FHO2UaKJo+X9hxWaOFpi0Y5zyC7QoPY+Oz7atDpxP4SUDCclAkm+YWgxCDH5Gmh1NfuXkckAW6U57K0sYG9pATuVBS6lZiM1qwDpuYUGdWbna/TBpChUFP2emV8UDLLyC/VhIyu/8EH7/X7Z+Rpo/lXv2KBm6N6iEbJKhpLiQJH/IKTkqA2fPyyYlfTprgto4WJtMIJSw91WppLBRm4mg3WJEFAcPIrDRckQYqN8EAaKwojcoF/xMizktXcuTO9WLtj+ai/kqjX6YFQcTEqGoJpwt1Pht5O3kJ5bCCtF0fKtFHKoLB4EJ0uFHJb3n1sq5LCyKPppqTCH1f12VXHQsjCHSmFWNJ+FHHIzGX4/nYxJ/z1mhD1SMww3j4i0rAL8ePwGNh29joTbOfp2P3dbjOjWFEM7NYa9lQVupucZfd05BRr8fSMDJ67fw4nEdJxITMft7AL4OFsj9vVg/XByVRRqdbh6OwcXUrJxISULF1OzcCElG1dv55R68ZbJUOHQrrONAj768PIgyDR2tKz0YaD+n/2BXLX2of3KCi/Fvzd2sISlonTY+2zXBWSX/iBnFFqdwN0cNW5nF6CRtQKudqraWVENFY+QpOeqkZ5bFCzScwuRnlfyedHvqVkFmNjLB4VaXZmjJUVhRaMPKpUJnQ9jIZcVBZP74cTe8n5QsTR/8LtB+4OftkrzUm9c0zYex7ZTSZgffRor9126P6Lx8L+vyir5f+LbuGv4Nu5atZelsjCDjdICNko5bFRFQaH4+S/xt/T9LqfllJpXJgOs74cL6/sjH8WjG8Vt1kpz2CgetNmoin9/MCpyL1cNhbmZwQiJ0tysWq8tpiKTydDG065W1+HpYImY1x6v1XV0auqANWEBsLe0qNX1PAzDjYRpdQIHLqYh6sh17D6bon/Tt1bI8VQnT7zQtSk6NLE36guATieQcCcHJxLTcTyxKMycT84s81Palds50OoEzOXlr79Qq8O1OyVCzP2fCWWEmGI2SnO0cLXByevpAIpexM3NZGjayKrECIw1WrjaoIWzDeytqv+f0MNehat3cvXBpjrhxdjyC7W4nV2A29lq3Mku0P9+O7sAd/71826uWv8mZyGX4dDbfWsccHQ6gawCDdJz1biXW4h7ueqi33MK4WStQO/WLiXCSVEo0T+/H1gyyphW3r93WaZ9d7zKdVsp5AZBxK6igGJlGFZUFsZ9I/Wwf/BvkJJpmGyV5mawVZnDVmUB2/thouhn0XM7VVEAMJxucX+eot+tLOQ4fPkOPth6GjLIHoQSVVGQsDFY7v0woTKHbXG4UBRNs1aaVziasfi5Djh06TZ0OhgEluJlGmtEorqH1sj4XG1VeOIx039IYrhpYAo0WshlMphX8IJyKz0Pm/+6gR/+um4wEtPJywEjunnhyQ6esFYa558+I68QJ68/CDLx19ORkVdYqp+nvQqdmzqic1MHtHCxwfj1Rw2ma7Q6XL2Ti4spRSMwF1KzcPF+iCnvZD5rhRwt3WzRytUGrdxs4etW9NPDXgWZTIaE2zm4lJoNHxdrNHWyqpUh5ahJQTifkoXGDpa1Hl6upGUjPbfwflgpGVhKBhl1lc+XKv4UX6gVuJGeZxBu8gu1SL8fUO7dHxnR/8xR6wPIvRLtGXmFNT5UUx6F3AwOVhZFD0sF7K0s4GB5/7mVArvPpuDGvTy42SlLBRK7f42aFE0z17fV5iGHqnojtDWCW7vA3MzMIJTYKM2NdplwT19n/D4z2CjLKo/SXI6+fm61ug6isjDcNBA5BRp8tf8yvj5wBd2aN8K3L3YzmF6o1WHPuVREHUnE/gtp+pESO5U5nunSBC9084Kfe82GPLU6gQspWfcPLd3DievpuJRa+qQxpbkZOjSxLwozXg7o3NQR7iU+iWaUOI9gxqZ4XErJxpXb2eWGGCuFHL6uNvB1s0Urt+KftvC8H2LK09zZGs2drWuwxQ/nbq8y2LbaNOX/Kj8aoZCbwdlGgUY2yhI/i353tlGiUYmfTlYK9P10PxLv5mLU6v/B29n6fmBR1+jkTCuF/H7wUMDR2gKHLt0pNc3eSlEinFjA3lJxP7j86/n9MPOwEZJpfVpWu976RGUhRy9fF1OXQdRgMdzUc1qdwOa/ruPTXRf0Z9Cfvpmhn37tTg42Hb2OzcduGJxhH9jcCSO6NcWAdu7VPmn3dnYB4hPT9efKnLyeXuZx/2aNrPQhpktTR/h52Fb4KVgul+lHC7b9naRvt7SQw9fNBr6uRSGmeDTG097SKEPXDVWPls6IPnkLtkpzONsq0cjaMKA8CCwPgoydyrxKh0kcrSyQeBfIK9TibFKmwTS5mQyO90dG9GHFygKO1kXBw7Fku3XR86JDNYZ/d0II3MsthLVSzsubiahWMdzUY39cSMPC7WdxLrnoMm1HKwvcyy2EVghEn7yFqCOJOHz5wadhZxsFnvVvguEBXvBxsanRugs0OgR8uLtUu7VCjk5NHdDZq+gQUycvhyp/v4uN0hzvDm6D07cy7x9KKgo0jR0e7RBTns9HdMaS5zvW6reWfja8Ew5duq0/ZONopSgKLdZFJ7wa43wSmUwGpxKXAxMR1RaGm3roQkoWPtp2FvsvpAEoOrT06hO++H8+jfDkFweRnluIV78/AaDofIlevi4Y0dULTzzmVuM3QDuVucF3Rfi62qBzUwf9+TK+rsb51skXezav8TIeJbX9dew+LjY1DsRERPUFw009kpZVgM92X0DUkUTo7l/hMyaoGV7t6wtHawVulTg52MNehecDvPC8fxOjXilgq7LAL9N6IC2rAB2aOJj8cj4iIqKqYripB/ILtVhzMAEr917Sn9MyoK073h7oZ3BCrKeDJb4ZGwC5XIbHfV1q7av4/dzt4OdeK4smIiKqdQw3JqTTCfx68iY+iTmPWxlF35TbsYk95gxug27Ny75pZUgbXlZJRERUEYYbE/nflTv4aPtZ/H2j6MonT3sV3hrgh6c6evKkWiIiohpguKljCbdzELH9LH4/kwKg6Mqhl3u3wEs9mxv9PktERESPIoabOnIvR43lsRfxf39eg0YnYCYDRnRripn9WsG5ipdSExERUfkYbmpZgUaL/8Zdw+exF5GZX/S1+H1au+CdQY/B183WxNURERFJT724mcqKFSvg7e0NlUqFwMBAHDlypML+mzdvhp+fH1QqFdq3b4/t27fXUaWVJ4TA9lNJ6Lf0D3y47Swy8zXwc7fF/70UiHXjuzHYEBER1RKTh5tNmzYhPDwc8+fPx/Hjx9GxY0eEhoYiNTW1zP6HDx/GiBEj8NJLL+HEiRMYOnQohg4din/++aeOKy/ficR7eD4yDlM3Hkfi3Vy42irx8bMdsO3VXujp62zq8oiIiCRNJoSondv3VlJgYCC6du2KL7/8EgCg0+ng5eWFV155BbNmzSrVf/jw4cjJycHWrVv1bf/v//0/dOrUCZGRkQ9dX2ZmJuzt7ZGRkQE7u5rdSLKk44n38MzKwzCTQX/TSpWFGSY93gKTH/cx2l24iYiIHkVVef826ciNWq3GsWPHEBISom8zMzNDSEgI4uLiypwnLi7OoD8AhIaGltu/oKAAmZmZBo/apBNFt0R4zr8J9r3RB+H9WjHYEBER1SGTvuvevn0bWq0Wbm6GX0zn5uaGc+fOlTlPcnJymf2Tk5PL7B8REYH333/fOAVXoJWbLfzcbeFqp8LbA1qjrad9ra+TiIiISpP8kMLs2bMRHh6uf56ZmQkvLy+jr8dGaY6Y1x43+nKJiIioakwabpydnSGXy5GSkmLQnpKSAnf3sm9u5O7uXqX+SqUSSiW/R4aIiOhRYdJzbhQKBfz9/REbG6tv0+l0iI2NRVBQUJnzBAUFGfQHgF27dpXbn4iIiB4tJj8sFR4ejrCwMAQEBKBbt25YtmwZcnJyMH78eADA2LFj0bhxY0RERAAAZsyYgeDgYHz66acYPHgwoqKi8Ndff+Hrr7825WYQERFRPWHycDN8+HCkpaVh3rx5SE5ORqdOnRATE6M/aTgxMRFmZg8GmLp3747vvvsOc+fOxTvvvANfX1/88ssvaNeunak2gYiIiOoRk3/PTV2rre+5ISIiotrTYL7nhoiIiMjYGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFJMfvuFulb8hcyZmZkmroSIiIgqq/h9uzI3Vnjkwk1WVhYAwMvLy8SVEBERUVVlZWXB3t6+wj6P3L2ldDodbt26BVtbW8hkMqMuOzMzE15eXrh+/TrvW1WLuJ/rBvdz3eB+rjvc13WjtvazEAJZWVnw9PQ0uKF2WR65kRszMzM0adKkVtdhZ2fH/zh1gPu5bnA/1w3u57rDfV03amM/P2zEphhPKCYiIiJJYbghIiIiSWG4MSKlUon58+dDqVSauhRJ436uG9zPdYP7ue5wX9eN+rCfH7kTiomIiEjaOHJDREREksJwQ0RERJLCcENERESSwnBDREREksJwU0UrVqyAt7c3VCoVAgMDceTIkQr7b968GX5+flCpVGjfvj22b99eR5U2bFXZz6tXr0avXr3g6OgIR0dHhISEPPTfhYpU9e+5WFRUFGQyGYYOHVq7BUpEVfdzeno6pk2bBg8PDyiVSrRq1YqvHZVQ1f28bNkytG7dGpaWlvDy8sLMmTORn59fR9U2TH/88QeGDBkCT09PyGQy/PLLLw+dZ9++fejSpQuUSiVatmyJ9evX13qdEFRpUVFRQqFQiLVr14rTp0+LiRMnCgcHB5GSklJm/0OHDgm5XC4+/vhjcebMGTF37lxhYWEhTp06VceVNyxV3c8jR44UK1asECdOnBBnz54V48aNE/b29uLGjRt1XHnDUtX9XCwhIUE0btxY9OrVS/znP/+pm2IbsKru54KCAhEQECAGDRokDh48KBISEsS+fftEfHx8HVfesFR1P2/cuFEolUqxceNGkZCQIHbu3Ck8PDzEzJkz67jyhmX79u1izpw54qeffhIAxM8//1xh/ytXrggrKysRHh4uzpw5I7744gshl8tFTExMrdbJcFMF3bp1E9OmTdM/12q1wtPTU0RERJTZf9iwYWLw4MEGbYGBgWLy5Mm1WmdDV9X9/G8ajUbY2tqKDRs21FaJklCd/azRaET37t3FN998I8LCwhhuKqGq+3nVqlXCx8dHqNXquipREqq6n6dNmyb69u1r0BYeHi569OhRq3VKSWXCzVtvvSXatm1r0DZ8+HARGhpai5UJwcNSlaRWq3Hs2DGEhITo28zMzBASEoK4uLgy54mLizPoDwChoaHl9qfq7ed/y83NRWFhIZycnGqrzAavuvv5gw8+gKurK1566aW6KLPBq85+jo6ORlBQEKZNmwY3Nze0a9cOCxcuhFarrauyG5zq7Ofu3bvj2LFj+kNXV65cwfbt2zFo0KA6qflRYar3wUfuxpnVdfv2bWi1Wri5uRm0u7m54dy5c2XOk5ycXGb/5OTkWquzoavOfv63t99+G56enqX+Q9ED1dnPBw8exJo1axAfH18HFUpDdfbzlStXsGfPHowaNQrbt2/HpUuXMHXqVBQWFmL+/Pl1UXaDU539PHLkSNy+fRs9e/aEEAIajQZTpkzBO++8UxclPzLKex/MzMxEXl4eLC0ta2W9HLkhSVm0aBGioqLw888/Q6VSmbocycjKysKYMWOwevVqODs7m7ocSdPpdHB1dcXXX38Nf39/DB8+HHPmzEFkZKSpS5OUffv2YeHChVi5ciWOHz+On376Cdu2bcOCBQtMXRoZAUduKsnZ2RlyuRwpKSkG7SkpKXB3dy9zHnd39yr1p+rt52JLlizBokWLsHv3bnTo0KE2y2zwqrqfL1++jKtXr2LIkCH6Np1OBwAwNzfH+fPn0aJFi9otugGqzt+zh4cHLCwsIJfL9W2PPfYYkpOToVaroVAoarXmhqg6+/ndd9/FmDFjMGHCBABA+/btkZOTg0mTJmHOnDkwM+Nnf2Mo733Qzs6u1kZtAI7cVJpCoYC/vz9iY2P1bTqdDrGxsQgKCipznqCgIIP+ALBr165y+1P19jMAfPzxx1iwYAFiYmIQEBBQF6U2aFXdz35+fjh16hTi4+P1j6eeegp9+vRBfHw8vLy86rL8BqM6f889evTApUuX9OERAC5cuAAPDw8Gm3JUZz/n5uaWCjDFgVLwlotGY7L3wVo9XVlioqKihFKpFOvXrxdnzpwRkyZNEg4ODiI5OVkIIcSYMWPErFmz9P0PHTokzM3NxZIlS8TZs2fF/PnzeSl4JVR1Py9atEgoFAqxZcsWkZSUpH9kZWWZahMahKru53/j1VKVU9X9nJiYKGxtbcX06dPF+fPnxdatW4Wrq6v48MMPTbUJDUJV9/P8+fOFra2t+P7778WVK1fE77//Llq0aCGGDRtmqk1oELKyssSJEyfEiRMnBACxdOlSceLECXHt2jUhhBCzZs0SY8aM0fcvvhT8zTffFGfPnhUrVqzgpeD10RdffCGaNm0qFAqF6Natm/jzzz/104KDg0VYWJhB/x9++EG0atVKKBQK0bZtW7Ft27Y6rrhhqsp+btasmQBQ6jF//vy6L7yBqerfc0kMN5VX1f18+PBhERgYKJRKpfDx8REfffSR0Gg0dVx1w1OV/VxYWCjee+890aJFC6FSqYSXl5eYOnWquHfvXt0X3oDs3bu3zNfb4n0bFhYmgoODS83TqVMnoVAohI+Pj1i3bl2t1ykTguNvREREJB0854aIiIgkheGGiIiIJIXhhoiIiCSF4YaIiIgkheGGiIiIJIXhhoiIiCSF4YaIiIgkheGGiAiATCbDL7/8AgC4evUqZDIZ74BO1EAx3BCRyY0bNw4ymQwymQwWFhZo3rw53nrrLeTn55u6NCJqgHhXcCKqFwYMGIB169ahsLAQx44dQ1hYGGQyGRYvXmzq0oiogeHIDRHVC0qlEu7u7vDy8sLQoUMREhKCXbt2ASi6w3NERASaN28OS0tLdOzYEVu2bDGY//Tp03jyySdhZ2cHW1tb9OrVC5cvXwYAHD16FP369YOzszPs7e0RHByM48eP1/k2ElHdYLghonrnn3/+weHDh6FQKAAAERER+PbbbxEZGYnTp09j5syZGD16NPbv3w8AuHnzJh5//HEolUrs2bMHx44dw4svvgiNRgMAyMrKQlhYGA4ePIg///wTvr6+GDRoELKysky2jURUe3hYiojqha1bt8LGxgYajQYFBQUwMzPDl19+iYKCAixcuBC7d+9GUFAQAMDHxwcHDx7EV199heDgYKxYsQL29vaIioqChYUFAKBVq1b6Zfft29dgXV9//TUcHBywf/9+PPnkk3W3kURUJxhuiKhe6NOnD1atWoWcnBx89tlnMDc3x7PPPovTp08jNzcX/fr1M+ivVqvRuXNnAEB8fDx69eqlDzb/lpKSgrlz52Lfvn1ITU2FVqtFbm4uEhMTa327iKjuMdwQUb1gbW2Nli1bAgDWrl2Ljh07Ys2aNWjXrh0AYNu2bWjcuLHBPEqlEgBgaWlZ4bLDwsJw584dLF++HM2aNYNSqURQUBDUanUtbAkRmRrDDRHVO2ZmZnjnnXcQHh6OCxcuQKlUIjExEcHBwWX279ChAzZs2IDCwsIyR28OHTqElStXYtCgQQCA69ev4/bt27W6DURkOjyhmIjqpeeffx5yuRxfffUV3njjDcycORMbNmzA5cuXcfz4cXzxxRfYsGEDAGD69OnIzMzECy+8gL/++gsXL17Ef//7X5w/fx4A4Ovri//+9784e/Ys/ve//2HUqFEPHe0hooaLIzdEVC+Zm5tj+vTp+Pjjj5GQkAAXFxdERETgypUrcHBwQJcuXfDOO+8AABo1aoQ9e/bgzTffRHBwMORyOTp16oQePXoAANasWYNJkyahS5cu8PLywsKFC/HGG2+YcvOIqBbJhBDC1EUQERERGQsPSxEREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaQw3BAREZGkMNwQERGRpDDcEBERkaT8fzTpWdJfIt3JAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction has 64 non-zero edges.\n",
      "Ground truth has 18 non-zero edges.\n",
      "19.75 percent of potential edges are filled.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 3029.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------\n",
      "\n",
      "With threshold set as 0.1 std:\n",
      "\n",
      "precision: 0.0625 \n",
      "\n",
      "recall: 0.2222222222222222 \n",
      "\n",
      "F_1: 0.1423611111111111 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "AUPRC: 0.050275531418871214 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "p-val: 0.2897102897102897 \n",
      "\n",
      "Prediction has 64 non-zero edges.\n",
      "\n",
      "Ground truth has 18 non-zero edges.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Recall of a random matrix is 0.05634375.\n",
      "\n",
      "Precision of a random matrix is 0.2003333333333333.\n",
      "\n",
      "F1 of a random matrix is 0.12833854166666667.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Model is predicting better than random.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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a7jp378/3n//fTz11FPV6h8dHY0mTZrg448/xiOPPIIpU6bg2WefxSeffFLDld5fUYkWVzPykZJVaO5SiAhAv379kJycjLNnz+LVV1/FO++8g48++qjCvqb6gkIvLy+oVCqT931Q7733HpKTk/Hvv/9ixIgRGDduHLZt21Yr664ravJLKJOSkrB582aMHj263LT9+/ejoKAAzz77LNauXVvh/OPGjUNycjJOnjyJwYMHY/Lkyfjuu+9qrN7hw4fjxIkT2LlzJzZv3ozff/8d48ePr3KeadOmYdOmTdiwYQN+++03XL9+HU8//XS5fqtXr0ZycrL0GDRokDRNqVRi2LBh+PTTT029SeXUq3Nu4uPjERYWptcWHh6O+Pj4SucpKipCdna23qMmnLiejR4L9mDwF5XXQkS1R6VSwcvLC40bN8ZLL72EsLAwxMbGAigd2Rk0aBA++OAD+Pj4oFWrVgCAK1euYPDgwXB2doarqyv++9//4tKlS3rLXbVqFdq0aQOVSgVvb29MmTJFmnb3oSaNRoMpU6bA29sbarUajRs3RlRUVIV9AeD48ePo3bs3bGxs0KBBA4wfP17v03RZzQsXLoS3tzcaNGiAyZMno7i4+L77wsHBAV5eXmjatCnefPNNuLq6YufOndL0zMxMjB07Fu7u7nB0dETv3r1x7NgxvWVs2rQJXbp0gVqthpubm96H0m+++QZBQUHSeoYNG4a0tLT71lWVq1evYujQoXB1dYWdnR2CgoLw559/6u2Lu73yyit47LHHpOePPfYYpkyZgldeeQVubm4IDw/HsGHDMGTIEL35iouL4ebmhq+//hpA6XetREVFoUmTJrCxsUGHDh2wcePGKmv9/vvv0aFDB/j6+pabtnLlSgwbNgwjR47EqlWrKpzf1tZW+vd555130KJFC+lv1dROnTqF7du346uvvkJwcDB69OiBzz77DDExMbh+/XqF82RlZWHlypVYtGgRevfujcDAQKxevRoHDx7EH3/8odfX2dkZXl5e0kOtVutNHzhwIGJjY1FQUFAj21emXoWblJQUeHp66rV5enoiOzu70h0VFRUFJycn6eHn51cbpRLJkhAC+ZoSszyEEA9Uu42Njd6n97i4OCQmJkqfXouLixEeHg4HBwfs27cPBw4cgL29Pfr16yfNt3z5ckyePBnjx4/H8ePHERsbi+bN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adrdgeXLL78UHTt2FHZ2dsLR0VE8/vjj4vDhwxX2FUKIf/75R/Tq1Uuo1Wrh6uoqxo0bJ3Jycqqs2dhwI4QQ4eHhon///kIIIbKzs8XLL78sfHx8hLW1tfDz8xPDhw8XSUlJUv8ffvhB+mDp5uYmnn76aWnat99+K/z9/YVKpRIhISEiNjb2gcKNEEJcunRJPPPMM8LR0VHY2tqKoKAgvTfb2bNnC09PT+Hk5CSmTZsmpkyZUu1wUxYwGjduLHQ6nd40nU4nFi9eLP0bu7u7i/DwcPHbb79VWmtxcbHw8fER27dvF0IIsXHjRmFhYSFSUlIq7P/II4+IadOm3bfOmnLz5k0xdOhQYW9vLxwdHcWYMWP0/tYuXrwoAIg9e/ZIbQUFBWLSpEnCxcVF2NraiqeeekokJydL07dt2yY6duwo7O3thZ2dnejQoYOIjo6WwnyZvn37iqioqEprM1W4UQjxgNdX1jPZ2dlwcnJCVlZWpUPPxjiclIGnlx1EI1db/P5G9Yasieq6wsJCXLx4EU2aNKnwhEkiKrV06VLExsbyG/OrcOLECfTu3RtnzpyBk5NThX2qes0x5P27fhw8JyIiqsMmTJiAzMxM5OTkVHgLBiq95cjXX39dabAxJYYbIiKiB2RlZYWZM2eau4w67d47DNSkevUNxURERET3w3BDREREssJwQ0T39ZBdd0BEZmKq1xqGGyKqVNlX/Rv7TbNERIYoe625+zYjxuAJxURUKSsrK9ja2iI9PR3W1tYG34KAiKi6dDod0tPTYWtrW+52KYZiuCGiSikUCnh7e+PixYs1fhdfIiILCws0atQICoXigZbDcENEVVIqlWjRogUPTRFRjVMqlSYZIWa4IaL7srCw4DcUE1G9wQPoREREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkKww3REREJCsMN0RERCQrDDdEREQkK2YPN0uXLoW/vz/UajWCg4Px119/Vdl/8eLFaNWqFWxsbODn54dp06ahsLCwlqolIiKius6s4Wb9+vWIjIzEnDlzcPjwYXTo0AHh4eFIS0ursP+3336L6dOnY86cOTh16hRWrlyJ9evX46233qrlyomIiKiuMmu4WbRoEcaNG4cxY8agdevWiI6Ohq2tLVatWlVh/4MHD6J79+4YNmwY/P390bdvXwwdOvS+oz1ERET08DBbuNFoNEhISEBYWNidYiwsEBYWhvj4+Arn6datGxISEqQwc+HCBWzduhUDBgyodD1FRUXIzs7WexAREZF8WZlrxTdu3IBWq4Wnp6deu6enJ06fPl3hPMOGDcONGzfQo0cPCCFQUlKCiRMnVnlYKioqCu+++65JayciIqK6y+wnFBti7969mDdvHpYtW4bDhw/jxx9/xJYtWzB37txK55kxYwaysrKkx5UrV2qxYiIiIqptZhu5cXNzg6WlJVJTU/XaU1NT4eXlVeE8b7/9NkaOHImxY8cCANq1a4e8vDyMHz8eM2fOhIVF+aymUqmgUqlMvwFERERUJ5lt5EapVCIwMBBxcXFSm06nQ1xcHEJCQiqcJz8/v1yAsbS0BAAIIWquWCIiIqo3zDZyAwCRkZGIiIhAUFAQunbtisWLFyMvLw9jxowBAIwaNQq+vr6IiooCAAwcOBCLFi1Cp06dEBwcjHPnzuHtt9/GwIEDpZBDREREDzezhpshQ4YgPT0ds2fPRkpKCjp27Ijt27dLJxknJSXpjdTMmjULCoUCs2bNwrVr1+Du7o6BAwfigw8+MNcmEBERUR2jEA/Z8Zzs7Gw4OTkhKysLjo6OJlvu4aQMPL3sIBq52uL3N3qZbLlERERk2Pt3vbpaioiIiOh+GG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVswebpYuXQp/f3+o1WoEBwfjr7/+qrJ/ZmYmJk+eDG9vb6hUKrRs2RJbt26tpWqJiIiorrMy58rXr1+PyMhIREdHIzg4GIsXL0Z4eDgSExPh4eFRrr9Go0GfPn3g4eGBjRs3wtfXF5cvX4azs3PtF09ERER1klnDzaJFizBu3DiMGTMGABAdHY0tW7Zg1apVmD59ern+q1atwq1bt3Dw4EFYW1sDAPz9/WuzZCIiIqrjzHZYSqPRICEhAWFhYXeKsbBAWFgY4uPjK5wnNjYWISEhmDx5Mjw9PdG2bVvMmzcPWq220vUUFRUhOztb70FERETyZbZwc+PGDWi1Wnh6euq1e3p6IiUlpcJ5Lly4gI0bN0Kr1WLr1q14++238fHHH+P999+vdD1RUVFwcnKSHn5+fibdDiIiIqpbzH5CsSF0Oh08PDzw5ZdfIjAwEEOGDMHMmTMRHR1d6TwzZsxAVlaW9Lhy5UotVkxERES1zWzn3Li5ucHS0hKpqal67ampqfDy8qpwHm9vb1hbW8PS0lJqe+SRR5CSkgKNRgOlUlluHpVKBZVKZdriiYiIqM4y28iNUqlEYGAg4uLipDadToe4uDiEhIRUOE/37t1x7tw56HQ6qe3MmTPw9vauMNgQERHRw8esh6UiIyOxYsUKrF27FqdOncJLL72EvLw86eqpUaNGYcaMGVL/l156Cbdu3cLUqVNx5swZbNmyBfPmzcPkyZPNtQlERERUx5j1UvAhQ4YgPT0ds2fPRkpKCjp27Ijt27dLJxknJSXBwuJO/vLz88OOHTswbdo0tG/fHr6+vpg6dSrefPNNc20CERER1TEKIYQwdxG1KTs7G05OTsjKyoKjo6PJlns4KQNPLzuIRq62+P2NXiZbLhERERn2/m3UyI1Wq8WaNWsQFxeHtLQ0vXNgAGD37t3GLJaIiIjogRkVbqZOnYo1a9bgiSeeQNu2baFQKExdFxEREZFRjAo3MTEx+P777zFgwABT10NERET0QIy6WkqpVKJ58+amroWIiIjogRkVbl599VUsWbIED9m5yERERFQPGHVYav/+/dizZw+2bduGNm3aSHfoLvPjjz+apDgiIiIiQxkVbpydnfHUU0+ZuhYiIiKiB2ZUuFm9erWp6yAiIiIyiQf6huL09HQkJiYCAFq1agV3d3eTFEVERERkLKNOKM7Ly8MLL7wAb29vPProo3j00Ufh4+ODF198Efn5+aaukYiIiKjajAo3kZGR+O2337Bp0yZkZmYiMzMTv/zyC3777Te8+uqrpq6RiIiIqNqMOiz1ww8/YOPGjXjsscektgEDBsDGxgaDBw/G8uXLTVUfERERkUGMGrnJz8+X7tx9Nw8PDx6WIiIiIrMyKtyEhIRgzpw5KCwslNoKCgrw7rvvIiQkxGTFERERERnKqMNSS5YsQXh4OBo2bIgOHToAAI4dOwa1Wo0dO3aYtEAiIiIiQxgVbtq2bYuzZ89i3bp1OH36NABg6NChGD58OGxsbExaIBEREZEhjP6eG1tbW4wbN86UtRARERE9sGqHm9jYWPTv3x/W1taIjY2tsu9//vOfBy6MiIiIyBjVDjeDBg1CSkoKPDw8MGjQoEr7KRQKaLVaU9RGREREZLBqhxudTlfh70RERER1iVGXglckMzPTVIsiIiIiMppR4WbBggVYv3699Py5556Dq6srfH19cezYMZMVR0RERGQoo8JNdHQ0/Pz8AAA7d+7Erl27sH37dvTv3x+vv/66SQskIiIiMoRRl4KnpKRI4Wbz5s0YPHgw+vbtC39/fwQHB5u0QCIiIiJDGDVy4+LigitXrgAAtm/fjrCwMACAEIJXShEREZFZGTVy8/TTT2PYsGFo0aIFbt68if79+wMAjhw5gubNm5u0QCIiIiJDGBVuPvnkE/j7++PKlSv48MMPYW9vDwBITk7GpEmTTFogERERkSGMCjfW1tZ47bXXyrVPmzbtgQsiIiIiehC8/QIRERHJCm+/QERERLLC2y8QERGRrJjs9gtEREREdYFR4eZ///sfPv3003Ltn3/+OV555ZUHrYmIiIjIaEaFmx9++AHdu3cv196tWzds3LjxgYsiIiIiMpZR4ebmzZtwcnIq1+7o6IgbN248cFFERERExjIq3DRv3hzbt28v175t2zY0bdr0gYsiIiIiMpZRX+IXGRmJKVOmID09Hb179wYAxMXF4eOPP8bixYtNWR8RERGRQYwKNy+88AKKiorwwQcfYO7cuQAAf39/LF++HKNGjTJpgURERESGMCrcAMBLL72El156Cenp6bCxsZHuL0VERERkTkZ/z01JSQl27dqFH3/8EUIIAMD169eRm5trsuKIiIiIDGXUyM3ly5fRr18/JCUloaioCH369IGDgwMWLFiAoqIiREdHm7pOIiIiomoxauRm6tSpCAoKQkZGBmxsbKT2p556CnFxcSYrjoiIiMhQRo3c7Nu3DwcPHoRSqdRr9/f3x7Vr10xSGBEREZExjBq50el0Fd75++rVq3BwcHjgooiIiIiMZVS46du3r9732SgUCuTm5mLOnDkYMGCAqWojIiIiMphRh6UWLlyIfv36oXXr1igsLMSwYcNw9uxZuLm54bvvvjN1jURERETVZlS48fPzw7Fjx7B+/XocO3YMubm5ePHFFzF8+HC9E4yJiIiIapvB4aa4uBgBAQHYvHkzhg8fjuHDh9dEXURERERGMficG2traxQWFtZELUREREQPzKgTiidPnowFCxagpKTE1PUQERERPRCjzrk5dOgQ4uLi8Ouvv6Jdu3aws7PTm/7jjz+apDgiIiIiQxkVbpydnfHMM8+YuhYiIiKiB2ZQuNHpdPjoo49w5swZaDQa9O7dG++88w6vkCIiIqI6w6Bzbj744AO89dZbsLe3h6+vLz799FNMnjy5pmojIiIiMphB4ebrr7/GsmXLsGPHDvz888/YtGkT1q1bB51OV1P1ERERERnEoHCTlJSkd3uFsLAwKBQKXL9+3eSFERERERnDoHBTUlICtVqt12ZtbY3i4uIHKmLp0qXw9/eHWq1GcHAw/vrrr2rNFxMTA4VCgUGDBj3Q+omIiEg+DDqhWAiB0aNHQ6VSSW2FhYWYOHGi3uXghlwKvn79ekRGRiI6OhrBwcFYvHgxwsPDkZiYCA8Pj0rnu3TpEl577TX07NnTkE0gIiIimTNo5CYiIgIeHh5wcnKSHiNGjICPj49emyEWLVqEcePGYcyYMWjdujWio6Nha2uLVatWVTqPVqvF8OHD8e6776Jp06YGrY+IiIjkzaCRm9WrV5t05RqNBgkJCZgxY4bUZmFhgbCwMMTHx1c633vvvQcPDw+8+OKL2Ldvn0lrIiIiovrNqC/xM5UbN25Aq9XC09NTr93T0xOnT5+ucJ79+/dj5cqVOHr0aLXWUVRUhKKiIul5dna20fUSERFR3WfUvaXMJScnByNHjsSKFSvg5uZWrXmioqL0Dpn5+fnVcJVERERkTmYduXFzc4OlpSVSU1P12lNTU+Hl5VWu//nz53Hp0iUMHDhQaiv7jh0rKyskJiaiWbNmevPMmDEDkZGR0vPs7GwGHCIiIhkza7hRKpUIDAxEXFycdDm3TqdDXFwcpkyZUq5/QEAAjh8/rtc2a9Ys5OTkYMmSJRWGFpVKpXd1FxEREcmbWcMNAERGRiIiIgJBQUHo2rUrFi9ejLy8PIwZMwYAMGrUKPj6+iIqKgpqtRpt27bVm9/Z2RkAyrUTERHRw8ns4WbIkCFIT0/H7NmzkZKSgo4dO2L79u3SScZJSUmwsKhXpwYRERGRGSmEEMLcRdSm7OxsODk5ISsrC46OjiZb7uGkDDy97CAaudri9zd6mWy5REREZNj7N4dEiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhW6kS4Wbp0Kfz9/aFWqxEcHIy//vqr0r4rVqxAz5494eLiAhcXF4SFhVXZn4iIiB4uZg8369evR2RkJObMmYPDhw+jQ4cOCA8PR1paWoX99+7di6FDh2LPnj2Ij4+Hn58f+vbti2vXrtVy5URERFQXmT3cLFq0COPGjcOYMWPQunVrREdHw9bWFqtWraqw/7p16zBp0iR07NgRAQEB+Oqrr6DT6RAXF1fLlRMREVFdZNZwo9FokJCQgLCwMKnNwsICYWFhiI+Pr9Yy8vPzUVxcDFdX15oqk4iIiOoRK3Ou/MaNG9BqtfD09NRr9/T0xOnTp6u1jDfffBM+Pj56AeluRUVFKCoqkp5nZ2cbXzARERHVeWY/LPUg5s+fj5iYGPz0009Qq9UV9omKioKTk5P08PPzq+UqiYiIqDaZNdy4ubnB0tISqampeu2pqanw8vKqct6FCxdi/vz5+PXXX9G+fftK+82YMQNZWVnS48qVKyapnYiIiOoms4YbpVKJwMBAvZOBy04ODgkJqXS+Dz/8EHPnzsX27dsRFBRU5TpUKhUcHR31HkRERCRfZj3nBgAiIyMRERGBoKAgdO3aFYsXL0ZeXh7GjBkDABg1ahR8fX0RFRUFAFiwYAFmz56Nb7/9Fv7+/khJSQEA2Nvbw97e3mzbQURERHWD2cPNkCFDkJ6ejtmzZyMlJQUdO3bE9u3bpZOMk5KSYGFxZ4Bp+fLl0Gg0ePbZZ/WWM2fOHLzzzju1WToRERHVQWYPNwAwZcoUTJkypcJpe/fu1Xt+6dKlmi+IiIiI6q16fbUUERER0b0YboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG6IiIhIVhhuSJY0JTocv5qF1OxCc5dCRES1zMrcBRCZQnJWAY4kZeJIUgaOJGXi+LUsFJXo0MBOifgZj0NpZfocr9UJJN3Kh6udEk421iZfPhERGYfhhuqdwmItjl/LkoLMkaRMpFQyQnMzT4MCjfaBwk1ZiDmTmoOzqTk4m5aLM6m5OJ+eC02JDs621oif/jhslJZGr4OIyFSKtTrkF2mRpylBvqYEeWW/F2lRotOhW3M3OKpLP5AJIVBUokNeUQnyNVrka+70zdeUSM8LNFrk3dOWX6RFfrEW+UUlyNNoUaAp/Vms1eF/vVvghR5NzLYPGG6oThOiNFiUjcocTsrEqeRslOiEXj9LCwUCvBzQqZEzOvm5oH1DJ/T55HeD1qXVCVwpCzFpubfDTGmIKSrRVTpfZn4xbuVr4Ku0MWobiUg+ysJCblHpm39u0e2AodEir6hEChFSe5FWasvI16B3gAdaeTlIQSJPcyc8SD9vz3f39LsDh0Zb+etVGQ8H1e0wU4J7Xk5NYvM/1xluiMrkFBbjn6t3jcpcycStPE25fu4OKnRu5IxOjVzQyc8Z7Ro6wVZ558+5pIr/3GUh5k6AyZFGYioLMSorCzT3sEdLTwe08LRHCw8HtPS0R59PfoemiuBTXUIIZBeU4EpGPq5mFOCq9LP094YutvhiZCAsLRQPvC6ih0WJVqcXKsp+zy17XmFbaUgobbsz7808DfxcbdCjuZsUSPLuGRUpa3uQsHDw/E2Tbb/S0gK2KkvYKa1gq7TE2bRcaVpaTlG5/jbWlrBVWkrz2Cjv/mkJW5UVbK1v/yxru73ssrZjVzLx/pZTJtsGYzHckNnodALn03Nvh5gMHL6ciTNpORD3vDAoLS3QxtcRnfxc0KmRMzo3doGPkxoKRfXe6PeeScO1zAKcTS0NM+fTc1FYXHmIaeZuj5ae9mjh6YCWnqUhpqGLbYXBorpR437h5VpGAXKKSiqd/3RKDi6k56KFp0M111j9unKLSpCWUwRnG2s0sFeZdPlEhtDqxF0jGnfCRe49QaTytrJRkNLplf0/N9aVWwX47q8r1e5ve/vN315V9tOqNDiorKRgUNZ2M1eDlfsvopGrbWlwkAKE1Z2AcldQqWi63e31lAWSig7Hn0nNQXZB8V2h5HaAsbaEhQk+PGVU8GHUHBhuSJJVUIxfT6Rgx4lUtPFxxLQ+LU26/JzCYhy9komEyxlIuJyBo0mZFb6hN3SxkUZkOjVyRmsfR6isjD+fZWrM0XJtSisLNL8rxLS4PSrj51pxiLkfIQSy8ouNDi9l3OxVaOhic/thi4YuNpi/7TRyi0pgyIdBIQQy84uRllOEtJxCpGUX3fN7Yenz7CIUFGtL94mlBfZP7wUPB7XB21+bCou1yMwvRka+Bhn5Gun3zPxiZORp4GRjjYmPNYO15cN1MWhZMMgpLEZuUQlyC0uQU1iCHOn34tvTSx+5RcVQWlnirQEB8Haq+JCqTieQX1waGHIK74x25Nw18pFbpEVuUTHybh+CyS0sHb0o+/3yzXx0b94ATdzsS/tr9Oe9E2RMH0bKWFkoYKcqDRJ2t8OFvepOSChtv/3z9ijEnTZLaHWlh1nKRjLKwold2fJut9kqLW+HldIRDkPDwttPtq6R7b9bSxN/QKqrGG4ecvmaEuw6lYZNx67jt8R06VjtgXM3HijclJ0rUxZkEi5nIDG1/KiMjbUl2jd0QufGpWGmYyNnk7y5Wloo0LOFG/68eEsaiWnp6SAdWmpkZIipTN9Pfke+RnvffhWFl7LffZ1tKjwp+ZOdZ5B7ewRZpxO4maeRwkn67aCSek9gSc8tMvhwmUarw9WMghoLN+L2P37ZiJtOJ5BdWIwMKZxokJFXXD6w5GuQkV+MrNs/y8JYVdr7OSO0pXuNbIep6XRCCgN3gsftMHL79+xC/YByp+1OYKnO319FNh27jj6tPaWAUTYikltYgvxibbn/s8bYk5iOPYnp1e5fURgpG5m4O4zcCRj6YaRsRKQsfDzIh6MyXZu4PvAyHgYdGzljZUSQ2a8gZbh5CBUWa7E3MR2b/rmOuFOpep+W/FxtcOVWAXQGvqIVFmvx77UsKcgcTsrAjdzyw5N+rjYIauwqhZkALwdY1cAnbIVCgW9eDIZOJ0wy1FoZbyc1Lt3Ml95YjAkv1TX0yz+QVVBc7mTqqjjZWMPTUQUPBzU8HFRwv/373W0ejir0W7wPSbfyq71cIQSyC0uQkaeRRlDKgklGvga38oqRma/BrTyNdMJ1Zr4GxVoBJxtrWChKRwqNPTfB0kIBZxtrONtaw8VWCWdbJVxsrbH3TDrSc4pQoLn/KNm921NUokN2YTGyC0pDRFnQyCksRvZdz7MLi+GgssJr4a1goVDcFUrKj5jcHVDujKIUSwEmt7B0JMMUAaKM0soCDiorOKitYK8ufZN3UFvDQVX63EFtBXuVNZbEnZH+7+88mVrlMi0tFLC7PSphr757lOPOOsqCh4MUKqyQVVCMvYlpcLNXSYdn7g4jZSMdd4cTW6UlVFYW1T7sTHWLh4Majz9i/tFfhpuHRLFWh/3nbmDTsev49UQqcu86ROLfwBYDO/jgyfY+sFdbofv83fddXlp2IQ4n3RmV+fdadrkz9JWWFmjr64jAxi4IbOyCzo1c4OFYu3/0NRlsACBmfAgSU3Pg62zzwOGlMp6OatzM0+Dm7WPZCgXQwE4J97JwcjugeDreDjBlQcZBBbW1YfUcvpyBm7llYaV0pKQswNwdUjLyi6E1MplkFRTrPbdTWpaGEzv9oFL2s7St9KeLrRLOdqVv1BW9+T27/CDSc4pw4NxNCAEpjNz9M+eeoFLWVqw1bHvWxl82avsrY2WhgIO6NIiUhQjH28HB/q52h7sCiv7z0n7VHaV4NrAhfjx8FRYKhTTCYX/vIZrby3+QsDE4yM+o+YgeBMONjGl1An9evIlNx5Kx7d9kZObfeVPxcVLjyQ4+GNjeB219HaUXrmuZBeWWU6LVITE1B4fLDjElZeDKrfL93OyVUpAJbOyCNj5OBr+51jdeTmp4OdVsYFvzQhf8ey0LDexKQ4ybvarGzicx9CoHW6VlaeiwuxM+XO1Kw0jpTyVcb4cTC4UCSbfySwPL7T7ONkqTfsFi2fvvN39cxjd/GB4+FArcHvWwhoPaCo5qazja3HnuoLbC8r3n9UacLC0UUsi4Ezas7wolpaMZZSMo9refl/1ub4IAYQx3BxUmhDartfUR1SaGG5nR6QSOXMnApmPJ2HI8Gel3Xe7nZq/EE+28MbCDDzo3cqlyVEOrE1j0ayISkkpP/M2753i+QgG08nRAkP/tMNPIFX6uNhxKrgEeDmr0DqjZADWwgzf+748kONlYS6MmUkixVcLZrjSklAWTstEUQ8Nrax/HGtqCUs8GNkRqdhHU1hZ6AaUscDioreBoYw1H9Z0Q4nhXcLFTWt13tO+1vq1wNaMAKqvSdaiteQiFqK5huJEBIQROXM/GpmPXsfmfZL3RFycbawxo54Un2/sguIlrtc9vKdEJfLr7nPTcQWWFjo2cpVGZjn7OcFDzlgNy8Xp4AF4PDzB3GQ9sSJdGGNKlUY2uQ6FQwM/VtkbXQUQPhuGmnsjM1yDm0BVs+PsKgps2wLyn2uFsag42HbuOTf8k4+KNPKmvndIS4W28MLCDD7o3dzNo2N/bUY1HW7oj6WYeOt91iKmFhwO/QI6IiOoFhps67mxqDlYfvIQfD1+Vrmw4n56Hw5czcDolR+qnsrJA2COeGNjBG4+18jD6XBcLCwW+fqGrSWonIiIyB4abOkinE9iTmIbVBy5h/7kbUru1pUK6ouN0Sg6sLRUIbemOgR188PgjnrBX8Z+TiIiI74Z1SE5hMTb8fRVr4y/h8s3S7xyxUAB9W3thdHd/dG7kghfXHgIADGzvg/A2XnCy5XkvREREd2O4qQMu3cjDmoOXsDHhqvT9M45qKzzftRFG/r/GeicvfvNisLnKJCIiqhcYbsxECIH9525gzYFL2J2YJn1DaTN3O4zu3gTPdPbVu8s1ERERVQ/fPWtZvqYEPx25hjUHLundfr5XK3eM6d4EPVu48TsziIiIHgDDTS25mpGPb+IvI+bQFenr5+2UlnguyA+jQhqjqbu9mSskIiKSh5r5DncDLV26FP7+/lCr1QgODsZff/1VZf8NGzYgICAAarUa7dq1w9atW2upUsMIIfDnhZuY+E0CHv1wD774/QKyCorRyNUWbz/ZGvFvPY53/tOGwYaIiMiEzD5ys379ekRGRiI6OhrBwcFYvHgxwsPDkZiYCA8Pj3L9Dx48iKFDhyIqKgpPPvkkvv32WwwaNAiHDx9G27ZtzbAF5RUWa7Hp2HWsPnAJJ5OzpfbuzRtgTLcm6BXgwS/EIyIiqiEKIYRxt/Y1keDgYHTp0gWff/45AECn08HPzw8vv/wypk+fXq7/kCFDkJeXh82bN0tt/+///T907NgR0dHR911fdnY2nJyckJWVBUdH093n5nBSBp5edhBqawvYKa2kOzirrCzwdGdfjO7WBK28HEy2PiIiooeJIe/fZh250Wg0SEhIwIwZM6Q2CwsLhIWFIT4+vsJ54uPjERkZqdcWHh6On3/+ucL+RUVFKCq6c/PI7OzsCvuZSmGxDoXFGvg4qTEyxB/Pd/GDi52yRtdJREREd5g13Ny4cQNarRaenp567Z6enjh9+nSF86SkpFTYPyUlpcL+UVFRePfdd01TcBWae9gjwMsBjmprRHTzR3gbz2rfpJKIiIhMx+zn3NS0GTNm6I30ZGdnw8/Pz+TrcVRbY/srj5p8uURERGQYs4YbNzc3WFpaIjU1Va89NTUVXl5eFc7j5eVlUH+VSgWVSmWagomIiKjOM+txE6VSicDAQMTFxUltOp0OcXFxCAkJqXCekJAQvf4AsHPnzkr7ExER0cPF7IelIiMjERERgaCgIHTt2hWLFy9GXl4exowZAwAYNWoUfH19ERUVBQCYOnUqQkND8fHHH+OJJ55ATEwM/v77b3z55Zfm3AwiIiKqI8weboYMGYL09HTMnj0bKSkp6NixI7Zv3y6dNJyUlAQLizsDTN26dcO3336LWbNm4a233kKLFi3w888/15nvuCEiIiLzMvv33NS2mvqeGyIiIqo5hrx/81plIiIikhWGGyIiIpIVhhsiIiKSFYYbIiIikhWGGyIiIpIVhhsiIiKSFYYbIiIikhWGGyIiIpIVhhsiIiKSFbPffqG2lX0hc3Z2tpkrISIiouoqe9+uzo0VHrpwk5OTAwDw8/MzcyVERERkqJycHDg5OVXZ56G7t5ROp8P169fh4OAAhUJh0mVnZ2fDz88PV65c4X2rahD3c+3gfq4d3M+1h/u6dtTUfhZCICcnBz4+Pno31K7IQzdyY2FhgYYNG9boOhwdHfkfpxZwP9cO7ufawf1ce7iva0dN7Of7jdiU4QnFREREJCsMN0RERCQrDDcmpFKpMGfOHKhUKnOXImvcz7WD+7l2cD/XHu7r2lEX9vNDd0IxERERyRtHboiIiEhWGG6IiIhIVhhuiIiISFYYboiIiEhWGG4MtHTpUvj7+0OtViM4OBh//fVXlf03bNiAgIAAqNVqtGvXDlu3bq2lSus3Q/bzihUr0LNnT7i4uMDFxQVhYWH3/XehUob+PZeJiYmBQqHAoEGDarZAmTB0P2dmZmLy5Mnw9vaGSqVCy5Yt+dpRDYbu58WLF6NVq1awsbGBn58fpk2bhsLCwlqqtn76/fffMXDgQPj4+EChUODnn3++7zx79+5F586doVKp0Lx5c6xZs6bG64SgaouJiRFKpVKsWrVKnDhxQowbN044OzuL1NTUCvsfOHBAWFpaig8//FCcPHlSzJo1S1hbW4vjx4/XcuX1i6H7ediwYWLp0qXiyJEj4tSpU2L06NHCyclJXL16tZYrr18M3c9lLl68KHx9fUXPnj3Ff//739opth4zdD8XFRWJoKAgMWDAALF//35x8eJFsXfvXnH06NFarrx+MXQ/r1u3TqhUKrFu3Tpx8eJFsWPHDuHt7S2mTZtWy5XXL1u3bhUzZ84UP/74owAgfvrppyr7X7hwQdja2orIyEhx8uRJ8dlnnwlLS0uxffv2Gq2T4cYAXbt2FZMnT5aea7Va4ePjI6KioirsP3jwYPHEE0/otQUHB4sJEybUaJ31naH7+V4lJSXCwcFBrF27tqZKlAVj9nNJSYno1q2b+Oqrr0RERATDTTUYup+XL18umjZtKjQaTW2VKAuG7ufJkyeL3r1767VFRkaK7t2712idclKdcPPGG2+INm3a6LUNGTJEhIeH12BlQvCwVDVpNBokJCQgLCxMarOwsEBYWBji4+MrnCc+Pl6vPwCEh4dX2p+M28/3ys/PR3FxMVxdXWuqzHrP2P383nvvwcPDAy+++GJtlFnvGbOfY2NjERISgsmTJ8PT0xNt27bFvHnzoNVqa6vseseY/dytWzckJCRIh64uXLiArVu3YsCAAbVS88PCXO+DD92NM41148YNaLVaeHp66rV7enri9OnTFc6TkpJSYf+UlJQaq7O+M2Y/3+vNN9+Ej49Puf9QdIcx+3n//v1YuXIljh49WgsVyoMx+/nChQvYvXs3hg8fjq1bt+LcuXOYNGkSiouLMWfOnNoou94xZj8PGzYMN27cQI8ePSCEQElJCSZOnIi33nqrNkp+aFT2PpidnY2CggLY2NjUyHo5ckOyMn/+fMTExOCnn36CWq02dzmykZOTg5EjR2LFihVwc3MzdzmyptPp4OHhgS+//BKBgYEYMmQIZs6ciejoaHOXJit79+7FvHnzsGzZMhw+fBg//vgjtmzZgrlz55q7NDIBjtxUk5ubGywtLZGamqrXnpqaCi8vrwrn8fLyMqg/GbefyyxcuBDz58/Hrl270L59+5oss94zdD+fP38ely5dwsCBA6U2nU4HALCyskJiYiKaNWtWs0XXQ8b8PXt7e8Pa2hqWlpZS2yOPPIKUlBRoNBoolcoarbk+MmY/v/322xg5ciTGjh0LAGjXrh3y8vIwfvx4zJw5ExYW/OxvCpW9Dzo6OtbYqA3AkZtqUyqVCAwMRFxcnNSm0+kQFxeHkJCQCucJCQnR6w8AO3furLQ/GbefAeDDDz/E3LlzsX37dgQFBdVGqfWaofs5ICAAx48fx9GjR6XHf/7zH/Tq1QtHjx6Fn59fbZZfbxjz99y9e3ecO3dOCo8AcObMGXh7ezPYVMKY/Zyfn18uwJQFSsFbLpqM2d4Ha/R0ZZmJiYkRKpVKrFmzRpw8eVKMHz9eODs7i5SUFCGEECNHjhTTp0+X+h84cEBYWVmJhQsXilOnTok5c+bwUvBqMHQ/z58/XyiVSrFx40aRnJwsPXJycsy1CfWCofv5XrxaqnoM3c9JSUnCwcFBTJkyRSQmJorNmzcLDw8P8f7775trE+oFQ/fznDlzhIODg/juu+/EhQsXxK+//iqaNWsmBg8ebK5NqBdycnLEkSNHxJEjRwQAsWjRInHkyBFx+fJlIYQQ06dPFyNHjpT6l10K/vrrr4tTp06JpUuX8lLwuuizzz4TjRo1EkqlUnTt2lX88ccf0rTQ0FARERGh1//7778XLVu2FEqlUrRp00Zs2bKlliuunwzZz40bNxYAyj3mzJlT+4XXM4b+Pd+N4ab6DN3PBw8eFMHBwUKlUommTZuKDz74QJSUlNRy1fWPIfu5uLhYvPPOO6JZs2ZCrVYLPz8/MWnSJJGRkVH7hdcje/bsqfD1tmzfRkREiNDQ0HLzdOzYUSiVStG0aVOxevXqGq9TIQTH34iIiEg+eM4NERERyQrDDREREckKww0RERHJCsMNERERyQrDDREREckKww0RERHJCsMNERERyQrDDRERAIVCgZ9//hkAcOnSJSgUCt4BnaieYrghIrMbPXo0FAoFFAoFrK2t0aRJE7zxxhsoLCw0d2lEVA/xruBEVCf069cPq1evRnFxMRISEhAREQGFQoEFCxaYuzQiqmc4ckNEdYJKpYKXlxf8/PwwaNAghIWFYefOnQBK7/AcFRWFJk2awMbGBh06dMDGjRv15j9x4gSefPJJODo6wsHBAT179sT58+cBAIcOHUKfPn3g5uYGJycnhIaG4vDhw7W+jURUOxhuiKjO+ffff3Hw4EEolUoAQFRUFL7++mtER0fjxIkTmDZtGkaMGIHffvsNAHDt2jU8+uijUKlU2L17NxISEvDCCy+gpKQEAJCTk4OIiAjs378ff/zxB1q0aIEBAwYgJyfHbNtIRDWHh6WIqE7YvHkz7O3tUVJSgqKiIlhYWODzzz9HUVER5s2bh127diEkJAQA0LRpU+zfvx9ffPEFQkNDsXTpUjg5OSEmJgbW1tYAgJYtW0rL7t27t966vvzySzg7O+O3337Dk08+WXsbSUS1guGGiOqEXr16Yfny5cjLy8Mnn3wCKysrPPPMMzhx4gTy8/PRp08fvf4ajQadOnUCABw9ehQ9e/aUgs29UlNTMWvWLOzduxdpaWnQarXIz89HUlJSjW8XEdU+hhsiqhPs7OzQvHlzAMCqVavQoUMHrFy5Em3btgUAbNmyBb6+vnrzqFQqAICNjU2Vy46IiMDNmzexZMkSNG7cGCqVCiEhIdBoNDWwJURkbgw3RFTnWFhY4K233kJkZCTOnDkDlUqFpKQkhIaGVti/ffv2WLt2LYqLiyscvTlw4ACWLVuGAQMGAACuXLmCGzdu1Og2EJH58IRiIqqTnnvuOVhaWuKLL77Aa6+9hmnTpmHt2rU4f/48Dh8+jM8++wxr164FAEyZMgXZ2dl4/vnn8ffff+Ps2bP45ptvkJiYCABo0aIFvvnmG5w6dQp//vknhg8fft/RHiKqvzhyQ0R1kpWVFaZMmYIPP/wQFy9ehLu7O6KionDhwgU4Ozujc+fOeOuttwAADRo0wO7du/H6668jNDQUlpaW6NixI7p37w4AWLlyJcaPH4/OnTvDz88P8+bNw2uvvWbOzSOiGqQQQghzF0FERERkKjwsRURERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREsvL/AYvuNu9Ad7ssAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prediction has 74 non-zero edges.\n",
      "Ground truth has 18 non-zero edges.\n",
      "22.84 percent of potential edges are filled.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 2979.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------\n",
      "\n",
      "With threshold set as 0.1 std:\n",
      "\n",
      "precision: 0.05405405405405406 \n",
      "\n",
      "recall: 0.2222222222222222 \n",
      "\n",
      "F_1: 0.13813813813813813 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "AUPRC: 0.054793575881925426 \n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "p-val: 0.3956043956043956 \n",
      "\n",
      "Prediction has 74 non-zero edges.\n",
      "\n",
      "Ground truth has 18 non-zero edges.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Recall of a random matrix is 0.055.\n",
      "\n",
      "Precision of a random matrix is 0.22611111111111112.\n",
      "\n",
      "F1 of a random matrix is 0.14055555555555554.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n",
      "Model is predicting worse than random.\n",
      "\n",
      "-------------------------------------------------------\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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iIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFJMHm6WLl0Kb29vqFQqBAQE4Pjx46W2X7x4MZo3bw5LS0t4eXlh6tSpyMnJqaZqiYiIqKYzabjZuHEjpk2bhjlz5uDUqVNo27YtQkJCkJSUVGz7H374AdOnT8ecOXNw4cIFrFq1Chs3bsR7771XzZUTERFRTWXScLNo0SKMHTsWo0aNQosWLRAeHg4rKyusXr262PZHjx5F586dMWTIEHh7e6NXr14YPHjwY3t7iIiI6MlhsnCjVqsRFRWF4ODgf4sxM0NwcDCOHTtW7DKdOnVCVFSUPsxcv34d27dvR9++fUvcTm5uLtLS0gweREREJF3mptrw3bt3odVq4ebmZjDdzc0NFy9eLHaZIUOG4O7du+jSpQuEENBoNJgwYUKpp6XCwsLw4YcfVmrtREREVHOZfEBxeezfvx/z5s3DsmXLcOrUKfz888/Ytm0b5s6dW+IyM2bMQGpqqv4RFxdXjRUTERFRdTNZz42zszPkcjkSExMNpicmJsLd3b3YZd5//30MHz4cY8aMAQC0bt0amZmZGDduHGbOnAkzs6JZTalUQqlUVv4OEBERUY1ksp4bhUIBPz8/REZG6qfpdDpERkYiMDCw2GWysrKKBBi5XA4AEEJUXbFERERUa5is5wYApk2bhtDQUPj7+6Njx45YvHgxMjMzMWrUKADAiBEj4OnpibCwMABAv379sGjRIrRr1w4BAQG4evUq3n//ffTr108fcoiIiOjJZtJwM2jQICQnJ2P27NlISEiAr68vdu7cqR9kHBsba9BTM2vWLMhkMsyaNQu3b9+Gi4sL+vXrh08++cRUu0BEREQ1jEw8Yedz0tLSYG9vj9TUVNjZ2VXaek/FPsCLy46ivpMVDr7TvdLWS0REROX7/K5VV0sRERERPQ7DDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUmKycPN0qVL4e3tDZVKhYCAABw/frzU9ikpKZg0aRI8PDygVCrRrFkzbN++vZqqJSIioprO3JQb37hxI6ZNm4bw8HAEBARg8eLFCAkJwaVLl+Dq6lqkvVqtRs+ePeHq6ootW7bA09MTN2/ehIODQ/UXT0RERDWSScPNokWLMHbsWIwaNQoAEB4ejm3btmH16tWYPn16kfarV6/G/fv3cfToUVhYWAAAvL29q7NkIiIiquFMdlpKrVYjKioKwcHB/xZjZobg4GAcO3as2GUiIiIQGBiISZMmwc3NDa1atcK8efOg1WpL3E5ubi7S0tIMHkRERCRdJgs3d+/ehVarhZubm8F0Nzc3JCQkFLvM9evXsWXLFmi1Wmzfvh3vv/8+Pv/8c3z88cclbicsLAz29vb6h5eXV6XuBxEREdUsJh9QXB46nQ6urq749ttv4efnh0GDBmHmzJkIDw8vcZkZM2YgNTVV/4iLi6vGiomIiKi6mWzMjbOzM+RyORITEw2mJyYmwt3dvdhlPDw8YGFhAblcrp/21FNPISEhAWq1GgqFosgySqUSSqWycosnIiKiGstkPTcKhQJ+fn6IjIzUT9PpdIiMjERgYGCxy3Tu3BlXr16FTqfTT7t8+TI8PDyKDTZERET05DHpaalp06ZhxYoVWLduHS5cuIDXXnsNmZmZ+qunRowYgRkzZujbv/baa7h//z6mTJmCy5cvY9u2bZg3bx4mTZpkql0gIiKiGsakl4IPGjQIycnJmD17NhISEuDr64udO3fqBxnHxsbCzOzf/OXl5YVdu3Zh6tSpaNOmDTw9PTFlyhS8++67ptoFIiIiqmFkQghh6iKqU1paGuzt7ZGamgo7O7tKW++p2Ad4cdlR1HeywsF3ulfaeomI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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "children_directories = [d for d in os.listdir(root_dir) if os.path.isdir(os.path.join(root_dir, d))]\n",
    "\n",
    "for run in children_directories:\n",
    "    ground_truth_adjusted = adj_matrix_np\n",
    "    save_dir = root_dir + '/' + run\n",
    "    get_results(save_dir,scale,ground_truth_adjusted)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf_ode",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
