{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experiments for Section 4.1\n",
    "First, we post-process the dataset and store it as pkl files. \n",
    "Then run our method with given parameters for two different models: linear and NN."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Download and Extract the Webscope Yahoo! LTR Dataset into ./yahoo/ subdirectory from\n",
    "\n",
    "https://webscope.sandbox.yahoo.com/catalog.php?datatype=c&did=44"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's first save the test files into pkl files"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats = []\n",
    "all_rels = []\n",
    "queries_used= {}\n",
    "with open(\"./yahoo/ltrc_yahoo/set1.test.txt\") as f:\n",
    "    curr_feats = []\n",
    "    curr_rels = []\n",
    "    curr_qid = None\n",
    "    for line in f:\n",
    "        line = line.split()\n",
    "        rel = int(line[0])\n",
    "        qid = int(line[1].split(':')[1])\n",
    "        if curr_qid is None:\n",
    "            curr_qid = qid\n",
    "        feats = np.zeros(700)\n",
    "        for j in range(2, len(line)):\n",
    "            featid = int(line[j].split(\":\")[0]) - 1\n",
    "            feats[featid] = float(line[j].split(\":\")[1])\n",
    "        if qid != curr_qid:\n",
    "            if qid in queries_used:\n",
    "                print(\"The queries arent sorted\")\n",
    "            all_feats.append(np.array(curr_feats))\n",
    "            all_rels.append(np.array(curr_rels))\n",
    "            curr_feats = []\n",
    "            curr_rels = []\n",
    "            queries_used[curr_qid] = True\n",
    "            curr_qid = qid\n",
    "        curr_feats.append(feats)\n",
    "        curr_rels.append(rel)\n",
    "    all_feats.append(np.array(curr_feats))\n",
    "    all_rels.append(np.array(curr_rels))\n",
    "    queries_used[curr_qid] = True\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'all_feats' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-4-8a01b0b84fc5>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mpickle\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mpkl\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mpkl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdump\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mall_feats\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mall_rels\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"yahoo/yahoo_test.pkl\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"wb\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m: name 'all_feats' is not defined"
     ]
    }
   ],
   "source": [
    "import pickle as pkl\n",
    "pkl.dump((all_feats, all_rels), open(\"yahoo/yahoo_test.pkl\", \"wb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats, all_rels = np.load('yahoo/test.pkl', allow_pickle = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "19.0"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.median([ all_feats[i].shape[0] for i in range(len(all_feats))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(23, 700)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_feats[0].shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Do the same for Train and Validation datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats = []\n",
    "all_rels = []\n",
    "queries_used= {}\n",
    "with open(\"./yahoo/ltrc_yahoo/set1.train.txt\") as f:\n",
    "    curr_feats = []\n",
    "    curr_rels = []\n",
    "    curr_qid = None\n",
    "    for line in f:\n",
    "        line = line.split()\n",
    "        rel = int(line[0])\n",
    "        qid = int(line[1].split(':')[1])\n",
    "        if curr_qid is None:\n",
    "            curr_qid = qid\n",
    "        feats = np.zeros(700)\n",
    "        for j in range(2, len(line)):\n",
    "            featid = int(line[j].split(\":\")[0]) - 1\n",
    "            feats[featid] = float(line[j].split(\":\")[1])\n",
    "        if qid != curr_qid:\n",
    "            if qid in queries_used:\n",
    "                print(\"The queries arent sorted\")\n",
    "            all_feats.append(np.array(curr_feats))\n",
    "            all_rels.append(np.array(curr_rels))\n",
    "            curr_feats = []\n",
    "            curr_rels = []\n",
    "            queries_used[curr_qid] = True\n",
    "            curr_qid = qid\n",
    "        curr_feats.append(feats)\n",
    "        curr_rels.append(rel)\n",
    "    all_feats.append(np.array(curr_feats))\n",
    "    all_rels.append(np.array(curr_rels))\n",
    "    queries_used[curr_qid] = True\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "pkl.dump((all_feats, all_rels), open(\"yahoo/yahoo_train.pkl\", \"wb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6983"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(all_feats)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats = []\n",
    "all_rels = []\n",
    "queries_used= {}\n",
    "with open(\"./yahoo/ltrc_yahoo/set1.valid.txt\") as f:\n",
    "    curr_feats = []\n",
    "    curr_rels = []\n",
    "    curr_qid = None\n",
    "    for line in f:\n",
    "        line = line.split()\n",
    "        rel = int(line[0])\n",
    "        qid = int(line[1].split(':')[1])\n",
    "        if curr_qid is None:\n",
    "            curr_qid = qid\n",
    "        feats = np.zeros(700)\n",
    "        for j in range(2, len(line)):\n",
    "            featid = int(line[j].split(\":\")[0]) - 1\n",
    "            feats[featid] = float(line[j].split(\":\")[1])\n",
    "        if qid != curr_qid:\n",
    "            if qid in queries_used:\n",
    "                print(\"The queries arent sorted\")\n",
    "            all_feats.append(np.array(curr_feats))\n",
    "            all_rels.append(np.array(curr_rels))\n",
    "            curr_feats = []\n",
    "            curr_rels = []\n",
    "            queries_used[curr_qid] = True\n",
    "            curr_qid = qid\n",
    "        curr_feats.append(feats)\n",
    "        curr_rels.append(rel)\n",
    "    all_feats.append(np.array(curr_feats))\n",
    "    all_rels.append(np.array(curr_rels))\n",
    "    queries_used[curr_qid] = True\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "pkl.dump((all_feats, all_rels), open(\"yahoo/yahoo_val.pkl\", \"wb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_feats, all_rels = np.load(\"yahoo/test.pkl\", \"wb\", allow_pickle = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6983"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(all_feats)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([7.4142e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       9.0265e-01, 8.0870e-01, 7.9522e-01, 8.0003e-01, 0.0000e+00,\n",
       "       5.6756e-01, 6.4688e-02, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 7.3248e-02, 0.0000e+00, 0.0000e+00, 9.3213e-01,\n",
       "       1.2578e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 1.8431e-01, 7.5984e-01, 0.0000e+00, 7.5616e-01,\n",
       "       0.0000e+00, 8.0374e-01, 0.0000e+00, 4.6928e-01, 0.0000e+00,\n",
       "       5.1765e-01, 4.6008e-01, 0.0000e+00, 4.2788e-01, 0.0000e+00,\n",
       "       9.8260e-01, 0.0000e+00, 9.3182e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 9.9684e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       1.8497e-01, 0.0000e+00, 0.0000e+00, 3.0373e-01, 5.2142e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 9.4942e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.9376e-01, 8.5719e-01, 0.0000e+00, 0.0000e+00,\n",
       "       7.7314e-01, 0.0000e+00, 8.9759e-01, 0.0000e+00, 9.8183e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       7.4024e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       9.8190e-01, 0.0000e+00, 3.2739e-01, 0.0000e+00, 8.7782e-01,\n",
       "       8.4892e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       8.1369e-01, 0.0000e+00, 7.8162e-01, 0.0000e+00, 0.0000e+00,\n",
       "       8.5131e-01, 0.0000e+00, 0.0000e+00, 9.2350e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.5842e-01, 0.0000e+00, 0.0000e+00, 9.5352e-01,\n",
       "       9.9884e-01, 5.6699e-01, 7.6794e-01, 9.1751e-01, 0.0000e+00,\n",
       "       5.4390e-01, 6.9889e-01, 0.0000e+00, 9.7271e-01, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 9.1559e-01, 0.0000e+00, 9.3894e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 4.5073e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 7.7475e-01,\n",
       "       4.2512e-01, 4.9064e-01, 0.0000e+00, 9.5668e-01, 8.5673e-01,\n",
       "       9.8853e-01, 8.8489e-01, 9.5202e-01, 9.3017e-01, 6.6796e-01,\n",
       "       0.0000e+00, 0.0000e+00, 9.2355e-01, 7.9890e-01, 0.0000e+00,\n",
       "       5.7391e-01, 7.1503e-01, 0.0000e+00, 9.1417e-01, 8.8161e-01,\n",
       "       0.0000e+00, 6.7808e-01, 0.0000e+00, 8.5342e-01, 0.0000e+00,\n",
       "       0.0000e+00, 6.1216e-01, 1.5927e-01, 0.0000e+00, 0.0000e+00,\n",
       "       7.2929e-01, 3.7921e-01, 0.0000e+00, 3.3180e-01, 0.0000e+00,\n",
       "       9.3793e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       8.5566e-01, 8.6598e-01, 0.0000e+00, 9.1859e-01, 0.0000e+00,\n",
       "       8.2201e-01, 5.8598e-01, 0.0000e+00, 0.0000e+00, 9.1437e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       7.4086e-01, 8.7428e-01, 0.0000e+00, 8.8737e-01, 0.0000e+00,\n",
       "       8.1369e-01, 0.0000e+00, 6.4296e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 4.2076e-01, 0.0000e+00, 0.0000e+00, 8.4426e-01,\n",
       "       7.5077e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 8.4324e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 2.6864e-05, 0.0000e+00, 0.0000e+00, 8.6841e-01,\n",
       "       0.0000e+00, 8.2201e-01, 7.5833e-01, 0.0000e+00, 2.1630e-01,\n",
       "       0.0000e+00, 0.0000e+00, 8.9518e-01, 0.0000e+00, 0.0000e+00,\n",
       "       5.2080e-01, 6.1150e-01, 1.5693e-01, 0.0000e+00, 8.1496e-01,\n",
       "       1.5920e-05, 4.7267e-01, 9.8077e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 9.8868e-01, 0.0000e+00, 7.8773e-01,\n",
       "       9.0503e-01, 0.0000e+00, 0.0000e+00, 2.1316e-01, 9.5566e-01,\n",
       "       8.8441e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 3.5005e-01,\n",
       "       7.5205e-01, 5.8909e-01, 9.0102e-01, 0.0000e+00, 0.0000e+00,\n",
       "       9.7757e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       8.0338e-01, 0.0000e+00, 0.0000e+00, 8.5790e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.8427e-01, 8.1730e-01, 0.0000e+00, 6.1591e-01,\n",
       "       0.0000e+00, 1.5920e-05, 0.0000e+00, 0.0000e+00, 9.2350e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 3.6042e-01, 0.0000e+00, 9.7410e-01, 6.9827e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 4.5073e-01, 2.9073e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 7.0080e-01, 0.0000e+00,\n",
       "       0.0000e+00, 9.8368e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 9.2684e-01, 0.0000e+00, 0.0000e+00, 9.9306e-01,\n",
       "       0.0000e+00, 8.5719e-01, 0.0000e+00, 0.0000e+00, 4.9284e-01,\n",
       "       8.1728e-01, 0.0000e+00, 0.0000e+00, 1.4790e-01, 9.2685e-01,\n",
       "       8.3370e-01, 7.2552e-01, 0.0000e+00, 0.0000e+00, 9.0619e-01,\n",
       "       0.0000e+00, 5.1314e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       1.0517e-01, 7.6807e-01, 0.0000e+00, 7.2056e-01, 9.5889e-01,\n",
       "       0.0000e+00, 1.4837e-01, 7.1954e-01, 1.3472e-01, 4.8687e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 8.4486e-01,\n",
       "       7.5552e-01, 0.0000e+00, 0.0000e+00, 7.8497e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.6444e-01, 9.0429e-01, 0.0000e+00, 0.0000e+00,\n",
       "       9.4054e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 9.6589e-01, 0.0000e+00, 2.1889e-05, 0.0000e+00,\n",
       "       9.6586e-01, 3.2834e-05, 0.0000e+00, 9.0963e-01, 0.0000e+00,\n",
       "       6.2368e-01, 5.2157e-01, 4.8098e-01, 2.9073e-01, 5.7718e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 7.5439e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.1369e-01, 7.7473e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 9.2368e-01, 0.0000e+00, 6.3044e-01, 9.0043e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 8.5138e-01, 9.1041e-01,\n",
       "       0.0000e+00, 0.0000e+00, 8.5328e-01, 0.0000e+00, 9.2146e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 8.9000e-01, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 4.8033e-01, 0.0000e+00, 0.0000e+00,\n",
       "       5.3140e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       7.6414e-01, 5.3058e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 8.0435e-01, 4.6958e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 2.8232e-01, 8.7170e-01, 0.0000e+00, 7.5329e-01,\n",
       "       0.0000e+00, 7.7041e-01, 0.0000e+00, 8.9039e-01, 8.5825e-01,\n",
       "       5.6687e-01, 8.3930e-01, 0.0000e+00, 0.0000e+00, 8.8989e-01,\n",
       "       2.4292e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       7.3988e-01, 9.8368e-01, 6.5528e-01, 0.0000e+00, 0.0000e+00,\n",
       "       9.8720e-01, 0.0000e+00, 9.0391e-01, 0.0000e+00, 5.6012e-01,\n",
       "       0.0000e+00, 0.0000e+00, 3.6814e-05, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 6.1592e-01, 0.0000e+00, 7.9283e-01, 7.3668e-01,\n",
       "       8.6119e-01, 8.4212e-01, 8.5842e-01, 8.5842e-01, 7.0647e-01,\n",
       "       6.1462e-01, 0.0000e+00, 7.9078e-01, 0.0000e+00, 8.7234e-01,\n",
       "       8.0071e-01, 0.0000e+00, 3.5819e-05, 8.3944e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.7274e-01, 8.5842e-01, 8.7274e-01, 0.0000e+00,\n",
       "       0.0000e+00, 9.1091e-01, 0.0000e+00, 8.6363e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.3130e-01, 0.0000e+00, 6.8842e-01, 3.4733e-01,\n",
       "       0.0000e+00, 6.3187e-01, 7.8928e-01, 0.0000e+00, 0.0000e+00,\n",
       "       9.3047e-01, 0.0000e+00, 9.3646e-01, 4.2767e-01, 4.9254e-01,\n",
       "       0.0000e+00, 0.0000e+00, 8.3519e-01, 0.0000e+00, 0.0000e+00,\n",
       "       9.2571e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 6.5104e-01, 9.1781e-01, 6.1068e-01,\n",
       "       0.0000e+00, 5.7992e-01, 3.0386e-01, 0.0000e+00, 3.2748e-01,\n",
       "       5.1183e-01, 5.7705e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 8.4562e-01, 0.0000e+00, 7.7350e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       8.6742e-01, 0.0000e+00, 8.9601e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 9.0936e-01, 8.6762e-01, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 4.9137e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 6.2520e-01, 4.8739e-01,\n",
       "       0.0000e+00, 0.0000e+00, 6.2757e-01, 8.4066e-01, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 3.4954e-01,\n",
       "       1.4837e-01, 8.7049e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 9.5712e-01,\n",
       "       5.4471e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 7.4838e-01,\n",
       "       0.0000e+00, 9.1970e-01, 1.9573e-01, 9.8406e-01, 9.2097e-01,\n",
       "       7.7935e-01, 3.1399e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       7.0193e-01, 0.0000e+00, 0.0000e+00, 8.7892e-01, 0.0000e+00,\n",
       "       6.4438e-01, 0.0000e+00, 9.0257e-01, 0.0000e+00, 9.9142e-01,\n",
       "       8.2696e-01, 9.5566e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 8.1369e-01, 0.0000e+00,\n",
       "       9.2518e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       1.6915e-05, 5.5389e-01, 8.6347e-01, 0.0000e+00, 2.3813e-01,\n",
       "       9.4636e-01, 9.0398e-01, 9.6876e-01, 7.0561e-01, 0.0000e+00,\n",
       "       0.0000e+00, 6.1399e-01, 3.4565e-03, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       8.9241e-01, 8.8590e-01, 0.0000e+00, 8.8208e-01, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 8.8409e-01, 3.7079e-01,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 3.9332e-01, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 4.6194e-01, 0.0000e+00,\n",
       "       0.0000e+00, 8.2599e-01, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "       0.0000e+00, 4.3149e-01, 0.0000e+00, 0.0000e+00, 7.7653e-01,\n",
       "       0.0000e+00, 8.8569e-01, 9.3784e-01, 4.0828e-01, 0.0000e+00,\n",
       "       0.0000e+00, 4.6567e-02, 8.6567e-01, 2.0164e-01, 0.0000e+00])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_feats[0][0,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "117"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max([all_feats[i].shape[0] for i in range(len(all_feats))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2994"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(all_feats)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Now, let's train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading data from pickle files: yahoo/train.pkl, yahoo/test.pkl\n",
      "Linear model initialized\n",
      "lr5e-05_lrdecay_0.0_l2_0.0_D_128\n",
      "Starting training with the following config\n",
      "Learning rate 5e-05, Weight decay 0.0, Sample size 10\n",
      "Lambda_reward: 1.0, lambda_ind_fairness:0.0, lambda_group_fairness:0.0\n",
      "Training....\n",
      "True\n",
      "Traceback (most recent call last):\n",
      "  File \"train_yahoo_dataset.py\", line 586, in <module>\n",
      "    args=args)\n",
      "  File \"train_yahoo_dataset.py\", line 192, in on_policy_training\n",
      "    range(len_train_set)) if args.progressbar else range(len_train_set)\n",
      "TypeError: 'module' object is not callable\n"
     ]
    }
   ],
   "source": [
    "! python train_yahoo_dataset.py --model Linear --lindf 0.0 --lr 0.00005"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading data from pickle files: yahoo/train.pkl, yahoo/test.pkl\n",
      "Linear model initialized\n",
      "lr5e-05_lrdecay_0.0_l2_0.0_D_128\n",
      "Starting training with the following config\n",
      "Learning rate 5e-05, Weight decay 0.0, Sample size 10\n",
      "Lambda_reward: 1.0, lambda_ind_fairness:0.0, lambda_group_fairness:0.0\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:58 Time:  0:01:58\n",
      "Epoch 0, Average Validation: NDCG: 0.7301078824759883, DCG 15.49721087700705, Average Rank 17.81100012191653, ERR 0.28060591466392504\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:21 ETA:   0:33:25\n",
      "Averages of last 1000 rewards: 0.7498184766572865, ndcgs: 0.7498184766572865, dcgs: 16.22547286031981\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:02:02 Time:  0:02:02\n",
      "Epoch 0, Average Validation: NDCG: 0.7516429088317071, DCG 16.097366918017627, Average Rank 17.508900719307515, ERR 0.3059196174389519\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:46 ETA:   0:14:56\n",
      "Averages of last 1000 rewards: 0.764998770114797, ndcgs: 0.764998770114797, dcgs: 15.509955236683137\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:56 Time:  0:01:56\n",
      "Epoch 0, Average Validation: NDCG: 0.7687126400383871, DCG 16.57514250094731, Average Rank 17.35154955906856, ERR 0.328632175285515\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:13:10 ETA:   0:28:10\n",
      "Averages of last 1000 rewards: 0.7742968201129489, ndcgs: 0.7742968201129489, dcgs: 16.746055431796577\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 0, Average Validation: NDCG: 0.7799139034348253, DCG 16.88523539117211, Average Rank 17.2576746454261, ERR 0.3445915221642877\n",
      " 40% (7998 of 19944) |#######            | Elapsed Time: 0:17:24 ETA:   0:13:34\n",
      "Averages of last 1000 rewards: 0.7898409871353906, ndcgs: 0.7898409871353906, dcgs: 17.479629066870547\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:46 Time:  0:01:46\n",
      "Epoch 0, Average Validation: NDCG: 0.7883510989480348, DCG 17.134083479129842, Average Rank 17.222346486772057, ERR 0.357710916028668\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:21:29 ETA:   0:12:52\n",
      "Averages of last 1000 rewards: 0.7863449879520581, ndcgs: 0.7863449879520581, dcgs: 17.66164366988089\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:47 Time:  0:01:47\n",
      "Epoch 0, Average Validation: NDCG: 0.7933692883436511, DCG 17.269307121444353, Average Rank 17.19635632137197, ERR 0.3652476341121256\n",
      " 60% (11998 of 19944) |##########        | Elapsed Time: 0:25:31 ETA:   0:08:55\n",
      "Averages of last 1000 rewards: 0.8073508296847716, ndcgs: 0.8073508296847716, dcgs: 17.483551090578576\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 0, Average Validation: NDCG: 0.797299186402868, DCG 17.387324095109772, Average Rank 17.157797374730766, ERR 0.372029612328646\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:29:41 ETA:   0:08:00\n",
      "Averages of last 1000 rewards: 0.7923743844405229, ndcgs: 0.7923743844405229, dcgs: 17.600385759819684\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 0, Average Validation: NDCG: 0.8008041574414146, DCG 17.475752692321116, Average Rank 17.125188767423904, ERR 0.3766365469749065\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:56 ETA:   0:04:28\n",
      "Averages of last 1000 rewards: 0.8041247395401218, ndcgs: 0.8041247395401218, dcgs: 17.20716369562548\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:58 Time:  0:01:58\n",
      "Epoch 0, Average Validation: NDCG: 0.8033301501074359, DCG 17.542258123037975, Average Rank 17.09948469947576, ERR 0.38040809080375326\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:38:18 ETA:   0:02:22\n",
      "Averages of last 1000 rewards: 0.8028404321419866, ndcgs: 0.8028404321419866, dcgs: 17.750131897519132\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:58 Time:  0:01:58\n",
      "Epoch 0, Average Validation: NDCG: 0.805704399548577, DCG 17.606715056032122, Average Rank 17.07765270045109, ERR 0.38419828413985085\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:42:36 Time:  0:42:36\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:57 Time:  0:01:57\n",
      "Epoch 1, Average Validation: NDCG: 0.8080817623548275, DCG 17.668293398152695, Average Rank 17.06471166741171, ERR 0.3877693656712781\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:26 ETA:   0:25:53\n",
      "Averages of last 1000 rewards: 0.8156622098957599, ndcgs: 0.8156622098957599, dcgs: 17.24123941970437\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:02:03 Time:  0:02:03\n",
      "Epoch 1, Average Validation: NDCG: 0.8101273650514954, DCG 17.73026927234379, Average Rank 17.051309789897182, ERR 0.39143317539723305\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:58 ETA:   0:22:26\n",
      "Averages of last 1000 rewards: 0.8105235988215562, ndcgs: 0.8105235988215562, dcgs: 17.585762044313938\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8113681410414161, DCG 17.767983786889435, Average Rank 17.049374568212297, ERR 0.3934144227085898\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:13:07 ETA:   0:13:24\n",
      "Averages of last 1000 rewards: 0.8162768055976604, ndcgs: 0.8162768055976604, dcgs: 18.271809521664537\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.812994398689413, DCG 17.808520533179628, Average Rank 17.014618604462147, ERR 0.3958603966241575\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:17:17 ETA:   0:11:31\n",
      "Averages of last 1000 rewards: 0.805772024346105, ndcgs: 0.805772024346105, dcgs: 17.4589619875357\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 1, Average Validation: NDCG: 0.8139198458588899, DCG 17.826164643887065, Average Rank 16.990845694314626, ERR 0.39685292260076893\n",
      " 50% (9998 of 19944) |#########          | Elapsed Time: 0:21:28 ETA:   0:12:22\n",
      "Averages of last 1000 rewards: 0.8086181825288214, ndcgs: 0.8086181825288214, dcgs: 18.759525693288992\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.814695062822937, DCG 17.859727883427137, Average Rank 17.003287682366807, ERR 0.39888723215257027\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:25:32 ETA:   0:09:14\n",
      "Averages of last 1000 rewards: 0.8181003352819787, ndcgs: 0.8181003352819787, dcgs: 17.744674459413908\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8161154224000823, DCG 17.891641239204677, Average Rank 16.990444995326534, ERR 0.40079012055403007\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:29:38 ETA:   0:07:22\n",
      "Averages of last 1000 rewards: 0.8137844937084527, ndcgs: 0.8137844937084527, dcgs: 17.942263604590714\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 1\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8171965231572565, DCG 17.921276084689108, Average Rank 16.979661072052668, ERR 0.40239262295654094\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:43 ETA:   0:04:33\n",
      "Averages of last 1000 rewards: 0.8130332990958666, ndcgs: 0.8130332990958666, dcgs: 18.09820436295068\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8177345525575921, DCG 17.93813202427765, Average Rank 16.969777705530948, ERR 0.4035043128873853\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:37:50 ETA:   0:02:16\n",
      "Averages of last 1000 rewards: 0.813065313367168, ndcgs: 0.813065313367168, dcgs: 17.83865508961661\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8179317909971432, DCG 17.951491372993768, Average Rank 16.957434063477873, ERR 0.40393355501125705\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:52 Time:  0:41:52\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8186222586968798, DCG 17.95930531310412, Average Rank 16.94021132198155, ERR 0.40457559364430695\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:07 ETA:   0:20:24\n",
      "Averages of last 1000 rewards: 0.819657018855669, ndcgs: 0.819657018855669, dcgs: 18.022209769103213\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8197682324329655, DCG 17.984084190562523, Average Rank 16.934699069370506, ERR 0.40584371742982345\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:15 ETA:   0:20:39\n",
      "Averages of last 1000 rewards: 0.8258933157263562, ndcgs: 0.8258933157263562, dcgs: 17.98894952703046\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8208859713161305, DCG 18.016790268744963, Average Rank 16.93186247815662, ERR 0.4079344757630492\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:20 ETA:   0:14:43\n",
      "Averages of last 1000 rewards: 0.8162246323972432, ndcgs: 0.8162246323972432, dcgs: 17.355008766618994\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.821445199647288, DCG 18.026879938733902, Average Rank 16.922292843499818, ERR 0.40856413187106727\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:24 ETA:   0:12:40\n",
      "Averages of last 1000 rewards: 0.8184092377546448, ndcgs: 0.8184092377546448, dcgs: 18.88692691705359\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8214395052498105, DCG 18.03422004764449, Average Rank 16.922781322387937, ERR 0.4089246831441716\n",
      " 50% (9996 of 19944) |#########          | Elapsed Time: 0:20:32 ETA:   0:12:10\n",
      "Averages of last 1000 rewards: 0.8158930518708787, ndcgs: 0.8158930518708787, dcgs: 18.149959229272184\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8221975462511114, DCG 18.062696325692116, Average Rank 16.927030519770796, ERR 0.4107352071225142\n",
      " 60% (11997 of 19944) |##########        | Elapsed Time: 0:24:36 ETA:   0:08:51\n",
      "Averages of last 1000 rewards: 0.8262648049381884, ndcgs: 0.8262648049381884, dcgs: 18.33736267729776\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.822825334176817, DCG 18.06955969460451, Average Rank 16.925251351241517, ERR 0.411080956926469\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:28:42 ETA:   0:06:05\n",
      "Averages of last 1000 rewards: 0.8228884795945055, ndcgs: 0.8228884795945055, dcgs: 18.37929764669074\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 2, Average Validation: NDCG: 0.8230739821784349, DCG 18.08148213408362, Average Rank 16.92006989880928, ERR 0.41181693009169473\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:32:50 ETA:   0:06:46\n",
      "Averages of last 1000 rewards: 0.8135492946238028, ndcgs: 0.8135492946238028, dcgs: 17.74824017081008\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8235716526797818, DCG 18.09215954167932, Average Rank 16.904175234689315, ERR 0.41223096832568706\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:36:55 ETA:   0:01:58\n",
      "Averages of last 1000 rewards: 0.8258750140269959, ndcgs: 0.8258750140269959, dcgs: 18.500916898599684\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 2\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 2, Average Validation: NDCG: 0.8238486304933202, DCG 18.099065930596243, Average Rank 16.89864753931808, ERR 0.41292251791035633\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:40:53 Time:  0:40:53\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8248288846946764, DCG 18.116586500705292, Average Rank 16.887844922176615, ERR 0.41399832930962127\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:06 ETA:   0:25:31\n",
      "Averages of last 1000 rewards: 0.8288117109864902, ndcgs: 0.8288117109864902, dcgs: 18.673047872810628\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8251867472738837, DCG 18.131009409216954, Average Rank 16.89027431218759, ERR 0.4147260602277539\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:13 ETA:   0:18:26\n",
      "Averages of last 1000 rewards: 0.829129568764508, ndcgs: 0.829129568764508, dcgs: 17.812618471465473\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8256551227512984, DCG 18.142731162456883, Average Rank 16.885215589060024, ERR 0.4154368710766823\n",
      " 30% (5998 of 19944) |#####              | Elapsed Time: 0:12:20 ETA:   0:14:53\n",
      "Averages of last 1000 rewards: 0.820823615320064, ndcgs: 0.820823615320064, dcgs: 17.83182563096141\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8257780226108798, DCG 18.138889144152312, Average Rank 16.87654163449425, ERR 0.4151644828879893\n",
      " 40% (7997 of 19944) |#######            | Elapsed Time: 0:16:26 ETA:   0:14:54\n",
      "Averages of last 1000 rewards: 0.818920597229671, ndcgs: 0.818920597229671, dcgs: 17.843207892066893\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8260635362559788, DCG 18.14948012962921, Average Rank 16.873635144471084, ERR 0.415586062810795\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:34 ETA:   0:11:08\n",
      "Averages of last 1000 rewards: 0.8203915874948162, ndcgs: 0.8203915874948162, dcgs: 17.973997240541934\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 3\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8261791642583843, DCG 18.16052915689031, Average Rank 16.86549112041289, ERR 0.41633207189362764\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:38 ETA:   0:10:07\n",
      "Averages of last 1000 rewards: 0.8242645083068975, ndcgs: 0.8242645083068975, dcgs: 17.57313334336537\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 3, Average Validation: NDCG: 0.826394938234269, DCG 18.161858681777126, Average Rank 16.867710813996016, ERR 0.4165511557219274\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:28:47 ETA:   0:08:24\n",
      "Averages of last 1000 rewards: 0.823505549969761, ndcgs: 0.823505549969761, dcgs: 17.931776532112085\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.826690027747092, DCG 18.166306933449444, Average Rank 16.85913520542935, ERR 0.4165946512686759\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:32:53 ETA:   0:04:34\n",
      "Averages of last 1000 rewards: 0.8251444561605868, ndcgs: 0.8251444561605868, dcgs: 18.147542338263143\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8274027104481616, DCG 18.18445648760877, Average Rank 16.86048766611127, ERR 0.4178680315638033\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:01 ETA:   0:02:01\n",
      "Averages of last 1000 rewards: 0.8238252260941076, ndcgs: 0.8238252260941076, dcgs: 18.771301097852426\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 3\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 3, Average Validation: NDCG: 0.8279938259188153, DCG 18.204038175463623, Average Rank 16.851295159913846, ERR 0.41899979391807435\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:04 Time:  0:41:04\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8280786438671021, DCG 18.208375634855575, Average Rank 16.850957044743367, ERR 0.4192588505683351\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:04 ETA:   0:20:44\n",
      "Averages of last 1000 rewards: 0.8323490924255709, ndcgs: 0.8323490924255709, dcgs: 18.360482708622555\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8282260530680029, DCG 18.203098128894048, Average Rank 16.851921810866827, ERR 0.41890046803856057\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:08 ETA:   0:14:45\n",
      "Averages of last 1000 rewards: 0.832427650405851, ndcgs: 0.832427650405851, dcgs: 17.511028829262145\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8287289481206489, DCG 18.221335214418357, Average Rank 16.847659609054332, ERR 0.41993972055617274\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:17 ETA:   0:15:37\n",
      "Averages of last 1000 rewards: 0.8272070474078829, ndcgs: 0.8272070474078829, dcgs: 18.99369624131916\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8288227513576053, DCG 18.230724278910674, Average Rank 16.842807331247204, ERR 0.42061871439105064\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:26 ETA:   0:13:44\n",
      "Averages of last 1000 rewards: 0.8305739000058683, ndcgs: 0.8305739000058683, dcgs: 18.64969033747499\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 4, Average Validation: NDCG: 0.828905105672355, DCG 18.23472789978274, Average Rank 16.85333766814321, ERR 0.42090740783398806\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:35 ETA:   0:10:52\n",
      "Averages of last 1000 rewards: 0.8286997107775683, ndcgs: 0.8286997107775683, dcgs: 17.86093372016785\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 4, Average Validation: NDCG: 0.8297351612897718, DCG 18.25383198771183, Average Rank 16.845035152598854, ERR 0.4219043998008988\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:47 ETA:   0:10:38\n",
      "Averages of last 1000 rewards: 0.8233823945763349, ndcgs: 0.8233823945763349, dcgs: 18.219590588393473\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8298124393284643, DCG 18.24753384105568, Average Rank 16.842122973137727, ERR 0.4215625384046895\n",
      " 70% (13998 of 19944) |############      | Elapsed Time: 0:28:55 ETA:   0:05:36\n",
      "Averages of last 1000 rewards: 0.8307853113434819, ndcgs: 0.8307853113434819, dcgs: 18.566910506467227\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8298646478457449, DCG 18.255414523566387, Average Rank 16.84227821351648, ERR 0.4218692751385726\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:00 ETA:   0:04:55\n",
      "Averages of last 1000 rewards: 0.8266185485692661, ndcgs: 0.8266185485692661, dcgs: 17.164830471177346\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:49 Time:  0:01:49\n",
      "Epoch 4, Average Validation: NDCG: 0.8307445971908509, DCG 18.27464616834068, Average Rank 16.838250091437395, ERR 0.42338258153063946\n",
      " 90% (17998 of 19944) |################  | Elapsed Time: 0:37:12 ETA:   0:02:27\n",
      "Averages of last 1000 rewards: 0.8328809081352821, ndcgs: 0.8328809081352821, dcgs: 19.366766231093518\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 4\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 4, Average Validation: NDCG: 0.8301528704521745, DCG 18.26773917841334, Average Rank 16.834267484862032, ERR 0.4226712890851008\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:17 Time:  0:41:17\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8304208721095621, DCG 18.271065094173565, Average Rank 16.839552159954483, ERR 0.42292002090531533\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:04 ETA:   0:20:41\n",
      "Averages of last 1000 rewards: 0.8284531341047588, ndcgs: 0.8284531341047588, dcgs: 17.821419789645486\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8306068325294022, DCG 18.274505159729344, Average Rank 16.834610476693623, ERR 0.4232134491481408\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:11 ETA:   0:15:41\n",
      "Averages of last 1000 rewards: 0.8332206435379403, ndcgs: 0.8332206435379403, dcgs: 18.048170129316553\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8311377467481894, DCG 18.294716704895656, Average Rank 16.835133904986385, ERR 0.42426780581665013\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:24 ETA:   0:17:51\n",
      "Averages of last 1000 rewards: 0.8305488610001103, ndcgs: 0.8305488610001103, dcgs: 18.880060006948366\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 5\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8311776289855163, DCG 18.287928582721616, Average Rank 16.826822448896657, ERR 0.423870386180508\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:32 ETA:   0:15:15\n",
      "Averages of last 1000 rewards: 0.8274065679532855, ndcgs: 0.8274065679532855, dcgs: 17.590736753307624\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8312492998190809, DCG 18.291350323554877, Average Rank 16.823815987320682, ERR 0.424063308798296\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:42 ETA:   0:09:39\n",
      "Averages of last 1000 rewards: 0.8268902479415183, ndcgs: 0.8268902479415183, dcgs: 18.061439088795883\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8313033369092921, DCG 18.29063797995038, Average Rank 16.821998618279352, ERR 0.4241227450943721\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:52 ETA:   0:07:44\n",
      "Averages of last 1000 rewards: 0.8249224569255571, ndcgs: 0.8249224569255571, dcgs: 17.59687562784039\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8316605578575629, DCG 18.301635747076208, Average Rank 16.82185231844597, ERR 0.4248249317088549\n",
      " 70% (13998 of 19944) |############      | Elapsed Time: 0:29:00 ETA:   0:06:12\n",
      "Averages of last 1000 rewards: 0.8347625342675796, ndcgs: 0.8347625342675796, dcgs: 19.212671953303865\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8321387849049855, DCG 18.305304428970892, Average Rank 16.82120616084854, ERR 0.42494912983172106\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:08 ETA:   0:05:11\n",
      "Averages of last 1000 rewards: 0.8305826772289195, ndcgs: 0.8305826772289195, dcgs: 18.560682677782616\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 5, Average Validation: NDCG: 0.8318793557480684, DCG 18.30740985747634, Average Rank 16.81867761206161, ERR 0.42503757188202446\n",
      " 90% (17998 of 19944) |################  | Elapsed Time: 0:37:16 ETA:   0:02:20\n",
      "Averages of last 1000 rewards: 0.8318366468974085, ndcgs: 0.8318366468974085, dcgs: 18.105863867013397\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 5\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 5, Average Validation: NDCG: 0.8321409538927427, DCG 18.310188291035182, Average Rank 16.81609135611818, ERR 0.4251795239743993\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:21 Time:  0:41:21\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 6, Average Validation: NDCG: 0.832656524292281, DCG 18.325146068304548, Average Rank 16.81622627707563, ERR 0.4261076837127653\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:11 ETA:   0:20:21\n",
      "Averages of last 1000 rewards: 0.8352798554083178, ndcgs: 0.8352798554083178, dcgs: 19.150775738994536\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 6, Average Validation: NDCG: 0.8323752526619931, DCG 18.316264647638768, Average Rank 16.818091599951234, ERR 0.42555948651101366\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:20 ETA:   0:20:21\n",
      "Averages of last 1000 rewards: 0.8287990813029181, ndcgs: 0.8287990813029181, dcgs: 18.27717006345443\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 6, Average Validation: NDCG: 0.8325100915564333, DCG 18.323589532220875, Average Rank 16.813574186207177, ERR 0.42596889612711425\n",
      " 30% (5998 of 19944) |#####              | Elapsed Time: 0:12:28 ETA:   0:18:29\n",
      "Averages of last 1000 rewards: 0.8308501898061993, ndcgs: 0.8308501898061993, dcgs: 18.437701330755726\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 6, Average Validation: NDCG: 0.8333340173262231, DCG 18.34485221268121, Average Rank 16.8080318608526, ERR 0.42760990603225063\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:37 ETA:   0:14:04\n",
      "Averages of last 1000 rewards: 0.8327390078311083, ndcgs: 0.8327390078311083, dcgs: 18.534090354468937\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:50 Time:  0:01:50\n",
      "Epoch 6, Average Validation: NDCG: 0.833134573698928, DCG 18.333427439691995, Average Rank 16.79560694111432, ERR 0.4266066227669184\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:44 ETA:   0:13:40\n",
      "Averages of last 1000 rewards: 0.8320633793095462, ndcgs: 0.8320633793095462, dcgs: 17.886727297712607\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 6, Average Validation: NDCG: 0.8335211121442266, DCG 18.344343292875198, Average Rank 16.80275043686756, ERR 0.42729268096077766\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:50 ETA:   0:08:03\n",
      "Averages of last 1000 rewards: 0.8327542708286291, ndcgs: 0.8327542708286291, dcgs: 18.21619424753078\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 6, Average Validation: NDCG: 0.833352784867397, DCG 18.34390647338016, Average Rank 16.802192059170157, ERR 0.4270340889289202\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:28:58 ETA:   0:08:48\n",
      "Averages of last 1000 rewards: 0.8362644762655664, ndcgs: 0.8362644762655664, dcgs: 18.401714824936526\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 6, Average Validation: NDCG: 0.8333381342615744, DCG 18.345021398919503, Average Rank 16.800581135449264, ERR 0.4271237010063756\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:08 ETA:   0:04:40\n",
      "Averages of last 1000 rewards: 0.8289167088863911, ndcgs: 0.8289167088863911, dcgs: 18.72010814505181\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 6, Average Validation: NDCG: 0.83356441545459, DCG 18.35222464297015, Average Rank 16.80336977282887, ERR 0.4277011444264074\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:37:21 ETA:   0:02:10\n",
      "Averages of last 1000 rewards: 0.8334562944918072, ndcgs: 0.8334562944918072, dcgs: 18.65667549187888\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 6\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 6, Average Validation: NDCG: 0.8338082272068291, DCG 18.356909718078967, Average Rank 16.793680659974804, ERR 0.4278454750064211\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:26 Time:  0:41:26\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8338267343456756, DCG 18.355901752905734, Average Rank 16.79617263380339, ERR 0.4279213151001344\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:12 ETA:   0:18:25\n",
      "Averages of last 1000 rewards: 0.8347784213736678, ndcgs: 0.8347784213736678, dcgs: 18.35628743953127\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 7\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8338602105605427, DCG 18.35911566650201, Average Rank 16.786875279392042, ERR 0.427955804168791\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:24 ETA:   0:18:00\n",
      "Averages of last 1000 rewards: 0.8316295502529022, ndcgs: 0.8316295502529022, dcgs: 19.004430905026076\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8342000611636914, DCG 18.370130952198394, Average Rank 16.793449831348802, ERR 0.4286913375298455\n",
      " 30% (5998 of 19944) |#####              | Elapsed Time: 0:12:31 ETA:   0:16:00\n",
      "Averages of last 1000 rewards: 0.8315006207680449, ndcgs: 0.8315006207680449, dcgs: 18.1935368716371\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8340971641508482, DCG 18.363045618043436, Average Rank 16.780982647214206, ERR 0.42810907203903453\n",
      " 40% (7997 of 19944) |#######            | Elapsed Time: 0:16:41 ETA:   0:13:05\n",
      "Averages of last 1000 rewards: 0.8343151235224594, ndcgs: 0.8343151235224594, dcgs: 18.245786902399647\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8343697756783938, DCG 18.36508856145102, Average Rank 16.783138131426018, ERR 0.4281591776940699\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:20:49 ETA:   0:10:55\n",
      "Averages of last 1000 rewards: 0.8390700356212255, ndcgs: 0.8390700356212255, dcgs: 18.022223748175865\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8343271866055795, DCG 18.364718016904224, Average Rank 16.778484983947656, ERR 0.42818686862352373\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:25:01 ETA:   0:09:32\n",
      "Averages of last 1000 rewards: 0.8278403868341729, ndcgs: 0.8278403868341729, dcgs: 18.983060187352798\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.834415076020447, DCG 18.371824959134475, Average Rank 16.780468159466817, ERR 0.4288149750616382\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:08 ETA:   0:06:39\n",
      "Averages of last 1000 rewards: 0.8392424004416927, ndcgs: 0.8392424004416927, dcgs: 17.835896208826867\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8348282247822418, DCG 18.38199105077102, Average Rank 16.775483399032794, ERR 0.42917965873035524\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:19 ETA:   0:04:09\n",
      "Averages of last 1000 rewards: 0.8303589900477498, ndcgs: 0.8303589900477498, dcgs: 18.247014146323068\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.834690314710845, DCG 18.37722872436139, Average Rank 16.77871256146625, ERR 0.4291195474661947\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:23 ETA:   0:02:01\n",
      "Averages of last 1000 rewards: 0.8365775902865469, ndcgs: 0.8365775902865469, dcgs: 18.18424072482381\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 7\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 7, Average Validation: NDCG: 0.8350057503648987, DCG 18.382349239166945, Average Rank 16.76933311659284, ERR 0.4292509009780935\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:28 Time:  0:41:28\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 8, Average Validation: NDCG: 0.8350495566454483, DCG 18.383491762589067, Average Rank 16.766055187548258, ERR 0.4292872320478338\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:10 ETA:   0:19:04\n",
      "Averages of last 1000 rewards: 0.8237083832827224, ndcgs: 0.8237083832827224, dcgs: 18.493526926961096\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 8, Average Validation: NDCG: 0.8346787599327181, DCG 18.374498335881643, Average Rank 16.76347380826594, ERR 0.42877377278783574\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:18 ETA:   0:16:33\n",
      "Averages of last 1000 rewards: 0.8325835893960002, ndcgs: 0.8325835893960002, dcgs: 18.49179119976048\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 8, Average Validation: NDCG: 0.8350652192333161, DCG 18.383208694616403, Average Rank 16.756029585077417, ERR 0.42923083570715953\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:27 ETA:   0:14:28\n",
      "Averages of last 1000 rewards: 0.833788721460831, ndcgs: 0.833788721460831, dcgs: 18.553856758697027\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 8, Average Validation: NDCG: 0.8350666373796631, DCG 18.381258344397686, Average Rank 16.752608607306865, ERR 0.4290270423254063\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:35 ETA:   0:13:24\n",
      "Averages of last 1000 rewards: 0.8324351783258326, ndcgs: 0.8324351783258326, dcgs: 17.586761715122577\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 8, Average Validation: NDCG: 0.8353993535643824, DCG 18.386197265728644, Average Rank 16.755722355427316, ERR 0.4291951128839334\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:20:47 ETA:   0:11:32\n",
      "Averages of last 1000 rewards: 0.8371712810857063, ndcgs: 0.8371712810857063, dcgs: 18.76756564025072\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 8, Average Validation: NDCG: 0.8356649653286196, DCG 18.396015389945365, Average Rank 16.749738692242044, ERR 0.4301094910355362\n",
      " 60% (11998 of 19944) |##########        | Elapsed Time: 0:24:58 ETA:   0:09:03\n",
      "Averages of last 1000 rewards: 0.8306755845972875, ndcgs: 0.8306755845972875, dcgs: 18.305978042925194\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 8, Average Validation: NDCG: 0.8353575320615872, DCG 18.389813861078988, Average Rank 16.748249685048968, ERR 0.4296268565717741\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:07 ETA:   0:05:40\n",
      "Averages of last 1000 rewards: 0.8370271959007594, ndcgs: 0.8370271959007594, dcgs: 18.758064100994204\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 8, Average Validation: NDCG: 0.835787307780171, DCG 18.395812651502645, Average Rank 16.742980452716708, ERR 0.4299620069396507\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:15 ETA:   0:05:45\n",
      "Averages of last 1000 rewards: 0.8368484677935057, ndcgs: 0.8368484677935057, dcgs: 19.12835274847816\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 8\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 8, Average Validation: NDCG: 0.8357269427873647, DCG 18.39669105302095, Average Rank 16.743355955622384, ERR 0.42996764783477587\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:37:28 ETA:   0:02:10\n",
      "Averages of last 1000 rewards: 0.8349334354131579, ndcgs: 0.8349334354131579, dcgs: 18.95935880175567\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 8\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 8, Average Validation: NDCG: 0.8358131310032421, DCG 18.395786382412673, Average Rank 16.74969480229203, ERR 0.4299024191511008\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:30 Time:  0:41:30\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 9, Average Validation: NDCG: 0.8359601455192436, DCG 18.40480965437317, Average Rank 16.74514569025074, ERR 0.4302958100232268\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:07 ETA:   0:26:50\n",
      "Averages of last 1000 rewards: 0.8388133718194879, ndcgs: 0.8388133718194879, dcgs: 18.63947045034232\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 9, Average Validation: NDCG: 0.8362927379739682, DCG 18.414841118908896, Average Rank 16.745173324663714, ERR 0.43118082132484337\n",
      " 20% (3998 of 19944) |###                | Elapsed Time: 0:08:19 ETA:   0:18:30\n",
      "Averages of last 1000 rewards: 0.82813403703888, ndcgs: 0.82813403703888, dcgs: 19.224505574253236\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 9, Average Validation: NDCG: 0.8364157642593713, DCG 18.414198963783964, Average Rank 16.74105335880034, ERR 0.43091048178036034\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:27 ETA:   0:12:52\n",
      "Averages of last 1000 rewards: 0.8358172538761259, ndcgs: 0.8358172538761259, dcgs: 17.460878011888692\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8363429841748529, DCG 18.414524812755015, Average Rank 16.744185800788394, ERR 0.4309349395051152\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:39 ETA:   0:13:35\n",
      "Averages of last 1000 rewards: 0.8411515406867099, ndcgs: 0.8411515406867099, dcgs: 18.458150968981244\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8366869102849445, DCG 18.416342073599733, Average Rank 16.737727475921485, ERR 0.4312529943664121\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:47 ETA:   0:11:15\n",
      "Averages of last 1000 rewards: 0.8341099722526324, ndcgs: 0.8341099722526324, dcgs: 17.73004005414771\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8366062128941972, DCG 18.41962855424297, Average Rank 16.736554638923884, ERR 0.4312343694048815\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:25:00 ETA:   0:07:09\n",
      "Averages of last 1000 rewards: 0.8354453350111127, ndcgs: 0.8354453350111127, dcgs: 18.61242696663381\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8366463838909166, DCG 18.416764478443987, Average Rank 16.73924330475068, ERR 0.4312208195424192\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:29:06 ETA:   0:06:54\n",
      "Averages of last 1000 rewards: 0.8386756315371933, ndcgs: 0.8386756315371933, dcgs: 18.140604119708392\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8368860555094895, DCG 18.427977862683644, Average Rank 16.746022676474173, ERR 0.4318936572478317\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:17 ETA:   0:04:52\n",
      "Averages of last 1000 rewards: 0.8326381324848605, ndcgs: 0.8326381324848605, dcgs: 18.35406008505093\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 9, Average Validation: NDCG: 0.8368722080758796, DCG 18.42987706323046, Average Rank 16.735630511643027, ERR 0.4318832017705687\n",
      " 90% (17997 of 19944) |################  | Elapsed Time: 0:37:26 ETA:   0:02:28\n",
      "Averages of last 1000 rewards: 0.8324412912789746, ndcgs: 0.8324412912789746, dcgs: 18.56254254426074\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 9\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:51 Time:  0:01:51\n",
      "Epoch 9, Average Validation: NDCG: 0.8365991729322789, DCG 18.425894298544, Average Rank 16.740527492177023, ERR 0.43159252975323786\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:34 Time:  0:41:34\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8368887875990374, DCG 18.42767944174723, Average Rank 16.740102409883367, ERR 0.4317055441332468\n",
      " 10% (1998 of 19944) |#                  | Elapsed Time: 0:04:05 ETA:   0:21:52\n",
      "Averages of last 1000 rewards: 0.8417433715642617, ndcgs: 0.8417433715642617, dcgs: 17.8347390268969\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8368924193455332, DCG 18.42666982528532, Average Rank 16.73344576746454, ERR 0.4315955650162899\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:18 ETA:   0:16:40\n",
      "Averages of last 1000 rewards: 0.8319008304254324, ndcgs: 0.8319008304254324, dcgs: 18.043455998420292\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8370679670904959, DCG 18.430760125387827, Average Rank 16.733457959117324, ERR 0.43194011627789686\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:27 ETA:   0:18:14\n",
      "Averages of last 1000 rewards: 0.8331181124126875, ndcgs: 0.8331181124126875, dcgs: 18.29458997091842\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8369762460689765, DCG 18.431334006652182, Average Rank 16.734206526598122, ERR 0.43191671449987523\n",
      " 40% (7996 of 19944) |#######            | Elapsed Time: 0:16:37 ETA:   0:15:22\n",
      "Averages of last 1000 rewards: 0.8408334427894871, ndcgs: 0.8408334427894871, dcgs: 18.89756940917721\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8370228877848745, DCG 18.4326197867546, Average Rank 16.731126915105456, ERR 0.4319417523717782\n",
      " 50% (9998 of 19944) |#########          | Elapsed Time: 0:20:42 ETA:   0:08:51\n",
      "Averages of last 1000 rewards: 0.8428472272153685, ndcgs: 0.8428472272153685, dcgs: 18.69398640736733\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.837209024855621, DCG 18.432536717828263, Average Rank 16.72710041858008, ERR 0.4319441410959133\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:56 ETA:   0:08:14\n",
      "Averages of last 1000 rewards: 0.8323166397624145, ndcgs: 0.8323166397624145, dcgs: 18.367878105849577\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8373410510786696, DCG 18.443766460009627, Average Rank 16.732970293006055, ERR 0.432784148727385\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:02 ETA:   0:07:28\n",
      "Averages of last 1000 rewards: 0.8454586021055092, ndcgs: 0.8454586021055092, dcgs: 18.94414513733109\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 10\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8373861386133523, DCG 18.442144016375213, Average Rank 16.730670947291422, ERR 0.4325274408038591\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:16 ETA:   0:05:16\n",
      "Averages of last 1000 rewards: 0.8265687390826871, ndcgs: 0.8265687390826871, dcgs: 17.75542449001391\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8374920270594209, DCG 18.44693090014645, Average Rank 16.733938310236926, ERR 0.4327688071403059\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:37:26 ETA:   0:01:55\n",
      "Averages of last 1000 rewards: 0.831671944569063, ndcgs: 0.831671944569063, dcgs: 18.68940071798113\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 10\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 10, Average Validation: NDCG: 0.8377377110040134, DCG 18.44583811331324, Average Rank 16.733749746007234, ERR 0.4329309116966156\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:34 Time:  0:41:34\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8377157115607576, DCG 18.450204674967157, Average Rank 16.730462063640427, ERR 0.43286169726274126\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:10 ETA:   0:20:47\n",
      "Averages of last 1000 rewards: 0.8331285576383582, ndcgs: 0.8331285576383582, dcgs: 18.771351504353294\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8379687939711907, DCG 18.45317783033381, Average Rank 16.731874669809404, ERR 0.4332364005943183\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:21 ETA:   0:16:57\n",
      "Averages of last 1000 rewards: 0.8320923723518315, ndcgs: 0.8320923723518315, dcgs: 19.046102745702907\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8379961596668846, DCG 18.45856939268042, Average Rank 16.737251188686145, ERR 0.4336673026399079\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:33 ETA:   0:19:14\n",
      "Averages of last 1000 rewards: 0.835870165008825, ndcgs: 0.835870165008825, dcgs: 18.271972715446033\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8377893054724403, DCG 18.453301433973685, Average Rank 16.736057219490387, ERR 0.43323067516374225\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:42 ETA:   0:12:47\n",
      "Averages of last 1000 rewards: 0.8348951381555098, ndcgs: 0.8348951381555098, dcgs: 18.46532946521641\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8379519060071017, DCG 18.460866510974423, Average Rank 16.738003820051205, ERR 0.43370891423381874\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:51 ETA:   0:11:54\n",
      "Averages of last 1000 rewards: 0.8463639179851048, ndcgs: 0.8463639179851048, dcgs: 18.26810272963794\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 11, Average Validation: NDCG: 0.8379716175167992, DCG 18.456329143772987, Average Rank 16.74009184378429, ERR 0.4334209519002579\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:25:03 ETA:   0:08:43\n",
      "Averages of last 1000 rewards: 0.8404065164229699, ndcgs: 0.8404065164229699, dcgs: 18.05349115839868\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.838036232311, DCG 18.457449857822308, Average Rank 16.741040354370707, ERR 0.43351852372255806\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:09 ETA:   0:07:05\n",
      "Averages of last 1000 rewards: 0.8379049937839873, ndcgs: 0.8379049937839873, dcgs: 17.688085488299958\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 11, Average Validation: NDCG: 0.8378726397189721, DCG 18.457463583961395, Average Rank 16.743750965172513, ERR 0.43338637940036695\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:18 ETA:   0:04:25\n",
      "Averages of last 1000 rewards: 0.8352678401816727, ndcgs: 0.8352678401816727, dcgs: 18.90878244128725\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 11, Average Validation: NDCG: 0.8380156511297642, DCG 18.4649412742446, Average Rank 16.73735197301581, ERR 0.4340033989293008\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:28 ETA:   0:02:16\n",
      "Averages of last 1000 rewards: 0.8360441697126915, ndcgs: 0.8360441697126915, dcgs: 18.338577201452487\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 11\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 11, Average Validation: NDCG: 0.8383150362581119, DCG 18.47067845576583, Average Rank 16.736071849473728, ERR 0.4343335225646486\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:35 Time:  0:41:35\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 12, Average Validation: NDCG: 0.8382997829430071, DCG 18.47380895932275, Average Rank 16.736204332100623, ERR 0.43453700851266364\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:08 ETA:   0:15:44\n",
      "Averages of last 1000 rewards: 0.8402261250319458, ndcgs: 0.8402261250319458, dcgs: 17.885381175221646\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8380515316012125, DCG 18.465489307192996, Average Rank 16.735609379444874, ERR 0.43409360987811496\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:19 ETA:   0:20:15\n",
      "Averages of last 1000 rewards: 0.8508817976243429, ndcgs: 0.8508817976243429, dcgs: 19.91790093673786\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 12, Average Validation: NDCG: 0.8384682755203019, DCG 18.468820798301408, Average Rank 16.736843174706383, ERR 0.43404478995513046\n",
      " 30% (5998 of 19944) |#####              | Elapsed Time: 0:12:28 ETA:   0:16:41\n",
      "Averages of last 1000 rewards: 0.8332072882013404, ndcgs: 0.8332072882013404, dcgs: 18.496298798288812\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8383205322768345, DCG 18.468913930113068, Average Rank 16.732296500995652, ERR 0.4342035365930371\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:35 ETA:   0:16:42\n",
      "Averages of last 1000 rewards: 0.8435026569636916, ndcgs: 0.8435026569636916, dcgs: 18.770680151780695\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8384087498783456, DCG 18.47296018962026, Average Rank 16.733578250091437, ERR 0.4343831903996693\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:45 ETA:   0:15:15\n",
      "Averages of last 1000 rewards: 0.8374192699368528, ndcgs: 0.8374192699368528, dcgs: 18.223115234733328\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 12\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8382325419983596, DCG 18.466764182257286, Average Rank 16.728294387775836, ERR 0.4340304286005876\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:58 ETA:   0:10:29\n",
      "Averages of last 1000 rewards: 0.8361540158609503, ndcgs: 0.8361540158609503, dcgs: 18.555179486584223\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 12, Average Validation: NDCG: 0.8385554196933822, DCG 18.47538231778695, Average Rank 16.729053521355713, ERR 0.4345620016735041\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:07 ETA:   0:05:57\n",
      "Averages of last 1000 rewards: 0.8404307993926831, ndcgs: 0.8404307993926831, dcgs: 18.09351089177245\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8386135861281317, DCG 18.47815927689206, Average Rank 16.73384809200634, ERR 0.4347212569872925\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:15 ETA:   0:04:06\n",
      "Averages of last 1000 rewards: 0.8371363360764358, ndcgs: 0.8371363360764358, dcgs: 18.462202371325873\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 12, Average Validation: NDCG: 0.8384942969092595, DCG 18.47566695468964, Average Rank 16.736121428861708, ERR 0.4344868963101038\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:27 ETA:   0:02:13\n",
      "Averages of last 1000 rewards: 0.8380452240793624, ndcgs: 0.8380452240793624, dcgs: 18.52856651055684\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 12\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 12, Average Validation: NDCG: 0.8386211332938518, DCG 18.480582781143124, Average Rank 16.73282968261064, ERR 0.4349770445734605\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:28 Time:  0:41:28\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 13, Average Validation: NDCG: 0.8387069987794742, DCG 18.48212565889756, Average Rank 16.728984435323284, ERR 0.43504074290495204\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:09 ETA:   0:19:13\n",
      "Averages of last 1000 rewards: 0.8420809313688126, ndcgs: 0.8420809313688126, dcgs: 18.591909225858195\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8388169950716686, DCG 18.481730407847706, Average Rank 16.72489941886455, ERR 0.43484458473511206\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:19 ETA:   0:17:16\n",
      "Averages of last 1000 rewards: 0.8400685394736499, ndcgs: 0.8400685394736499, dcgs: 18.790368452462157\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8389240434968944, DCG 18.480674492344843, Average Rank 16.73149672857317, ERR 0.43474452025142596\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:25 ETA:   0:14:38\n",
      "Averages of last 1000 rewards: 0.8344081634440178, ndcgs: 0.8344081634440178, dcgs: 18.54090346259895\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8390586704692162, DCG 18.481268713413513, Average Rank 16.721835250132077, ERR 0.434917772646752\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:37 ETA:   0:15:20\n",
      "Averages of last 1000 rewards: 0.836977887229014, ndcgs: 0.836977887229014, dcgs: 18.861536367367\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8390566030932232, DCG 18.484183054845314, Average Rank 16.719897590116634, ERR 0.4349551517728743\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:44 ETA:   0:13:36\n",
      "Averages of last 1000 rewards: 0.8481417793810638, ndcgs: 0.8481417793810638, dcgs: 18.481205759799167\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.839130962940405, DCG 18.4855954542203, Average Rank 16.713946438005447, ERR 0.43489195096331645\n",
      " 60% (11998 of 19944) |##########        | Elapsed Time: 0:24:51 ETA:   0:08:21\n",
      "Averages of last 1000 rewards: 0.8366254627086942, ndcgs: 0.8366254627086942, dcgs: 18.30084104625539\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8389567408096971, DCG 18.484616208966955, Average Rank 16.714875441947413, ERR 0.4348727727451625\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:28:59 ETA:   0:06:54\n",
      "Averages of last 1000 rewards: 0.8450814263967066, ndcgs: 0.8450814263967066, dcgs: 18.264944078087407\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8391927709853516, DCG 18.487210547078014, Average Rank 16.71296053968383, ERR 0.4351212841715822\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:10 ETA:   0:03:52\n",
      "Averages of last 1000 rewards: 0.8338341736922092, ndcgs: 0.8338341736922092, dcgs: 18.215932741556934\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.8389487290927062, DCG 18.48188379207147, Average Rank 16.71551184622262, ERR 0.43475149257504914\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:19 ETA:   0:02:08\n",
      "Averages of last 1000 rewards: 0.838002363165565, ndcgs: 0.838002363165565, dcgs: 18.318111478302498\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 13\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 13, Average Validation: NDCG: 0.839216698569139, DCG 18.48856438061543, Average Rank 16.718902751249644, ERR 0.43525147435800354\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:25 Time:  0:41:25\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8392176384018348, DCG 18.487948451214443, Average Rank 16.716668427683178, ERR 0.43500850012791964\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:11 ETA:   0:20:42\n",
      "Averages of last 1000 rewards: 0.8351606199804403, ndcgs: 0.8351606199804403, dcgs: 18.903697922773762\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8390933481666331, DCG 18.492713203668036, Average Rank 16.721509326614377, ERR 0.4355264562904538\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:20 ETA:   0:19:56\n",
      "Averages of last 1000 rewards: 0.8399098299967547, ndcgs: 0.8399098299967547, dcgs: 18.746760757995403\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8394966225495665, DCG 18.49560872888312, Average Rank 16.718749949201445, ERR 0.435634098611897\n",
      " 30% (5998 of 19944) |#####              | Elapsed Time: 0:12:31 ETA:   0:14:46\n",
      "Averages of last 1000 rewards: 0.8403685613978591, ndcgs: 0.8403685613978591, dcgs: 18.500027744150273\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 14\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:52 Time:  0:01:52\n",
      "Epoch 14, Average Validation: NDCG: 0.8394386869217112, DCG 18.497151834537434, Average Rank 16.714468240744505, ERR 0.43580906305035727\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:39 ETA:   0:11:38\n",
      "Averages of last 1000 rewards: 0.8343614691818978, ndcgs: 0.8343614691818978, dcgs: 18.39781596587085\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8395394769981827, DCG 18.498762012683436, Average Rank 16.71153899296948, ERR 0.4356413034273602\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:47 ETA:   0:10:07\n",
      "Averages of last 1000 rewards: 0.8387290510192613, ndcgs: 0.8387290510192613, dcgs: 18.585590926979766\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8396403881073221, DCG 18.49849268246676, Average Rank 16.706668834071607, ERR 0.435684061641351\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:54 ETA:   0:09:32\n",
      "Averages of last 1000 rewards: 0.8340266812444539, ndcgs: 0.8340266812444539, dcgs: 17.90036455704676\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8393846667686137, DCG 18.48974259639609, Average Rank 16.705604909172187, ERR 0.4351620317076373\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:29:01 ETA:   0:07:48\n",
      "Averages of last 1000 rewards: 0.8406496775336013, ndcgs: 0.8406496775336013, dcgs: 17.881911618525532\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8396372177464984, DCG 18.497030419148153, Average Rank 16.701784045190394, ERR 0.4354127502072628\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:33:07 ETA:   0:04:22\n",
      "Averages of last 1000 rewards: 0.8411403666550373, ndcgs: 0.8411403666550373, dcgs: 18.4370241577113\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8397853972038709, DCG 18.502752268253936, Average Rank 16.70713130410046, ERR 0.4360261248162295\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:16 ETA:   0:02:51\n",
      "Averages of last 1000 rewards: 0.8444940843663117, ndcgs: 0.8444940843663117, dcgs: 18.45523242283369\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 14\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 14, Average Validation: NDCG: 0.8398249117584728, DCG 18.50313990296303, Average Rank 16.707057341406916, ERR 0.4360218619835337\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:22 Time:  0:41:22\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.839817859097442, DCG 18.499346973493818, Average Rank 16.704607631974643, ERR 0.4359204542298242\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:06 ETA:   0:25:43\n",
      "Averages of last 1000 rewards: 0.8408194155195896, ndcgs: 0.8408194155195896, dcgs: 18.20586970974756\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.8399078050537018, DCG 18.50358214590223, Average Rank 16.702653716422155, ERR 0.43604946286827656\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:16 ETA:   0:20:51\n",
      "Averages of last 1000 rewards: 0.8387601549718089, ndcgs: 0.8387601549718089, dcgs: 18.02480393245702\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 15, Average Validation: NDCG: 0.839468163460361, DCG 18.498793103989616, Average Rank 16.705982037631568, ERR 0.43559521365696696\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:23 ETA:   0:15:54\n",
      "Averages of last 1000 rewards: 0.8368299861857119, ndcgs: 0.8368299861857119, dcgs: 18.4552433987168\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.8402124421969541, DCG 18.50968615539232, Average Rank 16.704348356158818, ERR 0.43643257628879645\n",
      " 40% (7997 of 19944) |#######            | Elapsed Time: 0:16:34 ETA:   0:10:39\n",
      "Averages of last 1000 rewards: 0.8398556095936115, ndcgs: 0.8398556095936115, dcgs: 19.175578859765963\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 15, Average Validation: NDCG: 0.8398017686758038, DCG 18.507982842760246, Average Rank 16.70307310927785, ERR 0.43623728271009365\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:41 ETA:   0:11:50\n",
      "Averages of last 1000 rewards: 0.8408298974676156, ndcgs: 0.8408298974676156, dcgs: 18.183098937002892\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.8399754354797652, DCG 18.506202769760442, Average Rank 16.70295525663429, ERR 0.4360264362736182\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:48 ETA:   0:09:13\n",
      "Averages of last 1000 rewards: 0.850331641565267, ndcgs: 0.850331641565267, dcgs: 19.01762410884231\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.8400029929198629, DCG 18.506892268477444, Average Rank 16.703079611492665, ERR 0.43625318920616146\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:28:52 ETA:   0:07:41\n",
      "Averages of last 1000 rewards: 0.8429456916754171, ndcgs: 0.8429456916754171, dcgs: 18.350632874625305\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 15, Average Validation: NDCG: 0.8401336170421477, DCG 18.509988175742926, Average Rank 16.70468078189133, ERR 0.43630410669786646\n",
      " 80% (15998 of 19944) |##############    | Elapsed Time: 0:32:57 ETA:   0:05:12\n",
      "Averages of last 1000 rewards: 0.8343551344487766, ndcgs: 0.8343551344487766, dcgs: 18.788447010329076\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 15, Average Validation: NDCG: 0.8398828290800819, DCG 18.504961419849156, Average Rank 16.700940382817898, ERR 0.4360458702461897\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:03 ETA:   0:02:15\n",
      "Averages of last 1000 rewards: 0.8392378405255252, ndcgs: 0.8392378405255252, dcgs: 18.67745837360027\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 15\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 15, Average Validation: NDCG: 0.8400814824723605, DCG 18.50820612098877, Average Rank 16.70245214776283, ERR 0.4363100411043992\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:07 Time:  0:41:07\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.8400397785651755, DCG 18.509551552457456, Average Rank 16.696540008940545, ERR 0.4362397845870205\n",
      " 10% (1999 of 19944) |#                  | Elapsed Time: 0:04:09 ETA:   0:23:48\n",
      "Averages of last 1000 rewards: 0.842845678263081, ndcgs: 0.842845678263081, dcgs: 19.133891837518277\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 16\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.840254588312405, DCG 18.508812347468023, Average Rank 16.69814036656236, ERR 0.43624614399659406\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:18 ETA:   0:25:34\n",
      "Averages of last 1000 rewards: 0.834767498303282, ndcgs: 0.834767498303282, dcgs: 19.013376800823753\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.840154827510387, DCG 18.514114246381965, Average Rank 16.704605193644085, ERR 0.43662045707069497\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:26 ETA:   0:16:56\n",
      "Averages of last 1000 rewards: 0.846486005746549, ndcgs: 0.846486005746549, dcgs: 18.971723053740718\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 16, Average Validation: NDCG: 0.8404021223230553, DCG 18.50980165599576, Average Rank 16.697635632137196, ERR 0.43647483852467267\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:30 ETA:   0:13:05\n",
      "Averages of last 1000 rewards: 0.8356763264504141, ndcgs: 0.8356763264504141, dcgs: 18.322386772263375\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 16, Average Validation: NDCG: 0.840656231457492, DCG 18.51615379778323, Average Rank 16.69889299792742, ERR 0.436764537396793\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:20:34 ETA:   0:12:21\n",
      "Averages of last 1000 rewards: 0.8304357542557376, ndcgs: 0.8304357542557376, dcgs: 18.386517030187356\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 16, Average Validation: NDCG: 0.8402594267336145, DCG 18.511887664627242, Average Rank 16.70239444060633, ERR 0.43644502613733077\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:41 ETA:   0:08:14\n",
      "Averages of last 1000 rewards: 0.8437964442221761, ndcgs: 0.8437964442221761, dcgs: 18.58029154353632\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.8402236388393771, DCG 18.51614645594223, Average Rank 16.706878530499452, ERR 0.4367301315999181\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:28:45 ETA:   0:07:00\n",
      "Averages of last 1000 rewards: 0.8360596252289357, ndcgs: 0.8360596252289357, dcgs: 18.150502531293743\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 16, Average Validation: NDCG: 0.8401181828648974, DCG 18.520798786139075, Average Rank 16.703886698906814, ERR 0.43683345838398474\n",
      " 80% (15998 of 19944) |##############    | Elapsed Time: 0:32:47 ETA:   0:05:23\n",
      "Averages of last 1000 rewards: 0.8455436668333144, ndcgs: 0.8455436668333144, dcgs: 17.9141405021296\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.840534289411414, DCG 18.51771881483789, Average Rank 16.70563579469257, ERR 0.43666161233782863\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:36:50 ETA:   0:02:16\n",
      "Averages of last 1000 rewards: 0.8405957508374141, ndcgs: 0.8405957508374141, dcgs: 18.016685668242374\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 16\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 16, Average Validation: NDCG: 0.8403387925288908, DCG 18.519100308345962, Average Rank 16.70781484943309, ERR 0.4367561089470102\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:40:52 Time:  0:40:52\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8407879041341708, DCG 18.52928089259115, Average Rank 16.704989637095135, ERR 0.43762719887212836\n",
      " 10% (1998 of 19944) |#                  | Elapsed Time: 0:04:04 ETA:   0:21:05\n",
      "Averages of last 1000 rewards: 0.8321026429643198, ndcgs: 0.8321026429643198, dcgs: 18.190810956554632\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.84024395854476, DCG 18.518008545283354, Average Rank 16.70033161295566, ERR 0.4367057267459952\n",
      " 20% (4000 of 19944) |###                | Elapsed Time: 0:08:09 ETA:   0:19:23\n",
      "Averages of last 1000 rewards: 0.8353538092635215, ndcgs: 0.8353538092635215, dcgs: 17.889081298897956\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.840257829290502, DCG 18.52219507904245, Average Rank 16.705576461982364, ERR 0.43697376438040636\n",
      " 30% (5999 of 19944) |#####              | Elapsed Time: 0:12:18 ETA:   0:15:21\n",
      "Averages of last 1000 rewards: 0.8363210370885386, ndcgs: 0.8363210370885386, dcgs: 18.684503240756833\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8406633595502356, DCG 18.5254274537921, Average Rank 16.696201080993212, ERR 0.43711720758516226\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:25 ETA:   0:15:10\n",
      "Averages of last 1000 rewards: 0.8396350888028874, ndcgs: 0.8396350888028874, dcgs: 18.622699581889872\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8407373289420144, DCG 18.52839308169917, Average Rank 16.699179908156214, ERR 0.43743282850803394\n",
      " 50% (10000 of 19944) |#########         | Elapsed Time: 0:20:30 ETA:   0:11:05\n",
      "Averages of last 1000 rewards: 0.8364725032220109, ndcgs: 0.8364725032220109, dcgs: 18.988634268627184\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:55 Time:  0:01:55\n",
      "Epoch 17, Average Validation: NDCG: 0.8408303607595652, DCG 18.531920188126563, Average Rank 16.6970024789694, ERR 0.43757576646583574\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:37 ETA:   0:10:45\n",
      "Averages of last 1000 rewards: 0.8449177861478306, ndcgs: 0.8449177861478306, dcgs: 18.717768570322367\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8406335875993194, DCG 18.526877244114242, Average Rank 16.698471979518022, ERR 0.4371859946161232\n",
      " 70% (14000 of 19944) |############      | Elapsed Time: 0:28:44 ETA:   0:05:35\n",
      "Averages of last 1000 rewards: 0.833906929038211, ndcgs: 0.833906929038211, dcgs: 18.59398103983765\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8405210661030789, DCG 18.521562415062125, Average Rank 16.69159263624172, ERR 0.4369047204915026\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:32:52 ETA:   0:04:34\n",
      "Averages of last 1000 rewards: 0.8387734095486178, ndcgs: 0.8387734095486178, dcgs: 18.719233694154966\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 17\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.840599592483668, DCG 18.52342722447381, Average Rank 16.690026415247694, ERR 0.43712980235547033\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:36:55 ETA:   0:01:41\n",
      "Averages of last 1000 rewards: 0.8439985395033753, ndcgs: 0.8439985395033753, dcgs: 19.133169349816416\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 17\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 17, Average Validation: NDCG: 0.8408371442895489, DCG 18.529574184476623, Average Rank 16.69600032511074, ERR 0.43743052541794497\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:40:56 Time:  0:40:56\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8405607584869308, DCG 18.524256419811696, Average Rank 16.692083553460396, ERR 0.43692873623121076\n",
      " 10% (1998 of 19944) |#                  | Elapsed Time: 0:04:03 ETA:   0:17:13\n",
      "Averages of last 1000 rewards: 0.8359365609190342, ndcgs: 0.8359365609190342, dcgs: 17.64610334419797\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.841251272972353, DCG 18.53092796464616, Average Rank 16.688420368187913, ERR 0.43739253473344086\n",
      " 20% (3998 of 19944) |###                | Elapsed Time: 0:08:08 ETA:   0:17:01\n",
      "Averages of last 1000 rewards: 0.8373433251392746, ndcgs: 0.8373433251392746, dcgs: 18.30477172877519\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8406570230229848, DCG 18.52407031997967, Average Rank 16.685991790953793, ERR 0.4369773872219926\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:17 ETA:   0:15:39\n",
      "Averages of last 1000 rewards: 0.8386779346752375, ndcgs: 0.8386779346752375, dcgs: 18.76978510996169\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8407685226149623, DCG 18.525621437443952, Average Rank 16.686557483642865, ERR 0.437047005195987\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:24 ETA:   0:13:32\n",
      "Averages of last 1000 rewards: 0.8379568560112618, ndcgs: 0.8379568560112618, dcgs: 18.521024586907913\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8411441062065144, DCG 18.534297682776494, Average Rank 16.68977120331613, ERR 0.4377286572207705\n",
      " 50% (9997 of 19944) |#########          | Elapsed Time: 0:20:31 ETA:   0:09:30\n",
      "Averages of last 1000 rewards: 0.841283554649177, ndcgs: 0.841283554649177, dcgs: 18.565453958787298\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8408779281357457, DCG 18.526677909206267, Average Rank 16.68255943430731, ERR 0.43712448172007523\n",
      " 60% (11999 of 19944) |##########        | Elapsed Time: 0:24:35 ETA:   0:11:15\n",
      "Averages of last 1000 rewards: 0.8384280907335699, ndcgs: 0.8384280907335699, dcgs: 18.480379593124933\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8410617200695644, DCG 18.52792971859916, Average Rank 16.680530743284432, ERR 0.43717894013085257\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:28:41 ETA:   0:05:57\n",
      "Averages of last 1000 rewards: 0.8367157951227256, ndcgs: 0.8367157951227256, dcgs: 18.434222136043093\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8409921184273202, DCG 18.527134007634135, Average Rank 16.679817125208274, ERR 0.43705446830188344\n",
      " 80% (15998 of 19944) |##############    | Elapsed Time: 0:32:47 ETA:   0:04:45\n",
      "Averages of last 1000 rewards: 0.8357650611715665, ndcgs: 0.8357650611715665, dcgs: 18.476515692509672\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8407567766702183, DCG 18.5317932318047, Average Rank 16.68172227414963, ERR 0.4375153733234504\n",
      " 90% (17999 of 19944) |################  | Elapsed Time: 0:36:54 ETA:   0:01:52\n",
      "Averages of last 1000 rewards: 0.840690494697401, ndcgs: 0.840690494697401, dcgs: 18.127847549530824\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 18\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 18, Average Validation: NDCG: 0.8412934948007186, DCG 18.53403820572364, Average Rank 16.679613930995245, ERR 0.43754523283251806\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:40:52 Time:  0:40:52\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8410763772445328, DCG 18.53489645285922, Average Rank 16.68044458893811, ERR 0.4375898163834714\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:02 ETA:   0:22:11\n",
      "Averages of last 1000 rewards: 0.8435603423975591, ndcgs: 0.8435603423975591, dcgs: 18.524635062712385\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8410794933696555, DCG 18.529061312165148, Average Rank 16.67784857967245, ERR 0.4371152239626713\n",
      " 20% (3999 of 19944) |###                | Elapsed Time: 0:08:11 ETA:   0:17:45\n",
      "Averages of last 1000 rewards: 0.8391738963713924, ndcgs: 0.8391738963713924, dcgs: 18.813388019545748\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8408866621350984, DCG 18.530894570094496, Average Rank 16.673119031169993, ERR 0.43734030605931207\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:14 ETA:   0:20:02\n",
      "Averages of last 1000 rewards: 0.84258406054826, ndcgs: 0.84258406054826, dcgs: 18.48077894373907\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.841077707872006, DCG 18.535839462208745, Average Rank 16.681499573292154, ERR 0.4376580124539956\n",
      " 40% (8000 of 19944) |#######            | Elapsed Time: 0:16:24 ETA:   0:10:45\n",
      "Averages of last 1000 rewards: 0.8378509201929522, ndcgs: 0.8378509201929522, dcgs: 18.698265950238433\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:53 Time:  0:01:53\n",
      "Epoch 19, Average Validation: NDCG: 0.8412641994434682, DCG 18.537512278024046, Average Rank 16.679882147356444, ERR 0.4376496903730985\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:20:28 ETA:   0:11:49\n",
      "Averages of last 1000 rewards: 0.838985075252249, ndcgs: 0.838985075252249, dcgs: 18.464408275296492\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8410658114703901, DCG 18.53264553155154, Average Rank 16.68204006989881, ERR 0.4374876219800623\n",
      " 60% (11997 of 19944) |##########        | Elapsed Time: 0:24:30 ETA:   0:06:38\n",
      "Averages of last 1000 rewards: 0.8343233646101269, ndcgs: 0.8343233646101269, dcgs: 17.7921364270996\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8413149765160512, DCG 18.538454443403687, Average Rank 16.682692729711057, ERR 0.4375981440498399\n",
      " 70% (13998 of 19944) |############      | Elapsed Time: 0:28:35 ETA:   0:05:49\n",
      "Averages of last 1000 rewards: 0.8420390436601491, ndcgs: 0.8420390436601491, dcgs: 18.263241538661507\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 19\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8414310708315886, DCG 18.538614059105623, Average Rank 16.681741780794084, ERR 0.43788951175598056\n",
      " 80% (16000 of 19944) |##############    | Elapsed Time: 0:32:40 ETA:   0:03:33\n",
      "Averages of last 1000 rewards: 0.8408480530378831, ndcgs: 0.8408480530378831, dcgs: 18.927373457758083\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8411654103302317, DCG 18.539492746197233, Average Rank 16.67694883569716, ERR 0.4379445347129606\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:36:45 ETA:   0:01:57\n",
      "Averages of last 1000 rewards: 0.836656843068518, ndcgs: 0.836656843068518, dcgs: 18.517617951999767\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 19\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:54 Time:  0:01:54\n",
      "Epoch 19, Average Validation: NDCG: 0.8411988733854278, DCG 18.540871521806917, Average Rank 16.67999918722315, ERR 0.43790566379512535\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:40:44 Time:  0:40:44\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:55 Time:  0:01:55\n",
      "Epoch 19, Average Validation: NDCG: 0.8410497298994656, DCG 18.535108401231955, Average Rank 16.68302840655098, ERR 0.4376041565716984\n"
     ]
    }
   ],
   "source": [
    "! python train_yahoo_dataset.py --model Linear --lindf 0.0 --lr 0.00005"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading data from pickle files: yahoo/train.pkl, yahoo/test.pkl\n",
      "Model initialized with 128 hidden layer size, Dropout=0.0, using concat_avg pooling\n",
      "lr5e-05_lrdecay_0.0_l2_0.0_D_128\n",
      "Starting training with the following config\n",
      "Learning rate 5e-05, Weight decay 0.0, Sample size 10\n",
      "Lambda_reward: 1.0, lambda_ind_fairness:0.0, lambda_group_fairness:0.0\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:39 Time:  0:01:39\n",
      "Epoch 0, Average Validation: NDCG: 0.7310390709758415, DCG 15.506312860117877, Average Rank 17.81409517616938, ERR 0.281159061831588\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:01 ETA:   0:18:47\n",
      "Averages of last 1000 rewards: 0.8078883498047469, ndcgs: 0.8078883498047469, dcgs: 18.460884823617263\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:42 Time:  0:01:42\n",
      "Epoch 0, Average Validation: NDCG: 0.8155455327758382, DCG 17.90472526302643, Average Rank 17.075386678587392, ERR 0.4021972598969387\n",
      " 20% (3998 of 19944) |###                | Elapsed Time: 0:08:08 ETA:   0:19:16\n",
      "Averages of last 1000 rewards: 0.8190569526523039, ndcgs: 0.8190569526523039, dcgs: 18.31215660046415\n",
      "Evaluating on validation set: iteration 4000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:44 Time:  0:01:44\n",
      "Epoch 0, Average Validation: NDCG: 0.8313026805625711, DCG 18.286979656206835, Average Rank 16.79267606778559, ERR 0.4233417190569732\n",
      " 30% (6000 of 19944) |#####              | Elapsed Time: 0:12:17 ETA:   0:15:15\n",
      "Averages of last 1000 rewards: 0.8357813079636083, ndcgs: 0.8357813079636083, dcgs: 19.118491397143682\n",
      "Evaluating on validation set: iteration 6000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:45 Time:  0:01:45\n",
      "Epoch 0, Average Validation: NDCG: 0.8357882175483108, DCG 18.416171198555425, Average Rank 16.778207014264233, ERR 0.43077514779414183\n",
      " 40% (7999 of 19944) |#######            | Elapsed Time: 0:16:21 ETA:   0:14:59\n",
      "Averages of last 1000 rewards: 0.8340890543077265, ndcgs: 0.8340890543077265, dcgs: 17.330283342057104\n",
      "Evaluating on validation set: iteration 8000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:45 Time:  0:01:45\n",
      "Epoch 0, Average Validation: NDCG: 0.8395923400231224, DCG 18.49394254290276, Average Rank 16.685631730808307, ERR 0.43485504912502265\n",
      " 50% (9999 of 19944) |#########          | Elapsed Time: 0:20:32 ETA:   0:13:27\n",
      "Averages of last 1000 rewards: 0.8437168783844321, ndcgs: 0.8437168783844321, dcgs: 18.864281777877753\n",
      "Evaluating on validation set: iteration 10000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:46 Time:  0:01:46\n",
      "Epoch 0, Average Validation: NDCG: 0.842007352829557, DCG 18.57331030810111, Average Rank 16.70904214247978, ERR 0.43877833186836684\n",
      " 60% (12000 of 19944) |##########        | Elapsed Time: 0:24:42 ETA:   0:10:41\n",
      "Averages of last 1000 rewards: 0.8405153759933498, ndcgs: 0.8405153759933498, dcgs: 18.624859796445126\n",
      "Evaluating on validation set: iteration 12000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:46 Time:  0:01:46\n",
      "Epoch 0, Average Validation: NDCG: 0.8438337939482873, DCG 18.62635633283259, Average Rank 16.74194822611452, ERR 0.4415501887414266\n",
      " 70% (13999 of 19944) |############      | Elapsed Time: 0:28:50 ETA:   0:07:56\n",
      "Averages of last 1000 rewards: 0.8420135938585055, ndcgs: 0.8420135938585055, dcgs: 18.491999445015566\n",
      "Evaluating on validation set: iteration 14000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:47 Time:  0:01:47\n",
      "Epoch 0, Average Validation: NDCG: 0.8437663149445433, DCG 18.585287630007535, Average Rank 16.567337749420897, ERR 0.43751730822185436\n",
      " 80% (15999 of 19944) |##############    | Elapsed Time: 0:33:00 ETA:   0:04:24\n",
      "Averages of last 1000 rewards: 0.8477406629662098, ndcgs: 0.8477406629662098, dcgs: 19.21654632470091\n",
      "Evaluating on validation set: iteration 16000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 0, Average Validation: NDCG: 0.8458643637115856, DCG 18.663984156493513, Average Rank 16.66265452919901, ERR 0.4428847064106984\n",
      " 90% (18000 of 19944) |################  | Elapsed Time: 0:37:13 ETA:   0:02:06\n",
      "Averages of last 1000 rewards: 0.8428106116622951, ndcgs: 0.8428106116622951, dcgs: 18.67197220348056\n",
      "Evaluating on validation set: iteration 18000/19944 of epoch 0\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 0, Average Validation: NDCG: 0.8465553518627554, DCG 18.676749174093647, Average Rank 16.61196488803999, ERR 0.4431824366265366\n",
      "100% (19944 of 19944) |##################| Elapsed Time: 0:41:17 Time:  0:41:17\n",
      "Training....\n",
      "N/A% (0 of 19944) |                      | Elapsed Time: 0:00:00 ETA:  --:--:--Evaluating on validation set: iteration 0/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8470749938877269, DCG 18.680392999896696, Average Rank 16.566073068639007, ERR 0.4419274876715969\n",
      " 10% (2000 of 19944) |#                  | Elapsed Time: 0:04:11 ETA:   0:19:02\n",
      "Averages of last 1000 rewards: 0.8466895021512594, ndcgs: 0.8466895021512594, dcgs: 17.580408519221457\n",
      "Evaluating on validation set: iteration 2000/19944 of epoch 1\n",
      "100% (6983 of 6983) |####################| Elapsed Time: 0:01:48 Time:  0:01:48\n",
      "Epoch 1, Average Validation: NDCG: 0.8481237787399842, DCG 18.724183780304255, Average Rank 16.60456049091722, ERR 0.4445883738623801\n",
      " 14% (2889 of 19944) |##                 | Elapsed Time: 0:07:05 ETA:   0:17:57[2.49168620e-11 1.44776094e-10 2.29299553e-06 7.86547218e-07\n",
      " 4.25776165e-07 7.97955454e-38 2.89932939e-11 6.82853340e-07\n",
      " 1.17593632e-38 4.36823279e-01 5.64856755e-13 1.17021717e-01\n",
      " 2.29340290e-39 8.52963619e-26 4.29859829e-05 9.71515647e-07\n",
      " 3.84011632e-22 5.62374201e-03 2.80259693e-45 1.84663318e-35\n",
      " 1.82168800e-43 2.17516121e-04 2.61870874e-39 2.01366589e-42\n",
      " 5.49019423e-05 5.65704190e-42 1.62040096e-33 1.30599560e-37\n",
      " 7.65256409e-05 1.22633625e-14 2.25609053e-43 2.67426437e-08\n",
      " 2.29340290e-39 2.24853473e-35 2.04390511e-04 0.00000000e+00\n",
      " 3.79505911e-22 1.96861879e-06 5.99126607e-32 3.47130269e-10\n",
      " 4.10235508e-08 3.67778382e-04 1.42776873e-04 4.39417124e-01\n",
      " 5.16339931e-08]\n",
      "                                                                               \r"
     ]
    }
   ],
   "source": [
    "! python train_yahoo_dataset.py --model NN --lindf 0.0 --lr 0.00005"
   ]
  },
  {
   "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.7.6"
  },
  "latex_envs": {
   "LaTeX_envs_menu_present": true,
   "autoclose": false,
   "autocomplete": true,
   "bibliofile": "biblio.bib",
   "cite_by": "apalike",
   "current_citInitial": 1,
   "eqLabelWithNumbers": true,
   "eqNumInitial": 1,
   "hotkeys": {
    "equation": "Ctrl-E",
    "itemize": "Ctrl-I"
   },
   "labels_anchors": false,
   "latex_user_defs": false,
   "report_style_numbering": false,
   "user_envs_cfg": false
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
