{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce63a777",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle5\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"MIG-a6f8dd9b-6af8-5e75-8654-84fb2b7b8f6d\"\n",
    "\n",
    "from model.ours3 import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "398c7676",
   "metadata": {},
   "outputs": [],
   "source": [
    "options = {}\n",
    "\n",
    "#basic setting\n",
    "options['use_cuda'] = True\n",
    "options['vocab_dir'] = '../MINERVA/datasets/data_preprocessed/WN18RR/vocab/'\n",
    "options['data_input_dir'] = '../MINERVA/datasets/data_preprocessed/WN18RR/'\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_WN18RR-1/'\n",
    "options['output_dir'] = './outputs_WN18RR-1/'\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'] = 1\n",
    "options['train_relation_embeddings'] = 1\n",
    "options['path_length'] = 3\n",
    "options['LSTM_layers'] = 1\n",
    "options['max_num_actions'] = 40\n",
    "options['gnn_layer'] = 2\n",
    "\n",
    "#hyperparameters\n",
    "options['test_rollouts'] = 40\n",
    "options['num_rollouts'] = 20\n",
    "options['batch_size'] = 64\n",
    "options['eval_batch_size'] = 32\n",
    "options['beta'] = 0.05\n",
    "options['Lambda'] = 0.05\n",
    "options['gamma'] = 1\n",
    "options['positive_reward'] = 1\n",
    "options['negative_reward'] = 0\n",
    "options['learning_rate'] = 5e-5\n",
    "options['grad_clip_norm'] = 100\n",
    "options['eval_every'] = 100\n",
    "options['total_iterations'] = 2000*(64/options['batch_size'])\n",
    "options['pool'] = 'max'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9d9b9fda",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "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": [
      "/root/miniconda3/lib/python3.10/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",
      "/root/Research/GraphRL/experiments/model/ours3.py:334: 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.1869, rewards: 0.1352\n",
      "Iteration: 20, Train loss: -0.2357, rewards: 0.2238\n",
      "Iteration: 30, Train loss: -0.2570, rewards: 0.2602\n",
      "Iteration: 40, Train loss: -0.2958, rewards: 0.2715\n",
      "Iteration: 50, Train loss: -0.3226, rewards: 0.2802\n",
      "Iteration: 60, Train loss: -0.3109, rewards: 0.2561\n",
      "Iteration: 70, Train loss: -0.3230, rewards: 0.2848\n",
      "Iteration: 80, Train loss: -0.3581, rewards: 0.2708\n",
      "Iteration: 90, Train loss: -0.3694, rewards: 0.3376\n",
      "Iteration: 100, Train loss: -0.3823, rewards: 0.3334\n",
      "Eval:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/Research/GraphRL/experiments/model/ours3.py:636: 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.3688, Hits@3: 0.4370, Hits@10: 0.4927, MRR: 0.4102\n",
      "------------------------------------------------------------\n",
      "Iteration: 110, Train loss: -0.3554, rewards: 0.3503\n",
      "Iteration: 120, Train loss: -0.2828, rewards: 0.3220\n",
      "Iteration: 130, Train loss: -0.3250, rewards: 0.3603\n",
      "Iteration: 140, Train loss: -0.3126, rewards: 0.3265\n",
      "Iteration: 150, Train loss: -0.3904, rewards: 0.4001\n",
      "Iteration: 160, Train loss: -0.3622, rewards: 0.3738\n",
      "Iteration: 170, Train loss: -0.3045, rewards: 0.3340\n",
      "Iteration: 180, Train loss: -0.3518, rewards: 0.3701\n",
      "Iteration: 190, Train loss: -0.3518, rewards: 0.4114\n",
      "Iteration: 200, Train loss: -0.3553, rewards: 0.3937\n",
      "Eval:\n",
      "Hits@1: 0.3912, Hits@3: 0.4506, Hits@10: 0.4970, MRR: 0.4266\n",
      "------------------------------------------------------------\n",
      "Iteration: 210, Train loss: -0.3242, rewards: 0.3695\n",
      "Iteration: 220, Train loss: -0.3522, rewards: 0.3812\n",
      "Iteration: 230, Train loss: -0.3187, rewards: 0.4006\n",
      "Iteration: 240, Train loss: -0.3406, rewards: 0.3896\n",
      "Iteration: 250, Train loss: -0.3481, rewards: 0.3966\n",
      "Iteration: 260, Train loss: -0.3399, rewards: 0.3931\n",
      "Iteration: 270, Train loss: -0.3555, rewards: 0.3910\n",
      "Iteration: 280, Train loss: -0.4084, rewards: 0.4041\n",
      "Iteration: 290, Train loss: -0.3745, rewards: 0.3942\n",
      "Iteration: 300, Train loss: -0.3453, rewards: 0.3859\n",
      "Eval:\n",
      "Hits@1: 0.4054, Hits@3: 0.4542, Hits@10: 0.5023, MRR: 0.4370\n",
      "------------------------------------------------------------\n",
      "Iteration: 310, Train loss: -0.4350, rewards: 0.4129\n",
      "Iteration: 320, Train loss: -0.4144, rewards: 0.3886\n",
      "Iteration: 330, Train loss: -0.3915, rewards: 0.3945\n",
      "Iteration: 340, Train loss: -0.3699, rewards: 0.3877\n",
      "Iteration: 350, Train loss: -0.3695, rewards: 0.3990\n",
      "Iteration: 360, Train loss: -0.3953, rewards: 0.4166\n",
      "Iteration: 370, Train loss: -0.3653, rewards: 0.4341\n",
      "Iteration: 380, Train loss: -0.3626, rewards: 0.3977\n",
      "Iteration: 390, Train loss: -0.3703, rewards: 0.4128\n",
      "Iteration: 400, Train loss: -0.3687, rewards: 0.4099\n",
      "Eval:\n",
      "Hits@1: 0.4146, Hits@3: 0.4641, Hits@10: 0.5059, MRR: 0.4456\n",
      "------------------------------------------------------------\n",
      "Iteration: 410, Train loss: -0.3742, rewards: 0.4135\n",
      "Iteration: 420, Train loss: -0.3913, rewards: 0.4328\n",
      "Iteration: 430, Train loss: -0.4218, rewards: 0.3893\n",
      "Iteration: 440, Train loss: -0.3581, rewards: 0.4311\n",
      "Iteration: 450, Train loss: -0.3840, rewards: 0.4175\n",
      "Iteration: 460, Train loss: -0.3760, rewards: 0.4259\n",
      "Iteration: 470, Train loss: -0.3520, rewards: 0.4103\n",
      "Iteration: 480, Train loss: -0.3447, rewards: 0.4071\n",
      "Iteration: 490, Train loss: -0.3797, rewards: 0.4354\n",
      "Iteration: 500, Train loss: -0.3687, rewards: 0.4004\n",
      "Eval:\n",
      "Hits@1: 0.4120, Hits@3: 0.4700, Hits@10: 0.5158, MRR: 0.4476\n",
      "------------------------------------------------------------\n",
      "Iteration: 510, Train loss: -0.3274, rewards: 0.3972\n",
      "Iteration: 520, Train loss: -0.3697, rewards: 0.4302\n",
      "Iteration: 530, Train loss: -0.3422, rewards: 0.3762\n",
      "Iteration: 540, Train loss: -0.3490, rewards: 0.4180\n",
      "Iteration: 550, Train loss: -0.3501, rewards: 0.4163\n",
      "Iteration: 560, Train loss: -0.3281, rewards: 0.4121\n",
      "Iteration: 570, Train loss: -0.3490, rewards: 0.4055\n",
      "Iteration: 580, Train loss: -0.3362, rewards: 0.3875\n",
      "Iteration: 590, Train loss: -0.3660, rewards: 0.4264\n",
      "Iteration: 600, Train loss: -0.3336, rewards: 0.4114\n",
      "Eval:\n",
      "Hits@1: 0.4041, Hits@3: 0.4637, Hits@10: 0.5119, MRR: 0.4405\n",
      "------------------------------------------------------------\n",
      "Iteration: 610, Train loss: -0.3300, rewards: 0.4175\n",
      "Iteration: 620, Train loss: -0.3457, rewards: 0.4227\n",
      "Iteration: 630, Train loss: -0.3900, rewards: 0.4367\n",
      "Iteration: 640, Train loss: -0.4086, rewards: 0.3662\n",
      "Iteration: 650, Train loss: -0.3717, rewards: 0.4078\n",
      "Iteration: 660, Train loss: -0.3474, rewards: 0.4208\n",
      "Iteration: 670, Train loss: -0.3418, rewards: 0.3958\n",
      "Iteration: 680, Train loss: -0.3562, rewards: 0.3995\n",
      "Iteration: 690, Train loss: -0.3603, rewards: 0.3795\n",
      "Iteration: 700, Train loss: -0.3493, rewards: 0.4145\n",
      "Eval:\n",
      "Hits@1: 0.4064, Hits@3: 0.4687, Hits@10: 0.5089, MRR: 0.4435\n",
      "------------------------------------------------------------\n",
      "Iteration: 710, Train loss: -0.3485, rewards: 0.3909\n",
      "Iteration: 720, Train loss: -0.3371, rewards: 0.4475\n",
      "Iteration: 730, Train loss: -0.3541, rewards: 0.4195\n",
      "Iteration: 740, Train loss: -0.3471, rewards: 0.4569\n",
      "Iteration: 750, Train loss: -0.3835, rewards: 0.4442\n",
      "Iteration: 760, Train loss: -0.3916, rewards: 0.4260\n",
      "Iteration: 770, Train loss: -0.3713, rewards: 0.4184\n",
      "Iteration: 780, Train loss: -0.4039, rewards: 0.4320\n",
      "Iteration: 790, Train loss: -0.3763, rewards: 0.4088\n",
      "Iteration: 800, Train loss: -0.3301, rewards: 0.4126\n",
      "Eval:\n",
      "Hits@1: 0.4031, Hits@3: 0.4634, Hits@10: 0.5145, MRR: 0.4411\n",
      "------------------------------------------------------------\n",
      "Iteration: 810, Train loss: -0.3136, rewards: 0.4150\n",
      "Iteration: 820, Train loss: -0.3499, rewards: 0.4030\n",
      "Iteration: 830, Train loss: -0.3779, rewards: 0.4178\n",
      "Iteration: 840, Train loss: -0.3574, rewards: 0.4029\n",
      "Iteration: 850, Train loss: -0.3744, rewards: 0.4425\n",
      "Iteration: 860, Train loss: -0.3957, rewards: 0.4312\n",
      "Iteration: 870, Train loss: -0.3434, rewards: 0.4133\n",
      "Iteration: 880, Train loss: -0.3894, rewards: 0.3959\n",
      "Iteration: 890, Train loss: -0.3703, rewards: 0.4141\n",
      "Iteration: 900, Train loss: -0.3652, rewards: 0.4122\n",
      "Eval:\n",
      "Hits@1: 0.3968, Hits@3: 0.4628, Hits@10: 0.5082, MRR: 0.4359\n",
      "------------------------------------------------------------\n",
      "Iteration: 910, Train loss: -0.3717, rewards: 0.4047\n",
      "Iteration: 920, Train loss: -0.3762, rewards: 0.4056\n",
      "Iteration: 930, Train loss: -0.3922, rewards: 0.4305\n",
      "Iteration: 940, Train loss: -0.3855, rewards: 0.4377\n",
      "Iteration: 950, Train loss: -0.3482, rewards: 0.4438\n",
      "Iteration: 960, Train loss: -0.3150, rewards: 0.4292\n",
      "Iteration: 970, Train loss: -0.2930, rewards: 0.4122\n",
      "Iteration: 980, Train loss: -0.3268, rewards: 0.4277\n",
      "Iteration: 990, Train loss: -0.3513, rewards: 0.4311\n",
      "Iteration: 1000, Train loss: -0.3874, rewards: 0.4132\n",
      "Eval:\n",
      "Hits@1: 0.3968, Hits@3: 0.4637, Hits@10: 0.5089, MRR: 0.4368\n",
      "------------------------------------------------------------\n",
      "Iteration: 1010, Train loss: -0.3670, rewards: 0.4165\n",
      "Iteration: 1020, Train loss: -0.3427, rewards: 0.4266\n",
      "Iteration: 1030, Train loss: -0.3535, rewards: 0.3979\n",
      "Iteration: 1040, Train loss: -0.3698, rewards: 0.4174\n",
      "Iteration: 1050, Train loss: -0.4024, rewards: 0.4396\n",
      "Iteration: 1060, Train loss: -0.4412, rewards: 0.4245\n",
      "Iteration: 1070, Train loss: -0.4155, rewards: 0.4399\n",
      "Iteration: 1080, Train loss: -0.4084, rewards: 0.4594\n",
      "Iteration: 1090, Train loss: -0.3295, rewards: 0.4323\n",
      "Iteration: 1100, Train loss: -0.3765, rewards: 0.4431\n",
      "Eval:\n",
      "Hits@1: 0.3889, Hits@3: 0.4651, Hits@10: 0.5092, MRR: 0.4330\n",
      "------------------------------------------------------------\n",
      "Iteration: 1110, Train loss: -0.3404, rewards: 0.4169\n",
      "Iteration: 1120, Train loss: -0.3007, rewards: 0.4147\n",
      "Iteration: 1130, Train loss: -0.3195, rewards: 0.4623\n",
      "Iteration: 1140, Train loss: -0.3379, rewards: 0.4037\n",
      "Iteration: 1150, Train loss: -0.3364, rewards: 0.4023\n",
      "Iteration: 1160, Train loss: -0.3718, rewards: 0.4191\n",
      "Iteration: 1170, Train loss: -0.3851, rewards: 0.4520\n",
      "Iteration: 1180, Train loss: -0.3744, rewards: 0.4382\n",
      "Iteration: 1190, Train loss: -0.3786, rewards: 0.4318\n",
      "Iteration: 1200, Train loss: -0.3524, rewards: 0.4230\n",
      "Eval:\n",
      "Hits@1: 0.4229, Hits@3: 0.4693, Hits@10: 0.5194, MRR: 0.4534\n",
      "------------------------------------------------------------\n",
      "Iteration: 1210, Train loss: -0.3295, rewards: 0.4388\n",
      "Iteration: 1220, Train loss: -0.3448, rewards: 0.4285\n",
      "Iteration: 1230, Train loss: -0.3574, rewards: 0.4513\n",
      "Iteration: 1240, Train loss: -0.3265, rewards: 0.4299\n",
      "Iteration: 1250, Train loss: -0.3679, rewards: 0.4308\n",
      "Iteration: 1260, Train loss: -0.3442, rewards: 0.4444\n",
      "Iteration: 1270, Train loss: -0.3471, rewards: 0.4212\n",
      "Iteration: 1280, Train loss: -0.3739, rewards: 0.4277\n",
      "Iteration: 1290, Train loss: -0.3774, rewards: 0.4273\n",
      "Iteration: 1300, Train loss: -0.3592, rewards: 0.4273\n",
      "Eval:\n",
      "Hits@1: 0.4219, Hits@3: 0.4723, Hits@10: 0.5138, MRR: 0.4536\n",
      "------------------------------------------------------------\n",
      "Iteration: 1310, Train loss: -0.3718, rewards: 0.4213\n",
      "Iteration: 1320, Train loss: -0.3572, rewards: 0.4198\n",
      "Iteration: 1330, Train loss: -0.3792, rewards: 0.4463\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1340, Train loss: -0.3706, rewards: 0.4275\n",
      "Iteration: 1350, Train loss: -0.3506, rewards: 0.4052\n",
      "Iteration: 1360, Train loss: -0.3384, rewards: 0.4078\n",
      "Iteration: 1370, Train loss: -0.3482, rewards: 0.4544\n",
      "Iteration: 1380, Train loss: -0.3571, rewards: 0.4456\n",
      "Iteration: 1390, Train loss: -0.3340, rewards: 0.4748\n",
      "Iteration: 1400, Train loss: -0.3603, rewards: 0.4485\n",
      "Eval:\n",
      "Hits@1: 0.4120, Hits@3: 0.4664, Hits@10: 0.5191, MRR: 0.4473\n",
      "------------------------------------------------------------\n",
      "Iteration: 1410, Train loss: -0.3777, rewards: 0.4397\n",
      "Iteration: 1420, Train loss: -0.3693, rewards: 0.4374\n",
      "Iteration: 1430, Train loss: -0.3308, rewards: 0.4438\n",
      "Iteration: 1440, Train loss: -0.3418, rewards: 0.4338\n",
      "Iteration: 1450, Train loss: -0.3604, rewards: 0.4472\n",
      "Iteration: 1460, Train loss: -0.3588, rewards: 0.4638\n",
      "Iteration: 1470, Train loss: -0.3688, rewards: 0.4361\n",
      "Iteration: 1480, Train loss: -0.3987, rewards: 0.4490\n",
      "Iteration: 1490, Train loss: -0.3429, rewards: 0.4128\n",
      "Iteration: 1500, Train loss: -0.3705, rewards: 0.4513\n",
      "Eval:\n",
      "Hits@1: 0.4166, Hits@3: 0.4637, Hits@10: 0.5086, MRR: 0.4466\n",
      "------------------------------------------------------------\n",
      "Iteration: 1510, Train loss: -0.3712, rewards: 0.4291\n",
      "Iteration: 1520, Train loss: -0.3414, rewards: 0.4320\n",
      "Iteration: 1530, Train loss: -0.2986, rewards: 0.4393\n",
      "Iteration: 1540, Train loss: -0.3152, rewards: 0.4441\n",
      "Iteration: 1550, Train loss: -0.3204, rewards: 0.4413\n",
      "Iteration: 1560, Train loss: -0.2855, rewards: 0.4308\n",
      "Iteration: 1570, Train loss: -0.3256, rewards: 0.4419\n",
      "Iteration: 1580, Train loss: -0.3315, rewards: 0.4406\n",
      "Iteration: 1590, Train loss: -0.3201, rewards: 0.4485\n",
      "Iteration: 1600, Train loss: -0.2933, rewards: 0.4816\n",
      "Eval:\n",
      "Hits@1: 0.4123, Hits@3: 0.4697, Hits@10: 0.5122, MRR: 0.4466\n",
      "------------------------------------------------------------\n",
      "Iteration: 1610, Train loss: -0.3178, rewards: 0.4203\n",
      "Iteration: 1620, Train loss: -0.3403, rewards: 0.4218\n",
      "Iteration: 1630, Train loss: -0.3205, rewards: 0.4280\n",
      "Iteration: 1640, Train loss: -0.3408, rewards: 0.4273\n",
      "Iteration: 1650, Train loss: -0.2862, rewards: 0.4507\n",
      "Iteration: 1660, Train loss: -0.2739, rewards: 0.4589\n",
      "Iteration: 1670, Train loss: -0.3177, rewards: 0.4050\n",
      "Iteration: 1680, Train loss: -0.3413, rewards: 0.4404\n",
      "Iteration: 1690, Train loss: -0.3058, rewards: 0.4241\n",
      "Iteration: 1700, Train loss: -0.3642, rewards: 0.4449\n",
      "Eval:\n",
      "Hits@1: 0.3866, Hits@3: 0.4674, Hits@10: 0.5119, MRR: 0.4328\n",
      "------------------------------------------------------------\n",
      "Iteration: 1710, Train loss: -0.3465, rewards: 0.4555\n",
      "Iteration: 1720, Train loss: -0.3071, rewards: 0.4615\n",
      "Iteration: 1730, Train loss: -0.3106, rewards: 0.4566\n",
      "Iteration: 1740, Train loss: -0.3157, rewards: 0.4419\n",
      "Iteration: 1750, Train loss: -0.3425, rewards: 0.4340\n",
      "Iteration: 1760, Train loss: -0.3547, rewards: 0.4291\n",
      "Iteration: 1770, Train loss: -0.3253, rewards: 0.4089\n",
      "Iteration: 1780, Train loss: -0.3400, rewards: 0.4467\n",
      "Iteration: 1790, Train loss: -0.3009, rewards: 0.4579\n",
      "Iteration: 1800, Train loss: -0.3467, rewards: 0.4470\n",
      "Eval:\n",
      "Hits@1: 0.3978, Hits@3: 0.4687, Hits@10: 0.5109, MRR: 0.4380\n",
      "------------------------------------------------------------\n",
      "Iteration: 1810, Train loss: -0.3185, rewards: 0.4243\n",
      "Iteration: 1820, Train loss: -0.3101, rewards: 0.4424\n",
      "Iteration: 1830, Train loss: -0.3497, rewards: 0.4732\n",
      "Iteration: 1840, Train loss: -0.3116, rewards: 0.4241\n",
      "Iteration: 1850, Train loss: -0.3205, rewards: 0.4426\n",
      "Iteration: 1860, Train loss: -0.2834, rewards: 0.4559\n",
      "Iteration: 1870, Train loss: -0.3056, rewards: 0.4088\n",
      "Iteration: 1880, Train loss: -0.3334, rewards: 0.4530\n",
      "Iteration: 1890, Train loss: -0.3338, rewards: 0.4443\n",
      "Iteration: 1900, Train loss: -0.3254, rewards: 0.4485\n",
      "Eval:\n",
      "Hits@1: 0.4090, Hits@3: 0.4667, Hits@10: 0.5148, MRR: 0.4448\n",
      "------------------------------------------------------------\n",
      "Iteration: 1910, Train loss: -0.3278, rewards: 0.4479\n",
      "Iteration: 1920, Train loss: -0.3390, rewards: 0.4716\n",
      "Iteration: 1930, Train loss: -0.2959, rewards: 0.4742\n",
      "Iteration: 1940, Train loss: -0.3527, rewards: 0.3934\n",
      "Iteration: 1950, Train loss: -0.3462, rewards: 0.4107\n",
      "Iteration: 1960, Train loss: -0.3362, rewards: 0.4198\n",
      "Iteration: 1970, Train loss: -0.3012, rewards: 0.3655\n",
      "Iteration: 1980, Train loss: -0.3613, rewards: 0.4183\n",
      "Iteration: 1990, Train loss: -0.3524, rewards: 0.4406\n",
      "Iteration: 2000, Train loss: -0.3745, rewards: 0.4314\n",
      "Eval:\n",
      "Hits@1: 0.4189, Hits@3: 0.4733, Hits@10: 0.5171, MRR: 0.4517\n",
      "------------------------------------------------------------\n",
      "Hits@1: 0.4381, Hits@3: 0.4802, Hits@10: 0.5233, MRR: 0.4657\n",
      "3\n",
      "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",
      "Iteration: 10, Train loss: -0.1858, rewards: 0.1286\n",
      "Iteration: 20, Train loss: -0.2712, rewards: 0.2275\n",
      "Iteration: 30, Train loss: -0.2349, rewards: 0.2550\n",
      "Iteration: 40, Train loss: -0.3445, rewards: 0.2331\n",
      "Iteration: 50, Train loss: -0.3470, rewards: 0.2645\n",
      "Iteration: 60, Train loss: -0.3579, rewards: 0.3480\n",
      "Iteration: 70, Train loss: -0.3830, rewards: 0.3539\n",
      "Iteration: 80, Train loss: -0.3284, rewards: 0.3322\n",
      "Iteration: 90, Train loss: -0.3068, rewards: 0.3136\n",
      "Iteration: 100, Train loss: -0.3610, rewards: 0.3350\n",
      "Eval:\n",
      "Hits@1: 0.3774, Hits@3: 0.4423, Hits@10: 0.5026, MRR: 0.4191\n",
      "------------------------------------------------------------\n",
      "Iteration: 110, Train loss: -0.4823, rewards: 0.3742\n",
      "Iteration: 120, Train loss: -0.4187, rewards: 0.3603\n",
      "Iteration: 130, Train loss: -0.3896, rewards: 0.3553\n",
      "Iteration: 140, Train loss: -0.3849, rewards: 0.4027\n",
      "Iteration: 150, Train loss: -0.3739, rewards: 0.3447\n",
      "Iteration: 160, Train loss: -0.4262, rewards: 0.3967\n",
      "Iteration: 170, Train loss: -0.4366, rewards: 0.3664\n",
      "Iteration: 180, Train loss: -0.4440, rewards: 0.3584\n",
      "Iteration: 190, Train loss: -0.4215, rewards: 0.3919\n",
      "Iteration: 200, Train loss: -0.4120, rewards: 0.3734\n",
      "Eval:\n",
      "Hits@1: 0.3869, Hits@3: 0.4473, Hits@10: 0.4993, MRR: 0.4246\n",
      "------------------------------------------------------------\n",
      "Iteration: 210, Train loss: -0.4028, rewards: 0.3844\n",
      "Iteration: 220, Train loss: -0.4188, rewards: 0.3941\n",
      "Iteration: 230, Train loss: -0.3820, rewards: 0.3561\n",
      "Iteration: 240, Train loss: -0.4664, rewards: 0.4522\n",
      "Iteration: 250, Train loss: -0.4426, rewards: 0.4206\n",
      "Iteration: 260, Train loss: -0.3850, rewards: 0.3986\n",
      "Iteration: 270, Train loss: -0.3920, rewards: 0.3867\n",
      "Iteration: 280, Train loss: -0.4024, rewards: 0.3747\n",
      "Iteration: 290, Train loss: -0.4632, rewards: 0.4266\n",
      "Iteration: 300, Train loss: -0.4147, rewards: 0.4192\n",
      "Eval:\n",
      "Hits@1: 0.4015, Hits@3: 0.4585, Hits@10: 0.5069, MRR: 0.4369\n",
      "------------------------------------------------------------\n",
      "Iteration: 310, Train loss: -0.4211, rewards: 0.3866\n",
      "Iteration: 320, Train loss: -0.4273, rewards: 0.3970\n",
      "Iteration: 330, Train loss: -0.4304, rewards: 0.3569\n",
      "Iteration: 340, Train loss: -0.3667, rewards: 0.3673\n",
      "Iteration: 350, Train loss: -0.3524, rewards: 0.3455\n",
      "Iteration: 360, Train loss: -0.4017, rewards: 0.3525\n",
      "Iteration: 370, Train loss: -0.3490, rewards: 0.4195\n",
      "Iteration: 380, Train loss: -0.3775, rewards: 0.3941\n",
      "Iteration: 390, Train loss: -0.3866, rewards: 0.3906\n",
      "Iteration: 400, Train loss: -0.4333, rewards: 0.4419\n",
      "Eval:\n",
      "Hits@1: 0.4015, Hits@3: 0.4611, Hits@10: 0.5076, MRR: 0.4380\n",
      "------------------------------------------------------------\n",
      "Iteration: 410, Train loss: -0.3461, rewards: 0.4188\n",
      "Iteration: 420, Train loss: -0.3488, rewards: 0.3994\n",
      "Iteration: 430, Train loss: -0.3447, rewards: 0.3470\n",
      "Iteration: 440, Train loss: -0.4103, rewards: 0.3992\n",
      "Iteration: 450, Train loss: -0.4022, rewards: 0.4256\n",
      "Iteration: 460, Train loss: -0.3870, rewards: 0.4155\n",
      "Iteration: 470, Train loss: -0.3781, rewards: 0.3659\n",
      "Iteration: 480, Train loss: -0.3714, rewards: 0.4558\n",
      "Iteration: 490, Train loss: -0.3894, rewards: 0.3772\n",
      "Iteration: 500, Train loss: -0.3802, rewards: 0.4172\n",
      "Eval:\n",
      "Hits@1: 0.4117, Hits@3: 0.4634, Hits@10: 0.5105, MRR: 0.4450\n",
      "------------------------------------------------------------\n",
      "Iteration: 510, Train loss: -0.3348, rewards: 0.3783\n",
      "Iteration: 520, Train loss: -0.3884, rewards: 0.3955\n",
      "Iteration: 530, Train loss: -0.4256, rewards: 0.4256\n",
      "Iteration: 540, Train loss: -0.3986, rewards: 0.3892\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 550, Train loss: -0.4004, rewards: 0.4023\n",
      "Iteration: 560, Train loss: -0.3389, rewards: 0.3841\n",
      "Iteration: 570, Train loss: -0.3723, rewards: 0.4239\n",
      "Iteration: 580, Train loss: -0.3328, rewards: 0.4113\n",
      "Iteration: 590, Train loss: -0.3508, rewards: 0.3945\n",
      "Iteration: 600, Train loss: -0.3375, rewards: 0.4023\n",
      "Eval:\n",
      "Hits@1: 0.4084, Hits@3: 0.4604, Hits@10: 0.5010, MRR: 0.4399\n",
      "------------------------------------------------------------\n",
      "Iteration: 610, Train loss: -0.3474, rewards: 0.4252\n",
      "Iteration: 620, Train loss: -0.3717, rewards: 0.3633\n",
      "Iteration: 630, Train loss: -0.3855, rewards: 0.4373\n",
      "Iteration: 640, Train loss: -0.3419, rewards: 0.3709\n",
      "Iteration: 650, Train loss: -0.3400, rewards: 0.3791\n",
      "Iteration: 660, Train loss: -0.3741, rewards: 0.4481\n",
      "Iteration: 670, Train loss: -0.4171, rewards: 0.3905\n",
      "Iteration: 680, Train loss: -0.3286, rewards: 0.4027\n",
      "Iteration: 690, Train loss: -0.3254, rewards: 0.4022\n",
      "Iteration: 700, Train loss: -0.3148, rewards: 0.4656\n",
      "Eval:\n",
      "Hits@1: 0.4150, Hits@3: 0.4697, Hits@10: 0.5142, MRR: 0.4479\n",
      "------------------------------------------------------------\n",
      "Iteration: 710, Train loss: -0.3676, rewards: 0.5023\n",
      "Iteration: 720, Train loss: -0.3465, rewards: 0.4242\n",
      "Iteration: 730, Train loss: -0.3336, rewards: 0.4147\n",
      "Iteration: 740, Train loss: -0.3452, rewards: 0.3962\n",
      "Iteration: 750, Train loss: -0.3635, rewards: 0.4431\n",
      "Iteration: 760, Train loss: -0.3698, rewards: 0.4352\n",
      "Iteration: 770, Train loss: -0.3171, rewards: 0.3872\n",
      "Iteration: 780, Train loss: -0.3649, rewards: 0.3937\n",
      "Iteration: 790, Train loss: -0.3624, rewards: 0.3909\n",
      "Iteration: 800, Train loss: -0.3646, rewards: 0.4234\n",
      "Eval:\n",
      "Hits@1: 0.4252, Hits@3: 0.4700, Hits@10: 0.5122, MRR: 0.4541\n",
      "------------------------------------------------------------\n",
      "Iteration: 810, Train loss: -0.3722, rewards: 0.4464\n",
      "Iteration: 820, Train loss: -0.3282, rewards: 0.4213\n",
      "Iteration: 830, Train loss: -0.3573, rewards: 0.4264\n",
      "Iteration: 840, Train loss: -0.3467, rewards: 0.4411\n",
      "Iteration: 850, Train loss: -0.3156, rewards: 0.4023\n",
      "Iteration: 860, Train loss: -0.3529, rewards: 0.4300\n",
      "Iteration: 870, Train loss: -0.3809, rewards: 0.3794\n",
      "Iteration: 880, Train loss: -0.3399, rewards: 0.3798\n",
      "Iteration: 890, Train loss: -0.3259, rewards: 0.4048\n",
      "Iteration: 900, Train loss: -0.3016, rewards: 0.3539\n",
      "Eval:\n",
      "Hits@1: 0.4160, Hits@3: 0.4674, Hits@10: 0.5079, MRR: 0.4469\n",
      "------------------------------------------------------------\n",
      "Iteration: 910, Train loss: -0.3535, rewards: 0.4792\n",
      "Iteration: 920, Train loss: -0.3856, rewards: 0.4464\n",
      "Iteration: 930, Train loss: -0.2989, rewards: 0.3787\n",
      "Iteration: 940, Train loss: -0.3553, rewards: 0.4605\n",
      "Iteration: 950, Train loss: -0.3646, rewards: 0.4397\n",
      "Iteration: 960, Train loss: -0.3879, rewards: 0.4609\n",
      "Iteration: 970, Train loss: -0.4005, rewards: 0.4309\n",
      "Iteration: 980, Train loss: -0.3125, rewards: 0.3686\n",
      "Iteration: 990, Train loss: -0.2943, rewards: 0.4136\n",
      "Iteration: 1000, Train loss: -0.3080, rewards: 0.4716\n",
      "Eval:\n",
      "Hits@1: 0.4176, Hits@3: 0.4651, Hits@10: 0.5059, MRR: 0.4476\n",
      "------------------------------------------------------------\n",
      "Iteration: 1010, Train loss: -0.3492, rewards: 0.4380\n",
      "Iteration: 1020, Train loss: -0.3140, rewards: 0.4814\n",
      "Iteration: 1030, Train loss: -0.3662, rewards: 0.4045\n",
      "Iteration: 1040, Train loss: -0.4074, rewards: 0.4534\n",
      "Iteration: 1050, Train loss: -0.4169, rewards: 0.4152\n",
      "Iteration: 1060, Train loss: -0.4205, rewards: 0.4361\n",
      "Iteration: 1070, Train loss: -0.4414, rewards: 0.3870\n",
      "Iteration: 1080, Train loss: -0.3362, rewards: 0.4225\n",
      "Iteration: 1090, Train loss: -0.3493, rewards: 0.4494\n",
      "Iteration: 1100, Train loss: -0.3202, rewards: 0.4239\n",
      "Eval:\n",
      "Hits@1: 0.4232, Hits@3: 0.4753, Hits@10: 0.5125, MRR: 0.4538\n",
      "------------------------------------------------------------\n",
      "Iteration: 1110, Train loss: -0.3541, rewards: 0.4103\n",
      "Iteration: 1120, Train loss: -0.3447, rewards: 0.4261\n",
      "Iteration: 1130, Train loss: -0.2696, rewards: 0.3647\n",
      "Iteration: 1140, Train loss: -0.3810, rewards: 0.3848\n",
      "Iteration: 1150, Train loss: -0.3605, rewards: 0.4603\n",
      "Iteration: 1160, Train loss: -0.3305, rewards: 0.4286\n",
      "Iteration: 1170, Train loss: -0.3843, rewards: 0.4383\n",
      "Iteration: 1180, Train loss: -0.3800, rewards: 0.4505\n",
      "Iteration: 1190, Train loss: -0.4058, rewards: 0.4856\n",
      "Iteration: 1200, Train loss: -0.4207, rewards: 0.4380\n",
      "Eval:\n",
      "Hits@1: 0.4209, Hits@3: 0.4624, Hits@10: 0.5036, MRR: 0.4467\n",
      "------------------------------------------------------------\n",
      "Iteration: 1210, Train loss: -0.3947, rewards: 0.4222\n",
      "Iteration: 1220, Train loss: -0.3826, rewards: 0.4269\n",
      "Iteration: 1230, Train loss: -0.3543, rewards: 0.4311\n",
      "Iteration: 1240, Train loss: -0.3438, rewards: 0.4475\n",
      "Iteration: 1250, Train loss: -0.3595, rewards: 0.4306\n",
      "Iteration: 1260, Train loss: -0.3495, rewards: 0.3959\n",
      "Iteration: 1270, Train loss: -0.3822, rewards: 0.4738\n",
      "Iteration: 1280, Train loss: -0.3734, rewards: 0.4306\n",
      "Iteration: 1290, Train loss: -0.3653, rewards: 0.4047\n",
      "Iteration: 1300, Train loss: -0.3788, rewards: 0.4220\n",
      "Eval:\n",
      "Hits@1: 0.4219, Hits@3: 0.4703, Hits@10: 0.5082, MRR: 0.4509\n",
      "------------------------------------------------------------\n",
      "Iteration: 1310, Train loss: -0.3680, rewards: 0.4298\n",
      "Iteration: 1320, Train loss: -0.3564, rewards: 0.3736\n",
      "Iteration: 1330, Train loss: -0.4332, rewards: 0.4436\n",
      "Iteration: 1340, Train loss: -0.3444, rewards: 0.4573\n",
      "Iteration: 1350, Train loss: -0.3177, rewards: 0.4478\n",
      "Iteration: 1360, Train loss: -0.2964, rewards: 0.4648\n",
      "Iteration: 1370, Train loss: -0.3683, rewards: 0.4105\n",
      "Iteration: 1380, Train loss: -0.3628, rewards: 0.4205\n",
      "Iteration: 1390, Train loss: -0.3320, rewards: 0.3936\n",
      "Iteration: 1400, Train loss: -0.3254, rewards: 0.4334\n",
      "Eval:\n",
      "Hits@1: 0.4258, Hits@3: 0.4710, Hits@10: 0.5096, MRR: 0.4546\n",
      "------------------------------------------------------------\n",
      "Iteration: 1410, Train loss: -0.3353, rewards: 0.4517\n",
      "Iteration: 1420, Train loss: -0.3746, rewards: 0.4448\n",
      "Iteration: 1430, Train loss: -0.3549, rewards: 0.4062\n",
      "Iteration: 1440, Train loss: -0.3581, rewards: 0.4617\n",
      "Iteration: 1450, Train loss: -0.3858, rewards: 0.4481\n",
      "Iteration: 1460, Train loss: -0.3683, rewards: 0.4142\n",
      "Iteration: 1470, Train loss: -0.3164, rewards: 0.4309\n",
      "Iteration: 1480, Train loss: -0.3194, rewards: 0.3836\n",
      "Iteration: 1490, Train loss: -0.3853, rewards: 0.4480\n",
      "Iteration: 1500, Train loss: -0.3690, rewards: 0.3930\n",
      "Eval:\n",
      "Hits@1: 0.4212, Hits@3: 0.4710, Hits@10: 0.5165, MRR: 0.4520\n",
      "------------------------------------------------------------\n",
      "Iteration: 1510, Train loss: -0.3651, rewards: 0.4183\n",
      "Iteration: 1520, Train loss: -0.3268, rewards: 0.4247\n",
      "Iteration: 1530, Train loss: -0.3825, rewards: 0.4748\n",
      "Iteration: 1540, Train loss: -0.3710, rewards: 0.4053\n",
      "Iteration: 1550, Train loss: -0.3300, rewards: 0.4636\n",
      "Iteration: 1560, Train loss: -0.3758, rewards: 0.4834\n",
      "Iteration: 1570, Train loss: -0.3386, rewards: 0.3906\n",
      "Iteration: 1580, Train loss: -0.3281, rewards: 0.4188\n",
      "Iteration: 1590, Train loss: -0.3633, rewards: 0.4278\n",
      "Iteration: 1600, Train loss: -0.3127, rewards: 0.4181\n",
      "Eval:\n",
      "Hits@1: 0.4255, Hits@3: 0.4697, Hits@10: 0.5105, MRR: 0.4538\n",
      "------------------------------------------------------------\n",
      "Iteration: 1610, Train loss: -0.3708, rewards: 0.4784\n",
      "Iteration: 1620, Train loss: -0.3744, rewards: 0.4280\n",
      "Iteration: 1630, Train loss: -0.3700, rewards: 0.3995\n",
      "Iteration: 1640, Train loss: -0.3259, rewards: 0.3886\n",
      "Iteration: 1650, Train loss: -0.3721, rewards: 0.4320\n",
      "Iteration: 1660, Train loss: -0.3503, rewards: 0.4230\n",
      "Iteration: 1670, Train loss: -0.3262, rewards: 0.4430\n",
      "Iteration: 1680, Train loss: -0.3653, rewards: 0.4081\n",
      "Iteration: 1690, Train loss: -0.3641, rewards: 0.3989\n",
      "Iteration: 1700, Train loss: -0.3042, rewards: 0.4041\n",
      "Eval:\n",
      "Hits@1: 0.4136, Hits@3: 0.4667, Hits@10: 0.5056, MRR: 0.4452\n",
      "------------------------------------------------------------\n",
      "Iteration: 1710, Train loss: -0.3446, rewards: 0.4537\n",
      "Iteration: 1720, Train loss: -0.3130, rewards: 0.4656\n",
      "Iteration: 1730, Train loss: -0.3693, rewards: 0.4169\n",
      "Iteration: 1740, Train loss: -0.2989, rewards: 0.4012\n",
      "Iteration: 1750, Train loss: -0.3044, rewards: 0.4130\n",
      "Iteration: 1760, Train loss: -0.3407, rewards: 0.4742\n",
      "Iteration: 1770, Train loss: -0.3183, rewards: 0.3994\n",
      "Iteration: 1780, Train loss: -0.2800, rewards: 0.4572\n",
      "Iteration: 1790, Train loss: -0.3188, rewards: 0.4375\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1800, Train loss: -0.3136, rewards: 0.3991\n",
      "Eval:\n",
      "Hits@1: 0.4265, Hits@3: 0.4670, Hits@10: 0.5076, MRR: 0.4528\n",
      "------------------------------------------------------------\n",
      "Iteration: 1810, Train loss: -0.2715, rewards: 0.4341\n",
      "Iteration: 1820, Train loss: -0.3059, rewards: 0.4037\n",
      "Iteration: 1830, Train loss: -0.3373, rewards: 0.4136\n",
      "Iteration: 1840, Train loss: -0.3575, rewards: 0.4055\n",
      "Iteration: 1850, Train loss: -0.3476, rewards: 0.4200\n",
      "Iteration: 1860, Train loss: -0.3887, rewards: 0.4552\n",
      "Iteration: 1870, Train loss: -0.3548, rewards: 0.3895\n",
      "Iteration: 1880, Train loss: -0.3908, rewards: 0.4345\n",
      "Iteration: 1890, Train loss: -0.3494, rewards: 0.4186\n",
      "Iteration: 1900, Train loss: -0.3612, rewards: 0.4034\n",
      "Eval:\n",
      "Hits@1: 0.4209, Hits@3: 0.4703, Hits@10: 0.5096, MRR: 0.4509\n",
      "------------------------------------------------------------\n",
      "Iteration: 1910, Train loss: -0.4048, rewards: 0.4253\n",
      "Iteration: 1920, Train loss: -0.3574, rewards: 0.4389\n",
      "Iteration: 1930, Train loss: -0.3222, rewards: 0.4078\n",
      "Iteration: 1940, Train loss: -0.3810, rewards: 0.4363\n",
      "Iteration: 1950, Train loss: -0.3370, rewards: 0.4592\n",
      "Iteration: 1960, Train loss: -0.3544, rewards: 0.4188\n",
      "Iteration: 1970, Train loss: -0.3683, rewards: 0.4372\n",
      "Iteration: 1980, Train loss: -0.3231, rewards: 0.4508\n",
      "Iteration: 1990, Train loss: -0.3783, rewards: 0.4231\n",
      "Iteration: 2000, Train loss: -0.3892, rewards: 0.4777\n",
      "Eval:\n",
      "Hits@1: 0.4318, Hits@3: 0.4713, Hits@10: 0.5142, MRR: 0.4573\n",
      "------------------------------------------------------------\n",
      "Hits@1: 0.4355, Hits@3: 0.4789, Hits@10: 0.5220, MRR: 0.4634\n",
      "4\n",
      "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",
      "Iteration: 10, Train loss: -0.2178, rewards: 0.1361\n",
      "Iteration: 20, Train loss: -0.2392, rewards: 0.2272\n",
      "Iteration: 30, Train loss: -0.3275, rewards: 0.2475\n",
      "Iteration: 40, Train loss: -0.3450, rewards: 0.2998\n",
      "Iteration: 50, Train loss: -0.3640, rewards: 0.2806\n",
      "Iteration: 60, Train loss: -0.3423, rewards: 0.2772\n",
      "Iteration: 70, Train loss: -0.3587, rewards: 0.2984\n",
      "Iteration: 80, Train loss: -0.4052, rewards: 0.3378\n",
      "Iteration: 90, Train loss: -0.4438, rewards: 0.3638\n",
      "Iteration: 100, Train loss: -0.4021, rewards: 0.3172\n",
      "Eval:\n",
      "Hits@1: 0.3764, Hits@3: 0.4446, Hits@10: 0.4911, MRR: 0.4165\n",
      "------------------------------------------------------------\n",
      "Iteration: 110, Train loss: -0.3909, rewards: 0.3887\n",
      "Iteration: 120, Train loss: -0.3769, rewards: 0.3889\n",
      "Iteration: 130, Train loss: -0.3420, rewards: 0.3887\n",
      "Iteration: 140, Train loss: -0.4157, rewards: 0.3592\n",
      "Iteration: 150, Train loss: -0.3293, rewards: 0.3255\n",
      "Iteration: 160, Train loss: -0.3618, rewards: 0.3909\n",
      "Iteration: 170, Train loss: -0.3008, rewards: 0.3736\n",
      "Iteration: 180, Train loss: -0.3597, rewards: 0.4239\n",
      "Iteration: 190, Train loss: -0.3652, rewards: 0.3839\n",
      "Iteration: 200, Train loss: -0.3380, rewards: 0.3997\n",
      "Eval:\n",
      "Hits@1: 0.3860, Hits@3: 0.4506, Hits@10: 0.4987, MRR: 0.4253\n",
      "------------------------------------------------------------\n",
      "Iteration: 210, Train loss: -0.3078, rewards: 0.4100\n",
      "Iteration: 220, Train loss: -0.2891, rewards: 0.3347\n",
      "Iteration: 230, Train loss: -0.2747, rewards: 0.3669\n",
      "Iteration: 240, Train loss: -0.3216, rewards: 0.3906\n",
      "Iteration: 250, Train loss: -0.3728, rewards: 0.4009\n",
      "Iteration: 260, Train loss: -0.3952, rewards: 0.4283\n",
      "Iteration: 270, Train loss: -0.3035, rewards: 0.3453\n",
      "Iteration: 280, Train loss: -0.2890, rewards: 0.3786\n",
      "Iteration: 290, Train loss: -0.3401, rewards: 0.3961\n",
      "Iteration: 300, Train loss: -0.3674, rewards: 0.4069\n",
      "Eval:\n",
      "Hits@1: 0.3876, Hits@3: 0.4552, Hits@10: 0.4977, MRR: 0.4270\n",
      "------------------------------------------------------------\n",
      "Iteration: 310, Train loss: -0.3478, rewards: 0.3948\n",
      "Iteration: 320, Train loss: -0.2873, rewards: 0.3817\n",
      "Iteration: 330, Train loss: -0.3197, rewards: 0.3816\n",
      "Iteration: 340, Train loss: -0.3515, rewards: 0.3939\n",
      "Iteration: 350, Train loss: -0.3616, rewards: 0.4092\n",
      "Iteration: 360, Train loss: -0.3620, rewards: 0.4173\n",
      "Iteration: 370, Train loss: -0.3846, rewards: 0.3837\n",
      "Iteration: 380, Train loss: -0.3830, rewards: 0.3666\n",
      "Iteration: 390, Train loss: -0.3862, rewards: 0.4392\n",
      "Iteration: 400, Train loss: -0.3110, rewards: 0.4572\n",
      "Eval:\n",
      "Hits@1: 0.4087, Hits@3: 0.4591, Hits@10: 0.5026, MRR: 0.4393\n",
      "------------------------------------------------------------\n",
      "Iteration: 410, Train loss: -0.3445, rewards: 0.4289\n",
      "Iteration: 420, Train loss: -0.3118, rewards: 0.4113\n",
      "Iteration: 430, Train loss: -0.3468, rewards: 0.3836\n",
      "Iteration: 440, Train loss: -0.3386, rewards: 0.3823\n",
      "Iteration: 450, Train loss: -0.3164, rewards: 0.3666\n",
      "Iteration: 460, Train loss: -0.3032, rewards: 0.3803\n",
      "Iteration: 470, Train loss: -0.3067, rewards: 0.3642\n",
      "Iteration: 480, Train loss: -0.3359, rewards: 0.3833\n",
      "Iteration: 490, Train loss: -0.4063, rewards: 0.4195\n",
      "Iteration: 500, Train loss: -0.3506, rewards: 0.4080\n",
      "Eval:\n",
      "Hits@1: 0.4107, Hits@3: 0.4598, Hits@10: 0.5056, MRR: 0.4410\n",
      "------------------------------------------------------------\n",
      "Iteration: 510, Train loss: -0.3366, rewards: 0.3934\n",
      "Iteration: 520, Train loss: -0.4098, rewards: 0.4256\n",
      "Iteration: 530, Train loss: -0.3866, rewards: 0.3819\n",
      "Iteration: 540, Train loss: -0.3691, rewards: 0.3917\n",
      "Iteration: 550, Train loss: -0.3833, rewards: 0.4017\n",
      "Iteration: 560, Train loss: -0.3809, rewards: 0.3933\n",
      "Iteration: 570, Train loss: -0.3411, rewards: 0.3847\n",
      "Iteration: 580, Train loss: -0.3321, rewards: 0.4269\n",
      "Iteration: 590, Train loss: -0.2709, rewards: 0.3852\n",
      "Iteration: 600, Train loss: -0.3105, rewards: 0.3831\n",
      "Eval:\n",
      "Hits@1: 0.4245, Hits@3: 0.4723, Hits@10: 0.5188, MRR: 0.4544\n",
      "------------------------------------------------------------\n",
      "Iteration: 610, Train loss: -0.2814, rewards: 0.4116\n",
      "Iteration: 620, Train loss: -0.2969, rewards: 0.4122\n",
      "Iteration: 630, Train loss: -0.3021, rewards: 0.4183\n",
      "Iteration: 640, Train loss: -0.3522, rewards: 0.4305\n",
      "Iteration: 650, Train loss: -0.3176, rewards: 0.4183\n",
      "Iteration: 660, Train loss: -0.3018, rewards: 0.3992\n",
      "Iteration: 670, Train loss: -0.3064, rewards: 0.3786\n",
      "Iteration: 680, Train loss: -0.2724, rewards: 0.4089\n",
      "Iteration: 690, Train loss: -0.2787, rewards: 0.3862\n",
      "Iteration: 700, Train loss: -0.3125, rewards: 0.4437\n",
      "Eval:\n",
      "Hits@1: 0.4051, Hits@3: 0.4670, Hits@10: 0.5102, MRR: 0.4415\n",
      "------------------------------------------------------------\n",
      "Iteration: 710, Train loss: -0.3844, rewards: 0.3937\n",
      "Iteration: 720, Train loss: -0.3563, rewards: 0.4355\n",
      "Iteration: 730, Train loss: -0.2907, rewards: 0.4142\n",
      "Iteration: 740, Train loss: -0.2962, rewards: 0.4011\n",
      "Iteration: 750, Train loss: -0.2966, rewards: 0.4600\n",
      "Iteration: 760, Train loss: -0.3337, rewards: 0.4061\n",
      "Iteration: 770, Train loss: -0.2925, rewards: 0.4225\n",
      "Iteration: 780, Train loss: -0.3147, rewards: 0.4384\n",
      "Iteration: 790, Train loss: -0.2914, rewards: 0.3767\n",
      "Iteration: 800, Train loss: -0.3012, rewards: 0.4119\n",
      "Eval:\n",
      "Hits@1: 0.4225, Hits@3: 0.4717, Hits@10: 0.5158, MRR: 0.4534\n",
      "------------------------------------------------------------\n",
      "Iteration: 810, Train loss: -0.2953, rewards: 0.3802\n",
      "Iteration: 820, Train loss: -0.3181, rewards: 0.4703\n",
      "Iteration: 830, Train loss: -0.2929, rewards: 0.4291\n",
      "Iteration: 840, Train loss: -0.3040, rewards: 0.4236\n",
      "Iteration: 850, Train loss: -0.3267, rewards: 0.4342\n",
      "Iteration: 860, Train loss: -0.3254, rewards: 0.4403\n",
      "Iteration: 870, Train loss: -0.3570, rewards: 0.4069\n",
      "Iteration: 880, Train loss: -0.3402, rewards: 0.4105\n",
      "Iteration: 890, Train loss: -0.2601, rewards: 0.3475\n",
      "Iteration: 900, Train loss: -0.2798, rewards: 0.3811\n",
      "Eval:\n",
      "Hits@1: 0.4212, Hits@3: 0.4713, Hits@10: 0.5092, MRR: 0.4505\n",
      "------------------------------------------------------------\n",
      "Iteration: 910, Train loss: -0.2397, rewards: 0.4522\n",
      "Iteration: 920, Train loss: -0.3211, rewards: 0.4139\n",
      "Iteration: 930, Train loss: -0.3648, rewards: 0.4403\n",
      "Iteration: 940, Train loss: -0.3412, rewards: 0.4636\n",
      "Iteration: 950, Train loss: -0.3106, rewards: 0.4033\n",
      "Iteration: 960, Train loss: -0.3094, rewards: 0.4458\n",
      "Iteration: 970, Train loss: -0.3141, rewards: 0.4042\n",
      "Iteration: 980, Train loss: -0.2641, rewards: 0.4673\n",
      "Iteration: 990, Train loss: -0.3356, rewards: 0.4094\n",
      "Iteration: 1000, Train loss: -0.4061, rewards: 0.4177\n",
      "Eval:\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hits@1: 0.4080, Hits@3: 0.4628, Hits@10: 0.5082, MRR: 0.4421\n",
      "------------------------------------------------------------\n",
      "Iteration: 1010, Train loss: -0.4033, rewards: 0.3956\n",
      "Iteration: 1020, Train loss: -0.3687, rewards: 0.4523\n",
      "Iteration: 1030, Train loss: -0.3557, rewards: 0.4039\n",
      "Iteration: 1040, Train loss: -0.3405, rewards: 0.3887\n",
      "Iteration: 1050, Train loss: -0.3425, rewards: 0.4102\n",
      "Iteration: 1060, Train loss: -0.3498, rewards: 0.4478\n",
      "Iteration: 1070, Train loss: -0.3608, rewards: 0.4208\n",
      "Iteration: 1080, Train loss: -0.3139, rewards: 0.4725\n",
      "Iteration: 1090, Train loss: -0.3436, rewards: 0.4453\n",
      "Iteration: 1100, Train loss: -0.3312, rewards: 0.4139\n",
      "Eval:\n",
      "Hits@1: 0.4242, Hits@3: 0.4661, Hits@10: 0.5175, MRR: 0.4524\n",
      "------------------------------------------------------------\n",
      "Iteration: 1110, Train loss: -0.2921, rewards: 0.4069\n",
      "Iteration: 1120, Train loss: -0.3411, rewards: 0.4644\n",
      "Iteration: 1130, Train loss: -0.3462, rewards: 0.4270\n",
      "Iteration: 1140, Train loss: -0.3666, rewards: 0.3705\n",
      "Iteration: 1150, Train loss: -0.2860, rewards: 0.3877\n",
      "Iteration: 1160, Train loss: -0.3324, rewards: 0.4495\n",
      "Iteration: 1170, Train loss: -0.3368, rewards: 0.3828\n",
      "Iteration: 1180, Train loss: -0.3215, rewards: 0.4169\n",
      "Iteration: 1190, Train loss: -0.3019, rewards: 0.4144\n",
      "Iteration: 1200, Train loss: -0.3614, rewards: 0.4092\n",
      "Eval:\n",
      "Hits@1: 0.4222, Hits@3: 0.4726, Hits@10: 0.5158, MRR: 0.4526\n",
      "------------------------------------------------------------\n",
      "Iteration: 1210, Train loss: -0.3820, rewards: 0.4247\n",
      "Iteration: 1220, Train loss: -0.3245, rewards: 0.4111\n",
      "Iteration: 1230, Train loss: -0.3562, rewards: 0.4144\n",
      "Iteration: 1240, Train loss: -0.4061, rewards: 0.3905\n",
      "Iteration: 1250, Train loss: -0.3881, rewards: 0.3942\n",
      "Iteration: 1260, Train loss: -0.3748, rewards: 0.3962\n",
      "Iteration: 1270, Train loss: -0.3078, rewards: 0.3433\n",
      "Iteration: 1280, Train loss: -0.3430, rewards: 0.4400\n",
      "Iteration: 1290, Train loss: -0.3370, rewards: 0.4092\n",
      "Iteration: 1300, Train loss: -0.3243, rewards: 0.3791\n",
      "Eval:\n",
      "Hits@1: 0.4196, Hits@3: 0.4687, Hits@10: 0.5125, MRR: 0.4510\n",
      "------------------------------------------------------------\n",
      "Iteration: 1310, Train loss: -0.3295, rewards: 0.4620\n",
      "Iteration: 1320, Train loss: -0.3726, rewards: 0.4298\n",
      "Iteration: 1330, Train loss: -0.3829, rewards: 0.4027\n",
      "Iteration: 1340, Train loss: -0.3433, rewards: 0.4234\n",
      "Iteration: 1350, Train loss: -0.3315, rewards: 0.3833\n",
      "Iteration: 1360, Train loss: -0.3032, rewards: 0.4355\n",
      "Iteration: 1370, Train loss: -0.3358, rewards: 0.4139\n",
      "Iteration: 1380, Train loss: -0.3019, rewards: 0.4553\n",
      "Iteration: 1390, Train loss: -0.3186, rewards: 0.4119\n",
      "Iteration: 1400, Train loss: -0.3363, rewards: 0.4409\n",
      "Eval:\n",
      "Hits@1: 0.4143, Hits@3: 0.4703, Hits@10: 0.5082, MRR: 0.4466\n",
      "------------------------------------------------------------\n",
      "Iteration: 1410, Train loss: -0.3257, rewards: 0.4036\n",
      "Iteration: 1420, Train loss: -0.3105, rewards: 0.4125\n",
      "Iteration: 1430, Train loss: -0.3110, rewards: 0.3836\n",
      "Iteration: 1440, Train loss: -0.3101, rewards: 0.3920\n",
      "Iteration: 1450, Train loss: -0.3811, rewards: 0.4111\n",
      "Iteration: 1460, Train loss: -0.3196, rewards: 0.4345\n",
      "Iteration: 1470, Train loss: -0.2960, rewards: 0.4234\n",
      "Iteration: 1480, Train loss: -0.3569, rewards: 0.4511\n",
      "Iteration: 1490, Train loss: -0.3648, rewards: 0.4006\n",
      "Iteration: 1500, Train loss: -0.3178, rewards: 0.3983\n",
      "Eval:\n",
      "Hits@1: 0.3935, Hits@3: 0.4713, Hits@10: 0.5201, MRR: 0.4389\n",
      "------------------------------------------------------------\n",
      "Iteration: 1510, Train loss: -0.3071, rewards: 0.4444\n",
      "Iteration: 1520, Train loss: -0.3182, rewards: 0.3955\n",
      "Iteration: 1530, Train loss: -0.3186, rewards: 0.4584\n",
      "Iteration: 1540, Train loss: -0.3615, rewards: 0.4334\n",
      "Iteration: 1550, Train loss: -0.3228, rewards: 0.4509\n",
      "Iteration: 1560, Train loss: -0.3750, rewards: 0.3862\n",
      "Iteration: 1570, Train loss: -0.3583, rewards: 0.4153\n",
      "Iteration: 1580, Train loss: -0.3813, rewards: 0.4100\n",
      "Iteration: 1590, Train loss: -0.3992, rewards: 0.4578\n",
      "Iteration: 1600, Train loss: -0.3612, rewards: 0.4470\n",
      "Eval:\n",
      "Hits@1: 0.4192, Hits@3: 0.4677, Hits@10: 0.5175, MRR: 0.4504\n",
      "------------------------------------------------------------\n",
      "Iteration: 1610, Train loss: -0.3597, rewards: 0.4723\n",
      "Iteration: 1620, Train loss: -0.3052, rewards: 0.4503\n",
      "Iteration: 1630, Train loss: -0.3192, rewards: 0.4370\n",
      "Iteration: 1640, Train loss: -0.3259, rewards: 0.4444\n",
      "Iteration: 1650, Train loss: -0.3154, rewards: 0.4562\n",
      "Iteration: 1660, Train loss: -0.3548, rewards: 0.4439\n",
      "Iteration: 1690, Train loss: -0.3054, rewards: 0.4395\n",
      "Iteration: 1700, Train loss: -0.2717, rewards: 0.4622\n",
      "Eval:\n",
      "Hits@1: 0.4183, Hits@3: 0.4730, Hits@10: 0.5191, MRR: 0.4521\n",
      "------------------------------------------------------------\n",
      "Iteration: 1710, Train loss: -0.2635, rewards: 0.4697\n",
      "Iteration: 1720, Train loss: -0.2694, rewards: 0.4373\n",
      "Iteration: 1730, Train loss: -0.2820, rewards: 0.4603\n",
      "Iteration: 1740, Train loss: -0.3041, rewards: 0.4152\n",
      "Iteration: 1750, Train loss: -0.3637, rewards: 0.4266\n",
      "Iteration: 1760, Train loss: -0.3330, rewards: 0.4550\n",
      "Iteration: 1770, Train loss: -0.3336, rewards: 0.3928\n",
      "Iteration: 1780, Train loss: -0.3034, rewards: 0.4411\n",
      "Iteration: 1790, Train loss: -0.3092, rewards: 0.4339\n",
      "Iteration: 1800, Train loss: -0.3298, rewards: 0.4111\n",
      "Eval:\n",
      "Hits@1: 0.4199, Hits@3: 0.4693, Hits@10: 0.5211, MRR: 0.4522\n",
      "------------------------------------------------------------\n",
      "Iteration: 1810, Train loss: -0.3280, rewards: 0.3634\n",
      "Iteration: 1820, Train loss: -0.3185, rewards: 0.4436\n",
      "Iteration: 1830, Train loss: -0.3186, rewards: 0.4191\n",
      "Iteration: 1840, Train loss: -0.3867, rewards: 0.4461\n",
      "Iteration: 1850, Train loss: -0.3685, rewards: 0.4528\n",
      "Iteration: 1860, Train loss: -0.3793, rewards: 0.4484\n",
      "Iteration: 1870, Train loss: -0.3620, rewards: 0.4719\n",
      "Iteration: 1880, Train loss: -0.3692, rewards: 0.4919\n",
      "Iteration: 1890, Train loss: -0.3497, rewards: 0.4270\n",
      "Iteration: 1900, Train loss: -0.2903, rewards: 0.4644\n",
      "Eval:\n",
      "Hits@1: 0.4064, Hits@3: 0.4753, Hits@10: 0.5185, MRR: 0.4464\n",
      "------------------------------------------------------------\n",
      "Iteration: 1910, Train loss: -0.3087, rewards: 0.4583\n",
      "Iteration: 1920, Train loss: -0.2670, rewards: 0.4688\n",
      "Iteration: 1930, Train loss: -0.3331, rewards: 0.4023\n",
      "Iteration: 1940, Train loss: -0.3681, rewards: 0.4403\n",
      "Iteration: 1950, Train loss: -0.3102, rewards: 0.3995\n",
      "Iteration: 1960, Train loss: -0.3410, rewards: 0.4450\n",
      "Iteration: 1970, Train loss: -0.3610, rewards: 0.4205\n",
      "Iteration: 1980, Train loss: -0.3103, rewards: 0.4231\n",
      "Iteration: 1990, Train loss: -0.3011, rewards: 0.4789\n",
      "Iteration: 2000, Train loss: -0.2798, rewards: 0.4597\n",
      "Eval:\n",
      "Hits@1: 0.4311, Hits@3: 0.4736, Hits@10: 0.5231, MRR: 0.4596\n",
      "------------------------------------------------------------\n",
      "Hits@1: 0.4400, Hits@3: 0.4860, Hits@10: 0.5335, MRR: 0.4700\n"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "for layer in [1, 3, 4]:\n",
    "    \n",
    "    print(layer)\n",
    "    options['gnn_layer'] = layer\n",
    "    options['model_dir'] = options['model_dir'] + str(layer) + 'layer' + '/'\n",
    "    options['output_dir'] = options['output_dir'] + str(layer) + 'layer' + '/'\n",
    "    \n",
    "    if not os.path.exists(options['model_dir']):\n",
    "        os.mkdir(options['model_dir'])\n",
    "    if not os.path.exists(options['output_dir']):\n",
    "        os.mkdir(options['output_dir'])\n",
    "\n",
    "    trainer = Trainer(options)\n",
    "    trainer.train()\n",
    "\n",
    "    trainer.agent.load_state_dict(torch.load(options['model_dir'] + 'agent.ckpt'))\n",
    "    trainer.agent.eval()\n",
    "    trainer.test_environment = trainer.test_test_environment\n",
    "    test_results = trainer.test(beam=True, print_paths=False, save_model=False)\n",
    "\n",
    "    results[layer] = deepcopy(test_results)\n",
    "    \n",
    "    with open(options['model_dir'] + '../layer_results.pk5', 'wb') as f:\n",
    "        pickle5.dump(results, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ca3d2db1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{1: 'Hits@1: 0.4381, Hits@3: 0.4802, Hits@10: 0.5233, MRR: 0.4657',\n",
       " 3: 'Hits@1: 0.4355, Hits@3: 0.4789, Hits@10: 0.5220, MRR: 0.4634',\n",
       " 4: 'Hits@1: 0.4400, Hits@3: 0.4860, Hits@10: 0.5335, MRR: 0.4700'}"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d146dbbc",
   "metadata": {},
   "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/miniconda3/lib/python3.10/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",
      "/root/Research/GraphRL/experiments/model/ours3.py:334: 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",
      "/root/Research/GraphRL/experiments/model/ours3.py:636: 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.4387, Hits@3: 0.4815, Hits@10: 0.5271, MRR: 0.4685\n",
      "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",
      "Hits@1: 0.4362, Hits@3: 0.4812, Hits@10: 0.5290, MRR: 0.4668\n",
      "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",
      "Hits@1: 0.4397, Hits@3: 0.4866, Hits@10: 0.5396, MRR: 0.4717\n"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "for layer in [1, 3, 4]:\n",
    "\n",
    "    options['test_rollouts'] = 100\n",
    "    options['max_num_actions'] = 100\n",
    "    options['eval_batch_size'] = 8\n",
    "    options['gnn_layer'] = layer\n",
    "    options['model_dir'] = options['model_dir'] + str(layer) + 'layer' + '/'\n",
    "    options['output_dir'] = options['output_dir'] + str(layer) + 'layer' + '/'\n",
    "    \n",
    "    if not os.path.exists(options['model_dir']):\n",
    "        os.mkdir(options['model_dir'])\n",
    "    if not os.path.exists(options['output_dir']):\n",
    "        os.mkdir(options['output_dir'])\n",
    "\n",
    "    trainer = Trainer(options)\n",
    "    #trainer.train()\n",
    "\n",
    "    trainer.agent.load_state_dict(torch.load(options['model_dir'] + 'agent.ckpt'))\n",
    "    trainer.agent.eval()\n",
    "    trainer.test_environment = trainer.test_test_environment\n",
    "    test_results = trainer.test(beam=True, print_paths=False, save_model=False)\n",
    "\n",
    "    results[layer] = deepcopy(test_results)\n",
    "    \n",
    "    with open(options['model_dir'] + '../layer_results.pk5', 'wb') as f:\n",
    "        pickle5.dump(results, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3c51881f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "tmp = pd.DataFrame([[0.4387, 0.4413, 0.4362, 0.4397], [0.6845, 0.6984, 0.6934, 0.6781]]).T\n",
    "tmp.columns = ['WN18RR', 'Nell-995']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "353f150e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(0.0, 0.77046)]"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA3ZElEQVR4nO3dfVyUVf7/8ffMwICo4D2gYqikZZkYBGFb6EZRuW322HZtv37T2M2tVitj219Su7jVFpplftcsdiuzb21F9+1jM8tI3CzKQqk017bWvClB/W6BogLOXL8/BuYGGJwh9Qi8no/H9WA48znXnLkc57w519zYLMuyBAAAYIjd9AAAAED3RhgBAABGEUYAAIBRhBEAAGAUYQQAABhFGAEAAEYRRgAAgFGEEQAAYFSE6QGEwu1265tvvlHv3r1ls9lMDwcAAITAsizt27dPgwcPlt0efP2jU4SRb775RklJSaaHAQAAOmDHjh0aOnRo0Os7RRjp3bu3JM+diY2NNTwaAAAQitraWiUlJXnn8WA6RRhpPjUTGxtLGAEAoJM50ksseAErAAAwijACAACM6hSnaQCjDtdLB7/1/HQ1NP2slw43+H6m5EjNrxT/9AXpwP+1saOmZcohadLQNM/lPZ9LW9f4ldgC6+0RUtoMX1PlM9LhQy1269cnKVMadKrnctVG6Zv1rW+/uY+zp3Ta5X77fjp4rSSdNEHqM8xz+ZtKae/nwet79PEcE0lqPCRteU2t+fVJPlfqNdBz+esK6bsdbdy/pp+94qVhmZ7Lh2qlrf9oo9avPvkHUnTT6d2dFVLdnuD7jk2UEsZ6Lh/4j/S1//ELHLJn3+dJEc6mfX8k1de2Lmy+jbgkqf9Iz+X9e6Q9m9vesfd4n+O7vLPC81iTJEeUFNmjaYvx/HT2lOwOAZ0VYQQnDrdLngm4aVLfv0c69J3f5F8fGAj8J6V9VdInJX4Bwa+uuf/FC6We/T31r/3GM9G0rGnud+Z06eIFntov35aeubL9sd+2S3LGeC6vWdBiom4he64vjOz8UFpxS/DayJjAMPLm7UGCTpNL7vOFkS9LpVWFwWvjhgWGkVeuD14rST9d7gsjG1+Q3lsSvHbweF8YadgvvfCL9vc94+++MLLuUenjp4PXnnyhNO15z+Xar6WSae3v+9fv+8LImvnSv94MXjvuv6TLH/Zcrt4k/fUn7e/7t19KEQM8l1fcIn2zIXjthBukC//oubxtrfT81e3v+w81vsvPXy3VbA9ee36hdO5vPJc/eV4qu0eK7NlGaImRevSTLrzL17fiCU/oba5zxvjqI3t4/p85e7Y/VuB7Iox0Z26XZ/J1H/Y9Wbvd0u7PWvzl32JyH36e1Kfprdb/WiVtf7/1SkFzv/4p0gV3eGr3VUlP/aTtyf9wvWS5pGtKpaHpnvrXfyttejn4+E+91C+M7Gp/4pWkSbf7wsjez1usGrTQeMB32eGUZJMiojybo/mn0/fTcvnqU3KkQWMkm/9ZUMt3cdApvst9kqQxlzWVWK3rHc7AcZ18oVS/r+1ayRcWJKnvcGnURX5l/n0k9RwY+HvKBa3359+n5yDf5f4p0ohJwev7p/ja7BGelY+W/Pcd7ffC9P4jpWET/AsD+w0c7bscEe1ZDWq5P/8+EdGB424Oc976IMfP2VNKHNf+vv3/jfuNlFyNfmUtxt0r3nc5qrc08NTW+2trTJLUL9nzWJPl+f/ScEBqPNj0OLU84aFZ3R7pP/9WUL3iA8PIils8+wxmysNS6n95Lq+5V3rvwabA0iMwtET29Pzb5d7tqT3cIK1d1KIuJvDywFFSdJynvvGQZ3XHERl8LOiybJbV8n/Miae2tlZxcXGqqanp3O+mcR0OnIAje/j+I+7fI/3fF77J/PChwFMCsknpeb59vf1HzxJ1m6GhXjp7ljS6aSL68FFp7f+0PflLUr8R0o1Nf9EdbpD+2GKSamnqU54gIEkrC6T3HwpeOyRdmlnqubyvSrp/dPBaSbp6hZR8jufy326QNr3qWQaPiA6c/COiPMvYOfM8tTU7PcekZY0jytPfESWNu1KK6eep3/6+dPA733UBQcPp+Xfp0ddT2/xfhA/cw4nGsjz/l21NYVmS9lVL326VGuqaAktTaGk8KDXWeR7jE2b7+j83vUXdAb/6g9KUh3yB+c3ftb8ilpgqXdt02rHu/6SFI9of/1WvSCObQu2rs6UNT0r2yMCQ42xa4Rl2tm9laf9uTzBqearKfyUo+Qee0Nd8TCy377oIZ5vDwdEX6vzNysjX6z1/SQR7PUD8ab7l5upN0rq/tH0qoPnnL1b6nhSWXeRZZWiut9yBtz3xNmnirZ7Ln6+U/jY7+DgjYwLDyIePSQf/E7z+1B/7LjfUtb/E6//XnCPS85eTw9nGxN70M6a/r35Ylmdlpfm6lqGhd6Kvtkc/6aqXW68s+K82RPk9WH+8xLOFIm6odHlxaLWS54ktVIQQnKhsNikyOrCtd7xnC7X/1CdDv70f5EtnXu0JNf4hp6EpwDT/cSV5VjnSf+Gr81/Naf7pvyLWeNDz090o1dd4Nn/+K3n7d0sfPtL+WGet862ivfpr6Yu3/MYWEbhCc/pPpPN/77muelNT0PE7tRWwstNDGvsz33Gv3tQUdGICw5DDyXNHGAgjqwqlr94Jfn1ani+M1O6SKpa3v7/Dh3xh5FCtdKim7Tqb3TOJN4vp51nmbWvyd0T5Xo/QLPM6T8AJ+Kver37Imb7asT+TTvqB3yqAs3Ug8I7LJt3SzusdWhrzY88WiginNPKHoe8bwIklpp9vdfFIevSRfvRA6Pue8pB0ycK2V3MaDwb+ERTTX8q+tXUY8u8X1eKvcJvDtxrsPux5sXHzC44Pfuurq/1G+uyV9sc6ZoovjLw4U9q9qXWNzeEJJT+YI53X9LqwL0qltQ8EntryDzBRvaRzbvLt44tSz1zRMgw1B6QuFHgIIwNGeV5gF2ySHnqWr7b/SM9qRqvTBv59e/jqpz7peV1GW6cCHC0O/SmTPVuomldUQhGb6NkA4ETV/PwYithEadJtoe/7v1/0nJJyNbYILQdaB50Bozwvdm8ZhvyDjv9rdGL6eVaTGw96VqGbA4/lkhr2KeD1PzU72//j19kijLx4Tfsr4JfcJ2XM9FyuWC69X9zihch+Aab3YCn7t01jszynxPxXc4akB65UHWeEkR8tCr223/DwQkDz2/gAAGbZbE1/SDo9qzbB9D1JyvxV6Pu9+u+BvzcHHu+pK7/bGn6edMUyX7hpaHG6y9bio7/iT/O8xdz/NTyNBzynsiRPiGi2r6rF28Vb6H+yL4y4GjyvyfN37TtS4hmh3++jjDACAMDR4oiUHHGBr59p1m+4ZwtVy6DTrDnwOPxWklL/y/MavparPm2dtnIflkZdHLjqY3BVRCKMAADQuTQHHn99hgW+Nb09zp7Sfz179Mf1PfBx8AAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMKpDYWTp0qVKTk5WdHS0MjMztW7duqC1EydOlM1ma7VNnjy5w4MGAABdR9hhpKSkRPn5+Zo3b57Wr1+vcePGKTc3V7t3726z/qWXXtKuXbu828aNG+VwOPTTn/70ew8eAAB0fmGHkUWLFmnmzJnKy8vTmDFjVFxcrJiYGC1btqzN+n79+ikhIcG7rVq1SjExMYQRAAAgKcww0tDQoIqKCuXk5Ph2YLcrJydH5eXlIe3jscce05VXXqmePXsGramvr1dtbW3ABgAAuqawwsjevXvlcrkUHx8f0B4fH6+qqqoj9l+3bp02btyoa665pt26oqIixcXFebekpKRwhgkAADqR4/pumscee0xjx45VRkZGu3UFBQWqqanxbjt27DhOIwQAAMdbRDjFAwYMkMPhUHV1dUB7dXW1EhIS2u1bV1enZ599VnfeeecRbycqKkpRUVHhDA0AAHRSYa2MOJ1OpaWlqbS01NvmdrtVWlqqrKysdvs+//zzqq+v13//9393bKQAAKBLCmtlRJLy8/M1Y8YMpaenKyMjQ4sXL1ZdXZ3y8vIkSdOnT9eQIUNUVFQU0O+xxx7TlClT1L9//6MzcgAA0CWEHUamTp2qPXv2qLCwUFVVVUpNTdXKlSu9L2rdvn277PbABZctW7Zo7dq1evPNN4/OqAEAQJdhsyzLMj2II6mtrVVcXJxqamoUGxtrejgAACAEoc7ffDcNAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwqkNhZOnSpUpOTlZ0dLQyMzO1bt26duu/++47zZo1S4mJiYqKitKoUaO0YsWKDg0YAAB0LRHhdigpKVF+fr6Ki4uVmZmpxYsXKzc3V1u2bNGgQYNa1Tc0NOiCCy7QoEGD9MILL2jIkCHatm2b+vTpczTGDwAAOjmbZVlWOB0yMzN11lln6cEHH5Qkud1uJSUl6YYbbtDcuXNb1RcXF2vhwoX65z//qcjIyA4Nsra2VnFxcaqpqVFsbGyH9gEAAI6vUOfvsE7TNDQ0qKKiQjk5Ob4d2O3KyclReXl5m33+9re/KSsrS7NmzVJ8fLxOP/103XPPPXK5XEFvp76+XrW1tQEbAADomsIKI3v37pXL5VJ8fHxAe3x8vKqqqtrs8+9//1svvPCCXC6XVqxYod///ve6//779cc//jHo7RQVFSkuLs67JSUlhTNMAADQiRzzd9O43W4NGjRIf/nLX5SWlqapU6fq9ttvV3FxcdA+BQUFqqmp8W47duw41sMEAACGhPUC1gEDBsjhcKi6ujqgvbq6WgkJCW32SUxMVGRkpBwOh7ft1FNPVVVVlRoaGuR0Olv1iYqKUlRUVDhDAwAAnVRYKyNOp1NpaWkqLS31trndbpWWliorK6vNPuecc46++OILud1ub9vnn3+uxMTENoMIAADoXsI+TZOfn69HHnlETzzxhDZv3qzrr79edXV1ysvLkyRNnz5dBQUF3vrrr79e//nPf3TTTTfp888/12uvvaZ77rlHs2bNOnr3AgAAdFphf87I1KlTtWfPHhUWFqqqqkqpqalauXKl90Wt27dvl93uyzhJSUl64403dPPNN+uMM87QkCFDdNNNN+nWW289evcCAAB0WmF/zogJfM4IAACdzzH5nBEAAICjjTACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwqkNhZOnSpUpOTlZ0dLQyMzO1bt26oLXLly+XzWYL2KKjozs8YAAA0LWEHUZKSkqUn5+vefPmaf369Ro3bpxyc3O1e/fuoH1iY2O1a9cu77Zt27bvNWgAANB1hB1GFi1apJkzZyovL09jxoxRcXGxYmJitGzZsqB9bDabEhISvFt8fPz3GjQAAOg6wgojDQ0NqqioUE5Ojm8HdrtycnJUXl4etN/+/ft10kknKSkpSZdddpk2bdrU7u3U19ertrY2YAMAAF1T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mpqqlStXel/Uun37dtntvgWXuro6/frXv9bOnTvVo0cPnXLKKXrqqac0derUo3cvAABApxX254yYwOeMAADQ+RyTzxkBAAA42ggjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAozoURpYuXark5GRFR0crMzNT69atC1r7yCOP6Nxzz1Xfvn3Vt29f5eTktFsPAAC6l7DDSElJifLz8zVv3jytX79e48aNU25urnbv3t1mfVlZmX7+859r9erVKi8vV1JSki688EJ9/fXX33vwAACg87NZlmWF0yEzM1NnnXWWHnzwQUmS2+1WUlKSbrjhBs2dO/eI/V0ul/r27asHH3xQ06dPD+k2a2trFRcXp5qaGsXGxoYzXAAAYEio83dYKyMNDQ2qqKhQTk6Obwd2u3JyclReXh7SPg4cOKDGxkb169cvaE19fb1qa2sDNgAA0DWFFUb27t0rl8ul+Pj4gPb4+HhVVVWFtI9bb71VgwcPDgg0LRUVFSkuLs67JSUlhTNMAADQiRzXd9PMnz9fzz77rF5++WVFR0cHrSsoKFBNTY1327Fjx3EcJQAAOJ4iwikeMGCAHA6HqqurA9qrq6uVkJDQbt/77rtP8+fP11tvvaUzzjij3dqoqChFRUWFMzQAANBJhbUy4nQ6lZaWptLSUm+b2+1WaWmpsrKygva79957ddddd2nlypVKT0/v+GgBAECXE9bKiCTl5+drxowZSk9PV0ZGhhYvXqy6ujrl5eVJkqZPn64hQ4aoqKhIkrRgwQIVFhbq6aefVnJysve1Jb169VKvXr2O4l0BAACdUdhhZOrUqdqzZ48KCwtVVVWl1NRUrVy50vui1u3bt8tu9y24PPzww2poaNAVV1wRsJ958+bpD3/4w/cbPQAA6PTC/pwRE/icEQAAOp9j8jkjAAAARxthBAAAGEUYAQAARhFGAACAUYQRAABgFGEEAAAYRRgBAABGEUYAAIBRhBEAAGAUYQQAABhFGAEAAEYRRgAAgFGEEQAAYBRhBAAAGEUYAQAARhFGAACAUYQRAABgFGEEAAAYRRgBAABGEUYAAIBRhBEAAGAUYQQAABhFGAEAAEYRRgAAgFGEEQAAYBRhBAAAGEUYAQAARhFGAACAUYQRAABgFGEEAAAYRRgBAABGEUYAAIBRhBEAAGAUYQQAABhFGAEAAEZFmB7A0eJ2u9XQ0GB6GAhRZGSkHA6H6WEAAE4AXSKMNDQ0aOvWrXK73aaHgjD06dNHCQkJstlspocCADCoQ2Fk6dKlWrhwoaqqqjRu3DgtWbJEGRkZbdZu2rRJhYWFqqio0LZt2/TAAw9ozpw532fMASzL0q5du+RwOJSUlCS7nTNPJzrLsnTgwAHt3r1bkpSYmGh4RAAAk8IOIyUlJcrPz1dxcbEyMzO1ePFi5ebmasuWLRo0aFCr+gMHDmjEiBH66U9/qptvvvmoDNrf4cOHdeDAAQ0ePFgxMTFHff84Nnr06CFJ2r17twYNGsQpGwDoxsJeRli0aJFmzpypvLw8jRkzRsXFxYqJidGyZcvarD/rrLO0cOFCXXnllYqKivreA27J5XJJkpxO51HfN46t5vDY2NhoeCQAAJPCCiMNDQ2qqKhQTk6Obwd2u3JyclReXn7UBlVfX6/a2tqA7Uh43UHnw78ZAEAKM4zs3btXLpdL8fHxAe3x8fGqqqo6aoMqKipSXFycd0tKSjpq+wYAACeWE/LVngUFBaqpqfFuO3bsMD0kAABwjIQVRgYMGCCHw6Hq6uqA9urqaiUkJBy1QUVFRSk2NjZg62qKi4vVu3dvHT582Nu2f/9+RUZGauLEiQG1ZWVlstls+vLLL5WcnCybzab3338/oGbOnDkB/TZt2qSf/OQn3vrFixe3GoPL5dLvf/97DR8+XD169NDIkSN11113ybIsb83EiRNls9lks9kUHR2tUaNGqaioKKDmq6++8tbYbDb169dP2dnZeuedd77fQQIAdAthhRGn06m0tDSVlpZ629xut0pLS5WVlXXUB9eVTZo0Sfv379dHH33kbXvnnXeUkJCgDz74QIcOHfK2r169WsOGDdPIkSMlSdHR0br11lvb3X/zu5jmz58fNCguWLBADz/8sB588EFt3rxZCxYs0L333qslS5YE1M2cOVO7du3Sli1bVFBQoMLCQhUXF7fa31tvvaVdu3bpH//4hwYPHqwf/ehHrYIrAAAthX2aJj8/X4888oieeOIJbd68Wddff73q6uqUl5cnSZo+fboKCgq89Q0NDaqsrFRlZaUaGhr09ddfq7KyUl988cXRuxed0OjRo5WYmKiysjJvW1lZmS677DINHz48YOWjrKxMkyZN8v7+q1/9Su+//75WrFgRdP+hvIvpvffe02WXXabJkycrOTlZV1xxhS688EKtW7cuoC4mJkYJCQk66aSTlJeXpzPOOEOrVq1qtb/+/fsrISFBp59+um677TbV1tbqgw8+CPWQAAC6qbDDyNSpU3XfffepsLBQqampqqys1MqVK70vat2+fbt27drlrf/mm280fvx4jR8/Xrt27dJ9992n8ePH65prrjl698KPZVk60HDYyOZ/6iIUkyZN0urVq72/r169WhMnTlR2dra3/eDBg/rggw8Cwsjw4cN13XXXqaCg4Ht96uyECRNUWlqqzz//XJL08ccfa+3atbr44ovbrLcsS++8847++c9/tvtW6oMHD+p///d/JfGWawDAkXXoE1hnz56t2bNnt3md/1/6kpScnBz2JP19HGx0aUzhG8ft9vx9dmeuYpyhH9JJkyZpzpw5Onz4sA4ePKgNGzYoOztbjY2N3tMg5eXlqq+vDwgjkvS73/1Ojz/+uP7617/qqquu6tB4586dq9raWp1yyilyOBxyuVy6++67NW3atIC6hx56SI8++qgaGhrU2Nio6Oho3Xjjja32N2HCBNntdh04cECWZSktLU3nn39+h8YGAOg+Tsh303QXEydOVF1dnT788EO98847GjVqlAYOHKjs7Gzv60bKyso0YsQIDRs2LKDvwIEDdcstt6iwsLDDXxD43HPP6a9//auefvpprV+/Xk888YTuu+8+PfHEEwF106ZNU2Vlpd59911dfPHFuv322zVhwoRW+yspKdGGDRv04osvKiUlRcuXL1dkZGSHxgYA6D66xBfl+esR6dBnd+Yau+1wpKSkaOjQoVq9erW+/fZbZWdnS5IGDx6spKQkvffee1q9erV++MMfttk/Pz9fDz30kB566KEOjfe3v/2t5s6dqyuvvFKSNHbsWG3btk1FRUWaMWOGty4uLk4pKSmSPAEmJSVFZ599dsCH30lSUlKSTj75ZJ188sk6fPiwLr/8cm3cuPGYfPIuAKDr6HIrIzabTTHOCCNbRz5RdNKkSSorK1NZWVnAW3PPO+88vf7661q3bl2rUzTNevXqpd///ve6++67tW/fvrBv+8CBA62+WNDhcLT7OpRevXrppptu0i233NLu6bcrrrhCERERHQ5KAIDuo8uFkc5m0qRJWrt2rSorK70rI5KUnZ2tP//5z2poaAgaRiTPO2vi4uL09NNPB7SH8i6mSy+9VHfffbdee+01ffXVV3r55Ze1aNEiXX755e2O+dprr9Xnn3+uF198MWiNzWbTjTfeqPnz5+vAgQNHOgwAgG6MMGLYpEmTdPDgQaWkpAR8zH52drb27dvnfQtwMJGRkbrrrrsCPpdECu1dTEuWLNEVV1yhX//61zr11FN1yy236Nprr9Vdd93V7pj79eun6dOn6w9/+EO7qygzZsxQY2OjHnzwwSMdBgBAN2azjudbXTqotrZWcXFxqqmpafVprIcOHdLWrVs1fPhwRUdHGxohOoJ/OwDo2tqbv/2xMgIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIox0csnJyVq8eLH3d5vNpldeecXYeAAACBdhxJCrr75aNptN8+fPD2h/5ZVXOvTtv+EoLS3VhAkT1Lt3byUkJOjWW2/V4cOHA2qee+45paamKiYmRieddJIWLlwYcH1ZWZlsNlurraqq6piOHQDQ9RBGDIqOjtaCBQv07bffHrfb/Pjjj3XJJZfooosu0oYNG1RSUqK//e1vmjt3rrfm9ddf17Rp03Tddddp48aNeuihh/TAAw+0+YV3W7Zs0a5du7zboEGDjtt9AQB0DYQRg3JycpSQkKCioqKgNWvXrtW5556rHj16KCkpSTfeeKPq6uo6fJslJSU644wzVFhYqJSUFGVnZ+vee+/V0qVLtW/fPknSk08+qSlTpui6667TiBEjNHnyZBUUFGjBggVq+b2KgwYNUkJCgnez23lIAQDC03Vnjoa69jeX32mJww3t1zYe9NVaVts1HeBwOHTPPfdoyZIl2rlzZ6vrv/zyS1100UX6yU9+ok8++UQlJSVau3atZs+e3aHbk6T6+vpW35Dbo0cPHTp0SBUVFe3W7Ny5U9u2bQtoT01NVWJioi644AK9++67HR4XAKD7ijA9gGPmnsHtX//T5dJpl3suv32n9N6S4LWDx0u/KvNcPvB/0sKRrWv+UNORUeryyy9Xamqq5s2bp8ceeyzguqKiIk2bNk1z5syRJJ188sn605/+pOzsbD388MOtAkMocnNztXjxYj3zzDP62c9+pqqqKt15552SpF27dnlrbr75Zl199dWaNGmSvvjiC91///3emuTkZCUmJqq4uFjp6emqr6/Xo48+qokTJ+qDDz7QmWee2aFjAQDonrruykgnsmDBAj3xxBPavHlzQPvHH3+s5cuXq1evXt4tNzdXbrdbW7duPeJ+L774Ym+/0047TZJ04YUXauHChbruuusUFRWlUaNG6ZJLLpEk7ymWmTNnavbs2frRj34kp9Ops88+W1deeWVAzejRo3XttdcqLS1NEyZM0LJlyzRhwgQ98MADR+24AAC6h667MnLbN+1f74jyXf5hoTSxIHitzS+zxfQ/8r7DdN555yk3N1cFBQW6+uqrve379+/XtddeqxtvvLFVn2HDhh1xv48++qgOHvScYoqMjPS25+fn6+abb9auXbvUt29fffXVVyooKNCIESMked4evGDBAt1zzz2qqqrSwIEDVVpaKknemrZkZGRo7dq1Id1nAACadd0w4uwZem2EU5IztFqbLbx9h2j+/PlKTU3V6NGjvW1nnnmmPvvsM6WkpHRon0OGDAl6nc1m0+DBnlNZzzzzjJKSklqdXnE4HN59PPPMM8rKytLAgQOD7rOyslKJiYkdGisAoPvqumGkkxk7dqymTZumP/3pT962W2+9VWeffbZmz56ta665Rj179tRnn32mVatWtfk221AtXLhQF110kex2u1566SXNnz9fzz33nBwOhyRp7969euGFFzRx4kQdOnRIjz/+uJ5//nmtWbPGu4/Fixdr+PDhOu2003To0CE9+uijevvtt/Xmm292/CAAALolXjNyArnzzjvldru9v59xxhlas2aNPv/8c5177rkaP368CgsLvSsaHfX666/r3HPPVXp6ul577TW9+uqrmjJlSkDNE088ofT0dJ1zzjnatGmTysrKlJGR4b2+oaFBv/nNbzR27FhlZ2fr448/1ltvvaXzzz//e40NAND92KyWHxxxAqqtrVVcXJxqamoUGxsbcN2hQ4e0detWDR8+vEPvLoE5/NsBQNfW3vztj5URAABgFGEEAAAYRRgBAABGEUYAAIBRhBEA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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = sns.lineplot(tmp)\n",
    "g.set(ylim=(0, None))"
   ]
  }
 ],
 "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
}
