{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "from matrix_completion import svt_solve, calc_unobserved_rmse, nuclear_norm_solve\n",
    "import ipdb\n",
    "import logging\n",
    "import random\n",
    "import scipy\n",
    "import sys\n",
    "from sklearn.cluster import KMeans\n",
    "from sklearn.decomposition import PCA\n",
    "import autoreload\n",
    "import time\n",
    "from cvxpy import *\n",
    "import seaborn as sns\n",
    "import copy\n",
    "import re\n",
    "\n",
    "logging.basicConfig(level=logging.INFO)\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_style('darkgrid')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "sys.path.append(\"./utils/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Configurations for the script\n",
    "_users_range = 100\n",
    "_movie_range = 23\n",
    "_T = 10\n",
    "\n",
    "# Controls how quickly the submodular regularization plateaus off\n",
    "# In a practical application, this would be a really important hyperparameter\n",
    "_lambda_one = 1\n",
    "_lambda_two = 20e-5\n",
    "\n",
    "# For matrix completion\n",
    "_mu = 1e-3\n",
    "\n",
    "#The variance of the noise in the rewards during the algorithm\n",
    "_sigma = 0.001\n",
    "\n",
    "# For the Laplacian non-sparsification\n",
    "_decay_rate = 5\n",
    "\n",
    "_num_meta_users = 1\n",
    "\n",
    "#For the tradeoff between the cosine, jaccard and linear kernel when designing the composite kernel\n",
    "_k1 = 1 \n",
    "_k2 = 1\n",
    "_k3 = 0\n",
    "\n",
    "\"\"\"\n",
    "The plots are looking quite good with this choice.\n",
    "It may be of interest to decay or make it grow, but I don't see a strong reason for either.\n",
    "\"\"\"\n",
    "_beta_lst = [0.01 for i in range(_T)]\n",
    "#_beta_lst = [2 + (np.log((i+1)/0.1))**3 for i in range(_T)]\n",
    "#_beta_lst = 100 * np.array(_beta_lst)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "First I load the dataframes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "ratings_df = #LOAD pd.read_csv('ratings.csv') data here from movieLens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "movies_df = #LOAD pd.read_csv('movies.csv') data here from movieLens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "popular_movies_gb = ratings_df.groupby('movieId').size().sort_values(ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [],
   "source": [
    "popular_movies = popular_movies_gb.index.tolist()[30:45]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[3578,\n",
       " 592,\n",
       " 588,\n",
       " 364,\n",
       " 4306,\n",
       " 380,\n",
       " 590,\n",
       " 58559,\n",
       " 377,\n",
       " 4226,\n",
       " 1580,\n",
       " 1704,\n",
       " 79132,\n",
       " 1240,\n",
       " 1291]"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "popular_movies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "handpicked_movies_lst = [858, 1221, 2023, 2628, 5378, 33493, 4896, 5816, 79132]\n",
    "selected_movies_lst = np.unique(handpicked_movies_lst + popular_movies)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "metadata": {},
   "outputs": [],
   "source": [
    "_movie_range = len(selected_movies_lst)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "23"
      ]
     },
     "execution_count": 172,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "_movie_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "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>movieId</th>\n",
       "      <th>title</th>\n",
       "      <th>genres</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>359</th>\n",
       "      <td>364</td>\n",
       "      <td>Lion King, The (1994)</td>\n",
       "      <td>Adventure|Animation|Children|Drama|Musical|IMAX</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>372</th>\n",
       "      <td>377</td>\n",
       "      <td>Speed (1994)</td>\n",
       "      <td>Action|Romance|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>375</th>\n",
       "      <td>380</td>\n",
       "      <td>True Lies (1994)</td>\n",
       "      <td>Action|Adventure|Comedy|Romance|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>580</th>\n",
       "      <td>588</td>\n",
       "      <td>Aladdin (1992)</td>\n",
       "      <td>Adventure|Animation|Children|Comedy|Musical</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>582</th>\n",
       "      <td>590</td>\n",
       "      <td>Dances with Wolves (1990)</td>\n",
       "      <td>Adventure|Drama|Western</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>584</th>\n",
       "      <td>592</td>\n",
       "      <td>Batman (1989)</td>\n",
       "      <td>Action|Crime|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>840</th>\n",
       "      <td>858</td>\n",
       "      <td>Godfather, The (1972)</td>\n",
       "      <td>Crime|Drama</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1190</th>\n",
       "      <td>1221</td>\n",
       "      <td>Godfather: Part II, The (1974)</td>\n",
       "      <td>Crime|Drama</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1207</th>\n",
       "      <td>1240</td>\n",
       "      <td>Terminator, The (1984)</td>\n",
       "      <td>Action|Sci-Fi|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1258</th>\n",
       "      <td>1291</td>\n",
       "      <td>Indiana Jones and the Last Crusade (1989)</td>\n",
       "      <td>Action|Adventure</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1523</th>\n",
       "      <td>1580</td>\n",
       "      <td>Men in Black (a.k.a. MIB) (1997)</td>\n",
       "      <td>Action|Comedy|Sci-Fi</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1640</th>\n",
       "      <td>1704</td>\n",
       "      <td>Good Will Hunting (1997)</td>\n",
       "      <td>Drama|Romance</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1934</th>\n",
       "      <td>2023</td>\n",
       "      <td>Godfather: Part III, The (1990)</td>\n",
       "      <td>Crime|Drama|Mystery|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2537</th>\n",
       "      <td>2628</td>\n",
       "      <td>Star Wars: Episode I - The Phantom Menace (1999)</td>\n",
       "      <td>Action|Adventure|Sci-Fi</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3479</th>\n",
       "      <td>3578</td>\n",
       "      <td>Gladiator (2000)</td>\n",
       "      <td>Action|Adventure|Drama</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4122</th>\n",
       "      <td>4226</td>\n",
       "      <td>Memento (2000)</td>\n",
       "      <td>Mystery|Thriller</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4201</th>\n",
       "      <td>4306</td>\n",
       "      <td>Shrek (2001)</td>\n",
       "      <td>Adventure|Animation|Children|Comedy|Fantasy|Ro...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4790</th>\n",
       "      <td>4896</td>\n",
       "      <td>Harry Potter and the Sorcerer's Stone (a.k.a. ...</td>\n",
       "      <td>Adventure|Children|Fantasy</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5270</th>\n",
       "      <td>5378</td>\n",
       "      <td>Star Wars: Episode II - Attack of the Clones (...</td>\n",
       "      <td>Action|Adventure|Sci-Fi|IMAX</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5704</th>\n",
       "      <td>5816</td>\n",
       "      <td>Harry Potter and the Chamber of Secrets (2002)</td>\n",
       "      <td>Adventure|Fantasy</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9952</th>\n",
       "      <td>33493</td>\n",
       "      <td>Star Wars: Episode III - Revenge of the Sith (...</td>\n",
       "      <td>Action|Adventure|Sci-Fi</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12221</th>\n",
       "      <td>58559</td>\n",
       "      <td>Dark Knight, The (2008)</td>\n",
       "      <td>Action|Crime|Drama|IMAX</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14937</th>\n",
       "      <td>79132</td>\n",
       "      <td>Inception (2010)</td>\n",
       "      <td>Action|Crime|Drama|Mystery|Sci-Fi|Thriller|IMAX</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       movieId                                              title  \\\n",
       "359        364                              Lion King, The (1994)   \n",
       "372        377                                       Speed (1994)   \n",
       "375        380                                   True Lies (1994)   \n",
       "580        588                                     Aladdin (1992)   \n",
       "582        590                          Dances with Wolves (1990)   \n",
       "584        592                                      Batman (1989)   \n",
       "840        858                              Godfather, The (1972)   \n",
       "1190      1221                     Godfather: Part II, The (1974)   \n",
       "1207      1240                             Terminator, The (1984)   \n",
       "1258      1291          Indiana Jones and the Last Crusade (1989)   \n",
       "1523      1580                   Men in Black (a.k.a. MIB) (1997)   \n",
       "1640      1704                           Good Will Hunting (1997)   \n",
       "1934      2023                    Godfather: Part III, The (1990)   \n",
       "2537      2628   Star Wars: Episode I - The Phantom Menace (1999)   \n",
       "3479      3578                                   Gladiator (2000)   \n",
       "4122      4226                                     Memento (2000)   \n",
       "4201      4306                                       Shrek (2001)   \n",
       "4790      4896  Harry Potter and the Sorcerer's Stone (a.k.a. ...   \n",
       "5270      5378  Star Wars: Episode II - Attack of the Clones (...   \n",
       "5704      5816     Harry Potter and the Chamber of Secrets (2002)   \n",
       "9952     33493  Star Wars: Episode III - Revenge of the Sith (...   \n",
       "12221    58559                            Dark Knight, The (2008)   \n",
       "14937    79132                                   Inception (2010)   \n",
       "\n",
       "                                                  genres  \n",
       "359      Adventure|Animation|Children|Drama|Musical|IMAX  \n",
       "372                              Action|Romance|Thriller  \n",
       "375             Action|Adventure|Comedy|Romance|Thriller  \n",
       "580          Adventure|Animation|Children|Comedy|Musical  \n",
       "582                              Adventure|Drama|Western  \n",
       "584                                Action|Crime|Thriller  \n",
       "840                                          Crime|Drama  \n",
       "1190                                         Crime|Drama  \n",
       "1207                              Action|Sci-Fi|Thriller  \n",
       "1258                                    Action|Adventure  \n",
       "1523                                Action|Comedy|Sci-Fi  \n",
       "1640                                       Drama|Romance  \n",
       "1934                        Crime|Drama|Mystery|Thriller  \n",
       "2537                             Action|Adventure|Sci-Fi  \n",
       "3479                              Action|Adventure|Drama  \n",
       "4122                                    Mystery|Thriller  \n",
       "4201   Adventure|Animation|Children|Comedy|Fantasy|Ro...  \n",
       "4790                          Adventure|Children|Fantasy  \n",
       "5270                        Action|Adventure|Sci-Fi|IMAX  \n",
       "5704                                   Adventure|Fantasy  \n",
       "9952                             Action|Adventure|Sci-Fi  \n",
       "12221                            Action|Crime|Drama|IMAX  \n",
       "14937    Action|Crime|Drama|Mystery|Sci-Fi|Thriller|IMAX  "
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "movies_df_s = movies_df[movies_df[\"movieId\"].isin(selected_movies_lst)]\n",
    "movies_df_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_movies = movies_df_s[\"title\"].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [],
   "source": [
    "affinity_mat = np.zeros((_movie_range, _movie_range))\n",
    "\n",
    "godfather_one = movie_to_column[858]\n",
    "godfather_two = movie_to_column[1221]\n",
    "godfather_three = movie_to_column[2023]\n",
    "\n",
    "\n",
    "harry_one = movie_to_column[4896]\n",
    "harry_two = movie_to_column[5816]\n",
    "\n",
    "sw_one = movie_to_column[2628]\n",
    "sw_two = movie_to_column[5378]\n",
    "sw_three = movie_to_column[33493]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Below, I extract the users that are most represented in the data. This will improve the quality of matrix completion and the ratings matrix that I am using."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "ratings_df = ratings_df[ratings_df['movieId'].isin(selected_movies_lst)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_users_gb = ratings_df.groupby('userId').size().sort_values(ascending=False)[:_users_range]\n",
    "selected_users_lst = selected_users_gb.index.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "userId\n",
       "148409    23\n",
       "70401     23\n",
       "93074     23\n",
       "133040    23\n",
       "112101    23\n",
       "          ..\n",
       "138551    23\n",
       "40523     23\n",
       "134638    23\n",
       "144475    23\n",
       "79175     23\n",
       "Length: 100, dtype: int64"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selected_users_gb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "ratings_df_s = ratings_df[ratings_df['userId'].isin(selected_users_lst)] "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Create the ratings matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_to_row = dict((e, idx) for (idx, e) in enumerate(selected_users_lst))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "movie_to_column = dict((e, idx) for (idx, e) in enumerate(selected_movies_lst))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "column_to_movie = dict(enumerate(selected_movies_lst))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "M = np.empty((_users_range, _movie_range))\n",
    "mask = np.zeros((_users_range, _movie_range))\n",
    "\n",
    "M[:] = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "for idx, row in ratings_df_s.iterrows():\n",
    "        user_id, movie_id, rating = int(row[\"userId\"]), int(row[\"movieId\"]), row[\"rating\"]\n",
    "        row, column = user_to_row[user_id], movie_to_column[movie_id]\n",
    "        M[row, column] = rating\n",
    "        mask[row, column] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n,bins,patches = plt.hist(np.ravel(M),20,facecolor='blue',alpha=0.5); \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "execution_count": 150,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#Sparsity ratio\n",
    "np.sum(mask)/mask.size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(100, 23)"
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "M.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "metadata": {},
   "outputs": [],
   "source": [
    "#plt.imshow(M.T)\n",
    "M_filled = M"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Create affinity matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [],
   "source": [
    "affinity_mat[:, godfather_one] = 1\n",
    "affinity_mat[:, harry_one] = 1/2\n",
    "affinity_mat[:, sw_one] = 1\n",
    "\n",
    "affinity_mat[godfather_one, godfather_two] = 10\n",
    "affinity_mat[godfather_two, godfather_three] = 10\n",
    "\n",
    "\n",
    "affinity_mat[harry_one, harry_two] = 10\n",
    "\n",
    "\n",
    "affinity_mat[sw_one, sw_two] = 10\n",
    "affinity_mat[sw_two, sw_three] = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "movies_dict = {}\n",
    "\n",
    "for i in range(_movie_range):\n",
    "    movie = column_to_movie[i]\n",
    "    movie_name = movies_df_s[movies_df[\"movieId\"] == movie][\"title\"].tolist()[0]\n",
    "    movies_dict[movie_name] = affinity_mat[:, i]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "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>Lion King, The (1994)</th>\n",
       "      <th>Speed (1994)</th>\n",
       "      <th>True Lies (1994)</th>\n",
       "      <th>Aladdin (1992)</th>\n",
       "      <th>Dances with Wolves (1990)</th>\n",
       "      <th>Batman (1989)</th>\n",
       "      <th>Godfather, The (1972)</th>\n",
       "      <th>Godfather: Part II, The (1974)</th>\n",
       "      <th>Terminator, The (1984)</th>\n",
       "      <th>Indiana Jones and the Last Crusade (1989)</th>\n",
       "      <th>...</th>\n",
       "      <th>Star Wars: Episode I - The Phantom Menace (1999)</th>\n",
       "      <th>Gladiator (2000)</th>\n",
       "      <th>Memento (2000)</th>\n",
       "      <th>Shrek (2001)</th>\n",
       "      <th>Harry Potter and the Sorcerer's Stone (a.k.a. Harry Potter and the Philosopher's Stone) (2001)</th>\n",
       "      <th>Star Wars: Episode II - Attack of the Clones (2002)</th>\n",
       "      <th>Harry Potter and the Chamber of Secrets (2002)</th>\n",
       "      <th>Star Wars: Episode III - Revenge of the Sith (2005)</th>\n",
       "      <th>Dark Knight, The (2008)</th>\n",
       "      <th>Inception (2010)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>23 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Lion King, The (1994)  Speed (1994)  True Lies (1994)  Aladdin (1992)  \\\n",
       "0                     0.0           0.0               0.0             0.0   \n",
       "1                     0.0           0.0               0.0             0.0   \n",
       "2                     0.0           0.0               0.0             0.0   \n",
       "3                     0.0           0.0               0.0             0.0   \n",
       "4                     0.0           0.0               0.0             0.0   \n",
       "5                     0.0           0.0               0.0             0.0   \n",
       "6                     0.0           0.0               0.0             0.0   \n",
       "7                     0.0           0.0               0.0             0.0   \n",
       "8                     0.0           0.0               0.0             0.0   \n",
       "9                     0.0           0.0               0.0             0.0   \n",
       "10                    0.0           0.0               0.0             0.0   \n",
       "11                    0.0           0.0               0.0             0.0   \n",
       "12                    0.0           0.0               0.0             0.0   \n",
       "13                    0.0           0.0               0.0             0.0   \n",
       "14                    0.0           0.0               0.0             0.0   \n",
       "15                    0.0           0.0               0.0             0.0   \n",
       "16                    0.0           0.0               0.0             0.0   \n",
       "17                    0.0           0.0               0.0             0.0   \n",
       "18                    0.0           0.0               0.0             0.0   \n",
       "19                    0.0           0.0               0.0             0.0   \n",
       "20                    0.0           0.0               0.0             0.0   \n",
       "21                    0.0           0.0               0.0             0.0   \n",
       "22                    0.0           0.0               0.0             0.0   \n",
       "\n",
       "    Dances with Wolves (1990)  Batman (1989)  Godfather, The (1972)  \\\n",
       "0                         0.0            0.0                    1.0   \n",
       "1                         0.0            0.0                    1.0   \n",
       "2                         0.0            0.0                    1.0   \n",
       "3                         0.0            0.0                    1.0   \n",
       "4                         0.0            0.0                    1.0   \n",
       "5                         0.0            0.0                    1.0   \n",
       "6                         0.0            0.0                    1.0   \n",
       "7                         0.0            0.0                    1.0   \n",
       "8                         0.0            0.0                    1.0   \n",
       "9                         0.0            0.0                    1.0   \n",
       "10                        0.0            0.0                    1.0   \n",
       "11                        0.0            0.0                    1.0   \n",
       "12                        0.0            0.0                    1.0   \n",
       "13                        0.0            0.0                    1.0   \n",
       "14                        0.0            0.0                    1.0   \n",
       "15                        0.0            0.0                    1.0   \n",
       "16                        0.0            0.0                    1.0   \n",
       "17                        0.0            0.0                    1.0   \n",
       "18                        0.0            0.0                    1.0   \n",
       "19                        0.0            0.0                    1.0   \n",
       "20                        0.0            0.0                    1.0   \n",
       "21                        0.0            0.0                    1.0   \n",
       "22                        0.0            0.0                    1.0   \n",
       "\n",
       "    Godfather: Part II, The (1974)  Terminator, The (1984)  \\\n",
       "0                              0.0                     0.0   \n",
       "1                              0.0                     0.0   \n",
       "2                              0.0                     0.0   \n",
       "3                              0.0                     0.0   \n",
       "4                              0.0                     0.0   \n",
       "5                              0.0                     0.0   \n",
       "6                             10.0                     0.0   \n",
       "7                              0.0                     0.0   \n",
       "8                              0.0                     0.0   \n",
       "9                              0.0                     0.0   \n",
       "10                             0.0                     0.0   \n",
       "11                             0.0                     0.0   \n",
       "12                             0.0                     0.0   \n",
       "13                             0.0                     0.0   \n",
       "14                             0.0                     0.0   \n",
       "15                             0.0                     0.0   \n",
       "16                             0.0                     0.0   \n",
       "17                             0.0                     0.0   \n",
       "18                             0.0                     0.0   \n",
       "19                             0.0                     0.0   \n",
       "20                             0.0                     0.0   \n",
       "21                             0.0                     0.0   \n",
       "22                             0.0                     0.0   \n",
       "\n",
       "    Indiana Jones and the Last Crusade (1989)  ...  \\\n",
       "0                                         0.0  ...   \n",
       "1                                         0.0  ...   \n",
       "2                                         0.0  ...   \n",
       "3                                         0.0  ...   \n",
       "4                                         0.0  ...   \n",
       "5                                         0.0  ...   \n",
       "6                                         0.0  ...   \n",
       "7                                         0.0  ...   \n",
       "8                                         0.0  ...   \n",
       "9                                         0.0  ...   \n",
       "10                                        0.0  ...   \n",
       "11                                        0.0  ...   \n",
       "12                                        0.0  ...   \n",
       "13                                        0.0  ...   \n",
       "14                                        0.0  ...   \n",
       "15                                        0.0  ...   \n",
       "16                                        0.0  ...   \n",
       "17                                        0.0  ...   \n",
       "18                                        0.0  ...   \n",
       "19                                        0.0  ...   \n",
       "20                                        0.0  ...   \n",
       "21                                        0.0  ...   \n",
       "22                                        0.0  ...   \n",
       "\n",
       "    Star Wars: Episode I - The Phantom Menace (1999)  Gladiator (2000)  \\\n",
       "0                                                1.0               0.0   \n",
       "1                                                1.0               0.0   \n",
       "2                                                1.0               0.0   \n",
       "3                                                1.0               0.0   \n",
       "4                                                1.0               0.0   \n",
       "5                                                1.0               0.0   \n",
       "6                                                1.0               0.0   \n",
       "7                                                1.0               0.0   \n",
       "8                                                1.0               0.0   \n",
       "9                                                1.0               0.0   \n",
       "10                                               1.0               0.0   \n",
       "11                                               1.0               0.0   \n",
       "12                                               1.0               0.0   \n",
       "13                                               1.0               0.0   \n",
       "14                                               1.0               0.0   \n",
       "15                                               1.0               0.0   \n",
       "16                                               1.0               0.0   \n",
       "17                                               1.0               0.0   \n",
       "18                                               1.0               0.0   \n",
       "19                                               1.0               0.0   \n",
       "20                                               1.0               0.0   \n",
       "21                                               1.0               0.0   \n",
       "22                                               1.0               0.0   \n",
       "\n",
       "    Memento (2000)  Shrek (2001)  \\\n",
       "0              0.0           0.0   \n",
       "1              0.0           0.0   \n",
       "2              0.0           0.0   \n",
       "3              0.0           0.0   \n",
       "4              0.0           0.0   \n",
       "5              0.0           0.0   \n",
       "6              0.0           0.0   \n",
       "7              0.0           0.0   \n",
       "8              0.0           0.0   \n",
       "9              0.0           0.0   \n",
       "10             0.0           0.0   \n",
       "11             0.0           0.0   \n",
       "12             0.0           0.0   \n",
       "13             0.0           0.0   \n",
       "14             0.0           0.0   \n",
       "15             0.0           0.0   \n",
       "16             0.0           0.0   \n",
       "17             0.0           0.0   \n",
       "18             0.0           0.0   \n",
       "19             0.0           0.0   \n",
       "20             0.0           0.0   \n",
       "21             0.0           0.0   \n",
       "22             0.0           0.0   \n",
       "\n",
       "    Harry Potter and the Sorcerer's Stone (a.k.a. Harry Potter and the Philosopher's Stone) (2001)  \\\n",
       "0                                                 0.5                                                \n",
       "1                                                 0.5                                                \n",
       "2                                                 0.5                                                \n",
       "3                                                 0.5                                                \n",
       "4                                                 0.5                                                \n",
       "5                                                 0.5                                                \n",
       "6                                                 0.5                                                \n",
       "7                                                 0.5                                                \n",
       "8                                                 0.5                                                \n",
       "9                                                 0.5                                                \n",
       "10                                                0.5                                                \n",
       "11                                                0.5                                                \n",
       "12                                                0.5                                                \n",
       "13                                                0.5                                                \n",
       "14                                                0.5                                                \n",
       "15                                                0.5                                                \n",
       "16                                                0.5                                                \n",
       "17                                                0.5                                                \n",
       "18                                                0.5                                                \n",
       "19                                                0.5                                                \n",
       "20                                                0.5                                                \n",
       "21                                                0.5                                                \n",
       "22                                                0.5                                                \n",
       "\n",
       "    Star Wars: Episode II - Attack of the Clones (2002)  \\\n",
       "0                                                 0.0     \n",
       "1                                                 0.0     \n",
       "2                                                 0.0     \n",
       "3                                                 0.0     \n",
       "4                                                 0.0     \n",
       "5                                                 0.0     \n",
       "6                                                 0.0     \n",
       "7                                                 0.0     \n",
       "8                                                 0.0     \n",
       "9                                                 0.0     \n",
       "10                                                0.0     \n",
       "11                                                0.0     \n",
       "12                                                0.0     \n",
       "13                                               10.0     \n",
       "14                                                0.0     \n",
       "15                                                0.0     \n",
       "16                                                0.0     \n",
       "17                                                0.0     \n",
       "18                                                0.0     \n",
       "19                                                0.0     \n",
       "20                                                0.0     \n",
       "21                                                0.0     \n",
       "22                                                0.0     \n",
       "\n",
       "    Harry Potter and the Chamber of Secrets (2002)  \\\n",
       "0                                              0.0   \n",
       "1                                              0.0   \n",
       "2                                              0.0   \n",
       "3                                              0.0   \n",
       "4                                              0.0   \n",
       "5                                              0.0   \n",
       "6                                              0.0   \n",
       "7                                              0.0   \n",
       "8                                              0.0   \n",
       "9                                              0.0   \n",
       "10                                             0.0   \n",
       "11                                             0.0   \n",
       "12                                             0.0   \n",
       "13                                             0.0   \n",
       "14                                             0.0   \n",
       "15                                             0.0   \n",
       "16                                             0.0   \n",
       "17                                            10.0   \n",
       "18                                             0.0   \n",
       "19                                             0.0   \n",
       "20                                             0.0   \n",
       "21                                             0.0   \n",
       "22                                             0.0   \n",
       "\n",
       "    Star Wars: Episode III - Revenge of the Sith (2005)  \\\n",
       "0                                                 0.0     \n",
       "1                                                 0.0     \n",
       "2                                                 0.0     \n",
       "3                                                 0.0     \n",
       "4                                                 0.0     \n",
       "5                                                 0.0     \n",
       "6                                                 0.0     \n",
       "7                                                 0.0     \n",
       "8                                                 0.0     \n",
       "9                                                 0.0     \n",
       "10                                                0.0     \n",
       "11                                                0.0     \n",
       "12                                                0.0     \n",
       "13                                                0.0     \n",
       "14                                                0.0     \n",
       "15                                                0.0     \n",
       "16                                                0.0     \n",
       "17                                                0.0     \n",
       "18                                               10.0     \n",
       "19                                                0.0     \n",
       "20                                                0.0     \n",
       "21                                                0.0     \n",
       "22                                                0.0     \n",
       "\n",
       "    Dark Knight, The (2008)  Inception (2010)  \n",
       "0                       0.0               0.0  \n",
       "1                       0.0               0.0  \n",
       "2                       0.0               0.0  \n",
       "3                       0.0               0.0  \n",
       "4                       0.0               0.0  \n",
       "5                       0.0               0.0  \n",
       "6                       0.0               0.0  \n",
       "7                       0.0               0.0  \n",
       "8                       0.0               0.0  \n",
       "9                       0.0               0.0  \n",
       "10                      0.0               0.0  \n",
       "11                      0.0               0.0  \n",
       "12                      0.0               0.0  \n",
       "13                      0.0               0.0  \n",
       "14                      0.0               0.0  \n",
       "15                      0.0               0.0  \n",
       "16                      0.0               0.0  \n",
       "17                      0.0               0.0  \n",
       "18                      0.0               0.0  \n",
       "19                      0.0               0.0  \n",
       "20                      0.0               0.0  \n",
       "21                      0.0               0.0  \n",
       "22                      0.0               0.0  \n",
       "\n",
       "[23 rows x 23 columns]"
      ]
     },
     "execution_count": 149,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "affinity_df = pd.DataFrame(movies_dict)\n",
    "affinity_df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Perform KMeans on Users"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [],
   "source": [
    "#normalized_ratings = np.array([row/np.linalg.norm(row) for row in M_filled])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "kmeans = KMeans(n_clusters=_num_meta_users, random_state=0).fit(M_filled)\n",
    "cluster_centers = kmeans.cluster_centers_\n",
    "user_labels = kmeans.labels_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n",
       "       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], dtype=int32)"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "user_labels"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Objective Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "Online reward evaluation\n",
    "\"\"\"\n",
    "def compute_affinity_gain(S_i, new_movie, affinity_mat):\n",
    "    \n",
    "    #Rows are movies that are already chosen\n",
    "    affinity_mat_filtered = affinity_mat[S_i]\n",
    "    \n",
    "    relevant_column = affinity_mat_filtered[:, new_movie]\n",
    "    return np.sum(relevant_column)\n",
    "\n",
    "\n",
    "def compute_facility_location_gain(S_i, new_movie, ratings_mat, running_max_per_user):    \n",
    "    S_new = copy.deepcopy(S_i)\n",
    "    S_new.append(new_movie)\n",
    "    \n",
    "    new_maxes = np.max(ratings_mat[:, S_new], axis = 1)\n",
    "    gain = np.sum(new_maxes) - np.sum(running_max_per_user)\n",
    "    \n",
    "    return gain, new_maxes\n",
    "\n",
    "\n",
    "def compute_bp_gain(S_i, new_movie, affinity_mat, ratings_mat, running_max_per_user, lambda_one, mutate = False):\n",
    "    \n",
    "    sub_gain, new_maxes = compute_facility_location_gain(S_i, new_movie, ratings_mat, running_max_per_user)\n",
    "    sup_gain = compute_affinity_gain(S_i, new_movie, affinity_mat)\n",
    "    \n",
    "    bp_gain = lambda_one * sup_gain + sub_gain\n",
    "    \n",
    "    if mutate :\n",
    "        return new_maxes, bp_gain\n",
    "    else:\n",
    "        return bp_gain"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Environment and Greedy for Simulation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Environment:\n",
    "\n",
    "    def __init__(self, T, sigma, lambda_one, ratings_mat, affinity_mat, movies_df_s, \n",
    "                  recommender, column_to_movie, seed = 0):\n",
    "        \n",
    "        self.T = T\n",
    "        self.sigma = sigma\n",
    "        self.lambda_one = lambda_one\n",
    "        self.ratings_mat = ratings_mat\n",
    "        self.affinity_mat = affinity_mat\n",
    "        self.movies_df_s = movies_df_s\n",
    "        self.recommender = recommender\n",
    "        self.column_to_movie = column_to_movie\n",
    "        self.seed = seed\n",
    "\n",
    "    def run_simulation(self):\n",
    "        user_range, movie_range = self.ratings_mat.shape\n",
    "\n",
    "        Si_lst = []\n",
    "        yi_hist = []\n",
    "        sub_hist, sup_hist = [], []\n",
    "        running_max = np.zeros(user_range)\n",
    "\n",
    "        for i in range(self.T):\n",
    "\n",
    "            Si = Si_lst\n",
    "\n",
    "            #Obtain recommendation from recommender\n",
    "            x_i = self.recommender.get_next_item()\n",
    "\n",
    "            movie_id = self.column_to_movie[x_i]\n",
    "            print(self.movies_df_s[self.movies_df_s[\"movieId\"] == movie_id])\n",
    "            print(\"\\n\")\n",
    "            Si_lst.append(x_i)\n",
    "\n",
    "            \n",
    "            sup_gain  = compute_affinity_gain(Si, x_i, self.affinity_mat)\n",
    "            sub_gain, new_maxes = compute_facility_location_gain(Si, x_i, self.ratings_mat, \n",
    "                                                                 running_max)\n",
    "            running_max = new_maxes\n",
    "            \n",
    "            if i > 0:\n",
    "                sub = sub_hist[-1] + sub_gain\n",
    "                sup =  sup_hist[-1] + self.lambda_one*sup_gain\n",
    "            else :\n",
    "                sub, sup = sub_gain, self.lambda_one*sup_gain\n",
    "\n",
    "\n",
    "            #Get reward\n",
    "            y_i = sub_gain + self.lambda_one*sup_gain + self.sigma*np.random.normal()\n",
    "\n",
    "            #Bookkeeping\n",
    "            sub_hist.append(sub)\n",
    "            sup_hist.append(sup)\n",
    "            yi_hist.append(y_i)\n",
    "\n",
    "        return Si_lst, yi_hist, sub_hist, sup_hist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [],
   "source": [
    "class GreedyBaseline:\n",
    "\n",
    "    def __init__(self, ground_set, column_to_movie, movies_df_s, ratings_mat, affinity_mat, lambda_one):\n",
    "\n",
    "        #Information about the ground set\n",
    "        self.ground_set = ground_set\n",
    "        self.movies_df_s = movies_df_s\n",
    "        self.ratings_mat = ratings_mat\n",
    "        self.lambda_one = lambda_one\n",
    "        self.affinity_mat = affinity_mat\n",
    "\n",
    "        #Record what is happening in the game\n",
    "        self.yi_list = []\n",
    "        self.selected = []\n",
    "        self.running_max_per_user = np.zeros(len(ratings_mat))\n",
    "    \n",
    "\n",
    "    def get_next_item(self):\n",
    "\n",
    "        potential_gains = []\n",
    "\n",
    "        for item in self.ground_set:\n",
    "            if item in self.selected:\n",
    "                potential_gains.append(0)\n",
    "                continue\n",
    "            else :\n",
    "                gain = compute_bp_gain(self.selected, item, self.affinity_mat, self.ratings_mat, \n",
    "                                       self.running_max_per_user, self.lambda_one, mutate = False)\n",
    "                \n",
    "                potential_gains.append(gain)\n",
    "                \n",
    "        selected_movie = np.argmax(potential_gains)\n",
    "        self.selected.append(selected_movie)\n",
    "\n",
    "        gain, running_max = compute_bp_gain(self.selected, selected_movie, self.affinity_mat, self.ratings_mat, \n",
    "                                       self.running_max_per_user, self.lambda_one, mutate = True)\n",
    "        \n",
    "        self.running_max_per_user = running_max\n",
    "        return selected_movie\n",
    "\n",
    "    def receive_reward(self, yi):\n",
    "        self.yi_list.append(yi)\n",
    "        return True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Running the Algorithm "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [],
   "source": [
    "ground_set = np.arange(_movie_range)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "User identity at iteration 0 is: 0\n",
      "      movieId                title  genres\n",
      "1225     1258  Shining, The (1980)  Horror\n",
      "\n",
      "\n",
      "User identity at iteration 1 is: 1\n",
      "      movieId           title            genres\n",
      "4122     4226  Memento (2000)  Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 2 is: 0\n",
      "      movieId                        title        genres\n",
      "1052     1079  Fish Called Wanda, A (1988)  Comedy|Crime\n",
      "\n",
      "\n",
      "User identity at iteration 3 is: 1\n",
      "       movieId                          title       genres\n",
      "11932    55820  No Country for Old Men (2007)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 4 is: 1\n",
      "      movieId           title                genres\n",
      "3930     4034  Traffic (2000)  Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 5 is: 2\n",
      "      movieId                      title genres\n",
      "1213     1246  Dead Poets Society (1989)  Drama\n",
      "\n",
      "\n",
      "User identity at iteration 6 is: 0\n",
      "      movieId                                             title  \\\n",
      "2537     2628  Star Wars: Episode I - The Phantom Menace (1999)   \n",
      "\n",
      "                       genres  \n",
      "2537  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 7 is: 2\n",
      "      movieId           title         genres\n",
      "1655     1721  Titanic (1997)  Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 8 is: 0\n",
      "      movieId                  title                  genres\n",
      "1062     1089  Reservoir Dogs (1992)  Crime|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 9 is: 0\n",
      "      movieId              title    genres\n",
      "5158     5266  Panic Room (2002)  Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 10 is: 0\n",
      "      movieId           title            genres\n",
      "4122     4226  Memento (2000)  Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 11 is: 2\n",
      "      movieId            title                         genres\n",
      "6211     6323  Identity (2003)  Crime|Horror|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 12 is: 1\n",
      "      movieId                       title  \\\n",
      "1167     1197  Princess Bride, The (1987)   \n",
      "\n",
      "                                       genres  \n",
      "1167  Action|Adventure|Comedy|Fantasy|Romance  \n",
      "\n",
      "\n",
      "User identity at iteration 13 is: 2\n",
      "      movieId                 title                  genres\n",
      "1232     1265  Groundhog Day (1993)  Comedy|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 14 is: 2\n",
      "      movieId              title                       genres\n",
      "8083     8798  Collateral (2004)  Action|Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 15 is: 0\n",
      "      movieId                     title        genres\n",
      "1666     1732  Big Lebowski, The (1998)  Comedy|Crime\n",
      "\n",
      "\n",
      "User identity at iteration 16 is: 1\n",
      "     movieId                       title                             genres\n",
      "637      648  Mission: Impossible (1996)  Action|Adventure|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 17 is: 1\n",
      "      movieId               title                  genres\n",
      "2480     2571  Matrix, The (1999)  Action|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 18 is: 1\n",
      "      movieId                                       title  \\\n",
      "2624     2716  Ghostbusters (a.k.a. Ghost Busters) (1984)   \n",
      "\n",
      "                    genres  \n",
      "2624  Action|Comedy|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 19 is: 1\n",
      "      movieId          title                          genres\n",
      "1170     1200  Aliens (1986)  Action|Adventure|Horror|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 20 is: 0\n",
      "      movieId            title         genres\n",
      "1914     2003  Gremlins (1984)  Comedy|Horror\n",
      "\n",
      "\n",
      "User identity at iteration 21 is: 1\n",
      "      movieId                          title                     genres\n",
      "3524     3623  Mission: Impossible II (2000)  Action|Adventure|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 22 is: 0\n",
      "      movieId                      title                genres\n",
      "1707     1784  As Good as It Gets (1997)  Comedy|Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 23 is: 0\n",
      "       movieId                    title                   genres\n",
      "12221    58559  Dark Knight, The (2008)  Action|Crime|Drama|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 24 is: 1\n",
      "       movieId                 title             genres\n",
      "10002    33794  Batman Begins (2005)  Action|Crime|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 25 is: 2\n",
      "       movieId                 title                         genres\n",
      "11163    48780  Prestige, The (2006)  Drama|Mystery|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 26 is: 0\n",
      "      movieId                             title                genres\n",
      "1523     1580  Men in Black (a.k.a. MIB) (1997)  Action|Comedy|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 27 is: 2\n",
      "      movieId                         title                 genres\n",
      "7952     8665  Bourne Supremacy, The (2004)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 28 is: 0\n",
      "      movieId              title                       genres\n",
      "8083     8798  Collateral (2004)  Action|Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 29 is: 1\n",
      "      movieId         title         genres\n",
      "1183     1214  Alien (1979)  Horror|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 30 is: 1\n",
      "      movieId                title                        genres\n",
      "7923     8636  Spider-Man 2 (2004)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 31 is: 2\n",
      "      movieId                 title                     genres\n",
      "1911     2000  Lethal Weapon (1987)  Action|Comedy|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 32 is: 0\n",
      "       movieId            title                       genres\n",
      "11407    51255  Hot Fuzz (2007)  Action|Comedy|Crime|Mystery\n",
      "\n",
      "\n",
      "User identity at iteration 33 is: 1\n",
      "      movieId                                      title  \\\n",
      "3374     3471  Close Encounters of the Third Kind (1977)   \n",
      "\n",
      "                      genres  \n",
      "3374  Adventure|Drama|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 34 is: 1\n",
      "      movieId               title        genres\n",
      "3890     3994  Unbreakable (2000)  Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 35 is: 1\n",
      "      movieId                     title                 genres\n",
      "7299     7438  Kill Bill: Vol. 2 (2004)  Action|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 36 is: 0\n",
      "      movieId                                              title  \\\n",
      "3892     3996  Crouching Tiger, Hidden Dragon (Wo hu cang lon...   \n",
      "\n",
      "                    genres  \n",
      "3892  Action|Drama|Romance  \n",
      "\n",
      "\n",
      "User identity at iteration 37 is: 2\n",
      "      movieId               title                             genres\n",
      "2798     2890  Three Kings (1999)  Action|Adventure|Comedy|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 38 is: 0\n",
      "       movieId                   title                                  genres\n",
      "11162    48774  Children of Men (2006)  Action|Adventure|Drama|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 39 is: 2\n",
      "      movieId                title        genres\n",
      "2411     2502  Office Space (1999)  Comedy|Crime\n",
      "\n",
      "\n",
      "User identity at iteration 40 is: 2\n",
      "      movieId                      title                genres\n",
      "1707     1784  As Good as It Gets (1997)  Comedy|Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 41 is: 0\n",
      "       movieId                 title                genres\n",
      "11124    48516  Departed, The (2006)  Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 42 is: 2\n",
      "       movieId            title                   genres\n",
      "12324    59315  Iron Man (2008)  Action|Adventure|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 43 is: 0\n",
      "    movieId                       title                  genres\n",
      "49       50  Usual Suspects, The (1995)  Crime|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 44 is: 0\n",
      "      movieId                                title                  genres\n",
      "4265     4370  A.I. Artificial Intelligence (2001)  Adventure|Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 45 is: 0\n",
      "      movieId                      title       genres\n",
      "2238     2329  American History X (1998)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 46 is: 1\n",
      "      movieId                 title                  genres\n",
      "1232     1265  Groundhog Day (1993)  Comedy|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 47 is: 1\n",
      "      movieId          title                          genres\n",
      "1369     1407  Scream (1996)  Comedy|Horror|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 48 is: 2\n",
      "      movieId                 title                genres\n",
      "6379     6502  28 Days Later (2002)  Action|Horror|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 49 is: 0\n",
      "      movieId            title        genres\n",
      "2304     2395  Rushmore (1998)  Comedy|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 50 is: 0\n",
      "   movieId             title                                       genres\n",
      "0        1  Toy Story (1995)  Adventure|Animation|Children|Comedy|Fantasy\n",
      "\n",
      "\n",
      "User identity at iteration 51 is: 1\n",
      "      movieId                            title  genres\n",
      "2826     2918  Ferris Bueller's Day Off (1986)  Comedy\n",
      "\n",
      "\n",
      "User identity at iteration 52 is: 0\n",
      "      movieId          title                          genres\n",
      "1369     1407  Scream (1996)  Comedy|Horror|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 53 is: 1\n",
      "      movieId           title                     genres\n",
      "1497     1552  Con Air (1997)  Action|Adventure|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 54 is: 2\n",
      "       movieId                   title                                  genres\n",
      "11162    48774  Children of Men (2006)  Action|Adventure|Drama|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 55 is: 2\n",
      "     movieId                title                    genres\n",
      "351      356  Forrest Gump (1994)  Comedy|Drama|Romance|War\n",
      "\n",
      "\n",
      "User identity at iteration 56 is: 0\n",
      "      movieId       title                        genres\n",
      "2705     2797  Big (1988)  Comedy|Drama|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 57 is: 1\n",
      "     movieId                             title       genres\n",
      "314      318  Shawshank Redemption, The (1994)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 58 is: 1\n",
      "     movieId                              title         genres\n",
      "581      589  Terminator 2: Judgment Day (1991)  Action|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 59 is: 1\n",
      "      movieId                      title                   genres\n",
      "1237     1270  Back to the Future (1985)  Adventure|Comedy|Sci-Fi\n",
      "\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "User identity at iteration 60 is: 1\n",
      "     movieId                     title                              genres\n",
      "898      919  Wizard of Oz, The (1939)  Adventure|Children|Fantasy|Musical\n",
      "\n",
      "\n",
      "User identity at iteration 61 is: 2\n",
      "      movieId                                              title  \\\n",
      "9952    33493  Star Wars: Episode III - Revenge of the Sith (...   \n",
      "\n",
      "                       genres  \n",
      "9952  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 62 is: 2\n",
      "      movieId               title                genres\n",
      "5269     5377  About a Boy (2002)  Comedy|Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 63 is: 2\n",
      "       movieId                    title                   genres\n",
      "12221    58559  Dark Knight, The (2008)  Action|Crime|Drama|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 64 is: 0\n",
      "      movieId             title genres\n",
      "3918     4022  Cast Away (2000)  Drama\n",
      "\n",
      "\n",
      "User identity at iteration 65 is: 2\n",
      "      movieId                    title                                  genres\n",
      "4742     4848  Mulholland Drive (2001)  Crime|Drama|Film-Noir|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 66 is: 1\n",
      "     movieId              title            genres\n",
      "108      110  Braveheart (1995)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 67 is: 0\n",
      "       movieId                  title                  genres\n",
      "14336    74458  Shutter Island (2010)  Drama|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 68 is: 1\n",
      "      movieId              title  \\\n",
      "2526     2617  Mummy, The (1999)   \n",
      "\n",
      "                                               genres  \n",
      "2526  Action|Adventure|Comedy|Fantasy|Horror|Thriller  \n",
      "\n",
      "\n",
      "User identity at iteration 69 is: 2\n",
      "      movieId                  title  \\\n",
      "4780     4886  Monsters, Inc. (2001)   \n",
      "\n",
      "                                           genres  \n",
      "4780  Adventure|Animation|Children|Comedy|Fantasy  \n",
      "\n",
      "\n",
      "User identity at iteration 70 is: 0\n",
      "      movieId                 title                          genres\n",
      "2988     3081  Sleepy Hollow (1999)  Fantasy|Horror|Mystery|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 71 is: 0\n",
      "      movieId                                         title  \\\n",
      "7236     7361  Eternal Sunshine of the Spotless Mind (2004)   \n",
      "\n",
      "                    genres  \n",
      "7236  Drama|Romance|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 72 is: 2\n",
      "    movieId                       title                  genres\n",
      "49       50  Usual Suspects, The (1995)  Crime|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 73 is: 0\n",
      "      movieId         title       genres\n",
      "9900    33166  Crash (2004)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 74 is: 0\n",
      "      movieId            title                               genres\n",
      "5280     5388  Insomnia (2002)  Action|Crime|Drama|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 75 is: 0\n",
      "      movieId                title                         genres\n",
      "4772     4878  Donnie Darko (2001)  Drama|Mystery|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 76 is: 0\n",
      "     movieId          title                 genres\n",
      "584      592  Batman (1989)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 77 is: 0\n",
      "      movieId                     title         genres\n",
      "8159     8874  Shaun of the Dead (2004)  Comedy|Horror\n",
      "\n",
      "\n",
      "User identity at iteration 78 is: 0\n",
      "      movieId                         title                 genres\n",
      "7952     8665  Bourne Supremacy, The (2004)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 79 is: 2\n",
      "      movieId         title         genres\n",
      "1183     1214  Alien (1979)  Horror|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 80 is: 0\n",
      "      movieId            title                 genres\n",
      "7022     7147  Big Fish (2003)  Drama|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 81 is: 2\n",
      "       movieId             title   genres\n",
      "15673    82459  True Grit (2010)  Western\n",
      "\n",
      "\n",
      "User identity at iteration 82 is: 1\n",
      "       movieId                    title                     genres\n",
      "13445    69481  Hurt Locker, The (2008)  Action|Drama|Thriller|War\n",
      "\n",
      "\n",
      "User identity at iteration 83 is: 1\n",
      "     movieId                              title                 genres\n",
      "163      165  Die Hard: With a Vengeance (1995)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 84 is: 1\n",
      "     movieId                 title    genres\n",
      "452      457  Fugitive, The (1993)  Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 85 is: 0\n",
      "     movieId             title                     genres\n",
      "718      733  Rock, The (1996)  Action|Adventure|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 86 is: 1\n",
      "      movieId                   title            genres\n",
      "4904     5010  Black Hawk Down (2001)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 87 is: 1\n",
      "      movieId                     title         genres\n",
      "8159     8874  Shaun of the Dead (2004)  Comedy|Horror\n",
      "\n",
      "\n",
      "User identity at iteration 88 is: 1\n",
      "       movieId                title                      genres\n",
      "11811    54997  3:10 to Yuma (2007)  Action|Crime|Drama|Western\n",
      "\n",
      "\n",
      "User identity at iteration 89 is: 0\n",
      "      movieId                  title            genres\n",
      "1177     1208  Apocalypse Now (1979)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 90 is: 1\n",
      "      movieId                                  title  \\\n",
      "1489     1544  Lost World: Jurassic Park, The (1997)   \n",
      "\n",
      "                                genres  \n",
      "1489  Action|Adventure|Sci-Fi|Thriller  \n",
      "\n",
      "\n",
      "User identity at iteration 91 is: 2\n",
      "      movieId                      title       genres\n",
      "2238     2329  American History X (1998)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 92 is: 0\n",
      "     movieId                 title              genres\n",
      "762      778  Trainspotting (1996)  Comedy|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 93 is: 1\n",
      "      movieId              title    genres\n",
      "5158     5266  Panic Room (2002)  Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 94 is: 2\n",
      "      movieId                       title                 genres\n",
      "2200     2291  Edward Scissorhands (1990)  Drama|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 95 is: 0\n",
      "      movieId               title                  genres\n",
      "2480     2571  Matrix, The (1999)  Action|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 96 is: 2\n",
      "      movieId            title              genres\n",
      "4158     4262  Scarface (1983)  Action|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 97 is: 0\n",
      "      movieId                        title                   genres\n",
      "5310     5418  Bourne Identity, The (2002)  Action|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 98 is: 1\n",
      "      movieId                                              title  \\\n",
      "1466     1517  Austin Powers: International Man of Mystery (1...   \n",
      "\n",
      "                       genres  \n",
      "1466  Action|Adventure|Comedy  \n",
      "\n",
      "\n",
      "User identity at iteration 99 is: 2\n",
      "      movieId                     title         genres\n",
      "1640     1704  Good Will Hunting (1997)  Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 100 is: 2\n",
      "      movieId               title                  genres\n",
      "2480     2571  Matrix, The (1999)  Action|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 101 is: 1\n",
      "     movieId                 title                            genres\n",
      "475      480  Jurassic Park (1993)  Action|Adventure|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 102 is: 0\n",
      "      movieId               title                             genres\n",
      "2798     2890  Three Kings (1999)  Action|Adventure|Comedy|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 103 is: 1\n",
      "       movieId            title                   genres\n",
      "12324    59315  Iron Man (2008)  Action|Adventure|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 104 is: 1\n",
      "       movieId                  title                       genres\n",
      "10679    44191  V for Vendetta (2006)  Action|Sci-Fi|Thriller|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 105 is: 0\n",
      "      movieId                title                            genres\n",
      "2824     2916  Total Recall (1990)  Action|Adventure|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 106 is: 2\n",
      "      movieId           title                     genres\n",
      "1497     1552  Con Air (1997)  Action|Adventure|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 107 is: 2\n",
      "      movieId           title        genres\n",
      "1527     1584  Contact (1997)  Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 108 is: 2\n",
      "      movieId           title                 genres\n",
      "1591     1653  Gattaca (1997)  Drama|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 109 is: 2\n",
      "      movieId           title     genres\n",
      "1063     1090  Platoon (1986)  Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 110 is: 1\n",
      "      movieId                                              title  \\\n",
      "3892     3996  Crouching Tiger, Hidden Dragon (Wo hu cang lon...   \n",
      "\n",
      "                    genres  \n",
      "3892  Action|Drama|Romance  \n",
      "\n",
      "\n",
      "User identity at iteration 111 is: 2\n",
      "      movieId                                      title  \\\n",
      "3374     3471  Close Encounters of the Third Kind (1977)   \n",
      "\n",
      "                      genres  \n",
      "3374  Adventure|Drama|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 112 is: 2\n",
      "      movieId             title                   genres\n",
      "5568     5679  Ring, The (2002)  Horror|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 113 is: 2\n",
      "     movieId             title                genres\n",
      "148      150  Apollo 13 (1995)  Adventure|Drama|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 114 is: 2\n",
      "      movieId                       title                genres\n",
      "6588     6711  Lost in Translation (2003)  Comedy|Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 115 is: 2\n",
      "      movieId                     title         genres\n",
      "8159     8874  Shaun of the Dead (2004)  Comedy|Horror\n",
      "\n",
      "\n",
      "User identity at iteration 116 is: 0\n",
      "      movieId                                      title            genres\n",
      "1258     1291  Indiana Jones and the Last Crusade (1989)  Action|Adventure\n",
      "\n",
      "\n",
      "User identity at iteration 117 is: 1\n",
      "      movieId         title                  genres\n",
      "5394     5502  Signs (2002)  Horror|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 118 is: 2\n",
      "      movieId            title                                   genres\n",
      "9778    32587  Sin City (2005)  Action|Crime|Film-Noir|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 119 is: 2\n",
      "      movieId                            title  genres\n",
      "2826     2918  Ferris Bueller's Day Off (1986)  Comedy\n",
      "\n",
      "\n",
      "User identity at iteration 120 is: 1\n",
      "      movieId                                              title  \\\n",
      "6416     6539  Pirates of the Caribbean: The Curse of the Bla...   \n",
      "\n",
      "                               genres  \n",
      "6416  Action|Adventure|Comedy|Fantasy  \n",
      "\n",
      "\n",
      "User identity at iteration 121 is: 2\n",
      "      movieId                     title     genres\n",
      "1191     1222  Full Metal Jacket (1987)  Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 122 is: 1\n",
      "      movieId                      title       genres\n",
      "2238     2329  American History X (1998)  Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 123 is: 0\n",
      "       movieId          title                        genres\n",
      "14102    72998  Avatar (2009)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 124 is: 2\n",
      "      movieId                title                        genres\n",
      "7923     8636  Spider-Man 2 (2004)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 125 is: 2\n",
      "       movieId            title                       genres\n",
      "11407    51255  Hot Fuzz (2007)  Action|Comedy|Crime|Mystery\n",
      "\n",
      "\n",
      "User identity at iteration 126 is: 0\n",
      "      movieId                 title                     genres\n",
      "1911     2000  Lethal Weapon (1987)  Action|Comedy|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 127 is: 2\n",
      "      movieId          title                          genres\n",
      "1170     1200  Aliens (1986)  Action|Adventure|Horror|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 128 is: 0\n",
      "      movieId            title                       genres\n",
      "1517     1573  Face/Off (1997)  Action|Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 129 is: 0\n",
      "      movieId                                title          genres\n",
      "1834     1923  There's Something About Mary (1998)  Comedy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 130 is: 2\n",
      "     movieId         title                                 genres\n",
      "579      587  Ghost (1990)  Comedy|Drama|Fantasy|Romance|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 131 is: 0\n",
      "     movieId           title                             genres\n",
      "721      736  Twister (1996)  Action|Adventure|Romance|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 132 is: 2\n",
      "      movieId                     title        genres\n",
      "1666     1732  Big Lebowski, The (1998)  Comedy|Crime\n",
      "\n",
      "\n",
      "User identity at iteration 133 is: 2\n",
      "      movieId                                        title  \\\n",
      "2025     2115  Indiana Jones and the Temple of Doom (1984)   \n",
      "\n",
      "                        genres  \n",
      "2025  Action|Adventure|Fantasy  \n",
      "\n",
      "\n",
      "User identity at iteration 134 is: 2\n",
      "      movieId                   title            genres\n",
      "4904     5010  Black Hawk Down (2001)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 135 is: 0\n",
      "      movieId                title                        genres\n",
      "7923     8636  Spider-Man 2 (2004)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 136 is: 0\n",
      "      movieId                       title                 genres\n",
      "2200     2291  Edward Scissorhands (1990)  Drama|Fantasy|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 137 is: 0\n",
      "      movieId                                      title  \\\n",
      "3374     3471  Close Encounters of the Third Kind (1977)   \n",
      "\n",
      "                      genres  \n",
      "3374  Adventure|Drama|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 138 is: 1\n",
      "       movieId        title                genres\n",
      "11983    56367  Juno (2007)  Comedy|Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 139 is: 2\n",
      "      movieId                     title         genres\n",
      "1614     1676  Starship Troopers (1997)  Action|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 140 is: 0\n",
      "      movieId             title                  genres\n",
      "3479     3578  Gladiator (2000)  Action|Adventure|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 141 is: 1\n",
      "       movieId                       title                         genres\n",
      "10275    38061  Kiss Kiss Bang Bang (2005)  Comedy|Crime|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 142 is: 2\n",
      "       movieId                 title                genres\n",
      "11124    48516  Departed, The (2006)  Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 143 is: 2\n",
      "      movieId                title                               genres\n",
      "6258     6377  Finding Nemo (2003)  Adventure|Animation|Children|Comedy\n",
      "\n",
      "\n",
      "User identity at iteration 144 is: 2\n",
      "       movieId                  title               genres\n",
      "11866    55290  Gone Baby Gone (2007)  Crime|Drama|Mystery\n",
      "\n",
      "\n",
      "User identity at iteration 145 is: 1\n",
      "     movieId             title                                    genres\n",
      "375      380  True Lies (1994)  Action|Adventure|Comedy|Romance|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 146 is: 0\n",
      "      movieId            title              genres\n",
      "4158     4262  Scarface (1983)  Action|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 147 is: 0\n",
      "      movieId                                              title  \\\n",
      "9952    33493  Star Wars: Episode III - Revenge of the Sith (...   \n",
      "\n",
      "                       genres  \n",
      "9952  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 148 is: 0\n",
      "      movieId               title           genres\n",
      "1226     1259  Stand by Me (1986)  Adventure|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 149 is: 0\n",
      "      movieId                                          title  \\\n",
      "5840     5952  Lord of the Rings: The Two Towers, The (2002)   \n",
      "\n",
      "                 genres  \n",
      "5840  Adventure|Fantasy  \n",
      "\n",
      "\n",
      "User identity at iteration 150 is: 2\n",
      "      movieId            title                               genres\n",
      "5280     5388  Insomnia (2002)  Action|Crime|Drama|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 151 is: 2\n",
      "      movieId                                             title  \\\n",
      "2537     2628  Star Wars: Episode I - The Phantom Menace (1999)   \n",
      "\n",
      "                       genres  \n",
      "2537  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 152 is: 0\n",
      "      movieId                     title     genres\n",
      "1191     1222  Full Metal Jacket (1987)  Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 153 is: 0\n",
      "      movieId           title          genres\n",
      "1074     1101  Top Gun (1986)  Action|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 154 is: 0\n",
      "     movieId                        title                 genres\n",
      "285      288  Natural Born Killers (1994)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 155 is: 1\n",
      "      movieId            title                 genres\n",
      "1013     1036  Die Hard (1988)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 156 is: 2\n",
      "      movieId            title        genres\n",
      "2304     2395  Rushmore (1998)  Comedy|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 157 is: 0\n",
      "       movieId                        title            genres\n",
      "13249    68157  Inglourious Basterds (2009)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 158 is: 0\n",
      "      movieId                     title         genres\n",
      "1640     1704  Good Will Hunting (1997)  Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 159 is: 1\n",
      "      movieId             title                  genres\n",
      "3479     3578  Gladiator (2000)  Action|Adventure|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 160 is: 0\n",
      "       movieId             title                                   genres\n",
      "10451    41569  King Kong (2005)  Action|Adventure|Drama|Fantasy|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 161 is: 2\n",
      "      movieId                                       title  \\\n",
      "2624     2716  Ghostbusters (a.k.a. Ghost Busters) (1984)   \n",
      "\n",
      "                    genres  \n",
      "2624  Action|Comedy|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 162 is: 1\n",
      "       movieId                   title                                  genres\n",
      "11162    48774  Children of Men (2006)  Action|Adventure|Drama|Sci-Fi|Thriller\n",
      "\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "User identity at iteration 163 is: 1\n",
      "      movieId                title                genres\n",
      "4670     4776  Training Day (2001)  Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 164 is: 1\n",
      "      movieId              title                            genres\n",
      "5241     5349  Spider-Man (2002)  Action|Adventure|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 165 is: 0\n",
      "      movieId           title                              genres\n",
      "2893     2985  RoboCop (1987)  Action|Crime|Drama|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 166 is: 0\n",
      "      movieId          title                 genres\n",
      "3907     4011  Snatch (2000)  Comedy|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 167 is: 0\n",
      "      movieId                                              title  \\\n",
      "1179     1210  Star Wars: Episode VI - Return of the Jedi (1983)   \n",
      "\n",
      "                       genres  \n",
      "1179  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 168 is: 1\n",
      "       movieId             title  \\\n",
      "14937    79132  Inception (2010)   \n",
      "\n",
      "                                                genres  \n",
      "14937  Action|Crime|Drama|Mystery|Sci-Fi|Thriller|IMAX  \n",
      "\n",
      "\n",
      "User identity at iteration 169 is: 1\n",
      "      movieId                     title                 genres\n",
      "6751     6874  Kill Bill: Vol. 1 (2003)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 170 is: 2\n",
      "       movieId                 title             genres\n",
      "10002    33794  Batman Begins (2005)  Action|Crime|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 171 is: 1\n",
      "      movieId                                         title  \\\n",
      "7236     7361  Eternal Sunshine of the Spotless Mind (2004)   \n",
      "\n",
      "                    genres  \n",
      "7236  Drama|Romance|Sci-Fi  \n",
      "\n",
      "\n",
      "User identity at iteration 172 is: 0\n",
      "      movieId           title     genres\n",
      "1063     1090  Platoon (1986)  Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 173 is: 0\n",
      "      movieId               title        genres\n",
      "3890     3994  Unbreakable (2000)  Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 174 is: 1\n",
      "      movieId                      title           genres\n",
      "2262     2353  Enemy of the State (1998)  Action|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 175 is: 2\n",
      "      movieId                                              title  \\\n",
      "1168     1198  Raiders of the Lost Ark (Indiana Jones and the...   \n",
      "\n",
      "                genres  \n",
      "1168  Action|Adventure  \n",
      "\n",
      "\n",
      "User identity at iteration 176 is: 1\n",
      "      movieId                             title                genres\n",
      "1523     1580  Men in Black (a.k.a. MIB) (1997)  Action|Comedy|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 177 is: 1\n",
      "      movieId                     title         genres\n",
      "4889     4995  Beautiful Mind, A (2001)  Drama|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 178 is: 1\n",
      "      movieId                 title                          genres\n",
      "2988     3081  Sleepy Hollow (1999)  Fantasy|Horror|Mystery|Romance\n",
      "\n",
      "\n",
      "User identity at iteration 179 is: 0\n",
      "      movieId                      title genres\n",
      "1213     1246  Dead Poets Society (1989)  Drama\n",
      "\n",
      "\n",
      "User identity at iteration 180 is: 0\n",
      "      movieId                 title           genres\n",
      "1550     1608  Air Force One (1997)  Action|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 181 is: 0\n",
      "       movieId             title                        genres\n",
      "13285    68358  Star Trek (2009)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 182 is: 1\n",
      "      movieId                              title                  genres\n",
      "3923     4027  O Brother, Where Art Thou? (2000)  Adventure|Comedy|Crime\n",
      "\n",
      "\n",
      "User identity at iteration 183 is: 2\n",
      "      movieId               title        genres\n",
      "3890     3994  Unbreakable (2000)  Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 184 is: 1\n",
      "     movieId                        title                 genres\n",
      "285      288  Natural Born Killers (1994)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 185 is: 1\n",
      "      movieId               title           genres\n",
      "1226     1259  Stand by Me (1986)  Adventure|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 186 is: 0\n",
      "      movieId                   title            genres\n",
      "4904     5010  Black Hawk Down (2001)  Action|Drama|War\n",
      "\n",
      "\n",
      "User identity at iteration 187 is: 0\n",
      "       movieId                                             title  \\\n",
      "11117    48394  Pan's Labyrinth (Laberinto del fauno, El) (2006)   \n",
      "\n",
      "                       genres  \n",
      "11117  Drama|Fantasy|Thriller  \n",
      "\n",
      "\n",
      "User identity at iteration 188 is: 1\n",
      "       movieId               title                              genres\n",
      "11974    56174  I Am Legend (2007)  Action|Horror|Sci-Fi|Thriller|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 189 is: 2\n",
      "       movieId             title                       genres\n",
      "12111    57669  In Bruges (2008)  Comedy|Crime|Drama|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 190 is: 0\n",
      "     movieId                              title                 genres\n",
      "163      165  Die Hard: With a Vengeance (1995)  Action|Crime|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 191 is: 2\n",
      "       movieId                    title                     genres\n",
      "13445    69481  Hurt Locker, The (2008)  Action|Drama|Thriller|War\n",
      "\n",
      "\n",
      "User identity at iteration 192 is: 2\n",
      "      movieId                                              title  \\\n",
      "6416     6539  Pirates of the Caribbean: The Curse of the Bla...   \n",
      "\n",
      "                               genres  \n",
      "6416  Action|Adventure|Comedy|Fantasy  \n",
      "\n",
      "\n",
      "User identity at iteration 193 is: 1\n",
      "      movieId            title              genres\n",
      "4158     4262  Scarface (1983)  Action|Crime|Drama\n",
      "\n",
      "\n",
      "User identity at iteration 194 is: 1\n",
      "      movieId                              title                 genres\n",
      "1070     1097  E.T. the Extra-Terrestrial (1982)  Children|Drama|Sci-Fi\n",
      "\n",
      "\n",
      "User identity at iteration 195 is: 1\n",
      "       movieId          title                        genres\n",
      "14102    72998  Avatar (2009)  Action|Adventure|Sci-Fi|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 196 is: 2\n",
      "      movieId             title                  genres\n",
      "1566     1625  Game, The (1997)  Drama|Mystery|Thriller\n",
      "\n",
      "\n",
      "User identity at iteration 197 is: 0\n",
      "      movieId                                              title  \\\n",
      "1168     1198  Raiders of the Lost Ark (Indiana Jones and the...   \n",
      "\n",
      "                genres  \n",
      "1168  Action|Adventure  \n",
      "\n",
      "\n",
      "User identity at iteration 198 is: 0\n",
      "       movieId                  title                       genres\n",
      "10679    44191  V for Vendetta (2006)  Action|Sci-Fi|Thriller|IMAX\n",
      "\n",
      "\n",
      "User identity at iteration 199 is: 1\n",
      "     movieId                                 title  \\\n",
      "764      780  Independence Day (a.k.a. ID4) (1996)   \n",
      "\n",
      "                               genres  \n",
      "764  Action|Adventure|Sci-Fi|Thriller  \n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "random_rec = RandomBaseline(ground_set, genre_list, movie_similarity_mat, \n",
    "                            column_to_movie, M_filled, movies_df_s, cluster_centers, user_labels)\n",
    "\n",
    "env_random = Environment(_T, _sigma, genre_list, _lambda_one, _lambda_two, \n",
    "                  movie_similarity_mat, column_to_movie, M_filled, movies_df_s, cluster_centers, user_labels, random_rec)\n",
    "\n",
    "ret_random = env_random.run_simulation()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     movieId                  title       genres\n",
      "840      858  Godfather, The (1972)  Crime|Drama\n",
      "\n",
      "\n",
      "      movieId           title            genres\n",
      "4122     4226  Memento (2000)  Mystery|Thriller\n",
      "\n",
      "\n",
      "      movieId                           title       genres\n",
      "1190     1221  Godfather: Part II, The (1974)  Crime|Drama\n",
      "\n",
      "\n",
      "       movieId                    title                   genres\n",
      "12221    58559  Dark Knight, The (2008)  Action|Crime|Drama|IMAX\n",
      "\n",
      "\n",
      "      movieId                            title                        genres\n",
      "1934     2023  Godfather: Part III, The (1990)  Crime|Drama|Mystery|Thriller\n",
      "\n",
      "\n",
      "      movieId                                             title  \\\n",
      "2537     2628  Star Wars: Episode I - The Phantom Menace (1999)   \n",
      "\n",
      "                       genres  \n",
      "2537  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "      movieId                                              title  \\\n",
      "5270     5378  Star Wars: Episode II - Attack of the Clones (...   \n",
      "\n",
      "                            genres  \n",
      "5270  Action|Adventure|Sci-Fi|IMAX  \n",
      "\n",
      "\n",
      "      movieId                                              title  \\\n",
      "9952    33493  Star Wars: Episode III - Revenge of the Sith (...   \n",
      "\n",
      "                       genres  \n",
      "9952  Action|Adventure|Sci-Fi  \n",
      "\n",
      "\n",
      "      movieId                                              title  \\\n",
      "4790     4896  Harry Potter and the Sorcerer's Stone (a.k.a. ...   \n",
      "\n",
      "                          genres  \n",
      "4790  Adventure|Children|Fantasy  \n",
      "\n",
      "\n",
      "      movieId                                           title  \\\n",
      "5704     5816  Harry Potter and the Chamber of Secrets (2002)   \n",
      "\n",
      "                 genres  \n",
      "5704  Adventure|Fantasy  \n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "greedy_rec = GreedyBaseline(ground_set, column_to_movie, movies_df_s, M_filled, affinity_mat, _lambda_one)\n",
    "\n",
    "\n",
    "env_greedy = Environment(_T, _sigma, _lambda_one, M_filled, affinity_mat, movies_df_s, \n",
    "                  greedy_rec, column_to_movie)\n",
    "\n",
    "ret_greedy = env_greedy.run_simulation()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 205,
   "metadata": {},
   "outputs": [],
   "source": [
    "column_idxs = ret_greedy[0]\n",
    "greedy_bp_movies = [column_to_movie[e] for e in column_idxs]\n",
    "greedy_movie_names = movies_df[movies_df[\"movieId\"].isin(greedy_bp_movies)][\"title\"].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['Godfather, The ',\n",
       " 'Godfather: Part II, The ',\n",
       " 'Godfather: Part III, The ',\n",
       " 'Star Wars: Episode I - The Phantom Menace ',\n",
       " 'Memento ',\n",
       " \"Harry Potter and the Sorcerer's Stone  \",\n",
       " 'Star Wars: Episode II - Attack of the Clones ',\n",
       " 'Harry Potter and the Chamber of Secrets ',\n",
       " 'Star Wars: Episode III - Revenge of the Sith ',\n",
       " 'Dark Knight, The ']"
      ]
     },
     "execution_count": 209,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "greedy_movie_names = [re.sub(r\"\\([^()]*\\)\", \"\", e) for e in greedy_movie_names]\n",
    "greedy_movie_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     movieId                  title       genres\n",
      "840      858  Godfather, The (1972)  Crime|Drama\n",
      "\n",
      "\n",
      "      movieId           title            genres\n",
      "4122     4226  Memento (2000)  Mystery|Thriller\n",
      "\n",
      "\n",
      "       movieId                    title                   genres\n",
      "12221    58559  Dark Knight, The (2008)  Action|Crime|Drama|IMAX\n",
      "\n",
      "\n",
      "       movieId             title  \\\n",
      "14937    79132  Inception (2010)   \n",
      "\n",
      "                                                genres  \n",
      "14937  Action|Crime|Drama|Mystery|Sci-Fi|Thriller|IMAX  \n",
      "\n",
      "\n",
      "      movieId                           title       genres\n",
      "1190     1221  Godfather: Part II, The (1974)  Crime|Drama\n",
      "\n",
      "\n",
      "      movieId                   title                  genres\n",
      "1207     1240  Terminator, The (1984)  Action|Sci-Fi|Thriller\n",
      "\n",
      "\n",
      "      movieId                                              title  \\\n",
      "4790     4896  Harry Potter and the Sorcerer's Stone (a.k.a. ...   \n",
      "\n",
      "                          genres  \n",
      "4790  Adventure|Children|Fantasy  \n",
      "\n",
      "\n",
      "      movieId                     title         genres\n",
      "1640     1704  Good Will Hunting (1997)  Drama|Romance\n",
      "\n",
      "\n",
      "     movieId                  title  \\\n",
      "359      364  Lion King, The (1994)   \n",
      "\n",
      "                                              genres  \n",
      "359  Adventure|Animation|Children|Drama|Musical|IMAX  \n",
      "\n",
      "\n",
      "     movieId         title                   genres\n",
      "372      377  Speed (1994)  Action|Romance|Thriller\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "greedy_rec_sm = GreedyBaseline(ground_set, column_to_movie, movies_df_s, M_filled, affinity_mat, 0)\n",
    "\n",
    "\n",
    "env_greedy_sm = Environment(_T, _sigma, 0, M_filled, affinity_mat, movies_df_s, \n",
    "                  greedy_rec_sm, column_to_movie)\n",
    "\n",
    "ret_greedy_sm = env_greedy_sm.run_simulation()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "metadata": {},
   "outputs": [],
   "source": [
    "column_idxs_sm = ret_greedy_sm[0]\n",
    "greedy_sm_movies = [column_to_movie[e] for e in column_idxs_sm]\n",
    "greedy_sm_movie_names = movies_df[movies_df[\"movieId\"].isin(greedy_sm_movies)][\"title\"].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['Lion King, The ',\n",
       " 'Speed ',\n",
       " 'Godfather, The ',\n",
       " 'Godfather: Part II, The ',\n",
       " 'Terminator, The ',\n",
       " 'Good Will Hunting ',\n",
       " 'Memento ',\n",
       " \"Harry Potter and the Sorcerer's Stone  \",\n",
       " 'Dark Knight, The ',\n",
       " 'Inception ']"
      ]
     },
     "execution_count": 215,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "greedy_sm_movie_names = [re.sub(r\"\\([^()]*\\)\", \"\", e) for e in greedy_sm_movie_names]\n",
    "greedy_sm_movie_names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_dict = {\"SM Objective\": greedy_sm_movie_names, \"BP Objective\": greedy_movie_names}\n",
    "output_df = pd.DataFrame(df_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lll}\n",
      "\\toprule\n",
      "{} &                             SM Objective &                                   BP Objective \\\\\n",
      "\\midrule\n",
      "0 &                          Lion King, The  &                                Godfather, The  \\\\\n",
      "1 &                                   Speed  &                       Godfather: Part II, The  \\\\\n",
      "2 &                          Godfather, The  &                      Godfather: Part III, The  \\\\\n",
      "3 &                 Godfather: Part II, The  &     Star Wars: Episode I - The Phantom Menace  \\\\\n",
      "4 &                         Terminator, The  &                                       Memento  \\\\\n",
      "5 &                       Good Will Hunting  &        Harry Potter and the Sorcerer's Stone   \\\\\n",
      "6 &                                 Memento  &  Star Wars: Episode II - Attack of the Clones  \\\\\n",
      "7 &  Harry Potter and the Sorcerer's Stone   &       Harry Potter and the Chamber of Secrets  \\\\\n",
      "8 &                        Dark Knight, The  &  Star Wars: Episode III - Revenge of the Sith  \\\\\n",
      "9 &                               Inception  &                              Dark Knight, The  \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(output_df.to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_movies = [re.sub(r\"\\([^()]*\\)\", \"\", e) for e in all_movies]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "metadata": {},
   "outputs": [],
   "source": [
    "lst_one = all_movies[:11] + [' ']\n",
    "lst_two = all_movies[11:]\n",
    "\n",
    "ground_set_df_dict = {\"First batch\": lst_one, \"Second batch\": lst_two}\n",
    "ground_set_df = pd.DataFrame(ground_set_df_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lll}\n",
      "\\toprule\n",
      "0  &                      Lion King, The  &                             Good Will Hunting  \\\\\n",
      "1  &                               Speed  &                      Godfather: Part III, The  \\\\\n",
      "2  &                           True Lies  &     Star Wars: Episode I - The Phantom Menace  \\\\\n",
      "3  &                             Aladdin  &                                     Gladiator  \\\\\n",
      "4  &                  Dances with Wolves  &                                       Memento  \\\\\n",
      "5  &                              Batman  &                                         Shrek  \\\\\n",
      "6  &                      Godfather, The  &        Harry Potter and the Sorcerer's Stone   \\\\\n",
      "7  &             Godfather: Part II, The  &  Star Wars: Episode II - Attack of the Clones  \\\\\n",
      "8  &                     Terminator, The  &       Harry Potter and the Chamber of Secrets  \\\\\n",
      "9  &  Indiana Jones and the Last Crusade  &  Star Wars: Episode III - Revenge of the Sith  \\\\\n",
      "10 &                       Men in Black   &                              Dark Knight, The  \\\\\n",
      "11 &                                      &                                     Inception  \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(ground_set_df.to_latex(header=False))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Analysing the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_sub_sup_split_plot_v2(ret, title, title_flag):\n",
    "    Si_dict = ret[0]\n",
    "    sub_hist = ret[-2]\n",
    "    sup_hist = ret[-1]\n",
    "    single_user_movies = Si_dict\n",
    "    single_sub_hist = sub_hist\n",
    "    single_sup_hist = sup_hist\n",
    "    \n",
    "\n",
    "    plt.plot(np.arange(len(single_sub_hist)), single_sub_hist, '--', label = title + ':submod')\n",
    "    plt.plot(np.arange(len(single_sup_hist)), single_sup_hist, label = title+ ':supermod')\n",
    "    if title_flag:\n",
    "        plt.title(title)\n",
    "    plt.legend()\n",
    "    return True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_yi_hist_plot(ret, T, title, title_flag):\n",
    "    yi_hist = ret[2]\n",
    "    yi_cumul = np.cumsum(yi_hist)\n",
    "    plt.plot(np.arange(len(yi_cumul)), yi_cumul, label = title)\n",
    "\n",
    "    if title_flag:\n",
    "        plt.title(title)\n",
    "    plt.legend()\n",
    "    return True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_sub_sup_split_plot_v2(ret_greedy, \"Greedy\", False)\n",
    "plt.title(\"Comparison between algorithms\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
