{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "316f0514",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"-1\"\n",
    "\n",
    "from model.trainer import Trainer\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d2e28869",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/cwong/miniconda3/envs/tracy/lib/python3.9/site-packages/scipy/__init__.py:146: UserWarning: A NumPy version >=1.16.5 and <1.23.0 is required for this version of SciPy (detected version 1.23.5\n",
      "  warnings.warn(f\"A NumPy version >={np_minversion} and <{np_maxversion}\"\n"
     ]
    }
   ],
   "source": [
    "from __future__ import absolute_import\n",
    "from __future__ import division\n",
    "from tqdm.notebook import tqdm\n",
    "import json\n",
    "import time\n",
    "import os\n",
    "import logging\n",
    "import numpy as np\n",
    "from model.agent import Agent\n",
    "from model.options import read_options\n",
    "from model.environment import env\n",
    "import codecs\n",
    "from collections import defaultdict\n",
    "import gc\n",
    "import resource\n",
    "import sys\n",
    "from model.baseline import ReactiveBaseline\n",
    "from scipy.special import logsumexp as lse\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch.optim import Adam, SGD, AdamW\n",
    "from copy import deepcopy\n",
    "from model.nell_eval import nell_eval\n",
    "\n",
    "def get_logger(output_dir):\n",
    "    filename=output_dir +'train'\n",
    "    from logging import getLogger, INFO, StreamHandler, FileHandler, Formatter\n",
    "    logger = getLogger(__name__)\n",
    "    logger.setLevel(INFO)\n",
    "    handler1 = StreamHandler()\n",
    "    handler1.setFormatter(Formatter(\"%(message)s\"))\n",
    "    handler2 = FileHandler(filename=f\"{filename}.log\")\n",
    "    handler2.setFormatter(Formatter(\"%(message)s\"))\n",
    "    logger.addHandler(handler1)\n",
    "    logger.addHandler(handler2)\n",
    "    return logger"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fc64eafe",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "import torch.nn.utils as utils\n",
    "from torch_scatter import scatter\n",
    "\n",
    "class node_aggregation(nn.Module):\n",
    "    def __init__(self, m, embedding_size, hidden_size, layer = 2):\n",
    "        super(node_aggregation, self).__init__()\n",
    "        \n",
    "        self.m = m\n",
    "        self.embedding_size = embedding_size\n",
    "        self.hidden_size = hidden_size\n",
    "        self.layer = layer\n",
    "        \n",
    "        self.query_encoder = nn.Linear(2*embedding_size, 2*embedding_size)\n",
    "        self.key_encoder = nn.Linear(2*embedding_size, 2*embedding_size)\n",
    "        self.value_encoder = nn.Linear(2*2*embedding_size, 2*embedding_size)\n",
    "        \n",
    "        self.mlp = nn.Sequential(nn.Linear(2*embedding_size, 2*2*embedding_size), nn.Mish(),\n",
    "                                 nn.Linear(2*2*embedding_size, 2*embedding_size))\n",
    "        self.mlp_norm = nn.LayerNorm(2*embedding_size)\n",
    "        self.norm = nn.LayerNorm(2*embedding_size)\n",
    "\n",
    "    def forward(self, H, L, T, X, Z):\n",
    "        \n",
    "        q = self.query_encoder(X[H] + Z[L])\n",
    "        k = self.key_encoder(X[T])\n",
    "        \n",
    "        v = self.value_encoder(torch.cat([X[T], Z[L]], -1))\n",
    "\n",
    "        score = (q*k).sum(-1)/np.sqrt(L.shape[-1])\n",
    "        norm = scatter(torch.exp(score), H.long(), dim = 0, reduce = 'sum')\n",
    "        norm = norm[H.long()]\n",
    "        att = torch.exp(score)/norm\n",
    "\n",
    "        x_ = scatter(v*att.unsqueeze(-1), H.long(), dim = 0, reduce = 'sum')\n",
    "        \n",
    "        x = X\n",
    "        x[:len(x_)] += x_\n",
    "        x = self.norm(x)\n",
    "        \n",
    "        x = self.mlp_norm(x + self.mlp(x))\n",
    "        return x\n",
    "    \n",
    "class relation_aggregation(nn.Module):\n",
    "    def __init__(self, m, embedding_size, hidden_size, layer = 2):\n",
    "        super(relation_aggregation, self).__init__()\n",
    "        \n",
    "        self.m = m\n",
    "        self.embedding_size = embedding_size\n",
    "        self.hidden_size = hidden_size\n",
    "        self.layer = layer\n",
    "        \n",
    "        self.node_encoder = nn.Sequential(nn.Linear(2*embedding_size, 2*embedding_size), nn.Mish(),\n",
    "                                          nn.Linear(2*embedding_size, 2*embedding_size))\n",
    "        self.mlp = nn.Sequential(nn.Linear(2*embedding_size, 2*2*embedding_size), nn.Mish(),\n",
    "                                 nn.Linear(2*2*embedding_size, 2*embedding_size))\n",
    "        self.mlp_norm = nn.LayerNorm(2*embedding_size)\n",
    "        self.norm = nn.LayerNorm(2*embedding_size)\n",
    "\n",
    "    def forward(self, H, L, T, X, Z):\n",
    "        h_x = self.node_encoder(X[H])\n",
    "        z_ = scatter(h_x, L.long(), dim = 0, reduce = 'mean')\n",
    "        \n",
    "        z = Z\n",
    "        z[:len(z_)] += z_\n",
    "        z = self.norm(z)\n",
    "        \n",
    "        z = self.mlp_norm(z + self.mlp(z))\n",
    "        return z"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "64ac7797",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "import torch.nn.utils as utils\n",
    "\n",
    "class Policy_step(nn.Module):\n",
    "    def __init__(self, m, embedding_size, hidden_size):\n",
    "        super(Policy_step, self).__init__()\n",
    "\n",
    "        self.batch_norm = nn.BatchNorm1d(m * hidden_size)\n",
    "        self.lstm_cell = nn.LSTMCell(input_size= (m * embedding_size), \n",
    "                                     hidden_size= m * hidden_size)\n",
    "        self.l1 = nn.Linear(m * embedding_size,  m * embedding_size)\n",
    "        self.l2 = nn.Linear( m * hidden_size, m * hidden_size)\n",
    "        self.l3 = nn.Linear( m * hidden_size, m * hidden_size)\n",
    "\n",
    "    def forward(self, prev_gnn, prev_action, prev_state):\n",
    "        prev_action = torch.relu(self.l1(prev_action))\n",
    "        \n",
    "        #prev_input = torch.cat([prev_gnn, prev_action], -1)\n",
    "        prev_input = prev_action\n",
    "        output, ch = self.lstm_cell(prev_input, prev_state)\n",
    "        output = torch.relu(self.l2(output))\n",
    "        ch = torch.relu(self.l3(ch))\n",
    "\n",
    "        ch = torch.cat([output.unsqueeze(0).unsqueeze(0), ch.unsqueeze(0).unsqueeze(0)], dim=1)\n",
    "\n",
    "        return output, ch\n",
    "\n",
    "class Policy_mlp(nn.Module):\n",
    "    def __init__(self, hidden_size, m, embedding_size):\n",
    "        super(Policy_mlp, self).__init__()\n",
    "\n",
    "        self.hidden_size = hidden_size\n",
    "        self.m = m\n",
    "        self.embedding_size = embedding_size\n",
    "        self.mlp_l1 = nn.Linear(m * self.hidden_size + 2 * 2* embedding_size, m * self.hidden_size, bias=True)\n",
    "        self.mlp_l2 = nn.Linear(m * self.hidden_size, (m * self.embedding_size * 2), bias=True)\n",
    "\n",
    "    def forward(self, state_query):\n",
    "        # state_query = state_query.float()\n",
    "        hidden = torch.relu(self.mlp_l1(state_query))\n",
    "        output = torch.relu(self.mlp_l2(hidden))\n",
    "        return output\n",
    "\n",
    "class Agent(nn.Module):\n",
    "\n",
    "    def __init__(self, params):\n",
    "        super(Agent, self).__init__()\n",
    "        self.action_vocab_size = len(params['relation_vocab'])\n",
    "        self.entity_vocab_size = len(params['entity_vocab'])\n",
    "        self.embedding_size = params['embedding_size']\n",
    "        self.hidden_size = params['hidden_size']\n",
    "        self.ePAD = params['entity_vocab']['PAD']\n",
    "        self.rPAD = params['relation_vocab']['PAD']\n",
    "        self.use_entity_embeddings = params['use_entity_embeddings']\n",
    "        self.train_entity_embeddings = params['train_entity_embeddings']\n",
    "        self.train_relation_embeddings = params['train_relation_embeddings']\n",
    "        self.device = params['device']\n",
    "\n",
    "        if self.use_entity_embeddings:\n",
    "            if self.train_entity_embeddings:\n",
    "                self.entity_embedding = nn.Embedding(self.entity_vocab_size, 2 * self.embedding_size)\n",
    "            else:\n",
    "                self.entity_embedding = nn.Embedding(self.entity_vocab_size, 2 * self.embedding_size).requires_grad_(\n",
    "                    False)\n",
    "            torch.nn.init.xavier_uniform_(self.entity_embedding.weight)\n",
    "        else:\n",
    "            if self.train_entity_embeddings:\n",
    "                self.entity_embedding = nn.Embedding(self.entity_vocab_size, 2 * self.embedding_size)\n",
    "            else:\n",
    "                self.entity_embedding = nn.Embedding(self.entity_vocab_size, 2 * self.embedding_size).requires_grad_(\n",
    "                    False)\n",
    "            torch.nn.init.constant_(self.entity_embedding.weight, 0.0)\n",
    "\n",
    "        if self.train_relation_embeddings:\n",
    "            self.relation_embedding = nn.Embedding(self.action_vocab_size, 2 * self.embedding_size)\n",
    "        else:\n",
    "            self.relation_embedding = nn.Embedding(self.action_vocab_size, 2 * self.embedding_size).requires_grad_(\n",
    "                False)\n",
    "        torch.nn.init.xavier_uniform_(self.relation_embedding.weight)\n",
    "\n",
    "        # self.relation_embedding = params['pretrained_embeddings_relation']\n",
    "\n",
    "        # self.train_entities = params['train_entity_embeddings']\n",
    "        # self.train_relations = params['train_relation_embeddings']\n",
    "\n",
    "        self.num_rollouts = params['num_rollouts']\n",
    "        self.test_rollouts = params['test_rollouts']\n",
    "        self.LSTM_Layers = params['LSTM_layers']\n",
    "        self.batch_size = params['batch_size'] * params['num_rollouts']\n",
    "        self.dummy_start_label = (torch.ones(self.batch_size) * params['relation_vocab']['DUMMY_START_RELATION']).long()\n",
    "        # print(self.dummy_start_label.size())\n",
    "        self.entity_embedding_size = self.embedding_size\n",
    "        self.initial_gnn_state = nn.Parameter(torch.zeros((1, self.embedding_size*2*2)))\n",
    "        torch.nn.init.xavier_uniform_(self.initial_gnn_state)\n",
    "\n",
    "        if self.use_entity_embeddings:\n",
    "            self.m = 4\n",
    "        else:\n",
    "            self.m = 2\n",
    "\n",
    "        self.policy_step = Policy_step(m=self.m, embedding_size=self.embedding_size, hidden_size=self.hidden_size).to(self.device)\n",
    "        self.policy_mlp = Policy_mlp(self.hidden_size, self.m, self.embedding_size).to(self.device)\n",
    "        \n",
    "        self.node_conv = nn.ModuleList()\n",
    "        self.rel_conv = nn.ModuleList()\n",
    "        for i in range(1):\n",
    "            self.node_conv.append(node_aggregation(m=self.m, \n",
    "                                                   embedding_size=self.embedding_size, \n",
    "                                                   hidden_size=self.hidden_size).to(self.device))\n",
    "            self.rel_conv.append(relation_aggregation(m=self.m, \n",
    "                                                      embedding_size=self.embedding_size, \n",
    "                                                      hidden_size=self.hidden_size).to(self.device))\n",
    "        \n",
    "        self.gate1_linear = nn.Linear(2*self.hidden_size, 3*2*self.hidden_size)\n",
    "        self.gate2_linear = nn.Linear(2*self.hidden_size, 3*2*self.hidden_size)\n",
    "        \n",
    "        self.state_encoder = nn.Sequential(nn.Linear(self.m*self.hidden_size*2 + self.embedding_size*2,\n",
    "                                           self.embedding_size*2*2), nn.Mish(), \n",
    "                                           nn.LayerNorm(self.embedding_size*2*2))\n",
    "\n",
    "\n",
    "    def get_mem_shape(self):\n",
    "        return (self.LSTM_Layers, 2, None, self.m * self.hidden_size)\n",
    "\n",
    "\n",
    "    def action_encoder(self, next_relations, next_entities):\n",
    "        # relation_embedding = self.relation_embedding[next_relations.cpu().numpy()]\n",
    "        # entity_embedding = self.entity_embedding[next_entities.cpu().numpy()]\n",
    "        relation_embedding = self.rel_embed[next_relations]\n",
    "        entity_embedding = self.ent_embed[next_entities]\n",
    "\n",
    "        if self.use_entity_embeddings:\n",
    "            action_embedding = torch.cat([relation_embedding, entity_embedding], dim=-1)\n",
    "        else:\n",
    "            action_embedding = relation_embedding\n",
    "\n",
    "        return action_embedding\n",
    "    \n",
    "    def neighbour_aggregation(self, query_relation, prev_state, next_neighbors):\n",
    "        link = next_neighbors[:, :, :, 1]\n",
    "        tail = next_neighbors[:, :, :, 0]\n",
    "        mask = (link != 0).float()\n",
    "\n",
    "        t_embed = self.entity_embedding(tail)\n",
    "        r_embed = self.relation_embedding(link)\n",
    "\n",
    "        lstm_state = torch.cat([prev_state[0], prev_state[1]], -1)\n",
    "        query_embedding = self.relation_embedding(query_relation.long())\n",
    "        state = self.state_encoder(torch.cat([lstm_state, query_embedding], -1))\n",
    "        neighbor_embedding = torch.cat([t_embed, r_embed], -1)\n",
    "\n",
    "        att = (state.unsqueeze(1).unsqueeze(1)*neighbor_embedding).sum(-1)/np.sqrt(state.shape[-1])\n",
    "        att = F.softmax(att - (1 - mask)*1e8, 2)\n",
    "        update_embedding = (neighbor_embedding*att.unsqueeze(-1)).sum(2)\n",
    "        return update_embedding\n",
    "\n",
    "    def step(self, next_relations, next_entities, prev_state, prev_relation, query_embedding, current_entities,\n",
    "             head, link, tail, next_neighbors, prev_gnn_state):\n",
    "        \n",
    "        n_ent = len(self.entity_embedding.weight)\n",
    "        n_rel = len(self.relation_embedding.weight)\n",
    "\n",
    "        self.ent_embed = self.entity_embedding(torch.arange(n_ent).to(head.device))\n",
    "        self.rel_embed = self.relation_embedding(torch.arange(n_rel).to(link.device))\n",
    "\n",
    "        for i in range(1):\n",
    "            self.ent_embed = self.node_conv[i](head, link, tail, \n",
    "                                                    self.ent_embed, self.rel_embed)\n",
    "            self.rel_embed = self.rel_conv[i](head, link, tail, \n",
    "                                                    self.ent_embed, self.rel_embed)\n",
    "\n",
    "        prev_action_embedding = self.action_encoder(prev_relation, current_entities) # (original batch_size * num_rollout, 4*self.embedding_size)\n",
    "\n",
    "        prev_state = torch.unbind(prev_state, dim=1)\n",
    "        prev_state = [prev_state[0].squeeze(0), prev_state[1].squeeze(0)]\n",
    "\n",
    "        new_prev_state = list()\n",
    "\n",
    "        output, new_state = self.policy_step(prev_gnn_state, prev_action_embedding, prev_state)\n",
    "\n",
    "        prev_entity = self.ent_embed[current_entities]\n",
    "        if self.use_entity_embeddings:\n",
    "            state = torch.cat([output, prev_entity], dim=-1)\n",
    "        else:\n",
    "            state = output\n",
    "\n",
    "        candidate_action_embeddings = self.action_encoder(next_relations, next_entities)\n",
    "        gnn_embedding = self.neighbour_aggregation(query_embedding, prev_state, next_neighbors)\n",
    "        candidate_action_embeddings = torch.cat([candidate_action_embeddings, gnn_embedding], -1)\n",
    "\n",
    "        query_embedding = self.rel_embed[query_embedding]\n",
    "        state_query_concat = torch.cat([state, query_embedding], dim=-1)\n",
    "\n",
    "        # MLP for policy#\n",
    "\n",
    "        output = self.policy_mlp(state_query_concat)\n",
    "        # print(output.size())\n",
    "        output_expanded = torch.unsqueeze(output, dim=1)  # [original batch_size * num_rollout, 1, 2D], D=self.hidden_size\n",
    "        # print(output_expanded.size(), candidate_action_embeddings.size())\n",
    "        prelim_scores = torch.sum(candidate_action_embeddings * output_expanded, dim=2)\n",
    "\n",
    "        # Masking PAD actions\n",
    "\n",
    "        comparison_tensor = torch.ones_like(next_relations).int() * self.rPAD  # matrix to compare\n",
    "        mask = next_relations == comparison_tensor  # The mask\n",
    "        dummy_scores = torch.ones_like(prelim_scores) * -99999.0  # the base matrix to choose from if dummy relation\n",
    "        scores = torch.where(mask, dummy_scores, prelim_scores)  # [original batch_size * num_rollout, max_num_actions]\n",
    "\n",
    "        # 4 sample action\n",
    "        action = torch.distributions.categorical.Categorical(logits=scores) # [original batch_size * num_rollout, 1]\n",
    "        label_action = action.sample() # [original batch_size * num_rollout,]\n",
    "\n",
    "        # loss\n",
    "        # 5a.\n",
    "        loss = torch.nn.CrossEntropyLoss(reduce=False)(scores, label_action)\n",
    "\n",
    "        # 6. Map back to true id\n",
    "        chosen_relation = next_relations[torch.arange(len(label_action)), label_action]\n",
    "\n",
    "        return loss, new_state, F.log_softmax(scores), label_action, chosen_relation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a5a4c2e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import absolute_import\n",
    "from __future__ import division\n",
    "from tqdm import tqdm\n",
    "import json\n",
    "import time\n",
    "import os\n",
    "import logging\n",
    "import numpy as np\n",
    "import sys\n",
    "sys.path.append('./code')\n",
    "\n",
    "#from model.agent import Agent\n",
    "from model.options import read_options\n",
    "from model.environment import env\n",
    "import codecs\n",
    "from collections import defaultdict\n",
    "import gc\n",
    "import resource\n",
    "import sys\n",
    "from model.baseline import ReactiveBaseline\n",
    "from scipy.special import logsumexp as lse\n",
    "import torch\n",
    "import torch.optim as optim\n",
    "from model.nell_eval import nell_eval\n",
    "\n",
    "logger = logging.getLogger()\n",
    "logging.basicConfig(stream=sys.stdout, level=logging.DEBUG)\n",
    "\n",
    "\n",
    "class Trainer(object):\n",
    "    def __init__(self, params):\n",
    "\n",
    "        # transfer parameters to self\n",
    "        for key, val in params.items(): setattr(self, key, val);\n",
    "        self.device = params['device']\n",
    "        print(self.device)\n",
    "        self.agent = Agent(params).to(self.device)\n",
    "        #self.c_agent = ClusterAgent(params).to(self.device)\n",
    "        self.model_dir = params['model_dir']\n",
    "        self.save_path = self.model_dir + \"model\" + '.ckpt'\n",
    "        self.train_environment = env(params, 'train')\n",
    "        self.dev_test_environment = env(params, 'dev')\n",
    "        self.test_test_environment = env(params, 'test')\n",
    "        self.test_environment = self.dev_test_environment\n",
    "        self.rev_relation_vocab = self.train_environment.grapher.rev_relation_vocab\n",
    "        self.rev_entity_vocab = self.train_environment.grapher.rev_entity_vocab\n",
    "        #self.rev_cluster_relation_vocab = self.train_environment.cluster_grapher.rev_cluster_relation_vocab\n",
    "        #self.rev_cluster_vocab = self.train_environment.cluster_grapher.rev_cluster_vocab\n",
    "\n",
    "        self.max_hits_at_10 = 0\n",
    "        self.ePAD = self.entity_vocab['PAD']\n",
    "        self.rPAD = self.relation_vocab['PAD']\n",
    "        self.decaying_beta_init = self.beta\n",
    "        # optimize\n",
    "        self.baseline = ReactiveBaseline(params, self.Lambda)\n",
    "\n",
    "        self.decay_batch = None\n",
    "        self.gamma = params['gamma']\n",
    "        self.grad_clip_norm = params['grad_clip_norm']\n",
    "        self.eval_every = params['eval_every']\n",
    "        self.total_iterations = params['total_iterations']\n",
    "        self.learning_rate = params['learning_rate']\n",
    "        self.pool = params['pool']\n",
    "        self.output_dir = params['output_dir']\n",
    "        self.params = params\n",
    "        \n",
    "        self.positive_reward_rates = []\n",
    "        self.optimizer = optim.Adam(list(self.agent.parameters()),\n",
    "                                    lr=self.learning_rate)\n",
    "        self.two_embeds_sim_criterion = torch.nn.KLDivLoss()\n",
    "\n",
    "    def calc_reinforce_loss(self, all_loss, all_logits, cum_discounted_reward, decaying_beta, baseline):\n",
    "\n",
    "        loss = torch.stack(all_loss, dim=1)  # [original batch_size * num_rollout, T]\n",
    "        base_value = baseline.get_baseline_value()\n",
    "\n",
    "        # multiply with rewards\n",
    "        final_reward = cum_discounted_reward - base_value\n",
    "        reward_mean = torch.mean(final_reward)\n",
    "\n",
    "        # Constant added for numerical stability\n",
    "        reward_std = torch.std(final_reward) + 1e-6\n",
    "        final_reward = torch.div(final_reward - reward_mean, reward_std)\n",
    "\n",
    "        loss = torch.mul(loss, final_reward)  # [original batch_size * num_rollout, T]\n",
    "\n",
    "        entropy_loss = decaying_beta * self.entropy_reg_loss(all_logits)\n",
    "\n",
    "        total_loss = torch.mean(loss) - entropy_loss  # scalar\n",
    "\n",
    "        return total_loss\n",
    "    \n",
    "    def entropy_reg_loss(self, all_logits):  # control diversity\n",
    "        all_logits = torch.stack(all_logits, dim=2)  # [original batch_size * num_rollout, max_num_actions, T]\n",
    "        entropy_loss = - torch.mean(torch.sum(torch.mul(torch.exp(all_logits), all_logits), dim=1))  # scalar\n",
    "        return entropy_loss\n",
    "\n",
    "    def calc_cum_discounted_reward(self, rewards):\n",
    "\n",
    "        running_add = torch.zeros([rewards.size(0)]).to(self.device)  # [original batch_size * num_rollout]\n",
    "        cum_disc_reward = torch.zeros([rewards.size(0), self.path_length]).to(\n",
    "            self.device)  # [original batch_size * num_rollout, T]\n",
    "        cum_disc_reward[:,\n",
    "        self.path_length - 1] = rewards  # set the last time step to the reward received at the last state\n",
    "        for t in reversed(range(self.path_length)):\n",
    "            running_add = self.gamma * running_add + cum_disc_reward[:, t]\n",
    "            cum_disc_reward[:, t] = running_add\n",
    "        return cum_disc_reward\n",
    "\n",
    "    def calc_cum_discounted_reward_credit(self, entity_rewards):\n",
    "\n",
    "        num_instances = entity_rewards.size(0)\n",
    "        running_add = torch.zeros([num_instances]).to(self.device)  # [original batch_size * num_rollout]\n",
    "        cum_disc_reward = torch.zeros([num_instances, self.path_length]).to(\n",
    "            self.device)  # [original batch_size * num_rollout, T]\n",
    "        cum_disc_reward[:,\n",
    "        self.path_length - 1] = entity_rewards  # set the last time step to the reward received at the last state\n",
    "\n",
    "        for t in reversed(range(1, self.path_length)):\n",
    "            running_add = self.gamma * running_add + cum_disc_reward[:, t] # approx_credits[t].to(self.device) * cluster_rewards\n",
    "            cum_disc_reward[:, t-1] = running_add\n",
    "\n",
    "        return cum_disc_reward\n",
    "\n",
    "    def get_graph(self, entity_episode, mode = 'train'):\n",
    "        if mode == 'train':\n",
    "            graph = deepcopy(self.train_environment.grapher)\n",
    "        else:\n",
    "            graph = deepcopy(self.test_environment.grapher)\n",
    "        \n",
    "        if mode == 'train':\n",
    "            ent_match = graph.array_store[entity_episode.start_entities,:,0] == np.expand_dims(entity_episode.end_entities, -1)\n",
    "            rel_match = graph.array_store[entity_episode.start_entities,:,1] == np.expand_dims(entity_episode.query_relation, -1)\n",
    "\n",
    "            tmp = graph.array_store[entity_episode.start_entities, :, :]\n",
    "            tmp[rel_match&ent_match] = 0\n",
    "            graph.array_store[entity_episode.start_entities, :, :] = tmp\n",
    "\n",
    "        head = torch.repeat_interleave(torch.arange(len(graph.rev_entity_vocab)), self.params['max_num_actions'])\n",
    "        tail = torch.LongTensor(graph.array_store[:, :, 0].reshape(-1))\n",
    "        link = torch.LongTensor(graph.array_store[:, :, 1].reshape(-1))\n",
    "\n",
    "        head = head[(link > 0)].to(self.device)\n",
    "        tail = tail[(link > 0)].to(self.device)\n",
    "        link = link[(link > 0)].to(self.device)\n",
    "        return head, link, tail\n",
    "    \n",
    "    def train(self):\n",
    "        train_loss = []\n",
    "        train_reward = []\n",
    "\n",
    "        start_time = time.time()\n",
    "        self.batch_counter = 0\n",
    "        current_decay = self.decaying_beta_init\n",
    "        current_decay_count = 0\n",
    "\n",
    "        print('Agent start learning ...')\n",
    "        for entity_episode in self.train_environment.get_episodes():\n",
    "\n",
    "            self.batch_counter += 1\n",
    "\n",
    "            current_decay_count += 1\n",
    "            if current_decay_count == self.decay_batch:\n",
    "                current_decay *= self.decay_rate\n",
    "                current_decay_count = 0\n",
    "\n",
    "            # get initial state for entity agent\n",
    "            head, link, tail = self.get_graph(entity_episode, mode = 'train')\n",
    "            entity_state_emb = torch.zeros(1, 2, self.batch_size * self.num_rollouts,\n",
    "                                           self.agent.m * self.hidden_size).to(self.device)\n",
    "            entity_state = entity_episode.get_state()\n",
    "            next_possible_relations = torch.tensor(entity_state['next_relations']).long().to(\n",
    "                self.device)  # original batch_size * num_rollout, max_num_actions\n",
    "            next_possible_entities = torch.tensor(entity_state['next_entities']).long().to(self.device)\n",
    "\n",
    "            # range_arr = torch.arange(self.batch_size * self.num_rollouts).to(self.device)\n",
    "            prev_relation = self.agent.dummy_start_label.to(self.device)  # original batch_size * num_rollout, 1-D, (1...)\n",
    "\n",
    "            query_relation = entity_episode.get_query_relation()\n",
    "            query_relation = torch.tensor(query_relation).long().to(self.device)\n",
    "            current_entities = torch.tensor(entity_state['current_entities']).long().to(self.device)\n",
    "            prev_gnn_state = self.agent.initial_gnn_state.repeat(len(current_entities), 1)\n",
    "            #prev_entities = current_entities.clone()\n",
    "\n",
    "            all_losses = []\n",
    "            all_logits = []\n",
    "            all_action_id = []\n",
    "            path = [current_entities]\n",
    "\n",
    "            for i in range(self.path_length):\n",
    "                next_neighbors = deepcopy(self.train_environment.grapher.array_store)\n",
    "                in_sample = next_neighbors[entity_episode.start_entities]\n",
    "                end_match = in_sample[:, :, 0] == np.expand_dims(entity_episode.end_entities, -1)\n",
    "                rel_match = in_sample[:, :, 1] == np.expand_dims(entity_episode.query_relation, -1)\n",
    "                in_sample[end_match&rel_match] = 0\n",
    "                next_neighbors[entity_episode.start_entities] = in_sample\n",
    "\n",
    "                next_neighbors = next_neighbors[next_possible_entities.cpu().numpy()]\n",
    "                next_neighbors = torch.LongTensor(next_neighbors).to(current_entities.device)\n",
    "\n",
    "                loss, entity_state_emb, logits, idx, chosen_relation = self.agent.step(\n",
    "                    next_possible_relations,\n",
    "                    next_possible_entities, entity_state_emb,\n",
    "                    prev_relation, query_relation,\n",
    "                    current_entities,\n",
    "                    head, link, tail,\n",
    "                    next_neighbors, prev_gnn_state\n",
    "                )\n",
    "\n",
    "                entity_state = entity_episode(idx.cpu())\n",
    "                next_possible_relations = torch.tensor(entity_state['next_relations']).long().to(self.device)\n",
    "                next_possible_entities = torch.tensor(entity_state['next_entities']).long().to(self.device)\n",
    "                current_entities = torch.tensor(entity_state['current_entities']).long().to(self.device)\n",
    "                prev_relation = chosen_relation.to(self.device)\n",
    "\n",
    "                all_losses.append(loss)\n",
    "                all_logits.append(logits)\n",
    "                all_action_id.append(idx)\n",
    "                path.append(current_entities)\n",
    "\n",
    "            rewards = entity_episode.get_reward()\n",
    "            rewards = torch.tensor(rewards).to(self.device)\n",
    "\n",
    "            cum_discounted_reward = self.calc_cum_discounted_reward(rewards)\n",
    "            reinforce_loss = self.calc_reinforce_loss(all_losses, all_logits, cum_discounted_reward,\n",
    "                                                        current_decay, self.baseline)\n",
    "\n",
    "            self.baseline.update(torch.mean(cum_discounted_reward))\n",
    "\n",
    "            self.optimizer.zero_grad()\n",
    "            reinforce_loss.backward()\n",
    "            torch.nn.utils.clip_grad_norm_(self.agent.parameters(), max_norm=self.grad_clip_norm, norm_type=2)\n",
    "            self.optimizer.step()\n",
    "\n",
    "            train_loss.append(reinforce_loss.detach().cpu().item())\n",
    "            train_reward.append(rewards.cpu().float().tolist())\n",
    "\n",
    "            if (self.batch_counter > 0)&(self.batch_counter % (self.eval_every//10) == 0):\n",
    "                avg_loss = np.mean(train_loss[-(self.eval_every//10):])\n",
    "                avg_reward = np.mean(sum(train_reward[-(self.eval_every//10):], []))\n",
    "                print('Iteration: {}, Train loss: {:.4f}, rewards: {:.4f}'.format(self.batch_counter, avg_loss, avg_reward))\n",
    "                gc.collect()\n",
    "\n",
    "            if (self.batch_counter > 0)&(self.batch_counter % self.eval_every == 0):\n",
    "                print('Eval:')\n",
    "                self.test(beam = True)\n",
    "                gc.collect()\n",
    "                print('------------------------------------------------------------')\n",
    "\n",
    "            if self.batch_counter > self.total_iterations:\n",
    "                break\n",
    "\n",
    "    def test(self, beam=False, print_paths=False, save_model=True):\n",
    "\n",
    "        with torch.no_grad():\n",
    "\n",
    "            batch_counter = 0\n",
    "            paths = defaultdict(list)\n",
    "            answers = []\n",
    "            all_final_reward_1 = 0\n",
    "            all_final_reward_3 = 0\n",
    "            all_final_reward_5 = 0\n",
    "            all_final_reward_10 = 0\n",
    "            all_final_reward_20 = 0\n",
    "            auc = 0\n",
    "\n",
    "            total_examples = self.test_environment.total_no_examples\n",
    "\n",
    "            for entity_episode in self.test_environment.get_episodes():\n",
    "                batch_counter += 1\n",
    "\n",
    "                temp_batch_size = entity_episode.no_examples\n",
    "\n",
    "                self.qr = entity_episode.get_query_relation()\n",
    "                query_relation = self.qr\n",
    "                query_relation = torch.tensor(query_relation).long().to(self.device)\n",
    "                # set initial beam probs\n",
    "                beam_probs = torch.zeros((temp_batch_size * self.test_rollouts, 1)).to(self.device)\n",
    "\n",
    "                # get initial state for entity agent\n",
    "                entity_state = entity_episode.get_state()\n",
    "                \n",
    "                head, link, tail = self.get_graph(entity_episode, mode = 'test')\n",
    "                next_relations = torch.tensor(entity_state['next_relations']).long().to(self.device)\n",
    "                next_entities = torch.tensor(entity_state['next_entities']).long().to(self.device)\n",
    "                current_entities = torch.tensor(entity_state['current_entities']).long().to(self.device)\n",
    "\n",
    "                entity_state_emb = torch.zeros(1, 2, temp_batch_size * self.test_rollouts,\n",
    "                                               self.agent.m * self.hidden_size).to(self.device)\n",
    "                prev_relation = (torch.ones(temp_batch_size * self.test_rollouts) * self.relation_vocab[\n",
    "                    'DUMMY_START_RELATION']).long().to(self.device)\n",
    "                prev_gnn_state = self.agent.initial_gnn_state.repeat(len(current_entities), 1)\n",
    "\n",
    "                if print_paths:\n",
    "                    self.entity_trajectory = [current_entities]\n",
    "                    self.relation_trajectory = [prev_relation]   \n",
    "\n",
    "                self.log_probs = np.zeros((temp_batch_size * self.test_rollouts,)) * 1.0\n",
    "                for i in range(self.path_length):\n",
    "                    \n",
    "                    next_neighbors = self.test_environment.grapher.array_store[next_entities.cpu().numpy()]\n",
    "                    next_neighbors = torch.LongTensor(next_neighbors).to(current_entities.device)\n",
    "                    \n",
    "                    loss, entity_state_emb, test_scores, test_action_idx, chosen_relation = self.agent.step(\n",
    "                        next_relations,\n",
    "                        next_entities, entity_state_emb,\n",
    "                        prev_relation, query_relation,\n",
    "                        current_entities,\n",
    "                        head, link, tail,\n",
    "                        next_neighbors, prev_gnn_state\n",
    "                    )\n",
    "                    \n",
    "                    #Mimic original implementation on pytorch\n",
    "                    if beam:\n",
    "                        k = self.test_rollouts\n",
    "                        beam_probs = beam_probs.to(self.device)\n",
    "                        new_scores = test_scores + beam_probs\n",
    "                        new_scores = new_scores.cpu()\n",
    "                        if i == 0:\n",
    "                            idx = np.argsort(new_scores)\n",
    "                            idx = idx[:, -k:]\n",
    "                            ranged_idx = np.tile([b for b in range(k)], temp_batch_size)\n",
    "                            idx = idx[np.arange(k * temp_batch_size), ranged_idx]\n",
    "                        else:\n",
    "                            idx = self.top_k(new_scores, k)\n",
    "\n",
    "                        y = idx // self.max_num_actions\n",
    "                        x = idx % self.max_num_actions\n",
    "\n",
    "                        y += np.repeat([b * k for b in range(temp_batch_size)], k)\n",
    "                        entity_state['current_entities'] = entity_state['current_entities'][y]\n",
    "                        entity_state['next_relations'] = entity_state['next_relations'][y, :]\n",
    "                        entity_state['next_entities'] = entity_state['next_entities'][y, :]\n",
    "                        entity_state_emb = entity_state_emb[:, :, y, :]\n",
    "\n",
    "                        test_action_idx = x\n",
    "                        chosen_relation = entity_state['next_relations'][np.arange(temp_batch_size * k), x]\n",
    "\n",
    "                        beam_probs = new_scores[y, x]\n",
    "                        beam_probs = beam_probs.reshape((-1, 1))\n",
    "\n",
    "#                     #My implementation to fit arbitrary dimension\n",
    "#                     if beam:\n",
    "#                         k = self.test_rollouts\n",
    "#                         beam_probs = beam_probs.to(self.device)\n",
    "#                         new_scores = test_scores + beam_probs\n",
    "#                         new_scores = new_scores.cpu()\n",
    "#                         if i == 0:\n",
    "#                             reshape_score = new_scores.reshape(temp_batch_size, self.test_rollouts, -1)\n",
    "#                             possible_idx = []\n",
    "#                             for x in reshape_score:\n",
    "#                                 possible_idx.append(torch.LongTensor(np.where(x[0].cpu() > -1000)[0]))\n",
    "#                             idx = []\n",
    "#                             for x in possible_idx:\n",
    "#                                 idx.append(torch.cat(([x]*(self.test_rollouts//len(x) + 1)))[:self.test_rollouts])\n",
    "#                             idx = torch.cat(idx, 0)\n",
    "#                         else:\n",
    "#                             idx = self.top_k(new_scores, k)\n",
    "\n",
    "#                         y = idx // self.max_num_actions\n",
    "#                         x = idx % self.max_num_actions\n",
    "\n",
    "#                         y += np.repeat([b * k for b in range(temp_batch_size)], k)\n",
    "#                         entity_state['current_entities'] = entity_state['current_entities'][y]\n",
    "#                         entity_state['next_relations'] = entity_state['next_relations'][y, :]\n",
    "#                         entity_state['next_entities'] = entity_state['next_entities'][y, :]\n",
    "#                         entity_state_emb = entity_state_emb[:, :, y, :]\n",
    "\n",
    "#                         test_action_idx = x\n",
    "#                         chosen_relation = entity_state['next_relations'][np.arange(temp_batch_size * k), x]\n",
    "#                         beam_probs = new_scores[y, x]\n",
    "#                         beam_probs = beam_probs.reshape((-1, 1))\n",
    "                        \n",
    "                        if print_paths:\n",
    "                            for j in range(i):\n",
    "                                self.entity_trajectory[j] = self.entity_trajectory[j][y]\n",
    "                                self.relation_trajectory[j] = self.relation_trajectory[j][y]\n",
    "\n",
    "                    entity_state = entity_episode(test_action_idx.cpu().numpy())\n",
    "                    next_relations = torch.tensor(entity_state['next_relations']).long().to(self.device)\n",
    "                    next_entities = torch.tensor(entity_state['next_entities']).long().to(self.device)\n",
    "                    current_entities = torch.tensor(entity_state['current_entities']).long().to(self.device)\n",
    "                    prev_relation = torch.tensor(chosen_relation).long().to(self.device)\n",
    "                    \n",
    "                    if print_paths:\n",
    "                        self.entity_trajectory.append(entity_state['current_entities'])\n",
    "                        self.relation_trajectory.append(chosen_relation)\n",
    "\n",
    "                    test_scores = test_scores.cpu().numpy()\n",
    "                    self.log_probs += test_scores[np.arange(self.log_probs.shape[0]), test_action_idx.cpu().numpy()]\n",
    "\n",
    "                if beam:\n",
    "                    self.log_probs = beam_probs\n",
    "\n",
    "                rewards = entity_episode.get_reward()  # [B*test_rollouts]\n",
    "                reward_reshape = np.reshape(rewards, (temp_batch_size, self.test_rollouts))  # [orig_batch, test_rollouts]\n",
    "                self.log_probs = np.reshape(self.log_probs, (temp_batch_size, self.test_rollouts))\n",
    "                sorted_indx = np.argsort(-self.log_probs)\n",
    "                final_reward_1 = 0\n",
    "                final_reward_3 = 0\n",
    "                final_reward_5 = 0\n",
    "                final_reward_10 = 0\n",
    "                final_reward_20 = 0\n",
    "                AP = 0\n",
    "                ce = entity_episode.state['current_entities'].reshape((temp_batch_size, self.test_rollouts))\n",
    "                se = entity_episode.start_entities.reshape((temp_batch_size, self.test_rollouts))\n",
    "                for b in range(temp_batch_size):\n",
    "                    answer_pos = None\n",
    "                    seen = set()\n",
    "                    pos=0\n",
    "                    if self.pool == 'max':\n",
    "                        for r in sorted_indx[b]:\n",
    "                            if reward_reshape[b,r] == self.positive_reward:\n",
    "                                answer_pos = pos\n",
    "                                break\n",
    "                            if ce[b, r] not in seen:\n",
    "                                seen.add(ce[b, r])\n",
    "                                pos += 1\n",
    "                    if self.pool == 'sum':\n",
    "                        scores = defaultdict(list)\n",
    "                        answer = ''\n",
    "                        for r in sorted_indx[b]:\n",
    "                            scores[ce[b,r]].append(self.log_probs[b,r])\n",
    "                            if reward_reshape[b,r] == self.positive_reward:\n",
    "                                answer = ce[b,r]\n",
    "                        final_scores = defaultdict(float)\n",
    "                        for e in scores:\n",
    "                            final_scores[e] = lse(scores[e])\n",
    "                        sorted_answers = sorted(final_scores, key=final_scores.get, reverse=True)\n",
    "                        if answer in  sorted_answers:\n",
    "                            answer_pos = sorted_answers.index(answer)\n",
    "                        else:\n",
    "                            answer_pos = None\n",
    "\n",
    "\n",
    "                    if answer_pos != None:\n",
    "                        if answer_pos < 20:\n",
    "                            final_reward_20 += 1\n",
    "                            if answer_pos < 10:\n",
    "                                final_reward_10 += 1\n",
    "                                if answer_pos < 5:\n",
    "                                    final_reward_5 += 1\n",
    "                                    if answer_pos < 3:\n",
    "                                        final_reward_3 += 1\n",
    "                                        if answer_pos < 1:\n",
    "                                            final_reward_1 += 1\n",
    "                    if answer_pos == None:\n",
    "                        AP += 0\n",
    "                    else:\n",
    "                        AP += 1.0/((answer_pos+1))\n",
    "                    \n",
    "                    if print_paths:\n",
    "                        qr = self.train_environment.grapher.rev_relation_vocab[self.qr[b * self.test_rollouts]]\n",
    "                        start_e = self.rev_entity_vocab[entity_episode.start_entities[b * self.test_rollouts]]\n",
    "                        end_e = self.rev_entity_vocab[entity_episode.end_entities[b * self.test_rollouts]]\n",
    "                        paths[str(qr)].append(str(start_e) + \"\\t\" + str(end_e) + \"\\n\")\n",
    "                        paths[str(qr)].append(\"Reward:\" + str(1 if answer_pos != None and answer_pos < 10 else 0) + \"\\n\")\n",
    "                        for r in sorted_indx[b]:\n",
    "                            indx = b * self.test_rollouts + r\n",
    "                            if rewards[indx] == self.positive_reward:\n",
    "                                rev = 1\n",
    "                            else:\n",
    "                                rev = -1\n",
    "                            answers.append(self.rev_entity_vocab[se[b,r]]+'\\t'+ self.rev_entity_vocab[ce[b,r]]+'\\t'+ str(self.log_probs[b,r])+'\\n')\n",
    "                            paths[str(qr)].append(\n",
    "                                '\\t'.join([str(self.rev_entity_vocab[e[indx]]) for e in\n",
    "                                           self.entity_trajectory]) + '\\n' + '\\t'.join(\n",
    "                                    [str(self.rev_relation_vocab[re[indx]]) for re in self.relation_trajectory]) + '\\n' + str(\n",
    "                                    rev) + '\\n' + str(\n",
    "                                    self.log_probs[b, r]) + '\\n___' + '\\n')\n",
    "                        paths[str(qr)].append(\"#####################\\n\")\n",
    "\n",
    "                all_final_reward_1 += final_reward_1\n",
    "                all_final_reward_3 += final_reward_3\n",
    "                all_final_reward_5 += final_reward_5\n",
    "                all_final_reward_10 += final_reward_10\n",
    "                all_final_reward_20 += final_reward_20\n",
    "                auc += AP\n",
    "\n",
    "            all_final_reward_1 /= total_examples\n",
    "            all_final_reward_3 /= total_examples\n",
    "            all_final_reward_5 /= total_examples\n",
    "            all_final_reward_10 /= total_examples\n",
    "            all_final_reward_20 /= total_examples\n",
    "            auc /= total_examples\n",
    "            \n",
    "            if save_model:\n",
    "                if all_final_reward_10 >= self.max_hits_at_10:\n",
    "                    self.max_hits_at_10 = all_final_reward_10\n",
    "                    torch.save(self.agent.state_dict(), self.model_dir + \"agent\" + '.ckpt')\n",
    "                    # self.save_path = self.model_dir + \"model\" + '.ckpt'\n",
    "\n",
    "            if print_paths:\n",
    "                logger.info(\"[ printing paths at {} ]\".format(self.output_dir + '/test_beam/'))\n",
    "                for q in paths:\n",
    "                    j = q.replace('/', '-')\n",
    "                    with codecs.open(self.path_logger_file_ + '_' + j, 'a', 'utf-8') as pos_file:\n",
    "                        for p in paths[q]:\n",
    "                            pos_file.write(p)\n",
    "                with open(self.path_logger_file_ + 'answers', 'w') as answer_file:\n",
    "                    for a in answers:\n",
    "                        answer_file.write(a)\n",
    "\n",
    "            with open(self.output_dir + '/scores.txt', 'a') as score_file:\n",
    "                score_file.write(\"Hits@1: {:.4f}\".format(all_final_reward_1))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"Hits@3: {:.4f}\".format(all_final_reward_3))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"Hits@5: {:.4f}\".format(all_final_reward_5))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"Hits@10: {:.4f}\".format(all_final_reward_10))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"Hits@20: {:.4f}\".format(all_final_reward_20))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"MRR: {:.4f}\".format(auc))\n",
    "                score_file.write(\"\\n\")\n",
    "                score_file.write(\"------------------------------------\")\n",
    "\n",
    "            print(\"Hits@1: {:.4f}, Hits@3: {:.4f}, Hits@10: {:.4f}, MRR: {:.4f}\".format(all_final_reward_1, \n",
    "                                                                                 all_final_reward_3,\n",
    "                                                                                 all_final_reward_10, auc))\n",
    "            \n",
    "    def top_k(self, scores, k):\n",
    "        scores = scores.reshape(-1, k * self.max_num_actions)  # [B, (k*max_num_actions)]\n",
    "        idx = np.argsort(scores, axis=1)\n",
    "        idx = idx[:, -k:]  # take the last k highest indices # [B , k]\n",
    "        return idx.reshape((-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8bca5f0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "options = {}\n",
    "\n",
    "#basic setting\n",
    "options['use_cuda'] = True\n",
    "options['vocab_dir'] = '../MINERVA/datasets/data_preprocessed/FB15K-237/vocab/'\n",
    "options['data_input_dir'] = '../MINERVA/datasets/data_preprocessed/FB15K-237/'\n",
    "options['device'] = 'cuda' if options['use_cuda'] else 'cpu'\n",
    "options['relation_vocab'] = json.load(open(options['vocab_dir'] + '/relation_vocab.json'))\n",
    "options['entity_vocab'] = json.load(open(options['vocab_dir'] + '/entity_vocab.json'))\n",
    "options['model_dir'] = './outputs_FB15K-237_v7-2/'\n",
    "options['output_dir'] = './outputs_FB15K-237_v7-2/'\n",
    "\n",
    "#agent setting\n",
    "options['pretrained_embeddings_relation'] = {}\n",
    "options['pretrained_embeddings_entity'] = {}\n",
    "options['embedding_size'] = 50\n",
    "options['hidden_size'] = 200\n",
    "options['use_entity_embeddings'] = 1\n",
    "options['train_entity_embeddings'] = 0\n",
    "options['train_relation_embeddings'] = 1\n",
    "options['path_length'] = 3\n",
    "options['LSTM_layers'] = 1\n",
    "options['max_num_actions'] = 100\n",
    "\n",
    "#hyperparameters\n",
    "options['test_rollouts'] = 100\n",
    "options['num_rollouts'] = 20\n",
    "options['batch_size'] = 8\n",
    "options['beta'] = 0.08\n",
    "options['Lambda'] = 0.08\n",
    "options['gamma'] = 1\n",
    "options['positive_reward'] = 1\n",
    "options['negative_reward'] = 0\n",
    "options['learning_rate'] = 1e-4\n",
    "options['grad_clip_norm'] = 100\n",
    "options['eval_every'] = 100\n",
    "options['total_iterations'] = 16000\n",
    "options['pool'] = 'max'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8dc1e4ea",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Agent start learning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/cwong/miniconda3/envs/tracy/lib/python3.9/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='none' instead.\n",
      "  warnings.warn(warning.format(ret))\n",
      "/tmp/ipykernel_3409973/1090773659.py:224: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
      "  return loss, new_state, F.log_softmax(scores), label_action, chosen_relation\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 10, Train loss: -0.3245, rewards: 0.0112\n",
      "Iteration: 20, Train loss: -0.3620, rewards: 0.0256\n",
      "Iteration: 30, Train loss: -0.3872, rewards: 0.0256\n",
      "Iteration: 40, Train loss: -0.3131, rewards: 0.0056\n",
      "Iteration: 50, Train loss: -0.3478, rewards: 0.0131\n",
      "Iteration: 60, Train loss: -0.3201, rewards: 0.0106\n",
      "Iteration: 70, Train loss: -0.3888, rewards: 0.0275\n",
      "Iteration: 80, Train loss: -0.3294, rewards: 0.0194\n",
      "Iteration: 90, Train loss: -0.3110, rewards: 0.0106\n",
      "Iteration: 100, Train loss: -0.3538, rewards: 0.0250\n",
      "Eval:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3409973/598236006.py:327: UserWarning: __floordiv__ is deprecated, and its behavior will change in a future version of pytorch. It currently rounds toward 0 (like the 'trunc' function NOT 'floor'). This results in incorrect rounding for negative values. To keep the current behavior, use torch.div(a, b, rounding_mode='trunc'), or for actual floor division, use torch.div(a, b, rounding_mode='floor').\n",
      "  y = idx // self.max_num_actions\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hits@1: 0.0072, Hits@3: 0.0231, Hits@10: 0.0648, MRR: 0.0259\n",
      "------------------------------------------------------------\n",
      "Iteration: 110, Train loss: -0.3559, rewards: 0.0156\n",
      "Iteration: 120, Train loss: -0.3558, rewards: 0.0256\n",
      "Iteration: 130, Train loss: -0.3782, rewards: 0.0238\n",
      "Iteration: 140, Train loss: -0.3289, rewards: 0.0112\n",
      "Iteration: 150, Train loss: -0.3001, rewards: 0.0050\n",
      "Iteration: 160, Train loss: -0.3325, rewards: 0.0131\n",
      "Iteration: 170, Train loss: -0.3133, rewards: 0.0094\n",
      "Iteration: 180, Train loss: -0.3768, rewards: 0.0262\n",
      "Iteration: 190, Train loss: -0.3320, rewards: 0.0200\n",
      "Iteration: 200, Train loss: -0.3309, rewards: 0.0063\n",
      "Eval:\n",
      "Hits@1: 0.0095, Hits@3: 0.0293, Hits@10: 0.0843, MRR: 0.0331\n",
      "------------------------------------------------------------\n",
      "Iteration: 210, Train loss: -0.3075, rewards: 0.0150\n",
      "Iteration: 220, Train loss: -0.3598, rewards: 0.0156\n",
      "Iteration: 230, Train loss: -0.3580, rewards: 0.0219\n",
      "Iteration: 240, Train loss: -0.4007, rewards: 0.0394\n",
      "Iteration: 250, Train loss: -0.3788, rewards: 0.0244\n",
      "Iteration: 260, Train loss: -0.3966, rewards: 0.0200\n",
      "Iteration: 270, Train loss: -0.3290, rewards: 0.0225\n",
      "Iteration: 280, Train loss: -0.4364, rewards: 0.0269\n",
      "Iteration: 290, Train loss: -0.3783, rewards: 0.0250\n",
      "Iteration: 300, Train loss: -0.4525, rewards: 0.0450\n",
      "Eval:\n",
      "Hits@1: 0.0115, Hits@3: 0.0366, Hits@10: 0.0959, MRR: 0.0394\n",
      "------------------------------------------------------------\n",
      "Iteration: 310, Train loss: -0.3857, rewards: 0.0244\n",
      "Iteration: 320, Train loss: -0.3249, rewards: 0.0106\n",
      "Iteration: 330, Train loss: -0.4378, rewards: 0.0387\n",
      "Iteration: 340, Train loss: -0.4826, rewards: 0.0569\n",
      "Iteration: 350, Train loss: -0.4022, rewards: 0.0362\n",
      "Iteration: 360, Train loss: -0.4248, rewards: 0.0450\n",
      "Iteration: 370, Train loss: -0.3744, rewards: 0.0169\n",
      "Iteration: 380, Train loss: -0.4031, rewards: 0.0450\n",
      "Iteration: 390, Train loss: -0.3739, rewards: 0.0250\n",
      "Iteration: 400, Train loss: -0.3736, rewards: 0.0250\n",
      "Eval:\n",
      "Hits@1: 0.0153, Hits@3: 0.0399, Hits@10: 0.1014, MRR: 0.0431\n",
      "------------------------------------------------------------\n",
      "Iteration: 410, Train loss: -0.3744, rewards: 0.0181\n",
      "Iteration: 420, Train loss: -0.4745, rewards: 0.0300\n",
      "Iteration: 430, Train loss: -0.3340, rewards: 0.0181\n",
      "Iteration: 440, Train loss: -0.4876, rewards: 0.0600\n",
      "Iteration: 450, Train loss: -0.3684, rewards: 0.0275\n",
      "Iteration: 460, Train loss: -0.5087, rewards: 0.0431\n",
      "Iteration: 470, Train loss: -0.4063, rewards: 0.0262\n",
      "Iteration: 480, Train loss: -0.4649, rewards: 0.0381\n",
      "Iteration: 490, Train loss: -0.3643, rewards: 0.0294\n",
      "Iteration: 500, Train loss: -0.4822, rewards: 0.0531\n",
      "Eval:\n",
      "Hits@1: 0.0167, Hits@3: 0.0456, Hits@10: 0.1135, MRR: 0.0473\n",
      "------------------------------------------------------------\n",
      "Iteration: 510, Train loss: -0.4529, rewards: 0.0425\n",
      "Iteration: 520, Train loss: -0.4757, rewards: 0.0638\n",
      "Iteration: 530, Train loss: -0.4839, rewards: 0.0544\n",
      "Iteration: 540, Train loss: -0.3988, rewards: 0.0288\n",
      "Iteration: 550, Train loss: -0.3582, rewards: 0.0238\n",
      "Iteration: 560, Train loss: -0.3617, rewards: 0.0331\n",
      "Iteration: 570, Train loss: -0.4004, rewards: 0.0306\n",
      "Iteration: 580, Train loss: -0.3858, rewards: 0.0275\n",
      "Iteration: 590, Train loss: -0.4264, rewards: 0.0488\n",
      "Iteration: 600, Train loss: -0.4169, rewards: 0.0381\n",
      "Eval:\n",
      "Hits@1: 0.0443, Hits@3: 0.0972, Hits@10: 0.1983, MRR: 0.0909\n",
      "------------------------------------------------------------\n",
      "Iteration: 610, Train loss: -0.4782, rewards: 0.0569\n",
      "Iteration: 620, Train loss: -0.4174, rewards: 0.0356\n",
      "Iteration: 630, Train loss: -0.4223, rewards: 0.0475\n",
      "Iteration: 640, Train loss: -0.3809, rewards: 0.0194\n",
      "Iteration: 650, Train loss: -0.3655, rewards: 0.0194\n",
      "Iteration: 660, Train loss: -0.3732, rewards: 0.0181\n",
      "Iteration: 670, Train loss: -0.4021, rewards: 0.0350\n",
      "Iteration: 680, Train loss: -0.3959, rewards: 0.0331\n",
      "Iteration: 690, Train loss: -0.4289, rewards: 0.0387\n",
      "Iteration: 700, Train loss: -0.4392, rewards: 0.0400\n",
      "Eval:\n",
      "Hits@1: 0.0585, Hits@3: 0.1111, Hits@10: 0.2000, MRR: 0.1025\n",
      "------------------------------------------------------------\n",
      "Iteration: 710, Train loss: -0.3964, rewards: 0.0362\n",
      "Iteration: 720, Train loss: -0.3831, rewards: 0.0281\n",
      "Iteration: 730, Train loss: -0.4690, rewards: 0.0488\n",
      "Iteration: 740, Train loss: -0.4332, rewards: 0.0319\n",
      "Iteration: 750, Train loss: -0.3398, rewards: 0.0206\n",
      "Iteration: 760, Train loss: -0.5024, rewards: 0.0712\n",
      "Iteration: 770, Train loss: -0.4238, rewards: 0.0475\n",
      "Iteration: 780, Train loss: -0.5039, rewards: 0.0575\n",
      "Iteration: 790, Train loss: -0.4508, rewards: 0.0494\n",
      "Iteration: 800, Train loss: -0.4393, rewards: 0.0506\n",
      "Eval:\n",
      "Hits@1: 0.0833, Hits@3: 0.1447, Hits@10: 0.2362, MRR: 0.1324\n",
      "------------------------------------------------------------\n",
      "Iteration: 810, Train loss: -0.5025, rewards: 0.0544\n",
      "Iteration: 820, Train loss: -0.4873, rewards: 0.0494\n",
      "Iteration: 830, Train loss: -0.4675, rewards: 0.0563\n",
      "Iteration: 840, Train loss: -0.4038, rewards: 0.0344\n",
      "Iteration: 850, Train loss: -0.4533, rewards: 0.0519\n",
      "Iteration: 860, Train loss: -0.4560, rewards: 0.0444\n",
      "Iteration: 870, Train loss: -0.4450, rewards: 0.0544\n",
      "Iteration: 880, Train loss: -0.4351, rewards: 0.0338\n",
      "Iteration: 890, Train loss: -0.5059, rewards: 0.0669\n",
      "Iteration: 900, Train loss: -0.5872, rewards: 0.0825\n",
      "Eval:\n",
      "Hits@1: 0.1062, Hits@3: 0.1712, Hits@10: 0.2634, MRR: 0.1562\n",
      "------------------------------------------------------------\n",
      "Iteration: 910, Train loss: -0.4717, rewards: 0.0631\n",
      "Iteration: 920, Train loss: -0.5055, rewards: 0.0525\n",
      "Iteration: 930, Train loss: -0.5017, rewards: 0.0681\n",
      "Iteration: 940, Train loss: -0.5394, rewards: 0.0462\n",
      "Iteration: 950, Train loss: -0.4963, rewards: 0.0831\n",
      "Iteration: 960, Train loss: -0.5019, rewards: 0.0456\n",
      "Iteration: 970, Train loss: -0.5595, rewards: 0.0800\n",
      "Iteration: 980, Train loss: -0.4426, rewards: 0.0294\n",
      "Iteration: 990, Train loss: -0.5204, rewards: 0.0813\n",
      "Iteration: 1000, Train loss: -0.5739, rewards: 0.0925\n",
      "Eval:\n",
      "Hits@1: 0.0989, Hits@3: 0.1615, Hits@10: 0.2579, MRR: 0.1490\n",
      "------------------------------------------------------------\n",
      "Iteration: 1010, Train loss: -0.3781, rewards: 0.0288\n",
      "Iteration: 1020, Train loss: -0.5269, rewards: 0.0594\n",
      "Iteration: 1030, Train loss: -0.5530, rewards: 0.0869\n",
      "Iteration: 1040, Train loss: -0.4864, rewards: 0.0694\n",
      "Iteration: 1050, Train loss: -0.4846, rewards: 0.0638\n",
      "Iteration: 1060, Train loss: -0.4761, rewards: 0.0587\n",
      "Iteration: 1070, Train loss: -0.4463, rewards: 0.0525\n",
      "Iteration: 1080, Train loss: -0.5080, rewards: 0.0700\n",
      "Iteration: 1090, Train loss: -0.5106, rewards: 0.0694\n",
      "Iteration: 1100, Train loss: -0.5731, rewards: 0.1156\n",
      "Eval:\n",
      "Hits@1: 0.1205, Hits@3: 0.1922, Hits@10: 0.2767, MRR: 0.1717\n",
      "------------------------------------------------------------\n",
      "Iteration: 1110, Train loss: -0.5859, rewards: 0.0925\n",
      "Iteration: 1120, Train loss: -0.4945, rewards: 0.0506\n",
      "Iteration: 1130, Train loss: -0.5252, rewards: 0.0819\n",
      "Iteration: 1140, Train loss: -0.7013, rewards: 0.0813\n",
      "Iteration: 1150, Train loss: -0.5463, rewards: 0.0725\n",
      "Iteration: 1160, Train loss: -0.5159, rewards: 0.0606\n",
      "Iteration: 1170, Train loss: -0.5551, rewards: 0.0838\n",
      "Iteration: 1180, Train loss: -0.5639, rewards: 0.0788\n",
      "Iteration: 1190, Train loss: -0.4843, rewards: 0.0731\n",
      "Iteration: 1200, Train loss: -0.5554, rewards: 0.0669\n",
      "Eval:\n",
      "Hits@1: 0.1170, Hits@3: 0.1868, Hits@10: 0.2722, MRR: 0.1675\n",
      "------------------------------------------------------------\n",
      "Iteration: 1210, Train loss: -0.4635, rewards: 0.0512\n",
      "Iteration: 1220, Train loss: -0.5451, rewards: 0.0969\n",
      "Iteration: 1230, Train loss: -0.5277, rewards: 0.0725\n",
      "Iteration: 1240, Train loss: -0.4955, rewards: 0.0519\n",
      "Iteration: 1250, Train loss: -0.5456, rewards: 0.0875\n",
      "Iteration: 1260, Train loss: -0.5367, rewards: 0.0750\n",
      "Iteration: 1270, Train loss: -0.4749, rewards: 0.0694\n",
      "Iteration: 1280, Train loss: -0.5615, rewards: 0.0813\n",
      "Iteration: 1290, Train loss: -0.4968, rewards: 0.0556\n",
      "Iteration: 1300, Train loss: -0.5049, rewards: 0.0512\n",
      "Eval:\n",
      "Hits@1: 0.1385, Hits@3: 0.2236, Hits@10: 0.3154, MRR: 0.1971\n",
      "------------------------------------------------------------\n",
      "Iteration: 1310, Train loss: -0.5991, rewards: 0.0806\n",
      "Iteration: 1320, Train loss: -0.6546, rewards: 0.0856\n",
      "Iteration: 1330, Train loss: -0.6564, rewards: 0.1144\n",
      "Iteration: 1340, Train loss: -0.5929, rewards: 0.1237\n",
      "Iteration: 1350, Train loss: -0.6096, rewards: 0.0862\n",
      "Iteration: 1360, Train loss: -0.5911, rewards: 0.1000\n",
      "Iteration: 1370, Train loss: -0.6403, rewards: 0.1194\n",
      "Iteration: 1380, Train loss: -0.5937, rewards: 0.1194\n",
      "Iteration: 1390, Train loss: -0.6315, rewards: 0.1094\n",
      "Iteration: 1400, Train loss: -0.5928, rewards: 0.0887\n",
      "Eval:\n",
      "Hits@1: 0.1482, Hits@3: 0.2278, Hits@10: 0.3259, MRR: 0.2058\n",
      "------------------------------------------------------------\n",
      "Iteration: 1410, Train loss: -0.6005, rewards: 0.0950\n",
      "Iteration: 1420, Train loss: -0.5584, rewards: 0.0988\n",
      "Iteration: 1430, Train loss: -0.5598, rewards: 0.0581\n",
      "Iteration: 1440, Train loss: -0.6470, rewards: 0.1113\n",
      "Iteration: 1450, Train loss: -0.5316, rewards: 0.0794\n",
      "Iteration: 1460, Train loss: -0.5605, rewards: 0.0719\n",
      "Iteration: 1470, Train loss: -0.5529, rewards: 0.1125\n",
      "Iteration: 1480, Train loss: -0.5823, rewards: 0.0975\n",
      "Iteration: 1490, Train loss: -0.5748, rewards: 0.1263\n",
      "Iteration: 1500, Train loss: -0.6177, rewards: 0.1013\n",
      "Eval:\n",
      "Hits@1: 0.1523, Hits@3: 0.2279, Hits@10: 0.3265, MRR: 0.2080\n",
      "------------------------------------------------------------\n",
      "Iteration: 1510, Train loss: -0.5139, rewards: 0.0906\n",
      "Iteration: 1520, Train loss: -0.5165, rewards: 0.0737\n",
      "Iteration: 1530, Train loss: -0.5955, rewards: 0.1256\n",
      "Iteration: 1540, Train loss: -0.5454, rewards: 0.0919\n",
      "Iteration: 1550, Train loss: -0.4783, rewards: 0.0719\n",
      "Iteration: 1560, Train loss: -0.4752, rewards: 0.0631\n",
      "Iteration: 1570, Train loss: -0.5655, rewards: 0.0663\n",
      "Iteration: 1580, Train loss: -0.5264, rewards: 0.1187\n",
      "Iteration: 1590, Train loss: -0.5917, rewards: 0.1131\n",
      "Iteration: 1600, Train loss: -0.5134, rewards: 0.1013\n",
      "Eval:\n",
      "Hits@1: 0.1511, Hits@3: 0.2310, Hits@10: 0.3277, MRR: 0.2085\n",
      "------------------------------------------------------------\n",
      "Iteration: 1610, Train loss: -0.6015, rewards: 0.0956\n",
      "Iteration: 1620, Train loss: -0.6772, rewards: 0.0988\n",
      "Iteration: 1630, Train loss: -0.6219, rewards: 0.1225\n",
      "Iteration: 1640, Train loss: -0.5375, rewards: 0.0819\n",
      "Iteration: 1650, Train loss: -0.5452, rewards: 0.1000\n",
      "Iteration: 1660, Train loss: -0.6348, rewards: 0.1256\n",
      "Iteration: 1670, Train loss: -0.7147, rewards: 0.2112\n",
      "Iteration: 1680, Train loss: -0.6610, rewards: 0.1363\n",
      "Iteration: 1690, Train loss: -0.5073, rewards: 0.0794\n",
      "Iteration: 1700, Train loss: -0.5722, rewards: 0.0862\n",
      "Eval:\n",
      "Hits@1: 0.1502, Hits@3: 0.2303, Hits@10: 0.3320, MRR: 0.2087\n",
      "------------------------------------------------------------\n",
      "Iteration: 1710, Train loss: -0.7953, rewards: 0.1406\n",
      "Iteration: 1720, Train loss: -0.5782, rewards: 0.1306\n",
      "Iteration: 1730, Train loss: -0.6875, rewards: 0.1169\n",
      "Iteration: 1740, Train loss: -0.7958, rewards: 0.1456\n",
      "Iteration: 1750, Train loss: -0.5461, rewards: 0.0856\n",
      "Iteration: 1760, Train loss: -0.6233, rewards: 0.0975\n",
      "Iteration: 1770, Train loss: -0.7382, rewards: 0.1650\n",
      "Iteration: 1780, Train loss: -0.4836, rewards: 0.0881\n",
      "Iteration: 1790, Train loss: -0.6073, rewards: 0.1344\n",
      "Iteration: 1800, Train loss: -0.5990, rewards: 0.0800\n",
      "Eval:\n",
      "Hits@1: 0.1513, Hits@3: 0.2297, Hits@10: 0.3215, MRR: 0.2071\n",
      "------------------------------------------------------------\n",
      "Iteration: 1810, Train loss: -0.6461, rewards: 0.1237\n",
      "Iteration: 1820, Train loss: -0.5638, rewards: 0.1050\n",
      "Iteration: 1830, Train loss: -0.6413, rewards: 0.1156\n",
      "Iteration: 1840, Train loss: -0.6809, rewards: 0.1275\n",
      "Iteration: 1850, Train loss: -0.8045, rewards: 0.1525\n",
      "Iteration: 1860, Train loss: -0.7090, rewards: 0.1331\n",
      "Iteration: 1870, Train loss: -0.6644, rewards: 0.0963\n",
      "Iteration: 1880, Train loss: -0.6380, rewards: 0.1456\n",
      "Iteration: 1890, Train loss: -0.5561, rewards: 0.0806\n",
      "Iteration: 1900, Train loss: -0.5509, rewards: 0.0969\n",
      "Eval:\n",
      "Hits@1: 0.1650, Hits@3: 0.2481, Hits@10: 0.3384, MRR: 0.2223\n",
      "------------------------------------------------------------\n",
      "Iteration: 1910, Train loss: -0.7329, rewards: 0.1319\n",
      "Iteration: 1920, Train loss: -0.9681, rewards: 0.1919\n",
      "Iteration: 1930, Train loss: -0.6349, rewards: 0.1219\n",
      "Iteration: 1940, Train loss: -0.5660, rewards: 0.1256\n",
      "Iteration: 1950, Train loss: -0.6151, rewards: 0.1425\n",
      "Iteration: 1960, Train loss: -0.6178, rewards: 0.1275\n",
      "Iteration: 1970, Train loss: -0.5792, rewards: 0.0988\n",
      "Iteration: 1980, Train loss: -0.6978, rewards: 0.1094\n",
      "Iteration: 1990, Train loss: -0.5662, rewards: 0.1019\n",
      "Iteration: 2000, Train loss: -0.5880, rewards: 0.0894\n",
      "Eval:\n",
      "Hits@1: 0.1696, Hits@3: 0.2457, Hits@10: 0.3330, MRR: 0.2234\n",
      "------------------------------------------------------------\n",
      "Iteration: 2010, Train loss: -0.7352, rewards: 0.1512\n",
      "Iteration: 2020, Train loss: -0.6058, rewards: 0.1375\n",
      "Iteration: 2030, Train loss: -0.6114, rewards: 0.1481\n",
      "Iteration: 2040, Train loss: -0.6197, rewards: 0.0900\n",
      "Iteration: 2050, Train loss: -0.5486, rewards: 0.0862\n",
      "Iteration: 2060, Train loss: -0.6503, rewards: 0.0944\n",
      "Iteration: 2070, Train loss: -0.5742, rewards: 0.1306\n",
      "Iteration: 2080, Train loss: -0.5689, rewards: 0.0944\n",
      "Iteration: 2090, Train loss: -0.6023, rewards: 0.0850\n",
      "Iteration: 2100, Train loss: -0.6693, rewards: 0.1375\n",
      "Eval:\n",
      "Hits@1: 0.1669, Hits@3: 0.2518, Hits@10: 0.3518, MRR: 0.2272\n",
      "------------------------------------------------------------\n",
      "Iteration: 2110, Train loss: -0.5654, rewards: 0.1062\n",
      "Iteration: 2120, Train loss: -0.7104, rewards: 0.1231\n",
      "Iteration: 2130, Train loss: -0.7413, rewards: 0.1363\n",
      "Iteration: 2140, Train loss: -0.5703, rewards: 0.0969\n",
      "Iteration: 2150, Train loss: -0.5635, rewards: 0.1275\n",
      "Iteration: 2160, Train loss: -0.5787, rewards: 0.1050\n",
      "Iteration: 2170, Train loss: -0.6747, rewards: 0.1263\n",
      "Iteration: 2180, Train loss: -0.6911, rewards: 0.1050\n",
      "Iteration: 2190, Train loss: -0.8524, rewards: 0.1494\n",
      "Iteration: 2200, Train loss: -0.6155, rewards: 0.1319\n",
      "Eval:\n",
      "Hits@1: 0.1648, Hits@3: 0.2440, Hits@10: 0.3414, MRR: 0.2218\n",
      "------------------------------------------------------------\n",
      "Iteration: 2210, Train loss: -0.6495, rewards: 0.1331\n",
      "Iteration: 2220, Train loss: -0.5868, rewards: 0.0900\n",
      "Iteration: 2230, Train loss: -0.6542, rewards: 0.1363\n",
      "Iteration: 2240, Train loss: -0.7213, rewards: 0.1338\n",
      "Iteration: 2250, Train loss: -0.6986, rewards: 0.1175\n",
      "Iteration: 2260, Train loss: -0.6522, rewards: 0.1650\n",
      "Iteration: 2270, Train loss: -0.4664, rewards: 0.0625\n",
      "Iteration: 2280, Train loss: -0.6768, rewards: 0.1244\n",
      "Iteration: 2290, Train loss: -0.6005, rewards: 0.0869\n",
      "Iteration: 2300, Train loss: -0.7414, rewards: 0.1344\n",
      "Eval:\n",
      "Hits@1: 0.1706, Hits@3: 0.2473, Hits@10: 0.3562, MRR: 0.2282\n",
      "------------------------------------------------------------\n",
      "Iteration: 2310, Train loss: -0.6332, rewards: 0.0981\n",
      "Iteration: 2320, Train loss: -0.6361, rewards: 0.0862\n",
      "Iteration: 2330, Train loss: -0.6335, rewards: 0.1613\n",
      "Iteration: 2340, Train loss: -0.5801, rewards: 0.0963\n",
      "Iteration: 2350, Train loss: -0.5539, rewards: 0.1019\n",
      "Iteration: 2360, Train loss: -0.6057, rewards: 0.0744\n",
      "Iteration: 2370, Train loss: -0.6459, rewards: 0.1275\n",
      "Iteration: 2380, Train loss: -0.6387, rewards: 0.1044\n",
      "Iteration: 2390, Train loss: -0.7353, rewards: 0.1388\n",
      "Iteration: 2400, Train loss: -0.5207, rewards: 0.0600\n",
      "Eval:\n",
      "Hits@1: 0.1752, Hits@3: 0.2503, Hits@10: 0.3483, MRR: 0.2315\n",
      "------------------------------------------------------------\n",
      "Iteration: 2410, Train loss: -0.7986, rewards: 0.1744\n",
      "Iteration: 2420, Train loss: -0.6206, rewards: 0.1319\n",
      "Iteration: 2430, Train loss: -0.6628, rewards: 0.1194\n",
      "Iteration: 2440, Train loss: -0.6503, rewards: 0.1106\n",
      "Iteration: 2450, Train loss: -0.5741, rewards: 0.1031\n",
      "Iteration: 2460, Train loss: -0.5949, rewards: 0.1181\n",
      "Iteration: 2470, Train loss: -0.5587, rewards: 0.0944\n",
      "Iteration: 2480, Train loss: -0.5652, rewards: 0.0887\n",
      "Iteration: 2490, Train loss: -0.6960, rewards: 0.0881\n",
      "Iteration: 2500, Train loss: -0.5714, rewards: 0.0794\n",
      "Eval:\n",
      "Hits@1: 0.1812, Hits@3: 0.2675, Hits@10: 0.3672, MRR: 0.2421\n",
      "------------------------------------------------------------\n",
      "Iteration: 2510, Train loss: -0.6368, rewards: 0.1619\n",
      "Iteration: 2520, Train loss: -0.6140, rewards: 0.1181\n",
      "Iteration: 2530, Train loss: -0.4771, rewards: 0.1187\n",
      "Iteration: 2540, Train loss: -0.7243, rewards: 0.1675\n",
      "Iteration: 2550, Train loss: -0.6275, rewards: 0.0969\n",
      "Iteration: 2560, Train loss: -0.6786, rewards: 0.1394\n",
      "Iteration: 2570, Train loss: -0.6521, rewards: 0.0956\n",
      "Iteration: 2580, Train loss: -0.6617, rewards: 0.1187\n",
      "Iteration: 2590, Train loss: -0.5564, rewards: 0.0925\n",
      "Iteration: 2600, Train loss: -0.5675, rewards: 0.1181\n",
      "Eval:\n",
      "Hits@1: 0.1862, Hits@3: 0.2723, Hits@10: 0.3766, MRR: 0.2479\n",
      "------------------------------------------------------------\n",
      "Iteration: 2610, Train loss: -0.6726, rewards: 0.1281\n",
      "Iteration: 2620, Train loss: -0.7452, rewards: 0.1644\n",
      "Iteration: 2630, Train loss: -0.6970, rewards: 0.1313\n",
      "Iteration: 2640, Train loss: -0.5973, rewards: 0.0994\n",
      "Iteration: 2650, Train loss: -0.7134, rewards: 0.1231\n",
      "Iteration: 2660, Train loss: -0.6463, rewards: 0.1113\n",
      "Iteration: 2670, Train loss: -0.6428, rewards: 0.1569\n",
      "Iteration: 2680, Train loss: -0.7438, rewards: 0.1519\n",
      "Iteration: 2690, Train loss: -0.7040, rewards: 0.1394\n",
      "Iteration: 2700, Train loss: -0.6622, rewards: 0.1338\n",
      "Eval:\n",
      "Hits@1: 0.1813, Hits@3: 0.2625, Hits@10: 0.3592, MRR: 0.2393\n",
      "------------------------------------------------------------\n",
      "Iteration: 2710, Train loss: -0.7041, rewards: 0.0894\n",
      "Iteration: 2720, Train loss: -0.7449, rewards: 0.1200\n",
      "Iteration: 2730, Train loss: -0.7516, rewards: 0.1319\n",
      "Iteration: 2740, Train loss: -0.7298, rewards: 0.1350\n",
      "Iteration: 2750, Train loss: -0.6732, rewards: 0.1656\n",
      "Iteration: 2760, Train loss: -0.7102, rewards: 0.1150\n",
      "Iteration: 2770, Train loss: -0.5990, rewards: 0.1075\n",
      "Iteration: 2780, Train loss: -0.6223, rewards: 0.0988\n",
      "Iteration: 2790, Train loss: -0.6035, rewards: 0.1325\n",
      "Iteration: 2800, Train loss: -0.7409, rewards: 0.1306\n",
      "Eval:\n",
      "Hits@1: 0.1871, Hits@3: 0.2706, Hits@10: 0.3691, MRR: 0.2459\n",
      "------------------------------------------------------------\n",
      "Iteration: 2810, Train loss: -0.6951, rewards: 0.1356\n",
      "Iteration: 2820, Train loss: -0.4373, rewards: 0.0644\n",
      "Iteration: 2830, Train loss: -0.5494, rewards: 0.0819\n",
      "Iteration: 2840, Train loss: -0.6276, rewards: 0.0950\n",
      "Iteration: 2850, Train loss: -0.6462, rewards: 0.1056\n",
      "Iteration: 2860, Train loss: -0.5952, rewards: 0.1206\n",
      "Iteration: 2870, Train loss: -0.6766, rewards: 0.1244\n",
      "Iteration: 2880, Train loss: -0.6220, rewards: 0.1113\n",
      "Iteration: 2890, Train loss: -0.5971, rewards: 0.0762\n",
      "Iteration: 2900, Train loss: -0.6164, rewards: 0.1219\n",
      "Eval:\n",
      "Hits@1: 0.1989, Hits@3: 0.2799, Hits@10: 0.3796, MRR: 0.2567\n",
      "------------------------------------------------------------\n",
      "Iteration: 2910, Train loss: -0.6588, rewards: 0.1313\n",
      "Iteration: 2920, Train loss: -0.7328, rewards: 0.1588\n",
      "Iteration: 2930, Train loss: -0.7056, rewards: 0.1456\n",
      "Iteration: 2940, Train loss: -0.6453, rewards: 0.1081\n",
      "Iteration: 2950, Train loss: -0.6811, rewards: 0.1288\n",
      "Iteration: 2960, Train loss: -0.8240, rewards: 0.1062\n",
      "Iteration: 2970, Train loss: -0.6670, rewards: 0.1056\n",
      "Iteration: 2980, Train loss: -0.8172, rewards: 0.1644\n",
      "Iteration: 2990, Train loss: -0.7579, rewards: 0.1619\n",
      "Iteration: 3000, Train loss: -0.7672, rewards: 0.1537\n",
      "Eval:\n",
      "Hits@1: 0.1973, Hits@3: 0.2864, Hits@10: 0.3870, MRR: 0.2593\n",
      "------------------------------------------------------------\n",
      "Iteration: 3010, Train loss: -0.6815, rewards: 0.1556\n",
      "Iteration: 3020, Train loss: -0.7563, rewards: 0.1569\n",
      "Iteration: 3030, Train loss: -0.7582, rewards: 0.1550\n",
      "Iteration: 3040, Train loss: -0.7761, rewards: 0.1594\n",
      "Iteration: 3050, Train loss: -0.6142, rewards: 0.1481\n",
      "Iteration: 3060, Train loss: -0.8140, rewards: 0.2013\n",
      "Iteration: 3070, Train loss: -0.7295, rewards: 0.1837\n",
      "Iteration: 3080, Train loss: -0.9035, rewards: 0.1156\n",
      "Iteration: 3090, Train loss: -0.6823, rewards: 0.1400\n",
      "Iteration: 3100, Train loss: -0.8044, rewards: 0.1369\n",
      "Eval:\n",
      "Hits@1: 0.1956, Hits@3: 0.2831, Hits@10: 0.3842, MRR: 0.2564\n",
      "------------------------------------------------------------\n",
      "Iteration: 3110, Train loss: -0.8852, rewards: 0.1750\n",
      "Iteration: 3120, Train loss: -0.7986, rewards: 0.1694\n",
      "Iteration: 3130, Train loss: -0.6509, rewards: 0.1187\n",
      "Iteration: 3140, Train loss: -0.5631, rewards: 0.0794\n",
      "Iteration: 3150, Train loss: -0.7575, rewards: 0.1650\n",
      "Iteration: 3160, Train loss: -0.7042, rewards: 0.1450\n",
      "Iteration: 3170, Train loss: -0.5172, rewards: 0.1081\n",
      "Iteration: 3180, Train loss: -0.6532, rewards: 0.1313\n",
      "Iteration: 3190, Train loss: -0.8069, rewards: 0.1975\n",
      "Iteration: 3200, Train loss: -0.6103, rewards: 0.0969\n",
      "Eval:\n",
      "Hits@1: 0.1946, Hits@3: 0.2801, Hits@10: 0.3814, MRR: 0.2553\n",
      "------------------------------------------------------------\n",
      "Iteration: 3210, Train loss: -0.7645, rewards: 0.1750\n",
      "Iteration: 3220, Train loss: -0.7710, rewards: 0.1350\n",
      "Iteration: 3230, Train loss: -0.7285, rewards: 0.1594\n",
      "Iteration: 3240, Train loss: -0.7742, rewards: 0.1775\n",
      "Iteration: 3250, Train loss: -0.8048, rewards: 0.1313\n",
      "Iteration: 3260, Train loss: -0.5292, rewards: 0.1087\n",
      "Iteration: 3270, Train loss: -0.7724, rewards: 0.1713\n",
      "Iteration: 3280, Train loss: -0.7092, rewards: 0.1181\n",
      "Iteration: 3290, Train loss: -0.8502, rewards: 0.1625\n",
      "Iteration: 3300, Train loss: -0.7980, rewards: 0.1744\n",
      "Eval:\n",
      "Hits@1: 0.1947, Hits@3: 0.2804, Hits@10: 0.3792, MRR: 0.2550\n",
      "------------------------------------------------------------\n",
      "Iteration: 3310, Train loss: -0.7481, rewards: 0.1519\n",
      "Iteration: 3320, Train loss: -0.7664, rewards: 0.1300\n",
      "Iteration: 3330, Train loss: -0.7956, rewards: 0.1487\n",
      "Iteration: 3340, Train loss: -0.6066, rewards: 0.1150\n",
      "Iteration: 3350, Train loss: -0.5453, rewards: 0.0856\n",
      "Iteration: 3360, Train loss: -0.9101, rewards: 0.1694\n",
      "Iteration: 3370, Train loss: -0.9243, rewards: 0.1400\n",
      "Iteration: 3380, Train loss: -0.8196, rewards: 0.1650\n",
      "Iteration: 3390, Train loss: -0.6963, rewards: 0.1713\n",
      "Iteration: 3400, Train loss: -0.8191, rewards: 0.1650\n",
      "Eval:\n",
      "Hits@1: 0.1869, Hits@3: 0.2722, Hits@10: 0.3754, MRR: 0.2476\n",
      "------------------------------------------------------------\n",
      "Iteration: 3410, Train loss: -0.7979, rewards: 0.1619\n",
      "Iteration: 3420, Train loss: -0.7510, rewards: 0.1300\n",
      "Iteration: 3430, Train loss: -0.5872, rewards: 0.1044\n",
      "Iteration: 3440, Train loss: -0.6756, rewards: 0.1006\n",
      "Iteration: 3450, Train loss: -0.7327, rewards: 0.1562\n",
      "Iteration: 3460, Train loss: -0.6290, rewards: 0.0963\n",
      "Iteration: 3470, Train loss: -0.7269, rewards: 0.2044\n",
      "Iteration: 3480, Train loss: -0.6487, rewards: 0.1144\n",
      "Iteration: 3490, Train loss: -0.6958, rewards: 0.1319\n",
      "Iteration: 3500, Train loss: -0.5478, rewards: 0.1062\n",
      "Eval:\n",
      "Hits@1: 0.1936, Hits@3: 0.2766, Hits@10: 0.3780, MRR: 0.2524\n",
      "------------------------------------------------------------\n",
      "Iteration: 3510, Train loss: -0.6704, rewards: 0.1187\n",
      "Iteration: 3520, Train loss: -0.6872, rewards: 0.1144\n",
      "Iteration: 3530, Train loss: -0.8229, rewards: 0.1562\n",
      "Iteration: 3540, Train loss: -0.7748, rewards: 0.1263\n",
      "Iteration: 3550, Train loss: -0.5097, rewards: 0.0850\n",
      "Iteration: 3560, Train loss: -0.8047, rewards: 0.1437\n",
      "Iteration: 3570, Train loss: -0.5687, rewards: 0.1013\n",
      "Iteration: 3580, Train loss: -0.5468, rewards: 0.0719\n",
      "Iteration: 3590, Train loss: -0.7514, rewards: 0.1544\n",
      "Iteration: 3600, Train loss: -0.7402, rewards: 0.1269\n",
      "Eval:\n",
      "Hits@1: 0.1909, Hits@3: 0.2750, Hits@10: 0.3736, MRR: 0.2498\n",
      "------------------------------------------------------------\n",
      "Iteration: 3610, Train loss: -0.8536, rewards: 0.1606\n",
      "Iteration: 3620, Train loss: -0.7591, rewards: 0.1619\n",
      "Iteration: 3630, Train loss: -0.5744, rewards: 0.1481\n",
      "Iteration: 3640, Train loss: -0.5912, rewards: 0.0825\n",
      "Iteration: 3650, Train loss: -0.7819, rewards: 0.1450\n",
      "Iteration: 3660, Train loss: -0.6030, rewards: 0.1225\n",
      "Iteration: 3670, Train loss: -0.6865, rewards: 0.1425\n",
      "Iteration: 3680, Train loss: -0.6182, rewards: 0.1125\n",
      "Iteration: 3690, Train loss: -0.6203, rewards: 0.1119\n",
      "Iteration: 3700, Train loss: -0.7406, rewards: 0.1237\n",
      "Eval:\n",
      "Hits@1: 0.2007, Hits@3: 0.2845, Hits@10: 0.3810, MRR: 0.2592\n",
      "------------------------------------------------------------\n",
      "Iteration: 3710, Train loss: -0.7639, rewards: 0.1381\n",
      "Iteration: 3720, Train loss: -0.7014, rewards: 0.1481\n",
      "Iteration: 3730, Train loss: -0.8512, rewards: 0.1756\n",
      "Iteration: 3740, Train loss: -0.8159, rewards: 0.1588\n",
      "Iteration: 3750, Train loss: -0.7856, rewards: 0.1494\n",
      "Iteration: 3760, Train loss: -0.7768, rewards: 0.1537\n",
      "Iteration: 3770, Train loss: -0.7379, rewards: 0.1850\n",
      "Iteration: 3780, Train loss: -0.7093, rewards: 0.1281\n",
      "Iteration: 3790, Train loss: -0.7428, rewards: 0.1187\n",
      "Iteration: 3800, Train loss: -0.6945, rewards: 0.1356\n",
      "Eval:\n",
      "Hits@1: 0.1958, Hits@3: 0.2790, Hits@10: 0.3743, MRR: 0.2535\n",
      "------------------------------------------------------------\n",
      "Iteration: 3810, Train loss: -0.6514, rewards: 0.1100\n",
      "Iteration: 3820, Train loss: -0.7726, rewards: 0.1487\n",
      "Iteration: 3830, Train loss: -0.9389, rewards: 0.1644\n",
      "Iteration: 3840, Train loss: -0.8176, rewards: 0.1756\n",
      "Iteration: 3850, Train loss: -0.7928, rewards: 0.2162\n",
      "Iteration: 3860, Train loss: -0.7264, rewards: 0.1219\n",
      "Iteration: 3870, Train loss: -0.6899, rewards: 0.1169\n",
      "Iteration: 3880, Train loss: -0.8309, rewards: 0.1375\n",
      "Iteration: 3890, Train loss: -0.7812, rewards: 0.1444\n",
      "Iteration: 3900, Train loss: -0.6077, rewards: 0.1113\n",
      "Eval:\n",
      "Hits@1: 0.1982, Hits@3: 0.2771, Hits@10: 0.3674, MRR: 0.2535\n",
      "------------------------------------------------------------\n",
      "Iteration: 3910, Train loss: -0.6878, rewards: 0.0938\n",
      "Iteration: 3920, Train loss: -0.8620, rewards: 0.1819\n",
      "Iteration: 3930, Train loss: -0.6886, rewards: 0.1294\n",
      "Iteration: 3940, Train loss: -0.8307, rewards: 0.1625\n",
      "Iteration: 3950, Train loss: -0.7361, rewards: 0.1562\n",
      "Iteration: 3960, Train loss: -0.7351, rewards: 0.1537\n",
      "Iteration: 3970, Train loss: -0.6375, rewards: 0.1144\n",
      "Iteration: 3980, Train loss: -0.6401, rewards: 0.0894\n",
      "Iteration: 3990, Train loss: -0.7083, rewards: 0.1150\n",
      "Iteration: 4000, Train loss: -0.6995, rewards: 0.1275\n",
      "Eval:\n",
      "Hits@1: 0.2009, Hits@3: 0.2861, Hits@10: 0.3772, MRR: 0.2593\n",
      "------------------------------------------------------------\n",
      "Iteration: 4010, Train loss: -0.7993, rewards: 0.1837\n",
      "Iteration: 4020, Train loss: -0.6866, rewards: 0.1231\n",
      "Iteration: 4030, Train loss: -0.6424, rewards: 0.1250\n",
      "Iteration: 4040, Train loss: -0.7114, rewards: 0.1237\n",
      "Iteration: 4050, Train loss: -0.7918, rewards: 0.1487\n",
      "Iteration: 4060, Train loss: -0.7593, rewards: 0.1444\n",
      "Iteration: 4070, Train loss: -0.6677, rewards: 0.1187\n",
      "Iteration: 4080, Train loss: -0.6184, rewards: 0.1450\n",
      "Iteration: 4090, Train loss: -0.8184, rewards: 0.1831\n",
      "Iteration: 4100, Train loss: -0.9002, rewards: 0.1975\n",
      "Eval:\n",
      "Hits@1: 0.2028, Hits@3: 0.2905, Hits@10: 0.3912, MRR: 0.2642\n",
      "------------------------------------------------------------\n",
      "Iteration: 4110, Train loss: -0.7523, rewards: 0.1619\n",
      "Iteration: 4120, Train loss: -0.8726, rewards: 0.1450\n",
      "Iteration: 4130, Train loss: -0.5766, rewards: 0.1263\n",
      "Iteration: 4140, Train loss: -0.7851, rewards: 0.1487\n",
      "Iteration: 4150, Train loss: -0.8051, rewards: 0.1550\n",
      "Iteration: 4160, Train loss: -0.8115, rewards: 0.1744\n",
      "Iteration: 4170, Train loss: -0.8833, rewards: 0.1569\n",
      "Iteration: 4180, Train loss: -0.7873, rewards: 0.1519\n",
      "Iteration: 4190, Train loss: -0.7979, rewards: 0.1481\n",
      "Iteration: 4200, Train loss: -0.6570, rewards: 0.1175\n",
      "Eval:\n",
      "Hits@1: 0.2057, Hits@3: 0.2930, Hits@10: 0.3900, MRR: 0.2660\n",
      "------------------------------------------------------------\n",
      "Iteration: 4210, Train loss: -0.7630, rewards: 0.1638\n",
      "Iteration: 4220, Train loss: -0.6473, rewards: 0.1550\n",
      "Iteration: 4230, Train loss: -0.8355, rewards: 0.1194\n",
      "Iteration: 4240, Train loss: -0.7633, rewards: 0.1300\n",
      "Iteration: 4250, Train loss: -0.6247, rewards: 0.1025\n",
      "Iteration: 4260, Train loss: -0.7723, rewards: 0.1231\n",
      "Iteration: 4270, Train loss: -0.6500, rewards: 0.0994\n",
      "Iteration: 4280, Train loss: -0.8039, rewards: 0.1581\n",
      "Iteration: 4290, Train loss: -0.6279, rewards: 0.1181\n",
      "Iteration: 4300, Train loss: -0.7108, rewards: 0.1325\n",
      "Eval:\n",
      "Hits@1: 0.1947, Hits@3: 0.2819, Hits@10: 0.3766, MRR: 0.2552\n",
      "------------------------------------------------------------\n",
      "Iteration: 4310, Train loss: -0.6958, rewards: 0.1506\n",
      "Iteration: 4320, Train loss: -0.8193, rewards: 0.1831\n",
      "Iteration: 4330, Train loss: -0.7400, rewards: 0.1506\n",
      "Iteration: 4340, Train loss: -0.8707, rewards: 0.1669\n",
      "Iteration: 4350, Train loss: -0.7888, rewards: 0.1806\n",
      "Iteration: 4360, Train loss: -0.6911, rewards: 0.1100\n",
      "Iteration: 4370, Train loss: -0.7898, rewards: 0.1669\n",
      "Iteration: 4380, Train loss: -0.7744, rewards: 0.1963\n",
      "Iteration: 4390, Train loss: -0.7974, rewards: 0.1512\n",
      "Iteration: 4400, Train loss: -0.8117, rewards: 0.2062\n",
      "Eval:\n",
      "Hits@1: 0.2036, Hits@3: 0.2921, Hits@10: 0.3858, MRR: 0.2638\n",
      "------------------------------------------------------------\n",
      "Iteration: 4410, Train loss: -0.8710, rewards: 0.1613\n",
      "Iteration: 4420, Train loss: -0.7535, rewards: 0.2231\n",
      "Iteration: 4430, Train loss: -0.7587, rewards: 0.1625\n",
      "Iteration: 4440, Train loss: -0.7390, rewards: 0.1794\n",
      "Iteration: 4450, Train loss: -0.7725, rewards: 0.1594\n",
      "Iteration: 4460, Train loss: -0.9866, rewards: 0.1900\n",
      "Iteration: 4470, Train loss: -0.7444, rewards: 0.1800\n",
      "Iteration: 4480, Train loss: -0.9558, rewards: 0.2256\n",
      "Iteration: 4490, Train loss: -0.8735, rewards: 0.2031\n",
      "Iteration: 4500, Train loss: -0.6617, rewards: 0.1650\n",
      "Eval:\n",
      "Hits@1: 0.2017, Hits@3: 0.2896, Hits@10: 0.3906, MRR: 0.2632\n",
      "------------------------------------------------------------\n",
      "Iteration: 4510, Train loss: -0.9450, rewards: 0.2162\n",
      "Iteration: 4520, Train loss: -0.7437, rewards: 0.1594\n",
      "Iteration: 4530, Train loss: -0.7588, rewards: 0.1456\n",
      "Iteration: 4540, Train loss: -0.8680, rewards: 0.1569\n",
      "Iteration: 4550, Train loss: -0.8028, rewards: 0.1256\n",
      "Iteration: 4560, Train loss: -0.6672, rewards: 0.0919\n",
      "Iteration: 4570, Train loss: -0.9185, rewards: 0.1638\n",
      "Iteration: 4580, Train loss: -0.8377, rewards: 0.1781\n",
      "Iteration: 4590, Train loss: -0.7161, rewards: 0.1437\n",
      "Iteration: 4600, Train loss: -0.6562, rewards: 0.1344\n",
      "Eval:\n",
      "Hits@1: 0.1987, Hits@3: 0.2854, Hits@10: 0.3859, MRR: 0.2596\n",
      "------------------------------------------------------------\n",
      "Iteration: 4610, Train loss: -0.7436, rewards: 0.1281\n",
      "Iteration: 4620, Train loss: -0.6642, rewards: 0.1006\n",
      "Iteration: 4630, Train loss: -0.7231, rewards: 0.1437\n",
      "Iteration: 4640, Train loss: -0.5469, rewards: 0.0788\n",
      "Iteration: 4650, Train loss: -0.5641, rewards: 0.0956\n",
      "Iteration: 4660, Train loss: -0.6765, rewards: 0.1325\n",
      "Iteration: 4670, Train loss: -0.9952, rewards: 0.1481\n",
      "Iteration: 4680, Train loss: -0.8686, rewards: 0.1706\n",
      "Iteration: 4690, Train loss: -0.6384, rewards: 0.1163\n",
      "Iteration: 4700, Train loss: -0.7751, rewards: 0.1500\n",
      "Eval:\n",
      "Hits@1: 0.2004, Hits@3: 0.2895, Hits@10: 0.3862, MRR: 0.2612\n",
      "------------------------------------------------------------\n",
      "Iteration: 4710, Train loss: -0.7799, rewards: 0.1631\n",
      "Iteration: 4720, Train loss: -0.9074, rewards: 0.2131\n",
      "Iteration: 4730, Train loss: -0.7840, rewards: 0.1581\n",
      "Iteration: 4740, Train loss: -0.6639, rewards: 0.1244\n",
      "Iteration: 4750, Train loss: -0.7317, rewards: 0.1594\n",
      "Iteration: 4760, Train loss: -0.6175, rewards: 0.1219\n",
      "Iteration: 4770, Train loss: -0.7678, rewards: 0.1500\n",
      "Iteration: 4780, Train loss: -0.8854, rewards: 0.1725\n",
      "Iteration: 4790, Train loss: -0.8158, rewards: 0.1425\n",
      "Iteration: 4800, Train loss: -0.8945, rewards: 0.1556\n",
      "Eval:\n",
      "Hits@1: 0.2056, Hits@3: 0.2944, Hits@10: 0.3886, MRR: 0.2661\n",
      "------------------------------------------------------------\n",
      "Iteration: 4810, Train loss: -0.7089, rewards: 0.1175\n",
      "Iteration: 4820, Train loss: -0.8251, rewards: 0.1713\n",
      "Iteration: 4830, Train loss: -0.8249, rewards: 0.1819\n",
      "Iteration: 4840, Train loss: -0.8499, rewards: 0.1569\n",
      "Iteration: 4850, Train loss: -0.6056, rewards: 0.1525\n",
      "Iteration: 4860, Train loss: -0.6508, rewards: 0.1062\n",
      "Iteration: 4870, Train loss: -0.8125, rewards: 0.1469\n",
      "Iteration: 4880, Train loss: -0.6028, rewards: 0.0969\n",
      "Iteration: 4890, Train loss: -0.8780, rewards: 0.1694\n",
      "Iteration: 4900, Train loss: -0.9018, rewards: 0.1669\n",
      "Eval:\n",
      "Hits@1: 0.2067, Hits@3: 0.2950, Hits@10: 0.3930, MRR: 0.2676\n",
      "------------------------------------------------------------\n",
      "Iteration: 4910, Train loss: -0.7352, rewards: 0.1331\n",
      "Iteration: 4920, Train loss: -0.7757, rewards: 0.1950\n",
      "Iteration: 4930, Train loss: -0.8499, rewards: 0.2069\n",
      "Iteration: 4940, Train loss: -0.7934, rewards: 0.1625\n",
      "Iteration: 4950, Train loss: -0.8625, rewards: 0.1606\n",
      "Iteration: 4960, Train loss: -0.8036, rewards: 0.1881\n",
      "Iteration: 4970, Train loss: -0.7571, rewards: 0.1481\n",
      "Iteration: 4980, Train loss: -0.7639, rewards: 0.1550\n",
      "Iteration: 4990, Train loss: -0.7606, rewards: 0.1581\n",
      "Iteration: 5000, Train loss: -0.7859, rewards: 0.1613\n",
      "Eval:\n",
      "Hits@1: 0.2079, Hits@3: 0.2917, Hits@10: 0.3807, MRR: 0.2651\n",
      "------------------------------------------------------------\n",
      "Iteration: 5010, Train loss: -0.8865, rewards: 0.1250\n",
      "Iteration: 5020, Train loss: -0.7948, rewards: 0.1750\n",
      "Iteration: 5030, Train loss: -0.8584, rewards: 0.1531\n",
      "Iteration: 5040, Train loss: -0.7339, rewards: 0.1981\n",
      "Iteration: 5050, Train loss: -0.8665, rewards: 0.1581\n",
      "Iteration: 5060, Train loss: -0.9168, rewards: 0.1487\n",
      "Iteration: 5070, Train loss: -0.7867, rewards: 0.1394\n",
      "Iteration: 5080, Train loss: -0.7585, rewards: 0.1319\n",
      "Iteration: 5090, Train loss: -0.9619, rewards: 0.1900\n",
      "Iteration: 5100, Train loss: -0.8838, rewards: 0.1569\n",
      "Eval:\n",
      "Hits@1: 0.2020, Hits@3: 0.2920, Hits@10: 0.3810, MRR: 0.2620\n",
      "------------------------------------------------------------\n",
      "Iteration: 5110, Train loss: -0.8769, rewards: 0.2131\n",
      "Iteration: 5120, Train loss: -0.8325, rewards: 0.1469\n",
      "Iteration: 5130, Train loss: -0.9046, rewards: 0.1506\n",
      "Iteration: 5140, Train loss: -0.6903, rewards: 0.1212\n",
      "Iteration: 5150, Train loss: -0.8397, rewards: 0.1731\n",
      "Iteration: 5160, Train loss: -0.7134, rewards: 0.1400\n",
      "Iteration: 5170, Train loss: -0.8529, rewards: 0.1688\n",
      "Iteration: 5180, Train loss: -0.7916, rewards: 0.2019\n",
      "Iteration: 5190, Train loss: -0.6622, rewards: 0.1369\n",
      "Iteration: 5200, Train loss: -1.0279, rewards: 0.2231\n",
      "Eval:\n",
      "Hits@1: 0.2022, Hits@3: 0.2878, Hits@10: 0.3820, MRR: 0.2616\n",
      "------------------------------------------------------------\n",
      "Iteration: 5210, Train loss: -0.8354, rewards: 0.1694\n",
      "Iteration: 5220, Train loss: -0.8966, rewards: 0.1862\n",
      "Iteration: 5230, Train loss: -0.5769, rewards: 0.1031\n",
      "Iteration: 5240, Train loss: -0.8457, rewards: 0.1619\n",
      "Iteration: 5250, Train loss: -0.6805, rewards: 0.1562\n",
      "Iteration: 5260, Train loss: -0.8022, rewards: 0.1281\n",
      "Iteration: 5270, Train loss: -0.7454, rewards: 0.1550\n",
      "Iteration: 5280, Train loss: -0.5993, rewards: 0.1113\n",
      "Iteration: 5290, Train loss: -0.7312, rewards: 0.1231\n",
      "Iteration: 5300, Train loss: -0.6671, rewards: 0.1394\n",
      "Eval:\n",
      "Hits@1: 0.2047, Hits@3: 0.2921, Hits@10: 0.3833, MRR: 0.2639\n",
      "------------------------------------------------------------\n",
      "Iteration: 5310, Train loss: -0.8936, rewards: 0.1963\n",
      "Iteration: 5320, Train loss: -0.7292, rewards: 0.1544\n",
      "Iteration: 5330, Train loss: -0.7575, rewards: 0.1200\n",
      "Iteration: 5340, Train loss: -0.7673, rewards: 0.1556\n",
      "Iteration: 5350, Train loss: -0.9608, rewards: 0.1694\n",
      "Iteration: 5360, Train loss: -0.9196, rewards: 0.1819\n",
      "Iteration: 5370, Train loss: -0.8462, rewards: 0.2037\n",
      "Iteration: 5380, Train loss: -0.7709, rewards: 0.1431\n",
      "Iteration: 5390, Train loss: -0.6277, rewards: 0.1544\n",
      "Iteration: 5400, Train loss: -0.7779, rewards: 0.1544\n",
      "Eval:\n",
      "Hits@1: 0.2091, Hits@3: 0.2981, Hits@10: 0.3955, MRR: 0.2702\n",
      "------------------------------------------------------------\n",
      "Iteration: 5410, Train loss: -0.7695, rewards: 0.1219\n",
      "Iteration: 5420, Train loss: -0.8027, rewards: 0.1806\n",
      "Iteration: 5430, Train loss: -0.7793, rewards: 0.1519\n",
      "Iteration: 5440, Train loss: -0.7749, rewards: 0.1544\n",
      "Iteration: 5450, Train loss: -0.7089, rewards: 0.1219\n",
      "Iteration: 5460, Train loss: -0.8021, rewards: 0.1694\n",
      "Iteration: 5470, Train loss: -0.9043, rewards: 0.2094\n",
      "Iteration: 5480, Train loss: -0.6174, rewards: 0.1244\n",
      "Iteration: 5490, Train loss: -0.9490, rewards: 0.2169\n",
      "Iteration: 5500, Train loss: -0.6809, rewards: 0.1200\n",
      "Eval:\n",
      "Hits@1: 0.2061, Hits@3: 0.2917, Hits@10: 0.3792, MRR: 0.2637\n",
      "------------------------------------------------------------\n",
      "Iteration: 5510, Train loss: -0.7536, rewards: 0.1369\n",
      "Iteration: 5520, Train loss: -0.7464, rewards: 0.1206\n",
      "Iteration: 5530, Train loss: -0.9923, rewards: 0.2000\n",
      "Iteration: 5540, Train loss: -0.6767, rewards: 0.1319\n",
      "Iteration: 5550, Train loss: -0.6461, rewards: 0.1175\n",
      "Iteration: 5560, Train loss: -0.8141, rewards: 0.1700\n",
      "Iteration: 5570, Train loss: -0.7439, rewards: 0.1388\n",
      "Iteration: 5580, Train loss: -0.9658, rewards: 0.1706\n",
      "Iteration: 5590, Train loss: -0.8939, rewards: 0.1825\n",
      "Iteration: 5600, Train loss: -0.7583, rewards: 0.1356\n",
      "Eval:\n",
      "Hits@1: 0.2080, Hits@3: 0.2984, Hits@10: 0.3952, MRR: 0.2696\n",
      "------------------------------------------------------------\n",
      "Iteration: 5610, Train loss: -0.8829, rewards: 0.2031\n",
      "Iteration: 5620, Train loss: -0.8337, rewards: 0.1475\n",
      "Iteration: 5630, Train loss: -0.7517, rewards: 0.1494\n",
      "Iteration: 5640, Train loss: -0.8002, rewards: 0.1237\n",
      "Iteration: 5650, Train loss: -0.6510, rewards: 0.0912\n",
      "Iteration: 5660, Train loss: -0.8509, rewards: 0.1825\n",
      "Iteration: 5670, Train loss: -0.8341, rewards: 0.1425\n",
      "Iteration: 5680, Train loss: -0.6699, rewards: 0.1406\n",
      "Iteration: 5690, Train loss: -0.6497, rewards: 0.1231\n",
      "Iteration: 5700, Train loss: -0.8666, rewards: 0.1775\n",
      "Eval:\n",
      "Hits@1: 0.2050, Hits@3: 0.2900, Hits@10: 0.3850, MRR: 0.2637\n",
      "------------------------------------------------------------\n",
      "Iteration: 5710, Train loss: -0.6926, rewards: 0.1394\n",
      "Iteration: 5720, Train loss: -0.6776, rewards: 0.0856\n",
      "Iteration: 5730, Train loss: -0.9100, rewards: 0.2013\n",
      "Iteration: 5740, Train loss: -0.9281, rewards: 0.1950\n",
      "Iteration: 5750, Train loss: -0.7681, rewards: 0.1244\n",
      "Iteration: 5760, Train loss: -0.9623, rewards: 0.2037\n",
      "Iteration: 5770, Train loss: -0.9418, rewards: 0.1806\n",
      "Iteration: 5780, Train loss: -0.9070, rewards: 0.2144\n",
      "Iteration: 5790, Train loss: -0.6742, rewards: 0.1219\n",
      "Iteration: 5800, Train loss: -0.8427, rewards: 0.2338\n",
      "Eval:\n",
      "Hits@1: 0.2084, Hits@3: 0.2965, Hits@10: 0.3924, MRR: 0.2683\n",
      "------------------------------------------------------------\n",
      "Iteration: 5810, Train loss: -0.8215, rewards: 0.1406\n",
      "Iteration: 5820, Train loss: -0.8775, rewards: 0.2019\n",
      "Iteration: 5830, Train loss: -0.7386, rewards: 0.1906\n",
      "Iteration: 5840, Train loss: -0.6787, rewards: 0.1206\n",
      "Iteration: 5850, Train loss: -0.6080, rewards: 0.0938\n",
      "Iteration: 5860, Train loss: -0.7617, rewards: 0.1231\n",
      "Iteration: 5870, Train loss: -0.5839, rewards: 0.1100\n",
      "Iteration: 5880, Train loss: -0.9108, rewards: 0.1794\n",
      "Iteration: 5890, Train loss: -0.6790, rewards: 0.1375\n",
      "Iteration: 5900, Train loss: -0.8330, rewards: 0.1237\n",
      "Eval:\n",
      "Hits@1: 0.2119, Hits@3: 0.2976, Hits@10: 0.3862, MRR: 0.2695\n",
      "------------------------------------------------------------\n",
      "Iteration: 5910, Train loss: -0.7816, rewards: 0.1275\n",
      "Iteration: 5920, Train loss: -0.7348, rewards: 0.1425\n",
      "Iteration: 5930, Train loss: -0.8131, rewards: 0.1756\n",
      "Iteration: 5940, Train loss: -0.8637, rewards: 0.1444\n",
      "Iteration: 5950, Train loss: -0.6583, rewards: 0.1437\n",
      "Iteration: 5960, Train loss: -0.7297, rewards: 0.1394\n",
      "Iteration: 5970, Train loss: -0.7064, rewards: 0.1087\n",
      "Iteration: 5980, Train loss: -0.7355, rewards: 0.2125\n",
      "Iteration: 5990, Train loss: -0.7118, rewards: 0.1594\n",
      "Iteration: 6000, Train loss: -0.6720, rewards: 0.1363\n",
      "Eval:\n",
      "Hits@1: 0.2072, Hits@3: 0.2919, Hits@10: 0.3906, MRR: 0.2666\n",
      "------------------------------------------------------------\n",
      "Iteration: 6010, Train loss: -0.9711, rewards: 0.1669\n",
      "Iteration: 6020, Train loss: -0.9032, rewards: 0.1762\n",
      "Iteration: 6030, Train loss: -0.8576, rewards: 0.1881\n",
      "Iteration: 6040, Train loss: -0.8797, rewards: 0.2263\n",
      "Iteration: 6050, Train loss: -0.8910, rewards: 0.2075\n",
      "Iteration: 6060, Train loss: -0.6079, rewards: 0.1225\n",
      "Iteration: 6070, Train loss: -0.7886, rewards: 0.1800\n",
      "Iteration: 6080, Train loss: -0.8526, rewards: 0.1625\n",
      "Iteration: 6090, Train loss: -0.9010, rewards: 0.1681\n",
      "Iteration: 6100, Train loss: -0.9837, rewards: 0.2062\n",
      "Eval:\n",
      "Hits@1: 0.2065, Hits@3: 0.2934, Hits@10: 0.3877, MRR: 0.2659\n",
      "------------------------------------------------------------\n",
      "Iteration: 6110, Train loss: -0.6591, rewards: 0.1000\n",
      "Iteration: 6120, Train loss: -0.7750, rewards: 0.1925\n",
      "Iteration: 6130, Train loss: -0.7962, rewards: 0.1656\n",
      "Iteration: 6140, Train loss: -1.0082, rewards: 0.2025\n",
      "Iteration: 6150, Train loss: -0.7760, rewards: 0.1663\n",
      "Iteration: 6160, Train loss: -0.8033, rewards: 0.1288\n",
      "Iteration: 6170, Train loss: -0.7955, rewards: 0.1856\n",
      "Iteration: 6180, Train loss: -0.8747, rewards: 0.1725\n",
      "Iteration: 6190, Train loss: -0.9760, rewards: 0.2050\n",
      "Iteration: 6200, Train loss: -0.6867, rewards: 0.1388\n",
      "Eval:\n",
      "Hits@1: 0.2050, Hits@3: 0.2945, Hits@10: 0.3887, MRR: 0.2657\n",
      "------------------------------------------------------------\n",
      "Iteration: 6210, Train loss: -0.7892, rewards: 0.1363\n",
      "Iteration: 6220, Train loss: -0.7360, rewards: 0.1581\n",
      "Iteration: 6230, Train loss: -0.7799, rewards: 0.1263\n",
      "Iteration: 6240, Train loss: -0.7066, rewards: 0.1681\n",
      "Iteration: 6250, Train loss: -0.7002, rewards: 0.1144\n",
      "Iteration: 6260, Train loss: -0.8498, rewards: 0.1713\n",
      "Iteration: 6270, Train loss: -0.7400, rewards: 0.1150\n",
      "Iteration: 6280, Train loss: -1.0734, rewards: 0.2331\n",
      "Iteration: 6290, Train loss: -0.8061, rewards: 0.1956\n",
      "Iteration: 6300, Train loss: -0.6752, rewards: 0.1619\n",
      "Eval:\n",
      "Hits@1: 0.1966, Hits@3: 0.2806, Hits@10: 0.3778, MRR: 0.2552\n",
      "------------------------------------------------------------\n",
      "Iteration: 6310, Train loss: -0.8508, rewards: 0.2213\n",
      "Iteration: 6320, Train loss: -0.8624, rewards: 0.1806\n",
      "Iteration: 6330, Train loss: -0.8056, rewards: 0.1731\n",
      "Iteration: 6340, Train loss: -0.6336, rewards: 0.1556\n",
      "Iteration: 6350, Train loss: -0.5304, rewards: 0.0950\n",
      "Iteration: 6360, Train loss: -1.0180, rewards: 0.1956\n",
      "Iteration: 6370, Train loss: -0.5836, rewards: 0.1181\n",
      "Iteration: 6380, Train loss: -0.8496, rewards: 0.1588\n",
      "Iteration: 6390, Train loss: -0.8397, rewards: 0.1569\n",
      "Iteration: 6400, Train loss: -0.8039, rewards: 0.1638\n",
      "Eval:\n",
      "Hits@1: 0.2031, Hits@3: 0.2981, Hits@10: 0.3971, MRR: 0.2665\n",
      "------------------------------------------------------------\n",
      "Iteration: 6410, Train loss: -0.8160, rewards: 0.1713\n",
      "Iteration: 6420, Train loss: -0.7748, rewards: 0.1306\n",
      "Iteration: 6430, Train loss: -0.8118, rewards: 0.1437\n",
      "Iteration: 6440, Train loss: -0.9166, rewards: 0.2306\n",
      "Iteration: 6450, Train loss: -0.8447, rewards: 0.1575\n",
      "Iteration: 6460, Train loss: -0.8004, rewards: 0.1556\n",
      "Iteration: 6470, Train loss: -0.8174, rewards: 0.1913\n",
      "Iteration: 6480, Train loss: -0.7284, rewards: 0.1706\n",
      "Iteration: 6490, Train loss: -1.0747, rewards: 0.1881\n",
      "Iteration: 6500, Train loss: -0.6895, rewards: 0.1363\n",
      "Eval:\n",
      "Hits@1: 0.2116, Hits@3: 0.2968, Hits@10: 0.3938, MRR: 0.2710\n",
      "------------------------------------------------------------\n",
      "Iteration: 6510, Train loss: -0.9003, rewards: 0.1688\n",
      "Iteration: 6520, Train loss: -0.6848, rewards: 0.1412\n",
      "Iteration: 6530, Train loss: -0.8255, rewards: 0.1356\n",
      "Iteration: 6540, Train loss: -0.6493, rewards: 0.1100\n",
      "Iteration: 6550, Train loss: -0.8892, rewards: 0.1806\n",
      "Iteration: 6560, Train loss: -0.7994, rewards: 0.1975\n",
      "Iteration: 6570, Train loss: -0.9359, rewards: 0.1663\n",
      "Iteration: 6580, Train loss: -0.9901, rewards: 0.2350\n",
      "Iteration: 6590, Train loss: -0.9897, rewards: 0.1950\n",
      "Iteration: 6600, Train loss: -0.8434, rewards: 0.1781\n",
      "Eval:\n",
      "Hits@1: 0.2058, Hits@3: 0.2928, Hits@10: 0.3878, MRR: 0.2655\n",
      "------------------------------------------------------------\n",
      "Iteration: 6610, Train loss: -0.8841, rewards: 0.1562\n",
      "Iteration: 6620, Train loss: -0.7120, rewards: 0.1369\n",
      "Iteration: 6630, Train loss: -0.8441, rewards: 0.1900\n",
      "Iteration: 6640, Train loss: -0.7207, rewards: 0.1350\n",
      "Iteration: 6650, Train loss: -0.7319, rewards: 0.1656\n",
      "Iteration: 6660, Train loss: -0.7454, rewards: 0.1412\n",
      "Iteration: 6670, Train loss: -0.7983, rewards: 0.1575\n",
      "Iteration: 6680, Train loss: -0.7896, rewards: 0.1525\n",
      "Iteration: 6690, Train loss: -0.8284, rewards: 0.1713\n",
      "Iteration: 6700, Train loss: -0.8937, rewards: 0.1787\n",
      "Eval:\n",
      "Hits@1: 0.2048, Hits@3: 0.2979, Hits@10: 0.3964, MRR: 0.2679\n",
      "------------------------------------------------------------\n",
      "Iteration: 6710, Train loss: -0.7202, rewards: 0.1062\n",
      "Iteration: 6720, Train loss: -0.5072, rewards: 0.0800\n",
      "Iteration: 6730, Train loss: -0.8285, rewards: 0.1531\n",
      "Iteration: 6740, Train loss: -0.6644, rewards: 0.1119\n",
      "Iteration: 6750, Train loss: -0.7794, rewards: 0.1194\n",
      "Iteration: 6760, Train loss: -0.7346, rewards: 0.1525\n",
      "Iteration: 6770, Train loss: -0.8861, rewards: 0.2394\n",
      "Iteration: 6780, Train loss: -0.7904, rewards: 0.1656\n",
      "Iteration: 6790, Train loss: -0.8149, rewards: 0.1713\n",
      "Iteration: 6800, Train loss: -0.8977, rewards: 0.2188\n",
      "Eval:\n",
      "Hits@1: 0.2069, Hits@3: 0.2982, Hits@10: 0.3887, MRR: 0.2674\n",
      "------------------------------------------------------------\n",
      "Iteration: 6810, Train loss: -0.7900, rewards: 0.1250\n",
      "Iteration: 6820, Train loss: -0.9245, rewards: 0.1931\n",
      "Iteration: 6830, Train loss: -0.5131, rewards: 0.1175\n",
      "Iteration: 6840, Train loss: -0.6433, rewards: 0.1269\n",
      "Iteration: 6850, Train loss: -0.7404, rewards: 0.1725\n",
      "Iteration: 6860, Train loss: -0.9349, rewards: 0.1806\n",
      "Iteration: 6870, Train loss: -0.9544, rewards: 0.2394\n",
      "Iteration: 6880, Train loss: -0.7521, rewards: 0.1981\n",
      "Iteration: 6890, Train loss: -0.6554, rewards: 0.1444\n",
      "Iteration: 6900, Train loss: -0.5390, rewards: 0.0881\n",
      "Eval:\n",
      "Hits@1: 0.2086, Hits@3: 0.2960, Hits@10: 0.3919, MRR: 0.2684\n",
      "------------------------------------------------------------\n",
      "Iteration: 6910, Train loss: -0.5480, rewards: 0.1131\n",
      "Iteration: 6920, Train loss: -0.7445, rewards: 0.1288\n",
      "Iteration: 6930, Train loss: -0.8570, rewards: 0.1300\n",
      "Iteration: 6940, Train loss: -0.8739, rewards: 0.2119\n",
      "Iteration: 6950, Train loss: -0.7577, rewards: 0.2206\n",
      "Iteration: 6960, Train loss: -0.8090, rewards: 0.1750\n",
      "Iteration: 6970, Train loss: -0.6505, rewards: 0.1294\n",
      "Iteration: 6980, Train loss: -0.7257, rewards: 0.1450\n",
      "Iteration: 6990, Train loss: -0.6389, rewards: 0.1369\n",
      "Iteration: 7000, Train loss: -0.7016, rewards: 0.1644\n",
      "Eval:\n",
      "Hits@1: 0.2140, Hits@3: 0.3047, Hits@10: 0.3986, MRR: 0.2750\n",
      "------------------------------------------------------------\n",
      "Iteration: 7010, Train loss: -0.6893, rewards: 0.1869\n",
      "Iteration: 7020, Train loss: -0.6951, rewards: 0.1562\n",
      "Iteration: 7030, Train loss: -0.9636, rewards: 0.1994\n",
      "Iteration: 7040, Train loss: -0.8276, rewards: 0.1681\n",
      "Iteration: 7050, Train loss: -0.8415, rewards: 0.1975\n",
      "Iteration: 7060, Train loss: -0.6678, rewards: 0.1369\n",
      "Iteration: 7070, Train loss: -0.7722, rewards: 0.1725\n",
      "Iteration: 7080, Train loss: -0.8654, rewards: 0.1437\n",
      "Iteration: 7090, Train loss: -0.9126, rewards: 0.2344\n",
      "Iteration: 7100, Train loss: -0.9044, rewards: 0.1844\n",
      "Eval:\n",
      "Hits@1: 0.2116, Hits@3: 0.3009, Hits@10: 0.3917, MRR: 0.2719\n",
      "------------------------------------------------------------\n",
      "Iteration: 7110, Train loss: -0.6909, rewards: 0.1700\n",
      "Iteration: 7120, Train loss: -0.8166, rewards: 0.1537\n",
      "Iteration: 7130, Train loss: -0.7213, rewards: 0.1212\n",
      "Iteration: 7140, Train loss: -0.7353, rewards: 0.1462\n",
      "Iteration: 7150, Train loss: -0.9230, rewards: 0.1925\n",
      "Iteration: 7160, Train loss: -0.8810, rewards: 0.1638\n",
      "Iteration: 7170, Train loss: -0.6743, rewards: 0.1487\n",
      "Iteration: 7180, Train loss: -0.7552, rewards: 0.1981\n",
      "Iteration: 7190, Train loss: -0.8095, rewards: 0.1731\n",
      "Iteration: 7200, Train loss: -0.7339, rewards: 0.1644\n",
      "Eval:\n",
      "Hits@1: 0.2205, Hits@3: 0.3135, Hits@10: 0.4072, MRR: 0.2825\n",
      "------------------------------------------------------------\n",
      "Iteration: 7210, Train loss: -0.9254, rewards: 0.1994\n",
      "Iteration: 7220, Train loss: -0.8339, rewards: 0.1737\n",
      "Iteration: 7230, Train loss: -0.9179, rewards: 0.1638\n",
      "Iteration: 7240, Train loss: -1.0100, rewards: 0.1831\n",
      "Iteration: 7250, Train loss: -0.7724, rewards: 0.1875\n",
      "Iteration: 7260, Train loss: -0.7071, rewards: 0.1781\n",
      "Iteration: 7270, Train loss: -0.6889, rewards: 0.1331\n",
      "Iteration: 7280, Train loss: -0.8228, rewards: 0.1588\n",
      "Iteration: 7290, Train loss: -0.9324, rewards: 0.1644\n",
      "Iteration: 7300, Train loss: -0.6868, rewards: 0.1537\n",
      "Eval:\n",
      "Hits@1: 0.2088, Hits@3: 0.2971, Hits@10: 0.3937, MRR: 0.2692\n",
      "------------------------------------------------------------\n",
      "Iteration: 7310, Train loss: -0.7568, rewards: 0.1644\n",
      "Iteration: 7320, Train loss: -0.7435, rewards: 0.1806\n",
      "Iteration: 7330, Train loss: -0.6288, rewards: 0.1150\n",
      "Iteration: 7340, Train loss: -0.8972, rewards: 0.1819\n",
      "Iteration: 7350, Train loss: -0.8922, rewards: 0.1806\n",
      "Iteration: 7360, Train loss: -0.8809, rewards: 0.2000\n",
      "Iteration: 7370, Train loss: -0.8882, rewards: 0.1812\n",
      "Iteration: 7380, Train loss: -0.9395, rewards: 0.1706\n",
      "Iteration: 7390, Train loss: -0.7596, rewards: 0.2050\n",
      "Iteration: 7400, Train loss: -0.7568, rewards: 0.1775\n",
      "Eval:\n",
      "Hits@1: 0.2107, Hits@3: 0.2978, Hits@10: 0.3908, MRR: 0.2696\n",
      "------------------------------------------------------------\n",
      "Iteration: 7410, Train loss: -0.7483, rewards: 0.1537\n",
      "Iteration: 7420, Train loss: -0.8501, rewards: 0.1787\n",
      "Iteration: 7430, Train loss: -0.8054, rewards: 0.1675\n",
      "Iteration: 7440, Train loss: -0.9204, rewards: 0.1994\n",
      "Iteration: 7450, Train loss: -0.8699, rewards: 0.1825\n",
      "Iteration: 7460, Train loss: -1.0535, rewards: 0.1906\n",
      "Iteration: 7470, Train loss: -0.8073, rewards: 0.1675\n",
      "Iteration: 7480, Train loss: -0.8141, rewards: 0.1431\n",
      "Iteration: 7490, Train loss: -0.7123, rewards: 0.1412\n",
      "Iteration: 7500, Train loss: -0.7032, rewards: 0.2056\n",
      "Eval:\n",
      "Hits@1: 0.2168, Hits@3: 0.3006, Hits@10: 0.3927, MRR: 0.2745\n",
      "------------------------------------------------------------\n",
      "Iteration: 7510, Train loss: -0.7239, rewards: 0.1619\n",
      "Iteration: 7520, Train loss: -0.9781, rewards: 0.2013\n",
      "Iteration: 7530, Train loss: -0.8498, rewards: 0.1862\n",
      "Iteration: 7540, Train loss: -0.7305, rewards: 0.1363\n",
      "Iteration: 7550, Train loss: -0.8694, rewards: 0.1519\n",
      "Iteration: 7560, Train loss: -0.7548, rewards: 0.1506\n",
      "Iteration: 7570, Train loss: -0.8616, rewards: 0.1719\n",
      "Iteration: 7580, Train loss: -0.8591, rewards: 0.1719\n",
      "Iteration: 7590, Train loss: -0.8700, rewards: 0.1444\n",
      "Iteration: 7600, Train loss: -0.8253, rewards: 0.1512\n",
      "Eval:\n",
      "Hits@1: 0.2120, Hits@3: 0.2968, Hits@10: 0.3910, MRR: 0.2707\n",
      "------------------------------------------------------------\n",
      "Iteration: 7610, Train loss: -0.5555, rewards: 0.1050\n",
      "Iteration: 7620, Train loss: -0.8883, rewards: 0.2475\n",
      "Iteration: 7630, Train loss: -0.9813, rewards: 0.2338\n",
      "Iteration: 7640, Train loss: -0.7993, rewards: 0.1494\n",
      "Iteration: 7650, Train loss: -0.9186, rewards: 0.1831\n",
      "Iteration: 7660, Train loss: -1.0734, rewards: 0.1919\n",
      "Iteration: 7670, Train loss: -0.9620, rewards: 0.2213\n",
      "Iteration: 7680, Train loss: -0.7471, rewards: 0.1825\n",
      "Iteration: 7690, Train loss: -0.9913, rewards: 0.2075\n",
      "Iteration: 7700, Train loss: -0.9396, rewards: 0.2131\n",
      "Eval:\n",
      "Hits@1: 0.2052, Hits@3: 0.2889, Hits@10: 0.3802, MRR: 0.2627\n",
      "------------------------------------------------------------\n",
      "Iteration: 7710, Train loss: -0.8359, rewards: 0.1656\n",
      "Iteration: 7720, Train loss: -0.9267, rewards: 0.2356\n",
      "Iteration: 7730, Train loss: -0.7671, rewards: 0.1450\n",
      "Iteration: 7740, Train loss: -0.8208, rewards: 0.1931\n",
      "Iteration: 7750, Train loss: -0.8419, rewards: 0.1144\n",
      "Iteration: 7760, Train loss: -0.6694, rewards: 0.1356\n",
      "Iteration: 7770, Train loss: -0.8853, rewards: 0.1694\n",
      "Iteration: 7780, Train loss: -0.9777, rewards: 0.2050\n",
      "Iteration: 7790, Train loss: -0.9021, rewards: 0.1638\n",
      "Iteration: 7800, Train loss: -0.7999, rewards: 0.1388\n",
      "Eval:\n",
      "Hits@1: 0.2135, Hits@3: 0.3014, Hits@10: 0.3928, MRR: 0.2732\n",
      "------------------------------------------------------------\n",
      "Iteration: 7810, Train loss: -0.7877, rewards: 0.1494\n",
      "Iteration: 7820, Train loss: -0.7125, rewards: 0.1081\n",
      "Iteration: 7830, Train loss: -0.9354, rewards: 0.1769\n",
      "Iteration: 7840, Train loss: -0.9861, rewards: 0.1869\n",
      "Iteration: 7850, Train loss: -0.8475, rewards: 0.2362\n",
      "Iteration: 7860, Train loss: -0.7997, rewards: 0.1437\n",
      "Iteration: 7870, Train loss: -0.8277, rewards: 0.1825\n",
      "Iteration: 7880, Train loss: -0.8192, rewards: 0.1913\n",
      "Iteration: 7890, Train loss: -0.8320, rewards: 0.2275\n",
      "Iteration: 7900, Train loss: -0.7744, rewards: 0.1963\n",
      "Eval:\n",
      "Hits@1: 0.2121, Hits@3: 0.3030, Hits@10: 0.3924, MRR: 0.2727\n",
      "------------------------------------------------------------\n",
      "Iteration: 7910, Train loss: -0.8551, rewards: 0.1569\n",
      "Iteration: 7920, Train loss: -0.9895, rewards: 0.1931\n",
      "Iteration: 7930, Train loss: -0.7440, rewards: 0.1363\n",
      "Iteration: 7940, Train loss: -0.8812, rewards: 0.1819\n",
      "Iteration: 7950, Train loss: -0.8458, rewards: 0.1688\n",
      "Iteration: 7960, Train loss: -0.8104, rewards: 0.2162\n",
      "Iteration: 7970, Train loss: -0.8231, rewards: 0.1888\n",
      "Iteration: 7980, Train loss: -0.7520, rewards: 0.1556\n",
      "Iteration: 7990, Train loss: -0.8751, rewards: 0.1775\n",
      "Iteration: 8000, Train loss: -0.9147, rewards: 0.2275\n",
      "Eval:\n",
      "Hits@1: 0.2156, Hits@3: 0.3090, Hits@10: 0.4012, MRR: 0.2771\n",
      "------------------------------------------------------------\n",
      "Iteration: 8010, Train loss: -0.8457, rewards: 0.1512\n",
      "Iteration: 8020, Train loss: -0.8214, rewards: 0.1181\n",
      "Iteration: 8030, Train loss: -0.7902, rewards: 0.2013\n",
      "Iteration: 8040, Train loss: -0.7252, rewards: 0.1656\n",
      "Iteration: 8050, Train loss: -0.9023, rewards: 0.1975\n",
      "Iteration: 8060, Train loss: -0.7094, rewards: 0.1806\n",
      "Iteration: 8070, Train loss: -0.8445, rewards: 0.1562\n",
      "Iteration: 8080, Train loss: -0.7969, rewards: 0.1325\n",
      "Iteration: 8090, Train loss: -0.7838, rewards: 0.2075\n",
      "Iteration: 8100, Train loss: -0.8288, rewards: 0.1806\n",
      "Eval:\n",
      "Hits@1: 0.2164, Hits@3: 0.3075, Hits@10: 0.3972, MRR: 0.2771\n",
      "------------------------------------------------------------\n",
      "Iteration: 8110, Train loss: -1.0799, rewards: 0.2144\n",
      "Iteration: 8120, Train loss: -0.7902, rewards: 0.1606\n",
      "Iteration: 8130, Train loss: -0.7202, rewards: 0.1938\n",
      "Iteration: 8140, Train loss: -0.8786, rewards: 0.1625\n",
      "Iteration: 8150, Train loss: -0.8266, rewards: 0.2044\n",
      "Iteration: 8160, Train loss: -0.8777, rewards: 0.1869\n",
      "Iteration: 8170, Train loss: -0.8223, rewards: 0.1588\n",
      "Iteration: 8180, Train loss: -0.8242, rewards: 0.1988\n",
      "Iteration: 8190, Train loss: -0.9573, rewards: 0.2081\n",
      "Iteration: 8200, Train loss: -0.5665, rewards: 0.1087\n",
      "Eval:\n",
      "Hits@1: 0.2127, Hits@3: 0.3035, Hits@10: 0.3934, MRR: 0.2728\n",
      "------------------------------------------------------------\n",
      "Iteration: 8210, Train loss: -0.7305, rewards: 0.1750\n",
      "Iteration: 8220, Train loss: -0.8330, rewards: 0.2019\n",
      "Iteration: 8230, Train loss: -0.8271, rewards: 0.2275\n",
      "Iteration: 8240, Train loss: -0.8151, rewards: 0.2000\n",
      "Iteration: 8250, Train loss: -0.8873, rewards: 0.2137\n",
      "Iteration: 8260, Train loss: -0.8865, rewards: 0.1544\n",
      "Iteration: 8270, Train loss: -0.7750, rewards: 0.1331\n",
      "Iteration: 8280, Train loss: -0.9174, rewards: 0.2137\n",
      "Iteration: 8290, Train loss: -0.9021, rewards: 0.1806\n",
      "Iteration: 8300, Train loss: -0.7609, rewards: 0.1394\n",
      "Eval:\n",
      "Hits@1: 0.2189, Hits@3: 0.3071, Hits@10: 0.3978, MRR: 0.2786\n",
      "------------------------------------------------------------\n",
      "Iteration: 8310, Train loss: -0.7780, rewards: 0.1881\n",
      "Iteration: 8320, Train loss: -0.9094, rewards: 0.2188\n",
      "Iteration: 8330, Train loss: -0.7071, rewards: 0.1400\n",
      "Iteration: 8340, Train loss: -0.8446, rewards: 0.1737\n",
      "Iteration: 8350, Train loss: -0.8075, rewards: 0.1519\n",
      "Iteration: 8360, Train loss: -0.9426, rewards: 0.2056\n",
      "Iteration: 8370, Train loss: -0.7243, rewards: 0.1481\n",
      "Iteration: 8380, Train loss: -0.8929, rewards: 0.1894\n",
      "Iteration: 8390, Train loss: -0.7084, rewards: 0.1206\n",
      "Iteration: 8400, Train loss: -0.8792, rewards: 0.2019\n",
      "Eval:\n",
      "Hits@1: 0.2152, Hits@3: 0.2989, Hits@10: 0.3842, MRR: 0.2713\n",
      "------------------------------------------------------------\n",
      "Iteration: 8410, Train loss: -0.7612, rewards: 0.1644\n",
      "Iteration: 8420, Train loss: -0.7844, rewards: 0.1331\n",
      "Iteration: 8430, Train loss: -0.8534, rewards: 0.1713\n",
      "Iteration: 8440, Train loss: -0.7055, rewards: 0.1237\n",
      "Iteration: 8450, Train loss: -0.8575, rewards: 0.1819\n",
      "Iteration: 8460, Train loss: -0.7397, rewards: 0.1000\n",
      "Iteration: 8470, Train loss: -0.6970, rewards: 0.1719\n",
      "Iteration: 8480, Train loss: -0.9257, rewards: 0.1669\n",
      "Iteration: 8490, Train loss: -0.7953, rewards: 0.1681\n",
      "Iteration: 8500, Train loss: -0.7462, rewards: 0.1450\n",
      "Eval:\n",
      "Hits@1: 0.2179, Hits@3: 0.3049, Hits@10: 0.3926, MRR: 0.2761\n",
      "------------------------------------------------------------\n",
      "Iteration: 8510, Train loss: -0.9725, rewards: 0.1644\n",
      "Iteration: 8520, Train loss: -0.9388, rewards: 0.1875\n",
      "Iteration: 8530, Train loss: -0.9404, rewards: 0.2169\n",
      "Iteration: 8540, Train loss: -0.7569, rewards: 0.1688\n",
      "Iteration: 8550, Train loss: -0.9791, rewards: 0.2094\n",
      "Iteration: 8560, Train loss: -0.8206, rewards: 0.1431\n",
      "Iteration: 8570, Train loss: -0.8005, rewards: 0.2075\n",
      "Iteration: 8580, Train loss: -0.8255, rewards: 0.1263\n",
      "Iteration: 8590, Train loss: -0.8917, rewards: 0.1900\n",
      "Iteration: 8600, Train loss: -0.8438, rewards: 0.1613\n",
      "Eval:\n",
      "Hits@1: 0.2164, Hits@3: 0.3084, Hits@10: 0.3966, MRR: 0.2765\n",
      "------------------------------------------------------------\n",
      "Iteration: 8610, Train loss: -0.8950, rewards: 0.1750\n",
      "Iteration: 8620, Train loss: -0.6780, rewards: 0.1219\n",
      "Iteration: 8630, Train loss: -0.7205, rewards: 0.1950\n",
      "Iteration: 8640, Train loss: -0.7957, rewards: 0.1762\n",
      "Iteration: 8650, Train loss: -0.9817, rewards: 0.1806\n",
      "Iteration: 8660, Train loss: -0.7095, rewards: 0.1638\n",
      "Iteration: 8670, Train loss: -0.8579, rewards: 0.1400\n",
      "Iteration: 8680, Train loss: -0.5591, rewards: 0.0800\n",
      "Iteration: 8690, Train loss: -0.8046, rewards: 0.1388\n",
      "Iteration: 8700, Train loss: -0.6764, rewards: 0.1187\n",
      "Eval:\n",
      "Hits@1: 0.2155, Hits@3: 0.3099, Hits@10: 0.3985, MRR: 0.2770\n",
      "------------------------------------------------------------\n",
      "Iteration: 8710, Train loss: -0.7566, rewards: 0.1569\n",
      "Iteration: 8720, Train loss: -0.7006, rewards: 0.1200\n",
      "Iteration: 8730, Train loss: -0.8841, rewards: 0.1800\n",
      "Iteration: 8740, Train loss: -0.7940, rewards: 0.1344\n",
      "Iteration: 8750, Train loss: -0.8588, rewards: 0.2356\n",
      "Iteration: 8760, Train loss: -0.9462, rewards: 0.1613\n",
      "Iteration: 8770, Train loss: -1.0057, rewards: 0.1994\n",
      "Iteration: 8780, Train loss: -0.8465, rewards: 0.1313\n",
      "Iteration: 8790, Train loss: -0.8031, rewards: 0.1288\n",
      "Iteration: 8800, Train loss: -0.8242, rewards: 0.1594\n",
      "Eval:\n",
      "Hits@1: 0.2149, Hits@3: 0.3039, Hits@10: 0.3973, MRR: 0.2749\n",
      "------------------------------------------------------------\n",
      "Iteration: 8810, Train loss: -0.7995, rewards: 0.1512\n",
      "Iteration: 8820, Train loss: -0.9536, rewards: 0.1938\n",
      "Iteration: 8830, Train loss: -0.8743, rewards: 0.1862\n",
      "Iteration: 8840, Train loss: -0.9319, rewards: 0.2150\n",
      "Iteration: 8850, Train loss: -0.8848, rewards: 0.1769\n",
      "Iteration: 8860, Train loss: -0.6723, rewards: 0.1225\n",
      "Iteration: 8870, Train loss: -1.0645, rewards: 0.2406\n",
      "Iteration: 8880, Train loss: -0.9425, rewards: 0.2013\n",
      "Iteration: 8890, Train loss: -0.8703, rewards: 0.1594\n",
      "Iteration: 8900, Train loss: -0.8125, rewards: 0.1625\n",
      "Eval:\n",
      "Hits@1: 0.2170, Hits@3: 0.3022, Hits@10: 0.3924, MRR: 0.2750\n",
      "------------------------------------------------------------\n",
      "Iteration: 8910, Train loss: -0.8332, rewards: 0.1619\n",
      "Iteration: 8920, Train loss: -0.7340, rewards: 0.1138\n",
      "Iteration: 8930, Train loss: -0.9176, rewards: 0.1475\n",
      "Iteration: 8940, Train loss: -0.7726, rewards: 0.1650\n",
      "Iteration: 8950, Train loss: -0.8630, rewards: 0.1931\n",
      "Iteration: 8960, Train loss: -0.6946, rewards: 0.1456\n",
      "Iteration: 8970, Train loss: -0.7848, rewards: 0.1469\n",
      "Iteration: 8980, Train loss: -0.9376, rewards: 0.1831\n",
      "Iteration: 8990, Train loss: -0.7226, rewards: 0.1138\n",
      "Iteration: 9000, Train loss: -0.8405, rewards: 0.1519\n",
      "Eval:\n",
      "Hits@1: 0.2127, Hits@3: 0.2987, Hits@10: 0.3839, MRR: 0.2705\n",
      "------------------------------------------------------------\n",
      "Iteration: 9010, Train loss: -0.8684, rewards: 0.1500\n",
      "Iteration: 9020, Train loss: -0.9254, rewards: 0.1906\n",
      "Iteration: 9030, Train loss: -0.5978, rewards: 0.0944\n",
      "Iteration: 9040, Train loss: -0.7907, rewards: 0.2175\n",
      "Iteration: 9050, Train loss: -0.9882, rewards: 0.2419\n",
      "Iteration: 9060, Train loss: -0.7861, rewards: 0.1975\n",
      "Iteration: 9070, Train loss: -0.8131, rewards: 0.1975\n",
      "Iteration: 9080, Train loss: -0.6785, rewards: 0.1444\n",
      "Iteration: 9090, Train loss: -0.7988, rewards: 0.1875\n",
      "Iteration: 9100, Train loss: -0.8544, rewards: 0.1844\n",
      "Eval:\n",
      "Hits@1: 0.2176, Hits@3: 0.3046, Hits@10: 0.3897, MRR: 0.2755\n",
      "------------------------------------------------------------\n",
      "Iteration: 9110, Train loss: -0.7466, rewards: 0.1512\n",
      "Iteration: 9120, Train loss: -0.8692, rewards: 0.1550\n",
      "Iteration: 9130, Train loss: -0.7754, rewards: 0.1994\n",
      "Iteration: 9140, Train loss: -0.7332, rewards: 0.1950\n",
      "Iteration: 9150, Train loss: -0.6817, rewards: 0.1506\n",
      "Iteration: 9160, Train loss: -1.1031, rewards: 0.2213\n",
      "Iteration: 9170, Train loss: -0.9550, rewards: 0.1794\n",
      "Iteration: 9180, Train loss: -1.0963, rewards: 0.2281\n",
      "Iteration: 9190, Train loss: -0.7999, rewards: 0.1894\n",
      "Iteration: 9200, Train loss: -0.7645, rewards: 0.2225\n",
      "Eval:\n",
      "Hits@1: 0.2176, Hits@3: 0.3078, Hits@10: 0.3990, MRR: 0.2781\n",
      "------------------------------------------------------------\n",
      "Iteration: 9210, Train loss: -0.8010, rewards: 0.1925\n",
      "Iteration: 9220, Train loss: -0.8149, rewards: 0.1313\n",
      "Iteration: 9230, Train loss: -0.7322, rewards: 0.1419\n",
      "Iteration: 9240, Train loss: -0.9009, rewards: 0.2125\n",
      "Iteration: 9250, Train loss: -0.8512, rewards: 0.1706\n",
      "Iteration: 9260, Train loss: -0.8489, rewards: 0.1800\n",
      "Iteration: 9270, Train loss: -0.8111, rewards: 0.1606\n",
      "Iteration: 9280, Train loss: -0.8333, rewards: 0.2181\n",
      "Iteration: 9290, Train loss: -0.8473, rewards: 0.2550\n",
      "Iteration: 9300, Train loss: -0.9095, rewards: 0.2331\n",
      "Eval:\n",
      "Hits@1: 0.2178, Hits@3: 0.3060, Hits@10: 0.3963, MRR: 0.2771\n",
      "------------------------------------------------------------\n",
      "Iteration: 9310, Train loss: -0.7287, rewards: 0.1244\n",
      "Iteration: 9320, Train loss: -0.7167, rewards: 0.1444\n",
      "Iteration: 9330, Train loss: -0.8891, rewards: 0.1731\n",
      "Iteration: 9340, Train loss: -0.6893, rewards: 0.1781\n",
      "Iteration: 9350, Train loss: -0.5860, rewards: 0.1131\n",
      "Iteration: 9360, Train loss: -0.8824, rewards: 0.1888\n",
      "Iteration: 9370, Train loss: -1.1471, rewards: 0.2013\n",
      "Iteration: 9380, Train loss: -0.8555, rewards: 0.2181\n",
      "Iteration: 9390, Train loss: -0.9782, rewards: 0.2500\n",
      "Iteration: 9400, Train loss: -0.7492, rewards: 0.1631\n",
      "Eval:\n",
      "Hits@1: 0.2129, Hits@3: 0.2988, Hits@10: 0.3886, MRR: 0.2715\n",
      "------------------------------------------------------------\n",
      "Iteration: 9410, Train loss: -0.7721, rewards: 0.1456\n",
      "Iteration: 9420, Train loss: -0.7650, rewards: 0.1588\n",
      "Iteration: 9430, Train loss: -0.8794, rewards: 0.1819\n",
      "Iteration: 9440, Train loss: -0.8249, rewards: 0.1713\n",
      "Iteration: 9450, Train loss: -0.9864, rewards: 0.2056\n",
      "Iteration: 9460, Train loss: -0.9458, rewards: 0.2194\n",
      "Iteration: 9470, Train loss: -0.8361, rewards: 0.1381\n",
      "Iteration: 9480, Train loss: -0.7301, rewards: 0.1862\n",
      "Iteration: 9490, Train loss: -0.7667, rewards: 0.1450\n",
      "Iteration: 9500, Train loss: -0.8328, rewards: 0.1869\n",
      "Eval:\n"
     ]
    }
   ],
   "source": [
    "trainer = Trainer(options)\n",
    "trainer.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "6c2ad0c6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3409973/1090773659.py:224: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
      "  return loss, new_state, F.log_softmax(scores), label_action, chosen_relation\n",
      "/tmp/ipykernel_3409973/598236006.py:327: UserWarning: __floordiv__ is deprecated, and its behavior will change in a future version of pytorch. It currently rounds toward 0 (like the 'trunc' function NOT 'floor'). This results in incorrect rounding for negative values. To keep the current behavior, use torch.div(a, b, rounding_mode='trunc'), or for actual floor division, use torch.div(a, b, rounding_mode='floor').\n",
      "  y = idx // self.max_num_actions\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hits@1: 0.2273, Hits@3: 0.3130, Hits@10: 0.4084, MRR: 0.2864\n"
     ]
    }
   ],
   "source": [
    "trainer.agent.load_state_dict(torch.load(options['model_dir'] + 'agent.ckpt'))\n",
    "trainer.agent.eval()\n",
    "\n",
    "trainer.test_environment = trainer.test_test_environment\n",
    "trainer.test(beam=True, print_paths=False, save_model=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc9340fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# print_paths = True\n",
    "# with torch.no_grad():\n",
    "\n",
    "#     batch_counter = 0\n",
    "#     paths = defaultdict(list)\n",
    "#     answers = []\n",
    "#     all_final_reward_1 = 0\n",
    "#     all_final_reward_3 = 0\n",
    "#     all_final_reward_5 = 0\n",
    "#     all_final_reward_10 = 0\n",
    "#     all_final_reward_20 = 0\n",
    "#     auc = 0\n",
    "\n",
    "#     total_examples = self.test_environment.total_no_examples\n",
    "\n",
    "#     for entity_episode in self.test_environment.get_episodes():\n",
    "#         batch_counter += 1\n",
    "\n",
    "#         temp_batch_size = entity_episode.no_examples\n",
    "\n",
    "#         self.qr = entity_episode.get_query_relation()\n",
    "#         query_relation = self.qr\n",
    "#         query_relation = torch.tensor(query_relation).long().to(self.device)\n",
    "#         # set initial beam probs\n",
    "#         beam_probs = torch.zeros((temp_batch_size * self.test_rollouts, 1)).to(self.device)\n",
    "\n",
    "#         # get initial state for entity agent\n",
    "#         entity_state = entity_episode.get_state()\n",
    "\n",
    "#         head, link, tail = self.get_graph(entity_episode, mode = 'test')\n",
    "#         next_relations = torch.tensor(entity_state['next_relations']).long().to(self.device)\n",
    "#         next_entities = torch.tensor(entity_state['next_entities']).long().to(self.device)\n",
    "#         current_entities = torch.tensor(entity_state['current_entities']).long().to(self.device)\n",
    "\n",
    "#         entity_state_emb = torch.zeros(1, 2, temp_batch_size * self.test_rollouts,\n",
    "#                                        self.agent.m * self.hidden_size).to(self.device)\n",
    "#         prev_relation = (torch.ones(temp_batch_size * self.test_rollouts) * self.relation_vocab[\n",
    "#             'DUMMY_START_RELATION']).long().to(self.device)\n",
    "\n",
    "#         if print_paths:\n",
    "#             self.entity_trajectory = [current_entities]\n",
    "#             self.relation_trajectory = [prev_relation]   \n",
    "\n",
    "#         self.log_probs = np.zeros((temp_batch_size * self.test_rollouts,)) * 1.0\n",
    "#         for i in range(self.path_length):\n",
    "#             break\n",
    "#         break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f512a9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# next_relations, next_entities, prev_state = next_relations, next_entities, entity_state_emb\n",
    "# prev_relation, query_embedding, current_entities = prev_relation, query_relation,current_entities\n",
    "# head, link, tail = head, link, tail"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70c5dc8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with torch.no_grad():\n",
    "    \n",
    "#     n_ent = len(self.agent.entity_embedding.weight)\n",
    "#     n_rel = len(self.agent.relation_embedding.weight)\n",
    "    \n",
    "#     self.agent.ent_embed = self.agent.entity_embedding(torch.arange(n_ent).to(head.device))\n",
    "#     self.agent.rel_embed = self.agent.relation_embedding(torch.arange(n_rel).to(link.device))\n",
    "\n",
    "#     for i in range(2):\n",
    "#         self.agent.ent_embed = self.agent.node_conv[i](head, link, tail, \n",
    "#                                                 self.agent.ent_embed, self.agent.rel_embed)\n",
    "#         self.agent.rel_embed = self.agent.rel_conv[i](head, link, tail, \n",
    "#                                                 self.agent.ent_embed, self.agent.rel_embed)\n",
    "\n",
    "#     prev_action_embedding = self.agent.action_encoder(prev_relation, current_entities) # (original batch_size * num_rollout, 4*self.agent.embedding_size)\n",
    "\n",
    "#     prev_state = torch.unbind(prev_state, dim=1)\n",
    "#     prev_state = [prev_state[0].squeeze(0), prev_state[1].squeeze(0)]\n",
    "\n",
    "#     new_prev_state = list()\n",
    "\n",
    "#     output, new_state = self.agent.policy_step(prev_action_embedding, prev_state)\n",
    "\n",
    "#     prev_entity = self.agent.ent_embed[current_entities]\n",
    "#     if self.agent.use_entity_embeddings:\n",
    "#         state = torch.cat([output, prev_entity], dim=-1)\n",
    "#     else:\n",
    "#         state = output\n",
    "\n",
    "#     candidate_action_embeddings = self.agent.action_encoder(next_relations, next_entities)\n",
    "#     query_embedding = self.agent.rel_embed[query_embedding]\n",
    "\n",
    "#     state_query_concat = torch.cat([state, query_embedding], dim=-1)\n",
    "\n",
    "#     # MLP for policy#\n",
    "\n",
    "#     output = self.agent.policy_mlp(state_query_concat)\n",
    "#     # print(output.size())\n",
    "#     output_expanded = torch.unsqueeze(output, dim=1)  # [original batch_size * num_rollout, 1, 2D], D=self.agent.hidden_size\n",
    "#     # print(output_expanded.size(), candidate_action_embeddings.size())\n",
    "#     prelim_scores = torch.sum(candidate_action_embeddings * output_expanded, dim=2)\n",
    "\n",
    "#     # Masking PAD actions\n",
    "\n",
    "#     comparison_tensor = torch.ones_like(next_relations).int() * self.agent.rPAD  # matrix to compare\n",
    "#     mask = next_relations == comparison_tensor  # The mask\n",
    "#     dummy_scores = torch.ones_like(prelim_scores) * -99999.0  # the base matrix to choose from if dummy relation\n",
    "#     scores = torch.where(mask, dummy_scores, prelim_scores)  # [original batch_size * num_rollout, max_num_actions]\n",
    "\n",
    "#     # 4 sample action\n",
    "#     action = torch.distributions.categorical.Categorical(logits=scores) # [original batch_size * num_rollout, 1]\n",
    "#     label_action = action.sample() # [original batch_size * num_rollout,]\n",
    "\n",
    "#     # loss\n",
    "#     # 5a.\n",
    "#     loss = torch.nn.CrossEntropyLoss(reduce=False)(scores, label_action)\n",
    "\n",
    "#     # 6. Map back to true id\n",
    "#     chosen_relation = next_relations[torch.arange(len(label_action)), label_action]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70c874d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# next_relations, next_entities, prev_state = next_possible_relations, next_possible_entities, entity_state_emb\n",
    "# prev_relation, query_embedding, current_entities = prev_relation, query_relation,current_entities\n",
    "# head, link, tail = head, link, tail"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc1d1658",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with torch.no_grad():\n",
    "#     self.agent.ent_embed = self.agent.entity_embedding(torch.arange(head.max().item() + 1).to(head.device))\n",
    "#     self.agent.rel_embed = self.agent.relation_embedding(torch.arange(link.max().item() + 1).to(link.device))\n",
    "\n",
    "#     for i in range(2):\n",
    "#         self.agent.ent_embed = self.agent.node_conv[i](head, link, tail, \n",
    "#                                                 self.agent.ent_embed, self.agent.rel_embed)\n",
    "#         self.agent.rel_embed = self.agent.rel_conv[i](head, link, tail, \n",
    "#                                                 self.agent.ent_embed, self.agent.rel_embed)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0aa96cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with torch.no_grad():\n",
    "#     prev_action_embedding = self.agent.action_encoder(prev_relation, current_entities) # (original batch_size * num_rollout, 4*self.embedding_size)\n",
    "\n",
    "#     prev_state = torch.unbind(prev_state, dim=1)\n",
    "#     prev_state = [prev_state[0].squeeze(0), prev_state[1].squeeze(0)]\n",
    "\n",
    "#     new_prev_state = list()\n",
    "\n",
    "#     output, new_state = self.agent.policy_step(prev_action_embedding, prev_state)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8763062b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with torch.no_grad():\n",
    "#     prev_entity = self.agent.ent_embed[current_entities]\n",
    "#     if self.agent.use_entity_embeddings:\n",
    "#         state = torch.cat([output, prev_entity], dim=-1)\n",
    "#     else:\n",
    "#         state = output\n",
    "\n",
    "#     candidate_action_embeddings = self.agent.action_encoder(next_relations, next_entities)\n",
    "#     query_embedding = self.agent.rel_embed[query_embedding]\n",
    "\n",
    "#     state_query_concat = torch.cat([state, query_embedding], dim=-1)\n",
    "\n",
    "#     # MLP for policy#\n",
    "\n",
    "#     output = self.agent.policy_mlp(state_query_concat)\n",
    "#     # print(output.size())\n",
    "#     output_expanded = torch.unsqueeze(output, dim=1)  # [original batch_size * num_rollout, 1, 2D], D=self.agent.hidden_size\n",
    "#     # print(output_expanded.size(), candidate_action_embeddings.size())\n",
    "#     prelim_scores = torch.sum(candidate_action_embeddings * output_expanded, dim=2)\n",
    "\n",
    "#     # Masking PAD actions\n",
    "\n",
    "#     comparison_tensor = torch.ones_like(next_relations).int() * self.agent.rPAD  # matrix to compare\n",
    "#     mask = next_relations == comparison_tensor  # The mask\n",
    "#     dummy_scores = torch.ones_like(prelim_scores) * -99999.0  # the base matrix to choose from if dummy relation\n",
    "#     scores = torch.where(mask, dummy_scores, prelim_scores)  # [original batch_size * num_rollout, max_num_actions]\n",
    "\n",
    "#     # 4 sample action\n",
    "#     action = torch.distributions.categorical.Categorical(logits=scores) # [original batch_size * num_rollout, 1]\n",
    "#     label_action = action.sample() # [original batch_size * num_rollout,]\n",
    "\n",
    "#     # loss\n",
    "#     # 5a.\n",
    "#     loss = torch.nn.CrossEntropyLoss(reduce=False)(scores, label_action)\n",
    "\n",
    "#     # 6. Map back to true id\n",
    "#     chosen_relation = next_relations[torch.arange(len(label_action)), label_action]"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
