{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "132ed467",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle5\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"MIG-0bf58d0a-b3c9-59ef-811b-2885c7169709\"\n",
    "\n",
    "from model.ours3 import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "bce7f995",
   "metadata": {},
   "outputs": [],
   "source": [
    "options = {}\n",
    "\n",
    "#basic setting\n",
    "options['use_cuda'] = True\n",
    "options['vocab_dir'] = '../MINERVA/datasets/data_preprocessed/nell/vocab/'\n",
    "options['data_input_dir'] = '../MINERVA/datasets/data_preprocessed/nell/'\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_nell995-1/'\n",
    "options['output_dir'] = './outputs_nell995-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.15\n",
    "options['Lambda'] = 0.15\n",
    "options['gamma'] = 1\n",
    "options['positive_reward'] = 1\n",
    "options['negative_reward'] = 0\n",
    "options['learning_rate'] = 0.00005\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": "9e8e25fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\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.2730, rewards: 0.1040\n",
      "Iteration: 20, Train loss: -0.3430, rewards: 0.1604\n",
      "Iteration: 30, Train loss: -0.3316, rewards: 0.2178\n",
      "Iteration: 40, Train loss: -0.3715, rewards: 0.3294\n",
      "Iteration: 50, Train loss: -0.3279, rewards: 0.3199\n",
      "Iteration: 60, Train loss: -0.3272, rewards: 0.3722\n",
      "Iteration: 70, Train loss: -0.3705, rewards: 0.3532\n",
      "Iteration: 80, Train loss: -0.2992, rewards: 0.3781\n",
      "Iteration: 90, Train loss: -0.3275, rewards: 0.4359\n",
      "Iteration: 100, Train loss: -0.3212, rewards: 0.4074\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.5212, Hits@3: 0.6151, Hits@10: 0.6556, MRR: 0.5711\n",
      "------------------------------------------------------------\n",
      "Iteration: 110, Train loss: -0.2928, rewards: 0.4454\n",
      "Iteration: 120, Train loss: -0.2639, rewards: 0.4660\n",
      "Iteration: 130, Train loss: -0.2158, rewards: 0.4607\n",
      "Iteration: 140, Train loss: -0.2638, rewards: 0.4835\n",
      "Iteration: 150, Train loss: -0.2027, rewards: 0.4918\n",
      "Iteration: 160, Train loss: -0.2529, rewards: 0.5104\n",
      "Iteration: 170, Train loss: -0.2686, rewards: 0.5154\n",
      "Iteration: 180, Train loss: -0.2225, rewards: 0.4984\n",
      "Iteration: 190, Train loss: -0.2178, rewards: 0.5253\n",
      "Iteration: 200, Train loss: -0.2452, rewards: 0.5052\n",
      "Eval:\n",
      "Hits@1: 0.5930, Hits@3: 0.6446, Hits@10: 0.6722, MRR: 0.6209\n",
      "------------------------------------------------------------\n",
      "Iteration: 210, Train loss: -0.1873, rewards: 0.5196\n",
      "Iteration: 220, Train loss: -0.1955, rewards: 0.5445\n",
      "Iteration: 230, Train loss: -0.1843, rewards: 0.4971\n",
      "Iteration: 240, Train loss: -0.1426, rewards: 0.5245\n",
      "Iteration: 250, Train loss: -0.1656, rewards: 0.5541\n",
      "Iteration: 260, Train loss: -0.2565, rewards: 0.5307\n",
      "Iteration: 270, Train loss: -0.1643, rewards: 0.5120\n",
      "Iteration: 280, Train loss: -0.1514, rewards: 0.5353\n",
      "Iteration: 290, Train loss: -0.1662, rewards: 0.4997\n",
      "Iteration: 300, Train loss: -0.1122, rewards: 0.5275\n",
      "Eval:\n",
      "Hits@1: 0.5801, Hits@3: 0.6519, Hits@10: 0.6685, MRR: 0.6154\n",
      "------------------------------------------------------------\n",
      "Iteration: 310, Train loss: -0.1454, rewards: 0.4842\n",
      "Iteration: 320, Train loss: -0.1793, rewards: 0.5873\n",
      "Iteration: 330, Train loss: -0.1944, rewards: 0.5408\n",
      "Iteration: 340, Train loss: -0.1754, rewards: 0.5352\n",
      "Iteration: 350, Train loss: -0.1711, rewards: 0.5662\n",
      "Iteration: 360, Train loss: -0.1297, rewards: 0.5273\n",
      "Iteration: 370, Train loss: -0.1668, rewards: 0.5656\n",
      "Iteration: 380, Train loss: -0.1935, rewards: 0.5513\n",
      "Iteration: 390, Train loss: -0.1451, rewards: 0.5572\n",
      "Iteration: 400, Train loss: -0.1811, rewards: 0.5634\n",
      "Eval:\n",
      "Hits@1: 0.5820, Hits@3: 0.6483, Hits@10: 0.6814, MRR: 0.6182\n",
      "------------------------------------------------------------\n",
      "Iteration: 410, Train loss: -0.1337, rewards: 0.5637\n",
      "Iteration: 420, Train loss: -0.1445, rewards: 0.5637\n",
      "Iteration: 430, Train loss: -0.1713, rewards: 0.5698\n",
      "Iteration: 440, Train loss: -0.2026, rewards: 0.5780\n",
      "Iteration: 450, Train loss: -0.1910, rewards: 0.5784\n",
      "Iteration: 460, Train loss: -0.1478, rewards: 0.5468\n",
      "Iteration: 470, Train loss: -0.1196, rewards: 0.5654\n",
      "Iteration: 480, Train loss: -0.1546, rewards: 0.5555\n",
      "Iteration: 490, Train loss: -0.1184, rewards: 0.5476\n",
      "Iteration: 500, Train loss: -0.1935, rewards: 0.6007\n",
      "Eval:\n",
      "Hits@1: 0.5930, Hits@3: 0.6409, Hits@10: 0.6722, MRR: 0.6210\n",
      "------------------------------------------------------------\n",
      "Iteration: 510, Train loss: -0.1694, rewards: 0.5616\n",
      "Iteration: 520, Train loss: -0.0899, rewards: 0.5540\n",
      "Iteration: 530, Train loss: -0.0733, rewards: 0.5723\n",
      "Iteration: 540, Train loss: -0.1365, rewards: 0.5827\n",
      "Iteration: 550, Train loss: -0.1301, rewards: 0.5658\n",
      "Iteration: 560, Train loss: -0.1475, rewards: 0.5598\n",
      "Iteration: 570, Train loss: -0.1716, rewards: 0.5818\n",
      "Iteration: 580, Train loss: -0.0862, rewards: 0.5720\n",
      "Iteration: 590, Train loss: -0.0898, rewards: 0.6112\n",
      "Iteration: 600, Train loss: -0.2045, rewards: 0.5630\n",
      "Eval:\n",
      "Hits@1: 0.5875, Hits@3: 0.6427, Hits@10: 0.6759, MRR: 0.6202\n",
      "------------------------------------------------------------\n",
      "Iteration: 610, Train loss: -0.1516, rewards: 0.5613\n",
      "Iteration: 620, Train loss: -0.1373, rewards: 0.6094\n",
      "Iteration: 630, Train loss: -0.1385, rewards: 0.5848\n",
      "Iteration: 640, Train loss: -0.1332, rewards: 0.5750\n",
      "Iteration: 650, Train loss: -0.1100, rewards: 0.5809\n",
      "Iteration: 660, Train loss: -0.1433, rewards: 0.5754\n",
      "Iteration: 670, Train loss: -0.1681, rewards: 0.5804\n",
      "Iteration: 680, Train loss: -0.1186, rewards: 0.5584\n",
      "Iteration: 690, Train loss: -0.1261, rewards: 0.5959\n",
      "Iteration: 700, Train loss: -0.1452, rewards: 0.5837\n",
      "Eval:\n",
      "Hits@1: 0.5912, Hits@3: 0.6390, Hits@10: 0.6740, MRR: 0.6214\n",
      "------------------------------------------------------------\n",
      "Iteration: 710, Train loss: -0.0698, rewards: 0.5665\n",
      "Iteration: 720, Train loss: -0.1106, rewards: 0.5974\n",
      "Iteration: 730, Train loss: -0.1254, rewards: 0.5817\n",
      "Iteration: 740, Train loss: -0.0994, rewards: 0.5747\n",
      "Iteration: 750, Train loss: -0.1224, rewards: 0.5613\n",
      "Iteration: 760, Train loss: -0.1822, rewards: 0.5621\n",
      "Iteration: 770, Train loss: -0.1273, rewards: 0.5873\n",
      "Iteration: 780, Train loss: -0.1373, rewards: 0.5559\n",
      "Iteration: 790, Train loss: -0.1237, rewards: 0.5711\n",
      "Iteration: 800, Train loss: -0.0897, rewards: 0.5843\n",
      "Eval:\n",
      "Hits@1: 0.5967, Hits@3: 0.6519, Hits@10: 0.6777, MRR: 0.6272\n",
      "------------------------------------------------------------\n",
      "Iteration: 810, Train loss: -0.1151, rewards: 0.5794\n",
      "Iteration: 820, Train loss: -0.1482, rewards: 0.6144\n",
      "Iteration: 830, Train loss: -0.0868, rewards: 0.6102\n",
      "Iteration: 840, Train loss: -0.1355, rewards: 0.5923\n",
      "Iteration: 850, Train loss: -0.1466, rewards: 0.6011\n",
      "Iteration: 860, Train loss: -0.1449, rewards: 0.5833\n",
      "Iteration: 870, Train loss: -0.1363, rewards: 0.5855\n",
      "Iteration: 880, Train loss: -0.0968, rewards: 0.6216\n",
      "Iteration: 890, Train loss: -0.1000, rewards: 0.5749\n",
      "Iteration: 900, Train loss: -0.1020, rewards: 0.5742\n",
      "Eval:\n",
      "Hits@1: 0.5912, Hits@3: 0.6519, Hits@10: 0.6832, MRR: 0.6258\n",
      "------------------------------------------------------------\n",
      "Iteration: 910, Train loss: -0.0906, rewards: 0.5898\n",
      "Iteration: 920, Train loss: -0.1127, rewards: 0.6102\n",
      "Iteration: 930, Train loss: -0.1575, rewards: 0.5816\n",
      "Iteration: 940, Train loss: -0.1151, rewards: 0.6238\n",
      "Iteration: 950, Train loss: -0.1468, rewards: 0.5729\n",
      "Iteration: 960, Train loss: -0.1109, rewards: 0.6026\n",
      "Iteration: 970, Train loss: -0.0505, rewards: 0.5652\n",
      "Iteration: 980, Train loss: -0.1296, rewards: 0.5908\n",
      "Iteration: 990, Train loss: -0.1676, rewards: 0.5944\n",
      "Iteration: 1000, Train loss: -0.1326, rewards: 0.5902\n",
      "Eval:\n",
      "Hits@1: 0.5893, Hits@3: 0.6409, Hits@10: 0.6832, MRR: 0.6221\n",
      "------------------------------------------------------------\n",
      "Iteration: 1010, Train loss: -0.1381, rewards: 0.5801\n",
      "Iteration: 1020, Train loss: -0.0867, rewards: 0.5929\n",
      "Iteration: 1030, Train loss: -0.0934, rewards: 0.5913\n",
      "Iteration: 1040, Train loss: -0.0822, rewards: 0.6170\n",
      "Iteration: 1050, Train loss: -0.0844, rewards: 0.6094\n",
      "Iteration: 1060, Train loss: -0.0664, rewards: 0.6035\n",
      "Iteration: 1070, Train loss: -0.1373, rewards: 0.6358\n",
      "Iteration: 1080, Train loss: -0.1430, rewards: 0.6201\n",
      "Iteration: 1090, Train loss: -0.0723, rewards: 0.6059\n",
      "Iteration: 1100, Train loss: -0.1323, rewards: 0.6212\n",
      "Eval:\n",
      "Hits@1: 0.5875, Hits@3: 0.6519, Hits@10: 0.6796, MRR: 0.6222\n",
      "------------------------------------------------------------\n",
      "Iteration: 1110, Train loss: -0.1269, rewards: 0.5981\n",
      "Iteration: 1120, Train loss: -0.1255, rewards: 0.6404\n",
      "Iteration: 1130, Train loss: -0.0756, rewards: 0.5980\n",
      "Iteration: 1140, Train loss: -0.0801, rewards: 0.6085\n",
      "Iteration: 1150, Train loss: -0.0816, rewards: 0.6048\n",
      "Iteration: 1160, Train loss: -0.1402, rewards: 0.5965\n",
      "Iteration: 1170, Train loss: -0.0600, rewards: 0.5805\n",
      "Iteration: 1180, Train loss: -0.1093, rewards: 0.5807\n",
      "Iteration: 1190, Train loss: -0.1445, rewards: 0.6156\n",
      "Iteration: 1200, Train loss: -0.1132, rewards: 0.5735\n",
      "Eval:\n",
      "Hits@1: 0.6059, Hits@3: 0.6538, Hits@10: 0.6814, MRR: 0.6332\n",
      "------------------------------------------------------------\n",
      "Iteration: 1210, Train loss: -0.0730, rewards: 0.5977\n",
      "Iteration: 1220, Train loss: -0.1069, rewards: 0.6026\n",
      "Iteration: 1230, Train loss: -0.1054, rewards: 0.5855\n",
      "Iteration: 1240, Train loss: -0.1392, rewards: 0.6066\n",
      "Iteration: 1250, Train loss: -0.1224, rewards: 0.6057\n",
      "Iteration: 1260, Train loss: -0.1272, rewards: 0.6147\n",
      "Iteration: 1270, Train loss: -0.0859, rewards: 0.5663\n",
      "Iteration: 1280, Train loss: -0.1397, rewards: 0.5988\n",
      "Iteration: 1290, Train loss: -0.1544, rewards: 0.5920\n",
      "Iteration: 1300, Train loss: -0.0874, rewards: 0.6040\n",
      "Eval:\n",
      "Hits@1: 0.6022, Hits@3: 0.6556, Hits@10: 0.6906, MRR: 0.6322\n",
      "------------------------------------------------------------\n",
      "Iteration: 1310, Train loss: -0.1242, rewards: 0.5873\n",
      "Iteration: 1320, Train loss: -0.0635, rewards: 0.6262\n",
      "Iteration: 1330, Train loss: -0.0342, rewards: 0.5834\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration: 1340, Train loss: -0.1001, rewards: 0.5891\n",
      "Iteration: 1350, Train loss: -0.0733, rewards: 0.6256\n",
      "Iteration: 1360, Train loss: -0.0608, rewards: 0.5957\n",
      "Iteration: 1370, Train loss: -0.1495, rewards: 0.5814\n",
      "Iteration: 1380, Train loss: -0.0664, rewards: 0.6161\n",
      "Iteration: 1390, Train loss: -0.0688, rewards: 0.6103\n",
      "Iteration: 1400, Train loss: -0.0501, rewards: 0.6050\n",
      "Eval:\n",
      "Hits@1: 0.5838, Hits@3: 0.6390, Hits@10: 0.6740, MRR: 0.6163\n",
      "------------------------------------------------------------\n",
      "Iteration: 1410, Train loss: -0.0863, rewards: 0.6114\n",
      "Iteration: 1420, Train loss: -0.0343, rewards: 0.6349\n",
      "Iteration: 1430, Train loss: -0.1414, rewards: 0.6231\n",
      "Iteration: 1440, Train loss: -0.0607, rewards: 0.6206\n",
      "Iteration: 1450, Train loss: -0.1201, rewards: 0.6291\n",
      "Iteration: 1460, Train loss: -0.0734, rewards: 0.5898\n",
      "Iteration: 1470, Train loss: -0.0819, rewards: 0.6103\n",
      "Iteration: 1480, Train loss: -0.0931, rewards: 0.6093\n",
      "Iteration: 1490, Train loss: -0.1149, rewards: 0.6136\n",
      "Iteration: 1500, Train loss: -0.1092, rewards: 0.5971\n",
      "Eval:\n",
      "Hits@1: 0.5930, Hits@3: 0.6483, Hits@10: 0.6777, MRR: 0.6244\n",
      "------------------------------------------------------------\n",
      "Iteration: 1510, Train loss: -0.1188, rewards: 0.6140\n",
      "Iteration: 1520, Train loss: -0.1164, rewards: 0.6225\n",
      "Iteration: 1530, Train loss: -0.0279, rewards: 0.6188\n",
      "Iteration: 1540, Train loss: -0.1306, rewards: 0.5985\n",
      "Iteration: 1550, Train loss: -0.2263, rewards: 0.6398\n",
      "Iteration: 1560, Train loss: -0.0960, rewards: 0.5625\n",
      "Iteration: 1570, Train loss: -0.1157, rewards: 0.5895\n",
      "Iteration: 1580, Train loss: -0.0787, rewards: 0.6072\n",
      "Iteration: 1590, Train loss: -0.0725, rewards: 0.6175\n",
      "Iteration: 1600, Train loss: -0.0759, rewards: 0.6281\n",
      "Eval:\n",
      "Hits@1: 0.5912, Hits@3: 0.6390, Hits@10: 0.6740, MRR: 0.6212\n",
      "------------------------------------------------------------\n",
      "Iteration: 1610, Train loss: -0.1127, rewards: 0.6043\n",
      "Iteration: 1620, Train loss: -0.1322, rewards: 0.6192\n",
      "Iteration: 1630, Train loss: -0.0606, rewards: 0.6230\n",
      "Iteration: 1640, Train loss: -0.1263, rewards: 0.6241\n",
      "Iteration: 1650, Train loss: -0.0834, rewards: 0.6405\n",
      "Iteration: 1660, Train loss: -0.0805, rewards: 0.6116\n",
      "Iteration: 1670, Train loss: -0.1079, rewards: 0.6145\n",
      "Iteration: 1680, Train loss: -0.0849, rewards: 0.6048\n",
      "Iteration: 1690, Train loss: -0.1162, rewards: 0.6391\n",
      "Iteration: 1700, Train loss: -0.1220, rewards: 0.6034\n",
      "Eval:\n",
      "Hits@1: 0.5912, Hits@3: 0.6519, Hits@10: 0.6851, MRR: 0.6256\n",
      "------------------------------------------------------------\n",
      "Iteration: 1710, Train loss: -0.1543, rewards: 0.6123\n",
      "Iteration: 1720, Train loss: -0.1040, rewards: 0.6141\n",
      "Iteration: 1730, Train loss: -0.0578, rewards: 0.6273\n",
      "Iteration: 1740, Train loss: -0.0241, rewards: 0.6059\n",
      "Iteration: 1750, Train loss: -0.0763, rewards: 0.6366\n",
      "Iteration: 1760, Train loss: -0.0752, rewards: 0.6273\n",
      "Iteration: 1770, Train loss: -0.0788, rewards: 0.5787\n",
      "Iteration: 1780, Train loss: -0.1260, rewards: 0.6240\n",
      "Iteration: 1790, Train loss: -0.0999, rewards: 0.6050\n",
      "Iteration: 1800, Train loss: -0.1149, rewards: 0.6288\n",
      "Eval:\n",
      "Hits@1: 0.5912, Hits@3: 0.6409, Hits@10: 0.6740, MRR: 0.6213\n",
      "------------------------------------------------------------\n",
      "Iteration: 1810, Train loss: -0.0904, rewards: 0.6434\n",
      "Iteration: 1820, Train loss: -0.0463, rewards: 0.6237\n",
      "Iteration: 1830, Train loss: -0.0200, rewards: 0.6080\n",
      "Iteration: 1840, Train loss: -0.1198, rewards: 0.6582\n",
      "Iteration: 1850, Train loss: -0.0943, rewards: 0.6436\n",
      "Iteration: 1860, Train loss: -0.1155, rewards: 0.6613\n",
      "Iteration: 1870, Train loss: -0.0532, rewards: 0.6420\n",
      "Iteration: 1880, Train loss: -0.0947, rewards: 0.5891\n",
      "Iteration: 1890, Train loss: -0.0550, rewards: 0.6227\n",
      "Iteration: 1900, Train loss: -0.1353, rewards: 0.6404\n",
      "Eval:\n",
      "Hits@1: 0.5930, Hits@3: 0.6390, Hits@10: 0.6740, MRR: 0.6204\n",
      "------------------------------------------------------------\n",
      "Iteration: 1910, Train loss: -0.0222, rewards: 0.6031\n",
      "Iteration: 1920, Train loss: -0.0819, rewards: 0.6415\n",
      "Iteration: 1930, Train loss: -0.0994, rewards: 0.6173\n",
      "Iteration: 1940, Train loss: -0.1034, rewards: 0.5963\n",
      "Iteration: 1950, Train loss: -0.0717, rewards: 0.6184\n",
      "Iteration: 1960, Train loss: -0.0899, rewards: 0.6170\n",
      "Iteration: 1970, Train loss: -0.0644, rewards: 0.6522\n",
      "Iteration: 1980, Train loss: -0.1586, rewards: 0.6171\n",
      "Iteration: 1990, Train loss: -0.1040, rewards: 0.6030\n",
      "Iteration: 2000, Train loss: -0.0947, rewards: 0.6423\n",
      "Eval:\n",
      "Hits@1: 0.5820, Hits@3: 0.6427, Hits@10: 0.6814, MRR: 0.6173\n",
      "------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "trainer = Trainer(options)\n",
    "trainer.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e48d79b0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Hits@1: 0.6984, Hits@3: 0.7960, Hits@10: 0.8545, MRR: 0.7555\n"
     ]
    }
   ],
   "source": [
    "options['test_rollouts'] = 100\n",
    "options['max_num_actions'] = 100\n",
    "options['eval_batch_size'] = 8\n",
    "trainer = Trainer(options)\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b9f2edfa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hits@1: 0.6984, Hits@3: 0.7960, Hits@10: 0.8545, MRR: 0.7555\n"
     ]
    }
   ],
   "source": [
    "print(test_results)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "21a2147c",
   "metadata": {},
   "source": [
    "# Check Embedding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7af17c07",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "Reading vocab...\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\n",
      "batcher loaded\n",
      "KG constructed\n",
      "Reading vocab...\n",
      "Contains full graph\n",
      "batcher loaded\n",
      "KG constructed\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Agent(\n",
       "  (entity_embedding): Embedding(75494, 100)\n",
       "  (relation_embedding): Embedding(404, 100)\n",
       "  (policy_step): Policy_step(\n",
       "    (batch_norm): BatchNorm1d(800, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (lstm_cell): LSTMCell(200, 800)\n",
       "    (l1): Linear(in_features=200, out_features=200, bias=True)\n",
       "    (l2): Linear(in_features=800, out_features=800, bias=True)\n",
       "    (l3): Linear(in_features=800, out_features=800, bias=True)\n",
       "  )\n",
       "  (policy_mlp): Policy_mlp(\n",
       "    (mlp_l1): Linear(in_features=1000, out_features=800, bias=True)\n",
       "    (mlp_l2): Linear(in_features=800, out_features=400, bias=True)\n",
       "  )\n",
       "  (node_conv): ModuleList(\n",
       "    (0): node_aggregation(\n",
       "      (query_encoder): Linear(in_features=100, out_features=100, bias=True)\n",
       "      (key_encoder): Linear(in_features=100, out_features=100, bias=True)\n",
       "      (value_encoder): Linear(in_features=200, out_features=100, bias=True)\n",
       "      (mlp): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=200, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=200, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp_norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "      (norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "    (1): node_aggregation(\n",
       "      (query_encoder): Linear(in_features=100, out_features=100, bias=True)\n",
       "      (key_encoder): Linear(in_features=100, out_features=100, bias=True)\n",
       "      (value_encoder): Linear(in_features=200, out_features=100, bias=True)\n",
       "      (mlp): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=200, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=200, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp_norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "      (norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "  )\n",
       "  (rel_conv): ModuleList(\n",
       "    (0): relation_aggregation(\n",
       "      (node_encoder): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=100, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=100, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=200, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=200, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp_norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "      (norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "    (1): relation_aggregation(\n",
       "      (node_encoder): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=100, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=100, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp): Sequential(\n",
       "        (0): Linear(in_features=100, out_features=200, bias=True)\n",
       "        (1): Mish()\n",
       "        (2): Linear(in_features=200, out_features=100, bias=True)\n",
       "      )\n",
       "      (mlp_norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "      (norm): LayerNorm((100,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "  )\n",
       "  (gate1_linear): Linear(in_features=400, out_features=1200, bias=True)\n",
       "  (gate2_linear): Linear(in_features=400, out_features=1200, bias=True)\n",
       "  (state_encoder): Sequential(\n",
       "    (0): Linear(in_features=1700, out_features=200, bias=True)\n",
       "    (1): Mish()\n",
       "    (2): LayerNorm((200,), eps=1e-05, elementwise_affine=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trainer = Trainer(options)\n",
    "trainer.agent.load_state_dict(torch.load(options['model_dir'] + 'agent.ckpt'))\n",
    "trainer.agent.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "87d59758",
   "metadata": {},
   "outputs": [],
   "source": [
    "coach = [k for k in np.arange(75494) if 'coach' in trainer.rev_entity_vocab[k]]\n",
    "bank = [k for k in np.arange(75494) if 'bank' in trainer.rev_entity_vocab[k]]\n",
    "drug = [k for k in np.arange(75494) if 'drug' in trainer.rev_entity_vocab[k]]\n",
    "sampled_entity = coach + bank + drug\n",
    "sampled_embed = trainer.agent.entity_embedding.weight.data.cpu().numpy()[sampled_entity]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "293dce04",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.manifold import TSNE\n",
    "tsne = TSNE(random_state = 0, n_iter = 1000, metric = 'cosine')\n",
    "embeddings2d = tsne.fit_transform(sampled_embed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "a1af2ab3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "embeddingsdf = pd.DataFrame()\n",
    "embeddingsdf['relation'] = [trainer.rev_entity_vocab[k] for k in sampled_entity]\n",
    "embeddingsdf['x'] = embeddings2d[:,0]\n",
    "embeddingsdf['y'] = embeddings2d[:,1]\n",
    "embeddingsdf.head()\n",
    "embeddingsdf.relation = embeddingsdf.relation.str.split(':').str[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "092f2244",
   "metadata": {},
   "outputs": [],
   "source": [
    "select1 = embeddingsdf.relation.str.contains('coach')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "select2 = embeddingsdf.relation.str.contains('bank')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "select3 = embeddingsdf.relation.str.contains('drug')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "sample = embeddingsdf.loc[select1|select2|select3]\n",
    "sample['group'] = ''\n",
    "sample.loc[select1, 'group'] = 'coach'\n",
    "sample.loc[select2, 'group'] = 'bank'\n",
    "sample.loc[select3, 'group'] = 'drug'\n",
    "# sample_id = sample.sample(100).index.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "535ba865",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: xlabel='x', ylabel='y'>"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkQAAAGwCAYAAABIC3rIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB/b0lEQVR4nO3dd5hTZfrw8W+SSZ3MJNMLM0OXXqQKKtIEsWJ3VQRlsSzYcC28rn1VRH9YsDdk7WJdKyIqukov0qv0YXrJtPTz/hEZGCYZYFra/bmuuTTnSU7uA0zOnafcj0pRFAUhhBBCiCimDnYAQgghhBDBJgmREEIIIaKeJERCCCGEiHqSEAkhhBAi6klCJIQQQoioJwmREEIIIaKeJERCCCGEiHoxwQ4g1Hi9XnJzc4mLi0OlUgU7HCGEEEIcB0VRqKioIDMzE7X6xPt7JCE6Sm5uLtnZ2cEOQwghhBCNsG/fPrKysk74dZIQHSUuLg7w/YHGx8cHORohhBBCHA+bzUZ2dnbtffxESUJ0lEPDZPHx8ZIQCSGEEGGmsdNdZFK1EEIIIaKeJERCCCGEiHqSEAkhhBAi6skcIiGEEKIZeDweXC5XsMOIWFqtFo1G02Lnl4RICCGEaAJFUcjLy6OsrCzYoUQ8q9VKenp6i9QJlIRICCGEaIJDyVBqaiomk0mK+rYARVGorq6moKAAgIyMjGZ/D0mIhBBCiEbyeDy1yVBSUlKww4loRqMRgIKCAlJTU5t9+EwmVQshhBCNdGjOkMlkCnIk0eHQn3NLzNWShEgIIYRoIhkmax0t+ecsQ2ZCCBEKvB6oLgIFMCWBRj6ehWhN8hsnhBDBVn4A1n8Eq//jS4x6XQb9J4JVNpoWorXIkJkQQgST7QC8PR5+eBBK/oSyPfDrk/DmWCjbF+zoRBQaPnw4t912W7DDaHWSEAkhRDDt/AmKttU/bjsA6z709RiJqODxKizZWcwXaw+wZGcxHq8S7JCiigyZCSFEIDVlUFXo67UxWCE+E+IyoLkmdtptsPa9wO3rPoR+14A5tXneT4Ss7zYc5KEvN3Gw3F57LMNi4IHzunNWz+avudNYTqcTnU4X7DBahPQQCSGEPxX58PUd8PwAeOdieH0UvDYS8teD0kzf3NUa0DRwc4nRg6rltioQoeG7DQe56Z3VdZIhgLxyOze9s5rvNhxssfeuqqrimmuuwWw2k5GRwf/93//VaW/Xrh2PPPII11xzDfHx8Vx//fX8/PPPqFSqOpW5165di0qlYvfu3bXHXnvtNbKzszGZTFx44YXMnj0bq9XaYtfSVJIQCSHE0TwuWPYKbPi47vGKgzDvfCjf3zzvo4uFQVMCtw+YDLFS7C+SebwKD325CX8p9qFjD325qcWGz+68804WL17MF198wffff8/PP//M6tWr6zznqaeeok+fPqxZs4b77rvvuM7722+/ceONN3Lrrbeydu1azjzzTB599NGWuIRmI0NmQghxtIo8WP6K/7aaUsjf0HwrwNoMgE5nwo6FdY9n9oeTzmqe9xAha/mukno9Q0dSgIPldpbvKmFIx+ZNjisrK3njjTd45513GDVqFADz5s0jKyurzvNGjhzJHXfcUft4375jT/afM2cO48aN45///CcAJ510Er///jtfffVVM15B85IeIiGEOJrHAc7KwO3FO5vvveLS4IIX4KqPfQlQ5zPh8nfginchPnTmjoiWUVAROBlqzPNOxM6dO3E6nQwePLj2WGJiIl26dKnzvAEDBpzwubdu3cqgQYPqHDv6caiRHiIhhDhajBFik6GqyH97eq/mfb+4NIg7E9qdDiigNTbv+UXISo0zNOvzWkJsbGydx2q1ry9FOWIuXUtspdHawraHaObMmahUqjq1Eux2O1OnTiUpKQmz2czFF19Mfn5+8IIUQoSnuAw44x7/bda2kNy5Zd5Xa5BkKMoMap9IhsVAoHWLKnyrzQa1T2z29+7YsSNarZZly5bVHistLWXbNj9lII6QkpICwMGDhyd7r127ts5zunTpwooVK+ocO/pxqAnLhGjFihW88sor9O7du87x22+/nS+//JL58+ezePFicnNzueiii4IUpRAtyOPy9V7UlAc7ksikVkOPC2HUA76Jz4dknwLXfOFbfi9EM9CoVTxwXneAeknRoccPnNcdjbr59/Aym81MnjyZO++8kx9//JENGzYwadKk2h6gQDp16kR2djYPPvgg27dv5+uvv663Ou3mm2/mm2++Yfbs2Wzfvp1XXnmFb7/9NqT3fAu7hKiyspKrrrqK1157jYSEhNrj5eXlvPHGG8yePZuRI0fSv39/5s6dy++//87SpUuDGLEQzUhRoGQXLHoE5p0L718OW76GysJgRxZ5YpNhyFS4aSnc8CtMWwl/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hyfjHpqArCiKMmPGjLCcjHvInj17FED56aefFEWJjGvcv3+/0rlzZ+WKK65Q3G53vfZIuMZDjjWpOj8/v/bYK6+8osTHxyt2u70VI2ycQYMGKdOmTat97PF4lDZt2kT0pOqnnnqq9lh5eXlYTar2er3K1KlTlczMTGXbtm312g9Nxv34449rj23ZsiVsJx0fMmLECGXixIkRc302m63OfXD9+vXKgAEDlKuvvlpZv359s12nJERhZteuXfVWmZWVlSlpaWnKhAkTlA0bNigffPCBYjKZlFdeeSV4gZ6ApUuXKnPmzFHWrFmj7N69W1m0aJEydOhQpWPHjrU3yXC/xv379yudOnVSRo0apezfv185ePBg7c8h4X6NiuJLZNesWaM89NBDitlsVtasWaOsWbNGqaioUBRFUdxut9KzZ09lzJgxytq1a5XvvvtOSUlJUWbMmBHkyI/PBx98oOj1euWtt95SNm3apFx//fWK1Wqts2ounFRUVNT+HQHK7NmzlTVr1ih79uxRFEVRZs6cqVitVuWLL75Q1q1bp1xwwQVK+/btlZqamiBHfnxuuukmxWKxKD///HOd37nq6ura59x4441KTk6O8uOPPyorV65UhgwZogwZMiSIUZ+Ye+65R1m8eLGya9cuZd26dco999yjqFQq5fvvv1cUJfyvL5AjV5kpSvNcpyREYcZfQqQoivLHH38op512mqLX65U2bdooM2fODE6AjbBu3TplxIgRSmJioqLX65V27dopN954o7J///46zwvna5w7d64C+P05Ujhfo6IoysSJE/1e46GePkVRlN27dyvjxo1TjEajkpycrNxxxx2Ky+UKXtAnaM6cOUpOTo6i0+mUQYMGKUuXLg12SI32008/+f37mjhxoqIovh6W++67T0lLS1P0er0yatQoZevWrcEN+gQE+p2bO3du7XNqamqUf/zjH0pCQoJiMpmUCy+8sM4XlVB33XXXKW3btlV0Op2SkpKijBo1qjYZUpTwv75Ajk6ImuM6VYoS4rNWhRBCCCFamKwyE0IIIUTUk4RICCGEEFFPEiIhhBBCRD1JiIQQQggR9SQhEkIIIUTUk4RICCGEEFFPEiIhhBBCRD1JiIQQQggR9SQhEkIIIUTUk4RICCGEEFFPEiIhhBBCRD1JiIQQEa2wsJD09HQee+yx2mO///47Op2ORYsWBTEyIUQokc1dhRAR75tvvmH8+PH8/vvvdOnShb59+3LBBRcwe/bsYIcmhAgRkhAJIaLC1KlT+eGHHxgwYADr169nxYoV6PX6YIclhAgRkhAJIaJCTU0NPXv2ZN++faxatYpevXoFOyQhRAiROURCiKiwc+dOcnNz8Xq97N69O9jhCCFCjPQQCSEintPpZNCgQfTt25cuXbrwzDPPsH79elJTU4MdmhAiREhCJISIeHfeeScff/wxf/zxB2azmTPOOAOLxcJXX30V7NCEECFChsyEEBHt559/5plnnuHtt98mPj4etVrN22+/za+//spLL70U7PCEECFCeoiEEEIIEfWkh0gIIYQQUU8SIiGEEEJEPUmIhBBCCBH1JCESQgghRNSThEgIIYQQUU8SIiGEEEJEPUmIhBBCCBH1JCESQgghRNSThEgIIYQQUU8SIiGEEEJEPUmIhBBCCBH1/j9qpzzBIXeyaQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.scatterplot(x = sample.iloc[sample_id].x, y = sample.iloc[sample_id].y, hue = sample.iloc[sample_id].group.values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "fc1d4aaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "with torch.no_grad():\n",
    "    for entity_episode in trainer.test_environment.get_episodes():\n",
    "        head, link, tail = trainer.get_graph(entity_episode, mode = 'train')\n",
    "        trainer.agent.mgat(head, link, tail)\n",
    "        break\n",
    "        \n",
    "sampled_embed = trainer.agent.ent_embed.cpu().numpy()[sampled_entity]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "85851e92",
   "metadata": {},
   "outputs": [],
   "source": [
    "tsne = TSNE(random_state = 0, n_iter = 1000, metric = 'cosine')\n",
    "embeddings2d = tsne.fit_transform(sampled_embed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "e023852d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "embeddingsdf = pd.DataFrame()\n",
    "embeddingsdf['relation'] = [trainer.rev_entity_vocab[k] for k in sampled_entity]\n",
    "embeddingsdf['x'] = embeddings2d[:,0]\n",
    "embeddingsdf['y'] = embeddings2d[:,1]\n",
    "embeddingsdf.head()\n",
    "embeddingsdf.relation = embeddingsdf.relation.str.split(':').str[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "169e93a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "select1 = embeddingsdf.relation.str.contains('coach')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "select2 = embeddingsdf.relation.str.contains('bank')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "select3 = embeddingsdf.relation.str.contains('drug')#&(~embeddingsdf.relation.str.contains('_inv'))\n",
    "sample = embeddingsdf.loc[select1|select2|select3]\n",
    "sample['group'] = ''\n",
    "sample.loc[select1, 'group'] = 'coach'\n",
    "sample.loc[select2, 'group'] = 'bank'\n",
    "sample.loc[select3, 'group'] = 'drug'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "88074da9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: xlabel='x', ylabel='y'>"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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pkzx5eTk+NasWdOmfsdg27fffrulbNWqVRpsu49qampafVYvXbrUN2rUKN95553nW7p0qa53GCnxiXAbNmxoM6urqqrKl5mZ6Tv//PN9y5Yt873xxhu+uLg439NPPx2+QCPU1q1bfX379vUdc8wxvq1bt/qKiopaHjvoenecN954w2e1Wn0vvviib8WKFb7Jkyf7kpKSfMXFxeEOLeJdddVVPofD4Zs1a1ar3+OGhoaWY6688kpffn6+78svv/T9+OOPvrFjx/rGjh0bxqi7l11ndfl8ut7hosQnwgVKfHw+n2/x4sW+ww8/3Ge1Wn09evTw3XvvveEJMMK98MILPiDgY1e63h3nscce8+Xn5/ssFotvzJgxvh9++CHcIXULwX6PX3jhhZZjGhsbfX/4wx98ycnJvri4ON/pp5/eKsmX/fPrxEfXOzwMPp/PF/L+NREREZEw0KwuERERiRpKfERERCRqKPERERGRqKHER0RERKKGEh8RERGJGkp8REREJGoo8REREZGoocRHREREooYSHxEREYkaSnxEREQkaijxERERkaihxEdEurWysjKysrL4xz/+0VL2/fffY7FY+OKLL8IYmYiEgzYpFZFu7+OPP+a0007j+++/p3///gwfPpxTTz2VadOmhTs0EQkxJT4iEhWmTJnC559/zqhRo1i6dCnz58/HarWGOywRCTElPiISFRobGxkyZAhbtmxhwYIFHHjggeEOSUTCQGN8RCQqrF+/nsLCQrxeLxs3bgx3OCISJmrxEZFur6mpiTFjxjB8+HD69+/Pww8/zNKlS8nIyAh3aCISYkp8RKTb++Mf/8jbb7/N4sWLSUhIYPz48TgcDj788MNwhyYiIaauLhHp1mbNmsXDDz/Myy+/jN1ux2g08vLLL/PNN9/wr3/9K9zhiUiIqcVHREREooZafERERCRqKPERERGRqKHER0RERKKGEh8RERGJGkp8REREJGoo8REREZGoocRHREREooYSHxEREYkaSnxEREQkaijxERERkaihxEdERESixv8DXhANEqmJeaUAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.scatterplot(x = sample.iloc[sample_id].x, y = sample.iloc[sample_id].y, hue = sample.iloc[sample_id].group.values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e6828d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d148e729",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
