{
 "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: 4.199223279953003\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": 3,
   "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": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Score EDRep: 0.9508512119486109\n",
      "Score G2V: 0.8447566609708246\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": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rq1bt2rmzJn6yle+ouXLl+uXv/xls7aRqT/+8Y966KGHNH78eA0fPlzPP/+8ZsyYoRUrVmj58uUqKytT165ddc0112jatGlas2aNrrnmmh3rxyYgy5Yt05gxY1RdXa0TTzxRp59+ujZs2KAHH3xQxx57rP7+979r3Lhxu8Rw44036oknntApp5yikSNHasuWLTuWXXbZZTrssMN03HHHqXfv3tq4caNmz56t888/X2+88YZ+8YtfNKjrX//6l0aOHKk1a9Zo8ODBuuyyy1RXV6c333xTv/vd73TppZemvD+NeeSRRzRr1iyNHTtWl156qV577TXNnj1bixcv1muvvaaePXvuKPv6669r6NCh2rRpk04++WQNGDBAq1ev1mmnnZbw9wEAAAASrKKzYMECTZkypcGX83PPPVcnnXSSfvOb3zRIfm688UYtXLhQY8eO1UMPPaQ2bYI/l2uuuUZDhgzR9ddfry996UsaOnRoxtvI1Jw5c7R48WIdccQRDbZx7733atasWZowYYK6du2qKVOmaMGCBVqzZo2mTJmySz3bt2/XhAkT9NFHH6myslLDhw/fsey9997T5z//eX39619XVVWVysrKGqw7f/58LVq0SEceeeQu9b7yyiu7dNXbtm2bxo4dqxtuuEGXXnqp9tlnnx3LzjvvPK1Zs0a//OUv9aMf/ajBehs2bNDuu++u9u3bN7k/TXnwwQc1d+5cjR49ese8H/3oR7rhhht0xx13aPLkyTvmX3755dq0aZP++Mc/6rLLLtsx/7HHHiPBAgAASIIugkWmb9++uvrqqxvMO/HEE9WnTx+98MILDebfcccdMjPddNNNO5IrSdpjjz3005/+VJJ0++23N2sbmbriiisaJFeSdMkll0hSWtt49NFH9dZbb+nb3/52g+RKkvbee29NnjxZ77//fsKBIyZNmpQwuZIS3wfVrl07XX755dq+fXuD+pYuXapFixZp0KBB+sEPfrDLevXdLKNw9tlnN0iupGA/pIa/t7ffflvz58/XAQccoG984xsNyo8dO1bHH398JPEAAAC0NrRgFZlBgwaptLR0l/n77befFi1atOP9hx9+qFWrVmmfffZJONjEqFGjJEkvvvhixttojoqKioT1S9KmTZtSrqc+nmQtQv/85z8lBSMaxrfaDBkyJGm9a9eu1a9+9SvNmzdPa9eu1SeffNJgeey9Ys8995ykIAktKcnuNY9Uf2/Lly+XJH3hC19IGNOxxx6rJ598MjtBAgAAFDASrCLTtWvXhPPbtGmjurq6He/r7yfq3bt3wvL18zdv3pzxNpoj0TbqW9lqa2tTrmfjxo2SpPvuu6/Rch999NEu8/baa6+EZVevXq0hQ4Zo06ZN+uIXv6gxY8aoS5cuKi0tVVVVlaZPn66amp0Pj67/HcZ2GcyWVH9v9Z//nnvumbCeZPMBAACKHQkWEurSpYsk6f3330+4fN26dQ3KFar6+GfNmqXx48enta6ZJZx/0003aePGjbrzzjs1ceLEBsvuvfdeTZ8+vcG8+qQntlUr1zp37ixJ+ve//51webL5AAAAxY57sJBQp06d1L9/f7377rs7usnFqqyslCQdddRRLR1a2uq7KyZq2TrmmGMkSU8//XRk21u1apUk6YwzzthlWf0Q64limDt3bkotfI3tT1QGDRokKehCmSimZ555JmvbBgAAKGQkWEjqoosukrvr+9//foMv8xs2bNgxzPhFF12Uq/BS1qNHD0nBfVHxTj31VPXv319/+MMfNHv27ITrL1q0SFu3bk15e/VDpi9YsKDB/Llz5yYcFGTw4MEaOnSoli9frl/96le7LN+4caM+/fTTHe8b25+o9OnTRyNGjNCqVat06623Nlg2Z84c7r8CAABIgi6CSOp73/ueHnvsMc2aNUsDBw7UuHHjtHXrVt133336z3/+o8mTJ+vYY4/NdZhNGj16tO677z6dfvrpGjdunDp06KC+ffvq/PPPV9u2bfXAAw/oxBNP1Mknn6yhQ4dq0KBB6tixo95++20tXrxYq1ev1rp169SxY8eUtvfNb35Td955p8466yydeeaZ2nvvvfXKK69ozpw5mjBhgmbMmLHLOnfffbdGjBihH//4x7r//vs1YsQIubv++c9/6vHHH9frr7++I3FrbH+i9Ic//EHDhg3TN7/5Tc2ePXvHc7Duv/9+nXrqqZo1a1bWB+UAAAAoNCRYkmrqarT0qKW5DiOpmroalZWUNV0wYu3atdMTTzyhm266Sffcc49uueUWtWnTRgMHDtTNN9+sc845p8VjysTFF1+sNWvW6K9//at+/etfa/v27Ro+fPiOhGTAgAFasWKFbrrpJj3yyCO68847VVJSot69e+vII4/Utdde2+ABvE0ZMGCAKisrdfXVV+vRRx/V9u3bNXDgQD3wwAPq2rVrwgRr//3317Jly/TrX/9aDz74oH7/+9+rffv2Ki8v11VXXaU99tgj5f2JyqGHHqpFixbpxz/+sebPn6/58+drwIAB+vvf/66VK1dq1qxZO+7VAgAAQMDcPdcxZKyiosKXLFnSZLmVK1fqkEMOaYGIgOJw3nnn6Z577tHrr7+uz33uc02W53+wOK2evjqt8v0u6NfsbZrZUnff9XkEzZTq+aY1GLxscJNl8vmiJAC0lGTnHPr3AEiorq4u4SiS8+bN04wZM3TooYemlFwBAAAUE7oIAkho27Zt2m+//TRy5EgdfPDBatOmjV599VU98cQTateunf7whz/kOkQAAIC8Q4IFIKG2bdvq0ksv1fz58/X8889r69at6tmzp8466yz98Ic/1JFHHpnrEAEAAPIOCRaAhEpLS3XLLbfkOgwAAICCwj1YAAAAABAREiwAAAAAiAgJFgAAAABEhAQLAAAAACJCggUAAAAAESHBAgAAAICIkGABAIqamQ1PMn+SmS0xsyXr169v6bAAAAWKBAsAUNTcfWGS+VPdvcLdK3r16tXSYQEAChQJFgAAAABEhARLUl1tXa5DaFRU8VVVVcnMNHHixEjqKxZmphEjRuQ6DAAAABSANrkOIB+UlJZo9fTVuQ4jqX4X9Mt1CA2Ul5dLChK21qC17Q8AAAByhwSriOyzzz5auXKlunTpkutQCsrKlSvVsWPHXIcBAACAAkCCVUTatm2rgw8+ONdhFBx+ZwAAAEhVwd2DxbC5mUt0D9bEiRNlZqqqqtKtt96qI444Qu3bt9eee+6pSZMmacuWLTvKLliwQGamNWvWaM2aNTKzHVP8fV2vv/66Jk6cqP3220/t2rXTnnvuqXPPPVdvvPHGLnHVx7B69WrdcsstGjBggDp06LDjvqdt27bp97//vcaNG6e+ffuqrKxM3bt31/HHH6/HHnss6f6+8847uuKKK3TggQeqQ4cO6t69u4YMGaJf/OIXae1PonuwpkyZIjPTggULNHPmTA0ZMkQdO3ZU9+7ddfbZZ+vdd99NGNPixYs1ZswYderUSZ07d9bxxx+vRYsWNagPAAAAhSuvW7DM7Gh3fz52nrtPlTRVkioqKjwngbVCkydP1ty5c3XKKadozJgxqqys1G233aZVq1Zp/vz5koJ7la655hrdfPPNkqTvfOc7O9YfNGjQjtdz5szR6aefrs8++0ynnHKKDjjgAL3zzjt64IEH9Oijj6qyslJHHXXULjFceeWVevrpp3XyySdr3LhxKi0tlSRVV1fryiuv1NChQ3XCCSeoV69eWrdunR5++GGNGzdOt912my6++OIGdS1ZskQnnniiqqurddxxx+n000/X1q1b9dprr2nKlCn66U9/mvL+NOaPf/yjHnroIY0fP17Dhw/X888/rxkzZmjFihVavny5ysrKdpR96qmnNGbMGNXW1ur0009X//799fLLL2vkyJEaNWpUStsDAABAfsvrBCs+uUL2PPfcc3r55ZfVp08fSdL27ds1atQoVVZW6oUXXtCQIUNUXl6uKVOmaNq0aZKCVpx4mzZt0jnnnKOOHTvqqaee0qGHHrpj2SuvvKJjjjlGF198sZYtW7bLusuWLdOLL76o/fffv8H8bt26ac2aNdp3330bzN+yZYuGDRumyZMn67zzzlOHDh0kBS1eZ511lqqrq/WXv/xF5557boP13nnnHUlKaX+aMmfOHC1evFhHHHHEjnnnnnuu7r33Xs2aNUsTJkyQJNXV1enrX/+6ampqNHv2bI0dO3ZH+T/96U+67LLL0t42AAAA8k/BdRFEdvzsZz/bkVxJUps2bXThhRdKkl544YWU67nrrru0efNmXXvttQ2SK0k6/PDDdckll+jFF1/Ua6+9tsu6kydP3iW5kqSysrJdkitJ6tKliy666CJt2rRJixcv3jH/4YcfVlVVlcaPH79LciUpYV2ZuuKKKxokV5J0ySWXSGr4e3v22We1atUqjRw5skFyJUmTJk3SQQcdFFlMAAAAyJ28bsFCy6moqNhl3n777ScpaJVK1aJFiyRJK1asSNgi9Oabb0oKRuaLT8CGDBmStN5XX31Vv/nNb/TUU09p3bp1+vTTTxssj73n6bnnnpOkXRKZbEj19/biiy9Kko499thdypeUlGjo0KE7fjcAAAAoXCRYkCR17dp1l3lt2gR/HrW1tSnXs3HjRknSbbfd1mi5jz76aJd5e+21V8Kyzz33nEaNGqXt27dr9OjRGj9+vDp37qySkhItX75cs2bNUk1NzY7ymzdvlhQMS59tqf7e6gcL2XPPPRPWk2w+AAAACgsJFiJV/4ytFStWaMCAAWmta2YJ51933XX65JNPVFlZuctoftdff71mzZrVYF590pNsJL9c6Ny5syTp3//+d8LlyeYDAACgsHAPFtJWWlqatFXrmGOOkSQ9/fTTkW1v1apV6t69+y7JlSQtXLgwaQyNDeEeq7H9icqRRx4pSXrmmWd2WVZXV6dnn302q9sHAABAyyDBQtp69Oih9evX65NPPtll2YUXXqiuXbvq2muvTTg4Rl1dXdrPeiovL1d1dbVeeumlBvP//Oc/a+7cubuUP+WUU1ReXq6HHnpI99577y7L60cRTGV/ojJs2DD1799flZWVuyR+U6dO5f4rAACAVoIugkjb6NGjtXjxYp100kk67rjjVFZWpoEDB+qUU05Rjx49NHPmTJ122mk65phjNHr0aB122GEyM7399ttatGiRNm7cuMsgFY35zne+o7lz5+rYY4/VhAkT1KVLFy1ZskTPPPOMzjzzTM2cObNB+Xbt2um+++7TmDFjdO655+rWW2/VMccco08//VQrV67UvHnztH379pT2JyolJSW6/fbbddJJJ2n8+PE644wz1L9/f7300kt64oknNHbsWD322GMqKeGaBwAAQCEjwZJUV1unfhf0y3UYSdXV1qmkNH++eF999dXavHmzHn74Yf3jH/9QbW2tLrjggh0JyejRo/XSSy/pt7/9rebOnaunn35a7dq10957761Ro0bpjDPOSGt7J510kh5++GFdd911mjFjhkpLSzVkyBBVVlZq9erVuyRYUjC63/Lly3XDDTfoscce07PPPqtOnTrpgAMO0M9//vO09icqI0aM0MKFC3X11Vfr0UcflSQdffTRqqys1F/+8hdJO+/VAgAAQGEyd891DBmrqKjwJUuWNFlu5cqVOuSQQ1ogIiAzw4YN0/PPP68tW7Zot912y3U4keN/sDitnr46rfJRXOgys6XuvuvzE5op1fNNazB42eAmyyw9amkLRAIA+S3ZOSd/mkWAVm7r1q07hpCPNW3aND377LMaM2ZMq0yuAAAAigldBIEWsnbtWh155JE64YQTdMABB2j79u168cUX9cwzz6hr16668cYbcx0iAAAAmokEC2ghe+65p8477zwtXLhQlZWVqqmp0V577aULL7xQP/nJT9S/f/9chwgAAIBmIsECWki3bt10++235zoMAAAAZBH3YAEAAABAREiwAAAAACAiRZNgFfJw9EAh438PAAAUk6JIsEpLS/XZZ5/l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\n",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "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.savefig('../../paper/v5_NIPS/Figures/G2V.pdf', bbox_inches = 'tight', dpi = 400)\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "files.to_csv('saved_files/g2vec.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
