{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5dc1dba6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix, diags\n",
    "import matplotlib.pyplot as plt\n",
    "from os import listdir\n",
    "\n",
    "import sys\n",
    "sys.path += ['utils/']  \n",
    "\n",
    "from word_embedding import * \n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "397c5e6c",
   "metadata": {},
   "outputs": [],
   "source": [
    "directory = 'Bkp_vars/'\n",
    "\n",
    "df = pd.read_csv(directory + 'events.csv')\n",
    "\n",
    "all_visitor_id = df.visitorid.unique()\n",
    "n = len(all_visitor_id)\n",
    "visitor_mapper = dict(zip(all_visitor_id, np.arange(n)))\n",
    "\n",
    "all_item_id = df.itemid.unique()\n",
    "m = len(all_item_id)\n",
    "item_mapper = dict(zip(all_item_id, np.arange(m)))\n",
    "\n",
    "df.visitorid = df.visitorid.map(lambda x: visitor_mapper[x])\n",
    "df.itemid = df.itemid.map(lambda x: item_mapper[x])\n",
    "\n",
    "event_mapper = dict(zip(df.event.unique(), np.array([1,2,3])))\n",
    "df.event = df.event.map(lambda x: event_mapper[x])\n",
    "\n",
    "nrows = len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9fdbb412",
   "metadata": {},
   "outputs": [],
   "source": [
    "def RunSimulation(dim):\n",
    "\n",
    "    pv = [0.1, 0.3, 0.5, 0.7, 0.9]\n",
    "\n",
    "    Fscore = []\n",
    "\n",
    "\n",
    "    for p in pv[::-1]:\n",
    "        print(p, end = '\\r')\n",
    "        \n",
    "        # create train and test sets\n",
    "        train_bool = np.random.binomial(1, p, nrows) == 1\n",
    "        df_train = df[train_bool]\n",
    "        df_test = df[~train_bool]\n",
    "\n",
    "        # obtain the probability matrix from the train set\n",
    "        A = csr_matrix((df_train.event, (df_train.visitorid, df_train.itemid)), shape = (n,m))\n",
    "        D_1 = diags((A@np.ones(m))**(-1))\n",
    "        P = D_1@A\n",
    "        \n",
    "        # compute the embeddings\n",
    "        res = CreateEmbedding([P], dim = dim, n_epochs = 30, η = 0.8, sym = False)\n",
    "\n",
    "        # true positives\n",
    "        tp = np.mean((res.X[df.visitorid] * res.Y[df.itemid]).sum(axis = 1) > 0)\n",
    "        \n",
    "        # false negatives\n",
    "        fn = 1 - tp\n",
    "        \n",
    "        # true negatives\n",
    "        idxa, idxb = np.random.choice(np.arange(n), len(df)), np.random.choice(np.arange(m), len(df))\n",
    "        tn = np.mean((res.X[idxa] * res.Y[idxb]).sum(axis = 1) < 0)\n",
    "        \n",
    "        # false positives\n",
    "        fp = 1 - tn\n",
    "\n",
    "        \n",
    "        precision = tp/(tp + fp)\n",
    "        recall = tp/(tp + fn)\n",
    "\n",
    "        Fscore.append(2/(1/precision + 1/recall))\n",
    "        \n",
    "    # save the result\n",
    "    Fscore = pd.DataFrame(Fscore)\n",
    "    try:\n",
    "        nn = (np.max([int(x.split('_')[1]) for x in listdir('saved_files/matrix_completion')]))\n",
    "        print(nn)\n",
    "        Fscore.to_csv('saved_files/matrix_completion/v_' + str(nn+1) + '_.csv', index = False)\n",
    "\n",
    "    except:\n",
    "        Fscore.to_csv('saved_files/matrix_completion/v_' + str(1) + '_.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c480abce",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "6========================>] 100%\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "7========================>] 100%\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "8========================>] 100%\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "Running the optimization for k = 1\n",
      "9========================>] 100%\n"
     ]
    }
   ],
   "source": [
    "dim = 32\n",
    "n_sim = 4\n",
    "for i in range(n_sim):\n",
    "    RunSimulation(dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "936ffe40",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "directory = 'saved_files/matrix_completion/'\n",
    "files = listdir(directory)\n",
    "\n",
    "data = []\n",
    "\n",
    "for f in files:\n",
    "    data.append(pd.read_csv(directory + f))\n",
    "    \n",
    "data = pd.concat(data, axis = 1)\n",
    "\n",
    "pv = [0.1, 0.3, 0.5, 0.7, 0.9]\n",
    "\n",
    "μ = data.mean(axis = 1)\n",
    "σ = data.std(axis = 1) \n",
    "\n",
    "plt.figure(figsize = (10,5))\n",
    "\n",
    "plt.plot(pv[::-1], μ, color = 'navy', marker = 'd', markersize = 18, fillstyle = 'none')\n",
    "plt.fill_between(pv[::-1], μ - σ, μ + σ, color = 'dodgerblue', alpha = 0.4)\n",
    "plt.xlabel(r'$p$', fontsize = 25)\n",
    "plt.ylabel('F-score', fontsize = 25)\n",
    "plt.xticks(fontsize = 16)\n",
    "plt.yticks(fontsize = 16)\n",
    "plt.savefig('../../paper/v2/arXiv/Figures/mat_comp.pdf', dpi = 400, bbox_inches = 'tight')\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30bdd4d0",
   "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": 5
}
