{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Synthetic data\n",
    "- Social network $A_{ij}$ is real data and $z_i$ are inferred from it usin `pmf` $A_{ij}\\sim Poi(z_i^T \\beta_j)$\n",
    "- All the other parameters are synthetically generated with:\n",
    "    - Poisson $S_{ia}$ + Gamma embeddings $b_i$, $c_a$\n",
    "    - Bernoulli $S_{ia}$ + exp(Normal) embeddings $b_i$, $c_a$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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",
    "\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 and compute stats including overlap in songs rated by friends"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "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": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def to_mat(df, dim1, dim2, val_index=None):\n",
    "    mat = np.zeros((dim1, dim2))\n",
    "    for row in df.values:\n",
    "        row = [int(r) for r in row]\n",
    "        val = 1\n",
    "        if val_index:\n",
    "            val = row[val_index]\n",
    "        mat[row[0]-1][row[1]-1] = val\n",
    "    return mat"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Select test set\n",
    "- `holdout_pairs`: list of 3-tuples (user $i$,random article $j$, $S_{ij}$)\n",
    "- $N_{rows}=N_{users}$\n",
    "- One article is randomly picked for each user (and thus each row of `holdout_pairs`)\n",
    "- `rating_mat` is $S_{ij}$`=shares_mat[i][j]` set to 0 --> this matrix is the training\n",
    "\n",
    "This is because the distribution of `user_share_counts` is highly peaked in $1$, i.e. most of the users share exactly only 1 article!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num. ratings heldout: 1892\n"
     ]
    }
   ],
   "source": [
    "network_mat = to_mat(network_df, num_users, num_users)\n",
    "rating_mat = to_mat(rating_df, num_users, num_items)\n",
    "holdout_pairs,rating_mat = ut.get_holdout_pairs(rating_mat)\n",
    "print \"Num. ratings heldout:\", len(holdout_pairs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0, 5312, 0.0)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "holdout_pairs[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average correlation between friends: 8.746009278917985\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import pearsonr\n",
    "overlap = []\n",
    "for edge in network_df.values:\n",
    "    u1 = edge[0]-1\n",
    "    u2 = edge[1]-1\n",
    "    i1 = rating_mat[u1,:]\n",
    "    i2 = rating_mat[u2,:]\n",
    "    i1 = np.where(i1==1)\n",
    "    i2 = np.where(i2==1)\n",
    "    overlap.append(np.intersect1d(i1, i2).shape)\n",
    "print \"Average correlation between friends:\", np.average(overlap)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fit PMF to social network and compute training loss\n",
    "- $A_{ij}\\sim Poi(z_i^T \\beta_j)$\n",
    "- $z_i$: `user_embed`\n",
    "- $\\beta_j$: `friend_attr`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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.12779077e-04, 4.17235307e-05, 5.58893276e-03, ...,\n",
       "        1.42258427e-03, 6.41921558e-05, 1.24255925e-03],\n",
       "       [4.54840073e-05, 4.16792108e-05, 7.10828431e-05, ...,\n",
       "        7.07997356e-04, 6.52103020e-05, 5.65346620e-05],\n",
       "       [4.54840072e-05, 4.58460643e-04, 7.81892357e-04, ...,\n",
       "        5.21371003e-03, 6.36144563e-05, 5.65346617e-05],\n",
       "       ...,\n",
       "       [4.54840071e-05, 4.16792107e-05, 7.10823759e-05, ...,\n",
       "        2.63903923e-03, 6.99759836e-04, 6.21866959e-04],\n",
       "       [4.54840071e-05, 4.16792107e-05, 7.10823759e-05, ...,\n",
       "        6.43664332e-05, 1.97204733e-03, 5.65346617e-05],\n",
       "       [4.54840071e-05, 4.16792107e-05, 1.49272980e-03, ...,\n",
       "        6.43664332e-05, 6.36144562e-05, 5.65347280e-05]])"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K=10\n",
    "poisson_model = pmf.OnlinePoissonMF(n_components=K)\n",
    "poisson_model.fit(network_mat)\n",
    "poisson_model.transform(network_mat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "AUC on the whole network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training AUC: 0.9469801828151524\n"
     ]
    }
   ],
   "source": [
    "# user_embed = poisson_model.Et\n",
    "# friend_attr = poisson_model.Eb\n",
    "# expected_friendships = np.dot(user_embed, friend_attr)\n",
    "user_embed = poisson_model.Elogt\n",
    "friend_attr = poisson_model.Elogb\n",
    "expected_friendships = np.dot(np.exp(user_embed), np.exp(friend_attr))\n",
    "\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\n",
    "- The user preferences $z_i$ are inferred from the social network $A_{ij}$\n",
    "- All the other paramters are synthetically generated\n",
    "- Output is `'../lastfm/simulated/rating.csv'`"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "- `user_latent_pref` is $z_i$: $K$-dim vector inferred from social network $A_{ij}\\sim Poi(z_i^T \\beta_j)$\n",
    "- `item_latent_attr` is $\\gamma_a$: $K$-dim Gamma distributed vector\n",
    "- `pref_rates` is $z_i^T \\gamma_a$\n",
    "- `simulated_ratings` $\\sim Poi($`pref_rates`)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares: 0.0077703533936\n",
      "Real data proportion of items that receive shares: 0.0027826652386780905\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",
    "\n",
    "pref_dim = K  # latent dim social network\n",
    "pref_gamma_shape = 1.0\n",
    "pref_gamma_scale = 1.0\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",
    "### 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",
    "\n",
    "print \"Proportion of items that receive shares:\", float((simulated_ratings).sum())/(num_users*num_items)\n",
    "print \"Real data proportion of items that receive shares:\", (rating_mat).sum()/(num_users*num_items)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Poisson binary-cut shared matrix with Gamma embeddings"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "- `friend_latent_influence` is $b_i$: $Q$-dim Gamma distributed vector\n",
    "- `item_latent_influence` is $c_a$: $Q$-dim Gamma distributed vector\n",
    "- `influence_rates` is $A_{ij}b_j^T c_a$\n",
    "- `simulated` $\\sim Poi($`influence_rates`)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares due to influence: 0.00294843389685\n"
     ]
    }
   ],
   "source": [
    "influence_dim = 10\n",
    "influence_gamma_shape = 0.01\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",
    "print \"Proportion of items that receive shares due to influence:\", float(simulated.sum())/(num_users*num_items)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Combine two sources (social influence and intrinsic preference)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion of items that receive shares due to all factors: 0.0107208556517\n"
     ]
    }
   ],
   "source": [
    "total_rates = pref_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": "markdown",
   "metadata": {},
   "source": [
    "Make the rating matrix binary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "simulated_ratings[simulated_ratings > 1] = 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Build synthetic dataframe and output on file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('Outfile:', '../lastfm/simulated/rating.csv')\n"
     ]
    }
   ],
   "source": [
    "dir_to_write = os.path.join('..', 'lastfm', 'simulated')\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",
    "outfile=os.path.join(dir_to_write, 'rating.csv')\n",
    "sim_rating_df.to_csv(outfile, index=False, header=False)\n",
    "print('Outfile:',outfile)\n",
    "# np.savetxt(os.path.join(dir_to_write, 'simulated_rating'), simulated_ratings)\n",
    "# np.savetxt(os.path.join(dir_to_write, 'adjacencies'), network_mat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\n",
    "### Bernoulli shared matrix with Gaussian embeddings\n",
    "\n",
    "- `friend_latent_influence` is $b_i$: $Q$-dim Normal distributed vector\n",
    "- `item_latent_influence` is $c_a$: $Q$-dim Normal distributed vector\n",
    "- `influence_rates` is $A_{ij}b_j^T c_a$\n",
    "- `simulated` $\\sim Bern($`influence_rates`)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('Proportion of items that receive shares due to influence:', 0.442776955602537)\n"
     ]
    }
   ],
   "source": [
    "influence_dim = 10  # Q\n",
    "bias = -1.0\n",
    "num_items = 5000\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": "markdown",
   "metadata": {},
   "source": [
    "Build synthetic dataframe and output on file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('Outfile:', '../lastfm/simulated-bernoulli-influence-only/rating.csv')\n"
     ]
    }
   ],
   "source": [
    "\n",
    "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",
    "outfile=os.path.join(dir_to_write, 'rating.csv')\n",
    "sim_rating_df.to_csv(os.path.join(dir_to_write, 'rating.csv'), index=False, header=False)\n",
    "print('Outfile:',outfile)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10, 5000)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "item_latent_influence.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Deterministic influence behavior\n",
    "\n",
    "- Draw friends' influence $b_j$ and item embeddings $c_a$ from $Gamma$\n",
    "- Compute friends' expected clicks/ratings $S_{ia}$ on items as Poisson $S_{ia}\\sim Poi(A_{ij} b_j^T c_a)$\n",
    "#- Randomly select some of these friends as 'influencers'\n",
    "- Select those who have highest indegree as _influencers_\n",
    "- _Anyone_ (deterministically) who is friends with an influencer shares the items shared by those friends"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import gamma, poisson\n",
    "from numpy.random import choice\n",
    "reload(ut)\n",
    "\n",
    "shape = 0.1\n",
    "scale = 1.0\n",
    "num_items = 1000\n",
    "dim = 10  # Q\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  # binarize\n",
    "\n",
    "\n",
    "influencers = [i[0]-1 for i in ut.get_n_most_popular_users(network_df, n=100)] # ordered by indegree\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)[0]\n",
    "    exp_rat = expected_ratings[k, :]\n",
    "    items = np.where(exp_rat == 1)[0]\n",
    "    for j in friends:\n",
    "        sim_ratings[j,items] = 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Output on file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('Outfile:', '../dat/lastfm/simulated-det-influence/rating.csv')\n"
     ]
    }
   ],
   "source": [
    "dir_to_write = os.path.join('..','dat', 'lastfm', 'simulated-det-influence')\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(sim_ratings.shape[0]):\n",
    "    for j in range(sim_ratings.shape[1]):\n",
    "        if sim_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'), inf_embed)\n",
    "np.savetxt(os.path.join(dir_to_write, 'item_latent_influence'), item_embed)\n",
    "\n",
    "outfile=os.path.join(dir_to_write, 'rating.csv')\n",
    "sim_rating_df.to_csv(os.path.join(dir_to_write, 'rating.csv'), index=False, header=False)\n",
    "print('Outfile:',outfile)\n"
   ]
  },
  {
   "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
}
