{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pmf\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os\n",
    "from sklearn.metrics import roc_auc_score\n",
    "import utils as ut\n",
    "from importlib import reload\n",
    "\n",
    "datadir = os.path.join('..','dat', 'lastfm', 'trueratings')\n",
    "network_file = os.path.join(datadir, 'friends.txt')\n",
    "rating_file = os.path.join(datadir, 'rated')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load last.fm data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Users: 1892 Items: 17632\n",
      "Num. friendships: 25434\n",
      "Num. ratings: 92834\n"
     ]
    }
   ],
   "source": [
    "network_df = pd.read_csv(network_file, header=None, sep='\\t', names=['u1', 'u2'])\n",
    "rating_df = pd.read_csv(rating_file, header=None, sep='\\t', names=['user', 'item'])\n",
    "\n",
    "num_users = len(np.unique(rating_df['user']))\n",
    "num_items = len(np.unique(rating_df['item']))\n",
    "\n",
    "print(\"Users:\", num_users, \"Items:\", num_items)\n",
    "print(\"Num. friendships:\", network_df.shape[0])\n",
    "print(\"Num. ratings:\", rating_df.shape[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "network_mat = ut.to_mat(network_df, num_users, num_users)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fit PMF to adjacencies and compute training loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/dhanyasridhar/Documents/social-fake-news/scripts/pmf.py:168: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  improvement = (bound - old_bd) / abs(old_bd)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n",
      "\tMinibatch 1:\n",
      "\tMinibatch 2:\n",
      "\tMinibatch 3:\n",
      "\tMinibatch 4:\n",
      "\tMinibatch 5:\n",
      "\tMinibatch 6:\n",
      "\tMinibatch 7:\n",
      "\tMinibatch 8:\n",
      "\tMinibatch 9:\n",
      "\tMinibatch 10:\n",
      "\tMinibatch 11:\n",
      "\tMinibatch 12:\n",
      "\tMinibatch 13:\n",
      "\tMinibatch 14:\n",
      "\tMinibatch 15:\n",
      "\tMinibatch 16:\n",
      "\tMinibatch 17:\n",
      "\tMinibatch 18:\n",
      "\tMinibatch 19:\n",
      "\tMinibatch 20:\n",
      "\tMinibatch 21:\n",
      "\tMinibatch 22:\n",
      "\tMinibatch 23:\n",
      "\tMinibatch 24:\n",
      "\tMinibatch 25:\n",
      "\tMinibatch 26:\n",
      "\tMinibatch 27:\n",
      "\tMinibatch 28:\n",
      "\tMinibatch 29:\n",
      "\tMinibatch 30:\n",
      "\tMinibatch 31:\n",
      "\tMinibatch 32:\n",
      "\tMinibatch 33:\n",
      "\tMinibatch 34:\n",
      "\tMinibatch 35:\n",
      "\tMinibatch 36:\n",
      "\tMinibatch 37:\n",
      "\tMinibatch 38:\n",
      "\tMinibatch 39:\n",
      "\tMinibatch 40:\n",
      "\tMinibatch 41:\n",
      "\tMinibatch 42:\n",
      "\tMinibatch 43:\n",
      "\tMinibatch 44:\n",
      "\tMinibatch 45:\n",
      "\tMinibatch 46:\n",
      "\tMinibatch 47:\n",
      "\tMinibatch 48:\n",
      "\tMinibatch 49:\n",
      "\tMinibatch 50:\n",
      "\tMinibatch 51:\n",
      "\tMinibatch 52:\n",
      "\tMinibatch 53:\n",
      "\tMinibatch 54:\n",
      "\tMinibatch 55:\n",
      "\tMinibatch 56:\n",
      "\tMinibatch 57:\n",
      "\tMinibatch 58:\n",
      "\tMinibatch 59:\n",
      "\tMinibatch 60:\n",
      "\tMinibatch 61:\n",
      "\tMinibatch 62:\n",
      "\tMinibatch 63:\n",
      "\tMinibatch 64:\n",
      "\tMinibatch 65:\n",
      "\tMinibatch 66:\n",
      "\tMinibatch 67:\n",
      "\tMinibatch 68:\n",
      "\tMinibatch 69:\n",
      "\tMinibatch 70:\n",
      "\tMinibatch 71:\n",
      "\tMinibatch 72:\n",
      "\tMinibatch 73:\n",
      "\tMinibatch 74:\n",
      "\tMinibatch 75:\n",
      "\tMinibatch 76:\n",
      "\tMinibatch 77:\n",
      "\tMinibatch 78:\n",
      "\tMinibatch 79:\n",
      "\tMinibatch 80:\n",
      "\tMinibatch 81:\n",
      "\tMinibatch 82:\n",
      "\tMinibatch 83:\n",
      "\tMinibatch 84:\n",
      "\tMinibatch 85:\n",
      "\tMinibatch 86:\n",
      "\tMinibatch 87:\n",
      "\tMinibatch 88:\n",
      "\tMinibatch 89:\n",
      "\tMinibatch 90:\n",
      "\tMinibatch 91:\n",
      "\tMinibatch 92:\n",
      "\tMinibatch 93:\n",
      "\tMinibatch 94:\n",
      "\tMinibatch 95:\n",
      "\tMinibatch 96:\n",
      "\tMinibatch 97:\n",
      "\tMinibatch 98:\n",
      "\tMinibatch 99:\n",
      "\tMinibatch 100:\n",
      "\tMinibatch 101:\n",
      "\tMinibatch 102:\n",
      "\tMinibatch 103:\n",
      "\tMinibatch 104:\n",
      "\tMinibatch 105:\n",
      "\tMinibatch 106:\n",
      "\tMinibatch 107:\n",
      "\tMinibatch 108:\n",
      "\tMinibatch 109:\n",
      "\tMinibatch 110:\n",
      "\tMinibatch 111:\n",
      "\tMinibatch 112:\n",
      "\tMinibatch 113:\n",
      "\tMinibatch 114:\n",
      "\tMinibatch 115:\n",
      "\tMinibatch 116:\n",
      "\tMinibatch 117:\n",
      "\tMinibatch 118:\n",
      "\tMinibatch 119:\n",
      "\tMinibatch 120:\n",
      "\tMinibatch 121:\n",
      "\tMinibatch 122:\n",
      "\tMinibatch 123:\n",
      "\tMinibatch 124:\n",
      "\tMinibatch 125:\n",
      "\tMinibatch 126:\n",
      "\tMinibatch 127:\n",
      "\tMinibatch 128:\n",
      "\tMinibatch 129:\n",
      "\tMinibatch 130:\n",
      "\tMinibatch 131:\n",
      "\tMinibatch 132:\n",
      "\tMinibatch 133:\n",
      "\tMinibatch 134:\n",
      "\tMinibatch 135:\n",
      "\tMinibatch 136:\n",
      "\tMinibatch 137:\n",
      "\tMinibatch 138:\n",
      "\tMinibatch 139:\n",
      "\tMinibatch 140:\n",
      "\tMinibatch 141:\n",
      "\tMinibatch 142:\n",
      "\tMinibatch 143:\n",
      "\tMinibatch 144:\n",
      "\tMinibatch 145:\n",
      "\tMinibatch 146:\n",
      "\tMinibatch 147:\n",
      "\tMinibatch 148:\n",
      "\tMinibatch 149:\n",
      "\tMinibatch 150:\n",
      "\tMinibatch 151:\n",
      "\tMinibatch 152:\n",
      "\tMinibatch 153:\n",
      "\tMinibatch 154:\n",
      "\tMinibatch 155:\n",
      "\tMinibatch 156:\n",
      "\tMinibatch 157:\n",
      "\tMinibatch 158:\n",
      "\tMinibatch 159:\n",
      "\tMinibatch 160:\n",
      "\tMinibatch 161:\n",
      "\tMinibatch 162:\n",
      "\tMinibatch 163:\n",
      "\tMinibatch 164:\n",
      "\tMinibatch 165:\n",
      "\tMinibatch 166:\n",
      "\tMinibatch 167:\n",
      "\tMinibatch 168:\n",
      "\tMinibatch 169:\n",
      "\tMinibatch 170:\n",
      "\tMinibatch 171:\n",
      "\tMinibatch 172:\n",
      "\tMinibatch 173:\n",
      "\tMinibatch 174:\n",
      "\tMinibatch 175:\n",
      "\tMinibatch 176:\n",
      "\tMinibatch 177:\n",
      "\tMinibatch 178:\n",
      "\tMinibatch 179:\n",
      "\tMinibatch 180:\n",
      "\tMinibatch 181:\n",
      "\tMinibatch 182:\n",
      "\tMinibatch 183:\n",
      "\tMinibatch 184:\n",
      "\tMinibatch 185:\n",
      "\tMinibatch 186:\n",
      "\tMinibatch 187:\n",
      "\tMinibatch 188:\n",
      "\tMinibatch 189:\n",
      "\tMinibatch 190:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([[5.77329255e-05, 2.86485091e-05, 8.57020251e-05, ...,\n",
       "        5.01330755e-05, 5.74856950e-05, 6.59380527e-05],\n",
       "       [5.77329247e-05, 2.86485091e-05, 8.57020241e-05, ...,\n",
       "        5.01330755e-05, 5.74856937e-05, 6.59380519e-05],\n",
       "       [5.77329248e-05, 2.86485091e-05, 8.57020245e-05, ...,\n",
       "        5.01330755e-05, 5.74856938e-05, 6.59380521e-05],\n",
       "       ...,\n",
       "       [5.77329247e-05, 2.86485091e-05, 8.57020242e-05, ...,\n",
       "        5.01330755e-05, 5.74856937e-05, 6.59380519e-05],\n",
       "       [5.77329248e-05, 2.86485091e-05, 8.57020243e-05, ...,\n",
       "        5.01330755e-05, 5.74856937e-05, 6.59380520e-05],\n",
       "       [5.77329248e-05, 2.86485091e-05, 1.79910358e-03, ...,\n",
       "        5.01330755e-05, 5.74856937e-05, 6.59380520e-05]])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "poisson_model = pmf.OnlinePoissonMF(n_components=20)\n",
    "poisson_model.fit(network_mat)\n",
    "poisson_model.transform(network_mat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training AUC: 0.9517775638392079\n"
     ]
    }
   ],
   "source": [
    "user_embed = poisson_model.Et\n",
    "friend_attr = poisson_model.Eb\n",
    "expected_friendships = np.dot(user_embed, friend_attr)\n",
    "truth = network_mat.flatten()\n",
    "predicted = []\n",
    "\n",
    "for i in range(expected_friendships.shape[0]):\n",
    "    for j in range(expected_friendships.shape[1]):\n",
    "        predicted.append(expected_friendships[i][j])\n",
    "\n",
    "print(\"Training AUC:\", roc_auc_score(truth, predicted))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Use last.fm to generate semi-synthetic data from a Poisson model\n",
    "- User embedding fit with PMF on adjacencies above\n",
    "- Sample item attributes, influence and item influence attributes from Gamma(1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares: 0.0077019027484143765\n"
     ]
    }
   ],
   "source": [
    "from scipy.special import expit\n",
    "from scipy.stats import bernoulli, poisson, gamma\n",
    "\n",
    "pref_dim = 20\n",
    "pref_gamma_shape = 1.0\n",
    "pref_gamma_scale = 1.0\n",
    "num_items = 1000\n",
    "\n",
    "user_latent_pref = poisson_model.Et\n",
    "item_latent_attr = gamma.rvs(pref_gamma_shape, scale=pref_gamma_scale, size=(pref_dim, num_items))\n",
    "\n",
    "\n",
    "### This is just to check the expected number of items rated\n",
    "pref_rates = np.dot(user_latent_pref, item_latent_attr)\n",
    "simulated_ratings = poisson.rvs(pref_rates)\n",
    "simulated[simulated > 1] = 1\n",
    "\n",
    "print(\"Proportion of items that receive shares:\", float((simulated_ratings).sum())/(num_users*num_items))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares due to influence: 0.1955607822410148\n"
     ]
    }
   ],
   "source": [
    "influence_dim = 10\n",
    "influence_gamma_shape = 0.1\n",
    "influence_gamma_scale = 0.5\n",
    "\n",
    "friend_latent_influence = gamma.rvs(influence_gamma_shape, scale=influence_gamma_scale, size=(num_users, influence_dim))\n",
    "item_latent_influence = gamma.rvs(influence_gamma_shape, scale=influence_gamma_scale, size=(influence_dim, num_items))\n",
    "influence_rates = np.dot(friend_latent_influence,item_latent_influence)\n",
    "influence_rates = np.dot(network_mat, influence_rates)\n",
    "simulated = poisson.rvs(influence_rates)\n",
    "simulated[simulated > 1] = 1\n",
    "# simulated = bernoulli.rvs(expit(influence_rates))\n",
    "print(\"Proportion of items that receive shares due to influence:\", float(simulated.sum())/(num_users*num_items))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares due to all factors: 0.3633440803382664\n"
     ]
    }
   ],
   "source": [
    "total_rates = pref_rates + influence_rates\n",
    "total_rates = influence_rates\n",
    "simulated_ratings = poisson.rvs(total_rates)\n",
    "print(\"Proportion of items that receive shares due to all factors:\", float(simulated_ratings.sum())/(num_users*num_items))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "simulated_ratings[simulated_ratings > 1] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "dir_to_write = os.path.join('..', 'lastfm', 'simulated-poisson')\n",
    "if not os.path.exists(dir_to_write):\n",
    "    os.makedirs(dir_to_write)\n",
    "\n",
    "user_item_data = []\n",
    "for i in range(simulated_ratings.shape[0]):\n",
    "    for j in range(simulated_ratings.shape[1]):\n",
    "        if simulated_ratings[i][j] == 1:\n",
    "            user_item_data.append([i,j])\n",
    "sim_rating_df = pd.DataFrame(user_item_data)\n",
    "\n",
    "np.savetxt(os.path.join(dir_to_write, 'user_latent_pref'), user_latent_pref)\n",
    "np.savetxt(os.path.join(dir_to_write, 'item_latent_pref'), item_latent_attr)\n",
    "np.savetxt(os.path.join(dir_to_write, 'friend_latent_influence'), friend_latent_influence)\n",
    "np.savetxt(os.path.join(dir_to_write, 'item_latent_influence'), item_latent_influence)\n",
    "\n",
    "sim_rating_df.to_csv(os.path.join(dir_to_write, 'rating.csv'), index=False, header=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Simulate true Bernoulli data with Gaussian embeddings\n",
    "- User embedding fit with PMF on adjacencies above\n",
    "- Generate user-item implicit rating only from influence model\n",
    "- Influence and item embeddings from Normal(0,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares due to influence: 0.4642047040169133\n"
     ]
    }
   ],
   "source": [
    "from scipy.special import expit\n",
    "from scipy.stats import bernoulli, poisson, gamma, norm\n",
    "from numpy.random import randn, rand\n",
    "\n",
    "influence_dim = 10\n",
    "bias = -1.0\n",
    "num_items = 10000\n",
    "\n",
    "friend_latent_influence = randn(num_users, influence_dim)\n",
    "item_latent_influence = randn(influence_dim, num_items)\n",
    "\n",
    "lincomb = np.dot(friend_latent_influence,item_latent_influence)\n",
    "lincomb = np.dot(network_mat, lincomb)\n",
    "lincomb += bias\n",
    "\n",
    "simulated_ratings = bernoulli.rvs(expit(lincomb))\n",
    "\n",
    "print(\"Proportion of items that receive shares due to influence:\", float(simulated_ratings.sum())/(num_users*num_items))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "dir_to_write = os.path.join('..', 'lastfm', 'simulated-bernoulli-influence-only')\n",
    "if not os.path.exists(dir_to_write):\n",
    "    os.makedirs(dir_to_write)\n",
    "\n",
    "user_item_data = []\n",
    "for i in range(simulated_ratings.shape[0]):\n",
    "    for j in range(simulated_ratings.shape[1]):\n",
    "        if simulated_ratings[i][j] == 1:\n",
    "            user_item_data.append([i,j])\n",
    "sim_rating_df = pd.DataFrame(user_item_data)\n",
    "\n",
    "np.savetxt(os.path.join(dir_to_write, 'friend_latent_influence'), friend_latent_influence)\n",
    "np.savetxt(os.path.join(dir_to_write, 'item_latent_influence'), item_latent_influence)\n",
    "\n",
    "sim_rating_df.to_csv(os.path.join(dir_to_write, 'rating.csv'), index=False, header=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Simulate deterministic influence behavior\n",
    "- Draw friends' influence and item embeddings from Gamma(2, 1)\n",
    "- Compute friends' expected clicks/ratings on items as Poisson\n",
    "- Randomly select some of these friends as 'influencers'\n",
    "- Anyone who is friends with an influencer shares the items shared by those friends"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1395\n",
      "(array([1046, 1092, 1832]),)\n",
      "(array([  0,   1,   2,   3,   4,   5,   6,   7,   8,   9,  10,  11,  12,\n",
      "        14,  15,  16,  17,  18,  19,  20,  21,  22,  23,  24,  25,  26,\n",
      "        27,  28,  29,  30,  31,  32,  33,  34,  35,  36,  37,  38,  39,\n",
      "        40,  41,  42,  43,  44,  45,  46,  47,  48,  49,  50,  51,  52,\n",
      "        53,  54,  55,  56,  57,  58,  59,  60,  61,  62,  63,  64,  65,\n",
      "        66,  67,  68,  69,  70,  71,  72,  73,  74,  75,  76,  77,  78,\n",
      "        79,  80,  81,  82,  83,  84,  85,  86,  87,  88,  89,  90,  91,\n",
      "        92,  93,  94,  95,  96,  97,  98,  99, 100, 101, 102, 103, 104,\n",
      "       105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117,\n",
      "       118, 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130,\n",
      "       131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143,\n",
      "       144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156,\n",
      "       157, 158, 159, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169,\n",
      "       170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182,\n",
      "       183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195,\n",
      "       196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208,\n",
      "       209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221,\n",
      "       222, 223, 224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234,\n",
      "       235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247,\n",
      "       248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, 260,\n",
      "       261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273,\n",
      "       274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, 286,\n",
      "       287, 288, 289, 290, 291, 292, 293, 294, 295, 296, 297, 298, 299,\n",
      "       300, 301, 302, 303, 304, 305, 306, 307, 308, 309, 310, 311, 312,\n",
      "       313, 314, 315, 316, 317, 318, 319, 320, 321, 322, 323, 324, 325,\n",
      "       326, 327, 328, 329, 330, 331, 332, 333, 334, 335, 336, 337, 338,\n",
      "       339, 340, 341, 342, 343, 344, 345, 346, 347, 348, 349, 350, 351,\n",
      "       352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 363, 364,\n",
      "       365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377,\n",
      "       378, 379, 380, 381, 382, 383, 384, 385, 386, 387, 388, 389, 390,\n",
      "       391, 392, 393, 394, 395, 396, 397, 398, 399, 400, 401, 402, 403,\n",
      "       404, 405, 406, 407, 408, 409, 410, 411, 412, 413, 414, 415, 416,\n",
      "       417, 418, 419, 420, 421, 422, 423, 424, 425, 426, 427, 428, 429,\n",
      "       430, 431, 432, 433, 434, 435, 436, 437, 438, 439, 440, 441, 442,\n",
      "       443, 444, 445, 446, 447, 448, 449, 450, 451, 452, 453, 454, 455,\n",
      "       456, 457, 458, 459, 460, 461, 462, 463, 464, 465, 466, 467, 468,\n",
      "       469, 470, 471, 472, 473, 474, 475, 476, 477, 478, 479, 480, 481,\n",
      "       482, 483, 484, 485, 486, 487, 488, 489, 490, 491, 492, 493, 494,\n",
      "       495, 496, 497, 499, 500, 501, 502, 503, 504, 505, 506, 507, 508,\n",
      "       509, 510, 511, 512, 513, 514, 515, 516, 517, 518, 519, 520, 521,\n",
      "       522, 523, 524, 525, 526, 527, 528, 529, 530, 531, 532, 533, 534,\n",
      "       535, 536, 537, 538, 539, 540, 541, 542, 543, 544, 545, 546, 547,\n",
      "       548, 549, 550, 551, 552, 553, 554, 555, 556, 557, 558, 559, 560,\n",
      "       561, 562, 563, 564, 565, 566, 567, 568, 569, 570, 571, 572, 573,\n",
      "       574, 575, 576, 577, 578, 579, 580, 581, 582, 583, 584, 585, 586,\n",
      "       587, 588, 589, 590, 591, 592, 593, 594, 595, 596, 597, 598, 599,\n",
      "       600, 601, 602, 603, 604, 605, 606, 607, 608, 609, 610, 611, 612,\n",
      "       613, 614, 615, 616, 617, 618, 619, 620, 621, 622, 623, 624, 625,\n",
      "       626, 627, 628, 629, 630, 631, 632, 633, 634, 635, 636, 637, 638,\n",
      "       639, 640, 641, 642, 643, 644, 645, 646, 647, 648, 649, 650, 651,\n",
      "       652, 653, 654, 655, 656, 657, 658, 659, 660, 661, 662, 663, 664,\n",
      "       665, 666, 667, 668, 669, 670, 671, 672, 673, 674, 675, 676, 677,\n",
      "       678, 679, 680, 681, 682, 683, 684, 685, 686, 687, 688, 689, 690,\n",
      "       691, 692, 693, 694, 695, 696, 697, 698, 699, 700, 701, 702, 703,\n",
      "       704, 705, 706, 707, 708, 709, 710, 711, 712, 713, 714, 715, 716,\n",
      "       717, 718, 719, 720, 721, 722, 723, 724, 725, 726, 727, 728, 729,\n",
      "       730, 731, 732, 733, 734, 735, 736, 737, 738, 739, 740, 741, 742,\n",
      "       743, 744, 745, 746, 747, 748, 749, 750, 751, 752, 753, 754, 755,\n",
      "       756, 757, 758, 759, 760, 761, 762, 763, 764, 765, 766, 767, 768,\n",
      "       769, 770, 771, 772, 773, 774, 775, 776, 777, 778, 779, 780, 781,\n",
      "       782, 783, 784, 785, 786, 787, 788, 789, 790, 791, 792, 793, 794,\n",
      "       795, 796, 797, 798, 799, 800, 801, 802, 803, 804, 805, 806, 807,\n",
      "       808, 809, 810, 811, 812, 813, 814, 815, 816, 817, 818, 819, 820,\n",
      "       821, 822, 823, 824, 825, 826, 827, 828, 829, 830, 831, 832, 833,\n",
      "       834, 835, 836, 837, 838, 839, 840, 841, 842, 843, 844, 845, 846,\n",
      "       847, 848, 849, 850, 851, 852, 853, 854, 855, 856, 857, 858, 859,\n",
      "       860, 861, 862, 863, 864, 865, 866, 867, 868, 869, 870, 871, 872,\n",
      "       873, 874, 875, 876, 877, 878, 879, 880, 881, 882, 883, 884, 885,\n",
      "       886, 887, 888, 889, 890, 891, 892, 893, 894, 895, 896, 897, 898,\n",
      "       899, 900, 901, 902, 903, 904, 905, 906, 907, 908, 909, 910, 911,\n",
      "       912, 913, 914, 915, 916, 917, 918, 919, 920, 921, 922, 923, 924,\n",
      "       925, 926, 927, 928, 929, 930, 931, 933, 934, 935, 936, 937, 938,\n",
      "       939, 940, 941, 942, 943, 944, 945, 946, 947, 948, 949, 950, 951,\n",
      "       952, 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964,\n",
      "       965, 966, 967, 968, 969, 970, 971, 972, 973, 974, 975, 976, 977,\n",
      "       978, 979, 980, 981, 982, 983, 984, 985, 986, 987, 988, 989, 990,\n",
      "       991, 992, 993, 994, 995, 996, 997, 998, 999]),)\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import gamma, poisson\n",
    "from numpy.random import choice\n",
    "reload(ut)\n",
    "\n",
    "shape = 1.0\n",
    "scale = 1.0\n",
    "num_items = 1000\n",
    "dim = 10\n",
    "\n",
    "size_inf = (num_users, dim)\n",
    "size_item = (dim, num_items)\n",
    "\n",
    "inf_embed = gamma.rvs(shape, scale=scale, size=size_inf)\n",
    "item_embed = gamma.rvs(shape, scale=scale, size=size_item)\n",
    "\n",
    "expected_ratings = poisson.rvs(np.dot(inf_embed, item_embed))\n",
    "expected_ratings[expected_ratings > 1] = 1\n",
    "print(expected_ratings.sum())\n",
    "\n",
    "influencers = ut.get_n_most_popular_users(network_df, n=100)\n",
    "sim_ratings = np.zeros((num_users, num_items))\n",
    "\n",
    "for k in influencers:\n",
    "    adj = network_mat[:,k]\n",
    "    friends = np.where(adj == 1)\n",
    "    exp_rat = expected_ratings[k, :]\n",
    "    items = np.where(exp_rat == 1)\n",
    "    \n",
    "    print(k)\n",
    "    print(friends)\n",
    "    print(items)\n",
    "    \n",
    "    break\n",
    "    \n",
    "#     sim_ratings[friends,items] = 1\n",
    "\n",
    "# sim_ratings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import gamma\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "a = 2.0\n",
    "# theta = 2.0\n",
    "x = np.linspace(gamma.ppf(0.01, a), gamma.ppf(0.99, a), 1000)\n",
    "y1 = gamma.pdf(x, a)\n",
    "plt.plot(x, y1)\n",
    "\n",
    "\n",
    "plt.ylim([0,1])\n",
    "plt.xlim([0,12])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "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.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
