{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from scipy.sparse import csr_matrix, diags\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from time import time\n",
    "import csv\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "\n",
    "import sys\n",
    "sys.path += ['utils/']  \n",
    "\n",
    "from EDRep import *\n",
    "from node_embedding import *\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "directory = 'data_Gene2Vec/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running the optimization for k = 1\n",
      "Execution time: 6.237004280090332\n"
     ]
    }
   ],
   "source": [
    "# load the data\n",
    "EL = pd.read_csv(directory + 'train_text.txt', sep = ' ', names = [\"id1\", \"id2\"])\n",
    "\n",
    "# create the adjacency matrix\n",
    "dist_EL = pd.concat([EL.id1, EL.id2]).unique()\n",
    "n = len(dist_EL)\n",
    "EL_to_ID = {k: v for v, k in enumerate(dist_EL)}\n",
    "ID_to_EL = {v: k for v, k in enumerate(dist_EL)}\n",
    "A = csr_matrix((np.ones(len(EL)), (EL.id1.apply(lambda x: EL_to_ID[x]), EL.id2.apply(lambda x: EL_to_ID[x]))), shape = (n,n))\n",
    "A = (A + A.T).sign()\n",
    "\n",
    "dim = 200\n",
    "\n",
    "# run EDRep\n",
    "t0 = time()\n",
    "result = NodeEmbedding(A, dim = dim, n_epochs = 10, walk_length = 1, k = 1, verbose = True, η = 0.8, sym = True)\n",
    "print(f'Execution time: {time() - t0}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the files with labeled pairs\n",
    "files = pd.read_csv(directory + 'train_text.txt', header = None, sep = ' ', names = ['id1', 'id2'])\n",
    "files['label'] = pd.read_csv(directory + 'train_label.txt', header = None)[0].values\n",
    "files = files.dropna()\n",
    "\n",
    "# convert the embeddings to dataframes\n",
    "X_EDRep = pd.DataFrame(result.X)\n",
    "indeces = [ID_to_EL[x] for x in range(n)]\n",
    "X_EDRep['idx'] = indeces\n",
    "X_EDRep.set_index('idx', inplace = True)\n",
    "\n",
    "# load the G2V embedding\n",
    "X_G2V = pd.read_csv(directory + 'Gene2Vec_embeddings.txt', header = None, sep = ' ')\n",
    "X_G2V['idx'] = X_G2V[0].map(lambda x: x.split('\\t')[0])\n",
    "X_G2V[0] = X_G2V[0].map(lambda x: float(x.split('\\t')[1]))\n",
    "X_G2V = X_G2V.drop(columns =  200, axis = 0)\n",
    "X_G2V.set_index('idx', inplace = True)\n",
    "\n",
    "# add the predicted similarity column\n",
    "files['S_EDRep'] = files.apply(lambda x:X_EDRep.loc[x.id1]@X_EDRep.loc[x.id2], axis = 1)\n",
    "files['S_G2V'] = files.apply(lambda x: X_G2V.loc[x.id1]@X_G2V.loc[x.id2], axis = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Score EDRep: 0.9504901588266585\n",
      "Score G2V: 0.8446310509917166\n"
     ]
    }
   ],
   "source": [
    "# run the logistic regression\n",
    "\n",
    "idx = np.random.binomial(1, 0.7, len(files)) == 1\n",
    "files_train = files[idx]\n",
    "files_test = files[~idx]\n",
    "\n",
    "X = files_train.S_EDRep.values.reshape(1,-1).T\n",
    "y = files_train.label\n",
    "\n",
    "clf = LogisticRegression(random_state=0).fit(X, y)\n",
    "\n",
    "X = files_test.S_EDRep.values.reshape(1,-1).T\n",
    "y = files_test.label\n",
    "clf.predict(X)\n",
    "print(f'Score EDRep: {clf.score(X, y)}')\n",
    "\n",
    "X = files_train.S_G2V.values.reshape(1,-1).T\n",
    "y = files_train.label\n",
    "\n",
    "clf = LogisticRegression(random_state=0).fit(X, y)\n",
    "\n",
    "X = files_test.S_G2V.values.reshape(1,-1).T\n",
    "y = files_test.label\n",
    "clf.predict(X)\n",
    "print(f'Score G2V: {clf.score(X, y)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TtUFwHXMKQWgwmvatKlmzpypfv36WbalpaXpX//6l1555RWPtHnttdfqtddes6xnZWXp8OHDVk+QsUdOTo42btyo/fv3KyUlRQUFBapZs6aaN2+uLl26KDAw0K1x//7779q8ebOOHTum4OBg1a9fX126dFGjRo3c2g4AACU5depUsd7Mzz77rDp06OCW+gcOHOjUcSdOnNDGjRt17NgxnTp1SlWrVlWtWrV0+eWXq3Hjxm6JrVBBQYF++eUXbdu2TadOnVKVKlVUt25dde/eXXXq1HFLG948H1uuuuoqq/WDBw/aLFulShXddtttmjlzpmXbJ598ol69ejncbtEeWXfccYddicqMjAytX79ehw8f1okTJxQYGKhatWqpdevW6tixo9vmDj1+/Lh+/vlnnThxQidPnlRAQICio6PVokULtW/fvlhvfKDc8/X4QQDlk7/PKVWSnj17WtVXs2bNUuc+cGZOqUI7d+4sNq/Uxo0b7T5+x44dxu23325UrVq1WD2FS3R0tPHggw8ax48ft7teW+ezcOFCo3Xr1iW2YzKZjISEBOOnn36yux0AAJwxadIkq8+g8PBwIzU11Sex5OfnG5988okRHx9vmEwmm5/HrVq1MmbMmGH3XFdF7y9mzJhhae+dd94xGjRoYPPzuHfv3saOHTv86nyctWvXLqt2Q0JCSi2/evVqq/JVq1Y1zp8/71CbqampRmhoqFU9mzZtKvWYH3/80bjxxhsNs9ls8zWrVauW8fzzzxvp6ekOxVMoOzvb+M9//mO0a9eu1L9NYGCgkZCQYHz44YcOnzvgrxi+B6DSeOSRR6zWU1JS9NNPP3mkLaOEeQ7s+QUtLy9PDz30kC677DLNnz9f586ds1k2NTVV77zzjpo1a6alS5c6HedDDz2kgQMHaufOnTbLrF+/XldeeaUmTZrkVDsAANjj66+/tlq//fbbFRUV5fU49uzZo44dOyoxMVGbN28udf6iP//8U8OHD1dCQoJSUlKcai89PV3XX3+9HnzwQR06dKjEMoZhaPny5briiitKHepWEm+fjz0OHz5stR4TE1Nq+R49elj14jp37py+/PJLh9r84osvrKZTuPTSSxUfH19i2fPnz2vQoEG68sortWzZMmVnZ9us98SJE5o0aZJatGihTZs2ORTThg0b1KJFC40ZM0bbt28v9W+Tn5+v9evXa8SIEfriiy8cagfwVySlAFQaN910k8xms9W21atXe6Stkm4oa9euXeoxGRkZuuWWW/TOO++ooKDAal+dOnXUvn17dezYUbVq1bLad/bsWfXr10/z5893OM6XX35Z77zzjmU9PDxcl156aYndwwsKCvTCCy9oypQpDrcDAEBZzp07p61bt1ptu/nmm70ex88//6xu3bpp27ZtVtsDAwPVrFkzXX755WrdurVCQ0Ot9m/cuFFdu3Z1OJGTm5urW265Rd9//71lW61atdSxY0e1a9dOVapUsSqfkZGh2267zWreLX86H3utW7fOar1FixalljeZTLrnnnustpU2OXpJipZPTEwssdyJEyfUo0ePEu+tGjRooE6dOql9+/bF5iw9duyYevbsqR9//NGueObOnatevXqV+LesW7euOnTooI4dO6phw4Z21QeUSz7spQWgHCuPw/cMwzC6dOliVWe/fv1slnVl+N6TTz5pdWyNGjXKPOaee+4p1i39+eefN/7+++9iZX/77TfjtttusyofERFh7Nmzp9Q2Li5fv359IygoyJBk1K5d25g1a5aRmZlpKZuXl2d8++23RqtWrayOCwgIYCgfAMDtVqxYUWy4UkmfgZ509OhRo1atWlYxtGvXzvj888+Ns2fPWpXNzMw05s2bZzRt2tSq/E033WQUFBTYbKPo/UWTJk0s/77rrruM7du3W5XPysoyPv74YyMyMtLquEGDBvnF+TgjLy/P6rwlGa+++mqZx+3bt89qeFtAQIBx6NAhu9rcu3dvsaFwR44cKVYuPz/f6NWrl1XZmjVrGlOnTjWOHj1arOyPP/5oXH311VblGzRoYJw8ebLUeH755RcjJCTE6rjIyEhj0qRJRlJSUrHyp0+fNhYtWmTceeedRkhIiGXYJ1DekZQC4JSiSalp06YZK1eudHjZtm2bzTY8kZQaM2aMVZ1t27a1WdbZpNThw4eNqKgoq2NHjx5d6jFz5861Kt+0aVNj7969Zbb12muvWR3Xt2/fUssXvdmXZMTFxZV6Q3f+/HkjISHB6pg2bdq4/QYVAFC5vfPOO8W+oHvbDTfcYBXDyJEjjZycnFKPOXPmjNGtWzer47788kub5YveX0gX5ov68MMPS23nhx9+MAICAizHBAcHGydOnPD5+TjjP//5j1X9wcHBRnJysl3Hdu/e3erYyZMn23XcCy+8YHXcjTfeWGK5KVOmWJW74oorypy/Mz8/33jwwQetjnv44Ydtls/KyjIaNWpkVb5169bGwYMH7TqXQ4cOGbt27bKrLODvSEoBcErRpJSzS2k9lTyRlCpaZ2k9mJxJSu3bt89o166d1XFhYWHG/v37bR5TUFBgtGzZ0lI+PDzcroRUodtvv93qpnb37t02y5Z0E/zLL7+U2cbx48eLJdqWL19ud4wAAJTlpZdesvqcadKkiVfb37BhQ7Gkhb0/wBw9etSIiIiwHJuQkGCzbElJqUceecSudgYPHmx13Oeff+7z83HU3r17reqWZDz66KN2H//RRx9ZHduqVasyjykoKDAaN25sddy8efOKlTt//rxRvXp1S5m6desap06dsiuuvLw8qx75VatWNc6cOVNi2enTp1vFEhMTU2KvLaAyYE4pAJVK0XmSSptIvKgzZ87ou+++K7YsWbJE7733noYMGaJWrVpp+/btlmOCgoI0a9YsxcXF2ax3+fLl2rVrl2X9kUceUdOmTe2Oa/z48ZZ/G4ahr776yu5jb7vtNnXu3LnMcrVq1dITTzxhte3jjz+2ux0AAMpy+vRpq3VHJzj/4YcfSvycLrqsX7++xOPffPNNq/U33njDroeUSBfmfrz//vst6+vXr9fx48ftOjYsLEzPP/+8XWUHDx5stb5lyxabZX11PqUpnA/r7Nmzlm1xcXF66aWX7K7j9ttvV3h4uGX9zz//LHNy8XXr1ikpKcmyHh0drX79+hUrN2vWLKvrcOLEiapevbpdcQUGBmrcuHGW9XPnztmckL7o3+a1115T3bp17WoHqGiCfB0AAHhT1apVrdZzcnLsPnb79u267rrr7C5/ySWX6P3331fPnj1LLffNN99YrQ8dOtTuNiSpXbt2qlOnjo4dOybpwo3X008/bdexRScMLavshAkTLE+FWbt2rUNxAgBQmosTFZKKTfBdlltvvVWnTp0qs1xcXJz2799vta2goEDffvutZf3yyy/XJZdc4lD7119/vd544w3L+rp163TbbbeVedy1115b5pPnCrVv395qPTk5ucRyvjwfWwzDUGJion777TfLtqCgIM2ZM0cRERF21xMREaGBAwfq008/tWybNWtWqT+yzZo1y2p9yJAhxR5+I1nfkwUFBWnIkCF2xyVJ11xzjQICAiwPrFm3bl2xROKhQ4f0559/WtZjYmJ01113OdQOUJHQUwqAW6xevVrGhSHBDi2LFi3yapxFb3hLuiFxh3vvvVe///57mQkpyfrpM1WqVFHLli0dbi82Ntby74tvdEpjMpnUo0cPu9uIi4tTo0aNLOvHjh3TwYMH7T4eAIDSFE1MnD9/3mtt79ixQ2lpaZb1+Ph4h+so+oQ0ez+PHWmr6BN4L475Yr48H1ueeOIJLViwwGrbW2+9pYSEBIfrKvrUvLlz5yo3N7fEspmZmcWeolfSU/cMw7DqRdeiRQtFRkY6FFeVKlWsEowlvWZFnzp49dVXe+x+FCgPSEoBqFSK3rwV7TnlLh9//LEGDx6s7OzsMstefMNy/vx5BQQEyGQyObRc3G296PAHWxo2bOjQL5OS1KZNG6v1i7vCAwDgiqLDpGwlXDyhaPLg3Xffdfiz+NJLL7Wqw97P46KJptIU7T2WmZnpd+dTkilTplj1upKkCRMm6B//+IdT9V199dVWSbOTJ09q6dKlJZZdtGiR0tPTLeuXXHKJunTpUqzc8ePHrc5x586dDr9mJpNJKSkpljpKes327dtnte5MwhCoSEhKAahUTpw4YbVer149u4/t0aNHsZ5eubm5OnLkiBYvXqy+fftalf/yyy/LHIp3/vx5uxJXjrD3Jt7eoQKlHZOamupwHQAAlKRoUsqeoXgXO3nyZIm9slevXl3msY62ZQ97P49DQ0OdbqNwSH1RvjyfoqZPn24115IkPfzww5o4caLTsZhMpmJTEBQdomdre0m9pCTvvWZFE1WOJCWBioikFIBK5ddff7Vad2RC8ZIEBQWpbt266tOnj77++mu9//77Vvvnz5+vd9991+bxnkjq2LpBLeriSULtVfQXWkcmigcAoDQtWrSwWk9LSys295OneOLzuHBeIV/wl/P57LPPivWGSkxMLDbRtzOKJpeWLl1aLLF09OhRrVy50rIeEBBg8wdDb71mRaeS8FSvfaC8YKJzAJVGTk6Otm3bZrWtQ4cObm3jgQce0L59+zR16lTLtmeeeUa33nqr6tSpU6x80cRQ9erVNW/ePLfGZEtGRobDxxSd34MbKQCAu3Tt2lWBgYHKz8+3bNu8ebPVfIaeUvTz+I477tC9997rUp2O9MZ2N384n6+//lqJiYlWiZmBAwfqo48+svspgKVp1qyZEhISLPNA5eTkaO7cuRozZoylzJw5c6yup2uuuUYNGjQosb6ir1nr1q311ltvuRRjWFhYsW1Fp07gBz5UdiSlAFQaS5YsKTZUrlevXm5vZ9KkSVq0aJH27Nkj6cIvYi+88II++OCDYmWjo6MVFBSkvLw8SRfmhrj22mvdHlNJTp486fAxRX+BjI6OdlM0AIDKrmrVqurQoYM2b95s2fbNN9+49MQ3e9WoUcNqPTo62mufx57g6/P57rvvNHjwYMv9jST17t1bn332mQIDA93WTmJiotXk5J988olVUqro0L1hw4bZrKvoa2YYhkdes6LDVItOLQFUNgzfA1BpvP3221brderUKXGiS1eZzWZNnjzZatuMGTNKnBTcZDIpLi7Osp6ZmakjR464PaaSJCcnW038aY8dO3ZYrTdu3NidIQEAKrl+/fpZrX/xxRcOf1Y5o+jn2d69ez3epif58nzWr1+vfv36Wf0QeNVVV+mrr75SSEiIW9saPHiwVW+kTZs2adeuXZKkrVu3Wt23REZGasCAATbrqlOnjlVdBw4csPlEP1c0b97cav3iJCxQGZGUAlApfP3111q7dq3VthEjRrj117qLDRw40GpoYF5enl555ZUSyxbtrbVq1SqPxFSUYRj64Ycf7C5/4MABq7k96tSpU+xx0QAAuGL06NFWw6jOnz/v8hAqe1x++eVW7f7000/KysryeLue4qvz2bJli26++WarKQLi4+P1v//9r8ShbK4qKdFU2DuqaC+pQYMGlRpDcHCwEhISLOsZGRn6+eef3RjtBVdddZXV+qpVq9z+0BugPCEpBaDC27dvn4YPH261rXr16nrsscc82u748eOt1j/55BMdPHiwWLkbbrjBav2dd97xaFwXs/WkGnvKdu/e3d3hAAAquZiYmGJzH7388svavn27R9sNCQnR1VdfbVk/f/68ZsyY4dE2PckX57Nz50717t3b6olzbdq00bfffqvIyEiPtVt0wvPZs2crJydHn332WanlSlL0nqxoL3t3qFevntq2bWtZP3XqlObMmeP2doDygqQUgApt5cqV6tKli86cOWO1/c0331S1atU82vaAAQOsbjpyc3OLDeuTpP79+6tZs2aW9Z9//lnvvfeeR2MrtGDBAm3atKnMcidOnNDrr79utc3VCVMBACjJxIkTFRsba1nPyclR3759LcOyPOXJJ5+0Wp8wYUKJPyaVF948n6SkJF133XVW81U2a9ZMK1euVExMjEfaLHTttdeqfv36lvXk5GQ99dRTVnM1NWvWTFdeeWWZdd1///1W82UuWLBAS5cudWu8kvTII49YrT/11FM6evSo29sBygOSUgAqpJ9++km33367brjhhmITej/yyCM2HwfsTiaTqVhvqRkzZujw4cNW2wIDAzVp0qRiMX744YcOtffXX39p5MiRxeovjWEYGjRoUKnzWGVmZurWW2+1+uWzdevWuv766x2KDwAAe8TExGjevHkKDg62bDtw4IASEhI0d+5cGYbhUH1//fWXXeW6d++u3r17W9ZTUlJ0/fXXO5QMKygo0KJFi/T00087FKMneOt8jhw5omuvvdbqXqJhw4b6/vvvS3zysLsFBAQUu68rOuTznnvusauuqKgoq3MtKCjQHXfcocWLFzsU06+//qrBgwfb3D906FA1bdrUsn7q1Clde+21OnTokF31Hz58WLt373YoJsBf8fQ9AG7x66+/Wj1hxRG1atVSu3btyix39OhRfffdd1bbDMNQenq6UlNTlZKSos2bN2vjxo0lJmZMJpOeffZZvfzyy07F6YzbbrtNrVq10p9//ilJys7O1pQpU4p1Bx8yZIjWrFmj6dOnS7rQq2rkyJGaO3euHnvsMfXq1UtVqlSxOiY3N1c7d+7U6tWrtXDhQq1fv16GYejZZ5+1K7b69evr+PHj2r9/vzp27Khp06bptttuU2hoqKQLN2IrV67U448/rp07d1qOM5lM+uCDD9zyOGcAAErStWtXffDBB7rvvvtUUFAgSTp9+rTuuOMOTZkyRffdd5+uvfZatWrVqtixhmFo//79Wr58uWbPnm31dLayzJo1S/Hx8UpOTpYk7d69W506ddKIESM0fPhwtWvXrtjn35kzZ/Trr79q6dKlWrhwoZKTk9WjRw8Xzt59PH0+GRkZuv766/X3339btgUGBuqZZ57RX3/9ZXdCsNCVV15puQ9xxLBhwzRlypQS95lMJruTUtKFXkvr1q3TN998I+nCU5T79++v/v3768EHH1RCQoLMZrPVMVlZWdq+fbu+++47LVy4UFu2bJEkzZs3r8Q2QkJCNG/ePCUkJFjmk9q5c6fatGmjJ598UnfffbfVg3AkKTU1VWvXrtW8efO0cOFCTZ8+XZdccond5wX4LQMAnBAXF2dIcsvSr1+/EtuYMGGC29po0aKFsWLFCofOccaMGVZ19OjRw6nXavbs2Vb1hIaGGkeOHClWLicnxxg0aFCJ8QcFBRlNmzY1OnfubHTo0MFo3LixERISUmLZpKQkm7EUPZ9JkyZZbatSpYrRpk0bo0OHDka1atVKrH/SpElOvQ4AADhq0aJFRnR0tM3P96pVqxqNGzc2OnfubMTHxxuXXHKJUaVKFZvla9SoYXz00Ueltrl9+3YjNja2xOOjoqKM1q1bG1dccYVx6aWXGnXr1i2xXGn3DEXvL2bMmOHQa+LovYknzycpKclt92pl3cOUpUuXLiXW2atXL4frSk1NNXr27FlifWaz2WjRooVxxRVXGJdddpkRFxdnBAYGlli2LPPmzTPMZnOJx9avX9/o2LGj0alTJ6Nhw4aGyWRy6boB/BU9pQBUWIGBgerRo4dGjBih22+/3WNP2ivLkCFD9NJLL1l+LczKytJrr72mN954w6pccHCw5s2bp06dOmnixInKzMy07MvLy9O+ffu0b9++UtuqUaOGQ0+3GT9+vFJSUvTvf/9b0oWJUH///fcSywYEBOj5558vNiQRAABP6devn7Zv364nn3xSX3zxRbGhe+fOndO5c+eUlJRUaj3VqlXTfffdp+eee85qzqCStG3bVr/++quGDh2q5cuXW+1LS0uzGs5uiz89nbainY8tiYmJ2rhxY7Htw4YNc7iuqKgorVy5Uk8//bT+/e9/W40GyM7OtqsH2MXzotkyaNAg1atXT3fccUexoXuHDx92aEoGoLxiTikA5VpgYKDCw8NVp04dXXbZZerbt6+eeeYZLVy4UMePH9f333+vIUOG+CwhVRhj0SF106dPt5qA82JPPfWUkpKSNHbsWLtuAuvUqaO7775bX375pY4cOaLatWs7FN9bb72lhQsXljgEolC3bt20bt06TZw40aG6AQBwVWxsrObOnas///xTTzzxhJo0aWLXcbVr11b//v01d+5cHT16VFOnTi0zIVWoZs2a+vbbb/XDDz+oT58+xYbQF2UymdShQwc988wz2r59u0NPt/WGinY+JRkyZEixoX9Vq1bVwIEDnaovKChIr7/+unbv3q2RI0eqVq1aZR7TqFEjjRw5UitWrND+/fvtaufKK6/Unj179Prrr5c5HC8kJETXXnutPv30U91xxx121Q/4O5NR9OcGAIBf2bt3r377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tmyZunfv7vhJOmj9+vXq37+/Tp48admWlZWlFStWaMWKFZo6darGjh3rlramTZumZ5991pLAKZSUlKSkpCTNmjVL48eP10svvVRqPVlZWerdu7e+++47m2Veeuklvfjii8W2p6Wladu2bdq2bZvee+89zZ49WwMGDLBZz/79+zVgwIBi14wk7dmzR3v27NFnn32m1atXW5J8nvTVV1/p7rvvVkZGhmXbiRMntGjRIi1ZskRz5szR4MGDSzw2PT1dvXv3Lpa8+vXXX/Xrr79q7ty5mj59ukfjBwAAAAB3ISmFcuXWW2/Vzp079fDDD6tPnz6qXr26du/erUmTJunPP//UkiVL9OGHH+qBBx4oduzSpUstE4hXrVpVTzzxhK699loFBQXpp59+0uTJk3Xy5Ek9++yzio6O1ujRo23GsXz5cv3yyy9q27atHnnkEbVt21aZmZn66quv9NZbbykjI0NDhw7Vnj17FBIS4rHX4+jRo+rfv78CAgI0ZcoUXXnllQoJCdGPP/6ol156SampqRo3bpxuvPFGXXrppZbjVqxYoZycHLVt21aSNHr0aP3jH/+wqrtatWpW61OnTtVTTz0lSWrXrp1Gjx6t5s2bKzo6Wrt379Y777yjDRs2aNKkSapRo4Yefvhhm3E//fTT2r59u/r27athw4YpLi5Ox48fV3p6uqVMXl6e6tatqwEDBqhr165q0qSJQkNDlZycrJ9++knvvvuuzp07pzvvvFNbtmxRq1atirVz/PhxJSQk6MiRI5Kkq6++WomJiWrZsqVMJpOSkpK0atUqzZ8/33JM586dtWPHDn399dcaP368pAt/73r16lnV3bhxY9t/GBt27NihefPmqW7dunriiScUHx8vwzC0fPlyTZkyRVlZWRo5cqSuvvpq1axZs9jxQ4YMsSSkEhIS9NBDD6lZs2ZKSUnR7NmzNWfOHI0aNcrhuAAAAADAF0hKoVwp7A11cY+Wjh07qnfv3mrdurWOHz+ud999t1hSKjc3VyNHjrQkpNatW6f27dtb9nfp0kUDBw5U165ddfToUY0dO1a33367atSoUWIcGzdu1E033aSvvvrKKul01VVXKSYmRuPHj9fBgwe1dOnSUnvxuOqvv/5SXFyc1q9fr/r161u2d+7cWZ07d1b37t2Vl5enDz74QG+99ZZlf4sWLazqqVWrltq0aWOz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Ho0fAAAAAOC8SpWUMpvNMpvNvg4DHnL06FH1799fAQEBmjJliq688kqFhIToxx9/1EsvvaTU1FSNGzdON954oy699FLLcStWrFBOTo7atm0rSRo9erT+8Y9/WNVdrVo1q/WpU6fqqaeekiS1a9dOo0ePVvPmzRUdHa3du3frnXfe0YYNGzRp0iTVqFFDDz/8sM24n376aW3fvl19+/bVsGHDFBcXp+PHj1sNL83Ly1PdunU1YMAAde3aVU2aNFFoaKiSk5P1008/6d1339W5c+d05513asuWLWrVqlWxdo4fP66EhAQdOXJEknT11VcrMTFRLVu2lMlkUlJSklatWqX58+dbjuncubN27Nihr7/+WuPHj5ckLV++XPXq1bOqu3Hjxrb/MDbs2LFD8+bNU926dfXEE08oPj5ehmFo+fLlmjJlirKysjRy5EhdffXVqlmzZrHjhwwZYklIJSQk6KGHHlKzZs2UkpKi2bNna86cORo1apTDcQEAAAAAvKNSJaVQsf3111+Ki4vT+vXrVb9+fcv2zp07q3Pnzurevbvy8vL0wQcf6K233rLsb9GihVU9tWrVUps2bWy2s3PnTj333HOSpAkTJmjChAlWQ9U6deqkIUOGKDExUbNnz9Zzzz2noUOHFktsFdq+fbvGjx+vSZMm2Wzz/vvv14QJExQcHGy1vWPHjurXr58eeughdenSRYcPH9Yrr7yiTz/9tFgdo0ePtiSkXn31VUtSrVDnzp01aNAgTZs2zdL7q0qVKmrTpo3VUMQWLVqoUaNGNmO115YtW9SpUyetWrVKkZGRlu1dunRRs2bNdPfddys9PV2zZ8/WY489ZnXs119/bRmOeeutt2r+/PkKCPi/0cg33HCDOnTo4LZecQAAAAAA96uwc0qhcnr77betElKFrrzySl1xxRWSpHXr1rnUxuuvv67c3FzFx8cXS0gVCggI0Ntvvy2z2axz585pwYIFNutr0aKFJk6cWGqbjRo1KpaQuliDBg305JNPSpIWL14swzCs9u/evVuLFi2SJPXv379YQupiVatWtZlAc7ePP/7YKiFV6M4777T0xirp7/X+++9LksLCwvT+++9bJaQKPf744+rYsaObIwYAAAAAuAtJKVQY0dHRJU5wX6hTp06SpL///tuldpYsWSJJGjhwoM3JvAvjKRwSuGHDBpvlBg8erMDAQIdiSE9PV1JSkv744w/9/vvv+v333xUeHm6172JLly61JKqK9jrylbZt26pdu3Yl7jOZTOrQoYOk4n+vvLw8rV27VtKFHlElDe0rrGPo0KFujBgAAAAA4E4M30OF0bx58xJ7zBSqXr26JOns2bNOt3HgwAGlpKRIujBx/rhx4+w67tixYzb32UrMlNT2tGnTtGTJEh04cKDUsidPnlSTJk0s61u3bpUkBQcHq0uXLna152ktW7Ysdb+tv9e+ffuUmZkp6f8SjbbEx8e7ECEAAAAAwJNISqHCKOwpZEthwqqgoMDpNk6cOOHUcRc/Xa4oe4bKLVu2TLfddlup9VysMGlTqPBphNWrV1dISIhddXiavX+v/Px8q+1nzpyx/NtWLyl79wMAAAAAfIekFOCAixMkL7zwgm6//Xa7jqtSpYrNfWUN3Tt58qTuvPNOZWRkqGrVqho7dqx69+6tpk2bKioqypJkWrVqla655hpJKjanFAAAAAAA/oakFOCAmJgYy7+Dg4NLfUqfuyxYsECpqamSpK+++krXXnttieVOnz5ts44aNWpYyuTk5PhNbylnXNyzrHAopS1l7QcAAAAA+A4TnQMOaNKkiaKioiRJ69ev90qbf/zxh6QLQ+9sJaQkafPmzTb3FT6FLjc3t9RJ120pbUJ3b2vatKlCQ0MlSb/++mupZUt7TQAAAAAAvkVSCvj/ChMd2dnZNssEBgbqpptukiStWLFCf/75p8fjysvLkyRlZWXZnA8rIyNDn376qc06br75Zkti6c0333Q4hsLXRir99fGGoKAgde/eXZL07bff2uwNZRhGqa8JAAAAAMC3SEoB/1/dunUlXXi6W2nGjRunwMBAFRQU6LbbbtOhQ4dsls3Pz9ecOXNKLVOW5s2bS7qQePriiy9KbOP+++/XkSNHbNbRokULDRgwQJK0aNEiTZ061WbZ8+fPW00mLv3fayOV/fp4wwMPPCDpwoTuo0aNKjFZ969//UtbtmzxdmgAAAAAADuRlAL+v27dukmSFi9erOnTp+v333/X3r17tXfvXqun7rVt21bTpk2TJO3cuVNt2rTRU089pW+//VZbt27Vhg0b9Pnnn+vhhx9WbGys7r77bsucUM4YNGiQzGazJGn48OF65pln9P3332vz5s365JNPdMUVV+jzzz9XQkJCqfW8++67qlevniTpqaee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2bPHaNiwoaWehQsXOnoq8GNXXXWVIckICgoyfvrpp2L7X3vtNcvffsKECcX2r1692rI/MTGxxDZ2795tBAYGGpKM+Ph4IyMjw2p/RkaGER8fb4njr7/+csepoZzy9DWZlJRkbNmypdQYlixZYoSEhBiSjLCwMOPQoUPOng4qmKSkpDLf84qaMWNGqdesYRjG999/bynTt29fIy8vz2p/SkqK5bM4OjraOH36tItnUnG4+p4B+IPFixcbubm5NvcfO3bM6NChg+Vafv31170YHVA2Zz4f+Y4AT6sUc0p50pNPPql58+bpr7/+0lNPPaW9e/dqyJAhCgsL0+rVq/XKK68oLy9PYWFhevPNN51uZ8CAAWrWrJluvfVWXX755WrQoIHMZrOOHj2q5cuX66OPPrI8EWHQoEG69dZb3XSG8AdvvfWWEhISlJmZqeuvv17PPvusevXqpczMTM2dO1cffPCBJKlFixZ64oknnGqjRYsWevLJJzVlyhRt3rxZCQkJevrpp9W0aVPt27dPr776qrZu3SrpwnXPPCmVm6evyf3796tXr17q2rWr+vTpo8suu0y1atWSJP39999asGCBFixYYOklNW3aNH6NrsR+/PFH7d2717JeOKRTuvD0q4t7LEvSsGHDnGrn6quv1pAhQzR37lwtXrxY1113nR599FHVq1dPO3bs0D//+U8dPHhQkvTqq6+qWrVqTrVTEXnjcwzwtIceeki5ubkaOHCgunbtqkaNGiksLEwnT57UmjVrNH36dMv7z5VXXqkxY8b4OGJUdu74fOQ7AjzO11mximDPnj1G8+bNLVnnoktkZKSxZMmSUusoLGurp5Stuosuo0ePNrKysjxwlvC1xYsXG5GRkTb/9i1atDD27NlT4rH29JQyDMPIz8837r333lKvsfvuu8/Iz8/30FmiPPHkNXnx/tKW8PBwY/r06R4+U/i7xMREuz8nbd362NNTyjAu/CJ800032aw7ICCAnj42uPKeAfiDuLg4u95jBg4caJw5c8bX4QJu+Xw0DL4jwLPoKeUGzZo109atW/Wf//xH8+fP1969e5WTk6PY2FjddNNNeuSRRxQXF+dSG4sXL9aGDRv0888/68CBAzp58qTOnz+vyMhINWnSRFdddZXuvfdetWnTxk1nBX/Tp08fbd++XW+99ZaWLl2qQ4cOKSQkRM2aNdPtt9+uBx98UOHh4S61ERAQoI8++kgDBw7UBx98oE2bNunkyZOqUaOGOnfurAceeEA33nijm84I5Z0nr8lOnTpp9uzZ2rBhgzZv3qyjR4/q5MmTysvLU7Vq1XTppZfqmmuu0f3332/pQQV4Q1hYmJYuXarPPvtMM2fO1LZt25SamqratWvrqquu0oMPPqiuXbv6Oky/5I3PMcCTPvnkE61du1YbNmzQ33//rZMnTyo9PV1Vq1ZVbGysunXrpsTERN4DUOHwHQGeZDIMG7NzAwAAAAAAAB7C49kAAAAAAADgdSSlAAAAAAAA4HUkpQAAAAAAAOB1JKUAAAAAAADgdSSlAAAAAAAA4HUkpQAAAAAAAOB1JKUAAAAAAADgdSSlAAAAAAAA4HUkpQAAAAAAAOB1JKUAAAAAAADgdSSlAAAAAAAA4HUkpQAAAAAAAOB1JKUA4CLXXXedTCaTw0u/fv18HToAAIDduOcB4A+CfB0AAPgTs9mshISEYtvXr18vSWrZsqViYmKK7e/Tp4/HYwMAAHAX7nkA+AOTYRiGr4MAAH926NAhxcbGSpI2b96sTp06+TgiAAAA9+OeB4C3MXwPAMqwdetWSVJQUJDatGnj42gAAAA8g3seAN5GUgoAylB4g9a6dWuZzWYfRwMAAOAZ3PMA8DaSUgBQhsIbtA4dOvg4EgAAAM/hngeAt5GUAoAybNmyRRI3aAAAoGLjngeAt5GUAoBSnD59WgcPHpQkdezY0cfRAAAAeAb3PAB8gaQUAJSisBu7yWTSZZdd5uNoAAAAPIN7HgC+QFIKAEpReIPWtGlTRUZG+jgaAAAAz+CeB4AvkJQCgFIw4ScAAKgMuOcB4AskpQCUS7m5uYqPj5fJZCq2zJ07t8Rj8vLy1KlTJ4eOceQGzVsxAQCAyoN7HgAVGUkpAOVScHCw5syZo/Dw8GL7HnroIaWkpBTb/s9//tPyVJmLDR06VEOGDCm2PSMjQ7t375Zk3w2aN2ICAACVC/c8ACoyklIAyq1LLrlEb7zxRrHtJ0+e1JgxY6y2/fbbb/rnP/9ZrGyTJk30n//8p8T6t2/froKCAkn2d2X3dEwAAKDy4Z4HQEVFUgpAuTZy5Ej179+/2Pb58+dr4cKFki50MR82bJhyc3OtygQGBmr27NmKiIgose7Cbux169ZV7dq1/SImAABQOXHPA6AiIikFoNz773//q7p16xbb/o9//EOnTp3SSy+9pG3bthXb/8ILL6hr164263Vlwk9PxQQAACov7nkAVDQmwzAMXwcBAK5auXKlevfuraJvad27d9dPP/2kvLw8q+0JCQlau3atAgMDbdbZuXNnbd68Wc8995xefvllv4gJAABUbtzzAKhISEoBqDAef/zxEuc2KCoyMlLbtm1To0aNKmVMAACgfPPH+wt/jAmA/2P4HoAKY/LkyWrXrl2Z5d59912v3Qi5O6Ybb7xRJpNJM2fOdD04AABQLnHPA6CiICkFoMIwm8367LPPFBoaarPMXXfdpbvuuqvcxlQ4J4M9N30AAKBi4p4HQEVBUgpAhdK6detSb15KekKMp7krprNnzyoqKkqtWrXSpZde6qboAABAecQ9D4CKgDmlAFQor7/+usaOHWtzf+3atbVjxw7VrFmzUscEAADKN3+8v/DHmAD4N3pKAagwtm3bpmeffbbUMsePH9d9991nV30dOnSQyWTSsmXL/CYmAAAA7nkAVBQkpQBUCJmZmbrzzjuVk5NTZtklS5bovffeK7VMXl6edu7cKcn5uQzcHdMtt9wik8mkjz76yKl4AABA+cc9D4CKhKQUgArhiSeesNxQXez1118v8QkvTzzxhHbt2mWzvoMHD6px48bq1KmT6tev7xcxbd26VZLUvn17p+IBAADlH/c8ACoS5pQCUO7973//U58+fYpt7927t7799lutXbtWvXr1UtG3u44dO2rjxo0KDg72+5hSUlJUq1YtBQUF6dy5czKbzW6PGQAA+DfueQBUNPSUAlCuHTt2TPfee2+x7VFRUZYu3z169NCjjz5arMyWLVs0fvz4chHTb7/9Jklq1aoVN2cAAFRC3PMAqIhISgEotwzD0PDhw5WSklJs31tvvWXVBf2VV15Rq1atipWbNm2a1qxZU2x7QkKCTCaTFi5c6BcxFXZj79Chg0PxAACA8o97HgAVFUkpAOXWv//9b3377bfFtvfp00eJiYlW20JDQzVr1iwFBQVZbS8oKNA999yj1NRUq23btm2TdKFruT/EVPirIXMrAABQ+XDPA6CiIikFoFzasWOHnnnmmWLbq1evrg8++KDEY+Lj4/Xcc88V256cnKxRo0ZZ1vfs2aPz588rOjpajRs39ouYCm/Q+NUQAIDKhXseABUZE50DQBFz587VHXfcoZ49e2r16tW+DkeZmZmKiIhQfn6+zpw5o+joaF+HBAAAKgDueQD4Gj2lAKCILVu2SPKfX+i2b9+u/Px8NWrUiJszAADgNtzzAPA1klIAUEThBJuOzq3gKcytAAAAPIF7HgC+RlIKAIrwt6e++Fs8AACgYvC3ewx/iweA55GUAoCLJCcn69SpUwoLC1PLli19HY4kfjUEAADuxz0PAH9AUgoALlI4t0Lbtm0VGBjo42guPCp5x44dkvjVEAAAuA/3PAD8AUkpALiIv82tsGvXLmVkZKhmzZqKjY31dTgAAKCC4J4HgD8gKQUAF/G3uQwKH8/crVs3H0cCAAAqEu55APgDklIAcBF/ukE7deqU3nnnHUlSnz59fBwNAACoSLjnAeAPTIZhGL4OAgD8walTp1SjRg0FBQXp7NmzCg0N9Ukcy5Yt0/PPP69du3bp/Pnzuuyyy7Rx40afxQMAACoW7nkA+At6SgHA/xcTEyPDMJSbm+vTm6FVq1bp999/V926dfXEE09o9erV3JwBAAC34Z4HgL+gpxQAAAAAAAC8jp5SAAAAAAAA8DqSUgAAAAAAAPA6klIAAAAAAADwOpJSAAAAAAAA8DqSUgAAAAAAAPA6klIAAAAAAADwOpJSAAAAAAAA8DqSUgAAAAAAAPA6klIAAAAAAADwOpJSAAAAAAAA8DqSUgAAAAAAAPA6klIAAAAAAADwuv8HrNGbQX3bPlgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize= (12, 5))\n",
    "\n",
    "ax[0].hist(files[files.label == 0].S_EDRep, density = True, color = 'limegreen', edgecolor = 'white', bins =25, label = 'non interacting')\n",
    "ax[0].hist(files[files.label == 1].S_EDRep, density = True, color = 'plum', edgecolor = 'white', bins = 25, label = 'interacting')\n",
    "ax[0].set_title('EDRep', fontsize = 30)\n",
    "ax[0].tick_params(axis='x', which='major', labelsize=20)\n",
    "ax[0].tick_params(axis='y', which='major', labelsize=0)\n",
    "ax[0].set_xlabel(r'$\\mathbf{x}_i^T\\mathbf{x}_j$', fontsize = 24)\n",
    "\n",
    "\n",
    "ax[1].hist(files[files.label == 0].S_G2V, density = True, color = 'limegreen', edgecolor = 'white', bins =25, label = 'class 1')\n",
    "ax[1].hist(files[files.label == 1].S_G2V, density = True, color = 'plum', edgecolor = 'white', bins = 25, label = 'class 2')\n",
    "ax[1].set_title('Gene2Vec', fontsize = 30)\n",
    "ax[1].tick_params(axis='x', which='major', labelsize=20)\n",
    "ax[1].tick_params(axis='y', which='major', labelsize=0)\n",
    "ax[1].set_xlabel(r'$\\mathbf{x}_i^T\\mathbf{x}_j$', fontsize = 24)\n",
    "\n",
    "ax[0].set_ylabel('PDF', fontsize = 28)\n",
    "ax[0].legend(fontsize=  20)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "EDRep",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
