{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "83f98128",
   "metadata": {},
   "source": [
    "### Train the inductive link prediction model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ea7a7dae",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_name = 'WN18RR_v4'\n",
    "model_id = 'SiaLP_3_new'\n",
    "lower_bound = 1\n",
    "upper_bound_path = 10\n",
    "upper_bound_subg = 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "54797cb9",
   "metadata": {},
   "outputs": [],
   "source": [
    "#difine the names for saving\n",
    "model_name = 'Model_' + model_id + '_' + data_name\n",
    "one_hop_model_name = 'One_hop_model_' + model_id + '_' + data_name\n",
    "ids_name = 'IDs_' + model_id + '_' + data_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fba371e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import librosa\n",
    "import opensmile\n",
    "import os\n",
    "import sys\n",
    "import numpy as np\n",
    "import random\n",
    "import pickle\n",
    "\n",
    "from collections import defaultdict\n",
    "from copy import deepcopy\n",
    "from sklearn.utils import shuffle\n",
    "from sys import getsizeof\n",
    "\n",
    "import tensorflow as tf\n",
    "from tensorflow import keras\n",
    "from tensorflow.keras import layers\n",
    "from tensorflow.keras import Model\n",
    "from tensorflow.keras import initializers\n",
    "from tensorflow.keras.utils import plot_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c098e1a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "class LoadKG:\n",
    "    \n",
    "    def __init__(self):\n",
    "        \n",
    "        self.x = 'Hello'\n",
    "        \n",
    "    def load_train_data(self, data_path, one_hop, data, s_t_r, entity2id, id2entity,\n",
    "                     relation2id, id2relation):\n",
    "        \n",
    "        data_ = set()\n",
    "    \n",
    "        ####load the train, valid and test set##########\n",
    "        with open (data_path, 'r') as f:\n",
    "            \n",
    "            data_ini = f.readlines()\n",
    "                        \n",
    "            for i in range(len(data_ini)):\n",
    "            \n",
    "                x = data_ini[i].split()\n",
    "                \n",
    "                x_ = tuple(x)\n",
    "                \n",
    "                data_.add(x_)\n",
    "        \n",
    "        ####relation dict#################\n",
    "        index = len(relation2id)\n",
    "     \n",
    "        for key in data_:\n",
    "            \n",
    "            if key[1] not in relation2id:\n",
    "                \n",
    "                relation = key[1]\n",
    "                \n",
    "                relation2id[relation] = index\n",
    "                \n",
    "                id2relation[index] = relation\n",
    "                \n",
    "                index += 1\n",
    "                \n",
    "                #the inverse relation\n",
    "                iv_r = '_inverse_' + relation\n",
    "                \n",
    "                relation2id[iv_r] = index\n",
    "                \n",
    "                id2relation[index] = iv_r\n",
    "                \n",
    "                index += 1\n",
    "        \n",
    "        #get the id of the inverse relation, by above definition, initial relation has \n",
    "        #always even id, while inverse relation has always odd id.\n",
    "        def inverse_r(r):\n",
    "            \n",
    "            if r % 2 == 0: #initial relation\n",
    "                \n",
    "                iv_r = r + 1\n",
    "            \n",
    "            else: #inverse relation\n",
    "                \n",
    "                iv_r = r - 1\n",
    "            \n",
    "            return(iv_r)\n",
    "        \n",
    "        ####entity dict###################\n",
    "        index = len(entity2id)\n",
    "        \n",
    "        for key in data_:\n",
    "            \n",
    "            source, target = key[0], key[2]\n",
    "            \n",
    "            if source not in entity2id:\n",
    "                                \n",
    "                entity2id[source] = index\n",
    "                \n",
    "                id2entity[index] = source\n",
    "                \n",
    "                index += 1\n",
    "            \n",
    "            if target not in entity2id:\n",
    "                \n",
    "                entity2id[target] = index\n",
    "                \n",
    "                id2entity[index] = target\n",
    "                \n",
    "                index += 1\n",
    "                \n",
    "        #create the set of triples using id instead of string        \n",
    "        for ele in data_:\n",
    "            \n",
    "            s = entity2id[ele[0]]\n",
    "            \n",
    "            r = relation2id[ele[1]]\n",
    "            \n",
    "            t = entity2id[ele[2]]\n",
    "            \n",
    "            if (s,r,t) not in data:\n",
    "                \n",
    "                data.add((s,r,t))\n",
    "            \n",
    "            s_t_r[(s,t)].add(r)\n",
    "            \n",
    "            if s not in one_hop:\n",
    "                \n",
    "                one_hop[s] = set()\n",
    "            \n",
    "            one_hop[s].add((r,t))\n",
    "            \n",
    "            if t not in one_hop:\n",
    "                \n",
    "                one_hop[t] = set()\n",
    "            \n",
    "            r_inv = inverse_r(r)\n",
    "            \n",
    "            s_t_r[(t,s)].add(r_inv)\n",
    "            \n",
    "            one_hop[t].add((r_inv,s))\n",
    "            \n",
    "        #change each set in one_hop to list\n",
    "        for e in one_hop:\n",
    "            \n",
    "            one_hop[e] = list(one_hop[e])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f6cd0f8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ObtainPathsByDynamicProgramming:\n",
    "\n",
    "    def __init__(self, amount_bd=50, size_bd=50, threshold=20000):\n",
    "        \n",
    "        self.amount_bd = amount_bd #how many Tuples we choose in one_hop[node] for next recursion\n",
    "                        \n",
    "        self.size_bd = size_bd #size bound limit the number of paths to a target entity t\n",
    "        \n",
    "        #number of times paths with specific length been performed for recursion\n",
    "        self.threshold = threshold\n",
    "        \n",
    "    '''\n",
    "    Given an entity s, the function will find the paths from s to other entities, using recursion.\n",
    "    \n",
    "    One may refer to LeetCode Problem 797 for details:\n",
    "        https://leetcode.com/problems/all-paths-from-source-to-target/\n",
    "    '''\n",
    "    def obtain_paths(self, mode, s, t_input, lower_bd, upper_bd, one_hop):\n",
    "\n",
    "        if type(lower_bd) != type(1) or lower_bd < 1:\n",
    "            \n",
    "            raise TypeError(\"!!! invalid lower bound setting, must >= 1 !!!\")\n",
    "            \n",
    "        if type(upper_bd) != type(1) or upper_bd < 1:\n",
    "            \n",
    "            raise TypeError(\"!!! invalid upper bound setting, must >= 1 !!!\")\n",
    "            \n",
    "        if lower_bd > upper_bd:\n",
    "            \n",
    "            raise TypeError(\"!!! lower bound must not exced upper bound !!!\")\n",
    "            \n",
    "        if s not in one_hop:\n",
    "            \n",
    "            raise ValueError('!!! entity not in one_hop. Please work on existing entities')\n",
    "\n",
    "        #here is the result dict. Its key is each entity t sharing paths from s\n",
    "        #The value of each t is a set containing the paths from s to t\n",
    "        #These paths can be either the direct connection r, or a multi-hop path\n",
    "        res = defaultdict(set)\n",
    "        \n",
    "        #qualified_t contains the types of t we want to consider,\n",
    "        #that is, what t will be added to the result set.\n",
    "        qualified_t = set()\n",
    "\n",
    "        #under this mode, we will only consider the direct neighbour of s\n",
    "        if mode == 'direct_neighbour':\n",
    "        \n",
    "            for Tuple in one_hop[s]:\n",
    "            \n",
    "                t = Tuple[1]\n",
    "                \n",
    "                qualified_t.add(t)\n",
    "        \n",
    "        #under this mode, we will only consider one specified entity t\n",
    "        elif mode == 'target_specified':\n",
    "            \n",
    "            qualified_t.add(t_input)\n",
    "        \n",
    "        #under this mode, we will consider any entity\n",
    "        elif mode == 'any_target':\n",
    "            \n",
    "            for s_any in one_hop:\n",
    "                \n",
    "                qualified_t.add(s_any)\n",
    "                \n",
    "        else:\n",
    "            \n",
    "            raise ValueError('not a valid mode')\n",
    "        \n",
    "        '''\n",
    "        We use recursion to find the paths\n",
    "        On current node with the path [r1, ..., rk] and on-path entities {s, e1, ..., ek-1, node}\n",
    "        from s to this node, we will further find the direct neighbor t' of this node. \n",
    "        If t' is not an on-path entity (not among s, e1,...ek-1, node), we recursively proceed to t' \n",
    "        '''\n",
    "        def helper(node, path, on_path_en, res, qualified_t, lower_bd, upper_bd, one_hop, count_dict):\n",
    "\n",
    "            #when the current path is within lower_bd and upper_bd, \n",
    "            #and the node is among the qualified t, and it has not been fill of paths w.r.t size_limit,\n",
    "            #we will add this path to the node\n",
    "            if (len(path) >= lower_bd) and (len(path) <= upper_bd) and (\n",
    "                node in qualified_t) and (len(res[node]) < self.size_bd):\n",
    "                \n",
    "                res[node].add(tuple(path))\n",
    "                    \n",
    "            #won't start new recursions if the current path length already reaches upper limit\n",
    "            #or the number of recursions performed on this length has reached the limit\n",
    "            if (len(path) < upper_bd) and (count_dict[len(path)] <= self.threshold):\n",
    "                                \n",
    "                #temp list is the id list for us to go-over one_hop[node]\n",
    "                temp_list = [i for i in range(len(one_hop[node]))]\n",
    "                random.shuffle(temp_list) #so we random-shuffle the list\n",
    "                \n",
    "                #only take 20 recursions if there are too many (r,t)\n",
    "                for i in temp_list[:self.amount_bd]:\n",
    "                    \n",
    "                    #obtain tuple of (r,t)\n",
    "                    Tuple = one_hop[node][i]\n",
    "                    r, t = Tuple[0], Tuple[1]\n",
    "                    \n",
    "                    #add to count_dict even if eventually this step not proceed\n",
    "                    count_dict[len(path)] += 1\n",
    "                    \n",
    "                    #if t not on the path and we not exceed the computation threshold, \n",
    "                    #then finally proceed to next recursion\n",
    "                    if (t not in on_path_en) and (count_dict[len(path)] <= self.threshold):\n",
    "\n",
    "                        helper(t, path + [r], on_path_en.union({t}), res, qualified_t, \n",
    "                               lower_bd, upper_bd, one_hop, count_dict)\n",
    "\n",
    "        length_dict = defaultdict(int)\n",
    "        count_dict = defaultdict(int)\n",
    "        \n",
    "        helper(s, [], {s}, res, qualified_t, lower_bd, upper_bd, one_hop, count_dict)\n",
    "        \n",
    "        return(res, count_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ecaf24ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_path = '../data/' + data_name + '/train.txt'\n",
    "valid_path = '../data/' + data_name + '/valid.txt'\n",
    "test_path = '../data/' + data_name + '/test.txt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5718867e",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the classes\n",
    "Class_1 = LoadKG()\n",
    "Class_2 = ObtainPathsByDynamicProgramming()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "57c472f3",
   "metadata": {},
   "outputs": [],
   "source": [
    "#define the dictionaries and sets for load KG\n",
    "one_hop = dict() \n",
    "data = set()\n",
    "s_t_r = defaultdict(set)\n",
    "\n",
    "#define the dictionaries, which is shared by initail and inductive train/valid/test\n",
    "entity2id = dict()\n",
    "id2entity = dict()\n",
    "relation2id = dict()\n",
    "id2relation = dict()\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(train_path, one_hop, data, s_t_r,\n",
    "                        entity2id, id2entity, relation2id, id2relation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "54c4c0ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "#define the dictionaries and sets for load KG\n",
    "one_hop_valid = dict() \n",
    "data_valid = set()\n",
    "s_t_r_valid = defaultdict(set)\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(valid_path, one_hop_valid, data_valid, s_t_r_valid,\n",
    "                        entity2id, id2entity, relation2id, id2relation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "178bd0ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "#define the dictionaries and sets for load KG\n",
    "one_hop_test = dict() \n",
    "data_test = set()\n",
    "s_t_r_test = defaultdict(set)\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(test_path, one_hop_test, data_test, s_t_r_test,\n",
    "                        entity2id, id2entity, relation2id, id2relation)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2ee8babf",
   "metadata": {},
   "source": [
    "#### Build the path-based siamese neural network structure\n",
    "\n",
    "We use biLSTM to train on the input path embedding sequence to predict the output embedding or the relation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "68239c61",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-15 13:37:22.889519: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "# Input layer, using integer to represent each relation type\n",
    "#note that inputs_path is the path inputs, while inputs_out_re is the output relation inputs\n",
    "fst_path = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "scd_path = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "thd_path = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "\n",
    "#the relation input layer (for output embedding)\n",
    "id_rela = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "\n",
    "# Embed each integer in a 300-dimensional vector as input,\n",
    "# note that we add another \"space holder\" embedding, \n",
    "# which hold the spaces if the initial length of paths are not the same\n",
    "in_embd_var = layers.Embedding(len(relation2id)+1, 300)\n",
    "\n",
    "# Obtain the embedding\n",
    "fst_p_embd = in_embd_var(fst_path)\n",
    "scd_p_embd = in_embd_var(scd_path)\n",
    "thd_p_embd = in_embd_var(thd_path)\n",
    "\n",
    "# Embed each integer in a 300-dimensional vector as output\n",
    "rela_embd = layers.Embedding(len(relation2id)+1, 300)(id_rela)\n",
    "\n",
    "#add 2 layer bi-directional LSTM\n",
    "lstm_layer_1 = layers.Bidirectional(layers.LSTM(150, return_sequences=True))\n",
    "lstm_layer_2 = layers.Bidirectional(layers.LSTM(150, return_sequences=True))\n",
    "\n",
    "#first LSTM layer\n",
    "fst_lstm_mid = lstm_layer_1(fst_p_embd)\n",
    "scd_lstm_mid = lstm_layer_1(scd_p_embd)\n",
    "thd_lstm_mid = lstm_layer_1(thd_p_embd)\n",
    "\n",
    "#second LSTM layer\n",
    "fst_lstm_out = lstm_layer_2(fst_lstm_mid)\n",
    "scd_lstm_out = lstm_layer_2(scd_lstm_mid)\n",
    "thd_lstm_out = lstm_layer_2(thd_lstm_mid)\n",
    "\n",
    "#reduce max\n",
    "fst_reduce_max = tf.reduce_max(fst_lstm_out, axis=1)\n",
    "scd_reduce_max = tf.reduce_max(scd_lstm_out, axis=1)\n",
    "thd_reduce_max = tf.reduce_max(thd_lstm_out, axis=1)\n",
    "\n",
    "#concatenate the output vector from both siamese tunnel: (Batch, 900)\n",
    "path_concat = layers.concatenate([fst_reduce_max, scd_reduce_max, thd_reduce_max], axis=-1)\n",
    "\n",
    "#add dropout on top of the concatenation from all channels\n",
    "dropout = layers.Dropout(0.25)(path_concat)\n",
    "\n",
    "#multiply into output embd size by dense layer: (Batch, 300)\n",
    "path_out_vect = layers.Dense(300, activation='tanh')(dropout)\n",
    "\n",
    "#remove the time dimension from the output embd since there is only one step\n",
    "rela_out_embd = tf.reduce_sum(rela_embd, axis=1)\n",
    "\n",
    "# Normalize the vectors to have unit length\n",
    "path_out_vect_norm = tf.math.l2_normalize(path_out_vect, axis=-1)\n",
    "rela_out_embd_norm = tf.math.l2_normalize(rela_out_embd, axis=-1)\n",
    "\n",
    "# Calculate the dot product\n",
    "dot_product = layers.Dot(axes=-1)([path_out_vect_norm, rela_out_embd_norm])\n",
    "\n",
    "#put together the model\n",
    "model = keras.Model([fst_path, scd_path, thd_path, id_rela], dot_product)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d5cd4009",
   "metadata": {},
   "outputs": [],
   "source": [
    "#config the Adam optimizer \n",
    "opt = keras.optimizers.Adam(learning_rate=0.0005, decay=1e-6)\n",
    "\n",
    "#compile the model\n",
    "model.compile(loss='binary_crossentropy', optimizer=opt, metrics=['binary_accuracy'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f40033a4",
   "metadata": {},
   "source": [
    "#### Build the subgraph-based siamese neural network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "c407303b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#each input is an vector with number of relations to be dim:\n",
    "#each dim represent the existence (1) or not (0) of an out-going relation from the entity\n",
    "source_path_1 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "source_path_2 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "source_path_3 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "\n",
    "target_path_1 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "target_path_2 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "target_path_3 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "\n",
    "#the relation input layer (for output embedding)\n",
    "id_rela_ = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "\n",
    "# Embed each integer in a 300-dimensional vector as input,\n",
    "# note that we add another \"space holder\" embedding, \n",
    "# which hold the spaces if the initial length of paths are not the same\n",
    "in_embd_var_ = layers.Embedding(len(relation2id)+1, 300)\n",
    "\n",
    "# Obtain the source embeddings\n",
    "source_embd_1 = in_embd_var_(source_path_1)\n",
    "source_embd_2 = in_embd_var_(source_path_2)\n",
    "source_embd_3 = in_embd_var_(source_path_3)\n",
    "\n",
    "#Obtain the target embeddings\n",
    "target_embd_1 = in_embd_var_(target_path_1)\n",
    "target_embd_2 = in_embd_var_(target_path_2)\n",
    "target_embd_3 = in_embd_var_(target_path_3)\n",
    "\n",
    "# Embed each integer in a 300-dimensional vector as output\n",
    "rela_embd_ = layers.Embedding(len(relation2id)+1, 300)(id_rela_)\n",
    "\n",
    "#add 2 layer bi-directional LSTM network\n",
    "lstm_1 = layers.Bidirectional(layers.LSTM(150, return_sequences=True))\n",
    "lstm_2 = layers.Bidirectional(layers.LSTM(150, return_sequences=True))\n",
    "\n",
    "###source lstm implimentation########\n",
    "#first LSTM layer\n",
    "source_mid_1 = lstm_1(source_embd_1)\n",
    "source_mid_2 = lstm_1(source_embd_2)\n",
    "source_mid_3 = lstm_1(source_embd_3)\n",
    "\n",
    "#second LSTM layer\n",
    "source_out_1 = lstm_2(source_mid_1)\n",
    "source_out_2 = lstm_2(source_mid_2)\n",
    "source_out_3 = lstm_2(source_mid_3)\n",
    "\n",
    "#reduce max\n",
    "source_max_1 = tf.reduce_max(source_out_1, axis=1)\n",
    "source_max_2 = tf.reduce_max(source_out_2, axis=1)\n",
    "source_max_3 = tf.reduce_max(source_out_3, axis=1)\n",
    "\n",
    "#concatenate the output vector from both siamese tunnel: (Batch, 900)\n",
    "source_concat = layers.concatenate([source_max_1, source_max_2, source_max_3], axis=-1)\n",
    "\n",
    "#add dropout on top of the concatenation from all channels\n",
    "source_dropout = layers.Dropout(0.25)(source_concat)\n",
    "\n",
    "###target lstm implimentation########\n",
    "#first LSTM layer\n",
    "target_mid_1 = lstm_1(target_embd_1)\n",
    "target_mid_2 = lstm_1(target_embd_2)\n",
    "target_mid_3 = lstm_1(target_embd_3)\n",
    "\n",
    "#second LSTM layer\n",
    "target_out_1 = lstm_2(target_mid_1)\n",
    "target_out_2 = lstm_2(target_mid_2)\n",
    "target_out_3 = lstm_2(target_mid_3)\n",
    "\n",
    "#reduce max\n",
    "target_max_1 = tf.reduce_max(target_out_1, axis=1)\n",
    "target_max_2 = tf.reduce_max(target_out_2, axis=1)\n",
    "target_max_3 = tf.reduce_max(target_out_3, axis=1)\n",
    "\n",
    "#concatenate the output vector from both siamese tunnel: (Batch, 900)\n",
    "target_concat = layers.concatenate([target_max_1, target_max_2, target_max_3], axis=-1)\n",
    "\n",
    "#add dropout on top of the concatenation from all channels\n",
    "target_dropout = layers.Dropout(0.25)(target_concat)\n",
    "\n",
    "#further concatenate source and target output embeddings: (Batch, 1800)\n",
    "final_concat = layers.concatenate([source_dropout, target_dropout], axis=-1)\n",
    "\n",
    "#multiply into output embd size by dense layer: (Batch, 300)\n",
    "out_vect = layers.Dense(300, activation='tanh')(final_concat)\n",
    "\n",
    "#remove the time dimension from the output embd since there is only one step\n",
    "rela_out_embd_ = tf.reduce_sum(rela_embd_, axis=1)\n",
    "\n",
    "# Normalize the vectors to have unit length\n",
    "out_vect_norm = tf.math.l2_normalize(out_vect, axis=-1)\n",
    "rela_out_embd_norm_ = tf.math.l2_normalize(rela_out_embd_, axis=-1)\n",
    "\n",
    "# Calculate the dot product\n",
    "dot_product_ = layers.Dot(axes=-1)([out_vect_norm, rela_out_embd_norm_])\n",
    "\n",
    "#put together the model\n",
    "model_2 = keras.Model([source_path_1, source_path_2, source_path_3,\n",
    "                       target_path_1, target_path_2, target_path_3, id_rela_], dot_product_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "01a1f5b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "#config the Adam optimizer \n",
    "opt_ = keras.optimizers.Adam(learning_rate=0.0005, decay=1e-6)\n",
    "\n",
    "#compile the model\n",
    "model_2.compile(loss='binary_crossentropy', optimizer=opt_, metrics=['binary_accuracy'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "79fd204f",
   "metadata": {},
   "source": [
    "### Build the big-batch for path-based model\n",
    "We will build the big-batch for the path-based model training. That is, we will build three list to store three paths, respectively.\n",
    "\n",
    "In order to reduce computational complexity, we will run the path-finding algorithm for each entity e in the dataset before the training. That is, for each entity e, we will have two dictionaries. Dict 1 stores the paths between e and any other entities in the dataset. Will Dict 2 stores the paths between e and its direct neighbors. The two dicts will be used and invariant throughout the training.\n",
    "\n",
    "* At each step, three different paths between two entities s and t are selected. Each path is append to one of the list. \n",
    "* If this step is for positive samples, the existing relation r will be selected between s and t. If there are more than one relation from s to t, we randomly choose one. Also, the label list will be appended 1.\n",
    "* If this step is for negative samples, one relation that does not exist between s and t will be selected randomly and append to the relation list. Also, the label list will be appended 0.\n",
    "* In practice, the positive step is always fallowed by a negative step. The same paths in the positive step will be used in the next negative step, while the relation is a negative one chosen in the above way.\n",
    "* We do this until the length limit is reached.\n",
    "\n",
    "**For relation prediciton, we will only need to train using (s,r,t) triple. (t,r-1,s) is not necessary and hence not included in training.**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0bb3ab40",
   "metadata": {},
   "outputs": [],
   "source": [
    "#function to build the big batche for path-based training\n",
    "def build_big_batches_path(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                      x_p_list, x_r_list, y_list,\n",
    "                      relation2id, entity2id, id2relation, id2entity):\n",
    "    \n",
    "    #the set of all relation IDs\n",
    "    relation_id_set = set()\n",
    "    \n",
    "    #the set of all initial relations\n",
    "    ini_r_id_set = set()\n",
    "    \n",
    "    for i in range(len(id2relation)):\n",
    "        \n",
    "        if i not in id2relation:\n",
    "            raise ValueError('error when generaing id2relation')\n",
    "        \n",
    "        relation_id_set.add(i)\n",
    "        \n",
    "        if i % 2 == 0: #initial relation id is always an even number\n",
    "            ini_r_id_set.add(i)\n",
    "    \n",
    "    num_r = len(id2relation)\n",
    "    num_ini_r = len(ini_r_id_set)\n",
    "    \n",
    "    if num_ini_r != int(num_r/2):\n",
    "        raise ValueError('error when generating id2relation')\n",
    "    \n",
    "    #in case not all entities in entity2id are in one_hop, \n",
    "    #so we need to find out who are indeed in\n",
    "    existing_ids = set()\n",
    "    \n",
    "    for s_1 in one_hop:\n",
    "        existing_ids.add(s_1)\n",
    "        \n",
    "    existing_ids = list(existing_ids)\n",
    "    random.shuffle(existing_ids)\n",
    "    \n",
    "    count = 0\n",
    "    for s in existing_ids:\n",
    "        \n",
    "        #impliment the path finding algorithm to find paths between s and t\n",
    "        result, length_dict = Class_2.obtain_paths('direct_neighbour', s, 'nb', lower_bd, upper_bd, one_hop)\n",
    "        \n",
    "        for iteration in range(10):\n",
    "\n",
    "            #proceed only if at least three paths are between s and t\n",
    "            for t in result:\n",
    "\n",
    "                if len(s_t_r[(s,t)]) == 0:\n",
    "\n",
    "                    raise ValueError(s,t,id2entity[s], id2entity[t])\n",
    "\n",
    "                #we are only interested in forward link in relation prediciton\n",
    "                ini_r_list = list()\n",
    "\n",
    "                #obtain initial relations between s and t\n",
    "                for r in s_t_r[(s,t)]:\n",
    "                    if r % 2 == 0:#initial relation id is always an even number\n",
    "                        ini_r_list.append(r)\n",
    "\n",
    "                #if there exist more than three paths between s and t, \n",
    "                #and inital connection between s and t exists,\n",
    "                #and not every r in the relation dictionary exists between s and t (although this is rare)\n",
    "                #we then proceed\n",
    "                if len(result[t]) >= 3 and len(ini_r_list) > 0 and len(ini_r_list) < int(num_ini_r):\n",
    "\n",
    "                    #obtain the list form of all the paths from s to t\n",
    "                    temp_path_list = list(result[t])\n",
    "\n",
    "                    temp_pair = random.sample(temp_path_list, 3)\n",
    "\n",
    "                    path_1, path_2, path_3 = temp_pair[0], temp_pair[1], temp_pair[2]\n",
    "\n",
    "                    #####positive#####################\n",
    "                    #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                    x_p_list['1'].append(list(path_1) + [num_r]*abs(len(path_1)-upper_bd))\n",
    "                    x_p_list['2'].append(list(path_2) + [num_r]*abs(len(path_2)-upper_bd))\n",
    "                    x_p_list['3'].append(list(path_3) + [num_r]*abs(len(path_3)-upper_bd))\n",
    "\n",
    "                    #append relation\n",
    "                    r = random.choice(ini_r_list)\n",
    "                    x_r_list.append([r])\n",
    "                    y_list.append(1.)\n",
    "\n",
    "                    #####negative#####################\n",
    "                    #append the paths: note that we add the space holder id at the end\n",
    "                    #of the shorter path\n",
    "                    x_p_list['1'].append(list(path_1) + [num_r]*abs(len(path_1)-upper_bd))\n",
    "                    x_p_list['2'].append(list(path_2) + [num_r]*abs(len(path_2)-upper_bd))\n",
    "                    x_p_list['3'].append(list(path_3) + [num_r]*abs(len(path_3)-upper_bd))\n",
    "\n",
    "                    #append relation\n",
    "                    neg_r_list = list(ini_r_id_set.difference(set(ini_r_list)))\n",
    "                    r_ran = random.choice(neg_r_list)\n",
    "                    x_r_list.append([r_ran])\n",
    "                    y_list.append(0.)\n",
    "        \n",
    "        count += 1\n",
    "        if count % 100 == 0:\n",
    "            print('generating big-batches for path-based model', count, len(existing_ids))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f215dcc4",
   "metadata": {},
   "source": [
    "### Build the big-batch for the subgraph-based network training\n",
    "\n",
    "Again, to reduce computational complexity, we store the subgraph of each entity e at the biginning.\n",
    "\n",
    "* At each step, we will select one triple (s,r,t) from the dataset. Then, reaching out paths of s and t is generated respectively according to their out-going relations.\n",
    "* We will select three paths for each of source and target entity. Add them to the corresponding list.\n",
    "* If this is a positive sample step, the id of relation r is appended to the relation list.\n",
    "* If this is a negative sample step, the id of a random relation is appended to the relation lsit.\n",
    "* Similarly, one negative sample step always follows one positive step. The one-hop vectors from the previous positve step is used again for the negative step."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a6c3264b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Again, it is too slow to run the path-finding algorithm again and again on the complete FB15K-237\n",
    "#Instead, we will find the subgraph for each entity once.\n",
    "#then in the subgraph based training, the subgraphs are stored and used for multiple times\n",
    "def store_subgraph_dicts(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                         relation2id, entity2id, id2relation, id2entity):\n",
    "    \n",
    "    #the set of all relation IDs\n",
    "    relation_id_set = set()\n",
    "    \n",
    "    for i in range(len(id2relation)):\n",
    "        \n",
    "        if i not in id2relation:\n",
    "            raise ValueError('error when generaing id2relation')\n",
    "        \n",
    "        relation_id_set.add(i)\n",
    "    \n",
    "    num_r = len(id2relation)\n",
    "    \n",
    "    #in case not all entities in entity2id are in one_hop, \n",
    "    #so we need to find out who are indeed in\n",
    "    existing_ids = set()\n",
    "    \n",
    "    for s_1 in one_hop:\n",
    "        existing_ids.add(s_1)\n",
    "    \n",
    "    #the ids to start path finding\n",
    "    existing_ids = list(existing_ids)\n",
    "    random.shuffle(existing_ids)\n",
    "    \n",
    "    #Dict stores the subgraph for each entity\n",
    "    Dict_1 = dict()\n",
    "    \n",
    "    count = 0\n",
    "    for s in existing_ids:\n",
    "        \n",
    "        path_set = set()\n",
    "            \n",
    "        result, length_dict = Class_2.obtain_paths('any_target', s, 'any', lower_bd, upper_bd, one_hop)\n",
    "\n",
    "        for t_ in result:\n",
    "            for path in result[t_]:\n",
    "                path_set.add(path)\n",
    "\n",
    "        del(result, length_dict)\n",
    "        \n",
    "        path_list = list(path_set)\n",
    "        \n",
    "        path_select = random.sample(path_list, min(len(path_list), 100))\n",
    "            \n",
    "        Dict_1[s] = deepcopy(path_select)\n",
    "        \n",
    "        count += 1\n",
    "        if count % 100 == 0:\n",
    "            print('generating and storing paths for the path-based model', count, len(existing_ids))\n",
    "        \n",
    "    return(Dict_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "1551116a",
   "metadata": {},
   "outputs": [],
   "source": [
    "#function to build the big-batch for one-hope neighbor training\n",
    "def build_big_batches_subgraph(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                      x_s_list, x_t_list, x_r_list, y_list, Dict,\n",
    "                      relation2id, entity2id, id2relation, id2entity):\n",
    "    \n",
    "    #the set of all relation IDs\n",
    "    relation_id_set = set()\n",
    "    \n",
    "    #the set of all initial relations\n",
    "    ini_r_id_set = set()\n",
    "    \n",
    "    for i in range(len(id2relation)):\n",
    "        \n",
    "        if i not in id2relation:\n",
    "            raise ValueError('error when generaing id2relation')\n",
    "        \n",
    "        relation_id_set.add(i)\n",
    "        \n",
    "        if i % 2 == 0: #initial relation id is always an even number\n",
    "            ini_r_id_set.add(i)\n",
    "    \n",
    "    num_r = len(id2relation)\n",
    "    num_ini_r = len(ini_r_id_set)\n",
    "    \n",
    "    if num_ini_r != int(num_r/2):\n",
    "        raise ValueError('error when generating id2relation')\n",
    "        \n",
    "    #if an entity has at least three out-stretching paths, it is a qualified one\n",
    "    qualified = set()\n",
    "    for e in Dict:\n",
    "        if len(Dict[e]) >= 3:\n",
    "            qualified.add(e)\n",
    "    qualified = list(qualified)\n",
    "    \n",
    "    data = list(data)\n",
    "    \n",
    "    for iteration in range(10):\n",
    "\n",
    "        data = shuffle(data)\n",
    "\n",
    "        for i_0 in range(len(data)):\n",
    "\n",
    "            triple = data[i_0]\n",
    "\n",
    "            s, r, t = triple[0], triple[1], triple[2] #obtain entities and relation IDs\n",
    "\n",
    "            if s in qualified and t in qualified:\n",
    "\n",
    "                #obtain the path list for true entities\n",
    "                path_s, path_t = list(Dict[s]), list(Dict[t])\n",
    "\n",
    "                #####positive step###########\n",
    "                #randomly obtain three paths for true entities\n",
    "                temp_s = random.sample(path_s, 3)\n",
    "                temp_t = random.sample(path_t, 3)\n",
    "                s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "                t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(1.)\n",
    "\n",
    "                #####negative step for relation###########\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                neg_r_list = list(ini_r_id_set.difference({r}))\n",
    "                r_ran = random.choice(neg_r_list)\n",
    "                x_r_list.append([r_ran])\n",
    "                y_list.append(0.)\n",
    "                \n",
    "                ##############################################\n",
    "                ##############################################\n",
    "                #randomly choose two negative sampled entities\n",
    "                s_ran = random.choice(qualified)\n",
    "                t_ran = random.choice(qualified)\n",
    "\n",
    "                #obtain the path list for random entities\n",
    "                path_s_ran, path_t_ran = list(Dict[s_ran]), list(Dict[t_ran])\n",
    "                \n",
    "                #####positive step#################\n",
    "                #Again: randomly obtain three paths\n",
    "                temp_s = random.sample(path_s, 3)\n",
    "                temp_t = random.sample(path_t, 3)\n",
    "                s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "                t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(1.)\n",
    "\n",
    "                #####negative for source entity###########\n",
    "                #randomly obtain three paths\n",
    "                temp_s = random.sample(path_s_ran, 3)\n",
    "                s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(0.)\n",
    "\n",
    "                #####positive step###########\n",
    "                #Again: randomly obtain three paths\n",
    "                temp_s = random.sample(path_s, 3)\n",
    "                temp_t = random.sample(path_t, 3)\n",
    "                s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "                t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(1.)\n",
    "\n",
    "                #####negative for target entity###########\n",
    "                #randomly obtain three paths\n",
    "                temp_t = random.sample(path_t_ran, 3)\n",
    "                t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "\n",
    "                #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                x_s_list['1'].append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                x_s_list['2'].append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                x_s_list['3'].append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "                x_t_list['1'].append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                x_t_list['2'].append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                x_t_list['3'].append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(0.)\n",
    "\n",
    "            if i_0 % 200 == 0:\n",
    "                print('generating big-batches for subgraph-based model', i_0, len(data), iteration)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "851e0ac2",
   "metadata": {},
   "source": [
    "### Start Training: load the KG and call classes\n",
    "\n",
    "Here, we use the validation set to see the training efficiency. That is, we use the validation to check whether the true relation between entities can be predicted by paths.\n",
    "\n",
    "The trick is: in validation, we have to use the same relation ID and entity ID as in the training. But we don't want to use the links in training anymore. That is, in validation, we want to use (and update if necessary) entity2id, id2entity, relation2id and id2relation. But we want to use new one_hop, data, data_ and s_t_r for validation set. Then, path-finding will also be based on new one_hop.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "28be7a72",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Model_SiaLP_3_new_WN18RR_v4'"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "8103ea50",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'One_hop_model_SiaLP_3_new_WN18RR_v4'"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "one_hop_model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "17c02a41",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'IDs_SiaLP_3_new_WN18RR_v4'"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ids_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c7f57c2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "#first, we save the relation and ids\n",
    "Dict = dict()\n",
    "\n",
    "#save training data\n",
    "Dict['one_hop'] = one_hop\n",
    "Dict['data'] = data\n",
    "Dict['s_t_r'] = s_t_r\n",
    "\n",
    "#save valid data\n",
    "Dict['one_hop_valid'] = one_hop_valid\n",
    "Dict['data_valid'] = data_valid\n",
    "Dict['s_t_r_valid'] = s_t_r_valid\n",
    "\n",
    "#save test data\n",
    "Dict['one_hop_test'] = one_hop_test\n",
    "Dict['data_test'] = data_test\n",
    "Dict['s_t_r_test'] = s_t_r_test\n",
    "\n",
    "#save shared dictionaries\n",
    "Dict['entity2id'] = entity2id\n",
    "Dict['id2entity'] = id2entity\n",
    "Dict['relation2id'] = relation2id\n",
    "Dict['id2relation'] = id2relation\n",
    "\n",
    "with open('../weight_bin/' + ids_name + '.pickle', 'wb') as handle:\n",
    "    pickle.dump(Dict, handle, protocol=pickle.HIGHEST_PROTOCOL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "25a5deac",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generating big-batches for path-based model 100 3861\n",
      "generating big-batches for path-based model 200 3861\n",
      "generating big-batches for path-based model 300 3861\n",
      "generating big-batches for path-based model 400 3861\n",
      "generating big-batches for path-based model 500 3861\n",
      "generating big-batches for path-based model 600 3861\n",
      "generating big-batches for path-based model 700 3861\n",
      "generating big-batches for path-based model 800 3861\n",
      "generating big-batches for path-based model 900 3861\n",
      "generating big-batches for path-based model 1000 3861\n",
      "generating big-batches for path-based model 1100 3861\n",
      "generating big-batches for path-based model 1200 3861\n",
      "generating big-batches for path-based model 1300 3861\n",
      "generating big-batches for path-based model 1400 3861\n",
      "generating big-batches for path-based model 1500 3861\n",
      "generating big-batches for path-based model 1600 3861\n",
      "generating big-batches for path-based model 1700 3861\n",
      "generating big-batches for path-based model 1800 3861\n",
      "generating big-batches for path-based model 1900 3861\n",
      "generating big-batches for path-based model 2000 3861\n",
      "generating big-batches for path-based model 2100 3861\n",
      "generating big-batches for path-based model 2200 3861\n",
      "generating big-batches for path-based model 2300 3861\n",
      "generating big-batches for path-based model 2400 3861\n",
      "generating big-batches for path-based model 2500 3861\n",
      "generating big-batches for path-based model 2600 3861\n",
      "generating big-batches for path-based model 2700 3861\n",
      "generating big-batches for path-based model 2800 3861\n",
      "generating big-batches for path-based model 2900 3861\n",
      "generating big-batches for path-based model 3000 3861\n",
      "generating big-batches for path-based model 3100 3861\n",
      "generating big-batches for path-based model 3200 3861\n",
      "generating big-batches for path-based model 3300 3861\n",
      "generating big-batches for path-based model 3400 3861\n",
      "generating big-batches for path-based model 3500 3861\n",
      "generating big-batches for path-based model 3600 3861\n",
      "generating big-batches for path-based model 3700 3861\n",
      "generating big-batches for path-based model 3800 3861\n",
      "generating big-batches for path-based model 100 1410\n",
      "generating big-batches for path-based model 200 1410\n",
      "generating big-batches for path-based model 300 1410\n",
      "generating big-batches for path-based model 400 1410\n",
      "generating big-batches for path-based model 500 1410\n",
      "generating big-batches for path-based model 600 1410\n",
      "generating big-batches for path-based model 700 1410\n",
      "generating big-batches for path-based model 800 1410\n",
      "generating big-batches for path-based model 900 1410\n",
      "generating big-batches for path-based model 1000 1410\n",
      "generating big-batches for path-based model 1100 1410\n",
      "generating big-batches for path-based model 1200 1410\n",
      "generating big-batches for path-based model 1300 1410\n",
      "generating big-batches for path-based model 1400 1410\n",
      "Epoch 1/10\n",
      "2851/2851 [==============================] - 247s 84ms/step - loss: 0.6713 - binary_accuracy: 0.8887 - val_loss: 0.5917 - val_binary_accuracy: 0.8939\n",
      "Epoch 2/10\n",
      "2851/2851 [==============================] - 246s 86ms/step - loss: 0.5428 - binary_accuracy: 0.9105 - val_loss: 0.4128 - val_binary_accuracy: 0.8932\n",
      "Epoch 3/10\n",
      "2851/2851 [==============================] - 246s 86ms/step - loss: 0.3190 - binary_accuracy: 0.9175 - val_loss: 0.2317 - val_binary_accuracy: 0.9212\n",
      "Epoch 4/10\n",
      "2851/2851 [==============================] - 249s 87ms/step - loss: 0.2356 - binary_accuracy: 0.9318 - val_loss: 0.2162 - val_binary_accuracy: 0.9282\n",
      "Epoch 5/10\n",
      "2851/2851 [==============================] - 249s 87ms/step - loss: 0.2195 - binary_accuracy: 0.9385 - val_loss: 0.1848 - val_binary_accuracy: 0.9358\n",
      "Epoch 6/10\n",
      "2851/2851 [==============================] - 235s 82ms/step - loss: 0.1932 - binary_accuracy: 0.9462 - val_loss: 0.1605 - val_binary_accuracy: 0.9450\n",
      "Epoch 7/10\n",
      "2851/2851 [==============================] - 226s 79ms/step - loss: 0.1620 - binary_accuracy: 0.9567 - val_loss: 0.1412 - val_binary_accuracy: 0.9500\n",
      "Epoch 8/10\n",
      "2851/2851 [==============================] - 226s 79ms/step - loss: 0.1379 - binary_accuracy: 0.9638 - val_loss: 0.1520 - val_binary_accuracy: 0.9514\n",
      "Epoch 9/10\n",
      "2851/2851 [==============================] - 2169s 761ms/step - loss: 0.1274 - binary_accuracy: 0.9666 - val_loss: 0.1373 - val_binary_accuracy: 0.9540\n",
      "Epoch 10/10\n",
      "2851/2851 [==============================] - 202s 71ms/step - loss: 0.1109 - binary_accuracy: 0.9714 - val_loss: 0.1358 - val_binary_accuracy: 0.9517\n",
      "Save model\n"
     ]
    }
   ],
   "source": [
    "###train the path-based model\n",
    "lower_bd = lower_bound\n",
    "upper_bd = upper_bound_path\n",
    "num_epoch = 10\n",
    "batch_size = 32\n",
    "        \n",
    "#define the training lists\n",
    "train_p_list, train_r_list, train_y_list = {'1': [], '2': [], '3': []}, list(), list()\n",
    "\n",
    "#define the validation lists\n",
    "valid_p_list, valid_r_list, valid_y_list = {'1': [], '2': [], '3': []}, list(), list()\n",
    "\n",
    "#######################################\n",
    "###build the big-batches###############      \n",
    "\n",
    "#fill in the training array list\n",
    "build_big_batches_path(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                      train_p_list, train_r_list, train_y_list,\n",
    "                      relation2id, entity2id, id2relation, id2entity)\n",
    "\n",
    "#fill in the validation array list\n",
    "build_big_batches_path(lower_bd, upper_bd, data_valid, one_hop_valid, s_t_r_valid,\n",
    "                      valid_p_list, valid_r_list, valid_y_list,\n",
    "                      relation2id, entity2id, id2relation, id2entity)    \n",
    "\n",
    "#######################################\n",
    "###do the training#####################\n",
    "#sometimes the validation dataset is so small so sparse, \n",
    "#which cannot find three paths between any pair of s and t.\n",
    "#in such a case, we will divide the training big-batch into train and valid\n",
    "if len(valid_y_list) >= 100:\n",
    "    #generate the input arrays\n",
    "    x_train_1 = np.asarray(train_p_list['1'], dtype='int')\n",
    "    x_train_2 = np.asarray(train_p_list['2'], dtype='int')\n",
    "    x_train_3 = np.asarray(train_p_list['3'], dtype='int')\n",
    "    x_train_r = np.asarray(train_r_list, dtype='int')\n",
    "    y_train = np.asarray(train_y_list, dtype='int')\n",
    "\n",
    "    #generate the validation arrays\n",
    "    x_valid_1 = np.asarray(valid_p_list['1'], dtype='int')\n",
    "    x_valid_2 = np.asarray(valid_p_list['2'], dtype='int')\n",
    "    x_valid_3 = np.asarray(valid_p_list['3'], dtype='int')\n",
    "    x_valid_r = np.asarray(valid_r_list, dtype='int')\n",
    "    y_valid = np.asarray(valid_y_list, dtype='int')\n",
    "\n",
    "else:\n",
    "    split = int(len(train_y_list)*0.8)\n",
    "    #generate the input arrays\n",
    "    x_train_1 = np.asarray(train_p_list['1'][:split], dtype='int')\n",
    "    x_train_2 = np.asarray(train_p_list['2'][:split], dtype='int')\n",
    "    x_train_3 = np.asarray(train_p_list['3'][:split], dtype='int')\n",
    "    x_train_r = np.asarray(train_r_list[:split], dtype='int')\n",
    "    y_train = np.asarray(train_y_list[:split], dtype='int')\n",
    "\n",
    "    #generate the validation arrays\n",
    "    x_valid_1 = np.asarray(train_p_list['1'][split:], dtype='int')\n",
    "    x_valid_2 = np.asarray(train_p_list['2'][split:], dtype='int')\n",
    "    x_valid_3 = np.asarray(train_p_list['3'][split:], dtype='int')\n",
    "    x_valid_r = np.asarray(train_r_list[split:], dtype='int')\n",
    "    y_valid = np.asarray(train_y_list[split:], dtype='int')\n",
    "\n",
    "#do the training\n",
    "model.fit([x_train_1, x_train_2, x_train_3, x_train_r], y_train, \n",
    "          validation_data=([x_valid_1, x_valid_2, x_valid_3, x_valid_r], y_valid),\n",
    "          batch_size=batch_size, epochs=num_epoch)   \n",
    "\n",
    "# Save model and weights\n",
    "add_h5 = model_name + '.h5'\n",
    "save_dir = os.path.join(os.getcwd(), '../weight_bin')\n",
    "\n",
    "if not os.path.isdir(save_dir):\n",
    "    os.makedirs(save_dir)\n",
    "model_path = os.path.join(save_dir, add_h5)\n",
    "model.save(model_path)\n",
    "print('Save model')\n",
    "del(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b89853c4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generating and storing paths for the path-based model 100 3861\n",
      "generating and storing paths for the path-based model 200 3861\n",
      "generating and storing paths for the path-based model 300 3861\n",
      "generating and storing paths for the path-based model 400 3861\n",
      "generating and storing paths for the path-based model 500 3861\n",
      "generating and storing paths for the path-based model 600 3861\n",
      "generating and storing paths for the path-based model 700 3861\n",
      "generating and storing paths for the path-based model 800 3861\n",
      "generating and storing paths for the path-based model 900 3861\n",
      "generating and storing paths for the path-based model 1000 3861\n",
      "generating and storing paths for the path-based model 1100 3861\n",
      "generating and storing paths for the path-based model 1200 3861\n",
      "generating and storing paths for the path-based model 1300 3861\n",
      "generating and storing paths for the path-based model 1400 3861\n",
      "generating and storing paths for the path-based model 1500 3861\n",
      "generating and storing paths for the path-based model 1600 3861\n",
      "generating and storing paths for the path-based model 1700 3861\n",
      "generating and storing paths for the path-based model 1800 3861\n",
      "generating and storing paths for the path-based model 1900 3861\n",
      "generating and storing paths for the path-based model 2000 3861\n",
      "generating and storing paths for the path-based model 2100 3861\n",
      "generating and storing paths for the path-based model 2200 3861\n",
      "generating and storing paths for the path-based model 2300 3861\n",
      "generating and storing paths for the path-based model 2400 3861\n",
      "generating and storing paths for the path-based model 2500 3861\n",
      "generating and storing paths for the path-based model 2600 3861\n",
      "generating and storing paths for the path-based model 2700 3861\n",
      "generating and storing paths for the path-based model 2800 3861\n",
      "generating and storing paths for the path-based model 2900 3861\n",
      "generating and storing paths for the path-based model 3000 3861\n",
      "generating and storing paths for the path-based model 3100 3861\n",
      "generating and storing paths for the path-based model 3200 3861\n",
      "generating and storing paths for the path-based model 3300 3861\n",
      "generating and storing paths for the path-based model 3400 3861\n",
      "generating and storing paths for the path-based model 3500 3861\n",
      "generating and storing paths for the path-based model 3600 3861\n",
      "generating and storing paths for the path-based model 3700 3861\n",
      "generating and storing paths for the path-based model 3800 3861\n",
      "generating and storing paths for the path-based model 100 1410\n",
      "generating and storing paths for the path-based model 200 1410\n",
      "generating and storing paths for the path-based model 300 1410\n",
      "generating and storing paths for the path-based model 400 1410\n",
      "generating and storing paths for the path-based model 500 1410\n",
      "generating and storing paths for the path-based model 600 1410\n",
      "generating and storing paths for the path-based model 700 1410\n",
      "generating and storing paths for the path-based model 800 1410\n",
      "generating and storing paths for the path-based model 900 1410\n",
      "generating and storing paths for the path-based model 1000 1410\n",
      "generating and storing paths for the path-based model 1100 1410\n",
      "generating and storing paths for the path-based model 1200 1410\n",
      "generating and storing paths for the path-based model 1300 1410\n",
      "generating and storing paths for the path-based model 1400 1410\n",
      "generating big-batches for subgraph-based model 0 7940 0\n",
      "generating big-batches for subgraph-based model 200 7940 0\n",
      "generating big-batches for subgraph-based model 400 7940 0\n",
      "generating big-batches for subgraph-based model 600 7940 0\n",
      "generating big-batches for subgraph-based model 800 7940 0\n",
      "generating big-batches for subgraph-based model 1000 7940 0\n",
      "generating big-batches for subgraph-based model 1200 7940 0\n",
      "generating big-batches for subgraph-based model 1400 7940 0\n",
      "generating big-batches for subgraph-based model 1600 7940 0\n",
      "generating big-batches for subgraph-based model 1800 7940 0\n",
      "generating big-batches for subgraph-based model 2000 7940 0\n",
      "generating big-batches for subgraph-based model 2200 7940 0\n",
      "generating big-batches for subgraph-based model 2400 7940 0\n",
      "generating big-batches for subgraph-based model 2600 7940 0\n",
      "generating big-batches for subgraph-based model 2800 7940 0\n",
      "generating big-batches for subgraph-based model 3000 7940 0\n",
      "generating big-batches for subgraph-based model 3200 7940 0\n",
      "generating big-batches for subgraph-based model 3400 7940 0\n",
      "generating big-batches for subgraph-based model 3600 7940 0\n",
      "generating big-batches for subgraph-based model 3800 7940 0\n",
      "generating big-batches for subgraph-based model 4000 7940 0\n",
      "generating big-batches for subgraph-based model 4200 7940 0\n",
      "generating big-batches for subgraph-based model 4400 7940 0\n",
      "generating big-batches for subgraph-based model 4600 7940 0\n",
      "generating big-batches for subgraph-based model 4800 7940 0\n",
      "generating big-batches for subgraph-based model 5000 7940 0\n",
      "generating big-batches for subgraph-based model 5200 7940 0\n",
      "generating big-batches for subgraph-based model 5400 7940 0\n",
      "generating big-batches for subgraph-based model 5600 7940 0\n",
      "generating big-batches for subgraph-based model 5800 7940 0\n",
      "generating big-batches for subgraph-based model 6000 7940 0\n",
      "generating big-batches for subgraph-based model 6200 7940 0\n",
      "generating big-batches for subgraph-based model 6400 7940 0\n",
      "generating big-batches for subgraph-based model 6600 7940 0\n",
      "generating big-batches for subgraph-based model 6800 7940 0\n",
      "generating big-batches for subgraph-based model 7000 7940 0\n",
      "generating big-batches for subgraph-based model 7200 7940 0\n",
      "generating big-batches for subgraph-based model 7400 7940 0\n",
      "generating big-batches for subgraph-based model 7600 7940 0\n",
      "generating big-batches for subgraph-based model 7800 7940 0\n",
      "generating big-batches for subgraph-based model 0 7940 1\n",
      "generating big-batches for subgraph-based model 200 7940 1\n",
      "generating big-batches for subgraph-based model 400 7940 1\n",
      "generating big-batches for subgraph-based model 600 7940 1\n",
      "generating big-batches for subgraph-based model 800 7940 1\n",
      "generating big-batches for subgraph-based model 1000 7940 1\n",
      "generating big-batches for subgraph-based model 1200 7940 1\n",
      "generating big-batches for subgraph-based model 1400 7940 1\n",
      "generating big-batches for subgraph-based model 1600 7940 1\n",
      "generating big-batches for subgraph-based model 1800 7940 1\n",
      "generating big-batches for subgraph-based model 2000 7940 1\n",
      "generating big-batches for subgraph-based model 2200 7940 1\n",
      "generating big-batches for subgraph-based model 2400 7940 1\n",
      "generating big-batches for subgraph-based model 2600 7940 1\n",
      "generating big-batches for subgraph-based model 2800 7940 1\n",
      "generating big-batches for subgraph-based model 3000 7940 1\n",
      "generating big-batches for subgraph-based model 3200 7940 1\n",
      "generating big-batches for subgraph-based model 3400 7940 1\n",
      "generating big-batches for subgraph-based model 3600 7940 1\n",
      "generating big-batches for subgraph-based model 3800 7940 1\n",
      "generating big-batches for subgraph-based model 4000 7940 1\n",
      "generating big-batches for subgraph-based model 4200 7940 1\n",
      "generating big-batches for subgraph-based model 4400 7940 1\n",
      "generating big-batches for subgraph-based model 4600 7940 1\n",
      "generating big-batches for subgraph-based model 4800 7940 1\n",
      "generating big-batches for subgraph-based model 5000 7940 1\n",
      "generating big-batches for subgraph-based model 5200 7940 1\n",
      "generating big-batches for subgraph-based model 5400 7940 1\n",
      "generating big-batches for subgraph-based model 5600 7940 1\n",
      "generating big-batches for subgraph-based model 5800 7940 1\n",
      "generating big-batches for subgraph-based model 6000 7940 1\n",
      "generating big-batches for subgraph-based model 6200 7940 1\n",
      "generating big-batches for subgraph-based model 6400 7940 1\n",
      "generating big-batches for subgraph-based model 6600 7940 1\n",
      "generating big-batches for subgraph-based model 6800 7940 1\n",
      "generating big-batches for subgraph-based model 7000 7940 1\n",
      "generating big-batches for subgraph-based model 7200 7940 1\n",
      "generating big-batches for subgraph-based model 7400 7940 1\n",
      "generating big-batches for subgraph-based model 7600 7940 1\n",
      "generating big-batches for subgraph-based model 7800 7940 1\n",
      "generating big-batches for subgraph-based model 0 7940 2\n",
      "generating big-batches for subgraph-based model 200 7940 2\n",
      "generating big-batches for subgraph-based model 400 7940 2\n",
      "generating big-batches for subgraph-based model 600 7940 2\n",
      "generating big-batches for subgraph-based model 800 7940 2\n",
      "generating big-batches for subgraph-based model 1000 7940 2\n",
      "generating big-batches for subgraph-based model 1200 7940 2\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generating big-batches for subgraph-based model 1400 7940 2\n",
      "generating big-batches for subgraph-based model 1600 7940 2\n",
      "generating big-batches for subgraph-based model 1800 7940 2\n",
      "generating big-batches for subgraph-based model 2000 7940 2\n",
      "generating big-batches for subgraph-based model 2200 7940 2\n",
      "generating big-batches for subgraph-based model 2400 7940 2\n",
      "generating big-batches for subgraph-based model 2600 7940 2\n",
      "generating big-batches for subgraph-based model 2800 7940 2\n",
      "generating big-batches for subgraph-based model 3000 7940 2\n",
      "generating big-batches for subgraph-based model 3200 7940 2\n",
      "generating big-batches for subgraph-based model 3400 7940 2\n",
      "generating big-batches for subgraph-based model 3600 7940 2\n",
      "generating big-batches for subgraph-based model 3800 7940 2\n",
      "generating big-batches for subgraph-based model 4000 7940 2\n",
      "generating big-batches for subgraph-based model 4200 7940 2\n",
      "generating big-batches for subgraph-based model 4400 7940 2\n",
      "generating big-batches for subgraph-based model 4600 7940 2\n",
      "generating big-batches for subgraph-based model 4800 7940 2\n",
      "generating big-batches for subgraph-based model 5000 7940 2\n",
      "generating big-batches for subgraph-based model 5200 7940 2\n",
      "generating big-batches for subgraph-based model 5400 7940 2\n",
      "generating big-batches for subgraph-based model 5600 7940 2\n",
      "generating big-batches for subgraph-based model 5800 7940 2\n",
      "generating big-batches for subgraph-based model 6000 7940 2\n",
      "generating big-batches for subgraph-based model 6200 7940 2\n",
      "generating big-batches for subgraph-based model 6400 7940 2\n",
      "generating big-batches for subgraph-based model 6600 7940 2\n",
      "generating big-batches for subgraph-based model 6800 7940 2\n",
      "generating big-batches for subgraph-based model 7000 7940 2\n",
      "generating big-batches for subgraph-based model 7200 7940 2\n",
      "generating big-batches for subgraph-based model 7400 7940 2\n",
      "generating big-batches for subgraph-based model 7600 7940 2\n",
      "generating big-batches for subgraph-based model 7800 7940 2\n",
      "generating big-batches for subgraph-based model 0 7940 3\n",
      "generating big-batches for subgraph-based model 200 7940 3\n",
      "generating big-batches for subgraph-based model 400 7940 3\n",
      "generating big-batches for subgraph-based model 600 7940 3\n",
      "generating big-batches for subgraph-based model 800 7940 3\n",
      "generating big-batches for subgraph-based model 1000 7940 3\n",
      "generating big-batches for subgraph-based model 1200 7940 3\n",
      "generating big-batches for subgraph-based model 1400 7940 3\n",
      "generating big-batches for subgraph-based model 1600 7940 3\n",
      "generating big-batches for subgraph-based model 1800 7940 3\n",
      "generating big-batches for subgraph-based model 2000 7940 3\n",
      "generating big-batches for subgraph-based model 2200 7940 3\n",
      "generating big-batches for subgraph-based model 2400 7940 3\n",
      "generating big-batches for subgraph-based model 2600 7940 3\n",
      "generating big-batches for subgraph-based model 2800 7940 3\n",
      "generating big-batches for subgraph-based model 3000 7940 3\n",
      "generating big-batches for subgraph-based model 3200 7940 3\n",
      "generating big-batches for subgraph-based model 3400 7940 3\n",
      "generating big-batches for subgraph-based model 3600 7940 3\n",
      "generating big-batches for subgraph-based model 3800 7940 3\n",
      "generating big-batches for subgraph-based model 4000 7940 3\n",
      "generating big-batches for subgraph-based model 4200 7940 3\n",
      "generating big-batches for subgraph-based model 4400 7940 3\n",
      "generating big-batches for subgraph-based model 4600 7940 3\n",
      "generating big-batches for subgraph-based model 4800 7940 3\n",
      "generating big-batches for subgraph-based model 5000 7940 3\n",
      "generating big-batches for subgraph-based model 5200 7940 3\n",
      "generating big-batches for subgraph-based model 5400 7940 3\n",
      "generating big-batches for subgraph-based model 5600 7940 3\n",
      "generating big-batches for subgraph-based model 5800 7940 3\n",
      "generating big-batches for subgraph-based model 6000 7940 3\n",
      "generating big-batches for subgraph-based model 6200 7940 3\n",
      "generating big-batches for subgraph-based model 6400 7940 3\n",
      "generating big-batches for subgraph-based model 6600 7940 3\n",
      "generating big-batches for subgraph-based model 6800 7940 3\n",
      "generating big-batches for subgraph-based model 7000 7940 3\n",
      "generating big-batches for subgraph-based model 7200 7940 3\n",
      "generating big-batches for subgraph-based model 7400 7940 3\n",
      "generating big-batches for subgraph-based model 7600 7940 3\n",
      "generating big-batches for subgraph-based model 7800 7940 3\n",
      "generating big-batches for subgraph-based model 0 7940 4\n",
      "generating big-batches for subgraph-based model 200 7940 4\n",
      "generating big-batches for subgraph-based model 400 7940 4\n",
      "generating big-batches for subgraph-based model 600 7940 4\n",
      "generating big-batches for subgraph-based model 800 7940 4\n",
      "generating big-batches for subgraph-based model 1000 7940 4\n",
      "generating big-batches for subgraph-based model 1200 7940 4\n",
      "generating big-batches for subgraph-based model 1400 7940 4\n",
      "generating big-batches for subgraph-based model 1600 7940 4\n",
      "generating big-batches for subgraph-based model 1800 7940 4\n",
      "generating big-batches for subgraph-based model 2000 7940 4\n",
      "generating big-batches for subgraph-based model 2200 7940 4\n",
      "generating big-batches for subgraph-based model 2400 7940 4\n",
      "generating big-batches for subgraph-based model 2600 7940 4\n",
      "generating big-batches for subgraph-based model 2800 7940 4\n",
      "generating big-batches for subgraph-based model 3000 7940 4\n",
      "generating big-batches for subgraph-based model 3200 7940 4\n",
      "generating big-batches for subgraph-based model 3400 7940 4\n",
      "generating big-batches for subgraph-based model 3600 7940 4\n",
      "generating big-batches for subgraph-based model 3800 7940 4\n",
      "generating big-batches for subgraph-based model 4000 7940 4\n",
      "generating big-batches for subgraph-based model 4200 7940 4\n",
      "generating big-batches for subgraph-based model 4400 7940 4\n",
      "generating big-batches for subgraph-based model 4600 7940 4\n",
      "generating big-batches for subgraph-based model 4800 7940 4\n",
      "generating big-batches for subgraph-based model 5000 7940 4\n",
      "generating big-batches for subgraph-based model 5200 7940 4\n",
      "generating big-batches for subgraph-based model 5400 7940 4\n",
      "generating big-batches for subgraph-based model 5600 7940 4\n",
      "generating big-batches for subgraph-based model 5800 7940 4\n",
      "generating big-batches for subgraph-based model 6000 7940 4\n",
      "generating big-batches for subgraph-based model 6200 7940 4\n",
      "generating big-batches for subgraph-based model 6400 7940 4\n",
      "generating big-batches for subgraph-based model 6600 7940 4\n",
      "generating big-batches for subgraph-based model 6800 7940 4\n",
      "generating big-batches for subgraph-based model 7000 7940 4\n",
      "generating big-batches for subgraph-based model 7200 7940 4\n",
      "generating big-batches for subgraph-based model 7400 7940 4\n",
      "generating big-batches for subgraph-based model 7600 7940 4\n",
      "generating big-batches for subgraph-based model 7800 7940 4\n",
      "generating big-batches for subgraph-based model 0 7940 5\n",
      "generating big-batches for subgraph-based model 200 7940 5\n",
      "generating big-batches for subgraph-based model 400 7940 5\n",
      "generating big-batches for subgraph-based model 600 7940 5\n",
      "generating big-batches for subgraph-based model 800 7940 5\n",
      "generating big-batches for subgraph-based model 1000 7940 5\n",
      "generating big-batches for subgraph-based model 1200 7940 5\n",
      "generating big-batches for subgraph-based model 1400 7940 5\n",
      "generating big-batches for subgraph-based model 1600 7940 5\n",
      "generating big-batches for subgraph-based model 1800 7940 5\n",
      "generating big-batches for subgraph-based model 2000 7940 5\n",
      "generating big-batches for subgraph-based model 2200 7940 5\n",
      "generating big-batches for subgraph-based model 2400 7940 5\n",
      "generating big-batches for subgraph-based model 2600 7940 5\n",
      "generating big-batches for subgraph-based model 2800 7940 5\n",
      "generating big-batches for subgraph-based model 3000 7940 5\n",
      "generating big-batches for subgraph-based model 3200 7940 5\n",
      "generating big-batches for subgraph-based model 3400 7940 5\n",
      "generating big-batches for subgraph-based model 3600 7940 5\n",
      "generating big-batches for subgraph-based model 3800 7940 5\n",
      "generating big-batches for subgraph-based model 4000 7940 5\n",
      "generating big-batches for subgraph-based model 4200 7940 5\n",
      "generating big-batches for subgraph-based model 4400 7940 5\n",
      "generating big-batches for subgraph-based model 4600 7940 5\n",
      "generating big-batches for subgraph-based model 4800 7940 5\n",
      "generating big-batches for subgraph-based model 5000 7940 5\n",
      "generating big-batches for subgraph-based model 5200 7940 5\n",
      "generating big-batches for subgraph-based model 5400 7940 5\n",
      "generating big-batches for subgraph-based model 5600 7940 5\n",
      "generating big-batches for subgraph-based model 5800 7940 5\n",
      "generating big-batches for subgraph-based model 6000 7940 5\n",
      "generating big-batches for subgraph-based model 6200 7940 5\n",
      "generating big-batches for subgraph-based model 6400 7940 5\n",
      "generating big-batches for subgraph-based model 6600 7940 5\n",
      "generating big-batches for subgraph-based model 6800 7940 5\n",
      "generating big-batches for subgraph-based model 7000 7940 5\n",
      "generating big-batches for subgraph-based model 7200 7940 5\n",
      "generating big-batches for subgraph-based model 7400 7940 5\n",
      "generating big-batches for subgraph-based model 7600 7940 5\n",
      "generating big-batches for subgraph-based model 7800 7940 5\n",
      "generating big-batches for subgraph-based model 0 7940 6\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generating big-batches for subgraph-based model 200 7940 6\n",
      "generating big-batches for subgraph-based model 400 7940 6\n",
      "generating big-batches for subgraph-based model 600 7940 6\n",
      "generating big-batches for subgraph-based model 800 7940 6\n",
      "generating big-batches for subgraph-based model 1000 7940 6\n",
      "generating big-batches for subgraph-based model 1200 7940 6\n",
      "generating big-batches for subgraph-based model 1400 7940 6\n",
      "generating big-batches for subgraph-based model 1600 7940 6\n",
      "generating big-batches for subgraph-based model 1800 7940 6\n",
      "generating big-batches for subgraph-based model 2000 7940 6\n",
      "generating big-batches for subgraph-based model 2200 7940 6\n",
      "generating big-batches for subgraph-based model 2400 7940 6\n",
      "generating big-batches for subgraph-based model 2600 7940 6\n",
      "generating big-batches for subgraph-based model 2800 7940 6\n",
      "generating big-batches for subgraph-based model 3000 7940 6\n",
      "generating big-batches for subgraph-based model 3200 7940 6\n",
      "generating big-batches for subgraph-based model 3400 7940 6\n",
      "generating big-batches for subgraph-based model 3600 7940 6\n",
      "generating big-batches for subgraph-based model 3800 7940 6\n",
      "generating big-batches for subgraph-based model 4000 7940 6\n",
      "generating big-batches for subgraph-based model 4200 7940 6\n",
      "generating big-batches for subgraph-based model 4400 7940 6\n",
      "generating big-batches for subgraph-based model 4600 7940 6\n",
      "generating big-batches for subgraph-based model 4800 7940 6\n",
      "generating big-batches for subgraph-based model 5000 7940 6\n",
      "generating big-batches for subgraph-based model 5200 7940 6\n",
      "generating big-batches for subgraph-based model 5400 7940 6\n",
      "generating big-batches for subgraph-based model 5600 7940 6\n",
      "generating big-batches for subgraph-based model 5800 7940 6\n",
      "generating big-batches for subgraph-based model 6000 7940 6\n",
      "generating big-batches for subgraph-based model 6200 7940 6\n",
      "generating big-batches for subgraph-based model 6400 7940 6\n",
      "generating big-batches for subgraph-based model 6600 7940 6\n",
      "generating big-batches for subgraph-based model 6800 7940 6\n",
      "generating big-batches for subgraph-based model 7000 7940 6\n",
      "generating big-batches for subgraph-based model 7200 7940 6\n",
      "generating big-batches for subgraph-based model 7400 7940 6\n",
      "generating big-batches for subgraph-based model 7600 7940 6\n",
      "generating big-batches for subgraph-based model 7800 7940 6\n",
      "generating big-batches for subgraph-based model 0 7940 7\n",
      "generating big-batches for subgraph-based model 200 7940 7\n",
      "generating big-batches for subgraph-based model 400 7940 7\n",
      "generating big-batches for subgraph-based model 600 7940 7\n",
      "generating big-batches for subgraph-based model 800 7940 7\n",
      "generating big-batches for subgraph-based model 1000 7940 7\n",
      "generating big-batches for subgraph-based model 1200 7940 7\n",
      "generating big-batches for subgraph-based model 1400 7940 7\n",
      "generating big-batches for subgraph-based model 1600 7940 7\n",
      "generating big-batches for subgraph-based model 1800 7940 7\n",
      "generating big-batches for subgraph-based model 2000 7940 7\n",
      "generating big-batches for subgraph-based model 2200 7940 7\n",
      "generating big-batches for subgraph-based model 2400 7940 7\n",
      "generating big-batches for subgraph-based model 2600 7940 7\n",
      "generating big-batches for subgraph-based model 2800 7940 7\n",
      "generating big-batches for subgraph-based model 3000 7940 7\n",
      "generating big-batches for subgraph-based model 3200 7940 7\n",
      "generating big-batches for subgraph-based model 3400 7940 7\n",
      "generating big-batches for subgraph-based model 3600 7940 7\n",
      "generating big-batches for subgraph-based model 3800 7940 7\n",
      "generating big-batches for subgraph-based model 4000 7940 7\n",
      "generating big-batches for subgraph-based model 4200 7940 7\n",
      "generating big-batches for subgraph-based model 4400 7940 7\n",
      "generating big-batches for subgraph-based model 4600 7940 7\n",
      "generating big-batches for subgraph-based model 4800 7940 7\n",
      "generating big-batches for subgraph-based model 5000 7940 7\n",
      "generating big-batches for subgraph-based model 5200 7940 7\n",
      "generating big-batches for subgraph-based model 5400 7940 7\n",
      "generating big-batches for subgraph-based model 5600 7940 7\n",
      "generating big-batches for subgraph-based model 5800 7940 7\n",
      "generating big-batches for subgraph-based model 6000 7940 7\n",
      "generating big-batches for subgraph-based model 6200 7940 7\n",
      "generating big-batches for subgraph-based model 6400 7940 7\n",
      "generating big-batches for subgraph-based model 6600 7940 7\n",
      "generating big-batches for subgraph-based model 6800 7940 7\n",
      "generating big-batches for subgraph-based model 7000 7940 7\n",
      "generating big-batches for subgraph-based model 7200 7940 7\n",
      "generating big-batches for subgraph-based model 7400 7940 7\n",
      "generating big-batches for subgraph-based model 7600 7940 7\n",
      "generating big-batches for subgraph-based model 7800 7940 7\n",
      "generating big-batches for subgraph-based model 0 7940 8\n",
      "generating big-batches for subgraph-based model 200 7940 8\n",
      "generating big-batches for subgraph-based model 400 7940 8\n",
      "generating big-batches for subgraph-based model 600 7940 8\n",
      "generating big-batches for subgraph-based model 800 7940 8\n",
      "generating big-batches for subgraph-based model 1000 7940 8\n",
      "generating big-batches for subgraph-based model 1200 7940 8\n",
      "generating big-batches for subgraph-based model 1400 7940 8\n",
      "generating big-batches for subgraph-based model 1600 7940 8\n",
      "generating big-batches for subgraph-based model 1800 7940 8\n",
      "generating big-batches for subgraph-based model 2000 7940 8\n",
      "generating big-batches for subgraph-based model 2200 7940 8\n",
      "generating big-batches for subgraph-based model 2400 7940 8\n",
      "generating big-batches for subgraph-based model 2600 7940 8\n",
      "generating big-batches for subgraph-based model 2800 7940 8\n",
      "generating big-batches for subgraph-based model 3000 7940 8\n",
      "generating big-batches for subgraph-based model 3200 7940 8\n",
      "generating big-batches for subgraph-based model 3400 7940 8\n",
      "generating big-batches for subgraph-based model 3600 7940 8\n",
      "generating big-batches for subgraph-based model 3800 7940 8\n",
      "generating big-batches for subgraph-based model 4000 7940 8\n",
      "generating big-batches for subgraph-based model 4200 7940 8\n",
      "generating big-batches for subgraph-based model 4400 7940 8\n",
      "generating big-batches for subgraph-based model 4600 7940 8\n",
      "generating big-batches for subgraph-based model 4800 7940 8\n",
      "generating big-batches for subgraph-based model 5000 7940 8\n",
      "generating big-batches for subgraph-based model 5200 7940 8\n",
      "generating big-batches for subgraph-based model 5400 7940 8\n",
      "generating big-batches for subgraph-based model 5600 7940 8\n",
      "generating big-batches for subgraph-based model 5800 7940 8\n",
      "generating big-batches for subgraph-based model 6000 7940 8\n",
      "generating big-batches for subgraph-based model 6200 7940 8\n",
      "generating big-batches for subgraph-based model 6400 7940 8\n",
      "generating big-batches for subgraph-based model 6600 7940 8\n",
      "generating big-batches for subgraph-based model 6800 7940 8\n",
      "generating big-batches for subgraph-based model 7000 7940 8\n",
      "generating big-batches for subgraph-based model 7200 7940 8\n",
      "generating big-batches for subgraph-based model 7400 7940 8\n",
      "generating big-batches for subgraph-based model 7600 7940 8\n",
      "generating big-batches for subgraph-based model 7800 7940 8\n",
      "generating big-batches for subgraph-based model 0 7940 9\n",
      "generating big-batches for subgraph-based model 200 7940 9\n",
      "generating big-batches for subgraph-based model 400 7940 9\n",
      "generating big-batches for subgraph-based model 600 7940 9\n",
      "generating big-batches for subgraph-based model 800 7940 9\n",
      "generating big-batches for subgraph-based model 1000 7940 9\n",
      "generating big-batches for subgraph-based model 1200 7940 9\n",
      "generating big-batches for subgraph-based model 1400 7940 9\n",
      "generating big-batches for subgraph-based model 1600 7940 9\n",
      "generating big-batches for subgraph-based model 1800 7940 9\n",
      "generating big-batches for subgraph-based model 2000 7940 9\n",
      "generating big-batches for subgraph-based model 2200 7940 9\n",
      "generating big-batches for subgraph-based model 2400 7940 9\n",
      "generating big-batches for subgraph-based model 2600 7940 9\n",
      "generating big-batches for subgraph-based model 2800 7940 9\n",
      "generating big-batches for subgraph-based model 3000 7940 9\n",
      "generating big-batches for subgraph-based model 3200 7940 9\n",
      "generating big-batches for subgraph-based model 3400 7940 9\n",
      "generating big-batches for subgraph-based model 3600 7940 9\n",
      "generating big-batches for subgraph-based model 3800 7940 9\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generating big-batches for subgraph-based model 4000 7940 9\n",
      "generating big-batches for subgraph-based model 4200 7940 9\n",
      "generating big-batches for subgraph-based model 4400 7940 9\n",
      "generating big-batches for subgraph-based model 4600 7940 9\n",
      "generating big-batches for subgraph-based model 4800 7940 9\n",
      "generating big-batches for subgraph-based model 5000 7940 9\n",
      "generating big-batches for subgraph-based model 5200 7940 9\n",
      "generating big-batches for subgraph-based model 5400 7940 9\n",
      "generating big-batches for subgraph-based model 5600 7940 9\n",
      "generating big-batches for subgraph-based model 5800 7940 9\n",
      "generating big-batches for subgraph-based model 6000 7940 9\n",
      "generating big-batches for subgraph-based model 6200 7940 9\n",
      "generating big-batches for subgraph-based model 6400 7940 9\n",
      "generating big-batches for subgraph-based model 6600 7940 9\n",
      "generating big-batches for subgraph-based model 6800 7940 9\n",
      "generating big-batches for subgraph-based model 7000 7940 9\n",
      "generating big-batches for subgraph-based model 7200 7940 9\n",
      "generating big-batches for subgraph-based model 7400 7940 9\n",
      "generating big-batches for subgraph-based model 7600 7940 9\n",
      "generating big-batches for subgraph-based model 7800 7940 9\n",
      "generating big-batches for subgraph-based model 0 934 0\n",
      "generating big-batches for subgraph-based model 200 934 0\n",
      "generating big-batches for subgraph-based model 400 934 0\n",
      "generating big-batches for subgraph-based model 600 934 0\n",
      "generating big-batches for subgraph-based model 800 934 0\n",
      "generating big-batches for subgraph-based model 0 934 1\n",
      "generating big-batches for subgraph-based model 200 934 1\n",
      "generating big-batches for subgraph-based model 400 934 1\n",
      "generating big-batches for subgraph-based model 600 934 1\n",
      "generating big-batches for subgraph-based model 800 934 1\n",
      "generating big-batches for subgraph-based model 0 934 2\n",
      "generating big-batches for subgraph-based model 200 934 2\n",
      "generating big-batches for subgraph-based model 400 934 2\n",
      "generating big-batches for subgraph-based model 600 934 2\n",
      "generating big-batches for subgraph-based model 800 934 2\n",
      "generating big-batches for subgraph-based model 0 934 3\n",
      "generating big-batches for subgraph-based model 200 934 3\n",
      "generating big-batches for subgraph-based model 400 934 3\n",
      "generating big-batches for subgraph-based model 600 934 3\n",
      "generating big-batches for subgraph-based model 800 934 3\n",
      "generating big-batches for subgraph-based model 0 934 4\n",
      "generating big-batches for subgraph-based model 200 934 4\n",
      "generating big-batches for subgraph-based model 400 934 4\n",
      "generating big-batches for subgraph-based model 600 934 4\n",
      "generating big-batches for subgraph-based model 800 934 4\n",
      "generating big-batches for subgraph-based model 0 934 5\n",
      "generating big-batches for subgraph-based model 200 934 5\n",
      "generating big-batches for subgraph-based model 400 934 5\n",
      "generating big-batches for subgraph-based model 600 934 5\n",
      "generating big-batches for subgraph-based model 800 934 5\n",
      "generating big-batches for subgraph-based model 0 934 6\n",
      "generating big-batches for subgraph-based model 200 934 6\n",
      "generating big-batches for subgraph-based model 400 934 6\n",
      "generating big-batches for subgraph-based model 600 934 6\n",
      "generating big-batches for subgraph-based model 800 934 6\n",
      "generating big-batches for subgraph-based model 0 934 7\n",
      "generating big-batches for subgraph-based model 200 934 7\n",
      "generating big-batches for subgraph-based model 400 934 7\n",
      "generating big-batches for subgraph-based model 600 934 7\n",
      "generating big-batches for subgraph-based model 800 934 7\n",
      "generating big-batches for subgraph-based model 0 934 8\n",
      "generating big-batches for subgraph-based model 200 934 8\n",
      "generating big-batches for subgraph-based model 400 934 8\n",
      "generating big-batches for subgraph-based model 600 934 8\n",
      "generating big-batches for subgraph-based model 800 934 8\n",
      "generating big-batches for subgraph-based model 0 934 9\n",
      "generating big-batches for subgraph-based model 200 934 9\n",
      "generating big-batches for subgraph-based model 400 934 9\n",
      "generating big-batches for subgraph-based model 600 934 9\n",
      "generating big-batches for subgraph-based model 800 934 9\n",
      "Epoch 1/10\n",
      "14873/14873 [==============================] - 863s 56ms/step - loss: 0.5533 - binary_accuracy: 0.7184 - val_loss: 0.4706 - val_binary_accuracy: 0.7739\n",
      "Epoch 2/10\n",
      "14873/14873 [==============================] - 797s 54ms/step - loss: 0.4950 - binary_accuracy: 0.7564 - val_loss: 0.4164 - val_binary_accuracy: 0.8075\n",
      "Epoch 3/10\n",
      "14873/14873 [==============================] - 813s 55ms/step - loss: 0.4745 - binary_accuracy: 0.7671 - val_loss: 0.4082 - val_binary_accuracy: 0.8042\n",
      "Epoch 4/10\n",
      "14873/14873 [==============================] - 809s 54ms/step - loss: 0.4641 - binary_accuracy: 0.7737 - val_loss: 0.3977 - val_binary_accuracy: 0.8154\n",
      "Epoch 5/10\n",
      "14873/14873 [==============================] - 812s 55ms/step - loss: 0.4578 - binary_accuracy: 0.7774 - val_loss: 0.3898 - val_binary_accuracy: 0.8195\n",
      "Epoch 6/10\n",
      "14873/14873 [==============================] - 810s 54ms/step - loss: 0.4536 - binary_accuracy: 0.7798 - val_loss: 0.3945 - val_binary_accuracy: 0.8142\n",
      "Epoch 7/10\n",
      "14873/14873 [==============================] - 807s 54ms/step - loss: 0.4510 - binary_accuracy: 0.7813 - val_loss: 0.3899 - val_binary_accuracy: 0.8192\n",
      "Epoch 8/10\n",
      "14873/14873 [==============================] - 815s 55ms/step - loss: 0.4480 - binary_accuracy: 0.7828 - val_loss: 0.3865 - val_binary_accuracy: 0.8187\n",
      "Epoch 9/10\n",
      "14873/14873 [==============================] - 812s 55ms/step - loss: 0.4463 - binary_accuracy: 0.7841 - val_loss: 0.3876 - val_binary_accuracy: 0.8172\n",
      "Epoch 10/10\n",
      "14873/14873 [==============================] - 811s 55ms/step - loss: 0.4450 - binary_accuracy: 0.7846 - val_loss: 0.3808 - val_binary_accuracy: 0.8216\n",
      "Save model\n"
     ]
    }
   ],
   "source": [
    "###train the subgraph-based model\n",
    "lower_bd = lower_bound\n",
    "upper_bd = upper_bound_subg\n",
    "num_epoch = 10\n",
    "batch_size = 32\n",
    "\n",
    "Dict_train = store_subgraph_dicts(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                         relation2id, entity2id, id2relation, id2entity)\n",
    "\n",
    "Dict_valid = store_subgraph_dicts(lower_bd, upper_bd, data_valid, one_hop_valid, s_t_r_valid,\n",
    "                         relation2id, entity2id, id2relation, id2entity)\n",
    "        \n",
    "#define the training lists\n",
    "train_s_list, train_t_list, train_r_list, train_y_list = {'1': [], '2': [], '3': []}, {'1': [], '2': [], '3': []}, list(), list()\n",
    "\n",
    "#define the validation lists\n",
    "valid_s_list, valid_t_list, valid_r_list, valid_y_list = {'1': [], '2': [], '3': []}, {'1': [], '2': [], '3': []}, list(), list()\n",
    "\n",
    "#######################################\n",
    "###build the big-batches###############      \n",
    "\n",
    "#fill in the training array list\n",
    "build_big_batches_subgraph(lower_bd, upper_bd, data, one_hop, s_t_r,\n",
    "                      train_s_list, train_t_list, train_r_list, train_y_list, Dict_train,\n",
    "                      relation2id, entity2id, id2relation, id2entity)\n",
    "\n",
    "#fill in the validation array list\n",
    "build_big_batches_subgraph(lower_bd, upper_bd, data_valid, one_hop_valid, s_t_r_valid,\n",
    "                      valid_s_list, valid_t_list, valid_r_list, valid_y_list, Dict_valid,\n",
    "                      relation2id, entity2id, id2relation, id2entity)    \n",
    "\n",
    "#######################################\n",
    "###do the training#####################\n",
    "#sometimes the validation dataset is so small so sparse, \n",
    "#which cannot find three paths between any pair of s and t.\n",
    "#in such a case, we will divide the training big-batch into train and valid\n",
    "if len(valid_y_list) >= 100:\n",
    "    #generate the input arrays\n",
    "    x_train_s_1 = np.asarray(train_s_list['1'], dtype='int')\n",
    "    x_train_s_2 = np.asarray(train_s_list['2'], dtype='int')\n",
    "    x_train_s_3 = np.asarray(train_s_list['3'], dtype='int')\n",
    "\n",
    "    x_train_t_1 = np.asarray(train_t_list['1'], dtype='int')\n",
    "    x_train_t_2 = np.asarray(train_t_list['2'], dtype='int')\n",
    "    x_train_t_3 = np.asarray(train_t_list['3'], dtype='int')\n",
    "\n",
    "    x_train_r = np.asarray(train_r_list, dtype='int')\n",
    "    y_train = np.asarray(train_y_list, dtype='int')\n",
    "\n",
    "    #generate the validation arrays\n",
    "    x_valid_s_1 = np.asarray(valid_s_list['1'], dtype='int')\n",
    "    x_valid_s_2 = np.asarray(valid_s_list['2'], dtype='int')\n",
    "    x_valid_s_3 = np.asarray(valid_s_list['3'], dtype='int')\n",
    "\n",
    "    x_valid_t_1 = np.asarray(valid_t_list['1'], dtype='int')\n",
    "    x_valid_t_2 = np.asarray(valid_t_list['2'], dtype='int')\n",
    "    x_valid_t_3 = np.asarray(valid_t_list['3'], dtype='int')\n",
    "\n",
    "    x_valid_r = np.asarray(valid_r_list, dtype='int')\n",
    "    y_valid = np.asarray(valid_y_list, dtype='int')\n",
    "\n",
    "else:\n",
    "    split = int(len(train_y_list)*0.8)\n",
    "    #generate the input arrays\n",
    "    x_train_s_1 = np.asarray(train_s_list['1'][:split], dtype='int')\n",
    "    x_train_s_2 = np.asarray(train_s_list['2'][:split], dtype='int')\n",
    "    x_train_s_3 = np.asarray(train_s_list['3'][:split], dtype='int')\n",
    "\n",
    "    x_train_t_1 = np.asarray(train_t_list['1'][:split], dtype='int')\n",
    "    x_train_t_2 = np.asarray(train_t_list['2'][:split], dtype='int')\n",
    "    x_train_t_3 = np.asarray(train_t_list['3'][:split], dtype='int')\n",
    "\n",
    "    x_train_r = np.asarray(train_r_list[:split], dtype='int')\n",
    "    y_train = np.asarray(train_y_list[:split], dtype='int')\n",
    "\n",
    "    #generate the validation arrays\n",
    "    x_valid_s_1 = np.asarray(train_s_list['1'][split:], dtype='int')\n",
    "    x_valid_s_2 = np.asarray(train_s_list['2'][split:], dtype='int')\n",
    "    x_valid_s_3 = np.asarray(train_s_list['3'][split:], dtype='int')\n",
    "\n",
    "    x_valid_t_1 = np.asarray(train_t_list['1'][split:], dtype='int')\n",
    "    x_valid_t_2 = np.asarray(train_t_list['2'][split:], dtype='int')\n",
    "    x_valid_t_3 = np.asarray(train_t_list['3'][split:], dtype='int')\n",
    "\n",
    "    x_valid_r = np.asarray(train_r_list[split:], dtype='int')\n",
    "    y_valid = np.asarray(train_y_list[split:], dtype='int')\n",
    "\n",
    "#do the training\n",
    "model_2.fit([x_train_s_1, x_train_s_2, x_train_s_3, x_train_t_1, x_train_t_2, x_train_t_3, x_train_r], y_train, \n",
    "          validation_data=([x_valid_s_1, x_valid_s_2, x_valid_s_3, x_valid_t_1, x_valid_t_2, x_valid_t_3, x_valid_r], y_valid),\n",
    "          batch_size=batch_size, epochs=num_epoch)\n",
    "\n",
    "# Save model and weights\n",
    "one_hop_add_h5 = one_hop_model_name + '.h5'\n",
    "one_hop_save_dir = os.path.join(os.getcwd(), '../weight_bin')\n",
    "\n",
    "if not os.path.isdir(one_hop_save_dir):\n",
    "    os.makedirs(one_hop_save_dir)\n",
    "one_hop_model_path = os.path.join(one_hop_save_dir, one_hop_add_h5)\n",
    "model_2.save(one_hop_model_path)\n",
    "print('Save model')\n",
    "del(model_2, Dict_train, Dict_valid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a74957c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2178e81c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8f9152c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38cbcb96",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e4df421",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "867e4d49",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88f86bd9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01f1d82b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe787997",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3da50338",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3d51f71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9543feff",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea551344",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8526f0a4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0ef907e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28e528e4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "63f4eca8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9729af14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b107dff0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c689768",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "14b6bf00",
   "metadata": {},
   "source": [
    "### Result on the testset for inductive link prediction\n",
    "\n",
    "We use the testset for inductive link prediction."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "207ef966",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_name = 'fb237_v3'\n",
    "model_id = 'SiaLP_3_new'\n",
    "lower_bound = 1\n",
    "upper_bound_path = 10\n",
    "upper_bound_subg = 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c7e2a7ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "#difine the names for saving\n",
    "model_name = 'Model_' + model_id + '_' + data_name\n",
    "one_hop_model_name = 'One_hop_model_' + model_id + '_' + data_name\n",
    "ids_name = 'IDs_' + model_id + '_' + data_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8c59ddf2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'IDs_SiaLP_3_new_fb237_v3'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ids_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ae165f20",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'One_hop_model_SiaLP_3_new_fb237_v3'"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "one_hop_model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f87cc2fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Model_SiaLP_3_new_fb237_v3'"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5f959af0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import librosa\n",
    "import opensmile\n",
    "import os\n",
    "import sys\n",
    "import numpy as np\n",
    "import random\n",
    "import pickle\n",
    "\n",
    "from collections import defaultdict\n",
    "from copy import deepcopy\n",
    "from sklearn.utils import shuffle\n",
    "\n",
    "import tensorflow as tf\n",
    "from tensorflow import keras\n",
    "from tensorflow.keras import layers\n",
    "from tensorflow.keras import Model\n",
    "from tensorflow.keras import initializers\n",
    "from tensorflow.keras.utils import plot_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "37c81c86",
   "metadata": {},
   "outputs": [],
   "source": [
    "class LoadKG:\n",
    "    \n",
    "    def __init__(self):\n",
    "        \n",
    "        self.x = 'Hello'\n",
    "        \n",
    "    def load_train_data(self, data_path, one_hop, data, s_t_r, entity2id, id2entity,\n",
    "                     relation2id, id2relation):\n",
    "        \n",
    "        data_ = set()\n",
    "    \n",
    "        ####load the train, valid and test set##########\n",
    "        with open (data_path, 'r') as f:\n",
    "            \n",
    "            data_ini = f.readlines()\n",
    "                        \n",
    "            for i in range(len(data_ini)):\n",
    "            \n",
    "                x = data_ini[i].split()\n",
    "                \n",
    "                x_ = tuple(x)\n",
    "                \n",
    "                data_.add(x_)\n",
    "        \n",
    "        ####relation dict#################\n",
    "        index = len(relation2id)\n",
    "     \n",
    "        for key in data_:\n",
    "            \n",
    "            if key[1] not in relation2id:\n",
    "                \n",
    "                relation = key[1]\n",
    "                \n",
    "                relation2id[relation] = index\n",
    "                \n",
    "                id2relation[index] = relation\n",
    "                \n",
    "                index += 1\n",
    "                \n",
    "                #the inverse relation\n",
    "                iv_r = '_inverse_' + relation\n",
    "                \n",
    "                relation2id[iv_r] = index\n",
    "                \n",
    "                id2relation[index] = iv_r\n",
    "                \n",
    "                index += 1\n",
    "        \n",
    "        #get the id of the inverse relation, by above definition, initial relation has \n",
    "        #always even id, while inverse relation has always odd id.\n",
    "        def inverse_r(r):\n",
    "            \n",
    "            if r % 2 == 0: #initial relation\n",
    "                \n",
    "                iv_r = r + 1\n",
    "            \n",
    "            else: #inverse relation\n",
    "                \n",
    "                iv_r = r - 1\n",
    "            \n",
    "            return(iv_r)\n",
    "        \n",
    "        ####entity dict###################\n",
    "        index = len(entity2id)\n",
    "        \n",
    "        for key in data_:\n",
    "            \n",
    "            source, target = key[0], key[2]\n",
    "            \n",
    "            if source not in entity2id:\n",
    "                                \n",
    "                entity2id[source] = index\n",
    "                \n",
    "                id2entity[index] = source\n",
    "                \n",
    "                index += 1\n",
    "            \n",
    "            if target not in entity2id:\n",
    "                \n",
    "                entity2id[target] = index\n",
    "                \n",
    "                id2entity[index] = target\n",
    "                \n",
    "                index += 1\n",
    "                \n",
    "        #create the set of triples using id instead of string        \n",
    "        for ele in data_:\n",
    "            \n",
    "            s = entity2id[ele[0]]\n",
    "            \n",
    "            r = relation2id[ele[1]]\n",
    "            \n",
    "            t = entity2id[ele[2]]\n",
    "            \n",
    "            if (s,r,t) not in data:\n",
    "                \n",
    "                data.add((s,r,t))\n",
    "            \n",
    "            s_t_r[(s,t)].add(r)\n",
    "            \n",
    "            if s not in one_hop:\n",
    "                \n",
    "                one_hop[s] = set()\n",
    "            \n",
    "            one_hop[s].add((r,t))\n",
    "            \n",
    "            if t not in one_hop:\n",
    "                \n",
    "                one_hop[t] = set()\n",
    "            \n",
    "            r_inv = inverse_r(r)\n",
    "            \n",
    "            s_t_r[(t,s)].add(r_inv)\n",
    "            \n",
    "            one_hop[t].add((r_inv,s))\n",
    "            \n",
    "        #change each set in one_hop to list\n",
    "        for e in one_hop:\n",
    "            \n",
    "            one_hop[e] = list(one_hop[e])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7a714e01",
   "metadata": {},
   "outputs": [],
   "source": [
    "class ObtainPathsByDynamicProgramming:\n",
    "\n",
    "    def __init__(self, amount_bd=50, size_bd=50, threshold=20000):\n",
    "        \n",
    "        self.amount_bd = amount_bd #how many Tuples we choose in one_hop[node] for next recursion\n",
    "                        \n",
    "        self.size_bd = size_bd #size bound limit the number of paths to a target entity t\n",
    "        \n",
    "        #number of times paths with specific length been performed for recursion\n",
    "        self.threshold = threshold\n",
    "        \n",
    "    '''\n",
    "    Given an entity s, the function will find the paths from s to other entities, using recursion.\n",
    "    \n",
    "    One may refer to LeetCode Problem 797 for details:\n",
    "        https://leetcode.com/problems/all-paths-from-source-to-target/\n",
    "    '''\n",
    "    def obtain_paths(self, mode, s, t_input, lower_bd, upper_bd, one_hop):\n",
    "\n",
    "        if type(lower_bd) != type(1) or lower_bd < 1:\n",
    "            \n",
    "            raise TypeError(\"!!! invalid lower bound setting, must >= 1 !!!\")\n",
    "            \n",
    "        if type(upper_bd) != type(1) or upper_bd < 1:\n",
    "            \n",
    "            raise TypeError(\"!!! invalid upper bound setting, must >= 1 !!!\")\n",
    "            \n",
    "        if lower_bd > upper_bd:\n",
    "            \n",
    "            raise TypeError(\"!!! lower bound must not exced upper bound !!!\")\n",
    "            \n",
    "        if s not in one_hop:\n",
    "            \n",
    "            raise ValueError('!!! entity not in one_hop. Please work on existing entities')\n",
    "\n",
    "        #here is the result dict. Its key is each entity t sharing paths from s\n",
    "        #The value of each t is a set containing the paths from s to t\n",
    "        #These paths can be either the direct connection r, or a multi-hop path\n",
    "        res = defaultdict(set)\n",
    "        \n",
    "        #qualified_t contains the types of t we want to consider,\n",
    "        #that is, what t will be added to the result set.\n",
    "        qualified_t = set()\n",
    "\n",
    "        #under this mode, we will only consider the direct neighbour of s\n",
    "        if mode == 'direct_neighbour':\n",
    "        \n",
    "            for Tuple in one_hop[s]:\n",
    "            \n",
    "                t = Tuple[1]\n",
    "                \n",
    "                qualified_t.add(t)\n",
    "        \n",
    "        #under this mode, we will only consider one specified entity t\n",
    "        elif mode == 'target_specified':\n",
    "            \n",
    "            qualified_t.add(t_input)\n",
    "        \n",
    "        #under this mode, we will consider any entity\n",
    "        elif mode == 'any_target':\n",
    "            \n",
    "            for s_any in one_hop:\n",
    "                \n",
    "                qualified_t.add(s_any)\n",
    "                \n",
    "        else:\n",
    "            \n",
    "            raise ValueError('not a valid mode')\n",
    "        \n",
    "        '''\n",
    "        We use recursion to find the paths\n",
    "        On current node with the path [r1, ..., rk] and on-path entities {s, e1, ..., ek-1, node}\n",
    "        from s to this node, we will further find the direct neighbor t' of this node. \n",
    "        If t' is not an on-path entity (not among s, e1,...ek-1, node), we recursively proceed to t' \n",
    "        '''\n",
    "        def helper(node, path, on_path_en, res, qualified_t, lower_bd, upper_bd, one_hop, count_dict):\n",
    "\n",
    "            #when the current path is within lower_bd and upper_bd, \n",
    "            #and the node is among the qualified t, and it has not been fill of paths w.r.t size_limit,\n",
    "            #we will add this path to the node\n",
    "            if (len(path) >= lower_bd) and (len(path) <= upper_bd) and (\n",
    "                node in qualified_t) and (len(res[node]) < self.size_bd):\n",
    "                \n",
    "                res[node].add(tuple(path))\n",
    "                    \n",
    "            #won't start new recursions if the current path length already reaches upper limit\n",
    "            #or the number of recursions performed on this length has reached the limit\n",
    "            if (len(path) < upper_bd) and (count_dict[len(path)] <= self.threshold):\n",
    "                                \n",
    "                #temp list is the id list for us to go-over one_hop[node]\n",
    "                temp_list = [i for i in range(len(one_hop[node]))]\n",
    "                random.shuffle(temp_list) #so we random-shuffle the list\n",
    "                \n",
    "                #only take 20 recursions if there are too many (r,t)\n",
    "                for i in temp_list[:self.amount_bd]:\n",
    "                    \n",
    "                    #obtain tuple of (r,t)\n",
    "                    Tuple = one_hop[node][i]\n",
    "                    r, t = Tuple[0], Tuple[1]\n",
    "                    \n",
    "                    #add to count_dict even if eventually this step not proceed\n",
    "                    count_dict[len(path)] += 1\n",
    "                    \n",
    "                    #if t not on the path and we not exceed the computation threshold, \n",
    "                    #then finally proceed to next recursion\n",
    "                    if (t not in on_path_en) and (count_dict[len(path)] <= self.threshold):\n",
    "\n",
    "                        helper(t, path + [r], on_path_en.union({t}), res, qualified_t, \n",
    "                               lower_bd, upper_bd, one_hop, count_dict)\n",
    "\n",
    "        length_dict = defaultdict(int)\n",
    "        count_dict = defaultdict(int)\n",
    "        \n",
    "        helper(s, [], {s}, res, qualified_t, lower_bd, upper_bd, one_hop, count_dict)\n",
    "        \n",
    "        return(res, count_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f0d1f8d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the classes\n",
    "Class_1 = LoadKG()\n",
    "Class_2 = ObtainPathsByDynamicProgramming()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "10f13661",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "430"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#load ids and relation/entity dicts\n",
    "with open('../weight_bin/' + ids_name + '.pickle', 'rb') as handle:\n",
    "    Dict = pickle.load(handle)\n",
    "    \n",
    "#save training data\n",
    "one_hop = Dict['one_hop']\n",
    "data = Dict['data']\n",
    "s_t_r = Dict['s_t_r']\n",
    "\n",
    "#save valid data\n",
    "one_hop_valid = Dict['one_hop_valid']\n",
    "data_valid = Dict['data_valid']\n",
    "s_t_r_valid = Dict['s_t_r_valid']\n",
    "\n",
    "#save test data\n",
    "one_hop_test = Dict['one_hop_test']\n",
    "data_test = Dict['data_test']\n",
    "s_t_r_test = Dict['s_t_r_test']\n",
    "\n",
    "#save shared dictionaries\n",
    "entity2id = Dict['entity2id']\n",
    "id2entity = Dict['id2entity']\n",
    "relation2id = Dict['relation2id']\n",
    "id2relation = Dict['id2relation']\n",
    "\n",
    "#we want to keep the initial entity/relation dicts before adding new entities\n",
    "entity2id_ini = deepcopy(entity2id)\n",
    "id2entity_ini = deepcopy(id2entity)\n",
    "relation2id_ini = deepcopy(relation2id)\n",
    "id2relation_ini = deepcopy(id2relation)\n",
    "\n",
    "num_r = len(id2relation)\n",
    "num_r"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "74048a53",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'IDs_SiaLP_3_new_fb237_v3'"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ids_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "027883e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Model_SiaLP_3_new_fb237_v3'"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "50c64cf2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-16 20:11:45.528497: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "#load the model\n",
    "model = keras.models.load_model('../weight_bin/' + model_name + '.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "378e34e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the one-hop neighbor model\n",
    "model_2 = keras.models.load_model('../weight_bin/' + one_hop_model_name + '.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "d2ea521a",
   "metadata": {},
   "outputs": [],
   "source": [
    "ind_train_path = '../data/' + data_name + '_ind/train.txt'\n",
    "ind_valid_path = '../data/' + data_name + '_ind/valid.txt'\n",
    "ind_test_path = '../data/' + data_name + '_ind/test.txt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1d2e6087",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the test dataset\n",
    "one_hop_ind = dict() \n",
    "data_ind = set()\n",
    "s_t_r_ind = defaultdict(set)\n",
    "\n",
    "len_0 = len(relation2id)\n",
    "size_0 = len(entity2id)\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(ind_train_path, \n",
    "                        one_hop_ind, data_ind, s_t_r_ind,\n",
    "                        entity2id, id2entity, relation2id, id2relation)\n",
    "\n",
    "len_1 = len(relation2id)\n",
    "size_1 = len(entity2id)\n",
    "\n",
    "if len_0 != len_1:\n",
    "    raise ValueError('unseen relation!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4a6dfe59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3668 6169 7406\n"
     ]
    }
   ],
   "source": [
    "print(size_0, size_1, len(data_ind))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "63cec98f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the test dataset\n",
    "one_hop_ind_test = dict() \n",
    "data_ind_test = set()\n",
    "s_t_r_ind_test = defaultdict(set)\n",
    "\n",
    "len_0 = len(relation2id)\n",
    "size_0 = len(entity2id)\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(ind_test_path, \n",
    "                        one_hop_ind_test, data_ind_test, s_t_r_ind_test,\n",
    "                        entity2id, id2entity, relation2id, id2relation)\n",
    "\n",
    "\n",
    "len_1 = len(relation2id)\n",
    "size_1 = len(entity2id)\n",
    "\n",
    "if len_0 != len_1:\n",
    "    raise ValueError('unseen relation!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2d18fee1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6169 6169 865\n"
     ]
    }
   ],
   "source": [
    "print(size_0, size_1, len(data_ind_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "757526ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "#load the validation for existing triple removal when ranking\n",
    "one_hop_ind_valid = dict() \n",
    "data_ind_valid = set()\n",
    "s_t_r_ind_valid = defaultdict(set)\n",
    "\n",
    "len_0 = len(relation2id)\n",
    "size_0 = len(entity2id)\n",
    "\n",
    "#fill in the sets and dicts\n",
    "Class_1.load_train_data(ind_valid_path, \n",
    "                        one_hop_ind_valid, data_ind_valid, s_t_r_ind_valid,\n",
    "                        entity2id, id2entity, relation2id, id2relation)\n",
    "\n",
    "len_1 = len(relation2id)\n",
    "size_1 = len(entity2id)\n",
    "\n",
    "if len_0 != len_1:\n",
    "    raise ValueError('unseen relation!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "b2980a00",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6169 6169 866\n"
     ]
    }
   ],
   "source": [
    "print(size_0, size_1, len(data_ind_valid))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "0f17ff08",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6169 3668\n"
     ]
    }
   ],
   "source": [
    "print(len(entity2id), len(entity2id_ini))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "bd1cda6c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3668 2501 6169\n"
     ]
    }
   ],
   "source": [
    "#obtain all the inital entities and new entities\n",
    "ini_ent_set, new_ent_set, all_ent_set = set(), set(), set()\n",
    "\n",
    "for ID in id2entity:\n",
    "    all_ent_set.add(ID)\n",
    "    if ID in id2entity_ini:\n",
    "        ini_ent_set.add(ID)\n",
    "    else:\n",
    "        new_ent_set.add(ID)\n",
    "        \n",
    "print(len(ini_ent_set), len(new_ent_set), len(all_ent_set))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "915ad29b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#we want to check whether there are overlapping \n",
    "#between the entities of train triples and inductive test and valid triples\n",
    "overlapping = 0\n",
    "\n",
    "for ele in data_ind_test:\n",
    "    \n",
    "    s, r, t = ele[0], ele[1], ele[2]\n",
    "    \n",
    "    if s in id2entity_ini or t in id2entity_ini:\n",
    "        \n",
    "        overlapping += 1\n",
    "        \n",
    "overlapping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "80eb1e93",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "overlapping = 0\n",
    "\n",
    "for ele in data_ind_valid:\n",
    "    \n",
    "    s, r, t = ele[0], ele[1], ele[2]\n",
    "    \n",
    "    if s in id2entity_ini or t in id2entity_ini:\n",
    "        \n",
    "        overlapping += 1\n",
    "        \n",
    "overlapping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "7a3c9dd1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#we want to check whether there are overlapping \n",
    "#between the entities of train triples and inductive test and valid triples\n",
    "overlapping = 0\n",
    "\n",
    "for ele in data_ind:\n",
    "    \n",
    "    s, r, t = ele[0], ele[1], ele[2]\n",
    "    \n",
    "    if s in id2entity_ini or t in id2entity_ini:\n",
    "        \n",
    "        overlapping += 1\n",
    "        \n",
    "overlapping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "83ea5533",
   "metadata": {},
   "outputs": [],
   "source": [
    "#the function to do path-based relation scoring\n",
    "def path_based_relation_scoring(s, t, lower_bd, upper_bd, one_hop, id2relation, model):\n",
    "    \n",
    "    path_holder = set()\n",
    "    \n",
    "    for iteration in range(3):\n",
    "    \n",
    "        result, length_dict = Class_2.obtain_paths('target_specified', \n",
    "                                                   s, t, lower_bd, upper_bd, one_hop)\n",
    "        if t in result:\n",
    "            \n",
    "            for path in result[t]:\n",
    "                \n",
    "                path_holder.add(path)\n",
    "                \n",
    "        del(result, length_dict)\n",
    "    \n",
    "    path_holder = list(path_holder)\n",
    "    random.shuffle(path_holder)\n",
    "    \n",
    "    score_dict = defaultdict(float)\n",
    "    count_dict = defaultdict(int)\n",
    "    \n",
    "    count = 0\n",
    "    \n",
    "    if len(path_holder) >= 3:\n",
    "    \n",
    "        #iterate over path_1\n",
    "        while count < 10:\n",
    "\n",
    "            temp_pair = random.sample(path_holder, 3)\n",
    "\n",
    "            path_1, path_2, path_3 = temp_pair[0], temp_pair[1], temp_pair[2]\n",
    "\n",
    "            list_1 = list()\n",
    "            list_2 = list()\n",
    "            list_3 = list()\n",
    "            list_r = list()\n",
    "\n",
    "            for i in range(len(id2relation)):\n",
    "\n",
    "                if i not in id2relation:\n",
    "\n",
    "                    raise ValueError ('error when generating id2relation')\n",
    "                \n",
    "                #only care about initial relations\n",
    "                if i % 2 == 0:\n",
    "\n",
    "                    list_1.append(list(path_1) + [num_r]*abs(len(path_1)-upper_bd))\n",
    "                    list_2.append(list(path_2) + [num_r]*abs(len(path_2)-upper_bd))\n",
    "                    list_3.append(list(path_3) + [num_r]*abs(len(path_3)-upper_bd))\n",
    "                    list_r.append([i])\n",
    "            \n",
    "            #change to arrays\n",
    "            input_1 = np.array(list_1)\n",
    "            input_2 = np.array(list_2)\n",
    "            input_3 = np.array(list_3)\n",
    "            input_r = np.array(list_r)\n",
    "\n",
    "            pred = model.predict([input_1, input_2, input_3, input_r], verbose = 0)\n",
    "\n",
    "            for i in range(pred.shape[0]):\n",
    "                #need to times 2 to go back to relation id from pred position\n",
    "                score_dict[2*i] += float(pred[i])\n",
    "                count_dict[2*i] += 1\n",
    "\n",
    "            count += 1\n",
    "            \n",
    "    #average the score\n",
    "    for r in score_dict:\n",
    "        score_dict[r] = deepcopy(score_dict[r]/float(count_dict[r]))\n",
    "    \n",
    "    print(len(score_dict), len(path_holder))\n",
    "\n",
    "    return(score_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "c1e1b91c",
   "metadata": {},
   "outputs": [],
   "source": [
    "#the function to do path-based triple scoring: input one triple\n",
    "def path_based_triple_scoring(s, r, t, lower_bd, upper_bd, one_hop, id2relation, model):\n",
    "    \n",
    "    path_holder = set()\n",
    "    \n",
    "    for iteration in range(3):\n",
    "    \n",
    "        result, length_dict = Class_2.obtain_paths('target_specified', \n",
    "                                                   s, t, lower_bd, upper_bd, one_hop)\n",
    "        if t in result:\n",
    "            \n",
    "            for path in result[t]:\n",
    "                \n",
    "                path_holder.add(path)\n",
    "                \n",
    "        del(result, length_dict)\n",
    "    \n",
    "    path_holder = list(path_holder)\n",
    "    random.shuffle(path_holder)\n",
    "    \n",
    "    score = 0.\n",
    "    count = 0\n",
    "    \n",
    "    if len(path_holder) >= 3:\n",
    "        \n",
    "        list_1 = list()\n",
    "        list_2 = list()\n",
    "        list_3 = list()\n",
    "        list_r = list()\n",
    "    \n",
    "        #iterate over path_1\n",
    "        while count < 10:\n",
    "\n",
    "            temp_pair = random.sample(path_holder, 3)\n",
    "            path_1, path_2, path_3 = temp_pair[0], temp_pair[1], temp_pair[2]\n",
    "\n",
    "            list_1.append(list(path_1) + [num_r]*abs(len(path_1)-upper_bd))\n",
    "            list_2.append(list(path_2) + [num_r]*abs(len(path_2)-upper_bd))\n",
    "            list_3.append(list(path_3) + [num_r]*abs(len(path_3)-upper_bd))\n",
    "            list_r.append([r])\n",
    "            \n",
    "            count += 1\n",
    "            \n",
    "        #change to arrays\n",
    "        input_1 = np.array(list_1)\n",
    "        input_2 = np.array(list_2)\n",
    "        input_3 = np.array(list_3)\n",
    "        input_r = np.array(list_r)\n",
    "\n",
    "        pred = model.predict([input_1, input_2, input_3, input_r], verbose = 0)\n",
    "\n",
    "        for i in range(pred.shape[0]):\n",
    "            score += float(pred[i])\n",
    "            \n",
    "        #average the score\n",
    "        score = score/float(count)\n",
    "\n",
    "    return(score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "e8512335",
   "metadata": {},
   "outputs": [],
   "source": [
    "#subgraph based relation scoring\n",
    "def subgraph_relation_scoring(s, t, lower_bd, upper_bd, one_hop, id2relation, model_2):\n",
    "    \n",
    "    path_s, path_t = set(), set() #sets holding all the paths from s or t\n",
    "    \n",
    "    for iteration in range(3):\n",
    "    \n",
    "        #obtain the paths out from s or t by \"any target\" mode. That is, \n",
    "        result_s, length_dict_s = Class_2.obtain_paths('any_target', s, 'any', lower_bd, upper_bd, one_hop)\n",
    "        result_t, length_dict_t = Class_2.obtain_paths('any_target', t, 'any', lower_bd, upper_bd, one_hop)\n",
    "\n",
    "        #add paths to the source/target path_set\n",
    "        for e in result_s:\n",
    "            for path in result_s[e]:\n",
    "                path_s.add(path)\n",
    "        for e in result_t:\n",
    "            for path in result_t[e]:\n",
    "                path_t.add(path)\n",
    "                \n",
    "        del(result_s, length_dict_s, result_t, length_dict_t)\n",
    "    \n",
    "    #final output: the score dict\n",
    "    score_dict = defaultdict(float)\n",
    "    count_dict = defaultdict(int)\n",
    "    \n",
    "    #see if both path_s and path_t have at least three paths\n",
    "    if len(path_s) >= 3 and len(path_t) >= 3:\n",
    "\n",
    "        #change to lists\n",
    "        path_s, path_t = list(path_s), list(path_t)\n",
    "        \n",
    "        count = 0\n",
    "        while count < 10:\n",
    "            \n",
    "            #lists holding the input to the network\n",
    "            list_s_1 = list()\n",
    "            list_s_2 = list()\n",
    "            list_s_3 = list()\n",
    "            list_t_1 = list()\n",
    "            list_t_2 = list()\n",
    "            list_t_3 = list()\n",
    "            list_r = list()\n",
    "\n",
    "            #randomly obtain three paths\n",
    "            temp_s = random.sample(path_s, 3)\n",
    "            temp_t = random.sample(path_t, 3)\n",
    "            s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "            t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "            \n",
    "            #add all forward (initial relation)\n",
    "            for i in range(len(id2relation)):\n",
    "\n",
    "                if i not in id2relation:\n",
    "\n",
    "                    raise ValueError ('error when generating id2relation')\n",
    "                    \n",
    "                if i % 2 == 0:\n",
    "\n",
    "                    #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "                    list_s_1.append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "                    list_s_2.append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "                    list_s_3.append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "                    \n",
    "                    list_t_1.append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "                    list_t_2.append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "                    list_t_3.append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "                    \n",
    "                    list_r.append([i])\n",
    "                \n",
    "            #change to arrays\n",
    "            input_s_1 = np.array(list_s_1)\n",
    "            input_s_2 = np.array(list_s_2)\n",
    "            input_s_3 = np.array(list_s_3)\n",
    "            input_t_1 = np.array(list_t_1)\n",
    "            input_t_2 = np.array(list_t_2)\n",
    "            input_t_3 = np.array(list_t_3)\n",
    "            input_r = np.array(list_r)\n",
    "            \n",
    "            pred = model_2.predict([input_s_1, input_s_2, input_s_3,\n",
    "                                    input_t_1, input_t_2, input_t_3, input_r], verbose = 0)\n",
    "\n",
    "            for i in range(pred.shape[0]):\n",
    "                #need to times 2 to go back to relation id from pred position\n",
    "                score_dict[2*i] += float(pred[i])\n",
    "                count_dict[2*i] += 1\n",
    "\n",
    "            count += 1\n",
    "            \n",
    "    #average the score\n",
    "    for r in score_dict:\n",
    "        score_dict[r] = deepcopy(score_dict[r]/float(count_dict[r]))\n",
    "            \n",
    "    print(len(score_dict), len(path_s), len(path_t))\n",
    "        \n",
    "    return(score_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "26015662",
   "metadata": {},
   "outputs": [],
   "source": [
    "#subgraph based triple scoring\n",
    "def subgraph_triple_scoring(s, r, t, lower_bd, upper_bd, one_hop, id2relation, model_2):\n",
    "    \n",
    "    path_s, path_t = set(), set() #sets holding all the paths from s or t\n",
    "    \n",
    "    for iteration in range(3):\n",
    "    \n",
    "        #obtain the paths out from s or t by \"any target\" mode. That is, \n",
    "        result_s, length_dict_s = Class_2.obtain_paths('any_target', s, 'any', lower_bd, upper_bd, one_hop)\n",
    "        result_t, length_dict_t = Class_2.obtain_paths('any_target', t, 'any', lower_bd, upper_bd, one_hop)\n",
    "\n",
    "        #add paths to the source/target path_set\n",
    "        for e in result_s:\n",
    "            for path in result_s[e]:\n",
    "                path_s.add(path)\n",
    "        for e in result_t:\n",
    "            for path in result_t[e]:\n",
    "                path_t.add(path)\n",
    "                \n",
    "        del(result_s, length_dict_s, result_t, length_dict_t)\n",
    "    \n",
    "    #final output: the score dict\n",
    "    score = 0.\n",
    "    \n",
    "    #see if both path_s and path_t have at least three paths\n",
    "    if len(path_s) >= 3 and len(path_t) >= 3:\n",
    "\n",
    "        #change to lists\n",
    "        path_s, path_t = list(path_s), list(path_t)\n",
    "        \n",
    "        #lists holding the input to the network\n",
    "        list_s_1 = list()\n",
    "        list_s_2 = list()\n",
    "        list_s_3 = list()\n",
    "        list_t_1 = list()\n",
    "        list_t_2 = list()\n",
    "        list_t_3 = list()\n",
    "        list_r = list()\n",
    "        \n",
    "        count = 0\n",
    "        while count < 10:\n",
    "\n",
    "            #randomly obtain three paths\n",
    "            temp_s = random.sample(path_s, 3)\n",
    "            temp_t = random.sample(path_t, 3)\n",
    "            s_p_1, s_p_2, s_p_3 = temp_s[0], temp_s[1], temp_s[2]\n",
    "            t_p_1, t_p_2, t_p_3 = temp_t[0], temp_t[1], temp_t[2]\n",
    "\n",
    "            #append the paths: note that we add the space holder id at the end of the shorter path\n",
    "            list_s_1.append(list(s_p_1) + [num_r]*abs(len(s_p_1)-upper_bd))\n",
    "            list_s_2.append(list(s_p_2) + [num_r]*abs(len(s_p_2)-upper_bd))\n",
    "            list_s_3.append(list(s_p_3) + [num_r]*abs(len(s_p_3)-upper_bd))\n",
    "\n",
    "            list_t_1.append(list(t_p_1) + [num_r]*abs(len(t_p_1)-upper_bd))\n",
    "            list_t_2.append(list(t_p_2) + [num_r]*abs(len(t_p_2)-upper_bd))\n",
    "            list_t_3.append(list(t_p_3) + [num_r]*abs(len(t_p_3)-upper_bd))\n",
    "\n",
    "            list_r.append([r])\n",
    "            count += 1\n",
    "                \n",
    "        #change to arrays\n",
    "        input_s_1 = np.array(list_s_1)\n",
    "        input_s_2 = np.array(list_s_2)\n",
    "        input_s_3 = np.array(list_s_3)\n",
    "        input_t_1 = np.array(list_t_1)\n",
    "        input_t_2 = np.array(list_t_2)\n",
    "        input_t_3 = np.array(list_t_3)\n",
    "        input_r = np.array(list_r)\n",
    "\n",
    "        pred = model_2.predict([input_s_1, input_s_2, input_s_3,\n",
    "                                input_t_1, input_t_2, input_t_3, input_r], verbose = 0)\n",
    "\n",
    "        for i in range(pred.shape[0]):\n",
    "            score += float(pred[i])\n",
    "\n",
    "        #average the score\n",
    "        score = score/float(count)\n",
    "        \n",
    "    return(score)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0b602d8d",
   "metadata": {},
   "source": [
    "#### Not fine tuned "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "cb84dd20",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 302 1008\n",
      "checkcorrect 50 50 real score 1.7894456446170808 Hits@1 0.0 Hits@3 1.0 Hits@10 1.0 MRR 0.5 cur_rank 1 abs_cur_rank 1 total_num 0 865\n",
      "215 141\n",
      "215 32 292\n",
      "checkcorrect 92 92 real score 1.8012258470058442 Hits@1 0.5 Hits@3 1.0 Hits@10 1.0 MRR 0.75 cur_rank 0 abs_cur_rank 0 total_num 1 865\n",
      "215 14\n",
      "215 119 190\n",
      "checkcorrect 310 310 real score 1.7763434827327726 Hits@1 0.3333333333333333 Hits@3 1.0 Hits@10 1.0 MRR 0.6666666666666666 cur_rank 1 abs_cur_rank 2 total_num 2 865\n",
      "215 150\n",
      "215 530 432\n",
      "checkcorrect 56 56 real score 1.777762770652771 Hits@1 0.25 Hits@3 1.0 Hits@10 1.0 MRR 0.625 cur_rank 1 abs_cur_rank 1 total_num 3 865\n",
      "215 119\n",
      "215 64 142\n",
      "checkcorrect 276 276 real score 1.3644370466470717 Hits@1 0.4 Hits@3 1.0 Hits@10 1.0 MRR 0.7 cur_rank 0 abs_cur_rank 0 total_num 4 865\n",
      "215 150\n",
      "215 344 845\n",
      "checkcorrect 56 56 real score 1.7981335461139678 Hits@1 0.3333333333333333 Hits@3 1.0 Hits@10 1.0 MRR 0.6666666666666666 cur_rank 1 abs_cur_rank 1 total_num 5 865\n",
      "215 150\n",
      "215 500 582\n",
      "checkcorrect 302 302 real score 1.7037342250347138 Hits@1 0.2857142857142857 Hits@3 1.0 Hits@10 1.0 MRR 0.619047619047619 cur_rank 2 abs_cur_rank 2 total_num 6 865\n",
      "215 150\n",
      "215 12 142\n",
      "checkcorrect 276 276 real score 1.916477918624878 Hits@1 0.375 Hits@3 1.0 Hits@10 1.0 MRR 0.6666666666666666 cur_rank 0 abs_cur_rank 0 total_num 7 865\n",
      "215 139\n",
      "215 34 292\n",
      "checkcorrect 92 92 real score 1.896305686235428 Hits@1 0.4444444444444444 Hits@3 1.0 Hits@10 1.0 MRR 0.7037037037037037 cur_rank 0 abs_cur_rank 0 total_num 8 865\n",
      "215 150\n",
      "215 364 749\n",
      "checkcorrect 54 54 real score 1.895988655090332 Hits@1 0.5 Hits@3 1.0 Hits@10 1.0 MRR 0.7333333333333333 cur_rank 0 abs_cur_rank 0 total_num 9 865\n",
      "215 150\n",
      "215 4 705\n",
      "checkcorrect 4 4 real score 1.747389483451843 Hits@1 0.5454545454545454 Hits@3 1.0 Hits@10 1.0 MRR 0.7575757575757575 cur_rank 0 abs_cur_rank 0 total_num 10 865\n",
      "215 101\n",
      "215 21 586\n",
      "checkcorrect 326 326 real score 1.2757138907909393 Hits@1 0.5 Hits@3 0.9166666666666666 Hits@10 1.0 MRR 0.7083333333333331 cur_rank 5 abs_cur_rank 5 total_num 11 865\n",
      "215 150\n",
      "215 762 653\n",
      "checkcorrect 16 16 real score 1.9123742103576662 Hits@1 0.5384615384615384 Hits@3 0.9230769230769231 Hits@10 1.0 MRR 0.7307692307692306 cur_rank 0 abs_cur_rank 0 total_num 12 865\n",
      "215 150\n",
      "215 182 832\n",
      "checkcorrect 56 56 real score 1.9505273222923278 Hits@1 0.5714285714285714 Hits@3 0.9285714285714286 Hits@10 1.0 MRR 0.7499999999999999 cur_rank 0 abs_cur_rank 0 total_num 13 865\n",
      "215 148\n",
      "215 13 293\n",
      "checkcorrect 92 92 real score 1.8679488003253937 Hits@1 0.6 Hits@3 0.9333333333333333 Hits@10 1.0 MRR 0.7666666666666665 cur_rank 0 abs_cur_rank 0 total_num 14 865\n",
      "215 150\n",
      "215 157 304\n",
      "checkcorrect 10 10 real score 1.8634221613407136 Hits@1 0.625 Hits@3 0.9375 Hits@10 1.0 MRR 0.7812499999999999 cur_rank 0 abs_cur_rank 0 total_num 15 865\n",
      "215 150\n",
      "215 966 623\n",
      "checkcorrect 16 16 real score 1.961677885055542 Hits@1 0.6470588235294118 Hits@3 0.9411764705882353 Hits@10 1.0 MRR 0.7941176470588234 cur_rank 0 abs_cur_rank 0 total_num 16 865\n",
      "215 105\n",
      "215 415 524\n",
      "checkcorrect 10 10 real score 0.741739738045726 Hits@1 0.6111111111111112 Hits@3 0.8888888888888888 Hits@10 1.0 MRR 0.7579365079365078 cur_rank 6 abs_cur_rank 6 total_num 17 865\n",
      "215 3\n",
      "215 57 45\n",
      "checkcorrect 378 378 real score 1.5372397124767303 Hits@1 0.5789473684210527 Hits@3 0.8421052631578947 Hits@10 1.0 MRR 0.7312030075187969 cur_rank 3 abs_cur_rank 3 total_num 18 865\n",
      "215 150\n",
      "215 119 692\n",
      "checkcorrect 88 88 real score 1.9261290669441222 Hits@1 0.6 Hits@3 0.85 Hits@10 1.0 MRR 0.744642857142857 cur_rank 0 abs_cur_rank 0 total_num 19 865\n",
      "215 133\n",
      "215 609 314\n",
      "checkcorrect 16 16 real score 1.8915634393692016 Hits@1 0.6190476190476191 Hits@3 0.8571428571428571 Hits@10 1.0 MRR 0.7568027210884353 cur_rank 0 abs_cur_rank 0 total_num 20 865\n",
      "215 150\n",
      "215 238 936\n",
      "checkcorrect 20 20 real score 1.953542959690094 Hits@1 0.6363636363636364 Hits@3 0.8636363636363636 Hits@10 1.0 MRR 0.7678571428571427 cur_rank 0 abs_cur_rank 0 total_num 21 865\n",
      "0 0\n",
      "215 919 218\n",
      "checkcorrect 120 120 real score 0.919727623462677 Hits@1 0.6521739130434783 Hits@3 0.8695652173913043 Hits@10 1.0 MRR 0.777950310559006 cur_rank 0 abs_cur_rank 0 total_num 22 865\n",
      "215 150\n",
      "215 353 749\n",
      "checkcorrect 4 4 real score 1.8670831441879272 Hits@1 0.6666666666666666 Hits@3 0.875 Hits@10 1.0 MRR 0.7872023809523808 cur_rank 0 abs_cur_rank 0 total_num 23 865\n",
      "215 69\n",
      "215 650 125\n",
      "checkcorrect 44 44 real score 1.832058769464493 Hits@1 0.68 Hits@3 0.88 Hits@10 1.0 MRR 0.7957142857142856 cur_rank 0 abs_cur_rank 0 total_num 24 865\n",
      "215 150\n",
      "215 169 419\n",
      "checkcorrect 26 26 real score 1.954633039236069 Hits@1 0.6923076923076923 Hits@3 0.8846153846153846 Hits@10 1.0 MRR 0.8035714285714284 cur_rank 0 abs_cur_rank 0 total_num 25 865\n",
      "215 19\n",
      "215 763 54\n",
      "checkcorrect 2 2 real score 1.0154256379930302 Hits@1 0.7037037037037037 Hits@3 0.8888888888888888 Hits@10 1.0 MRR 0.8108465608465607 cur_rank 0 abs_cur_rank 0 total_num 26 865\n",
      "215 150\n",
      "215 158 210\n",
      "checkcorrect 118 118 real score 1.9119438171386718 Hits@1 0.7142857142857143 Hits@3 0.8928571428571429 Hits@10 1.0 MRR 0.8176020408163264 cur_rank 0 abs_cur_rank 0 total_num 27 865\n",
      "215 53\n",
      "215 233 150\n",
      "checkcorrect 46 46 real score 1.763068687915802 Hits@1 0.6896551724137931 Hits@3 0.896551724137931 Hits@10 1.0 MRR 0.8066502463054186 cur_rank 1 abs_cur_rank 1 total_num 28 865\n",
      "215 150\n",
      "215 142 202\n",
      "checkcorrect 178 178 real score 1.936224925518036 Hits@1 0.6666666666666666 Hits@3 0.9 Hits@10 1.0 MRR 0.7964285714285713 cur_rank 1 abs_cur_rank 2 total_num 29 865\n",
      "215 150\n",
      "215 569 516\n",
      "checkcorrect 24 24 real score 1.846291109919548 Hits@1 0.6451612903225806 Hits@3 0.9032258064516129 Hits@10 1.0 MRR 0.7868663594470044 cur_rank 1 abs_cur_rank 1 total_num 30 865\n",
      "215 150\n",
      "215 433 249\n",
      "checkcorrect 348 348 real score 1.8544991791248322 Hits@1 0.65625 Hits@3 0.90625 Hits@10 1.0 MRR 0.7935267857142856 cur_rank 0 abs_cur_rank 0 total_num 31 865\n",
      "215 146\n",
      "215 46 212\n",
      "checkcorrect 108 108 real score 1.742963057756424 Hits@1 0.6666666666666666 Hits@3 0.9090909090909091 Hits@10 1.0 MRR 0.7997835497835497 cur_rank 0 abs_cur_rank 0 total_num 32 865\n",
      "215 136\n",
      "215 46 100\n",
      "checkcorrect 344 344 real score 1.8784488022327421 Hits@1 0.6764705882352942 Hits@3 0.9117647058823529 Hits@10 1.0 MRR 0.8056722689075629 cur_rank 0 abs_cur_rank 0 total_num 33 865\n",
      "215 150\n",
      "215 338 994\n",
      "checkcorrect 24 24 real score 1.9343267261981965 Hits@1 0.6857142857142857 Hits@3 0.9142857142857143 Hits@10 1.0 MRR 0.8112244897959182 cur_rank 0 abs_cur_rank 0 total_num 34 865\n",
      "215 150\n",
      "215 621 403\n",
      "checkcorrect 50 50 real score 1.9362237095832824 Hits@1 0.6944444444444444 Hits@3 0.9166666666666666 Hits@10 1.0 MRR 0.8164682539682538 cur_rank 0 abs_cur_rank 0 total_num 35 865\n",
      "215 150\n",
      "215 323 264\n",
      "checkcorrect 56 56 real score 1.9321700364351273 Hits@1 0.7027027027027027 Hits@3 0.918918918918919 Hits@10 1.0 MRR 0.8214285714285713 cur_rank 0 abs_cur_rank 0 total_num 36 865\n",
      "215 67\n",
      "215 631 259\n",
      "checkcorrect 86 86 real score 1.7675089299678803 Hits@1 0.6842105263157895 Hits@3 0.9210526315789473 Hits@10 1.0 MRR 0.81296992481203 cur_rank 1 abs_cur_rank 1 total_num 37 865\n",
      "215 108\n",
      "215 180 225\n",
      "checkcorrect 332 332 real score 0.38548676231876017 Hits@1 0.6666666666666666 Hits@3 0.8974358974358975 Hits@10 1.0 MRR 0.7953296703296703 cur_rank 7 abs_cur_rank 7 total_num 38 865\n",
      "215 150\n",
      "215 1514 457\n",
      "checkcorrect 50 50 real score 1.763850349187851 Hits@1 0.65 Hits@3 0.9 Hits@10 1.0 MRR 0.7879464285714285 cur_rank 1 abs_cur_rank 1 total_num 39 865\n",
      "215 118\n",
      "215 489 158\n",
      "checkcorrect 366 366 real score 1.659888780117035 Hits@1 0.6341463414634146 Hits@3 0.8780487804878049 Hits@10 1.0 MRR 0.7717770034843204 cur_rank 7 abs_cur_rank 7 total_num 40 865\n",
      "215 150\n",
      "215 647 172\n",
      "checkcorrect 346 346 real score 1.8731402873992922 Hits@1 0.6428571428571429 Hits@3 0.8809523809523809 Hits@10 1.0 MRR 0.7772108843537414 cur_rank 0 abs_cur_rank 0 total_num 41 865\n",
      "215 5\n",
      "215 14 5\n",
      "checkcorrect 144 144 real score 1.8823418021202087 Hits@1 0.6511627906976745 Hits@3 0.8837209302325582 Hits@10 1.0 MRR 0.7823920265780729 cur_rank 0 abs_cur_rank 0 total_num 42 865\n",
      "0 1\n",
      "215 60 3\n",
      "checkcorrect 100 100 real score 0.8281217277050018 Hits@1 0.6590909090909091 Hits@3 0.8863636363636364 Hits@10 1.0 MRR 0.7873376623376622 cur_rank 0 abs_cur_rank 0 total_num 43 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 77 753\n",
      "checkcorrect 4 4 real score 1.8009914696216582 Hits@1 0.6666666666666666 Hits@3 0.8888888888888888 Hits@10 1.0 MRR 0.792063492063492 cur_rank 0 abs_cur_rank 0 total_num 44 865\n",
      "215 150\n",
      "215 471 702\n",
      "checkcorrect 176 176 real score 1.9655554294586182 Hits@1 0.6739130434782609 Hits@3 0.8913043478260869 Hits@10 1.0 MRR 0.7965838509316769 cur_rank 0 abs_cur_rank 1 total_num 45 865\n",
      "215 150\n",
      "215 456 513\n",
      "checkcorrect 86 86 real score 1.6952210903167724 Hits@1 0.6595744680851063 Hits@3 0.8723404255319149 Hits@10 1.0 MRR 0.7849544072948328 cur_rank 3 abs_cur_rank 3 total_num 46 865\n",
      "215 56\n",
      "215 256 319\n",
      "checkcorrect 46 46 real score 1.8820106565952301 Hits@1 0.6666666666666666 Hits@3 0.875 Hits@10 1.0 MRR 0.7894345238095237 cur_rank 0 abs_cur_rank 0 total_num 47 865\n",
      "215 150\n",
      "215 609 979\n",
      "checkcorrect 34 34 real score 1.8149343311786652 Hits@1 0.673469387755102 Hits@3 0.8775510204081632 Hits@10 1.0 MRR 0.7937317784256559 cur_rank 0 abs_cur_rank 1 total_num 48 865\n",
      "215 138\n",
      "215 528 221\n",
      "checkcorrect 16 16 real score 1.9676702201366425 Hits@1 0.68 Hits@3 0.88 Hits@10 1.0 MRR 0.7978571428571428 cur_rank 0 abs_cur_rank 0 total_num 49 865\n",
      "0 0\n",
      "0 1 41\n",
      "checkcorrect 40 40 real score 0.0 Hits@1 0.6666666666666666 Hits@3 0.8627450980392157 Hits@10 0.9803921568627451 MRR 0.7831465919701214 cur_rank 20 abs_cur_rank 20 total_num 50 865\n",
      "215 150\n",
      "215 452 441\n",
      "checkcorrect 56 56 real score 1.9240764319896697 Hits@1 0.6730769230769231 Hits@3 0.8653846153846154 Hits@10 0.9807692307692307 MRR 0.7873168498168498 cur_rank 0 abs_cur_rank 0 total_num 51 865\n",
      "215 91\n",
      "215 114 196\n",
      "checkcorrect 100 100 real score 1.793263041973114 Hits@1 0.6792452830188679 Hits@3 0.8679245283018868 Hits@10 0.9811320754716981 MRR 0.7913297394429469 cur_rank 0 abs_cur_rank 0 total_num 52 865\n",
      "215 150\n",
      "215 262 1595\n",
      "checkcorrect 56 56 real score 1.1606595567427576 Hits@1 0.6666666666666666 Hits@3 0.8703703703703703 Hits@10 0.9814814814814815 MRR 0.7859347442680776 cur_rank 1 abs_cur_rank 2 total_num 53 865\n",
      "215 150\n",
      "215 97 961\n",
      "checkcorrect 54 54 real score 1.9283156216144561 Hits@1 0.6727272727272727 Hits@3 0.8727272727272727 Hits@10 0.9818181818181818 MRR 0.7898268398268398 cur_rank 0 abs_cur_rank 0 total_num 54 865\n",
      "215 135\n",
      "215 855 340\n",
      "checkcorrect 2 2 real score 1.8763435781002045 Hits@1 0.6785714285714286 Hits@3 0.875 Hits@10 0.9821428571428571 MRR 0.7935799319727891 cur_rank 0 abs_cur_rank 0 total_num 55 865\n",
      "215 150\n",
      "215 301 432\n",
      "checkcorrect 264 264 real score 1.578369414806366 Hits@1 0.6666666666666666 Hits@3 0.8596491228070176 Hits@10 0.9824561403508771 MRR 0.7831662489557227 cur_rank 4 abs_cur_rank 4 total_num 56 865\n",
      "215 150\n",
      "215 528 702\n",
      "checkcorrect 128 128 real score 1.7954356908798217 Hits@1 0.6724137931034483 Hits@3 0.8620689655172413 Hits@10 0.9827586206896551 MRR 0.786904761904762 cur_rank 0 abs_cur_rank 0 total_num 57 865\n",
      "215 31\n",
      "215 280 235\n",
      "checkcorrect 172 172 real score 1.5421923309564591 Hits@1 0.6779661016949152 Hits@3 0.864406779661017 Hits@10 0.9830508474576272 MRR 0.7905165456012914 cur_rank 0 abs_cur_rank 0 total_num 58 865\n",
      "215 150\n",
      "215 63 691\n",
      "checkcorrect 54 54 real score 1.965291839838028 Hits@1 0.6833333333333333 Hits@3 0.8666666666666667 Hits@10 0.9833333333333333 MRR 0.7940079365079366 cur_rank 0 abs_cur_rank 0 total_num 59 865\n",
      "215 150\n",
      "215 543 463\n",
      "checkcorrect 50 50 real score 1.8867846101522445 Hits@1 0.6885245901639344 Hits@3 0.8688524590163934 Hits@10 0.9836065573770492 MRR 0.7973848555815769 cur_rank 0 abs_cur_rank 1 total_num 60 865\n",
      "215 150\n",
      "215 209 850\n",
      "checkcorrect 56 56 real score 1.9385201990604402 Hits@1 0.6935483870967742 Hits@3 0.8709677419354839 Hits@10 0.9838709677419355 MRR 0.8006528417818741 cur_rank 0 abs_cur_rank 0 total_num 61 865\n",
      "215 150\n",
      "215 481 575\n",
      "checkcorrect 50 50 real score 1.921141016483307 Hits@1 0.6984126984126984 Hits@3 0.873015873015873 Hits@10 0.9841269841269841 MRR 0.803817082388511 cur_rank 0 abs_cur_rank 0 total_num 62 865\n",
      "215 150\n",
      "215 200 402\n",
      "checkcorrect 20 20 real score 1.8364237666130065 Hits@1 0.703125 Hits@3 0.875 Hits@10 0.984375 MRR 0.8068824404761905 cur_rank 0 abs_cur_rank 0 total_num 63 865\n",
      "215 122\n",
      "215 335 351\n",
      "checkcorrect 238 238 real score 0.4758875221014023 Hits@1 0.6923076923076923 Hits@3 0.8615384615384616 Hits@10 0.9846153846153847 MRR 0.796007326007326 cur_rank 9 abs_cur_rank 11 total_num 64 865\n",
      "215 78\n",
      "215 65 97\n",
      "checkcorrect 20 20 real score 1.759197673201561 Hits@1 0.696969696969697 Hits@3 0.8636363636363636 Hits@10 0.9848484848484849 MRR 0.7990981240981242 cur_rank 0 abs_cur_rank 0 total_num 65 865\n",
      "215 150\n",
      "215 21 780\n",
      "checkcorrect 54 54 real score 1.8875037670135497 Hits@1 0.7014925373134329 Hits@3 0.8656716417910447 Hits@10 0.9850746268656716 MRR 0.8020966595593462 cur_rank 0 abs_cur_rank 0 total_num 66 865\n",
      "215 150\n",
      "215 472 228\n",
      "checkcorrect 20 20 real score 1.9100989699363708 Hits@1 0.7058823529411765 Hits@3 0.8676470588235294 Hits@10 0.9852941176470589 MRR 0.8050070028011205 cur_rank 0 abs_cur_rank 0 total_num 67 865\n",
      "215 16\n",
      "215 143 100\n",
      "checkcorrect 44 44 real score 1.7979171991348268 Hits@1 0.7101449275362319 Hits@3 0.8695652173913043 Hits@10 0.9855072463768116 MRR 0.807832988267771 cur_rank 0 abs_cur_rank 0 total_num 68 865\n",
      "215 100\n",
      "215 163 204\n",
      "checkcorrect 62 62 real score 1.7866889357566833 Hits@1 0.7142857142857143 Hits@3 0.8714285714285714 Hits@10 0.9857142857142858 MRR 0.810578231292517 cur_rank 0 abs_cur_rank 0 total_num 69 865\n",
      "215 57\n",
      "215 468 37\n",
      "checkcorrect 120 120 real score 1.698589065670967 Hits@1 0.7183098591549296 Hits@3 0.8732394366197183 Hits@10 0.9859154929577465 MRR 0.8132461435278338 cur_rank 0 abs_cur_rank 0 total_num 70 865\n",
      "215 150\n",
      "215 149 298\n",
      "checkcorrect 218 218 real score 1.7914217170327902 Hits@1 0.7222222222222222 Hits@3 0.875 Hits@10 0.9861111111111112 MRR 0.8158399470899471 cur_rank 0 abs_cur_rank 0 total_num 71 865\n",
      "215 95\n",
      "215 137 122\n",
      "checkcorrect 172 172 real score 1.851441240310669 Hits@1 0.726027397260274 Hits@3 0.8767123287671232 Hits@10 0.9863013698630136 MRR 0.8183626875407698 cur_rank 0 abs_cur_rank 0 total_num 72 865\n",
      "215 140\n",
      "215 96 204\n",
      "checkcorrect 344 344 real score 1.8490833699703217 Hits@1 0.7297297297297297 Hits@3 0.8783783783783784 Hits@10 0.9864864864864865 MRR 0.8208172458172459 cur_rank 0 abs_cur_rank 0 total_num 73 865\n",
      "215 146\n",
      "215 552 355\n",
      "checkcorrect 20 20 real score 1.9144632816314697 Hits@1 0.7333333333333333 Hits@3 0.88 Hits@10 0.9866666666666667 MRR 0.8232063492063493 cur_rank 0 abs_cur_rank 0 total_num 74 865\n",
      "215 16\n",
      "215 48 118\n",
      "checkcorrect 380 380 real score 1.1355500042438507 Hits@1 0.7236842105263158 Hits@3 0.868421052631579 Hits@10 0.9868421052631579 MRR 0.8145676691729323 cur_rank 5 abs_cur_rank 6 total_num 75 865\n",
      "0 1\n",
      "215 121 21\n",
      "checkcorrect 72 72 real score 0.8188933193683624 Hits@1 0.7142857142857143 Hits@3 0.8701298701298701 Hits@10 0.987012987012987 MRR 0.810482374768089 cur_rank 1 abs_cur_rank 2 total_num 76 865\n",
      "215 148\n",
      "215 483 296\n",
      "checkcorrect 172 172 real score 1.770750242471695 Hits@1 0.717948717948718 Hits@3 0.8717948717948718 Hits@10 0.9871794871794872 MRR 0.8129120879120879 cur_rank 0 abs_cur_rank 0 total_num 77 865\n",
      "215 128\n",
      "215 332 150\n",
      "checkcorrect 20 20 real score 1.8892392337322237 Hits@1 0.7215189873417721 Hits@3 0.8734177215189873 Hits@10 0.9873417721518988 MRR 0.8152802893309222 cur_rank 0 abs_cur_rank 0 total_num 78 865\n",
      "0 2\n",
      "215 130 20\n",
      "checkcorrect 284 284 real score 0.7282936096191406 Hits@1 0.725 Hits@3 0.875 Hits@10 0.9875 MRR 0.8175892857142857 cur_rank 0 abs_cur_rank 0 total_num 79 865\n",
      "215 150\n",
      "215 677 568\n",
      "checkcorrect 24 24 real score 1.9385898113250732 Hits@1 0.7283950617283951 Hits@3 0.8765432098765432 Hits@10 0.9876543209876543 MRR 0.8198412698412698 cur_rank 0 abs_cur_rank 1 total_num 80 865\n",
      "215 43\n",
      "215 123 89\n",
      "checkcorrect 50 50 real score 1.6291941821575167 Hits@1 0.7317073170731707 Hits@3 0.8780487804878049 Hits@10 0.9878048780487805 MRR 0.8220383275261324 cur_rank 0 abs_cur_rank 0 total_num 81 865\n",
      "215 71\n",
      "215 138 191\n",
      "checkcorrect 96 96 real score 1.7854257106781004 Hits@1 0.7349397590361446 Hits@3 0.8795180722891566 Hits@10 0.9879518072289156 MRR 0.8241824440619622 cur_rank 0 abs_cur_rank 0 total_num 82 865\n",
      "215 116\n",
      "215 119 646\n",
      "checkcorrect 54 54 real score 1.952307665348053 Hits@1 0.7380952380952381 Hits@3 0.8809523809523809 Hits@10 0.9880952380952381 MRR 0.8262755102040816 cur_rank 0 abs_cur_rank 0 total_num 83 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 86\n",
      "215 316 155\n",
      "checkcorrect 114 114 real score 1.9597935736179353 Hits@1 0.7411764705882353 Hits@3 0.8823529411764706 Hits@10 0.9882352941176471 MRR 0.8283193277310924 cur_rank 0 abs_cur_rank 0 total_num 84 865\n",
      "215 150\n",
      "215 170 294\n",
      "checkcorrect 316 316 real score 1.8426802337169645 Hits@1 0.7441860465116279 Hits@3 0.8837209302325582 Hits@10 0.9883720930232558 MRR 0.8303156146179402 cur_rank 0 abs_cur_rank 0 total_num 85 865\n",
      "215 85\n",
      "215 397 158\n",
      "checkcorrect 366 366 real score 1.7343024134635925 Hits@1 0.735632183908046 Hits@3 0.8850574712643678 Hits@10 0.9885057471264368 MRR 0.8246031746031746 cur_rank 2 abs_cur_rank 2 total_num 86 865\n",
      "215 125\n",
      "215 361 427\n",
      "checkcorrect 50 50 real score 1.9319658637046815 Hits@1 0.7386363636363636 Hits@3 0.8863636363636364 Hits@10 0.9886363636363636 MRR 0.8265963203463204 cur_rank 0 abs_cur_rank 0 total_num 87 865\n",
      "215 145\n",
      "215 360 377\n",
      "checkcorrect 44 44 real score 1.8615835547447204 Hits@1 0.7415730337078652 Hits@3 0.8876404494382022 Hits@10 0.9887640449438202 MRR 0.8285446762974853 cur_rank 0 abs_cur_rank 0 total_num 88 865\n",
      "215 79\n",
      "215 73 221\n",
      "checkcorrect 2 2 real score 1.5317366003990174 Hits@1 0.7444444444444445 Hits@3 0.8888888888888888 Hits@10 0.9888888888888889 MRR 0.8304497354497354 cur_rank 0 abs_cur_rank 0 total_num 89 865\n",
      "215 3\n",
      "215 467 286\n",
      "checkcorrect 50 50 real score 1.663955956697464 Hits@1 0.7472527472527473 Hits@3 0.8901098901098901 Hits@10 0.989010989010989 MRR 0.8323129251700679 cur_rank 0 abs_cur_rank 1 total_num 90 865\n",
      "215 150\n",
      "215 206 156\n",
      "checkcorrect 118 118 real score 1.8611464858055116 Hits@1 0.75 Hits@3 0.8913043478260869 Hits@10 0.9891304347826086 MRR 0.8341356107660455 cur_rank 0 abs_cur_rank 0 total_num 91 865\n",
      "215 150\n",
      "215 889 511\n",
      "checkcorrect 50 50 real score 1.910960739850998 Hits@1 0.7526881720430108 Hits@3 0.8924731182795699 Hits@10 0.989247311827957 MRR 0.8359190988223246 cur_rank 0 abs_cur_rank 0 total_num 92 865\n",
      "215 134\n",
      "215 448 408\n",
      "checkcorrect 2 2 real score 1.7861068159341813 Hits@1 0.7553191489361702 Hits@3 0.8936170212765957 Hits@10 0.9893617021276596 MRR 0.8376646403242147 cur_rank 0 abs_cur_rank 0 total_num 93 865\n",
      "0 2\n",
      "215 32 14\n",
      "checkcorrect 198 198 real score 0.9919333338737488 Hits@1 0.7578947368421053 Hits@3 0.8947368421052632 Hits@10 0.9894736842105263 MRR 0.8393734335839599 cur_rank 0 abs_cur_rank 0 total_num 94 865\n",
      "215 150\n",
      "215 87 769\n",
      "checkcorrect 54 54 real score 1.8605306208133698 Hits@1 0.7604166666666666 Hits@3 0.8958333333333334 Hits@10 0.9895833333333334 MRR 0.8410466269841269 cur_rank 0 abs_cur_rank 0 total_num 95 865\n",
      "215 150\n",
      "215 104 711\n",
      "checkcorrect 4 4 real score 1.8915430903434753 Hits@1 0.7628865979381443 Hits@3 0.8969072164948454 Hits@10 0.9896907216494846 MRR 0.8426853215513009 cur_rank 0 abs_cur_rank 0 total_num 96 865\n",
      "215 30\n",
      "215 51 180\n",
      "checkcorrect 54 54 real score 1.8335428595542909 Hits@1 0.7653061224489796 Hits@3 0.8979591836734694 Hits@10 0.9897959183673469 MRR 0.844290573372206 cur_rank 0 abs_cur_rank 0 total_num 97 865\n",
      "215 122\n",
      "215 336 357\n",
      "checkcorrect 24 24 real score 1.8507593393325805 Hits@1 0.7676767676767676 Hits@3 0.898989898989899 Hits@10 0.98989898989899 MRR 0.8458633958633959 cur_rank 0 abs_cur_rank 1 total_num 98 865\n",
      "215 150\n",
      "215 862 893\n",
      "checkcorrect 50 50 real score 1.8629201591014861 Hits@1 0.77 Hits@3 0.9 Hits@10 0.99 MRR 0.8474047619047619 cur_rank 0 abs_cur_rank 0 total_num 99 865\n",
      "215 150\n",
      "215 405 747\n",
      "checkcorrect 4 4 real score 1.8773805677890776 Hits@1 0.7722772277227723 Hits@3 0.900990099009901 Hits@10 0.9900990099009901 MRR 0.8489156058462989 cur_rank 0 abs_cur_rank 0 total_num 100 865\n",
      "0 1\n",
      "215 40 5\n",
      "checkcorrect 206 206 real score 0.3296369224786758 Hits@1 0.7647058823529411 Hits@3 0.8921568627450981 Hits@10 0.9803921568627451 MRR 0.8412931839402427 cur_rank 13 abs_cur_rank 13 total_num 101 865\n",
      "0 2\n",
      "215 95 95\n",
      "checkcorrect 192 192 real score 0.7019231855869293 Hits@1 0.7572815533980582 Hits@3 0.883495145631068 Hits@10 0.9805825242718447 MRR 0.8347434119278779 cur_rank 5 abs_cur_rank 6 total_num 102 865\n",
      "215 47\n",
      "215 419 88\n",
      "checkcorrect 60 60 real score 1.8408165156841276 Hits@1 0.7596153846153846 Hits@3 0.8846153846153846 Hits@10 0.9807692307692307 MRR 0.8363324175824176 cur_rank 0 abs_cur_rank 0 total_num 103 865\n",
      "215 150\n",
      "215 39 426\n",
      "checkcorrect 56 56 real score 1.858911293745041 Hits@1 0.7619047619047619 Hits@3 0.8857142857142857 Hits@10 0.9809523809523809 MRR 0.837891156462585 cur_rank 0 abs_cur_rank 0 total_num 104 865\n",
      "215 85\n",
      "215 97 172\n",
      "checkcorrect 172 172 real score 1.6854138314723968 Hits@1 0.7641509433962265 Hits@3 0.8867924528301887 Hits@10 0.9811320754716981 MRR 0.8394204851752022 cur_rank 0 abs_cur_rank 0 total_num 105 865\n",
      "215 150\n",
      "215 410 333\n",
      "checkcorrect 132 132 real score 1.7051125168800354 Hits@1 0.7663551401869159 Hits@3 0.8878504672897196 Hits@10 0.9813084112149533 MRR 0.8409212283044059 cur_rank 0 abs_cur_rank 0 total_num 106 865\n",
      "215 150\n",
      "215 240 1465\n",
      "checkcorrect 236 236 real score 1.6362575590610504 Hits@1 0.7685185185185185 Hits@3 0.8888888888888888 Hits@10 0.9814814814814815 MRR 0.8423941798941799 cur_rank 0 abs_cur_rank 0 total_num 107 865\n",
      "215 150\n",
      "215 322 848\n",
      "checkcorrect 56 56 real score 1.88433780670166 Hits@1 0.7706422018348624 Hits@3 0.8899082568807339 Hits@10 0.981651376146789 MRR 0.8438401048492792 cur_rank 0 abs_cur_rank 0 total_num 108 865\n",
      "215 73\n",
      "215 154 196\n",
      "checkcorrect 168 168 real score 1.9204837560653685 Hits@1 0.7636363636363637 Hits@3 0.8909090909090909 Hits@10 0.9818181818181818 MRR 0.8407142857142857 cur_rank 1 abs_cur_rank 1 total_num 109 865\n",
      "0 1\n",
      "215 4 8\n",
      "checkcorrect 194 194 real score 0.8440417766571044 Hits@1 0.7657657657657657 Hits@3 0.8918918918918919 Hits@10 0.9819819819819819 MRR 0.8421492921492921 cur_rank 0 abs_cur_rank 1 total_num 110 865\n",
      "0 1\n",
      "215 92 17\n",
      "checkcorrect 58 58 real score 0.917335307598114 Hits@1 0.7678571428571429 Hits@3 0.8928571428571429 Hits@10 0.9821428571428571 MRR 0.8435586734693877 cur_rank 0 abs_cur_rank 0 total_num 111 865\n",
      "215 150\n",
      "215 104 816\n",
      "checkcorrect 8 8 real score 1.7063717484474181 Hits@1 0.7699115044247787 Hits@3 0.8938053097345132 Hits@10 0.9823008849557522 MRR 0.8449431099873578 cur_rank 0 abs_cur_rank 0 total_num 112 865\n",
      "215 68\n",
      "215 35 75\n",
      "checkcorrect 228 228 real score 1.7730939567089081 Hits@1 0.7719298245614035 Hits@3 0.8947368421052632 Hits@10 0.9824561403508771 MRR 0.8463032581453634 cur_rank 0 abs_cur_rank 0 total_num 113 865\n",
      "215 150\n",
      "215 344 809\n",
      "checkcorrect 54 54 real score 1.9114162802696226 Hits@1 0.7739130434782608 Hits@3 0.8956521739130435 Hits@10 0.9826086956521739 MRR 0.847639751552795 cur_rank 0 abs_cur_rank 0 total_num 114 865\n",
      "215 150\n",
      "215 768 1012\n",
      "checkcorrect 16 16 real score 1.9361904203891753 Hits@1 0.7758620689655172 Hits@3 0.896551724137931 Hits@10 0.9827586206896551 MRR 0.8489532019704433 cur_rank 0 abs_cur_rank 0 total_num 115 865\n",
      "215 150\n",
      "215 247 736\n",
      "checkcorrect 52 52 real score 1.926942092180252 Hits@1 0.7777777777777778 Hits@3 0.8974358974358975 Hits@10 0.9829059829059829 MRR 0.8502442002442002 cur_rank 0 abs_cur_rank 0 total_num 116 865\n",
      "215 150\n",
      "215 530 532\n",
      "checkcorrect 78 78 real score 1.9677572846412659 Hits@1 0.7796610169491526 Hits@3 0.8983050847457628 Hits@10 0.9830508474576272 MRR 0.8515133171912833 cur_rank 0 abs_cur_rank 0 total_num 117 865\n",
      "215 36\n",
      "215 56 56\n",
      "checkcorrect 30 30 real score 1.7774432182312012 Hits@1 0.7815126050420168 Hits@3 0.8991596638655462 Hits@10 0.9831932773109243 MRR 0.8527611044417767 cur_rank 0 abs_cur_rank 0 total_num 118 865\n",
      "215 150\n",
      "215 48 402\n",
      "checkcorrect 26 26 real score 1.9503543615341186 Hits@1 0.7833333333333333 Hits@3 0.9 Hits@10 0.9833333333333333 MRR 0.8539880952380953 cur_rank 0 abs_cur_rank 0 total_num 119 865\n",
      "215 150\n",
      "215 24 262\n",
      "checkcorrect 172 172 real score 1.8910415709018706 Hits@1 0.7851239669421488 Hits@3 0.9008264462809917 Hits@10 0.9834710743801653 MRR 0.8551948051948052 cur_rank 0 abs_cur_rank 0 total_num 120 865\n",
      "215 150\n",
      "215 890 421\n",
      "checkcorrect 46 46 real score 1.859857451915741 Hits@1 0.7868852459016393 Hits@3 0.9016393442622951 Hits@10 0.9836065573770492 MRR 0.8563817330210772 cur_rank 0 abs_cur_rank 1 total_num 121 865\n",
      "215 55\n",
      "215 40 73\n",
      "checkcorrect 364 364 real score 1.9062419712543488 Hits@1 0.7886178861788617 Hits@3 0.9024390243902439 Hits@10 0.983739837398374 MRR 0.8575493612078978 cur_rank 0 abs_cur_rank 0 total_num 122 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 472 296\n",
      "checkcorrect 56 56 real score 1.9536013424396517 Hits@1 0.7903225806451613 Hits@3 0.9032258064516129 Hits@10 0.9838709677419355 MRR 0.8586981566820276 cur_rank 0 abs_cur_rank 0 total_num 123 865\n",
      "215 148\n",
      "215 920 468\n",
      "checkcorrect 52 52 real score 1.927687519788742 Hits@1 0.792 Hits@3 0.904 Hits@10 0.984 MRR 0.8598285714285714 cur_rank 0 abs_cur_rank 0 total_num 124 865\n",
      "215 44\n",
      "215 73 19\n",
      "checkcorrect 110 110 real score 1.8959289729595183 Hits@1 0.7936507936507936 Hits@3 0.9047619047619048 Hits@10 0.9841269841269841 MRR 0.8609410430839002 cur_rank 0 abs_cur_rank 0 total_num 125 865\n",
      "215 109\n",
      "215 54 83\n",
      "checkcorrect 220 220 real score 1.9069584190845488 Hits@1 0.7952755905511811 Hits@3 0.905511811023622 Hits@10 0.984251968503937 MRR 0.8620359955005624 cur_rank 0 abs_cur_rank 0 total_num 126 865\n",
      "215 150\n",
      "215 617 813\n",
      "checkcorrect 54 54 real score 1.8492473006248473 Hits@1 0.796875 Hits@3 0.90625 Hits@10 0.984375 MRR 0.8631138392857143 cur_rank 0 abs_cur_rank 0 total_num 127 865\n",
      "215 15\n",
      "215 301 33\n",
      "checkcorrect 100 100 real score 1.885984492301941 Hits@1 0.7984496124031008 Hits@3 0.9069767441860465 Hits@10 0.9844961240310077 MRR 0.8641749723145072 cur_rank 0 abs_cur_rank 0 total_num 128 865\n",
      "0 1\n",
      "215 23 3\n",
      "checkcorrect 242 242 real score 0.9398778021335602 Hits@1 0.8 Hits@3 0.9076923076923077 Hits@10 0.9846153846153847 MRR 0.8652197802197802 cur_rank 0 abs_cur_rank 0 total_num 129 865\n",
      "215 101\n",
      "215 52 223\n",
      "checkcorrect 222 222 real score 1.9177730262279509 Hits@1 0.7938931297709924 Hits@3 0.9083969465648855 Hits@10 0.9847328244274809 MRR 0.8624318429661941 cur_rank 1 abs_cur_rank 1 total_num 130 865\n",
      "215 56\n",
      "215 325 406\n",
      "checkcorrect 10 10 real score 1.7860490083694458 Hits@1 0.7954545454545454 Hits@3 0.9090909090909091 Hits@10 0.9848484848484849 MRR 0.863474025974026 cur_rank 0 abs_cur_rank 0 total_num 131 865\n",
      "215 150\n",
      "215 69 857\n",
      "checkcorrect 408 408 real score 1.896966314315796 Hits@1 0.7969924812030075 Hits@3 0.9097744360902256 Hits@10 0.9849624060150376 MRR 0.864500537056928 cur_rank 0 abs_cur_rank 0 total_num 132 865\n",
      "215 150\n",
      "215 207 799\n",
      "checkcorrect 54 54 real score 1.8366947174072266 Hits@1 0.7985074626865671 Hits@3 0.9104477611940298 Hits@10 0.9850746268656716 MRR 0.8655117270788912 cur_rank 0 abs_cur_rank 0 total_num 133 865\n",
      "215 143\n",
      "215 394 302\n",
      "checkcorrect 172 172 real score 1.8158435344696044 Hits@1 0.8 Hits@3 0.9111111111111111 Hits@10 0.9851851851851852 MRR 0.8665079365079364 cur_rank 0 abs_cur_rank 0 total_num 134 865\n",
      "215 150\n",
      "215 505 601\n",
      "checkcorrect 24 24 real score 1.9380251228809358 Hits@1 0.7941176470588235 Hits@3 0.9117647058823529 Hits@10 0.9852941176470589 MRR 0.8638130252100841 cur_rank 1 abs_cur_rank 1 total_num 135 865\n",
      "215 150\n",
      "215 888 229\n",
      "checkcorrect 20 20 real score 1.9100542306900024 Hits@1 0.7956204379562044 Hits@3 0.9124087591240876 Hits@10 0.9854014598540146 MRR 0.8648070907194995 cur_rank 0 abs_cur_rank 0 total_num 136 865\n",
      "215 25\n",
      "215 72 80\n",
      "checkcorrect 30 30 real score 1.6445085644721984 Hits@1 0.7898550724637681 Hits@3 0.9130434782608695 Hits@10 0.9855072463768116 MRR 0.8621635610766045 cur_rank 1 abs_cur_rank 1 total_num 137 865\n",
      "215 66\n",
      "215 225 269\n",
      "checkcorrect 312 312 real score 1.595895344018936 Hits@1 0.7841726618705036 Hits@3 0.9136690647482014 Hits@10 0.9856115107913669 MRR 0.858359027064063 cur_rank 2 abs_cur_rank 3 total_num 138 865\n",
      "215 131\n",
      "215 4 856\n",
      "checkcorrect 54 54 real score 1.8512730538845061 Hits@1 0.7857142857142857 Hits@3 0.9142857142857143 Hits@10 0.9857142857142858 MRR 0.8593707482993197 cur_rank 0 abs_cur_rank 0 total_num 139 865\n",
      "215 113\n",
      "215 427 391\n",
      "checkcorrect 46 46 real score 1.628403639793396 Hits@1 0.7872340425531915 Hits@3 0.9148936170212766 Hits@10 0.9858156028368794 MRR 0.8603681188787571 cur_rank 0 abs_cur_rank 1 total_num 140 865\n",
      "215 128\n",
      "215 483 261\n",
      "checkcorrect 10 10 real score 1.79988152384758 Hits@1 0.7816901408450704 Hits@3 0.9154929577464789 Hits@10 0.9859154929577465 MRR 0.8566566063044936 cur_rank 2 abs_cur_rank 2 total_num 141 865\n",
      "215 150\n",
      "215 130 196\n",
      "checkcorrect 168 168 real score 1.9577277898788452 Hits@1 0.7762237762237763 Hits@3 0.916083916083916 Hits@10 0.986013986013986 MRR 0.854162504162504 cur_rank 1 abs_cur_rank 1 total_num 142 865\n",
      "215 107\n",
      "215 166 230\n",
      "checkcorrect 124 124 real score 1.9712028563022614 Hits@1 0.7777777777777778 Hits@3 0.9166666666666666 Hits@10 0.9861111111111112 MRR 0.8551752645502645 cur_rank 0 abs_cur_rank 0 total_num 143 865\n",
      "215 65\n",
      "215 192 50\n",
      "checkcorrect 172 172 real score 1.8227656900882723 Hits@1 0.7793103448275862 Hits@3 0.9172413793103448 Hits@10 0.9862068965517241 MRR 0.8561740558292281 cur_rank 0 abs_cur_rank 0 total_num 144 865\n",
      "215 126\n",
      "215 214 403\n",
      "checkcorrect 26 26 real score 1.958716642856598 Hits@1 0.7808219178082192 Hits@3 0.9178082191780822 Hits@10 0.9863013698630136 MRR 0.8571591650358773 cur_rank 0 abs_cur_rank 0 total_num 145 865\n",
      "215 35\n",
      "215 44 62\n",
      "checkcorrect 172 172 real score 1.6828493952751158 Hits@1 0.782312925170068 Hits@3 0.9183673469387755 Hits@10 0.9863945578231292 MRR 0.8581308713961775 cur_rank 0 abs_cur_rank 0 total_num 146 865\n",
      "215 150\n",
      "215 84 576\n",
      "checkcorrect 218 218 real score 1.944152480363846 Hits@1 0.7837837837837838 Hits@3 0.918918918918919 Hits@10 0.9864864864864865 MRR 0.8590894465894465 cur_rank 0 abs_cur_rank 0 total_num 147 865\n",
      "215 150\n",
      "215 111 907\n",
      "checkcorrect 54 54 real score 1.871260052919388 Hits@1 0.785234899328859 Hits@3 0.9194630872483222 Hits@10 0.9865771812080537 MRR 0.8600351550015979 cur_rank 0 abs_cur_rank 0 total_num 148 865\n",
      "215 150\n",
      "215 174 99\n",
      "checkcorrect 138 138 real score 1.9841756522655487 Hits@1 0.7866666666666666 Hits@3 0.92 Hits@10 0.9866666666666667 MRR 0.8609682539682539 cur_rank 0 abs_cur_rank 0 total_num 149 865\n",
      "215 126\n",
      "215 19 290\n",
      "checkcorrect 92 92 real score 1.805982232093811 Hits@1 0.7880794701986755 Hits@3 0.9205298013245033 Hits@10 0.9867549668874173 MRR 0.8618889940081992 cur_rank 0 abs_cur_rank 0 total_num 150 865\n",
      "215 150\n",
      "215 208 754\n",
      "checkcorrect 4 4 real score 1.906900268793106 Hits@1 0.7894736842105263 Hits@3 0.9210526315789473 Hits@10 0.9868421052631579 MRR 0.862797619047619 cur_rank 0 abs_cur_rank 0 total_num 151 865\n",
      "215 150\n",
      "215 318 728\n",
      "checkcorrect 54 54 real score 1.8885000705718995 Hits@1 0.7908496732026143 Hits@3 0.9215686274509803 Hits@10 0.9869281045751634 MRR 0.863694366635543 cur_rank 0 abs_cur_rank 0 total_num 152 865\n",
      "215 4\n",
      "215 6 4\n",
      "checkcorrect 138 138 real score 1.9841811299324035 Hits@1 0.7922077922077922 Hits@3 0.922077922077922 Hits@10 0.987012987012987 MRR 0.8645794681508967 cur_rank 0 abs_cur_rank 0 total_num 153 865\n",
      "215 7\n",
      "215 176 10\n",
      "checkcorrect 352 352 real score 1.2732491552829743 Hits@1 0.7935483870967742 Hits@3 0.9225806451612903 Hits@10 0.9870967741935484 MRR 0.865453149001536 cur_rank 0 abs_cur_rank 0 total_num 154 865\n",
      "215 68\n",
      "215 493 90\n",
      "checkcorrect 352 352 real score 1.2369674727320672 Hits@1 0.7884615384615384 Hits@3 0.9230769230769231 Hits@10 0.9871794871794872 MRR 0.8631105006105005 cur_rank 1 abs_cur_rank 1 total_num 155 865\n",
      "215 74\n",
      "215 280 74\n",
      "checkcorrect 172 172 real score 1.9074263989925384 Hits@1 0.7898089171974523 Hits@3 0.9235668789808917 Hits@10 0.9872611464968153 MRR 0.8639824082499241 cur_rank 0 abs_cur_rank 0 total_num 156 865\n",
      "215 150\n",
      "215 206 237\n",
      "checkcorrect 118 118 real score 1.9765277624130249 Hits@1 0.7911392405063291 Hits@3 0.9240506329113924 Hits@10 0.9873417721518988 MRR 0.8648432790837853 cur_rank 0 abs_cur_rank 0 total_num 157 865\n",
      "215 38\n",
      "215 89 122\n",
      "checkcorrect 426 426 real score 0.7432513587176799 Hits@1 0.7861635220125787 Hits@3 0.9182389937106918 Hits@10 0.9811320754716981 MRR 0.8597970949386043 cur_rank 15 abs_cur_rank 15 total_num 158 865\n",
      "215 8\n",
      "215 13 29\n",
      "checkcorrect 132 132 real score 1.9111568212509153 Hits@1 0.7875 Hits@3 0.91875 Hits@10 0.98125 MRR 0.860673363095238 cur_rank 0 abs_cur_rank 0 total_num 159 865\n",
      "215 8\n",
      "215 111 85\n",
      "checkcorrect 120 120 real score 1.6783591747283935 Hits@1 0.782608695652174 Hits@3 0.9192546583850931 Hits@10 0.9813664596273292 MRR 0.858433155871044 cur_rank 1 abs_cur_rank 1 total_num 160 865\n",
      "215 150\n",
      "215 21 1541\n",
      "checkcorrect 34 34 real score 1.7435175836086274 Hits@1 0.7777777777777778 Hits@3 0.9197530864197531 Hits@10 0.9814814814814815 MRR 0.856220605526161 cur_rank 1 abs_cur_rank 1 total_num 161 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 140\n",
      "215 40 707\n",
      "checkcorrect 4 4 real score 1.9010482609272004 Hits@1 0.7791411042944786 Hits@3 0.9202453987730062 Hits@10 0.9815950920245399 MRR 0.8571026877008472 cur_rank 0 abs_cur_rank 0 total_num 162 865\n",
      "215 102\n",
      "215 458 296\n",
      "checkcorrect 46 46 real score 1.1130129374563693 Hits@1 0.7804878048780488 Hits@3 0.9207317073170732 Hits@10 0.9817073170731707 MRR 0.857974012775842 cur_rank 0 abs_cur_rank 1 total_num 163 865\n",
      "215 142\n",
      "215 514 278\n",
      "checkcorrect 46 46 real score 1.4175568103790281 Hits@1 0.7818181818181819 Hits@3 0.9212121212121213 Hits@10 0.9818181818181818 MRR 0.8588347763347762 cur_rank 0 abs_cur_rank 1 total_num 164 865\n",
      "215 149\n",
      "215 571 273\n",
      "checkcorrect 24 24 real score 1.7188099086284638 Hits@1 0.7831325301204819 Hits@3 0.9216867469879518 Hits@10 0.9819277108433735 MRR 0.8596851692484222 cur_rank 0 abs_cur_rank 1 total_num 165 865\n",
      "215 150\n",
      "215 297 745\n",
      "checkcorrect 54 54 real score 1.9297056138515472 Hits@1 0.7844311377245509 Hits@3 0.9221556886227545 Hits@10 0.9820359281437125 MRR 0.860525377815797 cur_rank 0 abs_cur_rank 0 total_num 166 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 168 168 real score 1.9568748056888579 Hits@1 0.7797619047619048 Hits@3 0.9226190476190477 Hits@10 0.9821428571428571 MRR 0.8583793934240362 cur_rank 1 abs_cur_rank 1 total_num 167 865\n",
      "215 112\n",
      "215 751 1036\n",
      "checkcorrect 356 356 real score 0.9370129212737084 Hits@1 0.7751479289940828 Hits@3 0.9171597633136095 Hits@10 0.9822485207100592 MRR 0.8540398703860241 cur_rank 7 abs_cur_rank 9 total_num 168 865\n",
      "215 150\n",
      "215 488 680\n",
      "checkcorrect 24 24 real score 1.891109624505043 Hits@1 0.7764705882352941 Hits@3 0.9176470588235294 Hits@10 0.9823529411764705 MRR 0.8548984593837534 cur_rank 0 abs_cur_rank 1 total_num 169 865\n",
      "215 150\n",
      "215 149 428\n",
      "checkcorrect 56 56 real score 1.9811553299427032 Hits@1 0.7777777777777778 Hits@3 0.9181286549707602 Hits@10 0.9824561403508771 MRR 0.8557470064049011 cur_rank 0 abs_cur_rank 0 total_num 170 865\n",
      "215 140\n",
      "215 491 584\n",
      "checkcorrect 24 24 real score 1.9339201867580413 Hits@1 0.7790697674418605 Hits@3 0.9186046511627907 Hits@10 0.9825581395348837 MRR 0.8565856866002214 cur_rank 0 abs_cur_rank 1 total_num 171 865\n",
      "215 150\n",
      "215 262 471\n",
      "checkcorrect 50 50 real score 1.6190655410289765 Hits@1 0.7803468208092486 Hits@3 0.9190751445086706 Hits@10 0.9826589595375722 MRR 0.8574146710707404 cur_rank 0 abs_cur_rank 0 total_num 172 865\n",
      "215 32\n",
      "215 280 27\n",
      "checkcorrect 172 172 real score 1.9176687359809876 Hits@1 0.7816091954022989 Hits@3 0.9195402298850575 Hits@10 0.9827586206896551 MRR 0.8582341269841269 cur_rank 0 abs_cur_rank 0 total_num 173 865\n",
      "215 150\n",
      "215 396 595\n",
      "checkcorrect 172 172 real score 1.8982832372188567 Hits@1 0.7828571428571428 Hits@3 0.92 Hits@10 0.9828571428571429 MRR 0.8590442176870747 cur_rank 0 abs_cur_rank 0 total_num 174 865\n",
      "215 69\n",
      "215 161 170\n",
      "checkcorrect 46 46 real score 1.6871761441230775 Hits@1 0.7840909090909091 Hits@3 0.9204545454545454 Hits@10 0.9829545454545454 MRR 0.8598451028138527 cur_rank 0 abs_cur_rank 1 total_num 175 865\n",
      "215 142\n",
      "215 69 208\n",
      "checkcorrect 54 54 real score 1.966895806789398 Hits@1 0.7853107344632768 Hits@3 0.9209039548022598 Hits@10 0.9830508474576272 MRR 0.8606369383911756 cur_rank 0 abs_cur_rank 0 total_num 176 865\n",
      "215 150\n",
      "215 100 525\n",
      "checkcorrect 78 78 real score 1.959046071767807 Hits@1 0.7865168539325843 Hits@3 0.9213483146067416 Hits@10 0.9831460674157303 MRR 0.8614198769395398 cur_rank 0 abs_cur_rank 0 total_num 177 865\n",
      "215 150\n",
      "215 453 429\n",
      "checkcorrect 56 56 real score 1.8844627857208252 Hits@1 0.7877094972067039 Hits@3 0.9217877094972067 Hits@10 0.9832402234636871 MRR 0.8621940675711625 cur_rank 0 abs_cur_rank 0 total_num 178 865\n",
      "215 150\n",
      "215 266 488\n",
      "checkcorrect 102 102 real score 1.9852375924587249 Hits@1 0.7888888888888889 Hits@3 0.9222222222222223 Hits@10 0.9833333333333333 MRR 0.8629596560846561 cur_rank 0 abs_cur_rank 0 total_num 179 865\n",
      "215 124\n",
      "215 382 333\n",
      "checkcorrect 50 50 real score 1.8596259355545044 Hits@1 0.7845303867403315 Hits@3 0.9226519337016574 Hits@10 0.9834254143646409 MRR 0.8609543541173375 cur_rank 1 abs_cur_rank 1 total_num 180 865\n",
      "0 2\n",
      "215 261 79\n",
      "checkcorrect 10 10 real score 0.6674407973885537 Hits@1 0.7802197802197802 Hits@3 0.9175824175824175 Hits@10 0.9835164835164835 MRR 0.8573227367870224 cur_rank 4 abs_cur_rank 5 total_num 181 865\n",
      "215 137\n",
      "215 357 271\n",
      "checkcorrect 16 16 real score 1.9688174545764923 Hits@1 0.7814207650273224 Hits@3 0.9180327868852459 Hits@10 0.9836065573770492 MRR 0.8581023939630495 cur_rank 0 abs_cur_rank 0 total_num 182 865\n",
      "215 131\n",
      "215 243 244\n",
      "checkcorrect 60 60 real score 1.701224136352539 Hits@1 0.782608695652174 Hits@3 0.9184782608695652 Hits@10 0.9836956521739131 MRR 0.8588735766045548 cur_rank 0 abs_cur_rank 0 total_num 183 865\n",
      "215 59\n",
      "215 888 531\n",
      "checkcorrect 302 302 real score 1.717199432849884 Hits@1 0.7837837837837838 Hits@3 0.918918918918919 Hits@10 0.9837837837837838 MRR 0.859636422136422 cur_rank 0 abs_cur_rank 2 total_num 184 865\n",
      "215 150\n",
      "215 677 584\n",
      "checkcorrect 50 50 real score 1.9018512666225433 Hits@1 0.7849462365591398 Hits@3 0.9193548387096774 Hits@10 0.9838709677419355 MRR 0.8603910650281617 cur_rank 0 abs_cur_rank 0 total_num 185 865\n",
      "215 149\n",
      "215 295 645\n",
      "checkcorrect 102 102 real score 1.9854515433311462 Hits@1 0.786096256684492 Hits@3 0.9197860962566845 Hits@10 0.983957219251337 MRR 0.8611376368729309 cur_rank 0 abs_cur_rank 0 total_num 186 865\n",
      "215 150\n",
      "215 205 729\n",
      "checkcorrect 86 86 real score 1.745654857158661 Hits@1 0.7872340425531915 Hits@3 0.9202127659574468 Hits@10 0.9840425531914894 MRR 0.8618762664640323 cur_rank 0 abs_cur_rank 0 total_num 187 865\n",
      "0 1\n",
      "215 438 52\n",
      "checkcorrect 34 34 real score 0.8680943489074707 Hits@1 0.7883597883597884 Hits@3 0.9206349206349206 Hits@10 0.9841269841269841 MRR 0.8626070798689845 cur_rank 0 abs_cur_rank 1 total_num 188 865\n",
      "0 0\n",
      "0 18 1\n",
      "checkcorrect 344 344 real score 0.0 Hits@1 0.7842105263157895 Hits@3 0.9157894736842105 Hits@10 0.9789473684210527 MRR 0.8580974654845205 cur_rank 172 abs_cur_rank 172 total_num 189 865\n",
      "215 150\n",
      "215 282 136\n",
      "checkcorrect 214 214 real score 1.9292407453060152 Hits@1 0.7853403141361257 Hits@3 0.9162303664921466 Hits@10 0.9790575916230366 MRR 0.8588404106914078 cur_rank 0 abs_cur_rank 0 total_num 190 865\n",
      "215 150\n",
      "215 361 281\n",
      "checkcorrect 46 46 real score 1.847304892539978 Hits@1 0.7864583333333334 Hits@3 0.9166666666666666 Hits@10 0.9791666666666666 MRR 0.8595756168857234 cur_rank 0 abs_cur_rank 1 total_num 191 865\n",
      "215 150\n",
      "215 111 121\n",
      "checkcorrect 80 80 real score 1.976035702228546 Hits@1 0.7875647668393783 Hits@3 0.917098445595855 Hits@10 0.9792746113989638 MRR 0.8603032043629995 cur_rank 0 abs_cur_rank 0 total_num 192 865\n",
      "215 150\n",
      "215 468 262\n",
      "checkcorrect 50 50 real score 1.4811353951692583 Hits@1 0.7835051546391752 Hits@3 0.9175257731958762 Hits@10 0.979381443298969 MRR 0.8575868648216094 cur_rank 2 abs_cur_rank 2 total_num 193 865\n",
      "215 149\n",
      "215 197 177\n",
      "checkcorrect 162 162 real score 1.7093455851078034 Hits@1 0.7846153846153846 Hits@3 0.9179487179487179 Hits@10 0.9794871794871794 MRR 0.858317188591755 cur_rank 0 abs_cur_rank 0 total_num 194 865\n",
      "215 113\n",
      "215 387 639\n",
      "checkcorrect 46 46 real score 1.7125637412071228 Hits@1 0.7857142857142857 Hits@3 0.9183673469387755 Hits@10 0.9795918367346939 MRR 0.8590400600785317 cur_rank 0 abs_cur_rank 1 total_num 195 865\n",
      "215 150\n",
      "215 207 738\n",
      "checkcorrect 56 56 real score 1.9724623620510102 Hits@1 0.7868020304568528 Hits@3 0.9187817258883249 Hits@10 0.9796954314720813 MRR 0.8597555927684885 cur_rank 0 abs_cur_rank 0 total_num 196 865\n",
      "215 150\n",
      "215 155 485\n",
      "checkcorrect 156 156 real score 1.9370114028453826 Hits@1 0.7878787878787878 Hits@3 0.9191919191919192 Hits@10 0.9797979797979798 MRR 0.8604638978555164 cur_rank 0 abs_cur_rank 0 total_num 197 865\n",
      "215 111\n",
      "215 151 435\n",
      "checkcorrect 232 232 real score 1.9308819234371186 Hits@1 0.7889447236180904 Hits@3 0.9195979899497487 Hits@10 0.9798994974874372 MRR 0.8611650842984534 cur_rank 0 abs_cur_rank 1 total_num 198 865\n",
      "215 150\n",
      "215 649 954\n",
      "checkcorrect 10 10 real score 1.8337289690971375 Hits@1 0.79 Hits@3 0.92 Hits@10 0.98 MRR 0.8618592588769611 cur_rank 0 abs_cur_rank 0 total_num 199 865\n",
      "215 11\n",
      "215 52 54\n",
      "checkcorrect 50 50 real score 1.8828486263751985 Hits@1 0.7910447761194029 Hits@3 0.9203980099502488 Hits@10 0.9800995024875622 MRR 0.8625465262457325 cur_rank 0 abs_cur_rank 1 total_num 200 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 57\n",
      "215 280 188\n",
      "checkcorrect 74 74 real score 1.9129227817058565 Hits@1 0.7920792079207921 Hits@3 0.9207920792079208 Hits@10 0.9801980198019802 MRR 0.8632269889870903 cur_rank 0 abs_cur_rank 0 total_num 201 865\n",
      "215 124\n",
      "215 98 253\n",
      "checkcorrect 116 116 real score 1.9890724658966064 Hits@1 0.7931034482758621 Hits@3 0.9211822660098522 Hits@10 0.9802955665024631 MRR 0.8639007476620307 cur_rank 0 abs_cur_rank 0 total_num 202 865\n",
      "215 98\n",
      "215 893 276\n",
      "checkcorrect 282 282 real score 0.7586610808968544 Hits@1 0.7892156862745098 Hits@3 0.9166666666666666 Hits@10 0.9803921568627451 MRR 0.8603662201874969 cur_rank 6 abs_cur_rank 6 total_num 203 865\n",
      "215 100\n",
      "215 197 191\n",
      "checkcorrect 310 310 real score 1.7276583313941956 Hits@1 0.7853658536585366 Hits@3 0.9170731707317074 Hits@10 0.9804878048780488 MRR 0.8586083361865823 cur_rank 1 abs_cur_rank 1 total_num 204 865\n",
      "215 146\n",
      "215 467 334\n",
      "checkcorrect 24 24 real score 1.93505397439003 Hits@1 0.7864077669902912 Hits@3 0.9174757281553398 Hits@10 0.9805825242718447 MRR 0.8592947034866474 cur_rank 0 abs_cur_rank 0 total_num 205 865\n",
      "215 23\n",
      "215 284 39\n",
      "checkcorrect 54 54 real score 1.6831813782453537 Hits@1 0.7874396135265701 Hits@3 0.9178743961352657 Hits@10 0.9806763285024155 MRR 0.859974439218596 cur_rank 0 abs_cur_rank 0 total_num 206 865\n",
      "215 150\n",
      "215 887 958\n",
      "checkcorrect 50 50 real score 1.9227894306182862 Hits@1 0.7884615384615384 Hits@3 0.9182692307692307 Hits@10 0.9807692307692307 MRR 0.860647639030045 cur_rank 0 abs_cur_rank 0 total_num 207 865\n",
      "215 13\n",
      "215 49 27\n",
      "checkcorrect 60 60 real score 0.9452080883085727 Hits@1 0.7894736842105263 Hits@3 0.9186602870813397 Hits@10 0.9808612440191388 MRR 0.8613143967380352 cur_rank 0 abs_cur_rank 0 total_num 208 865\n",
      "215 150\n",
      "215 913 1257\n",
      "checkcorrect 46 46 real score 1.3949211774393917 Hits@1 0.7904761904761904 Hits@3 0.919047619047619 Hits@10 0.9809523809523809 MRR 0.8619748043726161 cur_rank 0 abs_cur_rank 0 total_num 209 865\n",
      "215 142\n",
      "215 343 340\n",
      "checkcorrect 2 2 real score 1.8712949097156524 Hits@1 0.7914691943127962 Hits@3 0.919431279620853 Hits@10 0.981042654028436 MRR 0.8626289522191913 cur_rank 0 abs_cur_rank 0 total_num 210 865\n",
      "215 150\n",
      "215 462 483\n",
      "checkcorrect 20 20 real score 1.8487975001335144 Hits@1 0.7924528301886793 Hits@3 0.9198113207547169 Hits@10 0.9811320754716981 MRR 0.8632769288596668 cur_rank 0 abs_cur_rank 0 total_num 211 865\n",
      "215 149\n",
      "215 54 105\n",
      "checkcorrect 76 76 real score 1.9572166740894317 Hits@1 0.7934272300469484 Hits@3 0.92018779342723 Hits@10 0.9812206572769953 MRR 0.8639188212124383 cur_rank 0 abs_cur_rank 0 total_num 212 865\n",
      "215 22\n",
      "215 9 58\n",
      "checkcorrect 360 360 real score 0.9775264483178034 Hits@1 0.794392523364486 Hits@3 0.9205607476635514 Hits@10 0.9813084112149533 MRR 0.8645547145712588 cur_rank 0 abs_cur_rank 0 total_num 213 865\n",
      "215 128\n",
      "215 483 65\n",
      "checkcorrect 172 172 real score 1.915684461593628 Hits@1 0.7953488372093023 Hits@3 0.9209302325581395 Hits@10 0.9813953488372092 MRR 0.8651846926430203 cur_rank 0 abs_cur_rank 0 total_num 214 865\n",
      "215 150\n",
      "215 306 895\n",
      "checkcorrect 44 44 real score 1.8793176889419556 Hits@1 0.7962962962962963 Hits@3 0.9212962962962963 Hits@10 0.9814814814814815 MRR 0.8658088375844878 cur_rank 0 abs_cur_rank 0 total_num 215 865\n",
      "215 150\n",
      "215 323 705\n",
      "checkcorrect 102 102 real score 1.9858710289001464 Hits@1 0.7972350230414746 Hits@3 0.9216589861751152 Hits@10 0.9815668202764977 MRR 0.8664272300380155 cur_rank 0 abs_cur_rank 0 total_num 216 865\n",
      "215 134\n",
      "215 139 308\n",
      "checkcorrect 158 158 real score 1.9023079037666322 Hits@1 0.7981651376146789 Hits@3 0.9220183486238532 Hits@10 0.981651376146789 MRR 0.8670399491662815 cur_rank 0 abs_cur_rank 0 total_num 217 865\n",
      "215 150\n",
      "215 279 416\n",
      "checkcorrect 2 2 real score 1.7435030966997147 Hits@1 0.7990867579908676 Hits@3 0.9223744292237442 Hits@10 0.9817351598173516 MRR 0.8676470726860702 cur_rank 0 abs_cur_rank 0 total_num 218 865\n",
      "215 96\n",
      "215 162 362\n",
      "checkcorrect 50 50 real score 1.6068494766950607 Hits@1 0.8 Hits@3 0.9227272727272727 Hits@10 0.9818181818181818 MRR 0.8682486769011335 cur_rank 0 abs_cur_rank 0 total_num 219 865\n",
      "215 150\n",
      "215 901 426\n",
      "checkcorrect 50 50 real score 1.8803993165493011 Hits@1 0.8009049773755657 Hits@3 0.9230769230769231 Hits@10 0.9819004524886877 MRR 0.86884483673416 cur_rank 0 abs_cur_rank 0 total_num 220 865\n",
      "215 150\n",
      "215 372 286\n",
      "checkcorrect 24 24 real score 1.9316613674163818 Hits@1 0.8018018018018018 Hits@3 0.9234234234234234 Hits@10 0.9819819819819819 MRR 0.86943562575788 cur_rank 0 abs_cur_rank 0 total_num 221 865\n",
      "215 29\n",
      "215 32 16\n",
      "checkcorrect 338 338 real score 1.8674419045448303 Hits@1 0.8026905829596412 Hits@3 0.9237668161434978 Hits@10 0.9820627802690582 MRR 0.8700211162253335 cur_rank 0 abs_cur_rank 0 total_num 222 865\n",
      "215 112\n",
      "215 316 118\n",
      "checkcorrect 26 26 real score 1.9592224895954131 Hits@1 0.8035714285714286 Hits@3 0.9241071428571429 Hits@10 0.9821428571428571 MRR 0.8706013790993276 cur_rank 0 abs_cur_rank 0 total_num 223 865\n",
      "215 150\n",
      "215 321 295\n",
      "checkcorrect 56 56 real score 1.9685184717178346 Hits@1 0.8044444444444444 Hits@3 0.9244444444444444 Hits@10 0.9822222222222222 MRR 0.8711764840811083 cur_rank 0 abs_cur_rank 0 total_num 224 865\n",
      "215 150\n",
      "215 242 218\n",
      "checkcorrect 78 78 real score 1.9556146025657655 Hits@1 0.8053097345132744 Hits@3 0.9247787610619469 Hits@10 0.9823008849557522 MRR 0.8717464996382716 cur_rank 0 abs_cur_rank 0 total_num 225 865\n",
      "215 42\n",
      "215 425 66\n",
      "checkcorrect 50 50 real score 1.274245449900627 Hits@1 0.801762114537445 Hits@3 0.920704845814978 Hits@10 0.9823788546255506 MRR 0.8686404210789253 cur_rank 5 abs_cur_rank 5 total_num 226 865\n",
      "215 116\n",
      "215 472 277\n",
      "checkcorrect 246 246 real score 1.3148218810558319 Hits@1 0.7982456140350878 Hits@3 0.9166666666666666 Hits@10 0.9824561403508771 MRR 0.8659270858987544 cur_rank 3 abs_cur_rank 5 total_num 227 865\n",
      "215 150\n",
      "215 356 400\n",
      "checkcorrect 20 20 real score 1.9001481235027313 Hits@1 0.7991266375545851 Hits@3 0.9170305676855895 Hits@10 0.982532751091703 MRR 0.8665125571393713 cur_rank 0 abs_cur_rank 0 total_num 228 865\n",
      "215 150\n",
      "215 337 211\n",
      "checkcorrect 52 52 real score 1.9126268446445465 Hits@1 0.8 Hits@3 0.9173913043478261 Hits@10 0.9826086956521739 MRR 0.8670929373257219 cur_rank 0 abs_cur_rank 0 total_num 229 865\n",
      "215 107\n",
      "215 185 181\n",
      "checkcorrect 78 78 real score 1.8297265261411666 Hits@1 0.8008658008658008 Hits@3 0.9177489177489178 Hits@10 0.9826839826839827 MRR 0.867668292575394 cur_rank 0 abs_cur_rank 0 total_num 230 865\n",
      "215 22\n",
      "215 47 52\n",
      "checkcorrect 132 132 real score 1.9354186296463012 Hits@1 0.8017241379310345 Hits@3 0.9181034482758621 Hits@10 0.9827586206896551 MRR 0.8682386878660173 cur_rank 0 abs_cur_rank 0 total_num 231 865\n",
      "215 150\n",
      "215 166 682\n",
      "checkcorrect 54 54 real score 1.9215935528278352 Hits@1 0.8025751072961373 Hits@3 0.9184549356223176 Hits@10 0.9828326180257511 MRR 0.8688041870597254 cur_rank 0 abs_cur_rank 0 total_num 232 865\n",
      "215 150\n",
      "215 89 841\n",
      "checkcorrect 54 54 real score 1.9373832106590272 Hits@1 0.8034188034188035 Hits@3 0.9188034188034188 Hits@10 0.9829059829059829 MRR 0.8693648529269916 cur_rank 0 abs_cur_rank 0 total_num 233 865\n",
      "215 132\n",
      "215 531 721\n",
      "checkcorrect 16 16 real score 1.9353440999984741 Hits@1 0.8042553191489362 Hits@3 0.9191489361702128 Hits@10 0.9829787234042553 MRR 0.8699207471698555 cur_rank 0 abs_cur_rank 0 total_num 234 865\n",
      "215 150\n",
      "215 526 884\n",
      "checkcorrect 56 56 real score 1.819636458158493 Hits@1 0.8050847457627118 Hits@3 0.9194915254237288 Hits@10 0.9830508474576272 MRR 0.8704719304445594 cur_rank 0 abs_cur_rank 0 total_num 235 865\n",
      "215 150\n",
      "215 378 488\n",
      "checkcorrect 10 10 real score 1.8468270242214202 Hits@1 0.8059071729957806 Hits@3 0.919831223628692 Hits@10 0.9831223628691983 MRR 0.8710184623836119 cur_rank 0 abs_cur_rank 0 total_num 236 865\n",
      "215 150\n",
      "215 269 818\n",
      "checkcorrect 56 56 real score 1.9822180330753327 Hits@1 0.8067226890756303 Hits@3 0.9201680672268907 Hits@10 0.9831932773109243 MRR 0.8715604016172942 cur_rank 0 abs_cur_rank 0 total_num 237 865\n",
      "215 121\n",
      "215 208 199\n",
      "checkcorrect 26 26 real score 1.959923154115677 Hits@1 0.8075313807531381 Hits@3 0.9205020920502092 Hits@10 0.9832635983263598 MRR 0.8720978057946277 cur_rank 0 abs_cur_rank 0 total_num 238 865\n",
      "215 150\n",
      "215 518 587\n",
      "checkcorrect 2 2 real score 1.8554721772670746 Hits@1 0.8041666666666667 Hits@3 0.9208333333333333 Hits@10 0.9833333333333333 MRR 0.8705473982704834 cur_rank 1 abs_cur_rank 1 total_num 239 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 120 839\n",
      "checkcorrect 54 54 real score 1.8229119181632996 Hits@1 0.8049792531120332 Hits@3 0.921161825726141 Hits@10 0.983402489626556 MRR 0.8710845459955022 cur_rank 0 abs_cur_rank 0 total_num 240 865\n",
      "215 139\n",
      "215 146 555\n",
      "checkcorrect 54 54 real score 1.9571096003055573 Hits@1 0.8057851239669421 Hits@3 0.9214876033057852 Hits@10 0.9834710743801653 MRR 0.8716172544831241 cur_rank 0 abs_cur_rank 0 total_num 241 865\n",
      "215 150\n",
      "215 142 658\n",
      "checkcorrect 54 54 real score 1.9100359380245209 Hits@1 0.8065843621399177 Hits@3 0.9218106995884774 Hits@10 0.9835390946502057 MRR 0.8721455785387491 cur_rank 0 abs_cur_rank 0 total_num 242 865\n",
      "215 133\n",
      "215 965 119\n",
      "checkcorrect 16 16 real score 1.9213002681732179 Hits@1 0.8073770491803278 Hits@3 0.9221311475409836 Hits@10 0.9836065573770492 MRR 0.8726695720693279 cur_rank 0 abs_cur_rank 0 total_num 243 865\n",
      "215 131\n",
      "215 235 146\n",
      "checkcorrect 108 108 real score 1.8051872432231904 Hits@1 0.8081632653061225 Hits@3 0.9224489795918367 Hits@10 0.9836734693877551 MRR 0.873189288101698 cur_rank 0 abs_cur_rank 0 total_num 244 865\n",
      "215 150\n",
      "215 711 569\n",
      "checkcorrect 50 50 real score 1.883407324552536 Hits@1 0.8089430894308943 Hits@3 0.9227642276422764 Hits@10 0.983739837398374 MRR 0.8737047788004717 cur_rank 0 abs_cur_rank 0 total_num 245 865\n",
      "0 1\n",
      "215 301 44\n",
      "checkcorrect 140 140 real score 0.8213335335254669 Hits@1 0.805668016194332 Hits@3 0.9230769230769231 Hits@10 0.9838056680161943 MRR 0.8721918039875143 cur_rank 1 abs_cur_rank 2 total_num 246 865\n",
      "215 150\n",
      "215 29 918\n",
      "checkcorrect 54 54 real score 1.7883655309677122 Hits@1 0.8064516129032258 Hits@3 0.9233870967741935 Hits@10 0.9838709677419355 MRR 0.8727071596165968 cur_rank 0 abs_cur_rank 0 total_num 247 865\n",
      "215 65\n",
      "215 31 74\n",
      "checkcorrect 126 126 real score 1.1811766093596816 Hits@1 0.8072289156626506 Hits@3 0.9236947791164659 Hits@10 0.9839357429718876 MRR 0.8732183758430363 cur_rank 0 abs_cur_rank 0 total_num 248 865\n",
      "215 150\n",
      "215 189 688\n",
      "checkcorrect 4 4 real score 1.8975238382816315 Hits@1 0.808 Hits@3 0.924 Hits@10 0.984 MRR 0.8737255023396641 cur_rank 0 abs_cur_rank 0 total_num 249 865\n",
      "215 150\n",
      "215 254 251\n",
      "checkcorrect 26 26 real score 1.9548856317996979 Hits@1 0.8087649402390438 Hits@3 0.9243027888446215 Hits@10 0.9840637450199203 MRR 0.8742285879877133 cur_rank 0 abs_cur_rank 0 total_num 250 865\n",
      "215 150\n",
      "215 552 242\n",
      "checkcorrect 348 348 real score 1.7739411413669588 Hits@1 0.8095238095238095 Hits@3 0.9246031746031746 Hits@10 0.9841269841269841 MRR 0.874727680892524 cur_rank 0 abs_cur_rank 0 total_num 251 865\n",
      "215 89\n",
      "215 111 121\n",
      "checkcorrect 196 196 real score 1.8727816462516786 Hits@1 0.8102766798418972 Hits@3 0.924901185770751 Hits@10 0.9841897233201581 MRR 0.8752228283988776 cur_rank 0 abs_cur_rank 0 total_num 252 865\n",
      "215 150\n",
      "215 266 430\n",
      "checkcorrect 102 102 real score 1.985870611667633 Hits@1 0.8110236220472441 Hits@3 0.9251968503937008 Hits@10 0.984251968503937 MRR 0.8757140771059686 cur_rank 0 abs_cur_rank 0 total_num 253 865\n",
      "215 141\n",
      "215 471 587\n",
      "checkcorrect 56 56 real score 1.791521465778351 Hits@1 0.8117647058823529 Hits@3 0.9254901960784314 Hits@10 0.984313725490196 MRR 0.8762014728820237 cur_rank 0 abs_cur_rank 1 total_num 254 865\n",
      "215 150\n",
      "215 1264 347\n",
      "checkcorrect 20 20 real score 1.8750167191028595 Hits@1 0.8125 Hits@3 0.92578125 Hits@10 0.984375 MRR 0.8766850608785782 cur_rank 0 abs_cur_rank 0 total_num 255 865\n",
      "215 150\n",
      "215 228 825\n",
      "checkcorrect 54 54 real score 1.8640998125076296 Hits@1 0.8132295719844358 Hits@3 0.9260700389105059 Hits@10 0.9844357976653697 MRR 0.8771648855444203 cur_rank 0 abs_cur_rank 0 total_num 256 865\n",
      "215 133\n",
      "215 242 194\n",
      "checkcorrect 172 172 real score 1.8622451663017272 Hits@1 0.813953488372093 Hits@3 0.9263565891472868 Hits@10 0.9844961240310077 MRR 0.8776409906392094 cur_rank 0 abs_cur_rank 0 total_num 257 865\n",
      "215 150\n",
      "215 439 583\n",
      "checkcorrect 2 2 real score 1.7943862497806549 Hits@1 0.8146718146718147 Hits@3 0.9266409266409267 Hits@10 0.9845559845559846 MRR 0.87811341924678 cur_rank 0 abs_cur_rank 0 total_num 258 865\n",
      "215 150\n",
      "215 322 843\n",
      "checkcorrect 54 54 real score 1.8697604179382323 Hits@1 0.8153846153846154 Hits@3 0.926923076923077 Hits@10 0.9846153846153847 MRR 0.8785822137881386 cur_rank 0 abs_cur_rank 0 total_num 259 865\n",
      "215 150\n",
      "215 894 484\n",
      "checkcorrect 16 16 real score 1.9400641441345214 Hits@1 0.8160919540229885 Hits@3 0.9272030651340997 Hits@10 0.9846743295019157 MRR 0.879047416034161 cur_rank 0 abs_cur_rank 0 total_num 260 865\n",
      "215 93\n",
      "215 319 242\n",
      "checkcorrect 2 2 real score 1.7775720208883286 Hits@1 0.816793893129771 Hits@3 0.9274809160305344 Hits@10 0.9847328244274809 MRR 0.8795090671180001 cur_rank 0 abs_cur_rank 0 total_num 261 865\n",
      "215 150\n",
      "215 519 530\n",
      "checkcorrect 78 78 real score 1.9388100385665892 Hits@1 0.8174904942965779 Hits@3 0.9277566539923955 Hits@10 0.9847908745247148 MRR 0.8799672075472093 cur_rank 0 abs_cur_rank 0 total_num 262 865\n",
      "215 150\n",
      "215 191 1290\n",
      "checkcorrect 100 100 real score 1.8538764595985413 Hits@1 0.8181818181818182 Hits@3 0.928030303030303 Hits@10 0.9848484848484849 MRR 0.880421877215591 cur_rank 0 abs_cur_rank 0 total_num 263 865\n",
      "215 9\n",
      "215 17 21\n",
      "checkcorrect 36 36 real score 1.7793842554092407 Hits@1 0.8188679245283019 Hits@3 0.9283018867924528 Hits@10 0.9849056603773585 MRR 0.8808731154147774 cur_rank 0 abs_cur_rank 1 total_num 264 865\n",
      "215 150\n",
      "215 71 949\n",
      "checkcorrect 54 54 real score 1.9657128930091858 Hits@1 0.8195488721804511 Hits@3 0.9285714285714286 Hits@10 0.9849624060150376 MRR 0.881320960845549 cur_rank 0 abs_cur_rank 0 total_num 265 865\n",
      "215 150\n",
      "215 285 257\n",
      "checkcorrect 214 214 real score 1.9462529301643372 Hits@1 0.8202247191011236 Hits@3 0.9288389513108615 Hits@10 0.9850187265917603 MRR 0.881765451628899 cur_rank 0 abs_cur_rank 0 total_num 266 865\n",
      "215 150\n",
      "215 74 817\n",
      "checkcorrect 54 54 real score 1.847137266397476 Hits@1 0.8208955223880597 Hits@3 0.9291044776119403 Hits@10 0.9850746268656716 MRR 0.8822066253168508 cur_rank 0 abs_cur_rank 0 total_num 267 865\n",
      "215 109\n",
      "215 19 600\n",
      "checkcorrect 218 218 real score 1.9453375041484833 Hits@1 0.8215613382899628 Hits@3 0.929368029739777 Hits@10 0.9851301115241635 MRR 0.8826445189030335 cur_rank 0 abs_cur_rank 0 total_num 268 865\n",
      "215 110\n",
      "215 368 337\n",
      "checkcorrect 46 46 real score 1.8451038241386413 Hits@1 0.8185185185185185 Hits@3 0.9296296296296296 Hits@10 0.9851851851851852 MRR 0.8812273169811705 cur_rank 1 abs_cur_rank 1 total_num 269 865\n",
      "215 52\n",
      "215 116 263\n",
      "checkcorrect 24 24 real score 1.4360151410102844 Hits@1 0.8154981549815498 Hits@3 0.9261992619926199 Hits@10 0.985239852398524 MRR 0.878898064888989 cur_rank 3 abs_cur_rank 4 total_num 270 865\n",
      "215 85\n",
      "215 360 149\n",
      "checkcorrect 44 44 real score 1.8675156831741333 Hits@1 0.8161764705882353 Hits@3 0.9264705882352942 Hits@10 0.9852941176470589 MRR 0.879343292591603 cur_rank 0 abs_cur_rank 0 total_num 271 865\n",
      "215 79\n",
      "215 387 635\n",
      "checkcorrect 24 24 real score 1.7270143657922745 Hits@1 0.8131868131868132 Hits@3 0.9267399267399268 Hits@10 0.9853479853479854 MRR 0.8779537567213042 cur_rank 1 abs_cur_rank 2 total_num 272 865\n",
      "215 150\n",
      "215 278 449\n",
      "checkcorrect 2 2 real score 1.7731962621212007 Hits@1 0.8138686131386861 Hits@3 0.927007299270073 Hits@10 0.9854014598540146 MRR 0.8783991809668468 cur_rank 0 abs_cur_rank 0 total_num 273 865\n",
      "0 1\n",
      "215 7 8\n",
      "checkcorrect 194 194 real score 0.844041782617569 Hits@1 0.8145454545454546 Hits@3 0.9272727272727272 Hits@10 0.9854545454545455 MRR 0.878841365763331 cur_rank 0 abs_cur_rank 1 total_num 274 865\n",
      "215 133\n",
      "215 533 161\n",
      "checkcorrect 16 16 real score 1.9366653680801391 Hits@1 0.8152173913043478 Hits@3 0.927536231884058 Hits@10 0.9855072463768116 MRR 0.8792803463221596 cur_rank 0 abs_cur_rank 0 total_num 275 865\n",
      "215 150\n",
      "215 286 523\n",
      "checkcorrect 310 310 real score 1.7547718822956084 Hits@1 0.8122743682310469 Hits@3 0.927797833935018 Hits@10 0.9855595667870036 MRR 0.8773094184774346 cur_rank 2 abs_cur_rank 2 total_num 276 865\n",
      "215 150\n",
      "215 286 1513\n",
      "checkcorrect 72 72 real score 1.748816114664078 Hits@1 0.8093525179856115 Hits@3 0.9280575539568345 Hits@10 0.9856115107913669 MRR 0.8753526699697219 cur_rank 2 abs_cur_rank 2 total_num 277 865\n",
      "215 140\n",
      "215 6 722\n",
      "checkcorrect 4 4 real score 1.9171679735183715 Hits@1 0.8100358422939068 Hits@3 0.9283154121863799 Hits@10 0.985663082437276 MRR 0.8757994345934864 cur_rank 0 abs_cur_rank 0 total_num 278 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 96\n",
      "215 78 162\n",
      "checkcorrect 158 158 real score 1.8852711021900177 Hits@1 0.8107142857142857 Hits@3 0.9285714285714286 Hits@10 0.9857142857142858 MRR 0.8762430080413668 cur_rank 0 abs_cur_rank 0 total_num 279 865\n",
      "215 60\n",
      "215 80 126\n",
      "checkcorrect 334 334 real score 1.9351184725761414 Hits@1 0.8113879003558719 Hits@3 0.9288256227758007 Hits@10 0.9857651245551602 MRR 0.8766834243828566 cur_rank 0 abs_cur_rank 0 total_num 280 865\n",
      "215 128\n",
      "215 1570 1511\n",
      "checkcorrect 24 24 real score 1.6534882307052612 Hits@1 0.8085106382978723 Hits@3 0.9290780141843972 Hits@10 0.9858156028368794 MRR 0.8747566510103406 cur_rank 2 abs_cur_rank 4 total_num 281 865\n",
      "215 140\n",
      "215 1143 1106\n",
      "checkcorrect 50 50 real score 1.9014814078807831 Hits@1 0.8091872791519434 Hits@3 0.9293286219081273 Hits@10 0.9858657243816255 MRR 0.8751992070138377 cur_rank 0 abs_cur_rank 1 total_num 282 865\n",
      "215 116\n",
      "215 316 427\n",
      "checkcorrect 50 50 real score 1.822338306903839 Hits@1 0.8063380281690141 Hits@3 0.9295774647887324 Hits@10 0.9859154929577465 MRR 0.8738780830454791 cur_rank 1 abs_cur_rank 1 total_num 283 865\n",
      "215 150\n",
      "215 251 745\n",
      "checkcorrect 4 4 real score 1.8321818649768828 Hits@1 0.8070175438596491 Hits@3 0.9298245614035088 Hits@10 0.9859649122807017 MRR 0.8743206160874247 cur_rank 0 abs_cur_rank 0 total_num 284 865\n",
      "215 150\n",
      "215 286 364\n",
      "checkcorrect 20 20 real score 1.8793559193611145 Hits@1 0.8076923076923077 Hits@3 0.9300699300699301 Hits@10 0.986013986013986 MRR 0.8747600544927134 cur_rank 0 abs_cur_rank 0 total_num 285 865\n",
      "0 0\n",
      "215 291 6\n",
      "checkcorrect 240 240 real score 0.8162148952484131 Hits@1 0.8083623693379791 Hits@3 0.9303135888501742 Hits@10 0.9860627177700348 MRR 0.8751964306094636 cur_rank 0 abs_cur_rank 0 total_num 286 865\n",
      "215 149\n",
      "215 114 467\n",
      "checkcorrect 120 120 real score 1.7135484576225282 Hits@1 0.8055555555555556 Hits@3 0.9305555555555556 Hits@10 0.9861111111111112 MRR 0.873893665225403 cur_rank 1 abs_cur_rank 1 total_num 287 865\n",
      "0 1\n",
      "215 235 18\n",
      "checkcorrect 100 100 real score 0.8848210334777832 Hits@1 0.8062283737024222 Hits@3 0.9307958477508651 Hits@10 0.986159169550173 MRR 0.874330019324969 cur_rank 0 abs_cur_rank 0 total_num 288 865\n",
      "215 143\n",
      "215 102 133\n",
      "checkcorrect 172 172 real score 1.9201551795005798 Hits@1 0.8068965517241379 Hits@3 0.9310344827586207 Hits@10 0.9862068965517241 MRR 0.8747633640859175 cur_rank 0 abs_cur_rank 0 total_num 289 865\n",
      "215 150\n",
      "215 15 290\n",
      "checkcorrect 92 92 real score 1.8991745710372925 Hits@1 0.8075601374570447 Hits@3 0.9312714776632303 Hits@10 0.9862542955326461 MRR 0.8751937305323576 cur_rank 0 abs_cur_rank 0 total_num 290 865\n",
      "215 150\n",
      "215 444 608\n",
      "checkcorrect 20 20 real score 1.8844777345657349 Hits@1 0.8082191780821918 Hits@3 0.9315068493150684 Hits@10 0.9863013698630136 MRR 0.8756211492634112 cur_rank 0 abs_cur_rank 0 total_num 291 865\n",
      "215 150\n",
      "215 62 977\n",
      "checkcorrect 34 34 real score 1.7628677845001222 Hits@1 0.8054607508532423 Hits@3 0.931740614334471 Hits@10 0.9863481228668942 MRR 0.8743391658188261 cur_rank 1 abs_cur_rank 1 total_num 292 865\n",
      "215 150\n",
      "215 122 792\n",
      "checkcorrect 54 54 real score 1.9631870090961456 Hits@1 0.8061224489795918 Hits@3 0.9319727891156463 Hits@10 0.9863945578231292 MRR 0.8747665836221634 cur_rank 0 abs_cur_rank 0 total_num 293 865\n",
      "215 76\n",
      "215 73 207\n",
      "checkcorrect 2 2 real score 1.81712406873703 Hits@1 0.8067796610169492 Hits@3 0.9322033898305084 Hits@10 0.9864406779661017 MRR 0.8751911036776815 cur_rank 0 abs_cur_rank 0 total_num 294 865\n",
      "215 150\n",
      "215 602 466\n",
      "checkcorrect 24 24 real score 1.909826648235321 Hits@1 0.8074324324324325 Hits@3 0.9324324324324325 Hits@10 0.9864864864864865 MRR 0.8756127553544462 cur_rank 0 abs_cur_rank 1 total_num 295 865\n",
      "215 145\n",
      "215 1229 1498\n",
      "checkcorrect 24 24 real score 1.706977778673172 Hits@1 0.8047138047138047 Hits@3 0.9326599326599326 Hits@10 0.9865319865319865 MRR 0.8743480659424783 cur_rank 1 abs_cur_rank 3 total_num 296 865\n",
      "215 49\n",
      "215 992 260\n",
      "checkcorrect 50 50 real score 1.875077384710312 Hits@1 0.8053691275167785 Hits@3 0.9328859060402684 Hits@10 0.9865771812080537 MRR 0.8747697167279063 cur_rank 0 abs_cur_rank 0 total_num 297 865\n",
      "215 68\n",
      "215 110 63\n",
      "checkcorrect 42 42 real score 1.95814790725708 Hits@1 0.8060200668896321 Hits@3 0.9331103678929766 Hits@10 0.9866220735785953 MRR 0.8751885471067427 cur_rank 0 abs_cur_rank 0 total_num 298 865\n",
      "215 150\n",
      "215 75 851\n",
      "checkcorrect 54 54 real score 1.9167183995246888 Hits@1 0.8066666666666666 Hits@3 0.9333333333333333 Hits@10 0.9866666666666667 MRR 0.8756045852830535 cur_rank 0 abs_cur_rank 0 total_num 299 865\n",
      "215 150\n",
      "215 124 422\n",
      "checkcorrect 26 26 real score 1.949346899986267 Hits@1 0.8073089700996677 Hits@3 0.9335548172757475 Hits@10 0.9867109634551495 MRR 0.8760178590860999 cur_rank 0 abs_cur_rank 0 total_num 300 865\n",
      "215 150\n",
      "215 333 769\n",
      "checkcorrect 54 54 real score 1.864696705341339 Hits@1 0.8079470198675497 Hits@3 0.9337748344370861 Hits@10 0.9867549668874173 MRR 0.8764283959765432 cur_rank 0 abs_cur_rank 0 total_num 301 865\n",
      "215 98\n",
      "215 18 155\n",
      "checkcorrect 74 74 real score 1.8965578615665435 Hits@1 0.8085808580858086 Hits@3 0.933993399339934 Hits@10 0.9867986798679867 MRR 0.8768362230525283 cur_rank 0 abs_cur_rank 0 total_num 302 865\n",
      "215 136\n",
      "215 460 1431\n",
      "checkcorrect 100 100 real score 1.8860294103622435 Hits@1 0.8092105263157895 Hits@3 0.9342105263157895 Hits@10 0.9868421052631579 MRR 0.8772413670556449 cur_rank 0 abs_cur_rank 0 total_num 303 865\n",
      "215 139\n",
      "215 242 83\n",
      "checkcorrect 172 172 real score 1.9208329558372497 Hits@1 0.8098360655737705 Hits@3 0.9344262295081968 Hits@10 0.9868852459016394 MRR 0.877643854376774 cur_rank 0 abs_cur_rank 0 total_num 304 865\n",
      "215 150\n",
      "215 70 817\n",
      "checkcorrect 54 54 real score 1.8560466706752776 Hits@1 0.8104575163398693 Hits@3 0.934640522875817 Hits@10 0.9869281045751634 MRR 0.8780437110618172 cur_rank 0 abs_cur_rank 0 total_num 305 865\n",
      "215 150\n",
      "215 487 654\n",
      "checkcorrect 50 50 real score 1.9348934233188628 Hits@1 0.8110749185667753 Hits@3 0.9348534201954397 Hits@10 0.9869706840390879 MRR 0.8784409628173161 cur_rank 0 abs_cur_rank 0 total_num 306 865\n",
      "215 150\n",
      "215 32 837\n",
      "checkcorrect 88 88 real score 1.9757021844387053 Hits@1 0.8116883116883117 Hits@3 0.935064935064935 Hits@10 0.987012987012987 MRR 0.8788356350159612 cur_rank 0 abs_cur_rank 0 total_num 307 865\n",
      "215 150\n",
      "215 399 802\n",
      "checkcorrect 20 20 real score 1.9260672986507417 Hits@1 0.8122977346278317 Hits@3 0.9352750809061489 Hits@10 0.9870550161812298 MRR 0.8792277527019937 cur_rank 0 abs_cur_rank 0 total_num 308 865\n",
      "215 77\n",
      "215 10 105\n",
      "checkcorrect 40 40 real score 1.7017300903797148 Hits@1 0.8129032258064516 Hits@3 0.9354838709677419 Hits@10 0.9870967741935484 MRR 0.8796173405965034 cur_rank 0 abs_cur_rank 0 total_num 309 865\n",
      "215 19\n",
      "215 329 193\n",
      "checkcorrect 24 24 real score 1.4415462791919706 Hits@1 0.8102893890675241 Hits@3 0.932475884244373 Hits@10 0.9871382636655949 MRR 0.877592847539923 cur_rank 3 abs_cur_rank 4 total_num 310 865\n",
      "215 150\n",
      "215 292 753\n",
      "checkcorrect 44 44 real score 1.8483353793621062 Hits@1 0.8108974358974359 Hits@3 0.9326923076923077 Hits@10 0.9871794871794872 MRR 0.8779851781567822 cur_rank 0 abs_cur_rank 0 total_num 311 865\n",
      "215 150\n",
      "215 894 522\n",
      "checkcorrect 16 16 real score 1.9681053161621094 Hits@1 0.8115015974440895 Hits@3 0.9329073482428115 Hits@10 0.987220447284345 MRR 0.8783750018687414 cur_rank 0 abs_cur_rank 0 total_num 312 865\n",
      "215 44\n",
      "215 356 105\n",
      "checkcorrect 16 16 real score 1.963133692741394 Hits@1 0.8121019108280255 Hits@3 0.9331210191082803 Hits@10 0.9872611464968153 MRR 0.8787623426271212 cur_rank 0 abs_cur_rank 0 total_num 313 865\n",
      "215 85\n",
      "215 142 75\n",
      "checkcorrect 108 108 real score 1.9380422830581665 Hits@1 0.8126984126984127 Hits@3 0.9333333333333333 Hits@10 0.9873015873015873 MRR 0.8791472240790986 cur_rank 0 abs_cur_rank 0 total_num 314 865\n",
      "215 150\n",
      "215 132 941\n",
      "checkcorrect 20 20 real score 1.8909370720386505 Hits@1 0.8132911392405063 Hits@3 0.9335443037974683 Hits@10 0.9873417721518988 MRR 0.8795296695725192 cur_rank 0 abs_cur_rank 0 total_num 315 865\n",
      "215 106\n",
      "215 469 115\n",
      "checkcorrect 132 132 real score 1.193103763461113 Hits@1 0.8107255520504731 Hits@3 0.9305993690851735 Hits@10 0.9873817034700315 MRR 0.8773860428546247 cur_rank 4 abs_cur_rank 4 total_num 316 865\n",
      "215 9\n",
      "215 15 12\n",
      "checkcorrect 36 36 real score 1.7795388042926787 Hits@1 0.8113207547169812 Hits@3 0.9308176100628931 Hits@10 0.9874213836477987 MRR 0.877771621336214 cur_rank 0 abs_cur_rank 1 total_num 317 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 35 342\n",
      "checkcorrect 108 108 real score 1.9267534255981444 Hits@1 0.8119122257053292 Hits@3 0.9310344827586207 Hits@10 0.987460815047022 MRR 0.8781547823978559 cur_rank 0 abs_cur_rank 0 total_num 318 865\n",
      "215 150\n",
      "215 434 1557\n",
      "checkcorrect 100 100 real score 1.8741951823234557 Hits@1 0.8125 Hits@3 0.93125 Hits@10 0.9875 MRR 0.8785355487028627 cur_rank 0 abs_cur_rank 0 total_num 319 865\n",
      "215 149\n",
      "215 418 494\n",
      "checkcorrect 266 266 real score 1.871802669763565 Hits@1 0.8130841121495327 Hits@3 0.9314641744548287 Hits@10 0.9875389408099688 MRR 0.8789139426321372 cur_rank 0 abs_cur_rank 2 total_num 320 865\n",
      "215 150\n",
      "215 968 1013\n",
      "checkcorrect 16 16 real score 1.9387134611606598 Hits@1 0.8136645962732919 Hits@3 0.9316770186335404 Hits@10 0.9875776397515528 MRR 0.8792899862885591 cur_rank 0 abs_cur_rank 0 total_num 321 865\n",
      "215 150\n",
      "215 26 803\n",
      "checkcorrect 20 20 real score 1.7150285065174102 Hits@1 0.8142414860681114 Hits@3 0.9318885448916409 Hits@10 0.9876160990712074 MRR 0.879663701501288 cur_rank 0 abs_cur_rank 0 total_num 322 865\n",
      "215 150\n",
      "215 278 827\n",
      "checkcorrect 56 56 real score 1.8970153987407685 Hits@1 0.8148148148148148 Hits@3 0.9320987654320988 Hits@10 0.9876543209876543 MRR 0.8800351098299878 cur_rank 0 abs_cur_rank 0 total_num 323 865\n",
      "215 62\n",
      "215 184 803\n",
      "checkcorrect 226 226 real score 1.0484486281871797 Hits@1 0.8123076923076923 Hits@3 0.9292307692307692 Hits@10 0.9876923076923076 MRR 0.8780965402612801 cur_rank 3 abs_cur_rank 3 total_num 324 865\n",
      "215 113\n",
      "215 438 206\n",
      "checkcorrect 16 16 real score 1.9689308285713196 Hits@1 0.8128834355828221 Hits@3 0.9294478527607362 Hits@10 0.9877300613496932 MRR 0.8784704772543437 cur_rank 0 abs_cur_rank 0 total_num 325 865\n",
      "215 55\n",
      "215 160 191\n",
      "checkcorrect 50 50 real score 1.7678920447826387 Hits@1 0.8134556574923547 Hits@3 0.9296636085626911 Hits@10 0.9877675840978594 MRR 0.8788421271709971 cur_rank 0 abs_cur_rank 0 total_num 326 865\n",
      "215 150\n",
      "215 73 714\n",
      "checkcorrect 4 4 real score 1.8458458483219147 Hits@1 0.8140243902439024 Hits@3 0.9298780487804879 Hits@10 0.9878048780487805 MRR 0.8792115109296221 cur_rank 0 abs_cur_rank 0 total_num 327 865\n",
      "215 150\n",
      "215 142 115\n",
      "checkcorrect 108 108 real score 1.9438798069953918 Hits@1 0.8145896656534954 Hits@3 0.9300911854103343 Hits@10 0.9878419452887538 MRR 0.8795786491942736 cur_rank 0 abs_cur_rank 0 total_num 328 865\n",
      "215 133\n",
      "215 892 177\n",
      "checkcorrect 16 16 real score 1.9506873726844787 Hits@1 0.8151515151515152 Hits@3 0.9303030303030303 Hits@10 0.9878787878787879 MRR 0.8799435623785334 cur_rank 0 abs_cur_rank 0 total_num 329 865\n",
      "215 115\n",
      "215 250 161\n",
      "checkcorrect 108 108 real score 1.681858018040657 Hits@1 0.8157099697885196 Hits@3 0.9305135951661632 Hits@10 0.9879154078549849 MRR 0.8803062706492932 cur_rank 0 abs_cur_rank 0 total_num 330 865\n",
      "215 150\n",
      "215 71 713\n",
      "checkcorrect 54 54 real score 1.9522921860218048 Hits@1 0.8162650602409639 Hits@3 0.9307228915662651 Hits@10 0.9879518072289156 MRR 0.88066679393047 cur_rank 0 abs_cur_rank 0 total_num 331 865\n",
      "0 1\n",
      "0 1 1\n",
      "checkcorrect 242 242 real score 0.0 Hits@1 0.8138138138138138 Hits@3 0.9279279279279279 Hits@10 0.984984984984985 MRR 0.878046763682365 cur_rank 121 abs_cur_rank 121 total_num 332 865\n",
      "215 150\n",
      "215 377 1583\n",
      "checkcorrect 34 34 real score 1.782257115840912 Hits@1 0.8143712574850299 Hits@3 0.9281437125748503 Hits@10 0.9850299401197605 MRR 0.8784118931324177 cur_rank 0 abs_cur_rank 1 total_num 333 865\n",
      "215 112\n",
      "215 63 47\n",
      "checkcorrect 54 54 real score 1.8913763582706453 Hits@1 0.8149253731343283 Hits@3 0.9283582089552239 Hits@10 0.9850746268656716 MRR 0.8787748427051568 cur_rank 0 abs_cur_rank 0 total_num 334 865\n",
      "215 128\n",
      "215 200 215\n",
      "checkcorrect 24 24 real score 1.8196449846029281 Hits@1 0.8154761904761905 Hits@3 0.9285714285714286 Hits@10 0.9851190476190477 MRR 0.8791356318637724 cur_rank 0 abs_cur_rank 1 total_num 335 865\n",
      "215 150\n",
      "215 159 757\n",
      "checkcorrect 4 4 real score 1.8527045607566834 Hits@1 0.8160237388724035 Hits@3 0.9287833827893175 Hits@10 0.9851632047477745 MRR 0.8794942798404378 cur_rank 0 abs_cur_rank 0 total_num 336 865\n",
      "215 29\n",
      "215 192 192\n",
      "checkcorrect 46 46 real score 1.5969626218080522 Hits@1 0.8165680473372781 Hits@3 0.9289940828402367 Hits@10 0.985207100591716 MRR 0.8798508056397264 cur_rank 0 abs_cur_rank 0 total_num 337 865\n",
      "215 20\n",
      "215 617 26\n",
      "checkcorrect 100 100 real score 1.8609434425830842 Hits@1 0.8171091445427728 Hits@3 0.9292035398230089 Hits@10 0.9852507374631269 MRR 0.8802052280419691 cur_rank 0 abs_cur_rank 0 total_num 338 865\n",
      "215 122\n",
      "215 599 477\n",
      "checkcorrect 10 10 real score 1.8624472796916962 Hits@1 0.8176470588235294 Hits@3 0.9294117647058824 Hits@10 0.9852941176470589 MRR 0.8805575656065516 cur_rank 0 abs_cur_rank 0 total_num 339 865\n",
      "215 150\n",
      "215 491 165\n",
      "checkcorrect 176 176 real score 1.9649099171161652 Hits@1 0.8152492668621701 Hits@3 0.9296187683284457 Hits@10 0.9853372434017595 MRR 0.87944156101533 cur_rank 1 abs_cur_rank 1 total_num 340 865\n",
      "215 150\n",
      "215 488 492\n",
      "checkcorrect 176 176 real score 1.9653871834278105 Hits@1 0.8128654970760234 Hits@3 0.9298245614035088 Hits@10 0.9853801169590644 MRR 0.8783320827667471 cur_rank 1 abs_cur_rank 1 total_num 341 865\n",
      "215 41\n",
      "215 453 174\n",
      "checkcorrect 352 352 real score 1.2011826939880847 Hits@1 0.8104956268221575 Hits@3 0.9300291545189504 Hits@10 0.9854227405247813 MRR 0.877229073779089 cur_rank 1 abs_cur_rank 1 total_num 342 865\n",
      "215 150\n",
      "215 46 704\n",
      "checkcorrect 54 54 real score 1.8652933061122896 Hits@1 0.811046511627907 Hits@3 0.9302325581395349 Hits@10 0.9854651162790697 MRR 0.8775859660064754 cur_rank 0 abs_cur_rank 0 total_num 343 865\n",
      "215 150\n",
      "215 149 266\n",
      "checkcorrect 348 348 real score 1.573121079802513 Hits@1 0.8115942028985508 Hits@3 0.9304347826086956 Hits@10 0.9855072463768116 MRR 0.8779407892934131 cur_rank 0 abs_cur_rank 0 total_num 344 865\n",
      "215 150\n",
      "215 154 174\n",
      "checkcorrect 280 280 real score 1.8596867859363555 Hits@1 0.8092485549132948 Hits@3 0.930635838150289 Hits@10 0.9855491329479769 MRR 0.8768484748734899 cur_rank 1 abs_cur_rank 3 total_num 345 865\n",
      "215 56\n",
      "215 65 85\n",
      "checkcorrect 2 2 real score 1.5742034703493117 Hits@1 0.8097982708933718 Hits@3 0.930835734870317 Hits@10 0.9855907780979827 MRR 0.8772033784041139 cur_rank 0 abs_cur_rank 0 total_num 346 865\n",
      "215 126\n",
      "215 4 126\n",
      "checkcorrect 172 172 real score 1.8520179212093355 Hits@1 0.8103448275862069 Hits@3 0.9310344827586207 Hits@10 0.985632183908046 MRR 0.8775562422592745 cur_rank 0 abs_cur_rank 0 total_num 347 865\n",
      "215 150\n",
      "215 305 799\n",
      "checkcorrect 50 50 real score 1.7975998520851135 Hits@1 0.8080229226361032 Hits@3 0.9312320916905444 Hits@10 0.9856733524355301 MRR 0.8764744192155517 cur_rank 1 abs_cur_rank 1 total_num 348 865\n",
      "215 150\n",
      "215 344 317\n",
      "checkcorrect 46 46 real score 1.88755464553833 Hits@1 0.8085714285714286 Hits@3 0.9314285714285714 Hits@10 0.9857142857142858 MRR 0.8768273494463644 cur_rank 0 abs_cur_rank 0 total_num 349 865\n",
      "215 150\n",
      "215 197 1356\n",
      "checkcorrect 190 190 real score 1.3727622183971109 Hits@1 0.8062678062678063 Hits@3 0.9316239316239316 Hits@10 0.9857549857549858 MRR 0.8757537672542095 cur_rank 1 abs_cur_rank 1 total_num 350 865\n",
      "215 22\n",
      "215 176 148\n",
      "checkcorrect 50 50 real score 1.7387210458517073 Hits@1 0.8068181818181818 Hits@3 0.9318181818181818 Hits@10 0.9857954545454546 MRR 0.8761067395063282 cur_rank 0 abs_cur_rank 1 total_num 351 865\n",
      "215 150\n",
      "215 137 401\n",
      "checkcorrect 52 52 real score 1.87349311709404 Hits@1 0.8073654390934845 Hits@3 0.9320113314447592 Hits@10 0.9858356940509915 MRR 0.8764577119156587 cur_rank 0 abs_cur_rank 0 total_num 352 865\n",
      "215 35\n",
      "215 127 90\n",
      "checkcorrect 428 428 real score 0.7072377242147923 Hits@1 0.8050847457627118 Hits@3 0.9293785310734464 Hits@10 0.9858757062146892 MRR 0.8744526524658028 cur_rank 5 abs_cur_rank 7 total_num 353 865\n",
      "215 150\n",
      "215 201 176\n",
      "checkcorrect 26 26 real score 1.9442698538303376 Hits@1 0.8056338028169014 Hits@3 0.9295774647887324 Hits@10 0.9859154929577465 MRR 0.8748063069658992 cur_rank 0 abs_cur_rank 0 total_num 354 865\n",
      "215 150\n",
      "215 670 320\n",
      "checkcorrect 50 50 real score 1.7908556640148163 Hits@1 0.8033707865168539 Hits@3 0.9297752808988764 Hits@10 0.9859550561797753 MRR 0.8737534802609388 cur_rank 1 abs_cur_rank 1 total_num 355 865\n",
      "215 150\n",
      "215 373 861\n",
      "checkcorrect 54 54 real score 1.9037563621997833 Hits@1 0.803921568627451 Hits@3 0.9299719887955182 Hits@10 0.9859943977591037 MRR 0.8741071119688913 cur_rank 0 abs_cur_rank 0 total_num 356 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 875 266\n",
      "checkcorrect 348 348 real score 1.8737106025218964 Hits@1 0.8044692737430168 Hits@3 0.9301675977653632 Hits@10 0.9860335195530726 MRR 0.8744587680807101 cur_rank 0 abs_cur_rank 0 total_num 357 865\n",
      "215 142\n",
      "215 237 368\n",
      "checkcorrect 108 108 real score 1.8267555296421052 Hits@1 0.8050139275766016 Hits@3 0.9303621169916435 Hits@10 0.9860724233983287 MRR 0.8748084651055549 cur_rank 0 abs_cur_rank 0 total_num 358 865\n",
      "215 150\n",
      "215 304 1694\n",
      "checkcorrect 100 100 real score 1.8366643667221068 Hits@1 0.8055555555555556 Hits@3 0.9305555555555556 Hits@10 0.9861111111111112 MRR 0.8751562193691507 cur_rank 0 abs_cur_rank 0 total_num 359 865\n",
      "215 22\n",
      "215 52 64\n",
      "checkcorrect 394 394 real score 1.8833595097064972 Hits@1 0.8060941828254847 Hits@3 0.9307479224376731 Hits@10 0.9861495844875346 MRR 0.8755020470163275 cur_rank 0 abs_cur_rank 0 total_num 360 865\n",
      "215 150\n",
      "215 494 266\n",
      "checkcorrect 102 102 real score 1.9851734220981598 Hits@1 0.8066298342541437 Hits@3 0.930939226519337 Hits@10 0.9861878453038674 MRR 0.87584596401352 cur_rank 0 abs_cur_rank 0 total_num 361 865\n",
      "215 150\n",
      "215 582 336\n",
      "checkcorrect 10 10 real score 1.8574776291847228 Hits@1 0.8071625344352618 Hits@3 0.931129476584022 Hits@10 0.9862258953168044 MRR 0.8761879861512237 cur_rank 0 abs_cur_rank 0 total_num 362 865\n",
      "215 147\n",
      "215 460 401\n",
      "checkcorrect 20 20 real score 1.8812202572822572 Hits@1 0.8076923076923077 Hits@3 0.9313186813186813 Hits@10 0.9862637362637363 MRR 0.8765281290464126 cur_rank 0 abs_cur_rank 0 total_num 363 865\n",
      "215 36\n",
      "215 28 65\n",
      "checkcorrect 424 424 real score 0.26196715524420144 Hits@1 0.8054794520547945 Hits@3 0.9287671232876712 Hits@10 0.9835616438356164 MRR 0.8743374302734721 cur_rank 12 abs_cur_rank 12 total_num 364 865\n",
      "215 150\n",
      "215 765 477\n",
      "checkcorrect 16 16 real score 1.9519089221954347 Hits@1 0.8060109289617486 Hits@3 0.9289617486338798 Hits@10 0.9836065573770492 MRR 0.8746807706279162 cur_rank 0 abs_cur_rank 0 total_num 365 865\n",
      "215 80\n",
      "215 493 319\n",
      "checkcorrect 162 162 real score 1.4655789997428657 Hits@1 0.8065395095367848 Hits@3 0.9291553133514986 Hits@10 0.9836512261580381 MRR 0.8750222399177584 cur_rank 0 abs_cur_rank 0 total_num 366 865\n",
      "215 10\n",
      "215 115 22\n",
      "checkcorrect 2 2 real score 1.674721696972847 Hits@1 0.8043478260869565 Hits@3 0.9293478260869565 Hits@10 0.9836956521739131 MRR 0.8740031577440688 cur_rank 1 abs_cur_rank 1 total_num 367 865\n",
      "215 25\n",
      "215 514 53\n",
      "checkcorrect 162 162 real score 1.8088627338409424 Hits@1 0.8048780487804879 Hits@3 0.9295392953929539 Hits@10 0.983739837398374 MRR 0.8743446126011309 cur_rank 0 abs_cur_rank 0 total_num 368 865\n",
      "215 124\n",
      "215 238 424\n",
      "checkcorrect 156 156 real score 1.9214483380317688 Hits@1 0.8054054054054054 Hits@3 0.9297297297297298 Hits@10 0.9837837837837838 MRR 0.874684221756263 cur_rank 0 abs_cur_rank 0 total_num 369 865\n",
      "215 54\n",
      "215 131 120\n",
      "checkcorrect 50 50 real score 1.455857601761818 Hits@1 0.8032345013477089 Hits@3 0.9272237196765498 Hits@10 0.9838274932614556 MRR 0.8730004367919604 cur_rank 3 abs_cur_rank 3 total_num 370 865\n",
      "215 150\n",
      "215 28 781\n",
      "checkcorrect 4 4 real score 1.8590848326683045 Hits@1 0.803763440860215 Hits@3 0.9274193548387096 Hits@10 0.9838709677419355 MRR 0.8733418334672508 cur_rank 0 abs_cur_rank 0 total_num 371 865\n",
      "215 150\n",
      "215 63 804\n",
      "checkcorrect 84 84 real score 1.7720437526702881 Hits@1 0.8042895442359249 Hits@3 0.9276139410187667 Hits@10 0.9839142091152815 MRR 0.8736813995973655 cur_rank 0 abs_cur_rank 0 total_num 372 865\n",
      "215 150\n",
      "215 416 137\n",
      "checkcorrect 50 50 real score 1.520525647699833 Hits@1 0.8048128342245989 Hits@3 0.9278074866310161 Hits@10 0.983957219251337 MRR 0.8740191498658217 cur_rank 0 abs_cur_rank 0 total_num 373 865\n",
      "0 1\n",
      "215 170 25\n",
      "checkcorrect 24 24 real score 0.5604213148355484 Hits@1 0.8053333333333333 Hits@3 0.928 Hits@10 0.984 MRR 0.8743550987995128 cur_rank 0 abs_cur_rank 0 total_num 374 865\n",
      "215 9\n",
      "215 311 57\n",
      "checkcorrect 30 30 real score 1.7249139189720153 Hits@1 0.8058510638297872 Hits@3 0.9281914893617021 Hits@10 0.9840425531914894 MRR 0.8746892607707907 cur_rank 0 abs_cur_rank 0 total_num 375 865\n",
      "0 1\n",
      "215 3 575\n",
      "checkcorrect 54 54 real score 0.8479219675064087 Hits@1 0.8063660477453581 Hits@3 0.9283819628647215 Hits@10 0.9840848806366048 MRR 0.8750216499995154 cur_rank 0 abs_cur_rank 0 total_num 376 865\n",
      "215 130\n",
      "215 188 475\n",
      "checkcorrect 50 50 real score 1.822172999382019 Hits@1 0.8068783068783069 Hits@3 0.9285714285714286 Hits@10 0.9841269841269841 MRR 0.8753522805550723 cur_rank 0 abs_cur_rank 0 total_num 377 865\n",
      "215 145\n",
      "215 216 367\n",
      "checkcorrect 126 126 real score 1.6995641320943833 Hits@1 0.8047493403693932 Hits@3 0.9261213720316622 Hits@10 0.9841688654353562 MRR 0.8735703484164045 cur_rank 4 abs_cur_rank 4 total_num 378 865\n",
      "215 150\n",
      "215 159 584\n",
      "checkcorrect 158 158 real score 1.8915127873420716 Hits@1 0.8052631578947368 Hits@3 0.9263157894736842 Hits@10 0.9842105263157894 MRR 0.873903058025835 cur_rank 0 abs_cur_rank 0 total_num 379 865\n",
      "215 41\n",
      "215 225 60\n",
      "checkcorrect 74 74 real score 1.6895993173122406 Hits@1 0.8057742782152231 Hits@3 0.926509186351706 Hits@10 0.984251968503937 MRR 0.8742340211281294 cur_rank 0 abs_cur_rank 0 total_num 380 865\n",
      "215 134\n",
      "215 193 320\n",
      "checkcorrect 22 22 real score 1.9385872185230255 Hits@1 0.806282722513089 Hits@3 0.9267015706806283 Hits@10 0.9842931937172775 MRR 0.8745632514393124 cur_rank 0 abs_cur_rank 0 total_num 381 865\n",
      "215 106\n",
      "215 280 45\n",
      "checkcorrect 172 172 real score 1.9179738581180572 Hits@1 0.8067885117493473 Hits@3 0.9268929503916449 Hits@10 0.9843342036553525 MRR 0.87489076253216 cur_rank 0 abs_cur_rank 0 total_num 382 865\n",
      "215 3\n",
      "215 3 3\n",
      "checkcorrect 82 82 real score 1.9909754693508148 Hits@1 0.8072916666666666 Hits@3 0.9270833333333334 Hits@10 0.984375 MRR 0.8752165678380659 cur_rank 0 abs_cur_rank 0 total_num 383 865\n",
      "215 133\n",
      "215 207 252\n",
      "checkcorrect 108 108 real score 1.9418677628040313 Hits@1 0.8077922077922078 Hits@3 0.9272727272727272 Hits@10 0.9844155844155844 MRR 0.8755406806488761 cur_rank 0 abs_cur_rank 0 total_num 384 865\n",
      "215 100\n",
      "215 124 395\n",
      "checkcorrect 46 46 real score 1.8431872189044953 Hits@1 0.8082901554404145 Hits@3 0.927461139896373 Hits@10 0.9844559585492227 MRR 0.8758631141186977 cur_rank 0 abs_cur_rank 0 total_num 385 865\n",
      "215 3\n",
      "215 3 3\n",
      "checkcorrect 82 82 real score 1.990975522994995 Hits@1 0.8087855297157622 Hits@3 0.9276485788113695 Hits@10 0.9844961240310077 MRR 0.8761838812656778 cur_rank 0 abs_cur_rank 0 total_num 386 865\n",
      "215 66\n",
      "215 114 92\n",
      "checkcorrect 2 2 real score 1.8711474597454072 Hits@1 0.8092783505154639 Hits@3 0.9278350515463918 Hits@10 0.9845360824742269 MRR 0.8765029949737559 cur_rank 0 abs_cur_rank 0 total_num 387 865\n",
      "215 150\n",
      "215 112 827\n",
      "checkcorrect 54 54 real score 1.8819078326225283 Hits@1 0.8097686375321337 Hits@3 0.9280205655526992 Hits@10 0.9845758354755784 MRR 0.876820467994389 cur_rank 0 abs_cur_rank 0 total_num 388 865\n",
      "215 150\n",
      "215 262 266\n",
      "checkcorrect 348 348 real score 1.7769679695367813 Hits@1 0.8102564102564103 Hits@3 0.9282051282051282 Hits@10 0.9846153846153847 MRR 0.8771363129482495 cur_rank 0 abs_cur_rank 0 total_num 389 865\n",
      "215 47\n",
      "215 280 43\n",
      "checkcorrect 172 172 real score 1.917419195175171 Hits@1 0.8107416879795396 Hits@3 0.928388746803069 Hits@10 0.9846547314578005 MRR 0.8774505423268985 cur_rank 0 abs_cur_rank 0 total_num 390 865\n",
      "215 69\n",
      "215 540 142\n",
      "checkcorrect 26 26 real score 1.957553321123123 Hits@1 0.8112244897959183 Hits@3 0.9285714285714286 Hits@10 0.9846938775510204 MRR 0.8777631684944319 cur_rank 0 abs_cur_rank 0 total_num 391 865\n",
      "215 150\n",
      "215 215 384\n",
      "checkcorrect 52 52 real score 1.8582572281360625 Hits@1 0.811704834605598 Hits@3 0.9287531806615776 Hits@10 0.9847328244274809 MRR 0.8780742036891026 cur_rank 0 abs_cur_rank 0 total_num 392 865\n",
      "215 125\n",
      "215 212 73\n",
      "checkcorrect 108 108 real score 1.9473382890224458 Hits@1 0.8121827411167513 Hits@3 0.9289340101522843 Hits@10 0.9847715736040609 MRR 0.878383660024917 cur_rank 0 abs_cur_rank 0 total_num 393 865\n",
      "215 48\n",
      "215 142 58\n",
      "checkcorrect 108 108 real score 1.7783440470695495 Hits@1 0.8126582278481013 Hits@3 0.9291139240506329 Hits@10 0.9848101265822785 MRR 0.8786915494932084 cur_rank 0 abs_cur_rank 0 total_num 394 865\n",
      "215 150\n",
      "215 362 712\n",
      "checkcorrect 4 4 real score 1.872601491212845 Hits@1 0.8131313131313131 Hits@3 0.9292929292929293 Hits@10 0.9848484848484849 MRR 0.8789978839641851 cur_rank 0 abs_cur_rank 0 total_num 395 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 202 132\n",
      "checkcorrect 138 138 real score 1.984178513288498 Hits@1 0.8136020151133502 Hits@3 0.929471032745592 Hits@10 0.9848866498740554 MRR 0.8793026751884567 cur_rank 0 abs_cur_rank 0 total_num 396 865\n",
      "215 150\n",
      "215 66 69\n",
      "checkcorrect 420 420 real score 1.7115747451782226 Hits@1 0.8140703517587939 Hits@3 0.9296482412060302 Hits@10 0.9849246231155779 MRR 0.879605934798536 cur_rank 0 abs_cur_rank 0 total_num 397 865\n",
      "0 1\n",
      "215 7 5\n",
      "checkcorrect 242 242 real score 0.872111052274704 Hits@1 0.8145363408521303 Hits@3 0.9298245614035088 Hits@10 0.9849624060150376 MRR 0.879907674310319 cur_rank 0 abs_cur_rank 0 total_num 398 865\n",
      "215 150\n",
      "215 225 1500\n",
      "checkcorrect 264 264 real score 1.5736854016780852 Hits@1 0.8125 Hits@3 0.9275 Hits@10 0.985 MRR 0.8782079051245433 cur_rank 4 abs_cur_rank 4 total_num 399 865\n",
      "215 126\n",
      "215 322 223\n",
      "checkcorrect 312 312 real score 1.0014358490705488 Hits@1 0.8104738154613467 Hits@3 0.9251870324189526 Hits@10 0.9850374064837906 MRR 0.8762672370319634 cur_rank 9 abs_cur_rank 9 total_num 400 865\n",
      "215 150\n",
      "215 671 514\n",
      "checkcorrect 2 2 real score 1.8641642332077026 Hits@1 0.8109452736318408 Hits@3 0.9253731343283582 Hits@10 0.9850746268656716 MRR 0.87657502997467 cur_rank 0 abs_cur_rank 0 total_num 401 865\n",
      "0 1\n",
      "215 28 122\n",
      "checkcorrect 24 24 real score 0.724100598692894 Hits@1 0.8089330024813896 Hits@3 0.9255583126550868 Hits@10 0.9851116625310173 MRR 0.8756406006198941 cur_rank 1 abs_cur_rank 1 total_num 402 865\n",
      "215 150\n",
      "215 95 402\n",
      "checkcorrect 20 20 real score 1.8189597189426423 Hits@1 0.8094059405940595 Hits@3 0.9257425742574258 Hits@10 0.9851485148514851 MRR 0.8759484209153894 cur_rank 0 abs_cur_rank 0 total_num 403 865\n",
      "215 144\n",
      "215 318 203\n",
      "checkcorrect 2 2 real score 1.803560072183609 Hits@1 0.8098765432098766 Hits@3 0.9259259259259259 Hits@10 0.9851851851851852 MRR 0.87625472111066 cur_rank 0 abs_cur_rank 0 total_num 404 865\n",
      "215 83\n",
      "215 105 108\n",
      "checkcorrect 358 358 real score 1.5328267008066176 Hits@1 0.8103448275862069 Hits@3 0.9261083743842364 Hits@10 0.9852216748768473 MRR 0.8765595124379737 cur_rank 0 abs_cur_rank 0 total_num 405 865\n",
      "215 150\n",
      "215 492 452\n",
      "checkcorrect 162 162 real score 1.824066197872162 Hits@1 0.8108108108108109 Hits@3 0.9262899262899262 Hits@10 0.9852579852579852 MRR 0.8768628060192072 cur_rank 0 abs_cur_rank 0 total_num 406 865\n",
      "215 122\n",
      "215 459 286\n",
      "checkcorrect 50 50 real score 1.8821202993392945 Hits@1 0.8088235294117647 Hits@3 0.9264705882352942 Hits@10 0.9852941176470589 MRR 0.8759391226711208 cur_rank 1 abs_cur_rank 1 total_num 407 865\n",
      "215 84\n",
      "215 805 89\n",
      "checkcorrect 268 268 real score 1.3397984504699707 Hits@1 0.8068459657701712 Hits@3 0.9242053789731052 Hits@10 0.9853300733496333 MRR 0.8742049601870024 cur_rank 5 abs_cur_rank 5 total_num 408 865\n",
      "215 6\n",
      "215 175 118\n",
      "checkcorrect 24 24 real score 1.2782328695058824 Hits@1 0.8048780487804879 Hits@3 0.9219512195121952 Hits@10 0.9853658536585366 MRR 0.8724792570320749 cur_rank 5 abs_cur_rank 6 total_num 409 865\n",
      "215 90\n",
      "215 395 113\n",
      "checkcorrect 34 34 real score 1.83433712720871 Hits@1 0.805352798053528 Hits@3 0.9221411192214112 Hits@10 0.9854014598540146 MRR 0.8727895264796853 cur_rank 0 abs_cur_rank 1 total_num 410 865\n",
      "215 113\n",
      "215 367 257\n",
      "checkcorrect 26 26 real score 1.955520361661911 Hits@1 0.8058252427184466 Hits@3 0.9223300970873787 Hits@10 0.9854368932038835 MRR 0.8730982897649289 cur_rank 0 abs_cur_rank 0 total_num 411 865\n",
      "215 150\n",
      "215 643 804\n",
      "checkcorrect 44 44 real score 1.8721336662769317 Hits@1 0.8062953995157385 Hits@3 0.9225181598062954 Hits@10 0.9854721549636803 MRR 0.873405557828452 cur_rank 0 abs_cur_rank 0 total_num 412 865\n",
      "215 11\n",
      "215 76 44\n",
      "checkcorrect 50 50 real score 1.5354899346828461 Hits@1 0.8043478260869565 Hits@3 0.9202898550724637 Hits@10 0.9855072463768116 MRR 0.8718997473022964 cur_rank 3 abs_cur_rank 3 total_num 413 865\n",
      "215 150\n",
      "215 267 758\n",
      "checkcorrect 4 4 real score 1.860236632823944 Hits@1 0.8048192771084337 Hits@3 0.9204819277108434 Hits@10 0.9855421686746988 MRR 0.8722084226100016 cur_rank 0 abs_cur_rank 0 total_num 414 865\n",
      "215 150\n",
      "215 756 364\n",
      "checkcorrect 16 16 real score 1.9246480882167818 Hits@1 0.8052884615384616 Hits@3 0.9206730769230769 Hits@10 0.9855769230769231 MRR 0.8725156139018045 cur_rank 0 abs_cur_rank 0 total_num 415 865\n",
      "215 111\n",
      "215 240 112\n",
      "checkcorrect 74 74 real score 1.8347079277038574 Hits@1 0.8057553956834532 Hits@3 0.920863309352518 Hits@10 0.9856115107913669 MRR 0.8728213318540784 cur_rank 0 abs_cur_rank 0 total_num 416 865\n",
      "215 150\n",
      "215 891 542\n",
      "checkcorrect 52 52 real score 1.9421676814556121 Hits@1 0.80622009569378 Hits@3 0.9210526315789473 Hits@10 0.9856459330143541 MRR 0.8731255870410304 cur_rank 0 abs_cur_rank 0 total_num 417 865\n",
      "215 150\n",
      "215 1209 1455\n",
      "checkcorrect 100 100 real score 1.8707405209541321 Hits@1 0.8066825775656324 Hits@3 0.9212410501193318 Hits@10 0.9856801909307876 MRR 0.8734283899359205 cur_rank 0 abs_cur_rank 0 total_num 418 865\n",
      "215 100\n",
      "215 195 198\n",
      "checkcorrect 26 26 real score 1.9313430905342102 Hits@1 0.8071428571428572 Hits@3 0.9214285714285714 Hits@10 0.9857142857142858 MRR 0.8737297509122636 cur_rank 0 abs_cur_rank 0 total_num 419 865\n",
      "215 3\n",
      "215 3 3\n",
      "checkcorrect 82 82 real score 1.9909755408763885 Hits@1 0.8076009501187649 Hits@3 0.9216152019002375 Hits@10 0.9857482185273159 MRR 0.8740296802450135 cur_rank 0 abs_cur_rank 0 total_num 420 865\n",
      "215 147\n",
      "215 174 130\n",
      "checkcorrect 138 138 real score 1.9841793775558472 Hits@1 0.8080568720379147 Hits@3 0.9218009478672986 Hits@10 0.985781990521327 MRR 0.8743281881117315 cur_rank 0 abs_cur_rank 0 total_num 421 865\n",
      "215 139\n",
      "215 81 185\n",
      "checkcorrect 220 220 real score 1.8365996152162551 Hits@1 0.8085106382978723 Hits@3 0.9219858156028369 Hits@10 0.9858156028368794 MRR 0.8746252845937369 cur_rank 0 abs_cur_rank 0 total_num 422 865\n",
      "215 150\n",
      "215 884 909\n",
      "checkcorrect 54 54 real score 1.929027533531189 Hits@1 0.8089622641509434 Hits@3 0.9221698113207547 Hits@10 0.9858490566037735 MRR 0.8749209796772421 cur_rank 0 abs_cur_rank 0 total_num 423 865\n",
      "215 73\n",
      "215 567 198\n",
      "checkcorrect 302 302 real score 1.6980638444423675 Hits@1 0.8070588235294117 Hits@3 0.9223529411764706 Hits@10 0.9858823529411764 MRR 0.874038812666237 cur_rank 1 abs_cur_rank 2 total_num 424 865\n",
      "215 150\n",
      "215 388 278\n",
      "checkcorrect 16 16 real score 1.9223475337028502 Hits@1 0.8075117370892019 Hits@3 0.9225352112676056 Hits@10 0.9859154929577465 MRR 0.874334496204579 cur_rank 0 abs_cur_rank 0 total_num 425 865\n",
      "215 150\n",
      "215 48 784\n",
      "checkcorrect 4 4 real score 1.8356822013854979 Hits@1 0.8079625292740047 Hits@3 0.9227166276346604 Hits@10 0.9859484777517564 MRR 0.8746287948083155 cur_rank 0 abs_cur_rank 0 total_num 426 865\n",
      "215 91\n",
      "215 485 45\n",
      "checkcorrect 346 346 real score 1.8111048638820648 Hits@1 0.8060747663551402 Hits@3 0.9228971962616822 Hits@10 0.985981308411215 MRR 0.8737534938858661 cur_rank 1 abs_cur_rank 1 total_num 427 865\n",
      "215 150\n",
      "215 61 795\n",
      "checkcorrect 54 54 real score 1.9308860063552857 Hits@1 0.8065268065268065 Hits@3 0.9230769230769231 Hits@10 0.986013986013986 MRR 0.874047774785899 cur_rank 0 abs_cur_rank 0 total_num 428 865\n",
      "215 140\n",
      "215 207 199\n",
      "checkcorrect 46 46 real score 1.874392569065094 Hits@1 0.8069767441860465 Hits@3 0.9232558139534883 Hits@10 0.986046511627907 MRR 0.8743406869375597 cur_rank 0 abs_cur_rank 0 total_num 429 865\n",
      "215 7\n",
      "215 12 47\n",
      "checkcorrect 132 132 real score 1.8887340605258942 Hits@1 0.8074245939675174 Hits@3 0.9234338747099768 Hits@10 0.9860788863109049 MRR 0.874632239868099 cur_rank 0 abs_cur_rank 0 total_num 430 865\n",
      "215 123\n",
      "215 15 84\n",
      "checkcorrect 108 108 real score 1.9418228685855867 Hits@1 0.8078703703703703 Hits@3 0.9236111111111112 Hits@10 0.9861111111111112 MRR 0.8749224430165525 cur_rank 0 abs_cur_rank 0 total_num 431 865\n",
      "215 123\n",
      "215 10 901\n",
      "checkcorrect 54 54 real score 1.8991734564304352 Hits@1 0.8083140877598153 Hits@3 0.9237875288683602 Hits@10 0.9861431870669746 MRR 0.8752113057347591 cur_rank 0 abs_cur_rank 0 total_num 432 865\n",
      "215 144\n",
      "215 608 546\n",
      "checkcorrect 52 52 real score 1.931679892539978 Hits@1 0.8087557603686636 Hits@3 0.923963133640553 Hits@10 0.9861751152073732 MRR 0.8754988372883656 cur_rank 0 abs_cur_rank 0 total_num 433 865\n",
      "215 150\n",
      "215 898 652\n",
      "checkcorrect 46 46 real score 1.8644798815250396 Hits@1 0.8068965517241379 Hits@3 0.9241379310344827 Hits@10 0.9862068965517241 MRR 0.8746356215704614 cur_rank 1 abs_cur_rank 1 total_num 434 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 71\n",
      "215 212 131\n",
      "checkcorrect 60 60 real score 1.5117698460817337 Hits@1 0.8073394495412844 Hits@3 0.9243119266055045 Hits@10 0.9862385321100917 MRR 0.8749231545485108 cur_rank 0 abs_cur_rank 0 total_num 435 865\n",
      "215 150\n",
      "215 425 286\n",
      "checkcorrect 50 50 real score 1.9355184972286223 Hits@1 0.8077803203661327 Hits@3 0.9244851258581236 Hits@10 0.9862700228832952 MRR 0.8752093715861572 cur_rank 0 abs_cur_rank 1 total_num 436 865\n",
      "215 150\n",
      "215 559 476\n",
      "checkcorrect 24 24 real score 1.925349771976471 Hits@1 0.8082191780821918 Hits@3 0.9246575342465754 Hits@10 0.9863013698630136 MRR 0.8754942816966911 cur_rank 0 abs_cur_rank 0 total_num 437 865\n",
      "215 145\n",
      "215 119 170\n",
      "checkcorrect 420 420 real score 1.7397895991802215 Hits@1 0.8086560364464692 Hits@3 0.9248291571753986 Hits@10 0.9863325740318907 MRR 0.8757778938112772 cur_rank 0 abs_cur_rank 0 total_num 438 865\n",
      "215 4\n",
      "215 244 35\n",
      "checkcorrect 100 100 real score 1.9068901002407075 Hits@1 0.8090909090909091 Hits@3 0.925 Hits@10 0.9863636363636363 MRR 0.8760602167798879 cur_rank 0 abs_cur_rank 0 total_num 439 865\n",
      "215 150\n",
      "215 492 378\n",
      "checkcorrect 46 46 real score 1.8885789811611176 Hits@1 0.8095238095238095 Hits@3 0.9251700680272109 Hits@10 0.9863945578231292 MRR 0.8763412593722237 cur_rank 0 abs_cur_rank 0 total_num 440 865\n",
      "215 104\n",
      "215 127 174\n",
      "checkcorrect 168 168 real score 1.9573451280593872 Hits@1 0.8076923076923077 Hits@3 0.9253393665158371 Hits@10 0.9864253393665159 MRR 0.8754898085591645 cur_rank 1 abs_cur_rank 1 total_num 441 865\n",
      "215 114\n",
      "215 102 126\n",
      "checkcorrect 44 44 real score 1.5378250122070312 Hits@1 0.8081264108352144 Hits@3 0.9255079006772009 Hits@10 0.9864559819413092 MRR 0.875770869939392 cur_rank 0 abs_cur_rank 0 total_num 442 865\n",
      "215 150\n",
      "215 613 650\n",
      "checkcorrect 16 16 real score 1.9464996814727784 Hits@1 0.8085585585585585 Hits@3 0.9256756756756757 Hits@10 0.9864864864864865 MRR 0.8760506652773664 cur_rank 0 abs_cur_rank 0 total_num 443 865\n",
      "215 150\n",
      "215 175 407\n",
      "checkcorrect 26 26 real score 1.9223905563354493 Hits@1 0.8089887640449438 Hits@3 0.9258426966292135 Hits@10 0.9865168539325843 MRR 0.8763292031082038 cur_rank 0 abs_cur_rank 0 total_num 444 865\n",
      "215 27\n",
      "215 33 69\n",
      "checkcorrect 24 24 real score 1.7535685658454896 Hits@1 0.8094170403587444 Hits@3 0.9260089686098655 Hits@10 0.9865470852017937 MRR 0.8766064918904724 cur_rank 0 abs_cur_rank 1 total_num 445 865\n",
      "215 127\n",
      "215 26 224\n",
      "checkcorrect 42 42 real score 1.4597833514213563 Hits@1 0.8098434004474273 Hits@3 0.9261744966442953 Hits@10 0.9865771812080537 MRR 0.8768825400070485 cur_rank 0 abs_cur_rank 0 total_num 446 865\n",
      "215 12\n",
      "215 75 45\n",
      "checkcorrect 20 20 real score 1.84764284491539 Hits@1 0.8102678571428571 Hits@3 0.9263392857142857 Hits@10 0.9866071428571429 MRR 0.8771573557659613 cur_rank 0 abs_cur_rank 0 total_num 447 865\n",
      "215 141\n",
      "215 437 362\n",
      "checkcorrect 24 24 real score 1.9367504239082336 Hits@1 0.8106904231625836 Hits@3 0.9265033407572383 Hits@10 0.9866369710467706 MRR 0.8774309474012265 cur_rank 0 abs_cur_rank 1 total_num 448 865\n",
      "215 150\n",
      "215 221 259\n",
      "checkcorrect 232 232 real score 1.9308950304985046 Hits@1 0.8111111111111111 Hits@3 0.9266666666666666 Hits@10 0.9866666666666667 MRR 0.8777033230736682 cur_rank 0 abs_cur_rank 1 total_num 449 865\n",
      "215 149\n",
      "215 454 333\n",
      "checkcorrect 50 50 real score 1.8464983642101287 Hits@1 0.811529933481153 Hits@3 0.926829268292683 Hits@10 0.9866962305986696 MRR 0.877974490871731 cur_rank 0 abs_cur_rank 0 total_num 450 865\n",
      "215 150\n",
      "215 671 676\n",
      "checkcorrect 50 50 real score 1.9250422656536101 Hits@1 0.8119469026548672 Hits@3 0.9269911504424779 Hits@10 0.9867256637168141 MRR 0.8782444588122803 cur_rank 0 abs_cur_rank 1 total_num 451 865\n",
      "215 104\n",
      "215 639 179\n",
      "checkcorrect 78 78 real score 1.839927089214325 Hits@1 0.8123620309050773 Hits@3 0.9271523178807947 Hits@10 0.9867549668874173 MRR 0.8785132348413922 cur_rank 0 abs_cur_rank 0 total_num 452 865\n",
      "215 150\n",
      "215 490 1484\n",
      "checkcorrect 34 34 real score 1.8128129065036773 Hits@1 0.8127753303964758 Hits@3 0.9273127753303965 Hits@10 0.986784140969163 MRR 0.8787808268351337 cur_rank 0 abs_cur_rank 1 total_num 453 865\n",
      "215 150\n",
      "215 127 499\n",
      "checkcorrect 78 78 real score 1.9649893045425415 Hits@1 0.8131868131868132 Hits@3 0.9274725274725275 Hits@10 0.9868131868131869 MRR 0.8790472426003312 cur_rank 0 abs_cur_rank 0 total_num 454 865\n",
      "215 90\n",
      "215 468 601\n",
      "checkcorrect 24 24 real score 1.8509824573993683 Hits@1 0.8135964912280702 Hits@3 0.9276315789473685 Hits@10 0.9868421052631579 MRR 0.8793124898753305 cur_rank 0 abs_cur_rank 1 total_num 455 865\n",
      "215 99\n",
      "215 203 149\n",
      "checkcorrect 44 44 real score 1.8669821262359618 Hits@1 0.8140043763676149 Hits@3 0.9277899343544858 Hits@10 0.986870897155361 MRR 0.8795765763307455 cur_rank 0 abs_cur_rank 0 total_num 456 865\n",
      "215 71\n",
      "215 58 85\n",
      "checkcorrect 46 46 real score 1.5171750962734223 Hits@1 0.8144104803493449 Hits@3 0.9279475982532751 Hits@10 0.9868995633187773 MRR 0.879839509570198 cur_rank 0 abs_cur_rank 1 total_num 457 865\n",
      "215 150\n",
      "215 267 732\n",
      "checkcorrect 4 4 real score 1.8844053506851197 Hits@1 0.8148148148148148 Hits@3 0.9281045751633987 Hits@10 0.9869281045751634 MRR 0.8801012971310472 cur_rank 0 abs_cur_rank 0 total_num 458 865\n",
      "215 150\n",
      "215 393 300\n",
      "checkcorrect 172 172 real score 1.8055454730987548 Hits@1 0.8152173913043478 Hits@3 0.9282608695652174 Hits@10 0.9869565217391304 MRR 0.8803619464851102 cur_rank 0 abs_cur_rank 0 total_num 459 865\n",
      "215 132\n",
      "215 158 73\n",
      "checkcorrect 368 368 real score 0.6731714479625225 Hits@1 0.8134490238611713 Hits@3 0.9262472885032538 Hits@10 0.9869848156182213 MRR 0.8787234173170297 cur_rank 7 abs_cur_rank 7 total_num 460 865\n",
      "215 150\n",
      "215 894 282\n",
      "checkcorrect 2 2 real score 1.8576078116893768 Hits@1 0.8138528138528138 Hits@3 0.9264069264069265 Hits@10 0.987012987012987 MRR 0.8789859207427504 cur_rank 0 abs_cur_rank 0 total_num 461 865\n",
      "215 150\n",
      "215 241 413\n",
      "checkcorrect 26 26 real score 1.9495065450668334 Hits@1 0.8142548596112311 Hits@3 0.9265658747300216 Hits@10 0.9870410367170627 MRR 0.879247290244386 cur_rank 0 abs_cur_rank 0 total_num 462 865\n",
      "0 0\n",
      "0 101 1\n",
      "checkcorrect 172 172 real score 0.0 Hits@1 0.8125 Hits@3 0.9245689655172413 Hits@10 0.9849137931034483 MRR 0.8773771328362592 cur_rank 86 abs_cur_rank 86 total_num 463 865\n",
      "215 5\n",
      "215 98 14\n",
      "checkcorrect 204 204 real score 1.9055861592292787 Hits@1 0.8129032258064516 Hits@3 0.9247311827956989 Hits@10 0.9849462365591398 MRR 0.8776408379269338 cur_rank 0 abs_cur_rank 0 total_num 464 865\n",
      "215 150\n",
      "215 883 890\n",
      "checkcorrect 24 24 real score 1.7527551025152206 Hits@1 0.8133047210300429 Hits@3 0.924892703862661 Hits@10 0.9849785407725322 MRR 0.8779034112361035 cur_rank 0 abs_cur_rank 1 total_num 465 865\n",
      "215 145\n",
      "215 601 458\n",
      "checkcorrect 50 50 real score 1.748069804906845 Hits@1 0.8137044967880086 Hits@3 0.9250535331905781 Hits@10 0.9850107066381156 MRR 0.8781648600343132 cur_rank 0 abs_cur_rank 0 total_num 466 865\n",
      "215 14\n",
      "215 175 9\n",
      "checkcorrect 58 58 real score 1.8976523935794831 Hits@1 0.8141025641025641 Hits@3 0.9252136752136753 Hits@10 0.9850427350427351 MRR 0.8784251915299663 cur_rank 0 abs_cur_rank 0 total_num 467 865\n",
      "215 149\n",
      "215 391 310\n",
      "checkcorrect 56 56 real score 1.9317348778247831 Hits@1 0.814498933901919 Hits@3 0.9253731343283582 Hits@10 0.9850746268656716 MRR 0.8786844128699877 cur_rank 0 abs_cur_rank 0 total_num 468 865\n",
      "215 146\n",
      "215 354 320\n",
      "checkcorrect 16 16 real score 1.9547746002674102 Hits@1 0.8148936170212766 Hits@3 0.925531914893617 Hits@10 0.9851063829787234 MRR 0.878942531140477 cur_rank 0 abs_cur_rank 0 total_num 469 865\n",
      "215 63\n",
      "215 172 641\n",
      "checkcorrect 24 24 real score 1.9037601113319398 Hits@1 0.8152866242038217 Hits@3 0.9256900212314225 Hits@10 0.9851380042462845 MRR 0.8791995533673551 cur_rank 0 abs_cur_rank 1 total_num 470 865\n",
      "215 121\n",
      "215 227 312\n",
      "checkcorrect 50 50 real score 1.9094198048114777 Hits@1 0.815677966101695 Hits@3 0.9258474576271186 Hits@10 0.9851694915254238 MRR 0.8794554865170005 cur_rank 0 abs_cur_rank 0 total_num 471 865\n",
      "215 3\n",
      "215 3 3\n",
      "checkcorrect 82 82 real score 1.9909755170345305 Hits@1 0.8160676532769556 Hits@3 0.9260042283298098 Hits@10 0.985200845665962 MRR 0.87971033749688 cur_rank 0 abs_cur_rank 0 total_num 472 865\n",
      "215 150\n",
      "215 96 423\n",
      "checkcorrect 26 26 real score 1.9585828363895417 Hits@1 0.8164556962025317 Hits@3 0.9261603375527426 Hits@10 0.9852320675105485 MRR 0.8799641131561693 cur_rank 0 abs_cur_rank 0 total_num 473 865\n",
      "0 1\n",
      "0 2 3\n",
      "checkcorrect 120 120 real score 0.0 Hits@1 0.8147368421052632 Hits@3 0.9242105263157895 Hits@10 0.9831578947368421 MRR 0.8781460696392572 cur_rank 60 abs_cur_rank 60 total_num 474 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 14\n",
      "215 10 63\n",
      "checkcorrect 202 202 real score 1.6242140650749206 Hits@1 0.8151260504201681 Hits@3 0.9243697478991597 Hits@10 0.9831932773109243 MRR 0.8784020652912755 cur_rank 0 abs_cur_rank 0 total_num 475 865\n",
      "215 33\n",
      "215 89 13\n",
      "checkcorrect 80 80 real score 1.97752046585083 Hits@1 0.8155136268343816 Hits@3 0.9245283018867925 Hits@10 0.9832285115303984 MRR 0.8786569875862624 cur_rank 0 abs_cur_rank 0 total_num 476 865\n",
      "215 150\n",
      "215 154 202\n",
      "checkcorrect 168 168 real score 1.955856990814209 Hits@1 0.8138075313807531 Hits@3 0.9246861924686193 Hits@10 0.9832635983263598 MRR 0.8778648181561656 cur_rank 1 abs_cur_rank 1 total_num 477 865\n",
      "215 150\n",
      "215 254 246\n",
      "checkcorrect 348 348 real score 1.8318800568580627 Hits@1 0.81419624217119 Hits@3 0.9248434237995825 Hits@10 0.9832985386221295 MRR 0.8781197976589711 cur_rank 0 abs_cur_rank 0 total_num 478 865\n",
      "215 147\n",
      "215 444 332\n",
      "checkcorrect 50 50 real score 1.6843722313642502 Hits@1 0.8145833333333333 Hits@3 0.925 Hits@10 0.9833333333333333 MRR 0.8783737147471816 cur_rank 0 abs_cur_rank 0 total_num 479 865\n",
      "215 13\n",
      "215 467 166\n",
      "checkcorrect 120 120 real score 1.8659816443920136 Hits@1 0.814968814968815 Hits@3 0.9251559251559252 Hits@10 0.9833679833679834 MRR 0.8786265760470835 cur_rank 0 abs_cur_rank 0 total_num 480 865\n",
      "215 15\n",
      "215 7 30\n",
      "checkcorrect 20 20 real score 1.9601499915122986 Hits@1 0.8153526970954357 Hits@3 0.9253112033195021 Hits@10 0.983402489626556 MRR 0.8788783881299733 cur_rank 0 abs_cur_rank 0 total_num 481 865\n",
      "215 7\n",
      "215 185 75\n",
      "checkcorrect 58 58 real score 1.3438414871692657 Hits@1 0.8157349896480331 Hits@3 0.9254658385093167 Hits@10 0.9834368530020704 MRR 0.879129157512727 cur_rank 0 abs_cur_rank 0 total_num 482 865\n",
      "215 149\n",
      "215 686 242\n",
      "checkcorrect 348 348 real score 1.8357700288295744 Hits@1 0.8161157024793388 Hits@3 0.9256198347107438 Hits@10 0.9834710743801653 MRR 0.879378890658362 cur_rank 0 abs_cur_rank 0 total_num 483 865\n",
      "215 50\n",
      "215 428 92\n",
      "checkcorrect 46 46 real score 1.874879491329193 Hits@1 0.8144329896907216 Hits@3 0.9257731958762887 Hits@10 0.9835051546391752 MRR 0.8785966661415405 cur_rank 1 abs_cur_rank 1 total_num 484 865\n",
      "0 0\n",
      "0 2 19\n",
      "checkcorrect 120 120 real score 0.0 Hits@1 0.8127572016460906 Hits@3 0.9238683127572016 Hits@10 0.9814814814814815 MRR 0.8768225854347121 cur_rank 60 abs_cur_rank 60 total_num 485 865\n",
      "215 44\n",
      "215 219 188\n",
      "checkcorrect 46 46 real score 1.8939095795154572 Hits@1 0.813141683778234 Hits@3 0.9240246406570842 Hits@10 0.9815195071868583 MRR 0.8770755164707804 cur_rank 0 abs_cur_rank 0 total_num 486 865\n",
      "215 69\n",
      "215 15 30\n",
      "checkcorrect 362 362 real score 1.934052401781082 Hits@1 0.8135245901639344 Hits@3 0.9241803278688525 Hits@10 0.9815573770491803 MRR 0.8773274109042419 cur_rank 0 abs_cur_rank 0 total_num 487 865\n",
      "215 41\n",
      "215 280 33\n",
      "checkcorrect 172 172 real score 1.9140247404575348 Hits@1 0.8139059304703476 Hits@3 0.9243353783231084 Hits@10 0.9815950920245399 MRR 0.8775782750946218 cur_rank 0 abs_cur_rank 0 total_num 488 865\n",
      "215 63\n",
      "215 432 81\n",
      "checkcorrect 366 366 real score 1.7502272367477416 Hits@1 0.8122448979591836 Hits@3 0.9244897959183673 Hits@10 0.9816326530612245 MRR 0.8764675711318437 cur_rank 2 abs_cur_rank 2 total_num 489 865\n",
      "215 63\n",
      "215 452 945\n",
      "checkcorrect 86 86 real score 1.8359850645065308 Hits@1 0.8105906313645621 Hits@3 0.924643584521385 Hits@10 0.9816700610997964 MRR 0.8757008347344265 cur_rank 1 abs_cur_rank 1 total_num 490 865\n",
      "215 150\n",
      "215 193 301\n",
      "checkcorrect 218 218 real score 1.9416197836399078 Hits@1 0.8109756097560976 Hits@3 0.9247967479674797 Hits@10 0.9817073170731707 MRR 0.8759534753142345 cur_rank 0 abs_cur_rank 0 total_num 491 865\n",
      "215 150\n",
      "215 585 428\n",
      "checkcorrect 10 10 real score 1.8671632409095764 Hits@1 0.8113590263691683 Hits@3 0.9249492900608519 Hits@10 0.9817444219066938 MRR 0.8762050909829684 cur_rank 0 abs_cur_rank 0 total_num 492 865\n",
      "215 15\n",
      "215 96 45\n",
      "checkcorrect 20 20 real score 1.8483809947967529 Hits@1 0.8117408906882592 Hits@3 0.9251012145748988 Hits@10 0.9817813765182186 MRR 0.8764556879647842 cur_rank 0 abs_cur_rank 0 total_num 493 865\n",
      "0 1\n",
      "215 306 29\n",
      "checkcorrect 10 10 real score 0.8868969082832336 Hits@1 0.8101010101010101 Hits@3 0.9232323232323232 Hits@10 0.9818181818181818 MRR 0.8751901209183907 cur_rank 3 abs_cur_rank 3 total_num 494 865\n",
      "215 150\n",
      "215 949 932\n",
      "checkcorrect 50 50 real score 1.8381016999483109 Hits@1 0.8104838709677419 Hits@3 0.9233870967741935 Hits@10 0.9818548387096774 MRR 0.8754417537391198 cur_rank 0 abs_cur_rank 0 total_num 495 865\n",
      "215 150\n",
      "215 216 247\n",
      "checkcorrect 348 348 real score 1.6845748960971831 Hits@1 0.8108651911468813 Hits@3 0.9235412474849095 Hits@10 0.9818913480885312 MRR 0.8756923739529243 cur_rank 0 abs_cur_rank 0 total_num 496 865\n",
      "215 150\n",
      "215 548 751\n",
      "checkcorrect 20 20 real score 1.954842883348465 Hits@1 0.8112449799196787 Hits@3 0.9236947791164659 Hits@10 0.9819277108433735 MRR 0.8759419876598462 cur_rank 0 abs_cur_rank 0 total_num 497 865\n",
      "215 49\n",
      "215 442 162\n",
      "checkcorrect 120 120 real score 1.5236994564533233 Hits@1 0.8096192384769539 Hits@3 0.9238476953907816 Hits@10 0.9819639278557114 MRR 0.8748545955670074 cur_rank 2 abs_cur_rank 2 total_num 498 865\n",
      "215 150\n",
      "215 991 892\n",
      "checkcorrect 44 44 real score 1.8520867288112641 Hits@1 0.81 Hits@3 0.924 Hits@10 0.982 MRR 0.8751048863758735 cur_rank 0 abs_cur_rank 0 total_num 499 865\n",
      "215 62\n",
      "215 282 53\n",
      "checkcorrect 214 214 real score 1.872690314054489 Hits@1 0.810379241516966 Hits@3 0.9241516966067864 Hits@10 0.9820359281437125 MRR 0.8753541780198337 cur_rank 0 abs_cur_rank 0 total_num 500 865\n",
      "215 69\n",
      "215 81 191\n",
      "checkcorrect 230 230 real score 1.830718493461609 Hits@1 0.8107569721115537 Hits@3 0.9243027888446215 Hits@10 0.9820717131474104 MRR 0.8756024764699935 cur_rank 0 abs_cur_rank 0 total_num 501 865\n",
      "0 2\n",
      "215 110 18\n",
      "checkcorrect 120 120 real score 0.8933271408081055 Hits@1 0.8111332007952287 Hits@3 0.9244532803180915 Hits@10 0.9821073558648111 MRR 0.8758497876499736 cur_rank 0 abs_cur_rank 0 total_num 502 865\n",
      "215 114\n",
      "215 51 198\n",
      "checkcorrect 26 26 real score 1.9585174918174744 Hits@1 0.8115079365079365 Hits@3 0.9246031746031746 Hits@10 0.9821428571428571 MRR 0.8760961174363824 cur_rank 0 abs_cur_rank 0 total_num 503 865\n",
      "215 138\n",
      "215 1037 474\n",
      "checkcorrect 50 50 real score 1.7525261461734771 Hits@1 0.8118811881188119 Hits@3 0.9247524752475248 Hits@10 0.9821782178217822 MRR 0.8763414716592807 cur_rank 0 abs_cur_rank 0 total_num 504 865\n",
      "215 150\n",
      "215 507 449\n",
      "checkcorrect 20 20 real score 1.8658331215381623 Hits@1 0.8122529644268774 Hits@3 0.924901185770751 Hits@10 0.9822134387351779 MRR 0.8765858561026417 cur_rank 0 abs_cur_rank 0 total_num 505 865\n",
      "215 150\n",
      "215 596 722\n",
      "checkcorrect 16 16 real score 1.9392008304595947 Hits@1 0.8126232741617357 Hits@3 0.9250493096646942 Hits@10 0.9822485207100592 MRR 0.8768292765048061 cur_rank 0 abs_cur_rank 0 total_num 506 865\n",
      "215 144\n",
      "215 705 351\n",
      "checkcorrect 50 50 real score 1.8943900227546693 Hits@1 0.812992125984252 Hits@3 0.9251968503937008 Hits@10 0.9822834645669292 MRR 0.8770717385589305 cur_rank 0 abs_cur_rank 0 total_num 507 865\n",
      "215 66\n",
      "215 69 23\n",
      "checkcorrect 110 110 real score 1.8559893012046813 Hits@1 0.8133595284872298 Hits@3 0.925343811394892 Hits@10 0.9823182711198428 MRR 0.8773132479134317 cur_rank 0 abs_cur_rank 0 total_num 508 865\n",
      "215 150\n",
      "215 589 516\n",
      "checkcorrect 78 78 real score 1.961187791824341 Hits@1 0.8137254901960784 Hits@3 0.9254901960784314 Hits@10 0.9823529411764705 MRR 0.877553810172425 cur_rank 0 abs_cur_rank 0 total_num 509 865\n",
      "215 150\n",
      "215 231 843\n",
      "checkcorrect 56 56 real score 1.9793042361736297 Hits@1 0.8140900195694716 Hits@3 0.9256360078277887 Hits@10 0.9823874755381604 MRR 0.8777934308961579 cur_rank 0 abs_cur_rank 0 total_num 510 865\n",
      "215 120\n",
      "215 68 139\n",
      "checkcorrect 276 276 real score 1.8947042226791382 Hits@1 0.814453125 Hits@3 0.92578125 Hits@10 0.982421875 MRR 0.8780321156014389 cur_rank 0 abs_cur_rank 0 total_num 511 865\n",
      "215 11\n",
      "215 126 26\n",
      "checkcorrect 120 120 real score 1.6997058212757112 Hits@1 0.8148148148148148 Hits@3 0.9259259259259259 Hits@10 0.9824561403508771 MRR 0.8782698697620599 cur_rank 0 abs_cur_rank 0 total_num 512 865\n",
      "215 66\n",
      "215 496 168\n",
      "checkcorrect 96 96 real score 1.842736804485321 Hits@1 0.8151750972762646 Hits@3 0.9260700389105059 Hits@10 0.9824902723735408 MRR 0.8785066988092154 cur_rank 0 abs_cur_rank 0 total_num 513 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 211 789\n",
      "checkcorrect 54 54 real score 1.8170128047466276 Hits@1 0.8155339805825242 Hits@3 0.9262135922330097 Hits@10 0.9825242718446602 MRR 0.878742608131916 cur_rank 0 abs_cur_rank 0 total_num 514 865\n",
      "215 27\n",
      "215 411 206\n",
      "checkcorrect 24 24 real score 1.8332542777061462 Hits@1 0.8158914728682171 Hits@3 0.9263565891472868 Hits@10 0.9825581395348837 MRR 0.8789776030773967 cur_rank 0 abs_cur_rank 1 total_num 515 865\n",
      "215 104\n",
      "215 70 134\n",
      "checkcorrect 34 34 real score 1.7801240146160127 Hits@1 0.8143133462282398 Hits@3 0.9264990328820116 Hits@10 0.9825918762088974 MRR 0.8782445709631271 cur_rank 1 abs_cur_rank 1 total_num 516 865\n",
      "215 36\n",
      "215 199 70\n",
      "checkcorrect 60 60 real score 1.8421263337135314 Hits@1 0.8146718146718147 Hits@3 0.9266409266409267 Hits@10 0.9826254826254827 MRR 0.8784796200539319 cur_rank 0 abs_cur_rank 0 total_num 517 865\n",
      "215 42\n",
      "215 353 60\n",
      "checkcorrect 2 2 real score 1.8392480671405793 Hits@1 0.815028901734104 Hits@3 0.9267822736030829 Hits@10 0.9826589595375722 MRR 0.8787137633678935 cur_rank 0 abs_cur_rank 0 total_num 518 865\n",
      "215 105\n",
      "215 65 266\n",
      "checkcorrect 348 348 real score 1.8835777640342712 Hits@1 0.8153846153846154 Hits@3 0.926923076923077 Hits@10 0.9826923076923076 MRR 0.8789470061306476 cur_rank 0 abs_cur_rank 0 total_num 519 865\n",
      "215 150\n",
      "215 587 637\n",
      "checkcorrect 16 16 real score 1.9502395272254942 Hits@1 0.8157389635316699 Hits@3 0.927063339731286 Hits@10 0.982725527831094 MRR 0.8791793535277096 cur_rank 0 abs_cur_rank 0 total_num 520 865\n",
      "215 150\n",
      "215 260 729\n",
      "checkcorrect 56 56 real score 1.9824699938297272 Hits@1 0.8160919540229885 Hits@3 0.9272030651340997 Hits@10 0.9827586206896551 MRR 0.8794108107048596 cur_rank 0 abs_cur_rank 0 total_num 521 865\n",
      "215 123\n",
      "215 283 193\n",
      "checkcorrect 92 92 real score 1.5987421423196793 Hits@1 0.8164435946462715 Hits@3 0.9273422562141491 Hits@10 0.982791586998088 MRR 0.8796413827685214 cur_rank 0 abs_cur_rank 0 total_num 522 865\n",
      "215 112\n",
      "215 415 170\n",
      "checkcorrect 248 248 real score 1.460458767414093 Hits@1 0.8148854961832062 Hits@3 0.9274809160305344 Hits@10 0.982824427480916 MRR 0.8789168763128563 cur_rank 1 abs_cur_rank 2 total_num 523 865\n",
      "215 27\n",
      "215 12 63\n",
      "checkcorrect 170 170 real score 1.609010910987854 Hits@1 0.8133333333333334 Hits@3 0.9276190476190476 Hits@10 0.9828571428571429 MRR 0.8781951298817843 cur_rank 1 abs_cur_rank 2 total_num 524 865\n",
      "215 42\n",
      "215 221 110\n",
      "checkcorrect 248 248 real score 1.7664231330156328 Hits@1 0.8136882129277566 Hits@3 0.9277566539923955 Hits@10 0.9828897338403042 MRR 0.8784266980759253 cur_rank 0 abs_cur_rank 0 total_num 525 865\n",
      "215 150\n",
      "215 51 814\n",
      "checkcorrect 54 54 real score 1.966193950176239 Hits@1 0.8140417457305503 Hits@3 0.9278937381404174 Hits@10 0.9829222011385199 MRR 0.8786573874533904 cur_rank 0 abs_cur_rank 0 total_num 526 865\n",
      "215 150\n",
      "215 360 599\n",
      "checkcorrect 20 20 real score 1.8976921379566192 Hits@1 0.8143939393939394 Hits@3 0.928030303030303 Hits@10 0.9829545454545454 MRR 0.8788872030074559 cur_rank 0 abs_cur_rank 0 total_num 527 865\n",
      "215 96\n",
      "215 73 68\n",
      "checkcorrect 220 220 real score 1.864168530702591 Hits@1 0.8147448015122873 Hits@3 0.9281663516068053 Hits@10 0.9829867674858223 MRR 0.8791161496936422 cur_rank 0 abs_cur_rank 0 total_num 528 865\n",
      "215 150\n",
      "215 128 951\n",
      "checkcorrect 34 34 real score 1.8338141083717345 Hits@1 0.8132075471698114 Hits@3 0.9283018867924528 Hits@10 0.9830188679245283 MRR 0.8784008362036542 cur_rank 1 abs_cur_rank 1 total_num 529 865\n",
      "215 80\n",
      "215 16 105\n",
      "checkcorrect 76 76 real score 1.9572518646717072 Hits@1 0.8135593220338984 Hits@3 0.928436911487759 Hits@10 0.9830508474576272 MRR 0.8786298365121219 cur_rank 0 abs_cur_rank 0 total_num 530 865\n",
      "215 133\n",
      "215 200 106\n",
      "checkcorrect 50 50 real score 1.8744385957717895 Hits@1 0.8139097744360902 Hits@3 0.9285714285714286 Hits@10 0.9830827067669173 MRR 0.8788579759171743 cur_rank 0 abs_cur_rank 0 total_num 531 865\n",
      "215 150\n",
      "215 794 465\n",
      "checkcorrect 2 2 real score 1.8509913206100463 Hits@1 0.8142589118198874 Hits@3 0.9287054409005628 Hits@10 0.9831144465290806 MRR 0.8790852592644216 cur_rank 0 abs_cur_rank 1 total_num 532 865\n",
      "215 150\n",
      "215 192 846\n",
      "checkcorrect 54 54 real score 1.820884656906128 Hits@1 0.8146067415730337 Hits@3 0.9288389513108615 Hits@10 0.9831460674157303 MRR 0.8793116913631773 cur_rank 0 abs_cur_rank 0 total_num 533 865\n",
      "215 150\n",
      "215 432 434\n",
      "checkcorrect 16 16 real score 1.9351646423339846 Hits@1 0.8149532710280374 Hits@3 0.9289719626168225 Hits@10 0.983177570093458 MRR 0.8795372769867976 cur_rank 0 abs_cur_rank 0 total_num 534 865\n",
      "215 13\n",
      "215 254 112\n",
      "checkcorrect 24 24 real score 1.4585486203432083 Hits@1 0.8134328358208955 Hits@3 0.9272388059701493 Hits@10 0.9832089552238806 MRR 0.8782694835595835 cur_rank 4 abs_cur_rank 4 total_num 535 865\n",
      "215 150\n",
      "215 748 691\n",
      "checkcorrect 56 56 real score 1.935508167743683 Hits@1 0.813780260707635 Hits@3 0.9273743016759777 Hits@10 0.9832402234636871 MRR 0.878496169809938 cur_rank 0 abs_cur_rank 0 total_num 536 865\n",
      "215 150\n",
      "215 890 190\n",
      "checkcorrect 52 52 real score 1.9257984399795531 Hits@1 0.8141263940520446 Hits@3 0.9275092936802974 Hits@10 0.983271375464684 MRR 0.8787220133604772 cur_rank 0 abs_cur_rank 0 total_num 537 865\n",
      "215 27\n",
      "215 178 36\n",
      "checkcorrect 16 16 real score 1.8730290114879609 Hits@1 0.8144712430426716 Hits@3 0.9276437847866419 Hits@10 0.9833024118738405 MRR 0.8789470189015524 cur_rank 0 abs_cur_rank 0 total_num 538 865\n",
      "215 135\n",
      "215 423 276\n",
      "checkcorrect 46 46 real score 1.892332285642624 Hits@1 0.8148148148148148 Hits@3 0.9277777777777778 Hits@10 0.9833333333333333 MRR 0.8791711910887717 cur_rank 0 abs_cur_rank 0 total_num 539 865\n",
      "215 150\n",
      "215 490 434\n",
      "checkcorrect 102 102 real score 1.9857084095478057 Hits@1 0.8151571164510166 Hits@3 0.9279112754158965 Hits@10 0.9833641404805915 MRR 0.8793945345433211 cur_rank 0 abs_cur_rank 0 total_num 540 865\n",
      "215 150\n",
      "215 73 455\n",
      "checkcorrect 358 358 real score 1.782534348964691 Hits@1 0.8154981549815498 Hits@3 0.9280442804428044 Hits@10 0.9833948339483395 MRR 0.8796170538522817 cur_rank 0 abs_cur_rank 0 total_num 541 865\n",
      "215 150\n",
      "215 228 937\n",
      "checkcorrect 248 248 real score 1.6000559151172637 Hits@1 0.8139963167587477 Hits@3 0.9281767955801105 Hits@10 0.9834254143646409 MRR 0.8786110064848435 cur_rank 2 abs_cur_rank 2 total_num 542 865\n",
      "215 149\n",
      "215 612 295\n",
      "checkcorrect 16 16 real score 1.9576862335205079 Hits@1 0.8143382352941176 Hits@3 0.9283088235294118 Hits@10 0.9834558823529411 MRR 0.8788341480170405 cur_rank 0 abs_cur_rank 0 total_num 543 865\n",
      "215 77\n",
      "215 307 126\n",
      "checkcorrect 74 74 real score 1.833341473340988 Hits@1 0.8146788990825689 Hits@3 0.9284403669724771 Hits@10 0.9834862385321101 MRR 0.8790564706812294 cur_rank 0 abs_cur_rank 0 total_num 544 865\n",
      "215 150\n",
      "215 321 394\n",
      "checkcorrect 50 50 real score 1.9206637918949128 Hits@1 0.815018315018315 Hits@3 0.9285714285714286 Hits@10 0.9835164835164835 MRR 0.879277978976685 cur_rank 0 abs_cur_rank 0 total_num 545 865\n",
      "215 150\n",
      "215 507 378\n",
      "checkcorrect 46 46 real score 1.880959540605545 Hits@1 0.8153564899451554 Hits@3 0.9287020109689214 Hits@10 0.9835466179159049 MRR 0.8794986773697807 cur_rank 0 abs_cur_rank 0 total_num 546 865\n",
      "215 150\n",
      "215 374 891\n",
      "checkcorrect 20 20 real score 1.887712800502777 Hits@1 0.8156934306569343 Hits@3 0.9288321167883211 Hits@10 0.9835766423357665 MRR 0.8797185702942883 cur_rank 0 abs_cur_rank 0 total_num 547 865\n",
      "215 150\n",
      "215 511 454\n",
      "checkcorrect 86 86 real score 1.5457937687635421 Hits@1 0.8142076502732241 Hits@3 0.9271402550091075 Hits@10 0.9836065573770492 MRR 0.8785715419330966 cur_rank 3 abs_cur_rank 3 total_num 548 865\n",
      "215 3\n",
      "215 162 19\n",
      "checkcorrect 132 132 real score 1.8020235538482665 Hits@1 0.8145454545454546 Hits@3 0.9272727272727272 Hits@10 0.9836363636363636 MRR 0.8787923209477637 cur_rank 0 abs_cur_rank 0 total_num 549 865\n",
      "215 150\n",
      "215 482 594\n",
      "checkcorrect 50 50 real score 1.9353822469711304 Hits@1 0.8148820326678766 Hits@3 0.9274047186932849 Hits@10 0.9836660617059891 MRR 0.8790122985866969 cur_rank 0 abs_cur_rank 0 total_num 550 865\n",
      "215 144\n",
      "215 646 174\n",
      "checkcorrect 56 56 real score 1.8816189646720884 Hits@1 0.8152173913043478 Hits@3 0.927536231884058 Hits@10 0.9836956521739131 MRR 0.8792314792051993 cur_rank 0 abs_cur_rank 0 total_num 551 865\n",
      "215 150\n",
      "215 161 490\n",
      "checkcorrect 2 2 real score 1.7196220219135285 Hits@1 0.8155515370705244 Hits@3 0.9276672694394213 Hits@10 0.9837251356238698 MRR 0.8794498671270705 cur_rank 0 abs_cur_rank 0 total_num 552 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 650 443\n",
      "checkcorrect 102 102 real score 1.9862891733646393 Hits@1 0.8158844765342961 Hits@3 0.927797833935018 Hits@10 0.983754512635379 MRR 0.8796674666448917 cur_rank 0 abs_cur_rank 0 total_num 553 865\n",
      "215 150\n",
      "215 417 310\n",
      "checkcorrect 30 30 real score 1.8365172743797302 Hits@1 0.8144144144144144 Hits@3 0.9279279279279279 Hits@10 0.9837837837837838 MRR 0.8789833811194054 cur_rank 1 abs_cur_rank 1 total_num 554 865\n",
      "215 146\n",
      "215 543 202\n",
      "checkcorrect 102 102 real score 1.985528391599655 Hits@1 0.814748201438849 Hits@3 0.9280575539568345 Hits@10 0.9838129496402878 MRR 0.8792010369087591 cur_rank 0 abs_cur_rank 0 total_num 555 865\n",
      "215 150\n",
      "215 173 511\n",
      "checkcorrect 78 78 real score 1.9640762746334075 Hits@1 0.8150807899461401 Hits@3 0.9281867145421903 Hits@10 0.9838420107719928 MRR 0.879417911169246 cur_rank 0 abs_cur_rank 0 total_num 556 865\n",
      "215 150\n",
      "215 564 596\n",
      "checkcorrect 174 174 real score 1.5642499446868896 Hits@1 0.8136200716845878 Hits@3 0.9283154121863799 Hits@10 0.9838709677419355 MRR 0.8784392649724074 cur_rank 2 abs_cur_rank 3 total_num 557 865\n",
      "215 63\n",
      "215 43 155\n",
      "checkcorrect 172 172 real score 1.9153433978557586 Hits@1 0.813953488372093 Hits@3 0.9284436493738819 Hits@10 0.9838998211091234 MRR 0.8786567260368575 cur_rank 0 abs_cur_rank 0 total_num 558 865\n",
      "215 150\n",
      "215 953 1329\n",
      "checkcorrect 34 34 real score 1.8176808059215546 Hits@1 0.8142857142857143 Hits@3 0.9285714285714286 Hits@10 0.9839285714285714 MRR 0.8788734104546488 cur_rank 0 abs_cur_rank 1 total_num 559 865\n",
      "215 64\n",
      "215 355 158\n",
      "checkcorrect 52 52 real score 1.9062327086925506 Hits@1 0.8146167557932263 Hits@3 0.928698752228164 Hits@10 0.983957219251337 MRR 0.8790893223789721 cur_rank 0 abs_cur_rank 0 total_num 560 865\n",
      "215 150\n",
      "215 227 418\n",
      "checkcorrect 26 26 real score 1.9578048944473267 Hits@1 0.8149466192170819 Hits@3 0.9288256227758007 Hits@10 0.9839857651245552 MRR 0.8793044659334579 cur_rank 0 abs_cur_rank 0 total_num 561 865\n",
      "215 150\n",
      "215 146 919\n",
      "checkcorrect 54 54 real score 1.9341531813144683 Hits@1 0.8152753108348135 Hits@3 0.9289520426287744 Hits@10 0.9840142095914742 MRR 0.8795188452124393 cur_rank 0 abs_cur_rank 0 total_num 562 865\n",
      "215 99\n",
      "215 539 479\n",
      "checkcorrect 230 230 real score 1.7763406395912171 Hits@1 0.8156028368794326 Hits@3 0.9290780141843972 Hits@10 0.9840425531914894 MRR 0.8797324642812115 cur_rank 0 abs_cur_rank 0 total_num 563 865\n",
      "215 149\n",
      "215 594 305\n",
      "checkcorrect 132 132 real score 1.3853829681873322 Hits@1 0.8141592920353983 Hits@3 0.9274336283185841 Hits@10 0.984070796460177 MRR 0.8786178935479705 cur_rank 3 abs_cur_rank 3 total_num 564 865\n",
      "215 150\n",
      "215 943 350\n",
      "checkcorrect 16 16 real score 1.9053457856178282 Hits@1 0.8144876325088339 Hits@3 0.9275618374558304 Hits@10 0.9840989399293286 MRR 0.878832349566437 cur_rank 0 abs_cur_rank 0 total_num 565 865\n",
      "215 150\n",
      "215 443 852\n",
      "checkcorrect 268 268 real score 1.4762736439704893 Hits@1 0.8130511463844797 Hits@3 0.9259259259259259 Hits@10 0.9841269841269841 MRR 0.8776351143820165 cur_rank 4 abs_cur_rank 4 total_num 566 865\n",
      "215 150\n",
      "215 405 1469\n",
      "checkcorrect 100 100 real score 1.8881857275962828 Hits@1 0.8133802816901409 Hits@3 0.926056338028169 Hits@10 0.9841549295774648 MRR 0.8778505455186678 cur_rank 0 abs_cur_rank 0 total_num 567 865\n",
      "215 88\n",
      "215 173 242\n",
      "checkcorrect 80 80 real score 1.3142999917268754 Hits@1 0.8137082601054482 Hits@3 0.9261862917398945 Hits@10 0.984182776801406 MRR 0.8780652194281253 cur_rank 0 abs_cur_rank 0 total_num 568 865\n",
      "215 150\n",
      "215 155 814\n",
      "checkcorrect 54 54 real score 1.9074981272220612 Hits@1 0.8140350877192982 Hits@3 0.9263157894736842 Hits@10 0.9842105263157894 MRR 0.8782791400957953 cur_rank 0 abs_cur_rank 0 total_num 569 865\n",
      "215 46\n",
      "215 917 96\n",
      "checkcorrect 46 46 real score 1.8483387053012847 Hits@1 0.8143607705779334 Hits@3 0.9264448336252189 Hits@10 0.9842381786339754 MRR 0.8784923114791652 cur_rank 0 abs_cur_rank 0 total_num 570 865\n",
      "215 116\n",
      "215 378 348\n",
      "checkcorrect 16 16 real score 1.9534383177757264 Hits@1 0.8146853146853147 Hits@3 0.9265734265734266 Hits@10 0.9842657342657343 MRR 0.8787047375080478 cur_rank 0 abs_cur_rank 0 total_num 571 865\n",
      "215 73\n",
      "215 239 200\n",
      "checkcorrect 26 26 real score 1.9500215530395508 Hits@1 0.8150087260034904 Hits@3 0.9267015706806283 Hits@10 0.9842931937172775 MRR 0.8789164220848226 cur_rank 0 abs_cur_rank 0 total_num 572 865\n",
      "215 150\n",
      "215 380 738\n",
      "checkcorrect 56 56 real score 1.8199077904224397 Hits@1 0.8153310104529616 Hits@3 0.926829268292683 Hits@10 0.9843205574912892 MRR 0.8791273690846748 cur_rank 0 abs_cur_rank 0 total_num 573 865\n",
      "215 96\n",
      "215 598 182\n",
      "checkcorrect 16 16 real score 1.9513865053653716 Hits@1 0.8156521739130435 Hits@3 0.9269565217391305 Hits@10 0.9843478260869565 MRR 0.8793375823558318 cur_rank 0 abs_cur_rank 0 total_num 574 865\n",
      "215 150\n",
      "215 970 482\n",
      "checkcorrect 16 16 real score 1.9425994396209716 Hits@1 0.8159722222222222 Hits@3 0.9270833333333334 Hits@10 0.984375 MRR 0.8795470657197975 cur_rank 0 abs_cur_rank 0 total_num 575 865\n",
      "215 123\n",
      "215 444 96\n",
      "checkcorrect 20 20 real score 1.9122266709804534 Hits@1 0.8162911611785095 Hits@3 0.9272097053726169 Hits@10 0.9844020797227037 MRR 0.8797558229715828 cur_rank 0 abs_cur_rank 0 total_num 576 865\n",
      "215 150\n",
      "215 943 645\n",
      "checkcorrect 16 16 real score 1.9011886417865753 Hits@1 0.8166089965397924 Hits@3 0.9273356401384083 Hits@10 0.9844290657439446 MRR 0.8799638578799366 cur_rank 0 abs_cur_rank 0 total_num 577 865\n",
      "215 150\n",
      "215 232 213\n",
      "checkcorrect 20 20 real score 1.9370898485183714 Hits@1 0.8169257340241797 Hits@3 0.927461139896373 Hits@10 0.9844559585492227 MRR 0.8801711741875705 cur_rank 0 abs_cur_rank 0 total_num 578 865\n",
      "215 124\n",
      "215 61 454\n",
      "checkcorrect 86 86 real score 1.521229737997055 Hits@1 0.8155172413793104 Hits@3 0.9258620689655173 Hits@10 0.9844827586206897 MRR 0.8790846721631091 cur_rank 3 abs_cur_rank 3 total_num 579 865\n",
      "215 3\n",
      "215 4 9\n",
      "checkcorrect 296 296 real score 0.7928513118997217 Hits@1 0.8141135972461274 Hits@3 0.9259896729776248 Hits@10 0.9845094664371773 MRR 0.8781453411152094 cur_rank 2 abs_cur_rank 2 total_num 580 865\n",
      "215 150\n",
      "215 589 738\n",
      "checkcorrect 56 56 real score 1.9299823760986328 Hits@1 0.8144329896907216 Hits@3 0.9261168384879725 Hits@10 0.9845360824742269 MRR 0.8783547133813344 cur_rank 0 abs_cur_rank 0 total_num 581 865\n",
      "215 141\n",
      "215 744 194\n",
      "checkcorrect 348 348 real score 1.866885632276535 Hits@1 0.8147512864493996 Hits@3 0.9262435677530018 Hits@10 0.9845626072041166 MRR 0.8785633673892567 cur_rank 0 abs_cur_rank 0 total_num 582 865\n",
      "215 141\n",
      "215 349 197\n",
      "checkcorrect 284 284 real score 0.24955026656389234 Hits@1 0.8133561643835616 Hits@3 0.9246575342465754 Hits@10 0.9828767123287672 MRR 0.877173133312677 cur_rank 14 abs_cur_rank 14 total_num 583 865\n",
      "215 150\n",
      "215 481 702\n",
      "checkcorrect 176 176 real score 1.9650873720645905 Hits@1 0.8136752136752137 Hits@3 0.9247863247863248 Hits@10 0.9829059829059829 MRR 0.8773830937685527 cur_rank 0 abs_cur_rank 1 total_num 584 865\n",
      "215 150\n",
      "215 889 664\n",
      "checkcorrect 24 24 real score 1.9379340410232544 Hits@1 0.8139931740614335 Hits@3 0.9249146757679181 Hits@10 0.9829351535836177 MRR 0.8775923376358419 cur_rank 0 abs_cur_rank 1 total_num 585 865\n",
      "215 128\n",
      "215 232 183\n",
      "checkcorrect 50 50 real score 1.9116501092910767 Hits@1 0.8143100511073254 Hits@3 0.9250425894378195 Hits@10 0.9829642248722317 MRR 0.877800868576837 cur_rank 0 abs_cur_rank 1 total_num 586 865\n",
      "215 150\n",
      "215 127 424\n",
      "checkcorrect 26 26 real score 1.958187961578369 Hits@1 0.814625850340136 Hits@3 0.9251700680272109 Hits@10 0.9829931972789115 MRR 0.8780086902289173 cur_rank 0 abs_cur_rank 0 total_num 587 865\n",
      "215 150\n",
      "215 537 213\n",
      "checkcorrect 20 20 real score 1.9492420494556426 Hits@1 0.8149405772495756 Hits@3 0.9252971137521222 Hits@10 0.9830220713073005 MRR 0.8782158062047595 cur_rank 0 abs_cur_rank 0 total_num 588 865\n",
      "215 61\n",
      "215 343 346\n",
      "checkcorrect 50 50 real score 1.6053422659635546 Hits@1 0.8152542372881356 Hits@3 0.9254237288135593 Hits@10 0.9830508474576272 MRR 0.8784222200925481 cur_rank 0 abs_cur_rank 0 total_num 589 865\n",
      "215 150\n",
      "215 434 350\n",
      "checkcorrect 102 102 real score 1.9849834978580474 Hits@1 0.8155668358714044 Hits@3 0.9255499153976311 Hits@10 0.9830795262267343 MRR 0.8786279354561817 cur_rank 0 abs_cur_rank 0 total_num 590 865\n",
      "215 150\n",
      "215 190 893\n",
      "checkcorrect 20 20 real score 1.9397978127002715 Hits@1 0.8158783783783784 Hits@3 0.9256756756756757 Hits@10 0.9831081081081081 MRR 0.8788329558354786 cur_rank 0 abs_cur_rank 0 total_num 591 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 416 1428\n",
      "checkcorrect 236 236 real score 1.2587179437279703 Hits@1 0.8161888701517707 Hits@3 0.9258010118043845 Hits@10 0.9831365935919055 MRR 0.87903728474638 cur_rank 0 abs_cur_rank 0 total_num 592 865\n",
      "215 150\n",
      "215 205 356\n",
      "checkcorrect 102 102 real score 1.9852152228355409 Hits@1 0.8164983164983165 Hits@3 0.9259259259259259 Hits@10 0.9831649831649831 MRR 0.8792409256811504 cur_rank 0 abs_cur_rank 0 total_num 593 865\n",
      "215 150\n",
      "215 599 697\n",
      "checkcorrect 128 128 real score 1.7996149837970732 Hits@1 0.8168067226890756 Hits@3 0.9260504201680673 Hits@10 0.9831932773109243 MRR 0.879443882108577 cur_rank 0 abs_cur_rank 0 total_num 594 865\n",
      "215 89\n",
      "215 269 174\n",
      "checkcorrect 74 74 real score 1.8991777300834656 Hits@1 0.8171140939597316 Hits@3 0.9261744966442953 Hits@10 0.9832214765100671 MRR 0.8796461574741667 cur_rank 0 abs_cur_rank 0 total_num 595 865\n",
      "215 150\n",
      "215 157 250\n",
      "checkcorrect 348 348 real score 1.7098931878805161 Hits@1 0.8174204355108877 Hits@3 0.9262981574539364 Hits@10 0.983249581239531 MRR 0.8798477552003406 cur_rank 0 abs_cur_rank 0 total_num 596 865\n",
      "215 150\n",
      "215 394 272\n",
      "checkcorrect 172 172 real score 1.9077526509761809 Hits@1 0.8177257525083612 Hits@3 0.9264214046822743 Hits@10 0.9832775919732442 MRR 0.8800486786866277 cur_rank 0 abs_cur_rank 0 total_num 597 865\n",
      "215 129\n",
      "215 519 132\n",
      "checkcorrect 162 162 real score 1.7002398133277894 Hits@1 0.8180300500834724 Hits@3 0.9265442404006677 Hits@10 0.9833055091819699 MRR 0.8802489313098554 cur_rank 0 abs_cur_rank 0 total_num 598 865\n",
      "215 80\n",
      "215 800 341\n",
      "checkcorrect 2 2 real score 1.8647697925567628 Hits@1 0.8183333333333334 Hits@3 0.9266666666666666 Hits@10 0.9833333333333333 MRR 0.880448516424339 cur_rank 0 abs_cur_rank 0 total_num 599 865\n",
      "215 150\n",
      "215 370 424\n",
      "checkcorrect 26 26 real score 1.9569637715816497 Hits@1 0.8186356073211315 Hits@3 0.9267886855241264 Hits@10 0.9833610648918469 MRR 0.8806474373620689 cur_rank 0 abs_cur_rank 0 total_num 600 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 178 178 real score 1.9388185501098634 Hits@1 0.8172757475083057 Hits@3 0.9269102990033222 Hits@10 0.9833887043189369 MRR 0.8800151326488428 cur_rank 1 abs_cur_rank 2 total_num 601 865\n",
      "215 96\n",
      "215 460 118\n",
      "checkcorrect 26 26 real score 1.9380541801452638 Hits@1 0.8175787728026535 Hits@3 0.9270315091210614 Hits@10 0.9834162520729685 MRR 0.8802141125283638 cur_rank 0 abs_cur_rank 0 total_num 602 865\n",
      "215 124\n",
      "215 197 190\n",
      "checkcorrect 162 162 real score 1.7672780811786652 Hits@1 0.8178807947019867 Hits@3 0.9271523178807947 Hits@10 0.9834437086092715 MRR 0.8804124335341115 cur_rank 0 abs_cur_rank 0 total_num 603 865\n",
      "215 142\n",
      "215 364 539\n",
      "checkcorrect 52 52 real score 1.907469058036804 Hits@1 0.8181818181818182 Hits@3 0.9272727272727272 Hits@10 0.9834710743801653 MRR 0.8806100989332287 cur_rank 0 abs_cur_rank 0 total_num 604 865\n",
      "215 150\n",
      "215 303 695\n",
      "checkcorrect 156 156 real score 1.8512057423591615 Hits@1 0.8184818481848185 Hits@3 0.9273927392739274 Hits@10 0.9834983498349835 MRR 0.8808071119712927 cur_rank 0 abs_cur_rank 0 total_num 605 865\n",
      "215 110\n",
      "215 111 77\n",
      "checkcorrect 80 80 real score 1.7876757264137269 Hits@1 0.8187808896210873 Hits@3 0.9275123558484349 Hits@10 0.9835255354200988 MRR 0.8810034758724932 cur_rank 0 abs_cur_rank 0 total_num 606 865\n",
      "215 150\n",
      "215 193 1195\n",
      "checkcorrect 172 172 real score 1.697413367033005 Hits@1 0.819078947368421 Hits@3 0.9276315789473685 Hits@10 0.9835526315789473 MRR 0.8811991938398082 cur_rank 0 abs_cur_rank 0 total_num 607 865\n",
      "215 150\n",
      "215 225 1191\n",
      "checkcorrect 74 74 real score 1.8657251834869384 Hits@1 0.819376026272578 Hits@3 0.9277504105090312 Hits@10 0.9835796387520526 MRR 0.8813942690551779 cur_rank 0 abs_cur_rank 0 total_num 608 865\n",
      "215 150\n",
      "215 272 771\n",
      "checkcorrect 74 74 real score 1.8794957458972932 Hits@1 0.819672131147541 Hits@3 0.9278688524590164 Hits@10 0.9836065573770492 MRR 0.8815887046796776 cur_rank 0 abs_cur_rank 0 total_num 609 865\n",
      "215 30\n",
      "215 171 83\n",
      "checkcorrect 292 292 real score 0.5656002944335341 Hits@1 0.8183306055646481 Hits@3 0.9263502454991817 Hits@10 0.983633387888707 MRR 0.8803504252939498 cur_rank 7 abs_cur_rank 7 total_num 610 865\n",
      "215 150\n",
      "215 890 657\n",
      "checkcorrect 24 24 real score 1.789003387093544 Hits@1 0.8186274509803921 Hits@3 0.9264705882352942 Hits@10 0.9836601307189542 MRR 0.8805459311349728 cur_rank 0 abs_cur_rank 1 total_num 611 865\n",
      "215 150\n",
      "215 443 692\n",
      "checkcorrect 102 102 real score 1.9858432352542876 Hits@1 0.8189233278955954 Hits@3 0.9265905383360522 Hits@10 0.9836867862969005 MRR 0.8807407991102828 cur_rank 0 abs_cur_rank 0 total_num 612 865\n",
      "215 150\n",
      "215 422 818\n",
      "checkcorrect 56 56 real score 1.675285804271698 Hits@1 0.8192182410423453 Hits@3 0.9267100977198697 Hits@10 0.9837133550488599 MRR 0.8809350323364875 cur_rank 0 abs_cur_rank 0 total_num 613 865\n",
      "215 121\n",
      "215 894 162\n",
      "checkcorrect 52 52 real score 1.8393304884433745 Hits@1 0.8195121951219512 Hits@3 0.926829268292683 Hits@10 0.983739837398374 MRR 0.8811286339099241 cur_rank 0 abs_cur_rank 0 total_num 614 865\n",
      "215 127\n",
      "215 276 1470\n",
      "checkcorrect 100 100 real score 1.891472864151001 Hits@1 0.8198051948051948 Hits@3 0.926948051948052 Hits@10 0.9837662337662337 MRR 0.8813216069068236 cur_rank 0 abs_cur_rank 0 total_num 615 865\n",
      "215 150\n",
      "215 44 726\n",
      "checkcorrect 54 54 real score 1.8608898162841796 Hits@1 0.820097244732577 Hits@3 0.9270664505672609 Hits@10 0.9837925445705025 MRR 0.8815139543834738 cur_rank 0 abs_cur_rank 0 total_num 616 865\n",
      "215 65\n",
      "215 522 180\n",
      "checkcorrect 86 86 real score 1.6168818950653074 Hits@1 0.8187702265372169 Hits@3 0.9255663430420712 Hits@10 0.9838187702265372 MRR 0.8804920871433711 cur_rank 3 abs_cur_rank 3 total_num 617 865\n",
      "215 109\n",
      "215 9 430\n",
      "checkcorrect 136 136 real score 1.874779260158539 Hits@1 0.8190630048465266 Hits@3 0.925686591276252 Hits@10 0.9838449111470113 MRR 0.8806851532384545 cur_rank 0 abs_cur_rank 0 total_num 618 865\n",
      "215 76\n",
      "215 117 214\n",
      "checkcorrect 358 358 real score 1.5652391344308851 Hits@1 0.8193548387096774 Hits@3 0.9258064516129032 Hits@10 0.9838709677419355 MRR 0.8808775965396828 cur_rank 0 abs_cur_rank 0 total_num 619 865\n",
      "0 1\n",
      "215 154 24\n",
      "checkcorrect 280 280 real score 0.9615323305130005 Hits@1 0.8180354267310789 Hits@3 0.9243156199677939 Hits@10 0.9838969404186796 MRR 0.8798616905871229 cur_rank 3 abs_cur_rank 3 total_num 620 865\n",
      "215 4\n",
      "215 19 9\n",
      "checkcorrect 322 322 real score 1.7707358479499817 Hits@1 0.8183279742765274 Hits@3 0.9244372990353698 Hits@10 0.9839228295819936 MRR 0.8800548389945392 cur_rank 0 abs_cur_rank 0 total_num 621 865\n",
      "215 139\n",
      "215 529 136\n",
      "checkcorrect 96 96 real score 1.8441862881183624 Hits@1 0.8186195826645265 Hits@3 0.9245585874799358 Hits@10 0.9839486356340289 MRR 0.8802473673428626 cur_rank 0 abs_cur_rank 0 total_num 622 865\n",
      "215 143\n",
      "215 190 336\n",
      "checkcorrect 310 310 real score 1.7950559735298157 Hits@1 0.8173076923076923 Hits@3 0.9246794871794872 Hits@10 0.9839743589743589 MRR 0.8793709025447703 cur_rank 2 abs_cur_rank 2 total_num 623 865\n",
      "215 3\n",
      "215 3 3\n",
      "checkcorrect 82 82 real score 1.990975522994995 Hits@1 0.8176 Hits@3 0.9248 Hits@10 0.984 MRR 0.8795639091006988 cur_rank 0 abs_cur_rank 0 total_num 624 865\n",
      "215 146\n",
      "215 159 167\n",
      "checkcorrect 62 62 real score 1.7862807154655456 Hits@1 0.8178913738019169 Hits@3 0.9249201277955271 Hits@10 0.9840255591054313 MRR 0.8797562990222632 cur_rank 0 abs_cur_rank 0 total_num 625 865\n",
      "215 4\n",
      "215 66 30\n",
      "checkcorrect 20 20 real score 1.795354676246643 Hits@1 0.8181818181818182 Hits@3 0.9250398724082934 Hits@10 0.9840510366826156 MRR 0.8799480752598672 cur_rank 0 abs_cur_rank 0 total_num 626 865\n",
      "215 102\n",
      "215 415 381\n",
      "checkcorrect 356 356 real score 1.0181223250925542 Hits@1 0.8168789808917197 Hits@3 0.9235668789808917 Hits@10 0.9840764331210191 MRR 0.8787238125781016 cur_rank 8 abs_cur_rank 8 total_num 627 865\n",
      "215 150\n",
      "215 336 602\n",
      "checkcorrect 246 246 real score 1.4214233875274658 Hits@1 0.8155802861685215 Hits@3 0.9220985691573926 Hits@10 0.9841017488076311 MRR 0.8776447604118408 cur_rank 4 abs_cur_rank 5 total_num 628 865\n",
      "0 1\n",
      "215 45 13\n",
      "checkcorrect 52 52 real score 0.938873928785324 Hits@1 0.8158730158730159 Hits@3 0.9222222222222223 Hits@10 0.9841269841269841 MRR 0.8778389750778538 cur_rank 0 abs_cur_rank 0 total_num 629 865\n",
      "215 96\n",
      "215 477 742\n",
      "checkcorrect 32 32 real score 1.6600667178630828 Hits@1 0.8161648177496038 Hits@3 0.9223454833597464 Hits@10 0.9841521394611727 MRR 0.8780325741664784 cur_rank 0 abs_cur_rank 0 total_num 630 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 55\n",
      "215 162 53\n",
      "checkcorrect 2 2 real score 1.8862822294235229 Hits@1 0.8164556962025317 Hits@3 0.9224683544303798 Hits@10 0.9841772151898734 MRR 0.8782255605997593 cur_rank 0 abs_cur_rank 0 total_num 631 865\n",
      "215 46\n",
      "215 229 139\n",
      "checkcorrect 2 2 real score 1.7193098574876786 Hits@1 0.8167456556082149 Hits@3 0.9225908372827805 Hits@10 0.9842022116903634 MRR 0.8784179372812763 cur_rank 0 abs_cur_rank 0 total_num 632 865\n",
      "215 150\n",
      "215 267 258\n",
      "checkcorrect 74 74 real score 1.8754772245883942 Hits@1 0.8170347003154574 Hits@3 0.9227129337539433 Hits@10 0.9842271293375394 MRR 0.87860970709629 cur_rank 0 abs_cur_rank 0 total_num 633 865\n",
      "215 150\n",
      "215 40 863\n",
      "checkcorrect 8 8 real score 1.7195341527462005 Hits@1 0.815748031496063 Hits@3 0.9228346456692913 Hits@10 0.984251968503937 MRR 0.8780134713370833 cur_rank 1 abs_cur_rank 1 total_num 634 865\n",
      "215 121\n",
      "215 272 583\n",
      "checkcorrect 74 74 real score 1.8799440741539002 Hits@1 0.8160377358490566 Hits@3 0.9229559748427673 Hits@10 0.9842767295597484 MRR 0.8782052740551067 cur_rank 0 abs_cur_rank 0 total_num 635 865\n",
      "215 118\n",
      "215 391 643\n",
      "checkcorrect 58 58 real score 1.767274636030197 Hits@1 0.814756671899529 Hits@3 0.9230769230769231 Hits@10 0.9843014128728415 MRR 0.8776115452104362 cur_rank 1 abs_cur_rank 2 total_num 636 865\n",
      "215 150\n",
      "215 157 1504\n",
      "checkcorrect 236 236 real score 1.5839157104492188 Hits@1 0.8150470219435737 Hits@3 0.9231974921630094 Hits@10 0.9843260188087775 MRR 0.8778033766442757 cur_rank 0 abs_cur_rank 0 total_num 637 865\n",
      "215 100\n",
      "215 130 251\n",
      "checkcorrect 26 26 real score 1.9556496918201445 Hits@1 0.8153364632237872 Hits@3 0.9233176838810642 Hits@10 0.9843505477308294 MRR 0.8779946076667415 cur_rank 0 abs_cur_rank 0 total_num 638 865\n",
      "215 103\n",
      "215 394 150\n",
      "checkcorrect 172 172 real score 1.800145220756531 Hits@1 0.815625 Hits@3 0.9234375 Hits@10 0.984375 MRR 0.8781852410922623 cur_rank 0 abs_cur_rank 0 total_num 639 865\n",
      "215 42\n",
      "215 101 33\n",
      "checkcorrect 172 172 real score 1.919441133737564 Hits@1 0.8159126365054602 Hits@3 0.9235569422776911 Hits@10 0.984399375975039 MRR 0.8783752797177034 cur_rank 0 abs_cur_rank 0 total_num 640 865\n",
      "215 145\n",
      "215 908 1004\n",
      "checkcorrect 24 24 real score 1.9136916399002075 Hits@1 0.8161993769470405 Hits@3 0.9236760124610592 Hits@10 0.9844236760124611 MRR 0.8785647263225045 cur_rank 0 abs_cur_rank 1 total_num 641 865\n",
      "215 150\n",
      "215 149 777\n",
      "checkcorrect 4 4 real score 1.89027116894722 Hits@1 0.8164852255054432 Hits@3 0.9237947122861586 Hits@10 0.9844479004665629 MRR 0.8787535836688147 cur_rank 0 abs_cur_rank 0 total_num 642 865\n",
      "215 39\n",
      "215 287 103\n",
      "checkcorrect 290 290 real score 1.6452067375183106 Hits@1 0.8167701863354038 Hits@3 0.9239130434782609 Hits@10 0.984472049689441 MRR 0.8789418545016271 cur_rank 0 abs_cur_rank 0 total_num 643 865\n",
      "215 150\n",
      "215 452 436\n",
      "checkcorrect 44 44 real score 1.8638234198093415 Hits@1 0.8170542635658915 Hits@3 0.924031007751938 Hits@10 0.9844961240310077 MRR 0.8791295415489114 cur_rank 0 abs_cur_rank 0 total_num 644 865\n",
      "215 54\n",
      "215 1026 46\n",
      "checkcorrect 20 20 real score 1.8288575410842896 Hits@1 0.8173374613003096 Hits@3 0.9241486068111455 Hits@10 0.9845201238390093 MRR 0.8793166475217459 cur_rank 0 abs_cur_rank 0 total_num 645 865\n",
      "215 57\n",
      "215 28 158\n",
      "checkcorrect 424 424 real score 0.16400597675237805 Hits@1 0.8160741885625966 Hits@3 0.9227202472952086 Hits@10 0.9829984544049459 MRR 0.8780434464522464 cur_rank 17 abs_cur_rank 17 total_num 646 865\n",
      "215 53\n",
      "215 41 261\n",
      "checkcorrect 286 286 real score 1.3344598203897475 Hits@1 0.8148148148148148 Hits@3 0.9228395061728395 Hits@10 0.9830246913580247 MRR 0.8772028444258284 cur_rank 2 abs_cur_rank 3 total_num 647 865\n",
      "215 148\n",
      "215 126 170\n",
      "checkcorrect 92 92 real score 1.6983646512031556 Hits@1 0.8151001540832049 Hits@3 0.9229583975346687 Hits@10 0.9830508474576272 MRR 0.8773920542187007 cur_rank 0 abs_cur_rank 0 total_num 648 865\n",
      "215 134\n",
      "215 391 200\n",
      "checkcorrect 26 26 real score 1.9416394412517546 Hits@1 0.8153846153846154 Hits@3 0.9230769230769231 Hits@10 0.9830769230769231 MRR 0.8775806818275951 cur_rank 0 abs_cur_rank 0 total_num 649 865\n",
      "215 20\n",
      "215 204 41\n",
      "checkcorrect 172 172 real score 1.9181798458099366 Hits@1 0.815668202764977 Hits@3 0.9231950844854071 Hits@10 0.9831029185867896 MRR 0.8777687299353868 cur_rank 0 abs_cur_rank 0 total_num 650 865\n",
      "215 22\n",
      "215 230 223\n",
      "checkcorrect 268 268 real score 1.4985201537609099 Hits@1 0.8144171779141104 Hits@3 0.9217791411042945 Hits@10 0.9831288343558282 MRR 0.8768058944600258 cur_rank 3 abs_cur_rank 3 total_num 651 865\n",
      "215 150\n",
      "215 174 99\n",
      "checkcorrect 138 138 real score 1.9841788172721864 Hits@1 0.8147013782542113 Hits@3 0.9218989280245024 Hits@10 0.9831546707503829 MRR 0.8769945531208833 cur_rank 0 abs_cur_rank 0 total_num 652 865\n",
      "215 150\n",
      "215 561 190\n",
      "checkcorrect 196 196 real score 1.8658584535121918 Hits@1 0.8149847094801224 Hits@3 0.9220183486238532 Hits@10 0.9831804281345565 MRR 0.87718263484394 cur_rank 0 abs_cur_rank 0 total_num 653 865\n",
      "215 27\n",
      "215 73 41\n",
      "checkcorrect 358 358 real score 1.8229848384857177 Hits@1 0.815267175572519 Hits@3 0.9221374045801527 Hits@10 0.983206106870229 MRR 0.8773701422716592 cur_rank 0 abs_cur_rank 0 total_num 654 865\n",
      "215 3\n",
      "215 72 43\n",
      "checkcorrect 356 356 real score 1.6081299126148223 Hits@1 0.8140243902439024 Hits@3 0.9222560975609756 Hits@10 0.9832317073170732 MRR 0.8765408178677898 cur_rank 2 abs_cur_rank 2 total_num 655 865\n",
      "215 150\n",
      "215 640 481\n",
      "checkcorrect 102 102 real score 1.9855143249034881 Hits@1 0.8143074581430746 Hits@3 0.9223744292237442 Hits@10 0.9832572298325722 MRR 0.876728731387017 cur_rank 0 abs_cur_rank 0 total_num 656 865\n",
      "215 150\n",
      "215 633 423\n",
      "checkcorrect 26 26 real score 1.939899581670761 Hits@1 0.8145896656534954 Hits@3 0.9224924012158054 Hits@10 0.9832826747720365 MRR 0.8769160737405322 cur_rank 0 abs_cur_rank 0 total_num 657 865\n",
      "215 39\n",
      "215 179 129\n",
      "checkcorrect 196 196 real score 1.8807229101657867 Hits@1 0.8148710166919575 Hits@3 0.9226100151745068 Hits@10 0.9833080424886191 MRR 0.8771028475284828 cur_rank 0 abs_cur_rank 0 total_num 658 865\n",
      "215 150\n",
      "215 192 454\n",
      "checkcorrect 112 112 real score 1.4501365303993226 Hits@1 0.8151515151515152 Hits@3 0.9227272727272727 Hits@10 0.9833333333333333 MRR 0.8772890553352578 cur_rank 0 abs_cur_rank 0 total_num 659 865\n",
      "215 150\n",
      "215 653 561\n",
      "checkcorrect 50 50 real score 1.9387305915355681 Hits@1 0.8154311649016641 Hits@3 0.9228441754916793 Hits@10 0.983358547655068 MRR 0.8774746997296069 cur_rank 0 abs_cur_rank 0 total_num 660 865\n",
      "215 150\n",
      "215 105 739\n",
      "checkcorrect 290 290 real score 1.9214237213134764 Hits@1 0.8157099697885196 Hits@3 0.9229607250755287 Hits@10 0.9833836858006042 MRR 0.8776597832647586 cur_rank 0 abs_cur_rank 0 total_num 661 865\n",
      "215 150\n",
      "215 235 831\n",
      "checkcorrect 54 54 real score 1.9113749623298646 Hits@1 0.8159879336349924 Hits@3 0.9230769230769231 Hits@10 0.9834087481146304 MRR 0.8778443084785372 cur_rank 0 abs_cur_rank 0 total_num 662 865\n",
      "215 75\n",
      "215 159 293\n",
      "checkcorrect 86 86 real score 1.486229771375656 Hits@1 0.8147590361445783 Hits@3 0.9231927710843374 Hits@10 0.983433734939759 MRR 0.8772752658452864 cur_rank 1 abs_cur_rank 1 total_num 663 865\n",
      "215 150\n",
      "215 238 535\n",
      "checkcorrect 78 78 real score 1.9660950303077698 Hits@1 0.8150375939849624 Hits@3 0.9233082706766917 Hits@10 0.9834586466165414 MRR 0.8774598143176995 cur_rank 0 abs_cur_rank 0 total_num 664 865\n",
      "215 82\n",
      "215 257 210\n",
      "checkcorrect 62 62 real score 1.7874626576900483 Hits@1 0.8153153153153153 Hits@3 0.9234234234234234 Hits@10 0.9834834834834835 MRR 0.8776438085904957 cur_rank 0 abs_cur_rank 0 total_num 665 865\n",
      "215 120\n",
      "215 353 273\n",
      "checkcorrect 34 34 real score 1.761989599466324 Hits@1 0.8140929535232384 Hits@3 0.9235382308845578 Hits@10 0.9835082458770614 MRR 0.8770776259689208 cur_rank 1 abs_cur_rank 1 total_num 666 865\n",
      "215 150\n",
      "215 205 402\n",
      "checkcorrect 26 26 real score 1.9488175570964814 Hits@1 0.8143712574850299 Hits@3 0.9236526946107785 Hits@10 0.9835329341317365 MRR 0.8772616414989074 cur_rank 0 abs_cur_rank 0 total_num 667 865\n",
      "215 150\n",
      "215 32 431\n",
      "checkcorrect 88 88 real score 1.9866407871246339 Hits@1 0.8146487294469357 Hits@3 0.9237668161434978 Hits@10 0.9835575485799701 MRR 0.8774451069077281 cur_rank 0 abs_cur_rank 0 total_num 668 865\n",
      "215 150\n",
      "215 595 470\n",
      "checkcorrect 24 24 real score 1.7723119616508485 Hits@1 0.8134328358208955 Hits@3 0.9238805970149254 Hits@10 0.9835820895522388 MRR 0.8768817560018958 cur_rank 1 abs_cur_rank 1 total_num 669 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 105\n",
      "215 62 118\n",
      "checkcorrect 26 26 real score 1.9580404162406921 Hits@1 0.8137108792846498 Hits@3 0.9239940387481371 Hits@10 0.9836065573770492 MRR 0.8770652407172431 cur_rank 0 abs_cur_rank 0 total_num 670 865\n",
      "215 111\n",
      "215 449 172\n",
      "checkcorrect 162 162 real score 1.6586456716060638 Hits@1 0.8139880952380952 Hits@3 0.9241071428571429 Hits@10 0.9836309523809523 MRR 0.8772481793471282 cur_rank 0 abs_cur_rank 0 total_num 671 865\n",
      "215 150\n",
      "215 600 520\n",
      "checkcorrect 50 50 real score 1.928325891494751 Hits@1 0.8142644873699851 Hits@3 0.924219910846954 Hits@10 0.9836552748885586 MRR 0.8774305743258101 cur_rank 0 abs_cur_rank 0 total_num 672 865\n",
      "0 1\n",
      "215 24 6\n",
      "checkcorrect 204 204 real score 0.8958005964756012 Hits@1 0.814540059347181 Hits@3 0.9243323442136498 Hits@10 0.983679525222552 MRR 0.8776124280731011 cur_rank 0 abs_cur_rank 0 total_num 673 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 178 178 real score 1.9346448063850403 Hits@1 0.8133333333333334 Hits@3 0.9244444444444444 Hits@10 0.9837037037037037 MRR 0.8770530022537335 cur_rank 1 abs_cur_rank 2 total_num 674 865\n",
      "215 150\n",
      "215 903 447\n",
      "checkcorrect 20 20 real score 1.945410543680191 Hits@1 0.8136094674556213 Hits@3 0.9245562130177515 Hits@10 0.9837278106508875 MRR 0.8772348765107546 cur_rank 0 abs_cur_rank 0 total_num 675 865\n",
      "215 150\n",
      "215 114 370\n",
      "checkcorrect 220 220 real score 1.741524839401245 Hits@1 0.8138847858197932 Hits@3 0.9246676514032496 Hits@10 0.983751846381093 MRR 0.8774162134730726 cur_rank 0 abs_cur_rank 0 total_num 676 865\n",
      "215 93\n",
      "215 532 76\n",
      "checkcorrect 16 16 real score 1.895898473262787 Hits@1 0.8141592920353983 Hits@3 0.9247787610619469 Hits@10 0.9837758112094396 MRR 0.8775970155180975 cur_rank 0 abs_cur_rank 0 total_num 677 865\n",
      "215 54\n",
      "215 133 111\n",
      "checkcorrect 238 238 real score 1.5290738761425018 Hits@1 0.812960235640648 Hits@3 0.9248895434462445 Hits@10 0.9837997054491899 MRR 0.876795448975852 cur_rank 2 abs_cur_rank 2 total_num 678 865\n",
      "215 143\n",
      "215 165 417\n",
      "checkcorrect 50 50 real score 1.7943579256534576 Hits@1 0.8117647058823529 Hits@3 0.925 Hits@10 0.9838235294117647 MRR 0.8762413380214757 cur_rank 1 abs_cur_rank 1 total_num 679 865\n",
      "215 150\n",
      "215 278 448\n",
      "checkcorrect 114 114 real score 1.9243474006652832 Hits@1 0.8120411160058737 Hits@3 0.9251101321585903 Hits@10 0.9838472834067548 MRR 0.8764230688026483 cur_rank 0 abs_cur_rank 0 total_num 680 865\n",
      "215 121\n",
      "215 347 363\n",
      "checkcorrect 16 16 real score 1.9586731493473053 Hits@1 0.8123167155425219 Hits@3 0.9252199413489736 Hits@10 0.9838709677419355 MRR 0.8766042666489787 cur_rank 0 abs_cur_rank 0 total_num 681 865\n",
      "215 12\n",
      "215 120 53\n",
      "checkcorrect 72 72 real score 1.8066262185573576 Hits@1 0.8111273792093704 Hits@3 0.9253294289897511 Hits@10 0.9838945827232797 MRR 0.8758088480057641 cur_rank 2 abs_cur_rank 2 total_num 682 865\n",
      "215 150\n",
      "215 243 747\n",
      "checkcorrect 4 4 real score 1.8721901655197144 Hits@1 0.8114035087719298 Hits@3 0.9254385964912281 Hits@10 0.9839181286549707 MRR 0.8759904140174516 cur_rank 0 abs_cur_rank 0 total_num 683 865\n",
      "215 69\n",
      "215 17 170\n",
      "checkcorrect 96 96 real score 1.7170101583003996 Hits@1 0.8116788321167884 Hits@3 0.9255474452554745 Hits@10 0.983941605839416 MRR 0.8761714499093969 cur_rank 0 abs_cur_rank 0 total_num 684 865\n",
      "215 150\n",
      "215 105 425\n",
      "checkcorrect 26 26 real score 1.9439169466495514 Hits@1 0.8119533527696793 Hits@3 0.9256559766763849 Hits@10 0.9839650145772595 MRR 0.876351957999908 cur_rank 0 abs_cur_rank 0 total_num 685 865\n",
      "215 100\n",
      "215 111 217\n",
      "checkcorrect 32 32 real score 1.774820291996002 Hits@1 0.8122270742358079 Hits@3 0.925764192139738 Hits@10 0.9839883551673945 MRR 0.8765319405937946 cur_rank 0 abs_cur_rank 0 total_num 686 865\n",
      "215 150\n",
      "215 295 767\n",
      "checkcorrect 44 44 real score 1.856050616502762 Hits@1 0.8125 Hits@3 0.9258720930232558 Hits@10 0.9840116279069767 MRR 0.8767113999824664 cur_rank 0 abs_cur_rank 0 total_num 687 865\n",
      "215 15\n",
      "215 174 190\n",
      "checkcorrect 86 86 real score 1.5365941911935805 Hits@1 0.8113207547169812 Hits@3 0.9259796806966618 Hits@10 0.9840348330914369 MRR 0.8761646490390956 cur_rank 1 abs_cur_rank 1 total_num 688 865\n",
      "215 150\n",
      "215 206 872\n",
      "checkcorrect 56 56 real score 1.9820095121860504 Hits@1 0.8115942028985508 Hits@3 0.9260869565217391 Hits@10 0.9840579710144928 MRR 0.8763441205622273 cur_rank 0 abs_cur_rank 0 total_num 689 865\n",
      "215 150\n",
      "215 231 726\n",
      "checkcorrect 58 58 real score 1.6914066672325134 Hits@1 0.8104196816208393 Hits@3 0.9261939218523878 Hits@10 0.984081041968162 MRR 0.8755582872956155 cur_rank 2 abs_cur_rank 2 total_num 690 865\n",
      "215 14\n",
      "215 125 68\n",
      "checkcorrect 50 50 real score 1.8944675087928773 Hits@1 0.8092485549132948 Hits@3 0.9263005780346821 Hits@10 0.9841040462427746 MRR 0.875015573007616 cur_rank 1 abs_cur_rank 1 total_num 691 865\n",
      "215 9\n",
      "215 158 98\n",
      "checkcorrect 50 50 real score 1.8811747908592222 Hits@1 0.8095238095238095 Hits@3 0.9264069264069265 Hits@10 0.9841269841269841 MRR 0.8751959257161187 cur_rank 0 abs_cur_rank 1 total_num 692 865\n",
      "215 150\n",
      "215 200 845\n",
      "checkcorrect 54 54 real score 1.8839063107967378 Hits@1 0.8097982708933718 Hits@3 0.9265129682997119 Hits@10 0.984149855907781 MRR 0.8753757586761819 cur_rank 0 abs_cur_rank 0 total_num 693 865\n",
      "215 14\n",
      "215 236 23\n",
      "checkcorrect 54 54 real score 1.8973206341266633 Hits@1 0.8100719424460432 Hits@3 0.9266187050359712 Hits@10 0.9841726618705036 MRR 0.8755550741313242 cur_rank 0 abs_cur_rank 0 total_num 694 865\n",
      "215 150\n",
      "215 354 292\n",
      "checkcorrect 172 172 real score 1.8866924822330473 Hits@1 0.8103448275862069 Hits@3 0.9267241379310345 Hits@10 0.9841954022988506 MRR 0.8757338743121699 cur_rank 0 abs_cur_rank 0 total_num 695 865\n",
      "215 149\n",
      "215 93 141\n",
      "checkcorrect 348 348 real score 1.8878569424152374 Hits@1 0.8106169296987088 Hits@3 0.926829268292683 Hits@10 0.9842180774748924 MRR 0.8759121614365427 cur_rank 0 abs_cur_rank 0 total_num 696 865\n",
      "215 150\n",
      "215 952 511\n",
      "checkcorrect 268 268 real score 1.2927588760852813 Hits@1 0.8094555873925502 Hits@3 0.9255014326647565 Hits@10 0.9842406876790831 MRR 0.8748960504125171 cur_rank 5 abs_cur_rank 5 total_num 697 865\n",
      "215 114\n",
      "215 355 105\n",
      "checkcorrect 16 16 real score 1.9611665129661562 Hits@1 0.8097281831187411 Hits@3 0.9256080114449213 Hits@10 0.9842632331902719 MRR 0.8750750260199384 cur_rank 0 abs_cur_rank 0 total_num 698 865\n",
      "215 149\n",
      "215 337 337\n",
      "checkcorrect 20 20 real score 1.8846917927265168 Hits@1 0.81 Hits@3 0.9257142857142857 Hits@10 0.9842857142857143 MRR 0.8752534902684813 cur_rank 0 abs_cur_rank 0 total_num 699 865\n",
      "215 144\n",
      "215 105 259\n",
      "checkcorrect 26 26 real score 1.8736574351787567 Hits@1 0.8102710413694721 Hits@3 0.9258202567760342 Hits@10 0.9843081312410842 MRR 0.8754314453465576 cur_rank 0 abs_cur_rank 0 total_num 700 865\n",
      "215 39\n",
      "215 7 30\n",
      "checkcorrect 362 362 real score 1.9285440981388091 Hits@1 0.8105413105413105 Hits@3 0.9259259259259259 Hits@10 0.9843304843304843 MRR 0.8756088934301095 cur_rank 0 abs_cur_rank 0 total_num 701 865\n",
      "215 122\n",
      "215 727 390\n",
      "checkcorrect 50 50 real score 1.581835839152336 Hits@1 0.8093883357041252 Hits@3 0.9260312944523471 Hits@10 0.984352773826458 MRR 0.8750745991293555 cur_rank 1 abs_cur_rank 1 total_num 702 865\n",
      "215 150\n",
      "215 60 210\n",
      "checkcorrect 118 118 real score 1.9765576064586639 Hits@1 0.8096590909090909 Hits@3 0.9261363636363636 Hits@10 0.984375 MRR 0.8752520499828649 cur_rank 0 abs_cur_rank 0 total_num 703 865\n",
      "215 91\n",
      "215 21 157\n",
      "checkcorrect 28 28 real score 1.9085316777229309 Hits@1 0.8099290780141843 Hits@3 0.926241134751773 Hits@10 0.9843971631205674 MRR 0.8754289974296977 cur_rank 0 abs_cur_rank 0 total_num 704 865\n",
      "215 150\n",
      "215 697 200\n",
      "checkcorrect 346 346 real score 1.6796986281871795 Hits@1 0.8087818696883853 Hits@3 0.9263456090651558 Hits@10 0.9844192634560907 MRR 0.8748972283115254 cur_rank 1 abs_cur_rank 1 total_num 705 865\n",
      "0 1\n",
      "215 17 21\n",
      "checkcorrect 194 194 real score 0.8428657472133636 Hits@1 0.809052333804809 Hits@3 0.9264497878359265 Hits@10 0.9844413012729845 MRR 0.8750741770692176 cur_rank 0 abs_cur_rank 1 total_num 706 865\n",
      "215 150\n",
      "215 424 587\n",
      "checkcorrect 84 84 real score 1.7717924237251281 Hits@1 0.809322033898305 Hits@3 0.9265536723163842 Hits@10 0.9844632768361582 MRR 0.8752506259716623 cur_rank 0 abs_cur_rank 0 total_num 707 865\n",
      "215 114\n",
      "215 166 141\n",
      "checkcorrect 276 276 real score 1.641929316520691 Hits@1 0.8095909732016925 Hits@3 0.926657263751763 Hits@10 0.9844851904090268 MRR 0.8754265771339025 cur_rank 0 abs_cur_rank 0 total_num 708 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 426 568\n",
      "checkcorrect 24 24 real score 1.901991492509842 Hits@1 0.8098591549295775 Hits@3 0.9267605633802817 Hits@10 0.9845070422535211 MRR 0.875602032659066 cur_rank 0 abs_cur_rank 1 total_num 709 865\n",
      "215 109\n",
      "215 66 309\n",
      "checkcorrect 60 60 real score 1.8109566807746886 Hits@1 0.810126582278481 Hits@3 0.9268635724331927 Hits@10 0.9845288326300985 MRR 0.8757769946384485 cur_rank 0 abs_cur_rank 0 total_num 710 865\n",
      "215 140\n",
      "215 340 1419\n",
      "checkcorrect 34 34 real score 1.8219166457653047 Hits@1 0.8103932584269663 Hits@3 0.9269662921348315 Hits@10 0.9845505617977528 MRR 0.8759514651515967 cur_rank 0 abs_cur_rank 1 total_num 711 865\n",
      "215 150\n",
      "215 342 940\n",
      "checkcorrect 20 20 real score 1.9457460999488831 Hits@1 0.8106591865357644 Hits@3 0.9270687237026648 Hits@10 0.9845722300140253 MRR 0.8761254462663911 cur_rank 0 abs_cur_rank 0 total_num 712 865\n",
      "215 62\n",
      "215 71 161\n",
      "checkcorrect 34 34 real score 1.7875672280788422 Hits@1 0.8095238095238095 Hits@3 0.927170868347339 Hits@10 0.9845938375350141 MRR 0.8755986599270825 cur_rank 1 abs_cur_rank 1 total_num 713 865\n",
      "215 98\n",
      "215 364 180\n",
      "checkcorrect 236 236 real score 1.6364198088645936 Hits@1 0.8097902097902098 Hits@3 0.9272727272727272 Hits@10 0.9846153846153847 MRR 0.8757726478152964 cur_rank 0 abs_cur_rank 0 total_num 714 865\n",
      "215 64\n",
      "215 127 12\n",
      "checkcorrect 220 220 real score 1.9324127614498137 Hits@1 0.8100558659217877 Hits@3 0.9273743016759777 Hits@10 0.9846368715083799 MRR 0.8759461497038225 cur_rank 0 abs_cur_rank 0 total_num 715 865\n",
      "215 150\n",
      "215 280 289\n",
      "checkcorrect 172 172 real score 1.903993707895279 Hits@1 0.810320781032078 Hits@3 0.9274755927475593 Hits@10 0.9846582984658299 MRR 0.8761191676261323 cur_rank 0 abs_cur_rank 0 total_num 716 865\n",
      "215 74\n",
      "215 758 196\n",
      "checkcorrect 100 100 real score 1.7620574176311492 Hits@1 0.8105849582172702 Hits@3 0.9275766016713092 Hits@10 0.9846796657381616 MRR 0.8762917036043689 cur_rank 0 abs_cur_rank 0 total_num 717 865\n",
      "215 150\n",
      "215 164 779\n",
      "checkcorrect 4 4 real score 1.893363320827484 Hits@1 0.8108484005563282 Hits@3 0.9276773296244785 Hits@10 0.9847009735744089 MRR 0.8764637596494255 cur_rank 0 abs_cur_rank 0 total_num 718 865\n",
      "215 10\n",
      "215 9 17\n",
      "checkcorrect 14 14 real score 1.9680058121681214 Hits@1 0.8111111111111111 Hits@3 0.9277777777777778 Hits@10 0.9847222222222223 MRR 0.8766353377610234 cur_rank 0 abs_cur_rank 0 total_num 719 865\n",
      "215 87\n",
      "215 277 226\n",
      "checkcorrect 248 248 real score 1.6843908786773683 Hits@1 0.811373092926491 Hits@3 0.9278779472954231 Hits@10 0.984743411927878 MRR 0.8768064399277904 cur_rank 0 abs_cur_rank 0 total_num 720 865\n",
      "0 1\n",
      "215 3 105\n",
      "checkcorrect 40 40 real score 0.8355385363101959 Hits@1 0.8116343490304709 Hits@3 0.9279778393351801 Hits@10 0.9847645429362881 MRR 0.8769770681273364 cur_rank 0 abs_cur_rank 0 total_num 721 865\n",
      "215 132\n",
      "215 740 210\n",
      "checkcorrect 348 348 real score 1.8802461743354797 Hits@1 0.8118948824343015 Hits@3 0.9280774550484094 Hits@10 0.9847856154910097 MRR 0.8771472243263304 cur_rank 0 abs_cur_rank 0 total_num 722 865\n",
      "215 150\n",
      "215 333 752\n",
      "checkcorrect 4 4 real score 1.860365903377533 Hits@1 0.8121546961325967 Hits@3 0.9281767955801105 Hits@10 0.9848066298342542 MRR 0.8773169104805758 cur_rank 0 abs_cur_rank 0 total_num 723 865\n",
      "215 28\n",
      "215 315 565\n",
      "checkcorrect 2 2 real score 1.8496214210987092 Hits@1 0.8124137931034483 Hits@3 0.9282758620689655 Hits@10 0.9848275862068966 MRR 0.8774861285350853 cur_rank 0 abs_cur_rank 1 total_num 724 865\n",
      "215 46\n",
      "215 69 21\n",
      "checkcorrect 110 110 real score 1.8592063546180726 Hits@1 0.8126721763085399 Hits@3 0.928374655647383 Hits@10 0.9848484848484849 MRR 0.8776548804241555 cur_rank 0 abs_cur_rank 0 total_num 725 865\n",
      "215 150\n",
      "215 397 322\n",
      "checkcorrect 50 50 real score 1.892677354812622 Hits@1 0.81292984869326 Hits@3 0.9284731774415406 Hits@10 0.984869325997249 MRR 0.87782316807144 cur_rank 0 abs_cur_rank 0 total_num 726 865\n",
      "215 115\n",
      "215 302 215\n",
      "checkcorrect 50 50 real score 1.8154925227165222 Hits@1 0.8131868131868132 Hits@3 0.9285714285714286 Hits@10 0.9848901098901099 MRR 0.8779909933900232 cur_rank 0 abs_cur_rank 0 total_num 727 865\n",
      "215 32\n",
      "215 174 18\n",
      "checkcorrect 80 80 real score 0.839501304924488 Hits@1 0.813443072702332 Hits@3 0.9286694101508917 Hits@10 0.9849108367626886 MRR 0.8781583582824923 cur_rank 0 abs_cur_rank 0 total_num 728 865\n",
      "215 88\n",
      "215 40 80\n",
      "checkcorrect 328 328 real score 1.9303800761699677 Hits@1 0.8136986301369863 Hits@3 0.9287671232876712 Hits@10 0.9849315068493151 MRR 0.8783252646410095 cur_rank 0 abs_cur_rank 0 total_num 729 865\n",
      "215 150\n",
      "215 341 744\n",
      "checkcorrect 56 56 real score 1.7533374607563017 Hits@1 0.8125854993160054 Hits@3 0.9288645690834473 Hits@10 0.9849521203830369 MRR 0.8778077198193391 cur_rank 1 abs_cur_rank 1 total_num 730 865\n",
      "215 150\n",
      "215 210 226\n",
      "checkcorrect 124 124 real score 1.9709635198116302 Hits@1 0.8128415300546448 Hits@3 0.9289617486338798 Hits@10 0.9849726775956285 MRR 0.8779746491638482 cur_rank 0 abs_cur_rank 0 total_num 731 865\n",
      "215 150\n",
      "215 279 235\n",
      "checkcorrect 214 214 real score 1.891348773241043 Hits@1 0.8130968622100955 Hits@3 0.9290586630286494 Hits@10 0.984993178717599 MRR 0.8781411230394773 cur_rank 0 abs_cur_rank 0 total_num 732 865\n",
      "215 132\n",
      "215 410 214\n",
      "checkcorrect 420 420 real score 1.7050606191158295 Hits@1 0.8133514986376021 Hits@3 0.9291553133514986 Hits@10 0.9850136239782016 MRR 0.8783071433078159 cur_rank 0 abs_cur_rank 0 total_num 733 865\n",
      "215 118\n",
      "215 169 179\n",
      "checkcorrect 236 236 real score 1.5834711223840712 Hits@1 0.8136054421768707 Hits@3 0.9292517006802721 Hits@10 0.9850340136054422 MRR 0.8784727118203223 cur_rank 0 abs_cur_rank 0 total_num 734 865\n",
      "0 1\n",
      "215 73 12\n",
      "checkcorrect 100 100 real score 0.8679069757461548 Hits@1 0.813858695652174 Hits@3 0.9293478260869565 Hits@10 0.9850543478260869 MRR 0.8786378304183925 cur_rank 0 abs_cur_rank 0 total_num 735 865\n",
      "215 150\n",
      "215 323 434\n",
      "checkcorrect 56 56 real score 1.9387302219867706 Hits@1 0.8141112618724559 Hits@3 0.9294436906377205 Hits@10 0.9850746268656716 MRR 0.8788025009334286 cur_rank 0 abs_cur_rank 0 total_num 736 865\n",
      "215 149\n",
      "215 212 337\n",
      "checkcorrect 20 20 real score 1.9379093885421752 Hits@1 0.8143631436314364 Hits@3 0.9295392953929539 Hits@10 0.9850948509485095 MRR 0.8789667251869063 cur_rank 0 abs_cur_rank 0 total_num 737 865\n",
      "0 0\n",
      "0 1 742\n",
      "checkcorrect 100 100 real score 0.0 Hits@1 0.8132611637347767 Hits@3 0.9282814614343707 Hits@10 0.9837618403247632 MRR 0.8778038579581517 cur_rank 50 abs_cur_rank 50 total_num 738 865\n",
      "215 10\n",
      "215 51 14\n",
      "checkcorrect 14 14 real score 1.9357627272605895 Hits@1 0.8135135135135135 Hits@3 0.9283783783783783 Hits@10 0.9837837837837838 MRR 0.8779689878798299 cur_rank 0 abs_cur_rank 0 total_num 739 865\n",
      "215 136\n",
      "215 185 560\n",
      "checkcorrect 60 60 real score 1.5961651502177119 Hits@1 0.8137651821862348 Hits@3 0.9284750337381916 Hits@10 0.9838056680161943 MRR 0.8781336721067127 cur_rank 0 abs_cur_rank 0 total_num 740 865\n",
      "215 150\n",
      "215 202 692\n",
      "checkcorrect 102 102 real score 1.9848301887512207 Hits@1 0.8140161725067385 Hits@3 0.9285714285714286 Hits@10 0.9838274932614556 MRR 0.8782979124408007 cur_rank 0 abs_cur_rank 0 total_num 741 865\n",
      "215 150\n",
      "215 295 539\n",
      "checkcorrect 78 78 real score 1.9651503920555116 Hits@1 0.8142664872139973 Hits@3 0.9286675639300135 Hits@10 0.9838492597577388 MRR 0.8784617106743932 cur_rank 0 abs_cur_rank 0 total_num 742 865\n",
      "215 148\n",
      "215 285 291\n",
      "checkcorrect 92 92 real score 1.8679814219474793 Hits@1 0.8145161290322581 Hits@3 0.928763440860215 Hits@10 0.9838709677419355 MRR 0.8786250685901534 cur_rank 0 abs_cur_rank 0 total_num 743 865\n",
      "215 42\n",
      "215 17 76\n",
      "checkcorrect 228 228 real score 1.7796509742736817 Hits@1 0.8147651006711409 Hits@3 0.9288590604026845 Hits@10 0.9838926174496644 MRR 0.8787879879611733 cur_rank 0 abs_cur_rank 0 total_num 744 865\n",
      "215 150\n",
      "215 4 262\n",
      "checkcorrect 172 172 real score 1.9191289484500884 Hits@1 0.8150134048257373 Hits@3 0.9289544235924933 Hits@10 0.9839142091152815 MRR 0.8789504705510377 cur_rank 0 abs_cur_rank 0 total_num 745 865\n",
      "215 56\n",
      "215 55 128\n",
      "checkcorrect 240 240 real score 1.70498868227005 Hits@1 0.8139223560910308 Hits@3 0.927710843373494 Hits@10 0.9839357429718876 MRR 0.8779650711833082 cur_rank 6 abs_cur_rank 6 total_num 746 865\n",
      "215 84\n",
      "215 1181 381\n",
      "checkcorrect 50 50 real score 1.7761278986930846 Hits@1 0.8141711229946524 Hits@3 0.9278074866310161 Hits@10 0.983957219251337 MRR 0.8781282194838653 cur_rank 0 abs_cur_rank 0 total_num 747 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 93\n",
      "215 259 375\n",
      "checkcorrect 28 28 real score 1.8769080281257629 Hits@1 0.8144192256341789 Hits@3 0.9279038718291055 Hits@10 0.9839786381842457 MRR 0.8782909321414302 cur_rank 0 abs_cur_rank 0 total_num 748 865\n",
      "215 150\n",
      "215 653 709\n",
      "checkcorrect 102 102 real score 1.9863856196403504 Hits@1 0.8146666666666667 Hits@3 0.928 Hits@10 0.984 MRR 0.878453210898575 cur_rank 0 abs_cur_rank 0 total_num 749 865\n",
      "0 1\n",
      "215 4 3\n",
      "checkcorrect 30 30 real score 0.8828365266323089 Hits@1 0.8135818908122503 Hits@3 0.9280958721704394 Hits@10 0.9840213049267643 MRR 0.8777273522067438 cur_rank 2 abs_cur_rank 2 total_num 750 865\n",
      "215 111\n",
      "215 764 136\n",
      "checkcorrect 16 16 real score 1.9289862871170045 Hits@1 0.8138297872340425 Hits@3 0.9281914893617021 Hits@10 0.9840425531914894 MRR 0.8778899488128519 cur_rank 0 abs_cur_rank 0 total_num 751 865\n",
      "215 71\n",
      "215 162 318\n",
      "checkcorrect 62 62 real score 1.7809447824954987 Hits@1 0.8140770252324038 Hits@3 0.9282868525896414 Hits@10 0.9840637450199203 MRR 0.8780521135554643 cur_rank 0 abs_cur_rank 0 total_num 752 865\n",
      "215 150\n",
      "215 641 508\n",
      "checkcorrect 248 248 real score 1.6762337774038314 Hits@1 0.8143236074270557 Hits@3 0.9283819628647215 Hits@10 0.9840848806366048 MRR 0.8782138481528708 cur_rank 0 abs_cur_rank 0 total_num 753 865\n",
      "215 15\n",
      "215 108 190\n",
      "checkcorrect 30 30 real score 1.5317889899015427 Hits@1 0.8132450331125828 Hits@3 0.928476821192053 Hits@10 0.9841059602649007 MRR 0.8777129026586287 cur_rank 1 abs_cur_rank 1 total_num 754 865\n",
      "215 150\n",
      "215 288 508\n",
      "checkcorrect 78 78 real score 1.9664761960506438 Hits@1 0.8134920634920635 Hits@3 0.9285714285714286 Hits@10 0.9841269841269841 MRR 0.8778746580783924 cur_rank 0 abs_cur_rank 0 total_num 755 865\n",
      "215 103\n",
      "215 512 242\n",
      "checkcorrect 46 46 real score 1.7730776727199555 Hits@1 0.8137384412153237 Hits@3 0.9286657859973579 Hits@10 0.9841479524438573 MRR 0.878035986139055 cur_rank 0 abs_cur_rank 1 total_num 756 865\n",
      "215 135\n",
      "215 370 193\n",
      "checkcorrect 46 46 real score 1.8133444309234619 Hits@1 0.8139841688654353 Hits@3 0.9287598944591029 Hits@10 0.9841688654353562 MRR 0.8781968885320114 cur_rank 0 abs_cur_rank 1 total_num 757 865\n",
      "0 1\n",
      "215 200 27\n",
      "checkcorrect 326 326 real score 0.7435405135154725 Hits@1 0.8129117259552042 Hits@3 0.927536231884058 Hits@10 0.9841897233201581 MRR 0.8773033484944198 cur_rank 4 abs_cur_rank 4 total_num 758 865\n",
      "215 148\n",
      "215 144 465\n",
      "checkcorrect 2 2 real score 1.8573649525642395 Hits@1 0.8131578947368421 Hits@3 0.9276315789473685 Hits@10 0.9842105263157894 MRR 0.8774647914569271 cur_rank 0 abs_cur_rank 0 total_num 759 865\n",
      "215 149\n",
      "215 222 252\n",
      "checkcorrect 116 116 real score 1.9890688717365266 Hits@1 0.8134034165571616 Hits@3 0.9277266754270697 Hits@10 0.9842312746386334 MRR 0.8776258101278116 cur_rank 0 abs_cur_rank 0 total_num 760 865\n",
      "215 40\n",
      "215 206 411\n",
      "checkcorrect 24 24 real score 1.8170279562473297 Hits@1 0.8123359580052494 Hits@3 0.9278215223097113 Hits@10 0.984251968503937 MRR 0.87713023819851 cur_rank 1 abs_cur_rank 1 total_num 761 865\n",
      "215 150\n",
      "215 518 489\n",
      "checkcorrect 24 24 real score 1.912260353565216 Hits@1 0.8125819134993447 Hits@3 0.927916120576671 Hits@10 0.9842726081258192 MRR 0.877291273272955 cur_rank 0 abs_cur_rank 1 total_num 762 865\n",
      "215 150\n",
      "215 284 540\n",
      "checkcorrect 50 50 real score 1.6753422141075134 Hits@1 0.81282722513089 Hits@3 0.9280104712041884 Hits@10 0.9842931937172775 MRR 0.8774518867896134 cur_rank 0 abs_cur_rank 0 total_num 763 865\n",
      "215 150\n",
      "215 722 588\n",
      "checkcorrect 44 44 real score 1.8801005601882934 Hits@1 0.8130718954248366 Hits@3 0.9281045751633987 Hits@10 0.984313725490196 MRR 0.8776120804016532 cur_rank 0 abs_cur_rank 0 total_num 764 865\n",
      "215 73\n",
      "215 211 175\n",
      "checkcorrect 100 100 real score 1.570692229270935 Hits@1 0.8120104438642297 Hits@3 0.9281984334203656 Hits@10 0.9843342036553525 MRR 0.8771191142392489 cur_rank 1 abs_cur_rank 1 total_num 765 865\n",
      "215 150\n",
      "215 34 202\n",
      "checkcorrect 280 280 real score 1.910344660282135 Hits@1 0.8109517601043025 Hits@3 0.9269882659713168 Hits@10 0.984354628422425 MRR 0.8763014882754429 cur_rank 3 abs_cur_rank 3 total_num 766 865\n",
      "215 150\n",
      "215 66 200\n",
      "checkcorrect 420 420 real score 1.7398067355155944 Hits@1 0.8111979166666666 Hits@3 0.9270833333333334 Hits@10 0.984375 MRR 0.8764625540459176 cur_rank 0 abs_cur_rank 0 total_num 767 865\n",
      "215 4\n",
      "215 37 45\n",
      "checkcorrect 120 120 real score 1.7725489020347593 Hits@1 0.811443433029909 Hits@3 0.9271781534460338 Hits@10 0.9843953185955787 MRR 0.87662320091972 cur_rank 0 abs_cur_rank 0 total_num 768 865\n",
      "215 120\n",
      "215 147 385\n",
      "checkcorrect 58 58 real score 1.759362667798996 Hits@1 0.8103896103896104 Hits@3 0.925974025974026 Hits@10 0.9844155844155844 MRR 0.8758094045548892 cur_rank 3 abs_cur_rank 3 total_num 769 865\n",
      "215 150\n",
      "215 800 332\n",
      "checkcorrect 50 50 real score 1.9214866280555727 Hits@1 0.8106355382619974 Hits@3 0.9260700389105059 Hits@10 0.9844357976653697 MRR 0.8759704818511863 cur_rank 0 abs_cur_rank 0 total_num 770 865\n",
      "215 14\n",
      "215 54 51\n",
      "checkcorrect 24 24 real score 1.9216351211071014 Hits@1 0.810880829015544 Hits@3 0.9261658031088082 Hits@10 0.9844559585492227 MRR 0.8761311418487884 cur_rank 0 abs_cur_rank 1 total_num 771 865\n",
      "215 92\n",
      "215 4 129\n",
      "checkcorrect 172 172 real score 1.9208330690860747 Hits@1 0.8111254851228978 Hits@3 0.926261319534282 Hits@10 0.9844760672703752 MRR 0.8762913861672247 cur_rank 0 abs_cur_rank 0 total_num 772 865\n",
      "215 147\n",
      "215 1083 1253\n",
      "checkcorrect 428 428 real score 0.622894525155425 Hits@1 0.810077519379845 Hits@3 0.9250645994832042 Hits@10 0.9844961240310077 MRR 0.8753437967055837 cur_rank 6 abs_cur_rank 7 total_num 773 865\n",
      "215 150\n",
      "215 351 818\n",
      "checkcorrect 54 54 real score 1.8775542318820952 Hits@1 0.8103225806451613 Hits@3 0.9251612903225807 Hits@10 0.984516129032258 MRR 0.875504643419512 cur_rank 0 abs_cur_rank 0 total_num 774 865\n",
      "215 150\n",
      "215 260 1254\n",
      "checkcorrect 236 236 real score 1.1641613990068436 Hits@1 0.8092783505154639 Hits@3 0.9252577319587629 Hits@10 0.9845360824742269 MRR 0.8750207456831466 cur_rank 1 abs_cur_rank 2 total_num 775 865\n",
      "215 94\n",
      "215 385 287\n",
      "checkcorrect 16 16 real score 1.9425333976745605 Hits@1 0.8095238095238095 Hits@3 0.9253539253539254 Hits@10 0.9845559845559846 MRR 0.8751815941443009 cur_rank 0 abs_cur_rank 0 total_num 776 865\n",
      "215 150\n",
      "215 470 814\n",
      "checkcorrect 54 54 real score 1.9189350068569184 Hits@1 0.8097686375321337 Hits@3 0.9254498714652957 Hits@10 0.9845758354755784 MRR 0.8753420291132671 cur_rank 0 abs_cur_rank 0 total_num 777 865\n",
      "215 140\n",
      "215 579 492\n",
      "checkcorrect 128 128 real score 1.828948473930359 Hits@1 0.810012836970475 Hits@3 0.9255455712451861 Hits@10 0.9845956354300385 MRR 0.8755020521824413 cur_rank 0 abs_cur_rank 0 total_num 778 865\n",
      "215 132\n",
      "215 403 476\n",
      "checkcorrect 28 28 real score 1.881699365377426 Hits@1 0.8102564102564103 Hits@3 0.9256410256410257 Hits@10 0.9846153846153847 MRR 0.8756616649360536 cur_rank 0 abs_cur_rank 0 total_num 779 865\n",
      "215 150\n",
      "215 253 404\n",
      "checkcorrect 26 26 real score 1.9553831577301026 Hits@1 0.8104993597951344 Hits@3 0.9257362355953905 Hits@10 0.9846350832266325 MRR 0.8758208689502199 cur_rank 0 abs_cur_rank 0 total_num 780 865\n",
      "215 35\n",
      "215 28 114\n",
      "checkcorrect 100 100 real score 1.868922907114029 Hits@1 0.8107416879795396 Hits@3 0.9258312020460358 Hits@10 0.9846547314578005 MRR 0.8759796657929946 cur_rank 0 abs_cur_rank 0 total_num 781 865\n",
      "215 106\n",
      "215 79 204\n",
      "checkcorrect 344 344 real score 1.8581834197044373 Hits@1 0.8109833971902938 Hits@3 0.9259259259259259 Hits@10 0.9846743295019157 MRR 0.8761380570244212 cur_rank 0 abs_cur_rank 0 total_num 782 865\n",
      "215 150\n",
      "215 287 602\n",
      "checkcorrect 44 44 real score 1.8795435547828676 Hits@1 0.8112244897959183 Hits@3 0.9260204081632653 Hits@10 0.9846938775510204 MRR 0.8762960441965839 cur_rank 0 abs_cur_rank 0 total_num 783 865\n",
      "215 146\n",
      "215 1023 583\n",
      "checkcorrect 174 174 real score 1.6164896547794343 Hits@1 0.8101910828025478 Hits@3 0.9261146496815287 Hits@10 0.9847133757961783 MRR 0.875604371953446 cur_rank 2 abs_cur_rank 3 total_num 784 865\n",
      "215 125\n",
      "215 588 482\n",
      "checkcorrect 16 16 real score 1.95505211353302 Hits@1 0.8104325699745547 Hits@3 0.926208651399491 Hits@10 0.9847328244274809 MRR 0.875762636111266 cur_rank 0 abs_cur_rank 0 total_num 785 865\n",
      "0 1\n",
      "215 8 6\n",
      "checkcorrect 36 36 real score 0.846328181028366 Hits@1 0.8106734434561627 Hits@3 0.9263024142312579 Hits@10 0.9847522236340533 MRR 0.8759204980730052 cur_rank 0 abs_cur_rank 0 total_num 786 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 101\n",
      "215 46 79\n",
      "checkcorrect 344 344 real score 1.8799189507961271 Hits@1 0.8109137055837563 Hits@3 0.9263959390862944 Hits@10 0.9847715736040609 MRR 0.8760779593698669 cur_rank 0 abs_cur_rank 0 total_num 787 865\n",
      "215 150\n",
      "215 392 588\n",
      "checkcorrect 56 56 real score 1.9023813307285309 Hits@1 0.8111533586818758 Hits@3 0.926489226869455 Hits@10 0.9847908745247148 MRR 0.8762350215252916 cur_rank 0 abs_cur_rank 0 total_num 788 865\n",
      "0 1\n",
      "0 2 3\n",
      "checkcorrect 36 36 real score 0.0 Hits@1 0.810126582278481 Hits@3 0.9253164556962026 Hits@10 0.9835443037974684 MRR 0.8751924855220286 cur_rank 18 abs_cur_rank 18 total_num 789 865\n",
      "215 150\n",
      "215 586 1185\n",
      "checkcorrect 50 50 real score 1.8359325587749482 Hits@1 0.8103666245259166 Hits@3 0.9254108723135271 Hits@10 0.9835651074589128 MRR 0.8753502699903951 cur_rank 0 abs_cur_rank 0 total_num 790 865\n",
      "215 150\n",
      "215 331 514\n",
      "checkcorrect 78 78 real score 1.96550452709198 Hits@1 0.8106060606060606 Hits@3 0.9255050505050505 Hits@10 0.9835858585858586 MRR 0.8755076560131345 cur_rank 0 abs_cur_rank 0 total_num 791 865\n",
      "215 26\n",
      "215 118 142\n",
      "checkcorrect 72 72 real score 1.7484278917312621 Hits@1 0.8095838587641866 Hits@3 0.9255989911727617 Hits@10 0.9836065573770492 MRR 0.8748239557323277 cur_rank 2 abs_cur_rank 2 total_num 792 865\n",
      "215 132\n",
      "215 139 344\n",
      "checkcorrect 158 158 real score 1.8825489223003387 Hits@1 0.809823677581864 Hits@3 0.9256926952141058 Hits@10 0.9836272040302267 MRR 0.8749816081810275 cur_rank 0 abs_cur_rank 0 total_num 793 865\n",
      "215 150\n",
      "215 22 256\n",
      "checkcorrect 26 26 real score 1.915436065196991 Hits@1 0.810062893081761 Hits@3 0.9257861635220126 Hits@10 0.9836477987421384 MRR 0.8751388640197936 cur_rank 0 abs_cur_rank 0 total_num 794 865\n",
      "215 64\n",
      "215 185 256\n",
      "checkcorrect 62 62 real score 1.7863953590393065 Hits@1 0.8103015075376885 Hits@3 0.9258793969849246 Hits@10 0.9836683417085427 MRR 0.8752957247433868 cur_rank 0 abs_cur_rank 0 total_num 795 865\n",
      "215 150\n",
      "215 52 896\n",
      "checkcorrect 56 56 real score 1.868735432624817 Hits@1 0.8105395232120451 Hits@3 0.9259723964868256 Hits@10 0.9836888331242158 MRR 0.8754521918390664 cur_rank 0 abs_cur_rank 0 total_num 796 865\n",
      "215 140\n",
      "215 598 950\n",
      "checkcorrect 50 50 real score 1.926314491033554 Hits@1 0.8107769423558897 Hits@3 0.9260651629072681 Hits@10 0.9837092731829574 MRR 0.8756082667866365 cur_rank 0 abs_cur_rank 0 total_num 797 865\n",
      "0 1\n",
      "215 229 36\n",
      "checkcorrect 36 36 real score 0.6246457099914551 Hits@1 0.8110137672090113 Hits@3 0.9261576971214017 Hits@10 0.983729662077597 MRR 0.875763951058493 cur_rank 0 abs_cur_rank 0 total_num 798 865\n",
      "215 115\n",
      "215 176 329\n",
      "checkcorrect 2 2 real score 1.70136559009552 Hits@1 0.81125 Hits@3 0.92625 Hits@10 0.98375 MRR 0.8759192461196699 cur_rank 0 abs_cur_rank 0 total_num 799 865\n",
      "215 3\n",
      "215 27 15\n",
      "checkcorrect 380 380 real score 1.2548736333847046 Hits@1 0.8102372034956304 Hits@3 0.9250936329588015 Hits@10 0.9837702871410736 MRR 0.87513782383987 cur_rank 3 abs_cur_rank 4 total_num 800 865\n",
      "215 150\n",
      "215 85 1716\n",
      "checkcorrect 236 236 real score 1.6714334964752195 Hits@1 0.8104738154613467 Hits@3 0.9251870324189526 Hits@10 0.983790523690773 MRR 0.8752935123388228 cur_rank 0 abs_cur_rank 0 total_num 801 865\n",
      "0 1\n",
      "215 3 53\n",
      "checkcorrect 38 38 real score 0.7098116517066956 Hits@1 0.8107098381070984 Hits@3 0.925280199252802 Hits@10 0.9838107098381071 MRR 0.8754488130706549 cur_rank 0 abs_cur_rank 0 total_num 802 865\n",
      "0 1\n",
      "0 1 1\n",
      "checkcorrect 34 34 real score 0.0 Hits@1 0.8097014925373134 Hits@3 0.9241293532338308 Hits@10 0.9825870646766169 MRR 0.8744290453374272 cur_rank 17 abs_cur_rank 17 total_num 803 865\n",
      "215 148\n",
      "215 147 174\n",
      "checkcorrect 178 178 real score 1.932507473230362 Hits@1 0.808695652173913 Hits@3 0.924223602484472 Hits@10 0.9826086956521739 MRR 0.8739639160885608 cur_rank 1 abs_cur_rank 2 total_num 804 865\n",
      "215 87\n",
      "215 418 240\n",
      "checkcorrect 32 32 real score 1.7268926918506624 Hits@1 0.8089330024813896 Hits@3 0.924317617866005 Hits@10 0.9826302729528535 MRR 0.874120288401106 cur_rank 0 abs_cur_rank 0 total_num 805 865\n",
      "215 25\n",
      "215 177 56\n",
      "checkcorrect 120 120 real score 1.6946735084056854 Hits@1 0.8091697645600991 Hits@3 0.9244114002478315 Hits@10 0.9826517967781908 MRR 0.8742762731738432 cur_rank 0 abs_cur_rank 0 total_num 806 865\n",
      "215 148\n",
      "215 762 280\n",
      "checkcorrect 16 16 real score 1.9451826572418214 Hits@1 0.8094059405940595 Hits@3 0.9245049504950495 Hits@10 0.9826732673267327 MRR 0.8744318718456577 cur_rank 0 abs_cur_rank 0 total_num 807 865\n",
      "215 150\n",
      "215 997 892\n",
      "checkcorrect 24 24 real score 1.8715474873781204 Hits@1 0.8084054388133498 Hits@3 0.9245982694684796 Hits@10 0.9826946847960445 MRR 0.8739690388767508 cur_rank 1 abs_cur_rank 1 total_num 808 865\n",
      "215 41\n",
      "215 929 223\n",
      "checkcorrect 420 420 real score 1.6463651716709138 Hits@1 0.808641975308642 Hits@3 0.9246913580246914 Hits@10 0.9827160493827161 MRR 0.8741246326559153 cur_rank 0 abs_cur_rank 0 total_num 809 865\n",
      "215 111\n",
      "215 73 195\n",
      "checkcorrect 172 172 real score 1.8961874902248383 Hits@1 0.8088779284833539 Hits@3 0.9247842170160296 Hits@10 0.9827373612823674 MRR 0.8742798427266233 cur_rank 0 abs_cur_rank 0 total_num 810 865\n",
      "215 148\n",
      "215 375 368\n",
      "checkcorrect 52 52 real score 1.8410235166549684 Hits@1 0.8091133004926109 Hits@3 0.9248768472906403 Hits@10 0.9827586206896551 MRR 0.8744346705065166 cur_rank 0 abs_cur_rank 0 total_num 811 865\n",
      "215 107\n",
      "215 188 76\n",
      "checkcorrect 112 112 real score 1.323784065246582 Hits@1 0.8093480934809348 Hits@3 0.9249692496924969 Hits@10 0.982779827798278 MRR 0.8745891174062626 cur_rank 0 abs_cur_rank 0 total_num 812 865\n",
      "215 150\n",
      "215 190 764\n",
      "checkcorrect 54 54 real score 1.8558640003204347 Hits@1 0.8095823095823096 Hits@3 0.9250614250614251 Hits@10 0.9828009828009828 MRR 0.8747431848295963 cur_rank 0 abs_cur_rank 0 total_num 813 865\n",
      "215 150\n",
      "215 21 1491\n",
      "checkcorrect 236 236 real score 1.4274728119373323 Hits@1 0.8098159509202454 Hits@3 0.9251533742331288 Hits@10 0.9828220858895705 MRR 0.8748968741733637 cur_rank 0 abs_cur_rank 0 total_num 814 865\n",
      "215 150\n",
      "215 231 518\n",
      "checkcorrect 78 78 real score 1.9621010303497313 Hits@1 0.8100490196078431 Hits@3 0.9252450980392157 Hits@10 0.9828431372549019 MRR 0.8750501868275631 cur_rank 0 abs_cur_rank 0 total_num 815 865\n",
      "0 1\n",
      "215 21 179\n",
      "checkcorrect 46 46 real score 0.7972358465194702 Hits@1 0.8102815177478581 Hits@3 0.9253365973072215 Hits@10 0.9828641370869033 MRR 0.8752031241753874 cur_rank 0 abs_cur_rank 0 total_num 816 865\n",
      "215 150\n",
      "215 243 403\n",
      "checkcorrect 26 26 real score 1.9057157993316651 Hits@1 0.8105134474327629 Hits@3 0.9254278728606357 Hits@10 0.9828850855745721 MRR 0.8753556875932659 cur_rank 0 abs_cur_rank 0 total_num 817 865\n",
      "215 150\n",
      "215 66 225\n",
      "checkcorrect 20 20 real score 1.9579026103019714 Hits@1 0.8107448107448108 Hits@3 0.9255189255189256 Hits@10 0.9829059829059829 MRR 0.8755078784509053 cur_rank 0 abs_cur_rank 0 total_num 818 865\n",
      "215 129\n",
      "215 967 320\n",
      "checkcorrect 122 122 real score 1.9631331264972687 Hits@1 0.8109756097560976 Hits@3 0.925609756097561 Hits@10 0.9829268292682927 MRR 0.875659698111331 cur_rank 0 abs_cur_rank 0 total_num 819 865\n",
      "215 116\n",
      "215 108 389\n",
      "checkcorrect 44 44 real score 1.8685194611549378 Hits@1 0.8112058465286236 Hits@3 0.925700365408039 Hits@10 0.9829476248477467 MRR 0.8758111479309275 cur_rank 0 abs_cur_rank 0 total_num 820 865\n",
      "215 150\n",
      "215 558 402\n",
      "checkcorrect 24 24 real score 1.9356404840946198 Hits@1 0.8102189781021898 Hits@3 0.9257907542579076 Hits@10 0.9829683698296837 MRR 0.8753539567533959 cur_rank 1 abs_cur_rank 1 total_num 821 865\n",
      "0 1\n",
      "215 68 8\n",
      "checkcorrect 100 100 real score 0.8679903388023377 Hits@1 0.81044957472661 Hits@3 0.9258809234507898 Hits@10 0.982989064398542 MRR 0.8755054100258706 cur_rank 0 abs_cur_rank 0 total_num 822 865\n",
      "215 150\n",
      "215 596 739\n",
      "checkcorrect 56 56 real score 1.9116450190544128 Hits@1 0.8106796116504854 Hits@3 0.9259708737864077 Hits@10 0.9830097087378641 MRR 0.8756564956933148 cur_rank 0 abs_cur_rank 0 total_num 823 865\n",
      "215 150\n",
      "215 223 210\n",
      "checkcorrect 118 118 real score 1.9765209436416624 Hits@1 0.8109090909090909 Hits@3 0.926060606060606 Hits@10 0.983030303030303 MRR 0.8758072150924745 cur_rank 0 abs_cur_rank 0 total_num 824 865\n",
      "215 150\n",
      "215 21 722\n",
      "checkcorrect 4 4 real score 1.8247322976589202 Hits@1 0.8111380145278451 Hits@3 0.9261501210653753 Hits@10 0.9830508474576272 MRR 0.8759575695536216 cur_rank 0 abs_cur_rank 0 total_num 825 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 92\n",
      "215 58 204\n",
      "checkcorrect 2 2 real score 1.4894314646720885 Hits@1 0.81136638452237 Hits@3 0.9262394195888755 Hits@10 0.9830713422007256 MRR 0.8761075604005942 cur_rank 0 abs_cur_rank 0 total_num 826 865\n",
      "0 1\n",
      "215 8 17\n",
      "checkcorrect 30 30 real score 0.8917038679122925 Hits@1 0.8103864734299517 Hits@3 0.9263285024154589 Hits@10 0.9830917874396136 MRR 0.8754520359717691 cur_rank 2 abs_cur_rank 2 total_num 827 865\n",
      "215 150\n",
      "215 21 705\n",
      "checkcorrect 54 54 real score 1.8695105135440828 Hits@1 0.8106151990349819 Hits@3 0.9264173703256936 Hits@10 0.9831121833534379 MRR 0.8756022747703557 cur_rank 0 abs_cur_rank 0 total_num 828 865\n",
      "215 21\n",
      "215 43 151\n",
      "checkcorrect 222 222 real score 1.7758529841899873 Hits@1 0.810843373493976 Hits@3 0.9265060240963855 Hits@10 0.983132530120482 MRR 0.8757521515477408 cur_rank 0 abs_cur_rank 0 total_num 829 865\n",
      "215 136\n",
      "215 52 328\n",
      "checkcorrect 2 2 real score 1.9085263431072237 Hits@1 0.8110709987966306 Hits@3 0.9265944645006017 Hits@10 0.9831528279181708 MRR 0.8759016676108602 cur_rank 0 abs_cur_rank 0 total_num 830 865\n",
      "215 43\n",
      "215 243 245\n",
      "checkcorrect 126 126 real score 1.8075195610523225 Hits@1 0.8112980769230769 Hits@3 0.9266826923076923 Hits@10 0.9831730769230769 MRR 0.8760508242603664 cur_rank 0 abs_cur_rank 1 total_num 831 865\n",
      "0 1\n",
      "215 978 120\n",
      "checkcorrect 30 30 real score 0.8009895026683808 Hits@1 0.8103241296518607 Hits@3 0.9267707082833133 Hits@10 0.9831932773109243 MRR 0.8753993026626149 cur_rank 2 abs_cur_rank 2 total_num 832 865\n",
      "215 150\n",
      "215 66 926\n",
      "checkcorrect 54 54 real score 1.8283542096614838 Hits@1 0.8105515587529976 Hits@3 0.9268585131894485 Hits@10 0.9832134292565947 MRR 0.8755487039783671 cur_rank 0 abs_cur_rank 0 total_num 833 865\n",
      "215 150\n",
      "215 154 64\n",
      "checkcorrect 168 168 real score 1.9568054616451263 Hits@1 0.8095808383233533 Hits@3 0.9269461077844311 Hits@10 0.9832335329341317 MRR 0.8750989450514469 cur_rank 1 abs_cur_rank 1 total_num 834 865\n",
      "215 150\n",
      "215 520 790\n",
      "checkcorrect 4 4 real score 1.8989531636238097 Hits@1 0.8098086124401914 Hits@3 0.9270334928229665 Hits@10 0.9832535885167464 MRR 0.8752483482272227 cur_rank 0 abs_cur_rank 0 total_num 835 865\n",
      "215 150\n",
      "215 128 762\n",
      "checkcorrect 4 4 real score 1.8796511411666872 Hits@1 0.8100358422939068 Hits@3 0.927120669056153 Hits@10 0.983273596176822 MRR 0.8753973944061627 cur_rank 0 abs_cur_rank 0 total_num 836 865\n",
      "215 90\n",
      "215 326 246\n",
      "checkcorrect 16 16 real score 1.9407063841819765 Hits@1 0.8102625298329356 Hits@3 0.9272076372315036 Hits@10 0.9832935560859188 MRR 0.8755460848662986 cur_rank 0 abs_cur_rank 0 total_num 837 865\n",
      "215 59\n",
      "215 469 122\n",
      "checkcorrect 162 162 real score 1.6725920855998992 Hits@1 0.8104886769964244 Hits@3 0.9272943980929678 Hits@10 0.9833134684147795 MRR 0.8756944208795687 cur_rank 0 abs_cur_rank 0 total_num 838 865\n",
      "215 150\n",
      "215 524 900\n",
      "checkcorrect 56 56 real score 1.7345379382371902 Hits@1 0.8095238095238095 Hits@3 0.9273809523809524 Hits@10 0.9833333333333333 MRR 0.8752471656166169 cur_rank 1 abs_cur_rank 1 total_num 839 865\n",
      "215 90\n",
      "215 9 148\n",
      "checkcorrect 2 2 real score 1.8302065789699555 Hits@1 0.8097502972651606 Hits@3 0.9274673008323424 Hits@10 0.9833531510107015 MRR 0.8753955043019717 cur_rank 0 abs_cur_rank 0 total_num 840 865\n",
      "215 126\n",
      "215 32 394\n",
      "checkcorrect 52 52 real score 1.8048085153102873 Hits@1 0.8099762470308789 Hits@3 0.9275534441805225 Hits@10 0.9833729216152018 MRR 0.8755434906389052 cur_rank 0 abs_cur_rank 0 total_num 841 865\n",
      "215 150\n",
      "215 462 433\n",
      "checkcorrect 56 56 real score 1.8154988646507264 Hits@1 0.8102016607354685 Hits@3 0.9276393831553974 Hits@10 0.9833926453143536 MRR 0.8756911258813265 cur_rank 0 abs_cur_rank 0 total_num 842 865\n",
      "215 128\n",
      "215 566 789\n",
      "checkcorrect 0 0 real score 1.6438694924116133 Hits@1 0.8104265402843602 Hits@3 0.9277251184834123 Hits@10 0.9834123222748815 MRR 0.8758384112772016 cur_rank 0 abs_cur_rank 0 total_num 843 865\n",
      "215 80\n",
      "215 90 466\n",
      "checkcorrect 24 24 real score 1.6753757059574128 Hits@1 0.8094674556213017 Hits@3 0.927810650887574 Hits@10 0.9834319526627219 MRR 0.8753936320922582 cur_rank 1 abs_cur_rank 1 total_num 844 865\n",
      "215 123\n",
      "215 227 334\n",
      "checkcorrect 24 24 real score 1.8464994549751284 Hits@1 0.8096926713947991 Hits@3 0.9278959810874704 Hits@10 0.983451536643026 MRR 0.875540920943213 cur_rank 0 abs_cur_rank 1 total_num 845 865\n",
      "215 49\n",
      "215 670 339\n",
      "checkcorrect 50 50 real score 1.8613441824913024 Hits@1 0.8099173553719008 Hits@3 0.9279811097992916 Hits@10 0.9834710743801653 MRR 0.8756878620046732 cur_rank 0 abs_cur_rank 0 total_num 846 865\n",
      "215 139\n",
      "215 496 195\n",
      "checkcorrect 162 162 real score 1.8833932042121888 Hits@1 0.8101415094339622 Hits@3 0.9280660377358491 Hits@10 0.9834905660377359 MRR 0.8758344565070262 cur_rank 0 abs_cur_rank 0 total_num 847 865\n",
      "215 150\n",
      "215 611 378\n",
      "checkcorrect 2 2 real score 1.883149254322052 Hits@1 0.8103651354534747 Hits@3 0.928150765606596 Hits@10 0.983510011778563 MRR 0.8759807056748624 cur_rank 0 abs_cur_rank 0 total_num 848 865\n",
      "215 135\n",
      "215 160 85\n",
      "checkcorrect 92 92 real score 1.9310617446899414 Hits@1 0.8105882352941176 Hits@3 0.928235294117647 Hits@10 0.9835294117647059 MRR 0.8761266107270096 cur_rank 0 abs_cur_rank 0 total_num 849 865\n",
      "215 64\n",
      "215 39 74\n",
      "checkcorrect 240 240 real score 1.6747098028659821 Hits@1 0.8096357226792009 Hits@3 0.927144535840188 Hits@10 0.9835487661574618 MRR 0.875243970761408 cur_rank 7 abs_cur_rank 7 total_num 850 865\n",
      "215 8\n",
      "215 90 30\n",
      "checkcorrect 202 202 real score 1.7163392364978791 Hits@1 0.8098591549295775 Hits@3 0.9272300469483568 Hits@10 0.9835680751173709 MRR 0.8753903980257726 cur_rank 0 abs_cur_rank 0 total_num 851 865\n",
      "215 29\n",
      "215 45 187\n",
      "checkcorrect 126 126 real score 1.5676181972026826 Hits@1 0.8089097303634232 Hits@3 0.9261430246189918 Hits@10 0.9835873388042204 MRR 0.8745316251592208 cur_rank 6 abs_cur_rank 6 total_num 852 865\n",
      "215 139\n",
      "215 622 224\n",
      "checkcorrect 56 56 real score 1.8983530700206757 Hits@1 0.8091334894613583 Hits@3 0.9262295081967213 Hits@10 0.9836065573770492 MRR 0.8746785436309312 cur_rank 0 abs_cur_rank 0 total_num 853 865\n",
      "215 16\n",
      "215 63 15\n",
      "checkcorrect 100 100 real score 1.8604244470596314 Hits@1 0.8093567251461988 Hits@3 0.9263157894736842 Hits@10 0.9836257309941521 MRR 0.8748251184337021 cur_rank 0 abs_cur_rank 0 total_num 854 865\n",
      "215 141\n",
      "215 28 268\n",
      "checkcorrect 26 26 real score 1.9577440679073335 Hits@1 0.8095794392523364 Hits@3 0.9264018691588785 Hits@10 0.9836448598130841 MRR 0.8749713507719805 cur_rank 0 abs_cur_rank 0 total_num 855 865\n",
      "0 1\n",
      "215 153 15\n",
      "checkcorrect 100 100 real score 0.8997398257255554 Hits@1 0.809801633605601 Hits@3 0.926487747957993 Hits@10 0.9836639439906651 MRR 0.8751172418445919 cur_rank 0 abs_cur_rank 0 total_num 856 865\n",
      "215 150\n",
      "215 445 546\n",
      "checkcorrect 176 176 real score 1.9652807354927062 Hits@1 0.8088578088578089 Hits@3 0.9265734265734266 Hits@10 0.9836829836829837 MRR 0.8746800422620225 cur_rank 1 abs_cur_rank 1 total_num 857 865\n",
      "215 126\n",
      "215 332 523\n",
      "checkcorrect 74 74 real score 1.9014305472373962 Hits@1 0.8090803259604191 Hits@3 0.9266589057043073 Hits@10 0.9837019790454016 MRR 0.8748259327832542 cur_rank 0 abs_cur_rank 0 total_num 858 865\n",
      "215 85\n",
      "215 45 73\n",
      "checkcorrect 364 364 real score 1.9243211448192596 Hits@1 0.8093023255813954 Hits@3 0.9267441860465117 Hits@10 0.9837209302325581 MRR 0.8749714840242039 cur_rank 0 abs_cur_rank 0 total_num 859 865\n",
      "215 150\n",
      "215 885 686\n",
      "checkcorrect 54 54 real score 1.8704172134399415 Hits@1 0.8095238095238095 Hits@3 0.926829268292683 Hits@10 0.983739837398374 MRR 0.8751166971670329 cur_rank 0 abs_cur_rank 0 total_num 860 865\n",
      "215 150\n",
      "215 48 859\n",
      "checkcorrect 54 54 real score 1.9661674082279204 Hits@1 0.8097447795823666 Hits@3 0.9269141531322506 Hits@10 0.9837587006960556 MRR 0.8752615733884168 cur_rank 0 abs_cur_rank 0 total_num 861 865\n",
      "215 150\n",
      "215 104 930\n",
      "checkcorrect 126 126 real score 1.8228792428970335 Hits@1 0.8088064889918888 Hits@3 0.9269988412514485 Hits@10 0.9837775202780996 MRR 0.8748267395837952 cur_rank 1 abs_cur_rank 1 total_num 862 865\n",
      "215 150\n",
      "215 680 715\n",
      "checkcorrect 4 4 real score 1.8798391461372375 Hits@1 0.8090277777777778 Hits@3 0.9270833333333334 Hits@10 0.9837962962962963 MRR 0.8749716160426103 cur_rank 0 abs_cur_rank 0 total_num 863 865\n",
      "215 48\n",
      "215 54 23\n",
      "checkcorrect 110 110 real score 1.9025265157222748 Hits@1 0.8092485549132948 Hits@3 0.9271676300578034 Hits@10 0.9838150289017341 MRR 0.8751161575269542 cur_rank 0 abs_cur_rank 0 total_num 864 865\n"
     ]
    }
   ],
   "source": [
    "########################################################\n",
    "#obtain the Hits@N for relation prediction##############\n",
    "\n",
    "#we select all the triples in the inductive test set\n",
    "selected = list(data_ind_test)\n",
    "\n",
    "###Hit at 1#############################\n",
    "#generate the negative samples by randomly replace relation with all the other relaiton\n",
    "Hits_at_1 = 0\n",
    "Hits_at_3 = 0\n",
    "Hits_at_10 = 0\n",
    "MRR_raw = 0.\n",
    "\n",
    "for i in range(len(selected)):\n",
    "    \n",
    "    s_true, r_true, t_true = selected[i][0], selected[i][1], selected[i][2]\n",
    "    \n",
    "    #run the path-based scoring\n",
    "    score_dict_path = path_based_relation_scoring(s_true, t_true, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "    \n",
    "    #run the one-hop neighbour based scoring\n",
    "    score_dict_subg = subgraph_relation_scoring(s_true, t_true, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "    \n",
    "    #final score dict\n",
    "    score_dict = defaultdict(float)\n",
    "    \n",
    "    for r in score_dict_path:\n",
    "        score_dict[r] += score_dict_path[r]\n",
    "    for r in score_dict_subg:\n",
    "        score_dict[r] += score_dict_subg[r]\n",
    "    \n",
    "    #[... [score, r], ...]\n",
    "    temp_list = list()\n",
    "    \n",
    "    for r in id2relation:\n",
    "        \n",
    "        #again, we only care about initial relation prediciton\n",
    "        if r % 2 == 0:\n",
    "        \n",
    "            if r in score_dict:\n",
    "\n",
    "                temp_list.append([score_dict[r], r])\n",
    "\n",
    "            else:\n",
    "\n",
    "                temp_list.append([0.0, r])\n",
    "        \n",
    "    sorted_list = sorted(temp_list, key = lambda x: x[0], reverse=True)\n",
    "    \n",
    "    p = 0\n",
    "    exist_tri = 0\n",
    "    \n",
    "    while p < len(sorted_list) and sorted_list[p][1] != r_true:\n",
    "        \n",
    "        #moreover, we want to remove existing triples\n",
    "        if ((s_true, sorted_list[p][1], t_true) in data_test) or (\n",
    "            (s_true, sorted_list[p][1], t_true) in data_valid) or (\n",
    "            (s_true, sorted_list[p][1], t_true) in data) or (\n",
    "            (s_true, sorted_list[p][1], t_true) in data_ind) or (\n",
    "            (s_true, sorted_list[p][1], t_true) in data_ind_valid) or (\n",
    "            (s_true, sorted_list[p][1], t_true) in data_ind_test):\n",
    "            \n",
    "            exist_tri += 1\n",
    "            \n",
    "        p += 1\n",
    "    \n",
    "    if p - exist_tri == 0:\n",
    "        \n",
    "        Hits_at_1 += 1\n",
    "        \n",
    "    if p - exist_tri < 3:\n",
    "        \n",
    "        Hits_at_3 += 1\n",
    "        \n",
    "    if p - exist_tri < 10:\n",
    "        \n",
    "        Hits_at_10 += 1\n",
    "        \n",
    "    MRR_raw += 1./float(p - exist_tri + 1.) \n",
    "        \n",
    "    print('checkcorrect', r_true, sorted_list[p][1],\n",
    "          'real score', sorted_list[p][0],\n",
    "          'Hits@1', Hits_at_1/(i+1),\n",
    "          'Hits@3', Hits_at_3/(i+1),\n",
    "          'Hits@10', Hits_at_10/(i+1),\n",
    "          'MRR', MRR_raw/(i+1),\n",
    "          'cur_rank', p - exist_tri,\n",
    "          'abs_cur_rank', p,\n",
    "          'total_num', i, len(selected))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "e1f0b73c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating scores 20 1730\n",
      "AUC-PR is: 0.9852430555555556\n",
      "evaluating scores 40 1730\n",
      "AUC-PR is: 0.9736755371640619\n",
      "evaluating scores 60 1730\n",
      "AUC-PR is: 0.9450227531205483\n",
      "evaluating scores 80 1730\n",
      "AUC-PR is: 0.9537486801198717\n",
      "evaluating scores 100 1730\n",
      "AUC-PR is: 0.9383628747133985\n",
      "evaluating scores 120 1730\n",
      "AUC-PR is: 0.9354111163403978\n",
      "evaluating scores 140 1730\n",
      "AUC-PR is: 0.9227295341077255\n",
      "evaluating scores 160 1730\n",
      "AUC-PR is: 0.8913037360408513\n",
      "evaluating scores 180 1730\n",
      "AUC-PR is: 0.8920137354828699\n",
      "evaluating scores 200 1730\n",
      "AUC-PR is: 0.8966200205729069\n",
      "evaluating scores 220 1730\n",
      "AUC-PR is: 0.9024831374065003\n",
      "evaluating scores 240 1730\n",
      "AUC-PR is: 0.907238665878264\n",
      "evaluating scores 260 1730\n",
      "AUC-PR is: 0.909856145403814\n",
      "evaluating scores 280 1730\n",
      "AUC-PR is: 0.9122543328043633\n",
      "evaluating scores 300 1730\n",
      "AUC-PR is: 0.915776563142007\n",
      "evaluating scores 320 1730\n",
      "AUC-PR is: 0.9005574321931236\n",
      "evaluating scores 340 1730\n",
      "AUC-PR is: 0.9004991342096755\n",
      "evaluating scores 360 1730\n",
      "AUC-PR is: 0.8865383814465223\n",
      "evaluating scores 380 1730\n",
      "AUC-PR is: 0.8904357754475631\n",
      "evaluating scores 400 1730\n",
      "AUC-PR is: 0.8888823723938346\n",
      "evaluating scores 420 1730\n",
      "AUC-PR is: 0.8894393044769084\n",
      "evaluating scores 440 1730\n",
      "AUC-PR is: 0.8972345676433087\n",
      "evaluating scores 460 1730\n",
      "AUC-PR is: 0.8977297932422746\n",
      "evaluating scores 480 1730\n",
      "AUC-PR is: 0.8985175073632012\n",
      "evaluating scores 500 1730\n",
      "AUC-PR is: 0.9030280431623339\n",
      "evaluating scores 520 1730\n",
      "AUC-PR is: 0.9037944894336748\n",
      "evaluating scores 540 1730\n",
      "AUC-PR is: 0.904920159507356\n",
      "evaluating scores 560 1730\n",
      "AUC-PR is: 0.9039812306048792\n",
      "evaluating scores 580 1730\n",
      "AUC-PR is: 0.9114296882963586\n",
      "evaluating scores 600 1730\n",
      "AUC-PR is: 0.9138864134591859\n",
      "evaluating scores 620 1730\n",
      "AUC-PR is: 0.9143768668013732\n",
      "evaluating scores 640 1730\n",
      "AUC-PR is: 0.9147187564636892\n",
      "evaluating scores 660 1730\n",
      "AUC-PR is: 0.9131861102096883\n",
      "evaluating scores 680 1730\n",
      "AUC-PR is: 0.9152916617162028\n",
      "evaluating scores 700 1730\n",
      "AUC-PR is: 0.9154650486161952\n",
      "evaluating scores 720 1730\n",
      "AUC-PR is: 0.9173072314081727\n",
      "evaluating scores 740 1730\n",
      "AUC-PR is: 0.9126353642250697\n",
      "evaluating scores 760 1730\n",
      "AUC-PR is: 0.9143067434639399\n",
      "evaluating scores 780 1730\n",
      "AUC-PR is: 0.9152095348194357\n",
      "evaluating scores 800 1730\n",
      "AUC-PR is: 0.9172652695467648\n",
      "evaluating scores 820 1730\n",
      "AUC-PR is: 0.918332762152622\n",
      "evaluating scores 840 1730\n",
      "AUC-PR is: 0.9191087525450733\n",
      "evaluating scores 860 1730\n",
      "AUC-PR is: 0.9198919028101757\n",
      "evaluating scores 880 1730\n",
      "AUC-PR is: 0.9225992472204707\n",
      "evaluating scores 900 1730\n",
      "AUC-PR is: 0.920903303863658\n",
      "evaluating scores 920 1730\n",
      "AUC-PR is: 0.9192533407136273\n",
      "evaluating scores 940 1730\n",
      "AUC-PR is: 0.9200678565781291\n",
      "evaluating scores 960 1730\n",
      "AUC-PR is: 0.9213226925890656\n",
      "evaluating scores 980 1730\n",
      "AUC-PR is: 0.9211075984691545\n",
      "evaluating scores 1000 1730\n",
      "AUC-PR is: 0.9215799581873136\n",
      "evaluating scores 1020 1730\n",
      "AUC-PR is: 0.9181703204597977\n",
      "evaluating scores 1040 1730\n",
      "AUC-PR is: 0.9196596205289269\n",
      "evaluating scores 1060 1730\n",
      "AUC-PR is: 0.9226036974078895\n",
      "evaluating scores 1080 1730\n",
      "AUC-PR is: 0.9224659158586573\n",
      "evaluating scores 1100 1730\n",
      "AUC-PR is: 0.9219840842037161\n",
      "evaluating scores 1120 1730\n",
      "AUC-PR is: 0.922452538469749\n",
      "evaluating scores 1140 1730\n",
      "AUC-PR is: 0.9203284950165885\n",
      "evaluating scores 1160 1730\n",
      "AUC-PR is: 0.9219675268247752\n",
      "evaluating scores 1180 1730\n",
      "AUC-PR is: 0.921941223402822\n",
      "evaluating scores 1200 1730\n",
      "AUC-PR is: 0.9224194830272102\n",
      "evaluating scores 1220 1730\n",
      "AUC-PR is: 0.9220738691644934\n",
      "evaluating scores 1240 1730\n",
      "AUC-PR is: 0.9222556813935913\n",
      "evaluating scores 1260 1730\n",
      "AUC-PR is: 0.9246647751853079\n",
      "evaluating scores 1280 1730\n",
      "AUC-PR is: 0.9252958553207961\n",
      "evaluating scores 1300 1730\n",
      "AUC-PR is: 0.9261891840829581\n",
      "evaluating scores 1320 1730\n",
      "AUC-PR is: 0.9263460196088487\n",
      "evaluating scores 1340 1730\n",
      "AUC-PR is: 0.9280180387183286\n",
      "evaluating scores 1360 1730\n",
      "AUC-PR is: 0.9256057355936235\n",
      "evaluating scores 1380 1730\n",
      "AUC-PR is: 0.925486911097885\n",
      "evaluating scores 1400 1730\n",
      "AUC-PR is: 0.9242270219088019\n",
      "evaluating scores 1420 1730\n",
      "AUC-PR is: 0.9248407506320069\n",
      "evaluating scores 1440 1730\n",
      "AUC-PR is: 0.9260179531038361\n",
      "evaluating scores 1460 1730\n",
      "AUC-PR is: 0.9264538891341002\n",
      "evaluating scores 1480 1730\n",
      "AUC-PR is: 0.9244364487605595\n",
      "evaluating scores 1500 1730\n",
      "AUC-PR is: 0.9254652417400351\n",
      "evaluating scores 1520 1730\n",
      "AUC-PR is: 0.9265834332220931\n",
      "evaluating scores 1540 1730\n",
      "AUC-PR is: 0.9261552806010003\n",
      "evaluating scores 1560 1730\n",
      "AUC-PR is: 0.926668576603845\n",
      "evaluating scores 1580 1730\n",
      "AUC-PR is: 0.9275774120639974\n",
      "evaluating scores 1600 1730\n",
      "AUC-PR is: 0.9275980618915121\n",
      "evaluating scores 1620 1730\n",
      "AUC-PR is: 0.9279931613323446\n",
      "evaluating scores 1640 1730\n",
      "AUC-PR is: 0.9273960518324874\n",
      "evaluating scores 1660 1730\n",
      "AUC-PR is: 0.9275719046370574\n",
      "evaluating scores 1680 1730\n",
      "AUC-PR is: 0.9271554806138513\n",
      "evaluating scores 1700 1730\n",
      "AUC-PR is: 0.9272943425449942\n",
      "evaluating scores 1720 1730\n",
      "AUC-PR is: 0.9279697391811371\n",
      "AUC-PR is: 0.9279628550412539\n"
     ]
    }
   ],
   "source": [
    "###########################################\n",
    "##obtain the AUC-PR for the test triples###\n",
    "from sklearn import datasets\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import average_precision_score, precision_recall_curve\n",
    "from sklearn.metrics import auc, plot_precision_recall_curve\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#we select all the triples in the inductive test set\n",
    "pos_triples = list(data_ind_test)\n",
    "\n",
    "#we build the negative samples by randomly replace head or tail entity in the triple.\n",
    "neg_triples = list()\n",
    "\n",
    "for i in range(len(pos_triples)):\n",
    "    \n",
    "    s_pos, r_pos, t_pos = pos_triples[i][0], pos_triples[i][1], pos_triples[i][2]\n",
    "    \n",
    "    #decide to replace the head or tail entity\n",
    "    number_0 = random.uniform(0, 1)\n",
    "    \n",
    "    if number_0 < 0.5: #replace head entity\n",
    "        \n",
    "        s_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        #filter out the existing triples\n",
    "        while ((s_neg, r_pos, t_pos) in data_test) or (\n",
    "               (s_neg, r_pos, t_pos) in data_valid) or (\n",
    "               (s_neg, r_pos, t_pos) in data) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind_valid) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind_test):\n",
    "            \n",
    "            s_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        neg_triples.append((s_neg, r_pos, t_pos))\n",
    "    \n",
    "    else: #replace tail entity\n",
    "\n",
    "        t_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        #filter out the existing triples\n",
    "        while ((s_pos, r_pos, t_neg) in data_test) or (\n",
    "               (s_pos, r_pos, t_neg) in data_valid) or (\n",
    "               (s_pos, r_pos, t_neg) in data) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind_valid) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind_test):\n",
    "            \n",
    "            t_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        neg_triples.append((s_pos, r_pos, t_neg))\n",
    "\n",
    "if len(pos_triples) != len(neg_triples):\n",
    "    raise ValueError('error when generating negative triples')\n",
    "        \n",
    "#combine all triples\n",
    "all_triples = pos_triples + neg_triples\n",
    "\n",
    "#obtain the label array\n",
    "arr1 = np.ones((len(pos_triples),))\n",
    "arr2 = np.zeros((len(neg_triples),))\n",
    "y_test = np.concatenate((arr1, arr2))\n",
    "\n",
    "#shuffle positive and negative triples (optional)\n",
    "all_triples, y_test = shuffle(all_triples, y_test)\n",
    "\n",
    "#obtain the score aray\n",
    "y_score = np.zeros((len(y_test),))\n",
    "\n",
    "#implement the scoring\n",
    "for i in range(len(all_triples)):\n",
    "    \n",
    "    s, r, t = all_triples[i][0], all_triples[i][1], all_triples[i][2]\n",
    "    \n",
    "    path_score = path_based_triple_scoring(s, r, t, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "    \n",
    "    subg_score = subgraph_triple_scoring(s, r, t, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "    \n",
    "    ave_score = (path_score + subg_score)/float(2)\n",
    "    \n",
    "    y_score[i] = ave_score\n",
    "    \n",
    "    if i % 20 == 0 and i > 0:\n",
    "        print('evaluating scores', i, len(all_triples))\n",
    "        \n",
    "        # Data to plot precision - recall curve\n",
    "        precision, recall, thresholds = precision_recall_curve(y_test[:i], y_score[:i])\n",
    "        # Use AUC function to calculate the area under the curve of precision recall curve\n",
    "        auc_precision_recall = auc(recall, precision)\n",
    "        print('AUC-PR is:', auc_precision_recall)\n",
    "        \n",
    "        \n",
    "# Data to plot precision - recall curve\n",
    "precision, recall, thresholds = precision_recall_curve(y_test, y_score)\n",
    "# Use AUC function to calculate the area under the curve of precision recall curve\n",
    "auc_precision_recall = auc(recall, precision)\n",
    "print('AUC-PR is:', auc_precision_recall)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "e101f932",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating scores 20 1730\n",
      "auc, auc-pr 1.0 0.9999999999999999\n",
      "evaluating scores 40 1730\n",
      "auc, auc-pr 0.9848484848484849 0.9824236517218974\n",
      "evaluating scores 60 1730\n",
      "auc, auc-pr 0.9764309764309764 0.9738506959365614\n",
      "evaluating scores 80 1730\n",
      "auc, auc-pr 0.9473015873015873 0.9373574624672163\n",
      "evaluating scores 100 1730\n",
      "auc, auc-pr 0.9590097402597403 0.952097879953739\n",
      "evaluating scores 120 1730\n",
      "auc, auc-pr 0.9627972027972028 0.9594634953324895\n",
      "evaluating scores 140 1730\n",
      "auc, auc-pr 0.9631927212572374 0.9578233836649785\n",
      "evaluating scores 160 1730\n",
      "auc, auc-pr 0.9677216186427334 0.9645949744754085\n",
      "evaluating scores 180 1730\n",
      "auc, auc-pr 0.9661919504643963 0.9640123026903334\n",
      "evaluating scores 200 1730\n",
      "auc, auc-pr 0.967793880837359 0.9633435432397089\n",
      "evaluating scores 220 1730\n",
      "auc, auc-pr 0.9631133952254642 0.9499421915734744\n",
      "evaluating scores 240 1730\n",
      "auc, auc-pr 0.9618443080357143 0.9488124229338251\n",
      "evaluating scores 260 1730\n",
      "auc, auc-pr 0.9644212523719164 0.9541709014386287\n",
      "evaluating scores 280 1730\n",
      "auc, auc-pr 0.965550778050778 0.95484770333227\n",
      "evaluating scores 300 1730\n",
      "auc, auc-pr 0.9629629629629629 0.9407242950372635\n",
      "evaluating scores 320 1730\n",
      "auc, auc-pr 0.9648412947831552 0.9436495623491471\n",
      "evaluating scores 340 1730\n",
      "auc, auc-pr 0.9666075958163939 0.9476953035722989\n",
      "evaluating scores 360 1730\n",
      "auc, auc-pr 0.9590952690367895 0.9383546192285687\n",
      "evaluating scores 380 1730\n",
      "auc, auc-pr 0.959049390599406 0.9392157795860885\n",
      "evaluating scores 400 1730\n",
      "auc, auc-pr 0.9598937849144518 0.9407802356892117\n",
      "evaluating scores 420 1730\n",
      "auc, auc-pr 0.9576482877645562 0.9359204293039081\n",
      "evaluating scores 440 1730\n",
      "auc, auc-pr 0.9593470705064548 0.9392929553313291\n",
      "evaluating scores 460 1730\n",
      "auc, auc-pr 0.9606819170876615 0.9418808007302935\n",
      "evaluating scores 480 1730\n",
      "auc, auc-pr 0.9604595383759733 0.9421042069799496\n",
      "evaluating scores 500 1730\n",
      "auc, auc-pr 0.9598084898560472 0.9439669349978692\n",
      "evaluating scores 520 1730\n",
      "auc, auc-pr 0.9550230442063457 0.93431842467301\n",
      "evaluating scores 540 1730\n",
      "auc, auc-pr 0.953182644127526 0.9312856421432795\n",
      "evaluating scores 560 1730\n",
      "auc, auc-pr 0.949375511875512 0.9297566637878241\n",
      "evaluating scores 580 1730\n",
      "auc, auc-pr 0.9477500000000001 0.9298779887342401\n",
      "evaluating scores 600 1730\n",
      "auc, auc-pr 0.9432579960200553 0.9183407885188495\n",
      "evaluating scores 620 1730\n",
      "auc, auc-pr 0.9432384878866436 0.9201947645956319\n",
      "evaluating scores 640 1730\n",
      "auc, auc-pr 0.937179863147605 0.9062736437095462\n",
      "evaluating scores 660 1730\n",
      "auc, auc-pr 0.9381955357060807 0.9080265605775001\n",
      "evaluating scores 680 1730\n",
      "auc, auc-pr 0.9390190070627337 0.9096317685257516\n",
      "evaluating scores 700 1730\n",
      "auc, auc-pr 0.9396200980392156 0.9104659119028908\n",
      "evaluating scores 720 1730\n",
      "auc, auc-pr 0.9382355212355212 0.9090487459836466\n",
      "evaluating scores 740 1730\n",
      "auc, auc-pr 0.9392340929528656 0.9102152450940075\n",
      "evaluating scores 760 1730\n",
      "auc, auc-pr 0.936338943590241 0.9080454137469447\n",
      "evaluating scores 780 1730\n",
      "auc, auc-pr 0.9354856744455261 0.9076991522459499\n",
      "evaluating scores 800 1730\n",
      "auc, auc-pr 0.9361637618464154 0.9108168182961489\n",
      "evaluating scores 820 1730\n",
      "auc, auc-pr 0.936061320193292 0.909645639333423\n",
      "evaluating scores 840 1730\n",
      "auc, auc-pr 0.9364844401340752 0.910335456426397\n",
      "evaluating scores 860 1730\n",
      "auc, auc-pr 0.9377526120149985 0.9125533758604506\n",
      "evaluating scores 880 1730\n",
      "auc, auc-pr 0.9380077519379845 0.9133986742151969\n",
      "evaluating scores 900 1730\n",
      "auc, auc-pr 0.9382891382955599 0.914962093335338\n",
      "evaluating scores 920 1730\n",
      "auc, auc-pr 0.9380462129237288 0.9137455174835678\n",
      "evaluating scores 940 1730\n",
      "auc, auc-pr 0.9386694386694386 0.9147152024028999\n",
      "evaluating scores 960 1730\n",
      "auc, auc-pr 0.9371370493113438 0.913075966130337\n",
      "evaluating scores 980 1730\n",
      "auc, auc-pr 0.937500781657113 0.9137209321637294\n",
      "evaluating scores 1000 1730\n",
      "auc, auc-pr 0.9380194072152568 0.9144189499611326\n",
      "evaluating scores 1020 1730\n",
      "auc, auc-pr 0.9376269699581384 0.9127547849166766\n",
      "evaluating scores 1040 1730\n",
      "auc, auc-pr 0.9385728461618211 0.9131998832686997\n",
      "evaluating scores 1060 1730\n",
      "auc, auc-pr 0.9393845418997001 0.9141288134291111\n",
      "evaluating scores 1080 1730\n",
      "auc, auc-pr 0.9393942513942515 0.9152535101434424\n",
      "evaluating scores 1100 1730\n",
      "auc, auc-pr 0.9395343759923785 0.9159714261797953\n",
      "evaluating scores 1120 1730\n",
      "auc, auc-pr 0.9384957107843137 0.9154154230437547\n",
      "evaluating scores 1140 1730\n",
      "auc, auc-pr 0.9383906686866447 0.9163137051718331\n",
      "evaluating scores 1160 1730\n",
      "auc, auc-pr 0.9392808613251109 0.918387329201604\n",
      "evaluating scores 1180 1730\n",
      "auc, auc-pr 0.9402826794192369 0.9188907566023802\n",
      "evaluating scores 1200 1730\n",
      "auc, auc-pr 0.9410905807168658 0.9200274252138896\n",
      "evaluating scores 1220 1730\n",
      "auc, auc-pr 0.9419397585179929 0.9212243425033636\n",
      "evaluating scores 1240 1730\n",
      "auc, auc-pr 0.9430334959349593 0.9240043370898381\n",
      "evaluating scores 1260 1730\n",
      "auc, auc-pr 0.9429669626389574 0.9237578468809977\n",
      "evaluating scores 1280 1730\n",
      "auc, auc-pr 0.9434499394507597 0.9247081719220218\n",
      "evaluating scores 1300 1730\n",
      "auc, auc-pr 0.9430945398687335 0.9251286741406699\n",
      "evaluating scores 1320 1730\n",
      "auc, auc-pr 0.9431457130001193 0.9253941922148274\n",
      "evaluating scores 1340 1730\n",
      "auc, auc-pr 0.9440092591973729 0.9254834936825854\n",
      "evaluating scores 1360 1730\n",
      "auc, auc-pr 0.9442166233013447 0.9257193153900898\n",
      "evaluating scores 1380 1730\n",
      "auc, auc-pr 0.9440704064398491 0.9253144735403187\n",
      "evaluating scores 1400 1730\n",
      "auc, auc-pr 0.9444224453430057 0.9257490283891863\n",
      "evaluating scores 1420 1730\n",
      "auc, auc-pr 0.9450611148475054 0.9270278048872\n",
      "evaluating scores 1440 1730\n",
      "auc, auc-pr 0.945528373713772 0.926896783364848\n",
      "evaluating scores 1460 1730\n",
      "auc, auc-pr 0.944650900900901 0.926642897741131\n",
      "evaluating scores 1480 1730\n",
      "auc, auc-pr 0.9451799846215382 0.9273654779211377\n",
      "evaluating scores 1500 1730\n",
      "auc, auc-pr 0.9453876244665718 0.9276919131789634\n",
      "evaluating scores 1520 1730\n",
      "auc, auc-pr 0.9446210889266422 0.9270322722241182\n",
      "evaluating scores 1540 1730\n",
      "auc, auc-pr 0.9436826814058957 0.9253887089636341\n",
      "evaluating scores 1560 1730\n",
      "auc, auc-pr 0.9418905145487424 0.9247248215461072\n",
      "evaluating scores 1580 1730\n",
      "auc, auc-pr 0.9420232371794873 0.9246199074508421\n",
      "evaluating scores 1600 1730\n",
      "auc, auc-pr 0.9423028539549536 0.9253539623068893\n",
      "evaluating scores 1620 1730\n",
      "auc, auc-pr 0.9428408323539409 0.9259736746657936\n",
      "evaluating scores 1640 1730\n",
      "auc, auc-pr 0.9435200059497248 0.9268365667570958\n",
      "evaluating scores 1660 1730\n",
      "auc, auc-pr 0.9426996225319397 0.9258770136809493\n",
      "evaluating scores 1680 1730\n",
      "auc, auc-pr 0.9427321922623367 0.926053932127522\n",
      "evaluating scores 1700 1730\n",
      "auc, auc-pr 0.9429175709793153 0.926755922733019\n",
      "evaluating scores 1720 1730\n",
      "auc, auc-pr 0.9435317692107996 0.9277768880302245\n",
      "evaluating scores 1729 1730\n",
      "(final) auc, auc-pr 0.9434688763406729 0.9281440878586201\n"
     ]
    }
   ],
   "source": [
    "##########################################################\n",
    "##obtain the AUC-PR for the test triples, using sklearn###\n",
    "from sklearn import datasets, metrics\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import average_precision_score, precision_recall_curve\n",
    "from sklearn.metrics import auc, plot_precision_recall_curve\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#we select all the triples in the inductive test set\n",
    "pos_triples = list(data_ind_test)\n",
    "\n",
    "#we build the negative samples by randomly replace head or tail entity in the triple.\n",
    "neg_triples = list()\n",
    "\n",
    "for i in range(len(pos_triples)):\n",
    "    \n",
    "    s_pos, r_pos, t_pos = pos_triples[i][0], pos_triples[i][1], pos_triples[i][2]\n",
    "    \n",
    "    #decide to replace the head or tail entity\n",
    "    number_0 = random.uniform(0, 1)\n",
    "    \n",
    "    if number_0 < 0.5: #replace head entity\n",
    "        \n",
    "        s_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        #filter out the existing triples\n",
    "        while ((s_neg, r_pos, t_pos) in data_test) or (\n",
    "               (s_neg, r_pos, t_pos) in data_valid) or (\n",
    "               (s_neg, r_pos, t_pos) in data) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind_valid) or (\n",
    "               (s_neg, r_pos, t_pos) in data_ind_test):\n",
    "            \n",
    "            s_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        neg_triples.append((s_neg, r_pos, t_pos))\n",
    "    \n",
    "    else: #replace tail entity\n",
    "\n",
    "        t_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        #filter out the existing triples\n",
    "        while ((s_pos, r_pos, t_neg) in data_test) or (\n",
    "               (s_pos, r_pos, t_neg) in data_valid) or (\n",
    "               (s_pos, r_pos, t_neg) in data) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind_valid) or (\n",
    "               (s_pos, r_pos, t_neg) in data_ind_test):\n",
    "            \n",
    "            t_neg = random.choice(list(new_ent_set))\n",
    "        \n",
    "        neg_triples.append((s_pos, r_pos, t_neg))\n",
    "\n",
    "if len(pos_triples) != len(neg_triples):\n",
    "    raise ValueError('error when generating negative triples')\n",
    "        \n",
    "#combine all triples\n",
    "all_triples = pos_triples + neg_triples\n",
    "\n",
    "#obtain the label array\n",
    "arr1 = np.ones((len(pos_triples),))\n",
    "arr2 = np.zeros((len(neg_triples),))\n",
    "y_test = np.concatenate((arr1, arr2))\n",
    "\n",
    "#shuffle positive and negative triples (optional)\n",
    "all_triples, y_test = shuffle(all_triples, y_test)\n",
    "\n",
    "#obtain the score aray\n",
    "y_score = np.zeros((len(y_test),))\n",
    "\n",
    "#implement the scoring\n",
    "for i in range(len(all_triples)):\n",
    "    \n",
    "    s, r, t = all_triples[i][0], all_triples[i][1], all_triples[i][2]\n",
    "    \n",
    "    path_score = path_based_triple_scoring(s, r, t, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "    \n",
    "    subg_score = subgraph_triple_scoring(s, r, t, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "    \n",
    "    ave_score = (path_score + subg_score)/float(2)\n",
    "    \n",
    "    y_score[i] = ave_score\n",
    "    \n",
    "    if i % 20 == 0 and i > 0:\n",
    "        print('evaluating scores', i, len(all_triples))\n",
    "        auc = metrics.roc_auc_score(y_test[:i], y_score[:i])\n",
    "        auc_pr = metrics.average_precision_score(y_test[:i], y_score[:i])\n",
    "        print('auc, auc-pr', auc, auc_pr)\n",
    "        \n",
    "print('evaluating scores', i, len(all_triples))\n",
    "auc = metrics.roc_auc_score(y_test, y_score)\n",
    "auc_pr = metrics.average_precision_score(y_test, y_score)\n",
    "print('(final) auc, auc-pr', auc, auc_pr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "6403a2e3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4351, 50, 3728) (4351, 50, 3728) real score 0.910797154903412 Hits@1 0.0 Hits@3 1.0 Hits@10 1.0 MRR 0.5 rank 1 total_num 0 865\n",
      "checkcorrect (4750, 92, 4069) (4750, 92, 4069) real score 0.857284015417099 Hits@1 0.5 Hits@3 1.0 Hits@10 1.0 MRR 0.75 rank 0 total_num 1 865\n",
      "checkcorrect (5568, 310, 4853) (5568, 310, 4853) real score 0.8543478101491928 Hits@1 0.3333333333333333 Hits@3 0.6666666666666666 Hits@10 1.0 MRR 0.5476190476190476 rank 6 total_num 2 865\n",
      "checkcorrect (3878, 56, 3888) (3878, 56, 3888) real score 0.9339187711477279 Hits@1 0.5 Hits@3 0.75 Hits@10 1.0 MRR 0.6607142857142857 rank 0 total_num 3 865\n",
      "checkcorrect (5284, 276, 4427) (5284, 276, 4427) real score 0.7774219021201134 Hits@1 0.4 Hits@3 0.8 Hits@10 1.0 MRR 0.6285714285714286 rank 1 total_num 4 865\n",
      "checkcorrect (4226, 56, 3826) (4226, 56, 3826) real score 0.9050567984580993 Hits@1 0.3333333333333333 Hits@3 0.8333333333333334 Hits@10 1.0 MRR 0.5793650793650794 rank 2 total_num 5 865\n",
      "checkcorrect (5035, 302, 4583) (5035, 302, 4583) real score 0.9048977255821229 Hits@1 0.2857142857142857 Hits@3 0.8571428571428571 Hits@10 1.0 MRR 0.5680272108843537 rank 1 total_num 6 865\n",
      "checkcorrect (5132, 276, 4427) (5132, 276, 4427) real score 0.9572099447250366 Hits@1 0.375 Hits@3 0.875 Hits@10 1.0 MRR 0.6220238095238095 rank 0 total_num 7 865\n",
      "checkcorrect (5864, 92, 4069) (5864, 92, 4069) real score 0.9587215811014176 Hits@1 0.3333333333333333 Hits@3 0.8888888888888888 Hits@10 1.0 MRR 0.6084656084656085 rank 1 total_num 8 865\n",
      "checkcorrect (3927, 54, 3669) (3927, 54, 3669) real score 0.9441245526075364 Hits@1 0.3 Hits@3 0.9 Hits@10 1.0 MRR 0.5809523809523809 rank 2 total_num 9 865\n",
      "checkcorrect (5221, 4, 3864) (5221, 4, 3864) real score 0.8780436813831329 Hits@1 0.2727272727272727 Hits@3 0.8181818181818182 Hits@10 1.0 MRR 0.5432900432900433 rank 5 total_num 10 865\n",
      "checkcorrect (6075, 326, 3933) (6075, 326, 3933) real score 0.6907524198293686 Hits@1 0.25 Hits@3 0.75 Hits@10 1.0 MRR 0.5188492063492064 rank 3 total_num 11 865\n",
      "checkcorrect (4004, 16, 5013) (4004, 16, 5013) real score 0.9518976241350174 Hits@1 0.23076923076923078 Hits@3 0.7692307692307693 Hits@10 1.0 MRR 0.5045787545787546 rank 2 total_num 12 865\n",
      "checkcorrect (4472, 56, 3793) (4472, 56, 3793) real score 0.9564106822013856 Hits@1 0.2857142857142857 Hits@3 0.7857142857142857 Hits@10 1.0 MRR 0.5399659863945578 rank 0 total_num 13 865\n",
      "checkcorrect (5031, 92, 4069) (5031, 92, 4069) real score 0.9438176155090332 Hits@1 0.3333333333333333 Hits@3 0.8 Hits@10 1.0 MRR 0.5706349206349207 rank 0 total_num 14 865\n",
      "checkcorrect (5141, 10, 4351) (5141, 10, 4351) real score 0.9197712570428849 Hits@1 0.3125 Hits@3 0.8125 Hits@10 1.0 MRR 0.5662202380952381 rank 1 total_num 15 865\n",
      "checkcorrect (3857, 16, 4549) (3857, 16, 4549) real score 0.9464289397001266 Hits@1 0.29411764705882354 Hits@3 0.7647058823529411 Hits@10 1.0 MRR 0.5446778711484593 rank 4 total_num 16 865\n",
      "checkcorrect (4681, 10, 4485) (4681, 10, 4485) real score 0.6349460064200685 Hits@1 0.2777777777777778 Hits@3 0.7222222222222222 Hits@10 0.9444444444444444 MRR 0.5186914936914937 rank 12 total_num 17 865\n",
      "checkcorrect (5023, 378, 4776) (5023, 378, 4776) real score 0.7881732016801835 Hits@1 0.3157894736842105 Hits@3 0.7368421052631579 Hits@10 0.9473684210526315 MRR 0.5440235203393098 rank 0 total_num 18 865\n",
      "checkcorrect (5158, 88, 3753) (5158, 88, 3753) real score 0.9929775893688202 Hits@1 0.35 Hits@3 0.75 Hits@10 0.95 MRR 0.5668223443223444 rank 0 total_num 19 865\n",
      "checkcorrect (4516, 16, 4430) (4516, 16, 4430) real score 0.9391711413860322 Hits@1 0.3333333333333333 Hits@3 0.7142857142857143 Hits@10 0.9523809523809523 MRR 0.5517355660212803 rank 3 total_num 20 865\n",
      "checkcorrect (4847, 20, 4305) (4847, 20, 4305) real score 0.9790717363357544 Hits@1 0.36363636363636365 Hits@3 0.7272727272727273 Hits@10 0.9545454545454546 MRR 0.5721112221112221 rank 0 total_num 21 865\n",
      "checkcorrect (3826, 120, 4425) (3826, 120, 4425) real score 0.45838833749294283 Hits@1 0.34782608695652173 Hits@3 0.6956521739130435 Hits@10 0.9565217391304348 MRR 0.5544831979614588 rank 5 total_num 22 865\n",
      "checkcorrect (4266, 4, 3864) (4266, 4, 3864) real score 0.9257099241018295 Hits@1 0.3333333333333333 Hits@3 0.6666666666666666 Hits@10 0.9583333333333334 MRR 0.5397130647130647 rank 4 total_num 23 865\n",
      "checkcorrect (3694, 44, 4990) (3694, 44, 4990) real score 0.921181783080101 Hits@1 0.32 Hits@3 0.68 Hits@10 0.96 MRR 0.5314578754578754 rank 2 total_num 24 865\n",
      "checkcorrect (5765, 26, 3723) (5765, 26, 3723) real score 0.9755696862936021 Hits@1 0.3076923076923077 Hits@3 0.6538461538461539 Hits@10 0.9615384615384616 MRR 0.5187094956325725 rank 4 total_num 25 865\n",
      "checkcorrect (4364, 2, 5165) (4364, 2, 5165) real score 0.4292144461069256 Hits@1 0.2962962962962963 Hits@3 0.6296296296296297 Hits@10 0.9629629629629629 MRR 0.5041276624609957 rank 7 total_num 26 865\n",
      "checkcorrect (4073, 118, 5130) (4073, 118, 5130) real score 0.938537310063839 Hits@1 0.32142857142857145 Hits@3 0.6428571428571429 Hits@10 0.9642857142857143 MRR 0.5218373888016744 rank 0 total_num 27 865\n",
      "checkcorrect (4615, 46, 4856) (4615, 46, 4856) real score 0.8977647632360458 Hits@1 0.3103448275862069 Hits@3 0.6206896551724138 Hits@10 0.9655172413793104 MRR 0.5095901225211569 rank 5 total_num 28 865\n",
      "checkcorrect (3929, 178, 4273) (3929, 178, 4273) real score 0.9651019096374511 Hits@1 0.3333333333333333 Hits@3 0.6333333333333333 Hits@10 0.9666666666666667 MRR 0.5259371184371183 rank 0 total_num 29 865\n",
      "checkcorrect (4039, 24, 4038) (4039, 24, 4038) real score 0.9517246931791306 Hits@1 0.3548387096774194 Hits@3 0.6451612903225806 Hits@10 0.967741935483871 MRR 0.5412294694552757 rank 0 total_num 30 865\n",
      "checkcorrect (3888, 348, 3811) (3888, 348, 3811) real score 0.8973125278949737 Hits@1 0.34375 Hits@3 0.65625 Hits@10 0.96875 MRR 0.5399410485347984 rank 1 total_num 31 865\n",
      "checkcorrect (5921, 108, 3802) (5921, 108, 3802) real score 0.8826056599617005 Hits@1 0.3333333333333333 Hits@3 0.6363636363636364 Hits@10 0.9696969696969697 MRR 0.5279082029082027 rank 6 total_num 32 865\n",
      "checkcorrect (5889, 344, 3916) (5889, 344, 3916) real score 0.9396137416362762 Hits@1 0.35294117647058826 Hits@3 0.6470588235294118 Hits@10 0.9705882352941176 MRR 0.5417932557638439 rank 0 total_num 33 865\n",
      "checkcorrect (5218, 24, 3710) (5218, 24, 3710) real score 0.9575499266386032 Hits@1 0.37142857142857144 Hits@3 0.6571428571428571 Hits@10 0.9714285714285714 MRR 0.554884877027734 rank 0 total_num 34 865\n",
      "checkcorrect (3962, 50, 3987) (3962, 50, 3987) real score 0.953570944070816 Hits@1 0.3888888888888889 Hits@3 0.6666666666666666 Hits@10 0.9722222222222222 MRR 0.5672491859991858 rank 0 total_num 35 865\n",
      "checkcorrect (3884, 56, 4455) (3884, 56, 4455) real score 0.9747188895940782 Hits@1 0.3783783783783784 Hits@3 0.6756756756756757 Hits@10 0.972972972972973 MRR 0.5654316404316403 rank 1 total_num 36 865\n",
      "checkcorrect (3813, 86, 4428) (3813, 86, 4428) real score 0.8840059459209442 Hits@1 0.39473684210526316 Hits@3 0.6842105263157895 Hits@10 0.9736842105263158 MRR 0.5768676498939656 rank 0 total_num 37 865\n",
      "checkcorrect (5064, 332, 4578) (5064, 332, 4578) real score 0.19557313843397425 Hits@1 0.38461538461538464 Hits@3 0.6666666666666666 Hits@10 0.9487179487179487 MRR 0.5630258393078905 rank 26 total_num 38 865\n",
      "checkcorrect (3833, 50, 3841) (3833, 50, 3841) real score 0.8960744947195053 Hits@1 0.375 Hits@3 0.675 Hits@10 0.95 MRR 0.5614501933251932 rank 1 total_num 39 865\n",
      "checkcorrect (5032, 366, 4132) (5032, 366, 4132) real score 0.8583925724029541 Hits@1 0.36585365853658536 Hits@3 0.6829268292682927 Hits@10 0.9512195121951219 MRR 0.5599514081221397 rank 1 total_num 40 865\n",
      "checkcorrect (3844, 346, 4109) (3844, 346, 4109) real score 0.9399508446455003 Hits@1 0.35714285714285715 Hits@3 0.6904761904761905 Hits@10 0.9523809523809523 MRR 0.5585239936430412 rank 1 total_num 41 865\n",
      "checkcorrect (3777, 144, 5599) (3777, 144, 5599) real score 0.9416356056928634 Hits@1 0.37209302325581395 Hits@3 0.6976744186046512 Hits@10 0.9534883720930233 MRR 0.5687908775118077 rank 0 total_num 42 865\n",
      "checkcorrect (5414, 100, 6028) (5414, 100, 6028) real score 0.41193012297153475 Hits@1 0.36363636363636365 Hits@3 0.6818181818181818 Hits@10 0.9318181818181818 MRR 0.5577577515077514 rank 11 total_num 43 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4740, 4, 3864) (4740, 4, 3864) real score 0.8960600674152375 Hits@1 0.35555555555555557 Hits@3 0.6666666666666666 Hits@10 0.9333333333333333 MRR 0.5478322706100482 rank 8 total_num 44 865\n",
      "checkcorrect (4117, 176, 3801) (4117, 176, 3801) real score 0.9828361719846725 Hits@1 0.3695652173913043 Hits@3 0.6739130434782609 Hits@10 0.9347826086956522 MRR 0.557662003857656 rank 0 total_num 45 865\n",
      "checkcorrect (4197, 86, 4168) (4197, 86, 4168) real score 0.8461340725421906 Hits@1 0.3617021276595745 Hits@3 0.6808510638297872 Hits@10 0.9361702127659575 MRR 0.5528890534209682 rank 2 total_num 46 865\n",
      "checkcorrect (5178, 46, 4808) (5178, 46, 4808) real score 0.9382827788591385 Hits@1 0.3541666666666667 Hits@3 0.6875 Hits@10 0.9375 MRR 0.5517871981413647 rank 1 total_num 47 865\n",
      "checkcorrect (4550, 34, 3879) (4550, 34, 3879) real score 0.9168120950460434 Hits@1 0.3469387755102041 Hits@3 0.6938775510204082 Hits@10 0.9387755102040817 MRR 0.5473289560024253 rank 2 total_num 48 865\n",
      "checkcorrect (4247, 16, 3685) (4247, 16, 3685) real score 0.9810229182243347 Hits@1 0.36 Hits@3 0.7 Hits@10 0.94 MRR 0.5563823768823767 rank 0 total_num 49 865\n",
      "checkcorrect (6098, 40, 4420) (6098, 40, 4420) real score 0.0 Hits@1 0.35294117647058826 Hits@3 0.6862745098039216 Hits@10 0.9215686274509803 MRR 0.5458814152441601 rank 47 total_num 50 865\n",
      "checkcorrect (4031, 56, 4056) (4031, 56, 4056) real score 0.9034317672252655 Hits@1 0.36538461538461536 Hits@3 0.6923076923076923 Hits@10 0.9230769230769231 MRR 0.5546144649510032 rank 0 total_num 51 865\n",
      "checkcorrect (4174, 100, 3895) (4174, 100, 3895) real score 0.895738559961319 Hits@1 0.3584905660377358 Hits@3 0.6792452830188679 Hits@10 0.9245283018867925 MRR 0.5488670222160786 rank 3 total_num 52 865\n",
      "checkcorrect (4951, 56, 3746) (4951, 56, 3746) real score 0.6225573424249887 Hits@1 0.37037037037037035 Hits@3 0.6851851851851852 Hits@10 0.9259259259259259 MRR 0.5572213366194846 rank 0 total_num 53 865\n",
      "checkcorrect (5471, 54, 3669) (5471, 54, 3669) real score 0.9657231211662293 Hits@1 0.38181818181818183 Hits@3 0.6909090909090909 Hits@10 0.9272727272727272 MRR 0.5652718577718576 rank 0 total_num 54 865\n",
      "checkcorrect (4379, 2, 5106) (4379, 2, 5106) real score 0.9269362211227417 Hits@1 0.375 Hits@3 0.6785714285714286 Hits@10 0.9285714285714286 MRR 0.5587491460259316 rank 4 total_num 55 865\n",
      "checkcorrect (4815, 264, 4403) (4815, 264, 4403) real score 0.7955091953277588 Hits@1 0.3684210526315789 Hits@3 0.6842105263157895 Hits@10 0.9298245614035088 MRR 0.5577184592535468 rank 1 total_num 56 865\n",
      "checkcorrect (3674, 128, 4086) (3674, 128, 4086) real score 0.9009848415851593 Hits@1 0.3620689655172414 Hits@3 0.6896551724137931 Hits@10 0.9310344827586207 MRR 0.5567233134043477 rank 1 total_num 57 865\n",
      "checkcorrect (3745, 172, 3910) (3745, 172, 3910) real score 0.7505346715450287 Hits@1 0.3559322033898305 Hits@3 0.6779661016949152 Hits@10 0.9322033898305084 MRR 0.5501121837986243 rank 5 total_num 58 865\n",
      "checkcorrect (6112, 54, 3712) (6112, 54, 3712) real score 0.9831448435783386 Hits@1 0.36666666666666664 Hits@3 0.6833333333333333 Hits@10 0.9333333333333333 MRR 0.5576103140686471 rank 0 total_num 59 865\n",
      "checkcorrect (4195, 50, 4194) (4195, 50, 4194) real score 0.9555008620023727 Hits@1 0.3770491803278688 Hits@3 0.6885245901639344 Hits@10 0.9344262295081968 MRR 0.564862604001948 rank 0 total_num 60 865\n",
      "checkcorrect (4390, 56, 3826) (4390, 56, 3826) real score 0.9810170382261276 Hits@1 0.3709677419354839 Hits@3 0.6935483870967742 Hits@10 0.9354838709677419 MRR 0.5638164329696586 rank 1 total_num 61 865\n",
      "checkcorrect (3860, 50, 3948) (3860, 50, 3948) real score 0.9655397444963455 Hits@1 0.38095238095238093 Hits@3 0.6984126984126984 Hits@10 0.9365079365079365 MRR 0.5707399816526798 rank 0 total_num 62 865\n",
      "checkcorrect (4129, 20, 3931) (4129, 20, 3931) real score 0.9613885432481766 Hits@1 0.390625 Hits@3 0.703125 Hits@10 0.9375 MRR 0.5774471694393567 rank 0 total_num 63 865\n",
      "checkcorrect (4726, 238, 3835) (4726, 238, 3835) real score 0.24765969440340996 Hits@1 0.38461538461538464 Hits@3 0.6923076923076923 Hits@10 0.9384615384615385 MRR 0.5707611690303996 rank 6 total_num 64 865\n",
      "checkcorrect (4805, 20, 4134) (4805, 20, 4134) real score 0.9615551084280014 Hits@1 0.3787878787878788 Hits@3 0.696969696969697 Hits@10 0.9393939393939394 MRR 0.5671637775804441 rank 2 total_num 65 865\n",
      "checkcorrect (4963, 54, 3669) (4963, 54, 3669) real score 0.9389256179332732 Hits@1 0.3880597014925373 Hits@3 0.7014925373134329 Hits@10 0.9402985074626866 MRR 0.5736240197061091 rank 0 total_num 66 865\n",
      "checkcorrect (3841, 20, 4054) (3841, 20, 4054) real score 0.9659724563360215 Hits@1 0.38235294117647056 Hits@3 0.7058823529411765 Hits@10 0.9411764705882353 MRR 0.5725413135339604 rank 1 total_num 67 865\n",
      "checkcorrect (5356, 44, 3781) (5356, 44, 3781) real score 0.8984776586294174 Hits@1 0.37681159420289856 Hits@3 0.7101449275362319 Hits@10 0.9420289855072463 MRR 0.5690745312122123 rank 2 total_num 68 865\n",
      "checkcorrect (4679, 62, 4817) (4679, 62, 4817) real score 0.8890111804008484 Hits@1 0.37142857142857144 Hits@3 0.7 Hits@10 0.9428571428571428 MRR 0.5623734664806093 rank 9 total_num 69 865\n",
      "checkcorrect (3714, 120, 5991) (3714, 120, 5991) real score 0.8422261238098144 Hits@1 0.36619718309859156 Hits@3 0.704225352112676 Hits@10 0.9436619718309859 MRR 0.5591475491123378 rank 2 total_num 70 865\n",
      "checkcorrect (4073, 218, 4574) (4073, 218, 4574) real score 0.46621591318398714 Hits@1 0.3611111111111111 Hits@3 0.6944444444444444 Hits@10 0.9305555555555556 MRR 0.552307536856148 rank 14 total_num 71 865\n",
      "checkcorrect (4395, 172, 5382) (4395, 172, 5382) real score 0.9428127914667129 Hits@1 0.3698630136986301 Hits@3 0.6986301369863014 Hits@10 0.9315068493150684 MRR 0.558440310323872 rank 0 total_num 72 865\n",
      "checkcorrect (3744, 344, 4974) (3744, 344, 4974) real score 0.9301498115062714 Hits@1 0.3783783783783784 Hits@3 0.7027027027027027 Hits@10 0.9324324324324325 MRR 0.5644073331573332 rank 0 total_num 73 865\n",
      "checkcorrect (4292, 20, 3896) (4292, 20, 3896) real score 0.9646217137575149 Hits@1 0.37333333333333335 Hits@3 0.7066666666666667 Hits@10 0.9333333333333333 MRR 0.5613263464930132 rank 2 total_num 74 865\n",
      "checkcorrect (5262, 380, 4571) (5262, 380, 4571) real score 0.5621333718299866 Hits@1 0.3815789473684211 Hits@3 0.7105263157894737 Hits@10 0.9342105263157895 MRR 0.5670983682496841 rank 0 total_num 75 865\n",
      "checkcorrect (5705, 72, 6075) (5705, 72, 6075) real score 0.4126784473657608 Hits@1 0.37662337662337664 Hits@3 0.7012987012987013 Hits@10 0.935064935064935 MRR 0.5611764558193131 rank 8 total_num 76 865\n",
      "checkcorrect (4106, 172, 5243) (4106, 172, 5243) real score 0.90636126101017 Hits@1 0.3717948717948718 Hits@3 0.7051282051282052 Hits@10 0.9358974358974359 MRR 0.5582553901464159 rank 2 total_num 77 865\n",
      "checkcorrect (4952, 20, 5775) (4952, 20, 5775) real score 0.9533321052789688 Hits@1 0.3670886075949367 Hits@3 0.7088607594936709 Hits@10 0.9367088607594937 MRR 0.5554082755032124 rank 2 total_num 78 865\n",
      "checkcorrect (4758, 284, 5140) (4758, 284, 5140) real score 0.3665523618459702 Hits@1 0.3625 Hits@3 0.7 Hits@10 0.925 MRR 0.5495073387260889 rank 11 total_num 79 865\n",
      "checkcorrect (4098, 24, 3948) (4098, 24, 3948) real score 0.9625038057565689 Hits@1 0.37037037037037035 Hits@3 0.7037037037037037 Hits@10 0.9259259259259259 MRR 0.555068976519594 rank 0 total_num 80 865\n",
      "checkcorrect (4932, 50, 4559) (4932, 50, 4559) real score 0.8890321090817451 Hits@1 0.3780487804878049 Hits@3 0.7073170731707317 Hits@10 0.926829268292683 MRR 0.5604949646108184 rank 0 total_num 81 865\n",
      "checkcorrect (5391, 96, 4358) (5391, 96, 4358) real score 0.8948037207126618 Hits@1 0.37349397590361444 Hits@3 0.6987951807228916 Hits@10 0.927710843373494 MRR 0.5550807013156412 rank 8 total_num 82 865\n",
      "checkcorrect (5874, 54, 3712) (5874, 54, 3712) real score 0.9784358590841293 Hits@1 0.36904761904761907 Hits@3 0.7023809523809523 Hits@10 0.9285714285714286 MRR 0.5544249786809312 rank 1 total_num 83 865\n",
      "checkcorrect (4873, 114, 5019) (4873, 114, 5019) real score 0.9802670657634736 Hits@1 0.3764705882352941 Hits@3 0.7058823529411765 Hits@10 0.9294117647058824 MRR 0.5596670377552733 rank 0 total_num 84 865\n",
      "checkcorrect (3979, 316, 4069) (3979, 316, 4069) real score 0.9550408571958542 Hits@1 0.38372093023255816 Hits@3 0.7093023255813954 Hits@10 0.9302325581395349 MRR 0.5647871884790491 rank 0 total_num 85 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3972, 366, 4132) (3972, 366, 4132) real score 0.8730267018079758 Hits@1 0.39080459770114945 Hits@3 0.7126436781609196 Hits@10 0.9310344827586207 MRR 0.5697896345884853 rank 0 total_num 86 865\n",
      "checkcorrect (4645, 50, 4588) (4645, 50, 4588) real score 0.9505154550075531 Hits@1 0.3977272727272727 Hits@3 0.7159090909090909 Hits@10 0.9318181818181818 MRR 0.574678388740889 rank 0 total_num 87 865\n",
      "checkcorrect (4647, 44, 4785) (4647, 44, 4785) real score 0.9211531758308411 Hits@1 0.39325842696629215 Hits@3 0.7191011235955056 Hits@10 0.9325842696629213 MRR 0.5738393057213284 rank 1 total_num 88 865\n",
      "checkcorrect (5592, 2, 3685) (5592, 2, 3685) real score 0.8802283108234406 Hits@1 0.3888888888888889 Hits@3 0.7111111111111111 Hits@10 0.9333333333333333 MRR 0.5693151652873877 rank 5 total_num 89 865\n",
      "checkcorrect (4058, 50, 4662) (4058, 50, 4662) real score 0.8087208911776542 Hits@1 0.38461538461538464 Hits@3 0.7032967032967034 Hits@10 0.9340659340659341 MRR 0.5642799559008352 rank 8 total_num 90 865\n",
      "checkcorrect (4074, 118, 4073) (4074, 118, 4073) real score 0.9772375166416168 Hits@1 0.3804347826086957 Hits@3 0.7065217391304348 Hits@10 0.9347826086956522 MRR 0.5635812607280001 rank 1 total_num 91 865\n",
      "checkcorrect (3914, 50, 3673) (3914, 50, 3673) real score 0.8988800555467606 Hits@1 0.3763440860215054 Hits@3 0.6989247311827957 Hits@10 0.9354838709677419 MRR 0.5596717848061936 rank 4 total_num 92 865\n",
      "checkcorrect (5282, 2, 5052) (5282, 2, 5052) real score 0.9427363276481628 Hits@1 0.3723404255319149 Hits@3 0.7021276595744681 Hits@10 0.9361702127659575 MRR 0.5572639289394611 rank 2 total_num 93 865\n",
      "checkcorrect (5630, 198, 5629) (5630, 198, 5629) real score 0.49596589207649233 Hits@1 0.3684210526315789 Hits@3 0.7052631578947368 Hits@10 0.9368421052631579 MRR 0.5566611507400984 rank 1 total_num 94 865\n",
      "checkcorrect (4697, 54, 3669) (4697, 54, 3669) real score 0.9342636078596115 Hits@1 0.3645833333333333 Hits@3 0.7083333333333334 Hits@10 0.9375 MRR 0.556070930419889 rank 1 total_num 95 865\n",
      "checkcorrect (5440, 4, 3864) (5440, 4, 3864) real score 0.9459556013345718 Hits@1 0.36082474226804123 Hits@3 0.711340206185567 Hits@10 0.9381443298969072 MRR 0.5537746665323987 rank 2 total_num 96 865\n",
      "checkcorrect (5443, 54, 3983) (5443, 54, 3983) real score 0.9346798062324524 Hits@1 0.35714285714285715 Hits@3 0.7040816326530612 Hits@10 0.9387755102040817 MRR 0.5501647209555376 rank 4 total_num 97 865\n",
      "checkcorrect (4010, 24, 4204) (4010, 24, 4204) real score 0.9211383000016212 Hits@1 0.35353535353535354 Hits@3 0.7070707070707071 Hits@10 0.9393939393939394 MRR 0.5479745049189496 rank 2 total_num 98 865\n",
      "checkcorrect (5087, 50, 3850) (5087, 50, 3850) real score 0.9205057501792908 Hits@1 0.35 Hits@3 0.7 Hits@10 0.94 MRR 0.5449947598697602 rank 3 total_num 99 865\n",
      "checkcorrect (4185, 4, 3864) (4185, 4, 3864) real score 0.9455821365118027 Hits@1 0.3465346534653465 Hits@3 0.7029702970297029 Hits@10 0.9405940594059405 MRR 0.5445492671977823 rank 1 total_num 100 865\n",
      "checkcorrect (4440, 206, 5347) (4440, 206, 5347) real score 0.16039694622159004 Hits@1 0.3431372549019608 Hits@3 0.696078431372549 Hits@10 0.9313725490196079 MRR 0.5399646967048931 rank 12 total_num 101 865\n",
      "checkcorrect (5030, 192, 4949) (5030, 192, 4949) real score 0.3565698266029358 Hits@1 0.33980582524271846 Hits@3 0.6893203883495146 Hits@10 0.9320388349514563 MRR 0.5359359132417388 rank 7 total_num 102 865\n",
      "checkcorrect (4443, 60, 3821) (4443, 60, 3821) real score 0.9132215768098831 Hits@1 0.33653846153846156 Hits@3 0.6826923076923077 Hits@10 0.9326923076923077 MRR 0.5323852474092862 rank 5 total_num 103 865\n",
      "checkcorrect (5725, 56, 3888) (5725, 56, 3888) real score 0.9218778103590012 Hits@1 0.3333333333333333 Hits@3 0.6761904761904762 Hits@10 0.9333333333333333 MRR 0.5292196736244359 rank 4 total_num 104 865\n",
      "checkcorrect (3744, 172, 5105) (3744, 172, 5105) real score 0.8384896665811539 Hits@1 0.330188679245283 Hits@3 0.6792452830188679 Hits@10 0.9339622641509434 MRR 0.527371689282067 rank 2 total_num 105 865\n",
      "checkcorrect (4947, 132, 4125) (4947, 132, 4125) real score 0.8638957023620606 Hits@1 0.32710280373831774 Hits@3 0.6728971962616822 Hits@10 0.9345794392523364 MRR 0.5243121407841037 rank 4 total_num 106 865\n",
      "checkcorrect (3757, 236, 3746) (3757, 236, 3746) real score 0.7820830658078194 Hits@1 0.3333333333333333 Hits@3 0.6759259259259259 Hits@10 0.9351851851851852 MRR 0.5287166579990658 rank 0 total_num 107 865\n",
      "checkcorrect (4430, 56, 3826) (4430, 56, 3826) real score 0.9913016766309738 Hits@1 0.3394495412844037 Hits@3 0.6788990825688074 Hits@10 0.9357798165137615 MRR 0.5330403583843955 rank 0 total_num 108 865\n",
      "checkcorrect (4754, 168, 4089) (4754, 168, 4089) real score 0.9697188466787339 Hits@1 0.34545454545454546 Hits@3 0.6818181818181818 Hits@10 0.9363636363636364 MRR 0.5372854460354464 rank 0 total_num 109 865\n",
      "checkcorrect (5892, 194, 5059) (5892, 194, 5059) real score 0.4220208883285522 Hits@1 0.34234234234234234 Hits@3 0.6756756756756757 Hits@10 0.9369369369369369 MRR 0.5342468384135054 rank 4 total_num 110 865\n",
      "checkcorrect (5779, 58, 5419) (5779, 58, 5419) real score 0.9519699305295943 Hits@1 0.3482142857142857 Hits@3 0.6785714285714286 Hits@10 0.9375 MRR 0.5384053487848134 rank 0 total_num 111 865\n",
      "checkcorrect (5081, 8, 3793) (5081, 8, 3793) real score 0.8705476492643356 Hits@1 0.34513274336283184 Hits@3 0.6814159292035398 Hits@10 0.9380530973451328 MRR 0.538065478441585 rank 1 total_num 112 865\n",
      "checkcorrect (4874, 228, 4567) (4874, 228, 4567) real score 0.8816951215267181 Hits@1 0.34210526315789475 Hits@3 0.6842105263157895 Hits@10 0.9385964912280702 MRR 0.537731570735957 rank 1 total_num 113 865\n",
      "checkcorrect (4263, 54, 3669) (4263, 54, 3669) real score 0.957551372051239 Hits@1 0.3391304347826087 Hits@3 0.6869565217391305 Hits@10 0.9391304347826087 MRR 0.5374034701208618 rank 1 total_num 114 865\n",
      "checkcorrect (4004, 16, 3812) (4004, 16, 3812) real score 0.9701028883457183 Hits@1 0.3448275862068966 Hits@3 0.6896551724137931 Hits@10 0.9396551724137931 MRR 0.5413913712405095 rank 0 total_num 115 865\n",
      "checkcorrect (4699, 52, 3912) (4699, 52, 3912) real score 0.9671255856752397 Hits@1 0.3504273504273504 Hits@3 0.6923076923076923 Hits@10 0.9401709401709402 MRR 0.5453111031102488 rank 0 total_num 116 865\n",
      "checkcorrect (4423, 78, 3799) (4423, 78, 3799) real score 0.9669923096895219 Hits@1 0.3474576271186441 Hits@3 0.6949152542372882 Hits@10 0.940677966101695 MRR 0.5435146813324783 rank 2 total_num 117 865\n",
      "checkcorrect (5068, 30, 4419) (5068, 30, 4419) real score 0.8949778407812119 Hits@1 0.35294117647058826 Hits@3 0.6974789915966386 Hits@10 0.9411764705882353 MRR 0.547350692413718 rank 0 total_num 118 865\n",
      "checkcorrect (5378, 26, 4055) (5378, 26, 4055) real score 0.9721750676631927 Hits@1 0.35 Hits@3 0.7 Hits@10 0.9416666666666667 MRR 0.5455672144213815 rank 2 total_num 119 865\n",
      "checkcorrect (4839, 172, 3866) (4839, 172, 3866) real score 0.9316373035311698 Hits@1 0.34710743801652894 Hits@3 0.7024793388429752 Hits@10 0.9421487603305785 MRR 0.5451906258724444 rank 1 total_num 120 865\n",
      "checkcorrect (3850, 46, 3680) (3850, 46, 3680) real score 0.9327507585287094 Hits@1 0.3442622950819672 Hits@3 0.6967213114754098 Hits@10 0.9426229508196722 MRR 0.5427710305784079 rank 3 total_num 121 865\n",
      "checkcorrect (4504, 364, 4217) (4504, 364, 4217) real score 0.9557523965835572 Hits@1 0.34146341463414637 Hits@3 0.6991869918699187 Hits@10 0.943089430894309 MRR 0.542423298622486 rank 1 total_num 122 865\n",
      "checkcorrect (3999, 56, 4762) (3999, 56, 4762) real score 0.9774278700351715 Hits@1 0.3387096774193548 Hits@3 0.7016129032258065 Hits@10 0.9435483870967742 MRR 0.5420811752464981 rank 1 total_num 123 865\n",
      "checkcorrect (4305, 52, 3841) (4305, 52, 3841) real score 0.9527744710445405 Hits@1 0.344 Hits@3 0.704 Hits@10 0.944 MRR 0.5457445258445262 rank 0 total_num 124 865\n",
      "checkcorrect (4215, 110, 5074) (4215, 110, 5074) real score 0.914482805132866 Hits@1 0.3492063492063492 Hits@3 0.7063492063492064 Hits@10 0.9444444444444444 MRR 0.5493497280203632 rank 0 total_num 125 865\n",
      "checkcorrect (4694, 220, 4216) (4694, 220, 4216) real score 0.9111235067248344 Hits@1 0.3543307086614173 Hits@3 0.7086614173228346 Hits@10 0.9448818897637795 MRR 0.5528981553587856 rank 0 total_num 126 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3962, 54, 3669) (3962, 54, 3669) real score 0.9349052459001541 Hits@1 0.3515625 Hits@3 0.703125 Hits@10 0.9453125 MRR 0.5501411385200451 rank 4 total_num 127 865\n",
      "checkcorrect (4351, 100, 5794) (4351, 100, 5794) real score 0.9381272464990615 Hits@1 0.3488372093023256 Hits@3 0.6976744186046512 Hits@10 0.9457364341085271 MRR 0.5468454707795797 rank 7 total_num 128 865\n",
      "checkcorrect (5430, 242, 6101) (5430, 242, 6101) real score 0.46861158311367035 Hits@1 0.34615384615384615 Hits@3 0.7 Hits@10 0.9461538461538461 MRR 0.5464851210043521 rank 1 total_num 129 865\n",
      "checkcorrect (6096, 222, 4371) (6096, 222, 4371) real score 0.9518328070640565 Hits@1 0.3435114503816794 Hits@3 0.7022900763358778 Hits@10 0.9465648854961832 MRR 0.5448580081213672 rank 2 total_num 130 865\n",
      "checkcorrect (3884, 10, 4185) (3884, 10, 4185) real score 0.8944562405347825 Hits@1 0.3409090909090909 Hits@3 0.696969696969697 Hits@10 0.946969696969697 MRR 0.542624235332569 rank 3 total_num 131 865\n",
      "checkcorrect (5641, 408, 3826) (5641, 408, 3826) real score 0.9577726185321809 Hits@1 0.3458646616541353 Hits@3 0.6992481203007519 Hits@10 0.9473684210526315 MRR 0.5460631508563842 rank 0 total_num 132 865\n",
      "checkcorrect (5150, 54, 3669) (5150, 54, 3669) real score 0.9167339533567429 Hits@1 0.34328358208955223 Hits@3 0.6940298507462687 Hits@10 0.9477611940298507 MRR 0.5438537243574559 rank 3 total_num 133 865\n",
      "checkcorrect (3726, 172, 4815) (3726, 172, 4815) real score 0.9101466029882431 Hits@1 0.34074074074074073 Hits@3 0.6962962962962963 Hits@10 0.9481481481481482 MRR 0.5422943140535735 rank 2 total_num 134 865\n",
      "checkcorrect (4043, 24, 3754) (4043, 24, 3754) real score 0.9388708591461181 Hits@1 0.3382352941176471 Hits@3 0.6911764705882353 Hits@10 0.9485294117647058 MRR 0.5401450911561207 rank 3 total_num 135 865\n",
      "checkcorrect (3914, 20, 4054) (3914, 20, 4054) real score 0.9682208955287934 Hits@1 0.34306569343065696 Hits@3 0.6934306569343066 Hits@10 0.948905109489051 MRR 0.5435016963301638 rank 0 total_num 136 865\n",
      "checkcorrect (6053, 30, 4267) (6053, 30, 4267) real score 0.8090376615524292 Hits@1 0.34782608695652173 Hits@3 0.6956521739130435 Hits@10 0.9492753623188406 MRR 0.5468096550524089 rank 0 total_num 137 865\n",
      "checkcorrect (4143, 312, 4144) (4143, 312, 4144) real score 0.7552866414189339 Hits@1 0.35251798561151076 Hits@3 0.697841726618705 Hits@10 0.9496402877697842 MRR 0.5500700172462765 rank 0 total_num 138 865\n",
      "checkcorrect (4970, 54, 3669) (4970, 54, 3669) real score 0.9258257001638412 Hits@1 0.35 Hits@3 0.6928571428571428 Hits@10 0.95 MRR 0.5479266599802316 rank 3 total_num 139 865\n",
      "checkcorrect (3893, 46, 4488) (3893, 46, 4488) real score 0.7713900059461594 Hits@1 0.3475177304964539 Hits@3 0.6879432624113475 Hits@10 0.950354609929078 MRR 0.5449271801222159 rank 7 total_num 140 865\n",
      "checkcorrect (4867, 10, 4800) (4867, 10, 4800) real score 0.8973464637994766 Hits@1 0.34507042253521125 Hits@3 0.6830985915492958 Hits@10 0.9507042253521126 MRR 0.5424981154734678 rank 4 total_num 141 865\n",
      "checkcorrect (4649, 168, 4089) (4649, 168, 4089) real score 0.9775518655776978 Hits@1 0.34965034965034963 Hits@3 0.6853146853146853 Hits@10 0.951048951048951 MRR 0.5456974293512757 rank 0 total_num 142 865\n",
      "checkcorrect (4027, 124, 5822) (4027, 124, 5822) real score 0.9859183341264726 Hits@1 0.3541666666666667 Hits@3 0.6875 Hits@10 0.9513888888888888 MRR 0.5488523083141141 rank 0 total_num 143 865\n",
      "checkcorrect (3730, 172, 5915) (3730, 172, 5915) real score 0.9421394377946853 Hits@1 0.35172413793103446 Hits@3 0.6896551724137931 Hits@10 0.9517241379310345 MRR 0.5485153958429823 rank 1 total_num 144 865\n",
      "checkcorrect (4748, 26, 3723) (4748, 26, 3723) real score 0.9708699256181716 Hits@1 0.3493150684931507 Hits@3 0.684931506849315 Hits@10 0.952054794520548 MRR 0.5461283040906331 rank 4 total_num 145 865\n",
      "checkcorrect (5579, 172, 5414) (5579, 172, 5414) real score 0.8585461586713791 Hits@1 0.3469387755102041 Hits@3 0.6802721088435374 Hits@10 0.9523809523809523 MRR 0.5437736897770914 rank 4 total_num 146 865\n",
      "checkcorrect (4906, 218, 3933) (4906, 218, 3933) real score 0.9637301564216614 Hits@1 0.35135135135135137 Hits@3 0.6824324324324325 Hits@10 0.9527027027027027 MRR 0.5468562999813003 rank 0 total_num 147 865\n",
      "checkcorrect (5375, 54, 3669) (5375, 54, 3669) real score 0.9515190303325654 Hits@1 0.348993288590604 Hits@3 0.6845637583892618 Hits@10 0.9530201342281879 MRR 0.5465418281693453 rank 1 total_num 148 865\n",
      "checkcorrect (3688, 138, 4622) (3688, 138, 4622) real score 0.9920897722244263 Hits@1 0.35333333333333333 Hits@3 0.6866666666666666 Hits@10 0.9533333333333334 MRR 0.5495648826482162 rank 0 total_num 149 865\n",
      "checkcorrect (6076, 92, 4069) (6076, 92, 4069) real score 0.8812778145074844 Hits@1 0.3576158940397351 Hits@3 0.6887417218543046 Hits@10 0.9536423841059603 MRR 0.5525478966704135 rank 0 total_num 150 865\n",
      "checkcorrect (4019, 4, 3864) (4019, 4, 3864) real score 0.9486319929361344 Hits@1 0.3618421052631579 Hits@3 0.6907894736842105 Hits@10 0.9539473684210527 MRR 0.5554916605081082 rank 0 total_num 151 865\n",
      "checkcorrect (4503, 54, 3669) (4503, 54, 3669) real score 0.9318459033966064 Hits@1 0.3660130718954248 Hits@3 0.6928104575163399 Hits@10 0.954248366013072 MRR 0.5583969437727611 rank 0 total_num 152 865\n",
      "checkcorrect (4445, 138, 4806) (4445, 138, 4806) real score 0.9920902401208878 Hits@1 0.37012987012987014 Hits@3 0.6948051948051948 Hits@10 0.9545454545454546 MRR 0.5612644960859249 rank 0 total_num 153 865\n",
      "checkcorrect (4925, 352, 4558) (4925, 352, 4558) real score 0.5922952175140381 Hits@1 0.3741935483870968 Hits@3 0.6967741935483871 Hits@10 0.9548387096774194 MRR 0.5640950477240803 rank 0 total_num 154 865\n",
      "checkcorrect (4608, 352, 5740) (4608, 352, 5740) real score 0.574319226294756 Hits@1 0.3782051282051282 Hits@3 0.6987179487179487 Hits@10 0.9551282051282052 MRR 0.5668893102386695 rank 0 total_num 155 865\n",
      "checkcorrect (3745, 172, 4686) (3745, 172, 4686) real score 0.92255799472332 Hits@1 0.37579617834394907 Hits@3 0.7006369426751592 Hits@10 0.9554140127388535 MRR 0.5654016925513743 rank 2 total_num 156 865\n",
      "checkcorrect (4074, 118, 4036) (4074, 118, 4036) real score 0.9781169384717942 Hits@1 0.379746835443038 Hits@3 0.7025316455696202 Hits@10 0.9556962025316456 MRR 0.5681523147504163 rank 0 total_num 157 865\n",
      "checkcorrect (4477, 426, 5315) (4477, 426, 5315) real score 0.3336643148213625 Hits@1 0.37735849056603776 Hits@3 0.7044025157232704 Hits@10 0.9559748427672956 MRR 0.5677236838400362 rank 1 total_num 158 865\n",
      "checkcorrect (5589, 132, 5593) (5589, 132, 5593) real score 0.937819629907608 Hits@1 0.38125 Hits@3 0.70625 Hits@10 0.95625 MRR 0.570425410816036 rank 0 total_num 159 865\n",
      "checkcorrect (3944, 120, 6106) (3944, 120, 6106) real score 0.7525345414876938 Hits@1 0.38509316770186336 Hits@3 0.7080745341614907 Hits@10 0.9565217391304348 MRR 0.573093575966247 rank 0 total_num 160 865\n",
      "checkcorrect (5040, 34, 3746) (5040, 34, 3746) real score 0.8813988864421844 Hits@1 0.38271604938271603 Hits@3 0.7037037037037037 Hits@10 0.9567901234567902 MRR 0.5703275662380602 rank 7 total_num 161 865\n",
      "checkcorrect (5363, 4, 3864) (5363, 4, 3864) real score 0.9450969099998474 Hits@1 0.3803680981595092 Hits@3 0.7055214723926381 Hits@10 0.9570552147239264 MRR 0.5698961087764771 rank 1 total_num 162 865\n",
      "checkcorrect (4024, 46, 4023) (4024, 46, 4023) real score 0.5943036888726055 Hits@1 0.3780487804878049 Hits@3 0.7012195121951219 Hits@10 0.9573170731707317 MRR 0.5670308886010107 rank 9 total_num 163 865\n",
      "checkcorrect (3700, 46, 5411) (3700, 46, 5411) real score 0.7678146749734879 Hits@1 0.37575757575757573 Hits@3 0.696969696969697 Hits@10 0.9575757575757575 MRR 0.5643519135185804 rank 7 total_num 164 865\n",
      "checkcorrect (4039, 24, 4144) (4039, 24, 4144) real score 0.8443009749054908 Hits@1 0.37349397590361444 Hits@3 0.6927710843373494 Hits@10 0.9578313253012049 MRR 0.5624582272925648 rank 3 total_num 165 865\n",
      "checkcorrect (5267, 54, 3712) (5267, 54, 3712) real score 0.9678346306085587 Hits@1 0.3712574850299401 Hits@3 0.6946107784431138 Hits@10 0.9580838323353293 MRR 0.5620842259315315 rank 1 total_num 166 865\n",
      "checkcorrect (5005, 168, 4774) (5005, 168, 4774) real score 0.9787180244922637 Hits@1 0.375 Hits@3 0.6964285714285714 Hits@10 0.9583333333333334 MRR 0.5646908674438438 rank 0 total_num 167 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4404, 356, 4164) (4404, 356, 4164) real score 0.4358286697417498 Hits@1 0.3727810650887574 Hits@3 0.6923076923076923 Hits@10 0.9585798816568047 MRR 0.5625329333169572 rank 4 total_num 168 865\n",
      "checkcorrect (3788, 24, 4098) (3788, 24, 4098) real score 0.9568884760141373 Hits@1 0.3764705882352941 Hits@3 0.6941176470588235 Hits@10 0.9588235294117647 MRR 0.565106269003328 rank 0 total_num 169 865\n",
      "checkcorrect (5392, 56, 3888) (5392, 56, 3888) real score 0.9912744373083114 Hits@1 0.3742690058479532 Hits@3 0.695906432748538 Hits@10 0.9590643274853801 MRR 0.5647255305881039 rank 1 total_num 170 865\n",
      "checkcorrect (3788, 24, 4345) (3788, 24, 4345) real score 0.9249921262264251 Hits@1 0.37209302325581395 Hits@3 0.6918604651162791 Hits@10 0.9593023255813954 MRR 0.5628957309916615 rank 3 total_num 171 865\n",
      "checkcorrect (3866, 50, 3909) (3866, 50, 3909) real score 0.8403506428003311 Hits@1 0.3699421965317919 Hits@3 0.6936416184971098 Hits@10 0.9595375722543352 MRR 0.5615687807161798 rank 2 total_num 172 865\n",
      "checkcorrect (3745, 172, 6119) (3745, 172, 6119) real score 0.9575304120779038 Hits@1 0.3735632183908046 Hits@3 0.6954022988505747 Hits@10 0.9597701149425287 MRR 0.5640885003672361 rank 0 total_num 173 865\n",
      "checkcorrect (3726, 172, 4666) (3726, 172, 4666) real score 0.9500615775585175 Hits@1 0.37714285714285717 Hits@3 0.6971428571428572 Hits@10 0.96 MRR 0.5665794232222805 rank 0 total_num 174 865\n",
      "checkcorrect (4163, 46, 5492) (4163, 46, 5492) real score 0.8650880694389343 Hits@1 0.375 Hits@3 0.6931818181818182 Hits@10 0.9602272727272727 MRR 0.5647806764994266 rank 3 total_num 175 865\n",
      "checkcorrect (5669, 54, 5823) (5669, 54, 5823) real score 0.9827006757259369 Hits@1 0.3728813559322034 Hits@3 0.6949152542372882 Hits@10 0.96045197740113 MRR 0.5634730643911436 rank 2 total_num 176 865\n",
      "checkcorrect (3699, 78, 3799) (3699, 78, 3799) real score 0.9819245010614395 Hits@1 0.37640449438202245 Hits@3 0.6966292134831461 Hits@10 0.9606741573033708 MRR 0.5659254629058001 rank 0 total_num 177 865\n",
      "checkcorrect (4031, 56, 3888) (4031, 56, 3888) real score 0.9757841736078263 Hits@1 0.3743016759776536 Hits@3 0.6983240223463687 Hits@10 0.9608938547486033 MRR 0.5655571642303487 rank 1 total_num 178 865\n",
      "checkcorrect (4017, 102, 3845) (4017, 102, 3845) real score 0.9926712095737458 Hits@1 0.37222222222222223 Hits@3 0.7 Hits@10 0.9611111111111111 MRR 0.5651929577624023 rank 1 total_num 179 865\n",
      "checkcorrect (3903, 50, 4626) (3903, 50, 4626) real score 0.9303531497716904 Hits@1 0.3701657458563536 Hits@3 0.6961325966850829 Hits@10 0.9613259668508287 MRR 0.563451560205704 rank 3 total_num 180 865\n",
      "checkcorrect (4951, 10, 5933) (4951, 10, 5933) real score 0.359586700797081 Hits@1 0.36813186813186816 Hits@3 0.6923076923076923 Hits@10 0.9560439560439561 MRR 0.5606054227620163 rank 21 total_num 181 865\n",
      "checkcorrect (4340, 16, 5151) (4340, 16, 5151) real score 0.9822489202022553 Hits@1 0.366120218579235 Hits@3 0.6939890710382514 Hits@10 0.9562841530054644 MRR 0.5602742455884534 rank 1 total_num 182 865\n",
      "checkcorrect (4535, 60, 4413) (4535, 60, 4413) real score 0.8681541740894319 Hits@1 0.3641304347826087 Hits@3 0.6956521739130435 Hits@10 0.9565217391304348 MRR 0.559946668166777 rank 1 total_num 183 865\n",
      "checkcorrect (3914, 302, 4423) (3914, 302, 4423) real score 0.8845442503690719 Hits@1 0.3621621621621622 Hits@3 0.6972972972972973 Hits@10 0.9567567567567568 MRR 0.5587217312217313 rank 2 total_num 184 865\n",
      "checkcorrect (4147, 50, 4345) (4147, 50, 4345) real score 0.9532217442989349 Hits@1 0.3602150537634409 Hits@3 0.6989247311827957 Hits@10 0.956989247311828 MRR 0.5584060229893564 rank 1 total_num 185 865\n",
      "checkcorrect (5000, 102, 3844) (5000, 102, 3844) real score 0.9927944004535675 Hits@1 0.36363636363636365 Hits@3 0.7005347593582888 Hits@10 0.9572192513368984 MRR 0.5607674881070605 rank 0 total_num 186 865\n",
      "checkcorrect (4338, 86, 4162) (4338, 86, 4162) real score 0.8478447079658509 Hits@1 0.3617021276595745 Hits@3 0.7021276595744681 Hits@10 0.9574468085106383 MRR 0.559557731964647 rank 2 total_num 187 865\n",
      "checkcorrect (4269, 34, 5567) (4269, 34, 5567) real score 0.4261431723833084 Hits@1 0.35978835978835977 Hits@3 0.6984126984126984 Hits@10 0.9523809523809523 MRR 0.5570781095251995 rank 10 total_num 188 865\n",
      "checkcorrect (5703, 344, 5168) (5703, 344, 5168) real score 0.0 Hits@1 0.35789473684210527 Hits@3 0.6947368421052632 Hits@10 0.9473684210526315 MRR 0.5542810722415986 rank 38 total_num 189 865\n",
      "checkcorrect (4254, 214, 4741) (4254, 214, 4741) real score 0.9600715845823289 Hits@1 0.3612565445026178 Hits@3 0.6963350785340314 Hits@10 0.9476439790575916 MRR 0.5566146791932133 rank 0 total_num 190 865\n",
      "checkcorrect (3748, 46, 3900) (3748, 46, 3900) real score 0.931908905506134 Hits@1 0.359375 Hits@3 0.6979166666666666 Hits@10 0.9479166666666666 MRR 0.5554517555168598 rank 2 total_num 191 865\n",
      "checkcorrect (4157, 80, 4289) (4157, 80, 4289) real score 0.9650168776512147 Hits@1 0.35751295336787564 Hits@3 0.6994818652849741 Hits@10 0.9481865284974094 MRR 0.554300882863059 rank 2 total_num 192 865\n",
      "checkcorrect (3909, 50, 3866) (3909, 50, 3866) real score 0.7651137828826904 Hits@1 0.3556701030927835 Hits@3 0.6958762886597938 Hits@10 0.9484536082474226 MRR 0.5519591257348989 rank 9 total_num 193 865\n",
      "checkcorrect (3795, 162, 3834) (3795, 162, 3834) real score 0.8190084457397462 Hits@1 0.35384615384615387 Hits@3 0.6923076923076923 Hits@10 0.9487179487179487 MRR 0.5501542071413866 rank 4 total_num 194 865\n",
      "checkcorrect (4813, 46, 4293) (4813, 46, 4293) real score 0.9105939030647278 Hits@1 0.3520408163265306 Hits@3 0.6938775510204082 Hits@10 0.9489795918367347 MRR 0.5490479781933864 rank 2 total_num 195 865\n",
      "checkcorrect (4390, 56, 3752) (4390, 56, 3752) real score 0.9908263981342316 Hits@1 0.3553299492385787 Hits@3 0.6954314720812182 Hits@10 0.949238578680203 MRR 0.5513370747507803 rank 0 total_num 196 865\n",
      "checkcorrect (5421, 156, 3676) (5421, 156, 3676) real score 0.9753728479146957 Hits@1 0.35858585858585856 Hits@3 0.696969696969697 Hits@10 0.9494949494949495 MRR 0.5536030491207259 rank 0 total_num 197 865\n",
      "checkcorrect (4497, 232, 4189) (4497, 232, 4189) real score 0.9654475718736648 Hits@1 0.35678391959798994 Hits@3 0.6984924623115578 Hits@10 0.949748743718593 MRR 0.5533336870648429 rank 1 total_num 198 865\n",
      "checkcorrect (4623, 10, 4682) (4623, 10, 4682) real score 0.9225812315940858 Hits@1 0.355 Hits@3 0.7 Hits@10 0.95 MRR 0.5522336852961852 rank 2 total_num 199 865\n",
      "checkcorrect (4548, 50, 4547) (4548, 50, 4547) real score 0.9356153100728988 Hits@1 0.35323383084577115 Hits@3 0.6965174129353234 Hits@10 0.9502487562189055 MRR 0.5504812789016769 rank 4 total_num 200 865\n",
      "checkcorrect (5549, 74, 4869) (5549, 74, 4869) real score 0.9568394273519516 Hits@1 0.35148514851485146 Hits@3 0.698019801980198 Hits@10 0.9504950495049505 MRR 0.5494062890721306 rank 2 total_num 201 865\n",
      "checkcorrect (5449, 116, 3877) (5449, 116, 3877) real score 0.9945348054170609 Hits@1 0.35467980295566504 Hits@3 0.6995073891625616 Hits@10 0.9507389162561576 MRR 0.5516259625249773 rank 0 total_num 202 865\n",
      "checkcorrect (3858, 282, 3868) (3858, 282, 3868) real score 0.3654042840003967 Hits@1 0.35294117647058826 Hits@3 0.696078431372549 Hits@10 0.9509803921568627 MRR 0.5494665759984387 rank 8 total_num 203 865\n",
      "checkcorrect (4370, 310, 5729) (4370, 310, 5729) real score 0.8671537160873413 Hits@1 0.35121951219512193 Hits@3 0.697560975609756 Hits@10 0.9512195121951219 MRR 0.5484122674976333 rank 2 total_num 204 865\n",
      "checkcorrect (4194, 24, 5218) (4194, 24, 5218) real score 0.9664457678794861 Hits@1 0.35436893203883496 Hits@3 0.6990291262135923 Hits@10 0.9514563106796117 MRR 0.5506044409563826 rank 0 total_num 205 865\n",
      "checkcorrect (4508, 54, 5528) (4508, 54, 5528) real score 0.9082426667213439 Hits@1 0.3526570048309179 Hits@3 0.6956521739130435 Hits@10 0.9516908212560387 MRR 0.5485483808551441 rank 7 total_num 206 865\n",
      "checkcorrect (3850, 50, 4682) (3850, 50, 4682) real score 0.9583015233278275 Hits@1 0.3557692307692308 Hits@3 0.6971153846153846 Hits@10 0.9519230769230769 MRR 0.550718821331802 rank 0 total_num 207 865\n",
      "checkcorrect (4546, 60, 5772) (4546, 60, 5772) real score 0.6842771247029305 Hits@1 0.3588516746411483 Hits@3 0.6985645933014354 Hits@10 0.9521531100478469 MRR 0.5528684920431332 rank 0 total_num 208 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4127, 46, 4284) (4127, 46, 4284) real score 0.6590795174241066 Hits@1 0.35714285714285715 Hits@3 0.6952380952380952 Hits@10 0.9476190476190476 MRR 0.5505532452556261 rank 14 total_num 209 865\n",
      "checkcorrect (5111, 2, 5762) (5111, 2, 5762) real score 0.925815936923027 Hits@1 0.35545023696682465 Hits@3 0.6919431279620853 Hits@10 0.9478672985781991 MRR 0.5488918554676848 rank 4 total_num 210 865\n",
      "checkcorrect (4521, 20, 4095) (4521, 20, 4095) real score 0.9616235196590424 Hits@1 0.35377358490566035 Hits@3 0.6933962264150944 Hits@10 0.9481132075471698 MRR 0.547875069985919 rank 2 total_num 211 865\n",
      "checkcorrect (4694, 76, 3919) (4694, 76, 3919) real score 0.9766949772834778 Hits@1 0.3568075117370892 Hits@3 0.6948356807511737 Hits@10 0.9483568075117371 MRR 0.5499977222395062 rank 0 total_num 212 865\n",
      "checkcorrect (5936, 360, 4870) (5936, 360, 4870) real score 0.41980820894241333 Hits@1 0.35514018691588783 Hits@3 0.6915887850467289 Hits@10 0.9439252336448598 MRR 0.5478524482613267 rank 10 total_num 213 865\n",
      "checkcorrect (4106, 172, 4805) (4106, 172, 4805) real score 0.9591096222400666 Hits@1 0.3581395348837209 Hits@3 0.6930232558139535 Hits@10 0.9441860465116279 MRR 0.5499554601298786 rank 0 total_num 214 865\n",
      "checkcorrect (4084, 44, 3729) (4084, 44, 3729) real score 0.9255175590515137 Hits@1 0.35648148148148145 Hits@3 0.6898148148148148 Hits@10 0.9444444444444444 MRR 0.5485667774440922 rank 3 total_num 215 865\n",
      "checkcorrect (4333, 102, 3801) (4333, 102, 3801) real score 0.9929916203022003 Hits@1 0.35944700460829493 Hits@3 0.6912442396313364 Hits@10 0.9447004608294931 MRR 0.5506471148752254 rank 0 total_num 216 865\n",
      "checkcorrect (3830, 158, 4619) (3830, 158, 4619) real score 0.9523085981607438 Hits@1 0.3623853211009174 Hits@3 0.6926605504587156 Hits@10 0.944954128440367 MRR 0.5527083666418529 rank 0 total_num 217 865\n",
      "checkcorrect (4508, 2, 4681) (4508, 2, 4681) real score 0.9343337416648865 Hits@1 0.3607305936073059 Hits@3 0.6894977168949772 Hits@10 0.9452054794520548 MRR 0.5513261366571868 rank 3 total_num 218 865\n",
      "checkcorrect (4220, 50, 4872) (4220, 50, 4872) real score 0.8056641533970833 Hits@1 0.35909090909090907 Hits@3 0.6863636363636364 Hits@10 0.9454545454545454 MRR 0.5497291996723814 rank 4 total_num 219 865\n",
      "checkcorrect (3858, 50, 4268) (3858, 50, 4268) real score 0.9325204819440842 Hits@1 0.3574660633484163 Hits@3 0.6832579185520362 Hits@10 0.9457013574660633 MRR 0.5481467146059906 rank 4 total_num 220 865\n",
      "checkcorrect (4457, 24, 4496) (4457, 24, 4496) real score 0.9609258562326431 Hits@1 0.35585585585585583 Hits@3 0.6846846846846847 Hits@10 0.9459459459459459 MRR 0.5479298375131708 rank 1 total_num 221 865\n",
      "checkcorrect (5073, 338, 4905) (5073, 338, 4905) real score 0.9287034660577774 Hits@1 0.35874439461883406 Hits@3 0.6860986547085202 Hits@10 0.9461883408071748 MRR 0.549957057972753 rank 0 total_num 222 865\n",
      "checkcorrect (4873, 26, 4239) (4873, 26, 4239) real score 0.9787365704774857 Hits@1 0.35714285714285715 Hits@3 0.6875 Hits@10 0.9464285714285714 MRR 0.5497340353925175 rank 1 total_num 223 865\n",
      "checkcorrect (3884, 56, 4762) (3884, 56, 4762) real score 0.9905997395515442 Hits@1 0.36 Hits@3 0.6888888888888889 Hits@10 0.9466666666666667 MRR 0.5517352174574396 rank 0 total_num 224 865\n",
      "checkcorrect (4840, 78, 3995) (4840, 78, 3995) real score 0.9776134341955185 Hits@1 0.3584070796460177 Hits@3 0.6858407079646017 Hits@10 0.9469026548672567 MRR 0.5500313743123477 rank 5 total_num 225 865\n",
      "checkcorrect (4521, 50, 5816) (4521, 50, 5816) real score 0.7016077145934105 Hits@1 0.3568281938325991 Hits@3 0.6828193832599119 Hits@10 0.947136563876652 MRR 0.5480978048709326 rank 8 total_num 226 865\n",
      "checkcorrect (4194, 246, 5033) (4194, 246, 5033) real score 0.6364081278443336 Hits@1 0.35526315789473684 Hits@3 0.6798245614035088 Hits@10 0.9473684210526315 MRR 0.5467903583583408 rank 3 total_num 227 865\n",
      "checkcorrect (3797, 20, 3931) (3797, 20, 3931) real score 0.9559919267892838 Hits@1 0.3537117903930131 Hits@3 0.6768558951965066 Hits@10 0.9475982532751092 MRR 0.5454943305925839 rank 3 total_num 228 865\n",
      "checkcorrect (3717, 52, 3969) (3717, 52, 3969) real score 0.9441716879606248 Hits@1 0.3521739130434783 Hits@3 0.6782608695652174 Hits@10 0.9478260869565217 MRR 0.5452965291552248 rank 1 total_num 229 865\n",
      "checkcorrect (5201, 78, 4636) (5201, 78, 4636) real score 0.980147448182106 Hits@1 0.35064935064935066 Hits@3 0.6796536796536796 Hits@10 0.948051948051948 MRR 0.545100440284423 rank 1 total_num 230 865\n",
      "checkcorrect (5837, 132, 5257) (5837, 132, 5257) real score 0.9702406436204911 Hits@1 0.35344827586206895 Hits@3 0.6810344827586207 Hits@10 0.9482758620689655 MRR 0.5470612142487142 rank 0 total_num 231 865\n",
      "checkcorrect (3898, 54, 3712) (3898, 54, 3712) real score 0.9757008612155914 Hits@1 0.351931330472103 Hits@3 0.6824034334763949 Hits@10 0.9484978540772532 MRR 0.5461439272061589 rank 2 total_num 232 865\n",
      "checkcorrect (3821, 54, 3669) (3821, 54, 3669) real score 0.9784382879734039 Hits@1 0.3547008547008547 Hits@3 0.6837606837606838 Hits@10 0.9487179487179487 MRR 0.5480834830727993 rank 0 total_num 233 865\n",
      "checkcorrect (4247, 16, 4001) (4247, 16, 4001) real score 0.962493246793747 Hits@1 0.35319148936170214 Hits@3 0.6851063829787234 Hits@10 0.948936170212766 MRR 0.5471696526483761 rank 2 total_num 234 865\n",
      "checkcorrect (3878, 56, 3826) (3878, 56, 3826) real score 0.9209005057811737 Hits@1 0.3516949152542373 Hits@3 0.6864406779661016 Hits@10 0.9491525423728814 MRR 0.5462635665495836 rank 2 total_num 235 865\n",
      "checkcorrect (4957, 10, 3755) (4957, 10, 3755) real score 0.9137852191925049 Hits@1 0.350210970464135 Hits@3 0.6877637130801688 Hits@10 0.9493670886075949 MRR 0.5453651267469835 rank 2 total_num 236 865\n",
      "checkcorrect (4399, 56, 3826) (4399, 56, 3826) real score 0.9794098496437074 Hits@1 0.35294117647058826 Hits@3 0.6890756302521008 Hits@10 0.9495798319327731 MRR 0.54727535730687 rank 0 total_num 237 865\n",
      "checkcorrect (4891, 26, 4671) (4891, 26, 4671) real score 0.9797658801078797 Hits@1 0.35564853556485354 Hits@3 0.6903765690376569 Hits@10 0.9497907949790795 MRR 0.5491696026737869 rank 0 total_num 238 865\n",
      "checkcorrect (4712, 2, 4583) (4712, 2, 4583) real score 0.9397468626499177 Hits@1 0.3541666666666667 Hits@3 0.6875 Hits@10 0.95 MRR 0.5477147293293128 rank 4 total_num 239 865\n",
      "checkcorrect (5662, 54, 3669) (5662, 54, 3669) real score 0.916411030292511 Hits@1 0.35269709543568467 Hits@3 0.6846473029045643 Hits@10 0.950207468879668 MRR 0.5462719296225521 rank 4 total_num 240 865\n",
      "checkcorrect (4041, 54, 3691) (4041, 54, 3691) real score 0.964240437746048 Hits@1 0.3512396694214876 Hits@3 0.6859504132231405 Hits@10 0.9504132231404959 MRR 0.5460807233017977 rank 1 total_num 241 865\n",
      "checkcorrect (4107, 54, 3712) (4107, 54, 3712) real score 0.956025305390358 Hits@1 0.3497942386831276 Hits@3 0.6831275720164609 Hits@10 0.9506172839506173 MRR 0.5448622841112554 rank 3 total_num 242 865\n",
      "checkcorrect (3857, 16, 4896) (3857, 16, 4896) real score 0.9601442337036132 Hits@1 0.3483606557377049 Hits@3 0.6844262295081968 Hits@10 0.9508196721311475 MRR 0.5439953621818376 rank 2 total_num 243 865\n",
      "checkcorrect (4265, 108, 5078) (4265, 108, 5078) real score 0.8806930914521218 Hits@1 0.3469387755102041 Hits@3 0.6816326530612244 Hits@10 0.9510204081632653 MRR 0.5425912994790546 rank 4 total_num 244 865\n",
      "checkcorrect (4062, 50, 4039) (4062, 50, 4039) real score 0.9537342548370361 Hits@1 0.34959349593495936 Hits@3 0.6829268292682927 Hits@10 0.9512195121951219 MRR 0.5444506844405219 rank 0 total_num 245 865\n",
      "checkcorrect (4619, 140, 6162) (4619, 140, 6162) real score 0.40550510585308075 Hits@1 0.3481781376518219 Hits@3 0.680161943319838 Hits@10 0.9473684210526315 MRR 0.5425163361904253 rank 14 total_num 246 865\n",
      "checkcorrect (5574, 54, 3669) (5574, 54, 3669) real score 0.8847478747367858 Hits@1 0.3467741935483871 Hits@3 0.6774193548387096 Hits@10 0.9475806451612904 MRR 0.5411352219315929 rank 4 total_num 247 865\n",
      "checkcorrect (5793, 126, 5051) (5793, 126, 5051) real score 0.43802278507500886 Hits@1 0.3453815261044177 Hits@3 0.6746987951807228 Hits@10 0.9437751004016064 MRR 0.5391982271825173 rank 16 total_num 248 865\n",
      "checkcorrect (5062, 4, 3864) (5062, 4, 3864) real score 0.9507392168045044 Hits@1 0.348 Hits@3 0.676 Hits@10 0.944 MRR 0.5410414342737873 rank 0 total_num 249 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5457, 26, 4100) (5457, 26, 4100) real score 0.9791980952024459 Hits@1 0.3466135458167331 Hits@3 0.6733067729083665 Hits@10 0.9442231075697212 MRR 0.5398819066471984 rank 3 total_num 250 865\n",
      "checkcorrect (4325, 348, 3811) (4325, 348, 3811) real score 0.8940237566828728 Hits@1 0.3492063492063492 Hits@3 0.6746031746031746 Hits@10 0.9444444444444444 MRR 0.5417077720970112 rank 0 total_num 251 865\n",
      "checkcorrect (3944, 196, 3704) (3944, 196, 3704) real score 0.9475735574960709 Hits@1 0.35177865612648224 Hits@3 0.6758893280632411 Hits@10 0.9446640316205533 MRR 0.543519203827853 rank 0 total_num 252 865\n",
      "checkcorrect (4017, 102, 3956) (4017, 102, 3956) real score 0.9927058637142181 Hits@1 0.3543307086614173 Hits@3 0.6771653543307087 Hits@10 0.9448818897637795 MRR 0.5453163723167197 rank 0 total_num 253 865\n",
      "checkcorrect (3999, 56, 3695) (3999, 56, 3695) real score 0.946986734867096 Hits@1 0.3568627450980392 Hits@3 0.6784313725490196 Hits@10 0.9450980392156862 MRR 0.547099445366458 rank 0 total_num 254 865\n",
      "checkcorrect (4250, 20, 3896) (4250, 20, 3896) real score 0.9539553880691528 Hits@1 0.359375 Hits@3 0.6796875 Hits@10 0.9453125 MRR 0.5488685881579953 rank 0 total_num 255 865\n",
      "checkcorrect (3684, 54, 3669) (3684, 54, 3669) real score 0.9182993710041045 Hits@1 0.35797665369649806 Hits@3 0.6770428015564203 Hits@10 0.9455252918287937 MRR 0.5473814211483015 rank 5 total_num 256 865\n",
      "checkcorrect (4061, 172, 5591) (4061, 172, 5591) real score 0.9493821889162064 Hits@1 0.35658914728682173 Hits@3 0.6782945736434108 Hits@10 0.9457364341085271 MRR 0.5471977722291219 rank 1 total_num 257 865\n",
      "checkcorrect (6018, 2, 4583) (6018, 2, 4583) real score 0.8642396926879883 Hits@1 0.3552123552123552 Hits@3 0.6756756756756757 Hits@10 0.9459459459459459 MRR 0.545514039946813 rank 8 total_num 258 865\n",
      "checkcorrect (5255, 54, 3669) (5255, 54, 3669) real score 0.9396028280258178 Hits@1 0.3576923076923077 Hits@3 0.676923076923077 Hits@10 0.9461538461538461 MRR 0.5472620628700945 rank 0 total_num 259 865\n",
      "checkcorrect (3729, 16, 3871) (3729, 16, 3871) real score 0.9740421086549759 Hits@1 0.36015325670498083 Hits@3 0.6781609195402298 Hits@10 0.946360153256705 MRR 0.5489966909817033 rank 0 total_num 260 865\n",
      "checkcorrect (4503, 2, 5580) (4503, 2, 5580) real score 0.9303453356027603 Hits@1 0.35877862595419846 Hits@3 0.6755725190839694 Hits@10 0.9465648854961832 MRR 0.5478554822374984 rank 3 total_num 261 865\n",
      "checkcorrect (3674, 78, 3799) (3674, 78, 3799) real score 0.9689626693725586 Hits@1 0.3574144486692015 Hits@3 0.6730038022813688 Hits@10 0.9467680608365019 MRR 0.5465328378183444 rank 4 total_num 262 865\n",
      "checkcorrect (5138, 100, 3746) (5138, 100, 3746) real score 0.9372058093547821 Hits@1 0.3560606060606061 Hits@3 0.6742424242424242 Hits@10 0.946969696969697 MRR 0.5457252639377194 rank 2 total_num 263 865\n",
      "checkcorrect (5058, 36, 5743) (5058, 36, 5743) real score 0.8898140043020248 Hits@1 0.3584905660377358 Hits@3 0.6754716981132075 Hits@10 0.9471698113207547 MRR 0.5474395082247469 rank 0 total_num 264 865\n",
      "checkcorrect (4025, 54, 3669) (4025, 54, 3669) real score 0.9802601426839829 Hits@1 0.3609022556390977 Hits@3 0.6766917293233082 Hits@10 0.9473684210526315 MRR 0.5491408634569847 rank 0 total_num 265 865\n",
      "checkcorrect (4254, 214, 4178) (4254, 214, 4178) real score 0.9512266203761102 Hits@1 0.36329588014981273 Hits@3 0.6779026217228464 Hits@10 0.947565543071161 MRR 0.5508294744552731 rank 0 total_num 266 865\n",
      "checkcorrect (4422, 54, 3669) (4422, 54, 3669) real score 0.9016619712114334 Hits@1 0.3619402985074627 Hits@3 0.6753731343283582 Hits@10 0.9477611940298507 MRR 0.5495204092520817 rank 4 total_num 267 865\n",
      "checkcorrect (5104, 218, 3933) (5104, 218, 3933) real score 0.973592072725296 Hits@1 0.36059479553903345 Hits@3 0.6765799256505576 Hits@10 0.9479553903345725 MRR 0.5487167398248745 rank 2 total_num 268 865\n",
      "checkcorrect (5561, 46, 4226) (5561, 46, 4226) real score 0.9354512691497803 Hits@1 0.362962962962963 Hits@3 0.6777777777777778 Hits@10 0.9481481481481482 MRR 0.5503881593070046 rank 0 total_num 269 865\n",
      "checkcorrect (4932, 24, 5515) (4932, 24, 5515) real score 0.802815055847168 Hits@1 0.36162361623616235 Hits@3 0.6752767527675276 Hits@10 0.948339483394834 MRR 0.548972212839697 rank 5 total_num 270 865\n",
      "checkcorrect (4647, 44, 5775) (4647, 44, 5775) real score 0.9254581302404403 Hits@1 0.3602941176470588 Hits@3 0.6764705882352942 Hits@10 0.9485294117647058 MRR 0.5487921679395511 rank 1 total_num 271 865\n",
      "checkcorrect (5183, 24, 3683) (5183, 24, 3683) real score 0.9353113859891891 Hits@1 0.3626373626373626 Hits@3 0.6776556776556777 Hits@10 0.9487179487179487 MRR 0.5504449438811645 rank 0 total_num 272 865\n",
      "checkcorrect (3863, 2, 5309) (3863, 2, 5309) real score 0.9084864526987075 Hits@1 0.3613138686131387 Hits@3 0.6751824817518248 Hits@10 0.948905109489051 MRR 0.5490442932343962 rank 5 total_num 273 865\n",
      "checkcorrect (4451, 194, 4452) (4451, 194, 4452) real score 0.42202083468437196 Hits@1 0.36 Hits@3 0.6763636363636364 Hits@10 0.9490909090909091 MRR 0.5488659503499075 rank 1 total_num 274 865\n",
      "checkcorrect (4247, 16, 4679) (4247, 16, 4679) real score 0.9755831897258758 Hits@1 0.36231884057971014 Hits@3 0.677536231884058 Hits@10 0.9492753623188406 MRR 0.55050049400806 rank 0 total_num 275 865\n",
      "checkcorrect (4509, 310, 4485) (4509, 310, 4485) real score 0.8934092998504639 Hits@1 0.36101083032490977 Hits@3 0.6787003610108303 Hits@10 0.9494584837545126 MRR 0.5497164970381151 rank 2 total_num 276 865\n",
      "checkcorrect (5500, 72, 3746) (5500, 72, 3746) real score 0.8891734391450883 Hits@1 0.3597122302158273 Hits@3 0.6762589928057554 Hits@10 0.9496402877697842 MRR 0.5486383801422946 rank 3 total_num 277 865\n",
      "checkcorrect (5566, 4, 3864) (5566, 4, 3864) real score 0.9637776374816895 Hits@1 0.36200716845878134 Hits@3 0.6774193548387096 Hits@10 0.9498207885304659 MRR 0.5502561637260139 rank 0 total_num 278 865\n",
      "checkcorrect (4153, 158, 4899) (4153, 158, 4899) real score 0.9437292844057084 Hits@1 0.3607142857142857 Hits@3 0.675 Hits@10 0.95 MRR 0.5488862012365162 rank 5 total_num 279 865\n",
      "checkcorrect (4464, 334, 5625) (4464, 334, 5625) real score 0.9660368084907531 Hits@1 0.36298932384341637 Hits@3 0.6761565836298933 Hits@10 0.9501779359430605 MRR 0.550491588420728 rank 0 total_num 280 865\n",
      "checkcorrect (3889, 24, 3833) (3889, 24, 3833) real score 0.8154604271054268 Hits@1 0.3617021276595745 Hits@3 0.6737588652482269 Hits@10 0.950354609929078 MRR 0.5490460762024173 rank 6 total_num 281 865\n",
      "checkcorrect (4988, 50, 4447) (4988, 50, 4447) real score 0.9265630811452865 Hits@1 0.36042402826855124 Hits@3 0.6713780918727915 Hits@10 0.950530035335689 MRR 0.5476107796181584 rank 6 total_num 282 865\n",
      "checkcorrect (5325, 50, 4268) (5325, 50, 4268) real score 0.9082173585891724 Hits@1 0.3591549295774648 Hits@3 0.6690140845070423 Hits@10 0.9507042253521126 MRR 0.5465628543378128 rank 3 total_num 283 865\n",
      "checkcorrect (4428, 4, 3864) (4428, 4, 3864) real score 0.9272210597991943 Hits@1 0.35789473684210527 Hits@3 0.6666666666666666 Hits@10 0.9508771929824561 MRR 0.5455222829190837 rank 3 total_num 284 865\n",
      "checkcorrect (4510, 20, 3806) (4510, 20, 3806) real score 0.9628941744565964 Hits@1 0.35664335664335667 Hits@3 0.6643356643356644 Hits@10 0.951048951048951 MRR 0.5444889882235624 rank 3 total_num 285 865\n",
      "checkcorrect (4023, 240, 5626) (4023, 240, 5626) real score 0.4082128703594208 Hits@1 0.3554006968641115 Hits@3 0.662020905923345 Hits@10 0.9477351916376306 MRR 0.542882174095025 rank 11 total_num 286 865\n",
      "checkcorrect (3943, 120, 3714) (3943, 120, 3714) real score 0.8779391258955002 Hits@1 0.3541666666666667 Hits@3 0.6631944444444444 Hits@10 0.9479166666666666 MRR 0.542733277657195 rank 1 total_num 287 865\n",
      "checkcorrect (5406, 100, 5558) (5406, 100, 5558) real score 0.4446281433105469 Hits@1 0.35294117647058826 Hits@3 0.6608996539792388 Hits@10 0.9446366782006921 MRR 0.5411024655249161 rank 13 total_num 288 865\n",
      "checkcorrect (3916, 172, 5203) (3916, 172, 5203) real score 0.9602883338928223 Hits@1 0.35517241379310344 Hits@3 0.6620689655172414 Hits@10 0.9448275862068966 MRR 0.5426848708162095 rank 0 total_num 289 865\n",
      "checkcorrect (6010, 92, 4069) (6010, 92, 4069) real score 0.9422964602708817 Hits@1 0.35738831615120276 Hits@3 0.6632302405498282 Hits@10 0.9450171821305842 MRR 0.5442564004697621 rank 0 total_num 290 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3908, 20, 4516) (3908, 20, 4516) real score 0.9644522577524186 Hits@1 0.3561643835616438 Hits@3 0.6643835616438356 Hits@10 0.9452054794520548 MRR 0.5435340611987469 rank 2 total_num 291 865\n",
      "checkcorrect (5782, 34, 3879) (5782, 34, 3879) real score 0.8859765887260438 Hits@1 0.35494880546075086 Hits@3 0.6621160409556314 Hits@10 0.9453924914675768 MRR 0.5420202930717887 rank 9 total_num 292 865\n",
      "checkcorrect (5776, 54, 3669) (5776, 54, 3669) real score 0.9647377490997315 Hits@1 0.35714285714285715 Hits@3 0.6632653061224489 Hits@10 0.9455782312925171 MRR 0.5435780471769868 rank 0 total_num 293 865\n",
      "checkcorrect (5434, 2, 3701) (5434, 2, 3701) real score 0.859249034523964 Hits@1 0.3559322033898305 Hits@3 0.6610169491525424 Hits@10 0.9457627118644067 MRR 0.5423003814803415 rank 5 total_num 294 865\n",
      "checkcorrect (3682, 24, 5601) (3682, 24, 5601) real score 0.9204953819513322 Hits@1 0.3547297297297297 Hits@3 0.6587837837837838 Hits@10 0.9459459459459459 MRR 0.5411439612726376 rank 4 total_num 295 865\n",
      "checkcorrect (3930, 24, 3833) (3930, 24, 3833) real score 0.8447533667087554 Hits@1 0.35353535353535354 Hits@3 0.6565656565656566 Hits@10 0.9461279461279462 MRR 0.5398029282139996 rank 6 total_num 296 865\n",
      "checkcorrect (3728, 50, 4677) (3728, 50, 4677) real score 0.9193675205111503 Hits@1 0.3523489932885906 Hits@3 0.6577181208053692 Hits@10 0.9463087248322147 MRR 0.5396693613407982 rank 1 total_num 297 865\n",
      "checkcorrect (4157, 42, 5577) (4157, 42, 5577) real score 0.9790698170661927 Hits@1 0.35451505016722407 Hits@3 0.6588628762541806 Hits@10 0.9464882943143813 MRR 0.5412089286941735 rank 0 total_num 298 865\n",
      "checkcorrect (5307, 54, 3669) (5307, 54, 3669) real score 0.9558482706546784 Hits@1 0.3566666666666667 Hits@3 0.66 Hits@10 0.9466666666666667 MRR 0.5427382322651929 rank 0 total_num 299 865\n",
      "checkcorrect (5272, 26, 3723) (5272, 26, 3723) real score 0.9760273396968842 Hits@1 0.3554817275747508 Hits@3 0.6611295681063123 Hits@10 0.946843853820598 MRR 0.5420425349265489 rank 2 total_num 300 865\n",
      "checkcorrect (4626, 54, 3669) (4626, 54, 3669) real score 0.9278049498796463 Hits@1 0.3543046357615894 Hits@3 0.6589403973509934 Hits@10 0.9470198675496688 MRR 0.5407995684753573 rank 5 total_num 301 865\n",
      "checkcorrect (5124, 74, 5421) (5124, 74, 5421) real score 0.9519695967435837 Hits@1 0.3564356435643564 Hits@3 0.6600660066006601 Hits@10 0.9471947194719472 MRR 0.5423150814506861 rank 0 total_num 302 865\n",
      "checkcorrect (4918, 100, 3746) (4918, 100, 3746) real score 0.9352314352989197 Hits@1 0.35855263157894735 Hits@3 0.6611842105263158 Hits@10 0.9473684210526315 MRR 0.5438206239459141 rank 0 total_num 303 865\n",
      "checkcorrect (4061, 172, 4283) (4061, 172, 4283) real score 0.9493689388036728 Hits@1 0.36065573770491804 Hits@3 0.6622950819672131 Hits@10 0.9475409836065574 MRR 0.5453162940313373 rank 0 total_num 304 865\n",
      "checkcorrect (4674, 54, 3669) (4674, 54, 3669) real score 0.931517431139946 Hits@1 0.35947712418300654 Hits@3 0.6633986928104575 Hits@10 0.9477124183006536 MRR 0.5451682015671826 rank 1 total_num 305 865\n",
      "checkcorrect (3860, 50, 3904) (3860, 50, 3904) real score 0.9627548694610596 Hits@1 0.3583061889250814 Hits@3 0.6644951140065146 Hits@10 0.9478827361563518 MRR 0.5450210738747814 rank 1 total_num 306 865\n",
      "checkcorrect (5630, 88, 3826) (5630, 88, 3826) real score 0.9933140754699707 Hits@1 0.36038961038961037 Hits@3 0.6655844155844156 Hits@10 0.948051948051948 MRR 0.5464982781803828 rank 0 total_num 307 865\n",
      "checkcorrect (4474, 20, 4083) (4474, 20, 4083) real score 0.9488834530115128 Hits@1 0.3592233009708738 Hits@3 0.6634304207119741 Hits@10 0.948220064724919 MRR 0.5452690496641571 rank 5 total_num 308 865\n",
      "checkcorrect (5939, 40, 3697) (5939, 40, 3697) real score 0.8484626829624176 Hits@1 0.36129032258064514 Hits@3 0.6645161290322581 Hits@10 0.9483870967741935 MRR 0.5467359236974985 rank 0 total_num 309 865\n",
      "checkcorrect (3971, 24, 5138) (3971, 24, 5138) real score 0.754122106730938 Hits@1 0.36012861736334406 Hits@3 0.662379421221865 Hits@10 0.9453376205787781 MRR 0.5451788950039375 rank 15 total_num 310 865\n",
      "checkcorrect (4023, 44, 4142) (4023, 44, 4142) real score 0.9175422012805938 Hits@1 0.358974358974359 Hits@3 0.6602564102564102 Hits@10 0.9455128205128205 MRR 0.5440725523917452 rank 4 total_num 311 865\n",
      "checkcorrect (3729, 16, 4387) (3729, 16, 4387) real score 0.9761482775211334 Hits@1 0.35782747603833864 Hits@3 0.6613418530351438 Hits@10 0.9456869009584664 MRR 0.5439317455150944 rank 1 total_num 312 865\n",
      "checkcorrect (3869, 16, 4725) (3869, 16, 4725) real score 0.977490708231926 Hits@1 0.35668789808917195 Hits@3 0.6624203821656051 Hits@10 0.945859872611465 MRR 0.5437918354975303 rank 1 total_num 313 865\n",
      "checkcorrect (4665, 108, 5280) (4665, 108, 5280) real score 0.9732341527938843 Hits@1 0.35555555555555557 Hits@3 0.6634920634920635 Hits@10 0.946031746031746 MRR 0.5436528137975382 rank 1 total_num 314 865\n",
      "checkcorrect (5055, 20, 4305) (5055, 20, 4305) real score 0.9318474560976029 Hits@1 0.35443037974683544 Hits@3 0.6645569620253164 Hits@10 0.9462025316455697 MRR 0.5429872458213857 rank 2 total_num 315 865\n",
      "checkcorrect (4022, 132, 4233) (4022, 132, 4233) real score 0.6439864337444305 Hits@1 0.35331230283911674 Hits@3 0.6624605678233438 Hits@10 0.9463722397476341 MRR 0.5416686740680059 rank 7 total_num 316 865\n",
      "checkcorrect (4175, 36, 4079) (4175, 36, 4079) real score 0.8897845774888993 Hits@1 0.3522012578616352 Hits@3 0.6635220125786163 Hits@10 0.9465408805031447 MRR 0.5415376405017543 rank 1 total_num 317 865\n",
      "checkcorrect (5884, 108, 4716) (5884, 108, 4716) real score 0.9699091821908951 Hits@1 0.3510971786833856 Hits@3 0.664576802507837 Hits@10 0.9467084639498433 MRR 0.5414074284625638 rank 1 total_num 318 865\n",
      "checkcorrect (4680, 100, 3746) (4680, 100, 3746) real score 0.922376948595047 Hits@1 0.35 Hits@3 0.665625 Hits@10 0.946875 MRR 0.540757196915285 rank 2 total_num 319 865\n",
      "checkcorrect (3975, 266, 3845) (3975, 266, 3845) real score 0.9357653141021729 Hits@1 0.35202492211838005 Hits@3 0.6666666666666666 Hits@10 0.9470404984423676 MRR 0.5421878598532437 rank 0 total_num 320 865\n",
      "checkcorrect (3857, 16, 3812) (3857, 16, 3812) real score 0.9671518355607986 Hits@1 0.35093167701863354 Hits@3 0.6645962732919255 Hits@10 0.9472049689440993 MRR 0.5409477023470446 rank 6 total_num 321 865\n",
      "checkcorrect (6135, 20, 4083) (6135, 20, 4083) real score 0.8391543209552765 Hits@1 0.3498452012383901 Hits@3 0.6625386996904025 Hits@10 0.9442724458204335 MRR 0.5395543939524998 rank 10 total_num 322 865\n",
      "checkcorrect (4264, 56, 3793) (4264, 56, 3793) real score 0.9340670838952064 Hits@1 0.3487654320987654 Hits@3 0.6635802469135802 Hits@10 0.9444444444444444 MRR 0.5394323124896835 rank 1 total_num 323 865\n",
      "checkcorrect (5400, 226, 3793) (5400, 226, 3793) real score 0.5496225729584694 Hits@1 0.3476923076923077 Hits@3 0.6615384615384615 Hits@10 0.9446153846153846 MRR 0.5382853412717664 rank 5 total_num 324 865\n",
      "checkcorrect (4476, 16, 4227) (4476, 16, 4227) real score 0.9786516457796097 Hits@1 0.3496932515337423 Hits@3 0.6625766871165644 Hits@10 0.9447852760736196 MRR 0.5397016439059021 rank 0 total_num 325 865\n",
      "checkcorrect (4315, 50, 4837) (4315, 50, 4837) real score 0.89079307615757 Hits@1 0.3516819571865443 Hits@3 0.6636085626911316 Hits@10 0.944954128440367 MRR 0.5411092841386058 rank 0 total_num 326 865\n",
      "checkcorrect (5631, 4, 3864) (5631, 4, 3864) real score 0.9288868099451065 Hits@1 0.35060975609756095 Hits@3 0.6615853658536586 Hits@10 0.9451219512195121 MRR 0.5400693168089149 rank 4 total_num 327 865\n",
      "checkcorrect (4665, 108, 4233) (4665, 108, 4233) real score 0.9730035722255707 Hits@1 0.3525835866261398 Hits@3 0.662613981762918 Hits@10 0.9452887537993921 MRR 0.5414672824113195 rank 0 total_num 328 865\n",
      "checkcorrect (3729, 16, 3834) (3729, 16, 3834) real score 0.9622884154319764 Hits@1 0.3515151515151515 Hits@3 0.6636363636363637 Hits@10 0.9454545454545454 MRR 0.5413416239797699 rank 1 total_num 329 865\n",
      "checkcorrect (5212, 108, 4664) (5212, 108, 4664) real score 0.8061387181282043 Hits@1 0.3504531722054381 Hits@3 0.6646525679758308 Hits@10 0.945619335347432 MRR 0.5412167248136679 rank 1 total_num 330 865\n",
      "checkcorrect (4755, 54, 3712) (4755, 54, 3712) real score 0.9801081091165542 Hits@1 0.35240963855421686 Hits@3 0.6656626506024096 Hits@10 0.9457831325301205 MRR 0.5425986021485665 rank 0 total_num 331 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4835, 242, 4834) (4835, 242, 4834) real score 0.0 Hits@1 0.35135135135135137 Hits@3 0.6636636636636637 Hits@10 0.9429429429429429 MRR 0.541136010417056 rank 17 total_num 332 865\n",
      "checkcorrect (4777, 34, 3746) (4777, 34, 3746) real score 0.9195588022470474 Hits@1 0.3502994011976048 Hits@3 0.6646706586826348 Hits@10 0.9431137724550899 MRR 0.5410128487092205 rank 1 total_num 333 865\n",
      "checkcorrect (5825, 54, 5296) (5825, 54, 5296) real score 0.959033939242363 Hits@1 0.3492537313432836 Hits@3 0.6656716417910448 Hits@10 0.9432835820895522 MRR 0.540890422295163 rank 1 total_num 334 865\n",
      "checkcorrect (3937, 24, 4705) (3937, 24, 4705) real score 0.9266193971037865 Hits@1 0.3482142857142857 Hits@3 0.6666666666666666 Hits@10 0.9434523809523809 MRR 0.5407687246097608 rank 1 total_num 335 865\n",
      "checkcorrect (4030, 4, 3864) (4030, 4, 3864) real score 0.9238028943538665 Hits@1 0.34718100890207715 Hits@3 0.6646884272997032 Hits@10 0.9436201780415431 MRR 0.5396586294823332 rank 5 total_num 336 865\n",
      "checkcorrect (5121, 46, 4975) (5121, 46, 4975) real score 0.8523617386817932 Hits@1 0.34615384615384615 Hits@3 0.6627218934911243 Hits@10 0.9437869822485208 MRR 0.5388016512885985 rank 3 total_num 337 865\n",
      "checkcorrect (4067, 100, 5821) (4067, 100, 5821) real score 0.9339995801448822 Hits@1 0.34513274336283184 Hits@3 0.6607669616519174 Hits@10 0.943952802359882 MRR 0.5377039079711297 rank 5 total_num 338 865\n",
      "checkcorrect (4779, 10, 4194) (4779, 10, 4194) real score 0.9353816837072373 Hits@1 0.34705882352941175 Hits@3 0.6617647058823529 Hits@10 0.9441176470588235 MRR 0.5390636023594498 rank 0 total_num 339 865\n",
      "checkcorrect (3845, 176, 3836) (3845, 176, 3836) real score 0.9825150519609451 Hits@1 0.3489736070381232 Hits@3 0.6627565982404692 Hits@10 0.9442815249266863 MRR 0.5404153220006245 rank 0 total_num 340 865\n",
      "checkcorrect (3676, 176, 3845) (3676, 176, 3845) real score 0.9828060239553451 Hits@1 0.347953216374269 Hits@3 0.6637426900584795 Hits@10 0.9444444444444444 MRR 0.5402971485444823 rank 1 total_num 341 865\n",
      "checkcorrect (4608, 352, 4771) (4608, 352, 4771) real score 0.6450382672250271 Hits@1 0.3498542274052478 Hits@3 0.6647230320699709 Hits@10 0.9446064139941691 MRR 0.5416373900939153 rank 0 total_num 342 865\n",
      "checkcorrect (5850, 54, 3712) (5850, 54, 3712) real score 0.9350854754447937 Hits@1 0.3488372093023256 Hits@3 0.6627906976744186 Hits@10 0.9447674418604651 MRR 0.5407896069831771 rank 3 total_num 343 865\n",
      "checkcorrect (4895, 348, 3947) (4895, 348, 3947) real score 0.8960350841283798 Hits@1 0.3507246376811594 Hits@3 0.663768115942029 Hits@10 0.9449275362318841 MRR 0.5421206516006173 rank 0 total_num 344 865\n",
      "checkcorrect (4754, 280, 3688) (4754, 280, 3688) real score 0.9588045924901962 Hits@1 0.35260115606936415 Hits@3 0.6647398843930635 Hits@10 0.9450867052023122 MRR 0.5434440023185345 rank 0 total_num 345 865\n",
      "checkcorrect (6111, 2, 5319) (6111, 2, 5319) real score 0.795875595510006 Hits@1 0.3515850144092219 Hits@3 0.6628242074927954 Hits@10 0.9452449567723343 MRR 0.5422381118219394 rank 7 total_num 346 865\n",
      "checkcorrect (6154, 172, 4883) (6154, 172, 4883) real score 0.9258353680372238 Hits@1 0.35344827586206895 Hits@3 0.6637931034482759 Hits@10 0.9454022988505747 MRR 0.5435535195465889 rank 0 total_num 347 865\n",
      "checkcorrect (4351, 50, 4572) (4351, 50, 4572) real score 0.9236920982599258 Hits@1 0.3524355300859599 Hits@3 0.664756446991404 Hits@10 0.9455587392550143 MRR 0.5429511694428261 rank 2 total_num 348 865\n",
      "checkcorrect (4221, 46, 4851) (4221, 46, 4851) real score 0.9427355051040649 Hits@1 0.3514285714285714 Hits@3 0.6657142857142857 Hits@10 0.9457142857142857 MRR 0.5428284518158465 rank 1 total_num 349 865\n",
      "checkcorrect (3795, 190, 3746) (3795, 190, 3746) real score 0.7939123682677746 Hits@1 0.3504273504273504 Hits@3 0.6666666666666666 Hits@10 0.9458689458689459 MRR 0.5427064334346048 rank 1 total_num 350 865\n",
      "checkcorrect (4828, 50, 4829) (4828, 50, 4829) real score 0.7876342326402664 Hits@1 0.3494318181818182 Hits@3 0.6647727272727273 Hits@10 0.9431818181818182 MRR 0.5414229182569755 rank 10 total_num 351 865\n",
      "checkcorrect (5462, 52, 5561) (5462, 52, 5561) real score 0.947023743391037 Hits@1 0.34844192634560905 Hits@3 0.6657223796033994 Hits@10 0.943342776203966 MRR 0.541305572879477 rank 1 total_num 352 865\n",
      "checkcorrect (5061, 428, 5740) (5061, 428, 5740) real score 0.40819432549178597 Hits@1 0.3474576271186441 Hits@3 0.6666666666666666 Hits@10 0.943502824858757 MRR 0.5407180806773693 rank 2 total_num 353 865\n",
      "checkcorrect (4817, 26, 5489) (4817, 26, 5489) real score 0.960078951716423 Hits@1 0.3464788732394366 Hits@3 0.6676056338028169 Hits@10 0.9436619718309859 MRR 0.5401338982904847 rank 2 total_num 354 865\n",
      "checkcorrect (3737, 50, 4846) (3737, 50, 4846) real score 0.9245339453220367 Hits@1 0.3455056179775281 Hits@3 0.6685393258426966 Hits@10 0.9438202247191011 MRR 0.539552997827122 rank 2 total_num 355 865\n",
      "checkcorrect (5046, 54, 3669) (5046, 54, 3669) real score 0.9519715934991837 Hits@1 0.3445378151260504 Hits@3 0.6694677871148459 Hits@10 0.9439775910364145 MRR 0.5394422051161216 rank 1 total_num 356 865\n",
      "checkcorrect (3826, 348, 3947) (3826, 348, 3947) real score 0.9391356647014617 Hits@1 0.3463687150837989 Hits@3 0.6703910614525139 Hits@10 0.9441340782122905 MRR 0.5407286794035068 rank 0 total_num 357 865\n",
      "checkcorrect (4265, 108, 4434) (4265, 108, 4434) real score 0.9339070752263069 Hits@1 0.34540389972144847 Hits@3 0.6713091922005571 Hits@10 0.9442896935933147 MRR 0.5401509764896623 rank 2 total_num 358 865\n",
      "checkcorrect (4544, 100, 3746) (4544, 100, 3746) real score 0.9200925886631012 Hits@1 0.34444444444444444 Hits@3 0.6694444444444444 Hits@10 0.9444444444444444 MRR 0.5393450015549688 rank 3 total_num 359 865\n",
      "checkcorrect (4693, 394, 3693) (4693, 394, 3693) real score 0.9344624191522599 Hits@1 0.34349030470914127 Hits@3 0.6703601108033241 Hits@10 0.9445983379501385 MRR 0.5387743321139116 rank 2 total_num 360 865\n",
      "checkcorrect (3845, 102, 4017) (3845, 102, 4017) real score 0.9924808472394944 Hits@1 0.3453038674033149 Hits@3 0.6712707182320442 Hits@10 0.9447513812154696 MRR 0.5400484361688456 rank 0 total_num 361 865\n",
      "checkcorrect (4779, 10, 5218) (4779, 10, 5218) real score 0.9347950667142868 Hits@1 0.34710743801652894 Hits@3 0.6721763085399449 Hits@10 0.9449035812672176 MRR 0.5413155203667276 rank 0 total_num 362 865\n",
      "checkcorrect (4521, 20, 3931) (4521, 20, 3931) real score 0.937861043214798 Hits@1 0.34615384615384615 Hits@3 0.6703296703296703 Hits@10 0.945054945054945 MRR 0.5405152030030826 rank 3 total_num 363 865\n",
      "checkcorrect (5673, 424, 4621) (5673, 424, 4621) real score 0.14697588057024405 Hits@1 0.3452054794520548 Hits@3 0.6684931506849315 Hits@10 0.9452054794520548 MRR 0.5397192709400606 rank 3 total_num 364 865\n",
      "checkcorrect (4004, 16, 4554) (4004, 16, 4554) real score 0.9783206522464752 Hits@1 0.3469945355191257 Hits@3 0.6693989071038251 Hits@10 0.9453551912568307 MRR 0.5409768685604429 rank 0 total_num 365 865\n",
      "checkcorrect (3678, 162, 4735) (3678, 162, 4735) real score 0.6453518649563194 Hits@1 0.3460490463215259 Hits@3 0.667574931880109 Hits@10 0.9455040871934605 MRR 0.540047776275537 rank 4 total_num 366 865\n",
      "checkcorrect (3740, 2, 4676) (3740, 2, 4676) real score 0.39570465087890627 Hits@1 0.3451086956521739 Hits@3 0.6657608695652174 Hits@10 0.9429347826086957 MRR 0.5387743545232355 rank 13 total_num 367 865\n",
      "checkcorrect (3700, 162, 6059) (3700, 162, 6059) real score 0.898490771651268 Hits@1 0.34417344173441733 Hits@3 0.6639566395663956 Hits@10 0.943089430894309 MRR 0.5378562668416007 rank 4 total_num 368 865\n",
      "checkcorrect (4579, 156, 3975) (4579, 156, 3975) real score 0.9377634525299072 Hits@1 0.34324324324324323 Hits@3 0.6648648648648648 Hits@10 0.9432432432432433 MRR 0.5373035021564433 rank 2 total_num 369 865\n",
      "checkcorrect (3997, 50, 5318) (3997, 50, 5318) real score 0.6607694268226623 Hits@1 0.3423180592991914 Hits@3 0.6630727762803235 Hits@10 0.9407008086253369 MRR 0.5360477745803574 rank 13 total_num 370 865\n",
      "checkcorrect (5673, 4, 3864) (5673, 4, 3864) real score 0.9273661762475967 Hits@1 0.34139784946236557 Hits@3 0.6639784946236559 Hits@10 0.9408602150537635 MRR 0.5355028432866826 rank 2 total_num 371 865\n",
      "checkcorrect (5785, 84, 3826) (5785, 84, 3826) real score 0.8865862935781479 Hits@1 0.34048257372654156 Hits@3 0.6648793565683646 Hits@10 0.9410187667560321 MRR 0.5349608338766201 rank 2 total_num 372 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4522, 50, 4663) (4522, 50, 4663) real score 0.7873334601521491 Hits@1 0.339572192513369 Hits@3 0.6631016042780749 Hits@10 0.9411764705882353 MRR 0.5341989065133136 rank 3 total_num 373 865\n",
      "checkcorrect (3906, 24, 5907) (3906, 24, 5907) real score 0.32353439182043076 Hits@1 0.33866666666666667 Hits@3 0.6613333333333333 Hits@10 0.9386666666666666 MRR 0.5329410427626113 rank 15 total_num 374 865\n",
      "checkcorrect (5683, 30, 5505) (5683, 30, 5505) real score 0.8231830596923828 Hits@1 0.3404255319148936 Hits@3 0.6622340425531915 Hits@10 0.9388297872340425 MRR 0.5341832208403704 rank 0 total_num 375 865\n",
      "checkcorrect (6026, 54, 3712) (6026, 54, 3712) real score 0.42399550378322604 Hits@1 0.3395225464190981 Hits@3 0.6604774535809018 Hits@10 0.9363395225464191 MRR 0.5329557549268112 rank 13 total_num 376 865\n",
      "checkcorrect (4869, 50, 4022) (4869, 50, 4022) real score 0.9261065542697906 Hits@1 0.3412698412698413 Hits@3 0.6613756613756614 Hits@10 0.9365079365079365 MRR 0.5341913217127192 rank 0 total_num 377 865\n",
      "checkcorrect (4632, 126, 3927) (4632, 126, 3927) real score 0.8613477289676665 Hits@1 0.3403693931398417 Hits@3 0.662269129287599 Hits@10 0.9366754617414248 MRR 0.5336613534056496 rank 2 total_num 378 865\n",
      "checkcorrect (3747, 158, 4345) (3747, 158, 4345) real score 0.9477863639593125 Hits@1 0.34210526315789475 Hits@3 0.6631578947368421 Hits@10 0.9368421052631579 MRR 0.5348885603703716 rank 0 total_num 379 865\n",
      "checkcorrect (3807, 74, 6118) (3807, 74, 6118) real score 0.8743164718151093 Hits@1 0.34120734908136485 Hits@3 0.6614173228346457 Hits@10 0.937007874015748 MRR 0.5337471205793732 rank 9 total_num 380 865\n",
      "checkcorrect (5146, 22, 4808) (5146, 22, 4808) real score 0.9693694233894348 Hits@1 0.34293193717277487 Hits@3 0.662303664921466 Hits@10 0.93717277486911 MRR 0.5349676778553434 rank 0 total_num 381 865\n",
      "checkcorrect (3745, 172, 5509) (3745, 172, 5509) real score 0.9592664182186127 Hits@1 0.34464751958224543 Hits@3 0.6631853785900783 Hits@10 0.9373368146214099 MRR 0.5361818614640762 rank 0 total_num 382 865\n",
      "checkcorrect (3854, 82, 6073) (3854, 82, 6073) real score 0.9954877436161041 Hits@1 0.3463541666666667 Hits@3 0.6640625 Hits@10 0.9375 MRR 0.5373897211998468 rank 0 total_num 383 865\n",
      "checkcorrect (4135, 108, 5194) (4135, 108, 5194) real score 0.9574747443199159 Hits@1 0.34805194805194806 Hits@3 0.6649350649350649 Hits@10 0.9376623376623376 MRR 0.5385913063395875 rank 0 total_num 384 865\n",
      "checkcorrect (4490, 46, 3972) (4490, 46, 3972) real score 0.9223052442073822 Hits@1 0.3471502590673575 Hits@3 0.6658031088082902 Hits@10 0.9378238341968912 MRR 0.5384913288620238 rank 1 total_num 385 865\n",
      "checkcorrect (3885, 82, 4641) (3885, 82, 4641) real score 0.9954877167940139 Hits@1 0.3488372093023256 Hits@3 0.6666666666666666 Hits@10 0.937984496124031 MRR 0.5396838577280134 rank 0 total_num 386 865\n",
      "checkcorrect (5314, 2, 5779) (5314, 2, 5779) real score 0.9382458597421646 Hits@1 0.35051546391752575 Hits@3 0.6675257731958762 Hits@10 0.9381443298969072 MRR 0.5408702395379927 rank 0 total_num 387 865\n",
      "checkcorrect (5610, 54, 3669) (5610, 54, 3669) real score 0.9398302733898163 Hits@1 0.3496143958868895 Hits@3 0.6683804627249358 Hits@10 0.9383033419023136 MRR 0.5403367256402944 rank 2 total_num 388 865\n",
      "checkcorrect (4178, 348, 3947) (4178, 348, 3947) real score 0.9161971807479858 Hits@1 0.35128205128205126 Hits@3 0.6692307692307692 Hits@10 0.9384615384615385 MRR 0.5415153494207039 rank 0 total_num 389 865\n",
      "checkcorrect (3745, 172, 5536) (3745, 172, 5536) real score 0.9579840570688247 Hits@1 0.35294117647058826 Hits@3 0.670076726342711 Hits@10 0.9386189258312021 MRR 0.5426879444349733 rank 0 total_num 390 865\n",
      "checkcorrect (3804, 26, 3942) (3804, 26, 3942) real score 0.9785148590803147 Hits@1 0.3520408163265306 Hits@3 0.6709183673469388 Hits@10 0.9387755102040817 MRR 0.5421538765495099 rank 2 total_num 391 865\n",
      "checkcorrect (4648, 52, 5561) (4648, 52, 5561) real score 0.9510695964097977 Hits@1 0.35368956743002544 Hits@3 0.6717557251908397 Hits@10 0.9389312977099237 MRR 0.5433188794081625 rank 0 total_num 392 865\n",
      "checkcorrect (4135, 108, 4794) (4135, 108, 4794) real score 0.9736690521240234 Hits@1 0.3553299492385787 Hits@3 0.6725888324873096 Hits@10 0.9390862944162437 MRR 0.5444779685467205 rank 0 total_num 393 865\n",
      "checkcorrect (4665, 108, 4870) (4665, 108, 4870) real score 0.9049340903759002 Hits@1 0.3569620253164557 Hits@3 0.6734177215189874 Hits@10 0.9392405063291139 MRR 0.5456311888795136 rank 0 total_num 394 865\n",
      "checkcorrect (3748, 4, 3864) (3748, 4, 3864) real score 0.9413260787725448 Hits@1 0.3560606060606061 Hits@3 0.6742424242424242 Hits@10 0.9393939393939394 MRR 0.5450950831836899 rank 2 total_num 395 865\n",
      "checkcorrect (4273, 138, 5108) (4273, 138, 5108) real score 0.9900713950395584 Hits@1 0.35768261964735515 Hits@3 0.6750629722921915 Hits@10 0.9395465994962217 MRR 0.5462409393973331 rank 0 total_num 396 865\n",
      "checkcorrect (5648, 420, 4192) (5648, 420, 4192) real score 0.8681621342897414 Hits@1 0.3592964824120603 Hits@3 0.6758793969849246 Hits@10 0.9396984924623115 MRR 0.5473810375395508 rank 0 total_num 397 865\n",
      "checkcorrect (5666, 242, 4769) (5666, 242, 4769) real score 0.4389709383249283 Hits@1 0.3583959899749373 Hits@3 0.6741854636591479 Hits@10 0.9398496240601504 MRR 0.5463671931919758 rank 6 total_num 398 865\n",
      "checkcorrect (4892, 264, 3746) (4892, 264, 3746) real score 0.7820649564266204 Hits@1 0.3575 Hits@3 0.6725 Hits@10 0.94 MRR 0.5453584180661387 rank 6 total_num 399 865\n",
      "checkcorrect (4514, 312, 4892) (4514, 312, 4892) real score 0.504451822116971 Hits@1 0.3566084788029925 Hits@3 0.6708229426433915 Hits@10 0.940149625935162 MRR 0.544497175128318 rank 4 total_num 400 865\n",
      "checkcorrect (3737, 2, 5056) (3737, 2, 5056) real score 0.9405208766460418 Hits@1 0.35572139303482586 Hits@3 0.6716417910447762 Hits@10 0.9402985074626866 MRR 0.544386485637949 rank 1 total_num 401 865\n",
      "checkcorrect (5990, 24, 5315) (5990, 24, 5315) real score 0.2662554904818535 Hits@1 0.3548387096774194 Hits@3 0.6699751861042184 Hits@10 0.9379652605459057 MRR 0.543181614778827 rank 16 total_num 402 865\n",
      "checkcorrect (4076, 20, 3931) (4076, 20, 3931) real score 0.9073624104261399 Hits@1 0.35396039603960394 Hits@3 0.6683168316831684 Hits@10 0.9381188118811881 MRR 0.5421907126206049 rank 6 total_num 403 865\n",
      "checkcorrect (5325, 2, 4227) (5325, 2, 4227) real score 0.9152646839618683 Hits@1 0.3530864197530864 Hits@3 0.6666666666666666 Hits@10 0.9382716049382716 MRR 0.5413457972808009 rank 4 total_num 404 865\n",
      "checkcorrect (4121, 358, 5349) (4121, 358, 5349) real score 0.5723958536982536 Hits@1 0.3522167487684729 Hits@3 0.6650246305418719 Hits@10 0.9384236453201971 MRR 0.5403203150214886 rank 7 total_num 405 865\n",
      "checkcorrect (3678, 162, 4986) (3678, 162, 4986) real score 0.8983332991600037 Hits@1 0.35135135135135137 Hits@3 0.6633906633906634 Hits@10 0.9385749385749386 MRR 0.5393437470309128 rank 6 total_num 406 865\n",
      "checkcorrect (4029, 50, 4496) (4029, 50, 4496) real score 0.950840350985527 Hits@1 0.35294117647058826 Hits@3 0.6642156862745098 Hits@10 0.9387254901960784 MRR 0.5404728064744645 rank 0 total_num 407 865\n",
      "checkcorrect (3742, 268, 5085) (3742, 268, 5085) real score 0.5948535531759263 Hits@1 0.35207823960880197 Hits@3 0.6625916870415648 Hits@10 0.9364303178484108 MRR 0.5393394330525785 rank 12 total_num 408 865\n",
      "checkcorrect (5512, 24, 5874) (5512, 24, 5874) real score 0.7493723496794701 Hits@1 0.35121951219512193 Hits@3 0.6609756097560976 Hits@10 0.9341463414634147 MRR 0.5382115882815308 rank 12 total_num 409 865\n",
      "checkcorrect (5034, 34, 4374) (5034, 34, 4374) real score 0.9215566843748093 Hits@1 0.35036496350364965 Hits@3 0.6618004866180048 Hits@10 0.9343065693430657 MRR 0.5381186160472692 rank 1 total_num 410 865\n",
      "checkcorrect (4620, 26, 4244) (4620, 26, 4244) real score 0.9741366982460022 Hits@1 0.34951456310679613 Hits@3 0.662621359223301 Hits@10 0.9344660194174758 MRR 0.5376215643901966 rank 2 total_num 411 865\n",
      "checkcorrect (4623, 44, 4083) (4623, 44, 4083) real score 0.940439173579216 Hits@1 0.35108958837772397 Hits@3 0.6634382566585957 Hits@10 0.9346246973365617 MRR 0.5387411247669758 rank 0 total_num 412 865\n",
      "checkcorrect (5362, 50, 5091) (5362, 50, 5091) real score 0.7907750740647317 Hits@1 0.3502415458937198 Hits@3 0.6642512077294686 Hits@10 0.9347826086956522 MRR 0.5382449706813873 rank 2 total_num 413 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4144, 4, 3864) (4144, 4, 3864) real score 0.9284281939268113 Hits@1 0.3493975903614458 Hits@3 0.6626506024096386 Hits@10 0.9349397590361446 MRR 0.5373496012741229 rank 5 total_num 414 865\n",
      "checkcorrect (4004, 16, 5564) (4004, 16, 5564) real score 0.9758335232734681 Hits@1 0.35096153846153844 Hits@3 0.6634615384615384 Hits@10 0.9350961538461539 MRR 0.5384617416556755 rank 0 total_num 415 865\n",
      "checkcorrect (4432, 74, 5367) (4432, 74, 5367) real score 0.9298357963562012 Hits@1 0.3501199040767386 Hits@3 0.6618705035971223 Hits@10 0.935251798561151 MRR 0.5377699868795228 rank 3 total_num 416 865\n",
      "checkcorrect (3729, 52, 4276) (3729, 52, 4276) real score 0.9523896902799607 Hits@1 0.3492822966507177 Hits@3 0.6602870813397129 Hits@10 0.9354066985645934 MRR 0.5369619247099545 rank 4 total_num 417 865\n",
      "checkcorrect (3832, 100, 3746) (3832, 100, 3746) real score 0.9335170894861221 Hits@1 0.34844868735083534 Hits@3 0.6610978520286396 Hits@10 0.9355608591885441 MRR 0.5368737100925083 rank 1 total_num 418 865\n",
      "checkcorrect (4961, 26, 4671) (4961, 26, 4671) real score 0.9771509796380997 Hits@1 0.35 Hits@3 0.6619047619047619 Hits@10 0.9357142857142857 MRR 0.5379763917351452 rank 0 total_num 419 865\n",
      "checkcorrect (3854, 82, 3862) (3854, 82, 3862) real score 0.995487779378891 Hits@1 0.3515439429928741 Hits@3 0.66270783847981 Hits@10 0.9358669833729216 MRR 0.5390738349851805 rank 0 total_num 420 865\n",
      "checkcorrect (3688, 138, 4649) (3688, 138, 4649) real score 0.9920892864465714 Hits@1 0.35308056872037913 Hits@3 0.6635071090047393 Hits@10 0.9360189573459715 MRR 0.540166077082372 rank 0 total_num 421 865\n",
      "checkcorrect (4101, 220, 4131) (4101, 220, 4131) real score 0.835280829668045 Hits@1 0.35224586288416077 Hits@3 0.6643026004728132 Hits@10 0.9361702127659575 MRR 0.5400711218174018 rank 1 total_num 422 865\n",
      "checkcorrect (4127, 54, 3669) (4127, 54, 3669) real score 0.9399209260940551 Hits@1 0.35377358490566035 Hits@3 0.6650943396226415 Hits@10 0.9363207547169812 MRR 0.5411558597376438 rank 0 total_num 423 865\n",
      "checkcorrect (4292, 302, 4822) (4292, 302, 4822) real score 0.8603742837905883 Hits@1 0.35294117647058826 Hits@3 0.6635294117647059 Hits@10 0.9364705882352942 MRR 0.5404707871264964 rank 3 total_num 424 865\n",
      "checkcorrect (3880, 16, 5411) (3880, 16, 5411) real score 0.9596831977367402 Hits@1 0.352112676056338 Hits@3 0.6619718309859155 Hits@10 0.9366197183098591 MRR 0.5396715599266689 rank 4 total_num 425 865\n",
      "checkcorrect (4730, 4, 3864) (4730, 4, 3864) real score 0.9200121402740479 Hits@1 0.351288056206089 Hits@3 0.6604215456674473 Hits@10 0.936768149882904 MRR 0.5387980121672779 rank 5 total_num 426 865\n",
      "checkcorrect (3845, 346, 5509) (3845, 346, 5509) real score 0.9004009395837784 Hits@1 0.352803738317757 Hits@3 0.6612149532710281 Hits@10 0.9369158878504673 MRR 0.5398755869052048 rank 0 total_num 427 865\n",
      "checkcorrect (5735, 54, 3669) (5735, 54, 3669) real score 0.9658029168844223 Hits@1 0.3543123543123543 Hits@3 0.662004662004662 Hits@10 0.9370629370629371 MRR 0.5409481379846798 rank 0 total_num 428 865\n",
      "checkcorrect (5259, 46, 5192) (5259, 46, 5192) real score 0.9305537104606629 Hits@1 0.35348837209302325 Hits@3 0.6604651162790698 Hits@10 0.9372093023255814 MRR 0.5401552353382038 rank 4 total_num 429 865\n",
      "checkcorrect (5727, 132, 5650) (5727, 132, 5650) real score 0.9685620307922362 Hits@1 0.35266821345707655 Hits@3 0.6612529002320185 Hits@10 0.9373549883990719 MRR 0.5400620677388112 rank 1 total_num 430 865\n",
      "checkcorrect (5717, 108, 6014) (5717, 108, 6014) real score 0.971251705288887 Hits@1 0.35185185185185186 Hits@3 0.6620370370370371 Hits@10 0.9375 MRR 0.5399693314708972 rank 1 total_num 431 865\n",
      "checkcorrect (5832, 54, 3669) (5832, 54, 3669) real score 0.9463934302330017 Hits@1 0.3510392609699769 Hits@3 0.6628175519630485 Hits@10 0.9376443418013857 MRR 0.5394921120756604 rank 2 total_num 432 865\n",
      "checkcorrect (4225, 52, 4276) (4225, 52, 4276) real score 0.9659327179193498 Hits@1 0.35023041474654376 Hits@3 0.6612903225806451 Hits@10 0.9377880184331797 MRR 0.5388250795593571 rank 3 total_num 433 865\n",
      "checkcorrect (3850, 46, 4623) (3850, 46, 4623) real score 0.9297607392072678 Hits@1 0.34942528735632183 Hits@3 0.6620689655172414 Hits@10 0.9379310344827586 MRR 0.5383526847404466 rank 2 total_num 434 865\n",
      "checkcorrect (3823, 60, 4245) (3823, 60, 4245) real score 0.909144127368927 Hits@1 0.3486238532110092 Hits@3 0.6628440366972477 Hits@10 0.9380733944954128 MRR 0.5382647198671887 rank 1 total_num 435 865\n",
      "checkcorrect (4766, 50, 4496) (4766, 50, 4496) real score 0.9599725574254989 Hits@1 0.3501144164759725 Hits@3 0.6636155606407322 Hits@10 0.9382151029748284 MRR 0.5393213223388885 rank 0 total_num 436 865\n",
      "checkcorrect (4195, 24, 4194) (4195, 24, 4194) real score 0.9621229499578476 Hits@1 0.3515981735159817 Hits@3 0.6643835616438356 Hits@10 0.9383561643835616 MRR 0.5403731001417678 rank 0 total_num 437 865\n",
      "checkcorrect (5705, 420, 3827) (5705, 420, 3827) real score 0.8693021208047866 Hits@1 0.3530751708428246 Hits@3 0.6651480637813212 Hits@10 0.9384965831435079 MRR 0.5414200862462285 rank 0 total_num 438 865\n",
      "checkcorrect (5353, 100, 5273) (5353, 100, 5273) real score 0.9533003628253938 Hits@1 0.35454545454545455 Hits@3 0.6659090909090909 Hits@10 0.9386363636363636 MRR 0.5424623133229416 rank 0 total_num 439 865\n",
      "checkcorrect (3920, 46, 4957) (3920, 46, 4957) real score 0.9372525572776794 Hits@1 0.35374149659863946 Hits@3 0.6643990929705216 Hits@10 0.9387755102040817 MRR 0.5416101689994579 rank 5 total_num 440 865\n",
      "checkcorrect (5200, 168, 3688) (5200, 168, 3688) real score 0.9774775296449661 Hits@1 0.3552036199095023 Hits@3 0.665158371040724 Hits@10 0.9389140271493213 MRR 0.5426472500650701 rank 0 total_num 441 865\n",
      "checkcorrect (5454, 44, 4990) (5454, 44, 4990) real score 0.6440295085310936 Hits@1 0.3544018058690745 Hits@3 0.6636568848758465 Hits@10 0.9390519187358917 MRR 0.5417985354298592 rank 5 total_num 442 865\n",
      "checkcorrect (4225, 16, 3694) (4225, 16, 3694) real score 0.9720359504222871 Hits@1 0.3536036036036036 Hits@3 0.6644144144144144 Hits@10 0.9391891891891891 MRR 0.5417043945842964 rank 1 total_num 443 865\n",
      "checkcorrect (4708, 26, 3723) (4708, 26, 3723) real score 0.9784003287553787 Hits@1 0.35280898876404493 Hits@3 0.6651685393258427 Hits@10 0.9393258426966292 MRR 0.5416106768436576 rank 1 total_num 444 865\n",
      "checkcorrect (5790, 24, 4792) (5790, 24, 4792) real score 0.8558298170566558 Hits@1 0.35201793721973096 Hits@3 0.6636771300448431 Hits@10 0.9394618834080718 MRR 0.5409568412453534 rank 3 total_num 445 865\n",
      "checkcorrect (6009, 42, 4520) (6009, 42, 4520) real score 0.7378006618469953 Hits@1 0.3512304250559284 Hits@3 0.6644295302013423 Hits@10 0.9395973154362416 MRR 0.5408652152022989 rank 1 total_num 446 865\n",
      "checkcorrect (5362, 20, 4313) (5362, 20, 4313) real score 0.9118163406848907 Hits@1 0.35044642857142855 Hits@3 0.6629464285714286 Hits@10 0.9397321428571429 MRR 0.539936944632651 rank 7 total_num 447 865\n",
      "checkcorrect (4269, 24, 3748) (4269, 24, 3748) real score 0.9556823879480363 Hits@1 0.34966592427616927 Hits@3 0.6636971046770601 Hits@10 0.9398663697104677 MRR 0.5398479982080793 rank 1 total_num 448 865\n",
      "checkcorrect (4234, 232, 3877) (4234, 232, 3877) real score 0.9654506325721741 Hits@1 0.3511111111111111 Hits@3 0.6644444444444444 Hits@10 0.94 MRR 0.5408705582120614 rank 0 total_num 449 865\n",
      "checkcorrect (4197, 50, 4626) (4197, 50, 4626) real score 0.9355341404676437 Hits@1 0.35033259423503327 Hits@3 0.6651884700665188 Hits@10 0.9401330376940134 MRR 0.5407799361317686 rank 1 total_num 450 865\n",
      "checkcorrect (4147, 50, 4098) (4147, 50, 4098) real score 0.9502903610467911 Hits@1 0.3495575221238938 Hits@3 0.665929203539823 Hits@10 0.9402654867256637 MRR 0.5406897150341319 rank 1 total_num 451 865\n",
      "checkcorrect (4293, 78, 4636) (4293, 78, 4636) real score 0.9767111033201217 Hits@1 0.3487858719646799 Hits@3 0.6666666666666666 Hits@10 0.9403973509933775 MRR 0.5402319746771765 rank 2 total_num 452 865\n",
      "checkcorrect (5035, 34, 3746) (5035, 34, 3746) real score 0.9052796483039856 Hits@1 0.34801762114537443 Hits@3 0.6651982378854625 Hits@10 0.9405286343612335 MRR 0.539592697199914 rank 3 total_num 453 865\n",
      "checkcorrect (4301, 78, 3799) (4301, 78, 3799) real score 0.9660695731639862 Hits@1 0.34725274725274724 Hits@3 0.6637362637362637 Hits@10 0.9406593406593406 MRR 0.5388463396236505 rank 4 total_num 454 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5601, 24, 3682) (5601, 24, 3682) real score 0.9348271399736405 Hits@1 0.34868421052631576 Hits@3 0.6644736842105263 Hits@10 0.9407894736842105 MRR 0.5398576415104407 rank 0 total_num 455 865\n",
      "checkcorrect (4227, 44, 5775) (4227, 44, 5775) real score 0.9390847980976105 Hits@1 0.350109409190372 Hits@3 0.6652078774617067 Hits@10 0.9409190371991247 MRR 0.5408645175684047 rank 0 total_num 456 865\n",
      "checkcorrect (6111, 46, 5319) (6111, 46, 5319) real score 0.7673858523368835 Hits@1 0.34934497816593885 Hits@3 0.6637554585152838 Hits@10 0.9410480349344978 MRR 0.5399565164383426 rank 7 total_num 457 865\n",
      "checkcorrect (4401, 4, 3864) (4401, 4, 3864) real score 0.9495918810367585 Hits@1 0.35076252723311546 Hits@3 0.664488017429194 Hits@10 0.9411764705882353 MRR 0.5409587898230086 rank 0 total_num 458 865\n",
      "checkcorrect (3726, 172, 4064) (3726, 172, 4064) real score 0.9084050297737121 Hits@1 0.35 Hits@3 0.6652173913043479 Hits@10 0.941304347826087 MRR 0.5408697489755673 rank 1 total_num 459 865\n",
      "checkcorrect (4590, 368, 4850) (4590, 368, 4850) real score 0.6414075748994946 Hits@1 0.351409978308026 Hits@3 0.665943600867679 Hits@10 0.9414316702819957 MRR 0.5418656931209564 rank 0 total_num 460 865\n",
      "checkcorrect (3858, 2, 3900) (3858, 2, 3900) real score 0.9423793643712998 Hits@1 0.35064935064935066 Hits@3 0.6666666666666666 Hits@10 0.9415584415584416 MRR 0.5414143243768275 rank 2 total_num 461 865\n",
      "checkcorrect (3974, 26, 3723) (3974, 26, 3723) real score 0.9757387161254882 Hits@1 0.34989200863930886 Hits@3 0.6673866090712743 Hits@10 0.9416846652267818 MRR 0.5409649053896926 rank 2 total_num 462 865\n",
      "checkcorrect (3916, 172, 5169) (3916, 172, 5169) real score 0.0 Hits@1 0.34913793103448276 Hits@3 0.665948275862069 Hits@10 0.9396551724137931 MRR 0.5398708718292262 rank 29 total_num 463 865\n",
      "checkcorrect (5139, 204, 5254) (5139, 204, 5254) real score 0.9531026631593704 Hits@1 0.35053763440860214 Hits@3 0.6666666666666666 Hits@10 0.9397849462365592 MRR 0.540860396836045 rank 0 total_num 464 865\n",
      "checkcorrect (5087, 24, 3850) (5087, 24, 3850) real score 0.9119433209300041 Hits@1 0.3497854077253219 Hits@3 0.6673819742489271 Hits@10 0.9399141630901288 MRR 0.5407727135810321 rank 1 total_num 465 865\n",
      "checkcorrect (3682, 50, 5601) (3682, 50, 5601) real score 0.9571415930986404 Hits@1 0.3511777301927195 Hits@3 0.6680942184154176 Hits@10 0.9400428265524625 MRR 0.5417560696547344 rank 0 total_num 466 865\n",
      "checkcorrect (4708, 58, 5633) (4708, 58, 5633) real score 0.9487768977880477 Hits@1 0.3504273504273504 Hits@3 0.6688034188034188 Hits@10 0.9401709401709402 MRR 0.5413107219275519 rank 2 total_num 467 865\n",
      "checkcorrect (4687, 56, 4088) (4687, 56, 4088) real score 0.9748311102390289 Hits@1 0.34968017057569295 Hits@3 0.6673773987206824 Hits@10 0.9402985074626866 MRR 0.5406895903242949 rank 3 total_num 468 865\n",
      "checkcorrect (3869, 16, 4808) (3869, 16, 4808) real score 0.983876895904541 Hits@1 0.35106382978723405 Hits@3 0.6680851063829787 Hits@10 0.9404255319148936 MRR 0.5416668465150942 rank 0 total_num 469 865\n",
      "checkcorrect (5063, 24, 3683) (5063, 24, 3683) real score 0.9366723001003265 Hits@1 0.3503184713375796 Hits@3 0.6687898089171974 Hits@10 0.940552016985138 MRR 0.5412245248310565 rank 2 total_num 470 865\n",
      "checkcorrect (3684, 50, 4383) (3684, 50, 4383) real score 0.9486655622720719 Hits@1 0.3495762711864407 Hits@3 0.6694915254237288 Hits@10 0.940677966101695 MRR 0.5411371847360755 rank 1 total_num 471 865\n",
      "checkcorrect (3885, 82, 6046) (3885, 82, 6046) real score 0.9954878062009811 Hits@1 0.35095137420718814 Hits@3 0.6701902748414377 Hits@10 0.9408033826638478 MRR 0.542107296396253 rank 0 total_num 472 865\n",
      "checkcorrect (5097, 26, 3723) (5097, 26, 3723) real score 0.9791006088256836 Hits@1 0.35232067510548526 Hits@3 0.6708860759493671 Hits@10 0.9409282700421941 MRR 0.5430733147582861 rank 0 total_num 473 865\n",
      "checkcorrect (5753, 120, 5844) (5753, 120, 5844) real score 0.0 Hits@1 0.35157894736842105 Hits@3 0.6694736842105263 Hits@10 0.9389473684210526 MRR 0.5419979142314606 rank 30 total_num 474 865\n",
      "checkcorrect (5143, 202, 4275) (5143, 202, 4275) real score 0.8100004881620406 Hits@1 0.35084033613445376 Hits@3 0.6701680672268907 Hits@10 0.9390756302521008 MRR 0.5415595432631872 rank 2 total_num 475 865\n",
      "checkcorrect (4128, 80, 5031) (4128, 80, 5031) real score 0.9885835081338883 Hits@1 0.3522012578616352 Hits@3 0.6708595387840671 Hits@10 0.939203354297694 MRR 0.5425206343674572 rank 0 total_num 476 865\n",
      "checkcorrect (5250, 168, 4273) (5250, 168, 4273) real score 0.9710792928934098 Hits@1 0.35355648535564854 Hits@3 0.6715481171548117 Hits@10 0.9393305439330544 MRR 0.5434777041700358 rank 0 total_num 477 865\n",
      "checkcorrect (4178, 348, 3811) (4178, 348, 3811) real score 0.8944263666868211 Hits@1 0.35490605427974947 Hits@3 0.6722338204592901 Hits@10 0.9394572025052192 MRR 0.5444307778565285 rank 0 total_num 478 865\n",
      "checkcorrect (3908, 50, 3772) (3908, 50, 3772) real score 0.8742498159408569 Hits@1 0.3541666666666667 Hits@3 0.6708333333333333 Hits@10 0.9395833333333333 MRR 0.5435941661169464 rank 6 total_num 479 865\n",
      "checkcorrect (3714, 120, 4318) (3714, 120, 4318) real score 0.9361494570970534 Hits@1 0.35550935550935553 Hits@3 0.6715176715176715 Hits@10 0.9397089397089398 MRR 0.544543034794458 rank 0 total_num 480 865\n",
      "checkcorrect (5831, 20, 6015) (5831, 20, 6015) real score 0.9789143860340118 Hits@1 0.35684647302904565 Hits@3 0.6721991701244814 Hits@10 0.9398340248962656 MRR 0.54548796625754 rank 0 total_num 481 865\n",
      "checkcorrect (4524, 58, 3917) (4524, 58, 3917) real score 0.6796599715948105 Hits@1 0.35610766045548653 Hits@3 0.6708074534161491 Hits@10 0.937888198757764 MRR 0.5445064768272523 rank 13 total_num 482 865\n",
      "checkcorrect (3753, 348, 3811) (3753, 348, 3811) real score 0.8985259294509887 Hits@1 0.3574380165289256 Hits@3 0.6714876033057852 Hits@10 0.9380165289256198 MRR 0.5454475791478571 rank 0 total_num 483 865\n",
      "checkcorrect (4268, 46, 5326) (4268, 46, 5326) real score 0.9411042690277099 Hits@1 0.35670103092783506 Hits@3 0.6721649484536083 Hits@10 0.9381443298969072 MRR 0.5450102301874148 rank 2 total_num 484 865\n",
      "checkcorrect (5753, 120, 5880) (5753, 120, 5880) real score 0.0 Hits@1 0.3559670781893004 Hits@3 0.6707818930041153 Hits@10 0.9362139917695473 MRR 0.5439916906191279 rank 19 total_num 485 865\n",
      "checkcorrect (4611, 46, 5400) (4611, 46, 5400) real score 0.9379670470952988 Hits@1 0.35523613963039014 Hits@3 0.6714579055441479 Hits@10 0.9363449691991786 MRR 0.5435591272571447 rank 2 total_num 486 865\n",
      "checkcorrect (5733, 362, 5994) (5733, 362, 5994) real score 0.9675535172224045 Hits@1 0.35655737704918034 Hits@3 0.6721311475409836 Hits@10 0.9364754098360656 MRR 0.5444944569144047 rank 0 total_num 487 865\n",
      "checkcorrect (3745, 172, 5229) (3745, 172, 5229) real score 0.9569242089986801 Hits@1 0.3558282208588957 Hits@3 0.6728016359918201 Hits@10 0.9366053169734151 MRR 0.5444034662049683 rank 1 total_num 488 865\n",
      "checkcorrect (3923, 366, 4959) (3923, 366, 4959) real score 0.8518639147281647 Hits@1 0.3551020408163265 Hits@3 0.6714285714285714 Hits@10 0.936734693877551 MRR 0.5438026428045499 rank 3 total_num 489 865\n",
      "checkcorrect (5270, 86, 3736) (5270, 86, 3736) real score 0.9045751392841339 Hits@1 0.3543788187372709 Hits@3 0.670061099796334 Hits@10 0.9368635437881874 MRR 0.5431024337560681 rank 4 total_num 490 865\n",
      "checkcorrect (3828, 218, 4574) (3828, 218, 4574) real score 0.9769043505191803 Hits@1 0.3556910569105691 Hits@3 0.6707317073170732 Hits@10 0.9369918699186992 MRR 0.5440310873459948 rank 0 total_num 491 865\n",
      "checkcorrect (4583, 10, 4588) (4583, 10, 4588) real score 0.9343828886747361 Hits@1 0.35496957403651114 Hits@3 0.6713995943204868 Hits@10 0.9371196754563894 MRR 0.5439417747955974 rank 1 total_num 492 865\n",
      "checkcorrect (4797, 20, 4313) (4797, 20, 4313) real score 0.9330636471509933 Hits@1 0.354251012145749 Hits@3 0.6720647773279352 Hits@10 0.937246963562753 MRR 0.5435154419181433 rank 2 total_num 493 865\n",
      "checkcorrect (4084, 10, 6159) (4084, 10, 6159) real score 0.4434753775596619 Hits@1 0.35353535353535354 Hits@3 0.6707070707070707 Hits@10 0.9353535353535354 MRR 0.5425728310797695 rank 12 total_num 494 865\n",
      "checkcorrect (4682, 50, 4252) (4682, 50, 4252) real score 0.9414981633424759 Hits@1 0.3528225806451613 Hits@3 0.6713709677419355 Hits@10 0.9354838709677419 MRR 0.5421509772536678 rank 2 total_num 495 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4000, 348, 3811) (4000, 348, 3811) real score 0.8955691576004028 Hits@1 0.35412474849094566 Hits@3 0.6720321931589537 Hits@10 0.9356136820925554 MRR 0.5430722026515477 rank 0 total_num 496 865\n",
      "checkcorrect (4276, 20, 4142) (4276, 20, 4142) real score 0.9764588475227356 Hits@1 0.35542168674698793 Hits@3 0.6726907630522089 Hits@10 0.9357429718875502 MRR 0.5439897283490346 rank 0 total_num 497 865\n",
      "checkcorrect (4056, 120, 5773) (4056, 120, 5773) real score 0.7666594415903092 Hits@1 0.35470941883767537 Hits@3 0.6733466933867736 Hits@10 0.935871743486974 MRR 0.5435675712447946 rank 2 total_num 498 865\n",
      "checkcorrect (3812, 44, 3729) (3812, 44, 3729) real score 0.9170201301574707 Hits@1 0.354 Hits@3 0.674 Hits@10 0.936 MRR 0.5431471027689716 rank 2 total_num 499 865\n",
      "checkcorrect (4254, 214, 5572) (4254, 214, 5572) real score 0.8651891082525254 Hits@1 0.35528942115768464 Hits@3 0.6746506986027944 Hits@10 0.936127744510978 MRR 0.5440589847993729 rank 0 total_num 500 865\n",
      "checkcorrect (4261, 230, 5729) (4261, 230, 5729) real score 0.9250385463237762 Hits@1 0.3565737051792829 Hits@3 0.6752988047808764 Hits@10 0.9362549800796812 MRR 0.5449672338336371 rank 0 total_num 501 865\n",
      "checkcorrect (3944, 120, 5602) (3944, 120, 5602) real score 0.4250782787799835 Hits@1 0.3558648111332008 Hits@3 0.6739562624254473 Hits@10 0.9363817097415507 MRR 0.5441046968103318 rank 8 total_num 502 865\n",
      "checkcorrect (4051, 26, 4671) (4051, 26, 4671) real score 0.9791148871183395 Hits@1 0.35714285714285715 Hits@3 0.6746031746031746 Hits@10 0.9365079365079365 MRR 0.5450092509833272 rank 0 total_num 503 865\n",
      "checkcorrect (4164, 50, 3841) (4164, 50, 3841) real score 0.9023913234472274 Hits@1 0.3564356435643564 Hits@3 0.6732673267326733 Hits@10 0.9366336633663367 MRR 0.5444250742487068 rank 3 total_num 504 865\n",
      "checkcorrect (4149, 20, 3851) (4149, 20, 3851) real score 0.9626693934202195 Hits@1 0.3557312252964427 Hits@3 0.6739130434782609 Hits@10 0.9367588932806324 MRR 0.544007896895119 rank 2 total_num 505 865\n",
      "checkcorrect (3785, 16, 4001) (3785, 16, 4001) real score 0.9673210382461548 Hits@1 0.35502958579881655 Hits@3 0.6745562130177515 Hits@10 0.9368836291913215 MRR 0.5435923652115652 rank 2 total_num 506 865\n",
      "checkcorrect (4517, 50, 4249) (4517, 50, 4249) real score 0.9102201193571091 Hits@1 0.3543307086614173 Hits@3 0.6732283464566929 Hits@10 0.937007874015748 MRR 0.5428503854900202 rank 5 total_num 507 865\n",
      "checkcorrect (5080, 110, 4360) (5080, 110, 4360) real score 0.950789812207222 Hits@1 0.35363457760314343 Hits@3 0.6738703339882122 Hits@10 0.93713163064833 MRR 0.5427662000568374 rank 1 total_num 508 865\n",
      "checkcorrect (4437, 78, 3799) (4437, 78, 3799) real score 0.9808194100856782 Hits@1 0.35294117647058826 Hits@3 0.6745098039215687 Hits@10 0.9372549019607843 MRR 0.5426823447626082 rank 1 total_num 509 865\n",
      "checkcorrect (4888, 56, 3826) (4888, 56, 3826) real score 0.9788106471300125 Hits@1 0.3522504892367906 Hits@3 0.675146771037182 Hits@10 0.9373776908023483 MRR 0.5425988176691394 rank 1 total_num 510 865\n",
      "checkcorrect (3761, 276, 4427) (3761, 276, 4427) real score 0.9451095759868622 Hits@1 0.3515625 Hits@3 0.67578125 Hits@10 0.9375 MRR 0.542190096020046 rank 2 total_num 511 865\n",
      "checkcorrect (4468, 120, 4288) (4468, 120, 4288) real score 0.8511890217661857 Hits@1 0.35282651072124754 Hits@3 0.6764132553606238 Hits@10 0.9376218323586745 MRR 0.5430825129868685 rank 0 total_num 512 865\n",
      "checkcorrect (3831, 96, 4720) (3831, 96, 4720) real score 0.9213439971208572 Hits@1 0.3521400778210117 Hits@3 0.6750972762645915 Hits@10 0.9377431906614786 MRR 0.5425123135452598 rank 3 total_num 513 865\n",
      "checkcorrect (4097, 54, 3669) (4097, 54, 3669) real score 0.9137683004140854 Hits@1 0.35145631067961164 Hits@3 0.6737864077669903 Hits@10 0.9378640776699029 MRR 0.5417016100238127 rank 7 total_num 514 865\n",
      "checkcorrect (3705, 24, 4531) (3705, 24, 4531) real score 0.8842113748192787 Hits@1 0.3507751937984496 Hits@3 0.6744186046511628 Hits@10 0.937984496124031 MRR 0.5416207929501231 rank 1 total_num 515 865\n",
      "checkcorrect (4459, 34, 5118) (4459, 34, 5118) real score 0.8961790382862092 Hits@1 0.35009671179883944 Hits@3 0.6731141199226306 Hits@10 0.9381044487427466 MRR 0.5408149500237206 rank 7 total_num 516 865\n",
      "checkcorrect (5883, 60, 5414) (5883, 60, 5414) real score 0.9173795342445374 Hits@1 0.34942084942084944 Hits@3 0.6737451737451737 Hits@10 0.9382239382239382 MRR 0.5404144063621561 rank 2 total_num 517 865\n",
      "checkcorrect (4266, 2, 4310) (4266, 2, 4310) real score 0.9330343425273895 Hits@1 0.348747591522158 Hits@3 0.6724470134874759 Hits@10 0.9383429672447013 MRR 0.5398548410319786 rank 3 total_num 518 865\n",
      "checkcorrect (4621, 348, 3947) (4621, 348, 3947) real score 0.9287462562322617 Hits@1 0.35 Hits@3 0.6730769230769231 Hits@10 0.9384615384615385 MRR 0.5407397355684554 rank 0 total_num 519 865\n",
      "checkcorrect (3734, 16, 4594) (3734, 16, 4594) real score 0.9692952066659928 Hits@1 0.3493282149712092 Hits@3 0.6717850287907869 Hits@10 0.9385796545105566 MRR 0.5400217450331354 rank 5 total_num 520 865\n",
      "checkcorrect (4678, 56, 3752) (4678, 56, 3752) real score 0.9771846860647202 Hits@1 0.3505747126436782 Hits@3 0.6724137931034483 Hits@10 0.9386973180076629 MRR 0.5409029294296236 rank 0 total_num 521 865\n",
      "checkcorrect (4202, 92, 4378) (4202, 92, 4378) real score 0.8354104638099671 Hits@1 0.34990439770554493 Hits@3 0.6730401529636711 Hits@10 0.9388145315487572 MRR 0.5408247211515556 rank 1 total_num 522 865\n",
      "checkcorrect (4522, 248, 4664) (4522, 248, 4664) real score 0.7952123701572418 Hits@1 0.34923664122137404 Hits@3 0.6717557251908397 Hits@10 0.9389312977099237 MRR 0.5400311625234037 rank 7 total_num 523 865\n",
      "checkcorrect (5552, 170, 5553) (5552, 170, 5553) real score 0.8150521963834763 Hits@1 0.3485714285714286 Hits@3 0.6723809523809524 Hits@10 0.939047619047619 MRR 0.5399549126900258 rank 1 total_num 524 865\n",
      "checkcorrect (4669, 248, 5375) (4669, 248, 5375) real score 0.8441921204328537 Hits@1 0.34790874524714827 Hits@3 0.6711026615969582 Hits@10 0.9391634980988594 MRR 0.539403667608866 rank 3 total_num 525 865\n",
      "checkcorrect (5702, 54, 3669) (5702, 54, 3669) real score 0.9832356840372085 Hits@1 0.349146110056926 Hits@3 0.6717267552182163 Hits@10 0.9392789373814042 MRR 0.5402776644445229 rank 0 total_num 526 865\n",
      "checkcorrect (4645, 20, 3785) (4645, 20, 3785) real score 0.9380267024040223 Hits@1 0.3484848484848485 Hits@3 0.6723484848484849 Hits@10 0.9393939393939394 MRR 0.5398857244234789 rank 2 total_num 527 865\n",
      "checkcorrect (4215, 220, 3761) (4215, 220, 3761) real score 0.8696490794420242 Hits@1 0.34782608695652173 Hits@3 0.6729678638941399 Hits@10 0.9395085066162571 MRR 0.539810326078633 rank 1 total_num 528 865\n",
      "checkcorrect (3997, 34, 3879) (3997, 34, 3879) real score 0.9178706347942353 Hits@1 0.3471698113207547 Hits@3 0.6735849056603773 Hits@10 0.939622641509434 MRR 0.5397352122558431 rank 1 total_num 529 865\n",
      "checkcorrect (3708, 76, 3919) (3708, 76, 3919) real score 0.9779591709375381 Hits@1 0.3483992467043315 Hits@3 0.6741996233521658 Hits@10 0.9397363465160076 MRR 0.5406020009333274 rank 0 total_num 530 865\n",
      "checkcorrect (3938, 50, 4946) (3938, 50, 4946) real score 0.9610778152942657 Hits@1 0.34962406015037595 Hits@3 0.674812030075188 Hits@10 0.9398496240601504 MRR 0.541465531006761 rank 0 total_num 531 865\n",
      "checkcorrect (4572, 2, 4196) (4572, 2, 4196) real score 0.9298914521932602 Hits@1 0.34896810506566606 Hits@3 0.6735459662288931 Hits@10 0.9399624765478424 MRR 0.540918691361345 rank 3 total_num 532 865\n",
      "checkcorrect (4435, 54, 3669) (4435, 54, 3669) real score 0.9143206506967545 Hits@1 0.34831460674157305 Hits@3 0.6722846441947565 Hits@10 0.9400749063670412 MRR 0.5403738998044885 rank 3 total_num 533 865\n",
      "checkcorrect (4476, 16, 3923) (4476, 16, 3923) real score 0.9784079700708389 Hits@1 0.34766355140186916 Hits@3 0.6728971962616822 Hits@10 0.9401869158878504 MRR 0.5402984345712091 rank 1 total_num 534 865\n",
      "checkcorrect (4573, 24, 4007) (4573, 24, 4007) real score 0.7419540971517563 Hits@1 0.34701492537313433 Hits@3 0.6716417910447762 Hits@10 0.9384328358208955 MRR 0.5394458877405414 rank 11 total_num 535 865\n",
      "checkcorrect (3706, 56, 3753) (3706, 56, 3753) real score 0.9570858597755432 Hits@1 0.34823091247672255 Hits@3 0.6722532588454376 Hits@10 0.9385474860335196 MRR 0.5403035304076912 rank 0 total_num 536 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3729, 52, 5164) (3729, 52, 5164) real score 0.9641693234443665 Hits@1 0.3475836431226766 Hits@3 0.6728624535315985 Hits@10 0.9386617100371747 MRR 0.5402286167823981 rank 1 total_num 537 865\n",
      "checkcorrect (4618, 16, 5929) (4618, 16, 5929) real score 0.9367982983589171 Hits@1 0.3469387755102041 Hits@3 0.6716141001855288 Hits@10 0.9387755102040817 MRR 0.5395355519398829 rank 5 total_num 538 865\n",
      "checkcorrect (4357, 46, 4893) (4357, 46, 4893) real score 0.9263904750347137 Hits@1 0.34629629629629627 Hits@3 0.6703703703703704 Hits@10 0.9388888888888889 MRR 0.538999374991846 rank 3 total_num 539 865\n",
      "checkcorrect (3845, 102, 3956) (3845, 102, 3956) real score 0.992766335606575 Hits@1 0.34750462107208874 Hits@3 0.6709796672828097 Hits@10 0.9390018484288355 MRR 0.53985150184029 rank 0 total_num 540 865\n",
      "checkcorrect (4414, 358, 3949) (4414, 358, 3949) real score 0.9055519223213195 Hits@1 0.34686346863468637 Hits@3 0.6715867158671587 Hits@10 0.9391143911439115 MRR 0.5397779750841271 rank 1 total_num 541 865\n",
      "checkcorrect (4669, 248, 3681) (4669, 248, 3681) real score 0.8464677423238754 Hits@1 0.3462246777163904 Hits@3 0.6703499079189686 Hits@10 0.9392265193370166 MRR 0.5391522329569003 rank 4 total_num 542 865\n",
      "checkcorrect (4225, 16, 4955) (4225, 16, 4955) real score 0.9822937816381454 Hits@1 0.34558823529411764 Hits@3 0.6709558823529411 Hits@10 0.9393382352941176 MRR 0.5390802619404353 rank 1 total_num 543 865\n",
      "checkcorrect (4977, 74, 4490) (4977, 74, 4490) real score 0.9121784567832947 Hits@1 0.344954128440367 Hits@3 0.671559633027523 Hits@10 0.9394495412844037 MRR 0.5390085550377923 rank 1 total_num 544 865\n",
      "checkcorrect (4938, 50, 5034) (4938, 50, 5034) real score 0.961631590127945 Hits@1 0.34615384615384615 Hits@3 0.6721611721611722 Hits@10 0.9395604395604396 MRR 0.5398528617135473 rank 0 total_num 545 865\n",
      "checkcorrect (4043, 46, 4957) (4043, 46, 4957) real score 0.9381611615419387 Hits@1 0.34552102376599636 Hits@3 0.6727605118829981 Hits@10 0.9396709323583181 MRR 0.5397800045623342 rank 1 total_num 546 865\n",
      "checkcorrect (5658, 20, 3729) (5658, 20, 3729) real score 0.953548514842987 Hits@1 0.3448905109489051 Hits@3 0.6733576642335767 Hits@10 0.9397810218978102 MRR 0.5397074133131329 rank 1 total_num 547 865\n",
      "checkcorrect (4168, 86, 4197) (4168, 86, 4197) real score 0.8009850084781647 Hits@1 0.3442622950819672 Hits@3 0.6721311475409836 Hits@10 0.9398907103825137 MRR 0.5389845530755082 rank 6 total_num 548 865\n",
      "checkcorrect (4570, 132, 5346) (4570, 132, 5346) real score 0.39938184022903445 Hits@1 0.34363636363636363 Hits@3 0.6709090909090909 Hits@10 0.9381818181818182 MRR 0.5381344512906956 rank 13 total_num 549 865\n",
      "checkcorrect (3755, 50, 3754) (3755, 50, 3754) real score 0.974131190776825 Hits@1 0.3448275862068966 Hits@3 0.6715063520871143 Hits@10 0.9382940108892922 MRR 0.5389726827765564 rank 0 total_num 550 865\n",
      "checkcorrect (4005, 56, 4187) (4005, 56, 4187) real score 0.9571959912776946 Hits@1 0.34601449275362317 Hits@3 0.6721014492753623 Hits@10 0.9384057971014492 MRR 0.5398078771918162 rank 0 total_num 551 865\n",
      "checkcorrect (4875, 2, 4243) (4875, 2, 4243) real score 0.911862275004387 Hits@1 0.3453887884267631 Hits@3 0.6708860759493671 Hits@10 0.9385171790235082 MRR 0.539283812314435 rank 3 total_num 552 865\n",
      "checkcorrect (3844, 102, 4258) (3844, 102, 4258) real score 0.9930373907089234 Hits@1 0.34657039711191334 Hits@3 0.6714801444043321 Hits@10 0.9386281588447654 MRR 0.5401154299817374 rank 0 total_num 553 865\n",
      "checkcorrect (4207, 30, 4088) (4207, 30, 4088) real score 0.8327252820134163 Hits@1 0.34594594594594597 Hits@3 0.6720720720720721 Hits@10 0.9387387387387387 MRR 0.5400431499277163 rank 1 total_num 554 865\n",
      "checkcorrect (3809, 102, 3808) (3809, 102, 3808) real score 0.9928034454584121 Hits@1 0.3471223021582734 Hits@3 0.6726618705035972 Hits@10 0.9388489208633094 MRR 0.5408704104494291 rank 0 total_num 555 865\n",
      "checkcorrect (4773, 78, 3799) (4773, 78, 3799) real score 0.9734722733497619 Hits@1 0.3464991023339318 Hits@3 0.6714542190305206 Hits@10 0.9389587073608617 MRR 0.5402584348471859 rank 4 total_num 556 865\n",
      "checkcorrect (4195, 174, 4779) (4195, 174, 4779) real score 0.7927103906869888 Hits@1 0.34767025089605735 Hits@3 0.6720430107526881 Hits@10 0.9390681003584229 MRR 0.5410823444621551 rank 0 total_num 557 865\n",
      "checkcorrect (4075, 172, 5421) (4075, 172, 5421) real score 0.9591317176818848 Hits@1 0.3488372093023256 Hits@3 0.6726296958855098 Hits@10 0.9391771019677997 MRR 0.5419033062788596 rank 0 total_num 558 865\n",
      "checkcorrect (3736, 34, 3746) (3736, 34, 3746) real score 0.896007290482521 Hits@1 0.3482142857142857 Hits@3 0.6714285714285714 Hits@10 0.9392857142857143 MRR 0.541158836089076 rank 7 total_num 559 865\n",
      "checkcorrect (3896, 52, 3898) (3896, 52, 3898) real score 0.9583145737648011 Hits@1 0.34759358288770054 Hits@3 0.6720142602495544 Hits@10 0.9393939393939394 MRR 0.5410854691798263 rank 1 total_num 560 865\n",
      "checkcorrect (5036, 26, 3723) (5036, 26, 3723) real score 0.9774951964616776 Hits@1 0.3469750889679715 Hits@3 0.6708185053380783 Hits@10 0.9395017793594306 MRR 0.540567523505129 rank 3 total_num 561 865\n",
      "checkcorrect (3675, 54, 3669) (3675, 54, 3669) real score 0.9477145791053772 Hits@1 0.3481349911190053 Hits@3 0.6714031971580817 Hits@10 0.9396092362344582 MRR 0.5413835669802533 rank 0 total_num 562 865\n",
      "checkcorrect (3804, 230, 3805) (3804, 230, 3805) real score 0.8479337245225906 Hits@1 0.3475177304964539 Hits@3 0.6702127659574468 Hits@10 0.9397163120567376 MRR 0.5407782769678768 rank 4 total_num 563 865\n",
      "checkcorrect (4666, 132, 4815) (4666, 132, 4815) real score 0.750392159819603 Hits@1 0.34690265486725663 Hits@3 0.6690265486725664 Hits@10 0.9398230088495575 MRR 0.5399981384245709 rank 9 total_num 564 865\n",
      "checkcorrect (4305, 16, 4122) (4305, 16, 4122) real score 0.9558630466461182 Hits@1 0.3462897526501767 Hits@3 0.6678445229681979 Hits@10 0.9399293286219081 MRR 0.5392964758882327 rank 6 total_num 565 865\n",
      "checkcorrect (5270, 268, 4562) (5270, 268, 4562) real score 0.8091191887855529 Hits@1 0.3474426807760141 Hits@3 0.6684303350970018 Hits@10 0.9400352733686067 MRR 0.5401090041494528 rank 0 total_num 566 865\n",
      "checkcorrect (5046, 100, 3746) (5046, 100, 3746) real score 0.9287355303764344 Hits@1 0.34683098591549294 Hits@3 0.6690140845070423 Hits@10 0.9401408450704225 MRR 0.5397449624754808 rank 2 total_num 567 865\n",
      "checkcorrect (3719, 80, 4922) (3719, 80, 4922) real score 0.6692702800035477 Hits@1 0.3462214411247803 Hits@3 0.6695957820738138 Hits@10 0.9402460456942003 MRR 0.5393822003855999 rank 2 total_num 568 865\n",
      "checkcorrect (4145, 54, 3669) (4145, 54, 3669) real score 0.9584280788898468 Hits@1 0.3456140350877193 Hits@3 0.6701754385964912 Hits@10 0.9403508771929825 MRR 0.539313108805976 rank 1 total_num 569 865\n",
      "checkcorrect (4252, 46, 5451) (4252, 46, 5451) real score 0.9336892575025558 Hits@1 0.3450087565674256 Hits@3 0.670753064798599 Hits@10 0.9404553415061296 MRR 0.5389523736475301 rank 2 total_num 570 865\n",
      "checkcorrect (4785, 16, 4844) (4785, 16, 4844) real score 0.9746410578489304 Hits@1 0.34440559440559443 Hits@3 0.6713286713286714 Hits@10 0.9405594405594405 MRR 0.5388842750922023 rank 1 total_num 571 865\n",
      "checkcorrect (3921, 26, 4671) (3921, 26, 4671) real score 0.9650154739618302 Hits@1 0.343804537521815 Hits@3 0.6701570680628273 Hits@10 0.9406631762652705 MRR 0.5381931282645669 rank 6 total_num 572 865\n",
      "checkcorrect (3967, 56, 3752) (3967, 56, 3752) real score 0.9448433548212052 Hits@1 0.343205574912892 Hits@3 0.6707317073170732 Hits@10 0.9407665505226481 MRR 0.5381265897135834 rank 1 total_num 573 865\n",
      "checkcorrect (3785, 16, 5177) (3785, 16, 5177) real score 0.9768343091011047 Hits@1 0.3443478260869565 Hits@3 0.671304347826087 Hits@10 0.9408695652173913 MRR 0.5389298478184293 rank 0 total_num 574 865\n",
      "checkcorrect (3857, 16, 3871) (3857, 16, 3871) real score 0.973113751411438 Hits@1 0.34375 Hits@3 0.671875 Hits@10 0.9409722222222222 MRR 0.538572909425226 rank 2 total_num 575 865\n",
      "checkcorrect (3908, 20, 4134) (3908, 20, 4134) real score 0.9648138731718063 Hits@1 0.34488734835355284 Hits@3 0.6724436741767764 Hits@10 0.9410745233968805 MRR 0.5393726097555115 rank 0 total_num 576 865\n",
      "checkcorrect (4305, 16, 4005) (4305, 16, 4005) real score 0.9630117535591125 Hits@1 0.34429065743944637 Hits@3 0.671280276816609 Hits@10 0.9411764705882353 MRR 0.5388719651019553 rank 3 total_num 577 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3759, 20, 3758) (3759, 20, 3758) real score 0.9684743613004685 Hits@1 0.3436960276338515 Hits@3 0.6718480138169257 Hits@10 0.9412780656303973 MRR 0.5388048287200866 rank 1 total_num 578 865\n",
      "checkcorrect (5735, 86, 5282) (5735, 86, 5282) real score 0.7707959726452828 Hits@1 0.3431034482758621 Hits@3 0.6706896551724137 Hits@10 0.9413793103448276 MRR 0.5383068893602244 rank 3 total_num 579 865\n",
      "checkcorrect (5959, 296, 5936) (5959, 296, 5936) real score 0.3754450500011444 Hits@1 0.3442340791738382 Hits@3 0.6712564543889845 Hits@10 0.9414802065404475 MRR 0.5391015418742343 rank 0 total_num 580 865\n",
      "checkcorrect (4437, 56, 3752) (4437, 56, 3752) real score 0.9068177372217179 Hits@1 0.3436426116838488 Hits@3 0.6701030927835051 Hits@10 0.9415807560137457 MRR 0.5386048038297769 rank 3 total_num 581 865\n",
      "checkcorrect (3752, 348, 4331) (3752, 348, 4331) real score 0.9346229374408722 Hits@1 0.34476843910806176 Hits@3 0.6706689536878216 Hits@10 0.9416809605488851 MRR 0.5393962192606007 rank 0 total_num 582 865\n",
      "checkcorrect (3835, 284, 3795) (3835, 284, 3795) real score 0.1769590713083744 Hits@1 0.3441780821917808 Hits@3 0.6695205479452054 Hits@10 0.940068493150685 MRR 0.5386282618490398 rank 10 total_num 583 865\n",
      "checkcorrect (3676, 176, 3801) (3676, 176, 3801) real score 0.9828075796365738 Hits@1 0.3452991452991453 Hits@3 0.67008547008547 Hits@10 0.9401709401709402 MRR 0.5394169314869046 rank 0 total_num 584 865\n",
      "checkcorrect (3858, 24, 4012) (3858, 24, 4012) real score 0.9554154515266419 Hits@1 0.3447098976109215 Hits@3 0.6706484641638225 Hits@10 0.9402730375426621 MRR 0.5393496670987017 rank 1 total_num 585 865\n",
      "checkcorrect (4349, 50, 4090) (4349, 50, 4090) real score 0.9593290954828262 Hits@1 0.3441226575809199 Hits@3 0.6712095400340715 Hits@10 0.9403747870528109 MRR 0.5389987023052343 rank 2 total_num 586 865\n",
      "checkcorrect (4301, 26, 3723) (4301, 26, 3723) real score 0.9795619964599609 Hits@1 0.34523809523809523 Hits@3 0.6717687074829932 Hits@10 0.9404761904761905 MRR 0.5397827181176403 rank 0 total_num 587 865\n",
      "checkcorrect (4882, 20, 3758) (4882, 20, 3758) real score 0.9572647601366043 Hits@1 0.34465195246179964 Hits@3 0.6723259762308998 Hits@10 0.9405772495755518 MRR 0.5397151753025 rank 1 total_num 588 865\n",
      "checkcorrect (4263, 50, 5255) (4263, 50, 5255) real score 0.8200839668512345 Hits@1 0.3440677966101695 Hits@3 0.6711864406779661 Hits@10 0.940677966101695 MRR 0.5391393868697839 rank 4 total_num 589 865\n",
      "checkcorrect (3956, 102, 4060) (3956, 102, 4060) real score 0.9926747858524323 Hits@1 0.34517766497461927 Hits@3 0.6717428087986463 Hits@10 0.9407783417935702 MRR 0.539919184861544 rank 0 total_num 590 865\n",
      "checkcorrect (5164, 20, 3729) (5164, 20, 3729) real score 0.9722856223583222 Hits@1 0.34459459459459457 Hits@3 0.6722972972972973 Hits@10 0.9408783783783784 MRR 0.5398517538060347 rank 1 total_num 591 865\n",
      "checkcorrect (4681, 236, 3746) (4681, 236, 3746) real score 0.7661011770367623 Hits@1 0.3440134907251265 Hits@3 0.6711635750421585 Hits@10 0.9409780775716695 MRR 0.5392224366270476 rank 5 total_num 592 865\n",
      "checkcorrect (5684, 102, 4060) (5684, 102, 4060) real score 0.9923692077398301 Hits@1 0.3434343434343434 Hits@3 0.6717171717171717 Hits@10 0.9410774410774411 MRR 0.539156405588955 rank 1 total_num 593 865\n",
      "checkcorrect (4087, 128, 4086) (4087, 128, 4086) real score 0.9180310130119325 Hits@1 0.3445378151260504 Hits@3 0.6722689075630253 Hits@10 0.9411764705882353 MRR 0.5399309326383852 rank 0 total_num 594 865\n",
      "checkcorrect (4607, 74, 4908) (4607, 74, 4908) real score 0.9560293614864349 Hits@1 0.34563758389261745 Hits@3 0.6728187919463087 Hits@10 0.9412751677852349 MRR 0.540702860603757 rank 0 total_num 595 865\n",
      "checkcorrect (5211, 348, 3811) (5211, 348, 3811) real score 0.9246904671192169 Hits@1 0.34673366834170855 Hits@3 0.6733668341708543 Hits@10 0.9413735343383585 MRR 0.5414722025457943 rank 0 total_num 596 865\n",
      "checkcorrect (3726, 172, 5194) (3726, 172, 5194) real score 0.9500524699687958 Hits@1 0.34615384615384615 Hits@3 0.6739130434782609 Hits@10 0.9414715719063546 MRR 0.5414028510365204 rank 1 total_num 597 865\n",
      "checkcorrect (3700, 162, 5332) (3700, 162, 5332) real score 0.9559946656227112 Hits@1 0.34724540901502504 Hits@3 0.674457429048414 Hits@10 0.9415692821368948 MRR 0.542168455625775 rank 0 total_num 598 865\n",
      "checkcorrect (4572, 2, 4936) (4572, 2, 4936) real score 0.9424690902233124 Hits@1 0.3466666666666667 Hits@3 0.675 Hits@10 0.9416666666666667 MRR 0.5418203970886208 rank 2 total_num 599 865\n",
      "checkcorrect (4667, 26, 3723) (4667, 26, 3723) real score 0.9784777671098709 Hits@1 0.34775374376039936 Hits@3 0.6755407653910149 Hits@10 0.9417637271214643 MRR 0.5425827591566931 rank 0 total_num 600 865\n",
      "checkcorrect (4622, 178, 4774) (4622, 178, 4774) real score 0.9700829356908798 Hits@1 0.3488372093023256 Hits@3 0.6760797342192691 Hits@10 0.9418604651162791 MRR 0.5433425884604195 rank 0 total_num 601 865\n",
      "checkcorrect (3949, 26, 4239) (3949, 26, 4239) real score 0.9742121756076814 Hits@1 0.3482587064676617 Hits@3 0.6749585406301825 Hits@10 0.9419568822553898 MRR 0.5428561165060904 rank 3 total_num 602 865\n",
      "checkcorrect (3795, 162, 5400) (3795, 162, 5400) real score 0.8830979973077775 Hits@1 0.34933774834437087 Hits@3 0.6754966887417219 Hits@10 0.9420529801324503 MRR 0.5436129772403518 rank 0 total_num 603 865\n",
      "checkcorrect (3806, 52, 4882) (3806, 52, 4882) real score 0.9497886806726455 Hits@1 0.3504132231404959 Hits@3 0.6760330578512397 Hits@10 0.9421487603305785 MRR 0.5443673359556571 rank 0 total_num 604 865\n",
      "checkcorrect (5231, 156, 3801) (5231, 156, 3801) real score 0.9021671712398529 Hits@1 0.35148514851485146 Hits@3 0.6765676567656765 Hits@10 0.9422442244224423 MRR 0.5451192050382385 rank 0 total_num 605 865\n",
      "checkcorrect (4157, 80, 4552) (4157, 80, 4552) real score 0.9423502027988434 Hits@1 0.35090609555189456 Hits@3 0.6771004942339374 Hits@10 0.942339373970346 MRR 0.5450448735637109 rank 1 total_num 606 865\n",
      "checkcorrect (3730, 172, 3832) (3730, 172, 3832) real score 0.8900349348783494 Hits@1 0.3503289473684211 Hits@3 0.6776315789473685 Hits@10 0.9424342105263158 MRR 0.5449707866006127 rank 1 total_num 607 865\n",
      "checkcorrect (3807, 74, 3832) (3807, 74, 3832) real score 0.9371666729450225 Hits@1 0.3497536945812808 Hits@3 0.6765188834154351 Hits@10 0.9425287356321839 MRR 0.5444864339132554 rank 3 total_num 608 865\n",
      "checkcorrect (4607, 74, 4364) (4607, 74, 4364) real score 0.9392062872648239 Hits@1 0.34918032786885245 Hits@3 0.6754098360655738 Hits@10 0.9426229508196722 MRR 0.5439217020543812 rank 4 total_num 609 865\n",
      "checkcorrect (4530, 292, 4209) (4530, 292, 4209) real score 0.42172870151698594 Hits@1 0.3502454991816694 Hits@3 0.6759410801963993 Hits@10 0.9427168576104746 MRR 0.5446681477138666 rank 0 total_num 610 865\n",
      "checkcorrect (3914, 24, 4012) (3914, 24, 4012) real score 0.9593898117542268 Hits@1 0.34967320261437906 Hits@3 0.6764705882352942 Hits@10 0.9428104575163399 MRR 0.5445951605443995 rank 1 total_num 611 865\n",
      "checkcorrect (4258, 102, 3801) (4258, 102, 3801) real score 0.9925355523824693 Hits@1 0.35073409461663946 Hits@3 0.6769983686786297 Hits@10 0.9429037520391517 MRR 0.545338072191146 rank 0 total_num 612 865\n",
      "checkcorrect (4312, 56, 3793) (4312, 56, 3793) real score 0.8887103468179702 Hits@1 0.3501628664495114 Hits@3 0.6775244299674267 Hits@10 0.9429967426710097 MRR 0.5449927876001723 rank 2 total_num 613 865\n",
      "checkcorrect (3729, 52, 4875) (3729, 52, 4875) real score 0.8846434503793716 Hits@1 0.34959349593495936 Hits@3 0.6764227642276422 Hits@10 0.943089430894309 MRR 0.5444318237178957 rank 4 total_num 614 865\n",
      "checkcorrect (6027, 100, 3746) (6027, 100, 3746) real score 0.9424935340881347 Hits@1 0.35064935064935066 Hits@3 0.676948051948052 Hits@10 0.9431818181818182 MRR 0.5451713824456264 rank 0 total_num 615 865\n",
      "checkcorrect (5329, 54, 3712) (5329, 54, 3712) real score 0.9319738984107971 Hits@1 0.3500810372771475 Hits@3 0.6758508914100486 Hits@10 0.9432739059967585 MRR 0.5444678811954893 rank 8 total_num 616 865\n",
      "checkcorrect (3673, 86, 5676) (3673, 86, 5676) real score 0.8064411893486977 Hits@1 0.3511326860841424 Hits@3 0.6763754045307443 Hits@10 0.9433656957928802 MRR 0.5452049881838461 rank 0 total_num 617 865\n",
      "checkcorrect (5691, 136, 3888) (5691, 136, 3888) real score 0.9359275937080384 Hits@1 0.35218093699515346 Hits@3 0.6768982229402262 Hits@10 0.9434571890145396 MRR 0.5459397135664247 rank 0 total_num 618 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5224, 358, 4891) (5224, 358, 4891) real score 0.7436243891716003 Hits@1 0.35161290322580646 Hits@3 0.6758064516129032 Hits@10 0.9435483870967742 MRR 0.5454623914477692 rank 3 total_num 619 865\n",
      "checkcorrect (4754, 280, 4780) (4754, 280, 4780) real score 0.47969136834144593 Hits@1 0.35104669887278583 Hits@3 0.6763285024154589 Hits@10 0.9436392914653784 MRR 0.5453891830879499 rank 1 total_num 620 865\n",
      "checkcorrect (5346, 322, 5906) (5346, 322, 5906) real score 0.8857286751270295 Hits@1 0.3520900321543408 Hits@3 0.6768488745980707 Hits@10 0.9437299035369775 MRR 0.5461200686456863 rank 0 total_num 621 865\n",
      "checkcorrect (4335, 96, 5470) (4335, 96, 5470) real score 0.9124929398298264 Hits@1 0.35152487961476725 Hits@3 0.6757624398073836 Hits@10 0.9438202247191011 MRR 0.5455109941641791 rank 5 total_num 622 865\n",
      "checkcorrect (4670, 310, 4726) (4670, 310, 4726) real score 0.8963006645441055 Hits@1 0.35096153846153844 Hits@3 0.6746794871794872 Hits@10 0.9439102564102564 MRR 0.5449572906478903 rank 4 total_num 623 865\n",
      "checkcorrect (4640, 82, 5881) (4640, 82, 5881) real score 0.9954877525568009 Hits@1 0.352 Hits@3 0.6752 Hits@10 0.944 MRR 0.5456853589828538 rank 0 total_num 624 865\n",
      "checkcorrect (4679, 62, 4606) (4679, 62, 4606) real score 0.8881217181682587 Hits@1 0.3514376996805112 Hits@3 0.6741214057507987 Hits@10 0.9440894568690096 MRR 0.5450418634299373 rank 6 total_num 625 865\n",
      "checkcorrect (6138, 20, 5289) (6138, 20, 5289) real score 0.887104120850563 Hits@1 0.3508771929824561 Hits@3 0.6730462519936204 Hits@10 0.9441786283891547 MRR 0.5443320677944828 rank 9 total_num 626 865\n",
      "checkcorrect (3838, 356, 4777) (3838, 356, 4777) real score 0.5298075385391712 Hits@1 0.3503184713375796 Hits@3 0.6719745222929936 Hits@10 0.9442675159235668 MRR 0.5437837683234725 rank 4 total_num 627 865\n",
      "checkcorrect (5218, 246, 4779) (5218, 246, 4779) real score 0.745909857749939 Hits@1 0.3497615262321145 Hits@3 0.6724960254372019 Hits@10 0.9443561208267091 MRR 0.543714159788777 rank 1 total_num 628 865\n",
      "checkcorrect (5344, 52, 5343) (5344, 52, 5343) real score 0.46891988515853883 Hits@1 0.3492063492063492 Hits@3 0.6714285714285714 Hits@10 0.9428571428571428 MRR 0.5429503277891123 rank 15 total_num 629 865\n",
      "checkcorrect (4117, 32, 3873) (4117, 32, 3873) real score 0.8503234297037124 Hits@1 0.3486529318541997 Hits@3 0.6719492868462758 Hits@10 0.9429477020602218 MRR 0.542618129699642 rank 2 total_num 630 865\n",
      "checkcorrect (4875, 2, 4848) (4875, 2, 4848) real score 0.9194728523492813 Hits@1 0.34810126582278483 Hits@3 0.6708860759493671 Hits@10 0.9430379746835443 MRR 0.5420760124058134 rank 4 total_num 631 865\n",
      "checkcorrect (4892, 2, 5225) (4892, 2, 5225) real score 0.8734436720609665 Hits@1 0.34755134281200634 Hits@3 0.669826224328594 Hits@10 0.943127962085308 MRR 0.5416145969043824 rank 3 total_num 632 865\n",
      "checkcorrect (4617, 74, 4677) (4617, 74, 4677) real score 0.9402625590562821 Hits@1 0.3470031545741325 Hits@3 0.6703470031545742 Hits@10 0.943217665615142 MRR 0.5412860775612104 rank 2 total_num 633 865\n",
      "checkcorrect (5220, 8, 3826) (5220, 8, 3826) real score 0.8511118412017822 Hits@1 0.3464566929133858 Hits@3 0.6692913385826772 Hits@10 0.9433070866141732 MRR 0.5407486191713502 rank 4 total_num 634 865\n",
      "checkcorrect (4607, 74, 3847) (4607, 74, 3847) real score 0.9421715646982193 Hits@1 0.3474842767295597 Hits@3 0.6698113207547169 Hits@10 0.9433962264150944 MRR 0.541470712537433 rank 0 total_num 635 865\n",
      "checkcorrect (3784, 58, 3687) (3784, 58, 3687) real score 0.8786796689033508 Hits@1 0.3469387755102041 Hits@3 0.6703296703296703 Hits@10 0.9434850863422292 MRR 0.5411439662592475 rank 2 total_num 636 865\n",
      "checkcorrect (3994, 236, 3746) (3994, 236, 3746) real score 0.714615811407566 Hits@1 0.3463949843260188 Hits@3 0.6692789968652038 Hits@10 0.9435736677115988 MRR 0.540687627754139 rank 3 total_num 637 865\n",
      "checkcorrect (4048, 26, 4100) (4048, 26, 4100) real score 0.9776219010353089 Hits@1 0.3458528951486698 Hits@3 0.6682316118935837 Hits@10 0.9436619718309859 MRR 0.5402327175385613 rank 3 total_num 638 865\n",
      "checkcorrect (3726, 172, 4560) (3726, 172, 4560) real score 0.8731534212827683 Hits@1 0.3453125 Hits@3 0.66875 Hits@10 0.94375 MRR 0.5399094372507406 rank 2 total_num 639 865\n",
      "checkcorrect (3916, 172, 5229) (3916, 172, 5229) real score 0.9600923538208008 Hits@1 0.34477379095163807 Hits@3 0.6692667706708268 Hits@10 0.9438377535101404 MRR 0.539847176038181 rank 1 total_num 640 865\n",
      "checkcorrect (3858, 24, 3728) (3858, 24, 3728) real score 0.9643752604722977 Hits@1 0.3442367601246106 Hits@3 0.6697819314641744 Hits@10 0.9439252336448598 MRR 0.539785108785785 rank 1 total_num 641 865\n",
      "checkcorrect (5261, 4, 3864) (5261, 4, 3864) real score 0.9380981355905533 Hits@1 0.343701399688958 Hits@3 0.6702954898911353 Hits@10 0.9440124416796267 MRR 0.5397232345886065 rank 1 total_num 642 865\n",
      "checkcorrect (4599, 290, 6045) (4599, 290, 6045) real score 0.8237428665161133 Hits@1 0.34316770186335405 Hits@3 0.6708074534161491 Hits@10 0.9440993788819876 MRR 0.5396615525473198 rank 1 total_num 643 865\n",
      "checkcorrect (3872, 44, 4476) (3872, 44, 4476) real score 0.9367993891239166 Hits@1 0.34418604651162793 Hits@3 0.6713178294573643 Hits@10 0.9441860465116279 MRR 0.5403752555666264 rank 0 total_num 644 865\n",
      "checkcorrect (3710, 20, 5344) (3710, 20, 5344) real score 0.9154902756214142 Hits@1 0.34365325077399383 Hits@3 0.6718266253869969 Hits@10 0.9442724458204335 MRR 0.5403127551710124 rank 1 total_num 645 865\n",
      "checkcorrect (5673, 424, 4895) (5673, 424, 4895) real score 0.08552926509873941 Hits@1 0.34312210200927357 Hits@3 0.6707882534775889 Hits@10 0.9428129829984544 MRR 0.5396181590902366 rank 10 total_num 646 865\n",
      "checkcorrect (4864, 286, 5341) (4864, 286, 5341) real score 0.6099609987810255 Hits@1 0.3425925925925926 Hits@3 0.6697530864197531 Hits@10 0.941358024691358 MRR 0.5389257068245249 rank 10 total_num 647 865\n",
      "checkcorrect (4575, 92, 3979) (4575, 92, 3979) real score 0.9027962945401669 Hits@1 0.3420647149460709 Hits@3 0.6687211093990755 Hits@10 0.9414483821263482 MRR 0.5384034792331157 rank 4 total_num 648 865\n",
      "checkcorrect (4488, 26, 4671) (4488, 26, 4671) real score 0.9745535194873809 Hits@1 0.3415384615384615 Hits@3 0.6692307692307692 Hits@10 0.9415384615384615 MRR 0.5380879867009621 rank 2 total_num 649 865\n",
      "checkcorrect (4974, 172, 4214) (4974, 172, 4214) real score 0.9577995866537095 Hits@1 0.3425499231950845 Hits@3 0.6697388632872504 Hits@10 0.9416282642089093 MRR 0.5387975289640944 rank 0 total_num 650 865\n",
      "checkcorrect (3690, 268, 3724) (3690, 268, 3724) real score 0.8202157765626907 Hits@1 0.34202453987730064 Hits@3 0.6702453987730062 Hits@10 0.941717791411043 MRR 0.5387380235515727 rank 1 total_num 651 865\n",
      "checkcorrect (3688, 138, 5005) (3688, 138, 5005) real score 0.9920902609825134 Hits@1 0.3430321592649311 Hits@3 0.6707503828483921 Hits@10 0.9418070444104135 MRR 0.5394443971755366 rank 0 total_num 652 865\n",
      "checkcorrect (3933, 196, 4358) (3933, 196, 4358) real score 0.9348590910434722 Hits@1 0.3440366972477064 Hits@3 0.6712538226299695 Hits@10 0.9418960244648318 MRR 0.5401486106355129 rank 0 total_num 653 865\n",
      "checkcorrect (4414, 358, 5888) (4414, 358, 5888) real score 0.8130347818136214 Hits@1 0.3435114503816794 Hits@3 0.6702290076335878 Hits@10 0.9419847328244275 MRR 0.5397056356574433 rank 3 total_num 654 865\n",
      "checkcorrect (4811, 356, 4810) (4811, 356, 4810) real score 0.3556808173656464 Hits@1 0.3429878048780488 Hits@3 0.6692073170731707 Hits@10 0.9405487804878049 MRR 0.5389591331640632 rank 19 total_num 655 865\n",
      "checkcorrect (3844, 102, 4117) (3844, 102, 4117) real score 0.9930817425251006 Hits@1 0.3439878234398782 Hits@3 0.669710806697108 Hits@10 0.9406392694063926 MRR 0.5396608696432655 rank 0 total_num 656 865\n",
      "checkcorrect (4293, 26, 3723) (4293, 26, 3723) real score 0.9647631466388702 Hits@1 0.3434650455927052 Hits@3 0.668693009118541 Hits@10 0.9407294832826748 MRR 0.5392206555556618 rank 3 total_num 657 865\n",
      "checkcorrect (4321, 196, 4381) (4321, 196, 4381) real score 0.9047060430049896 Hits@1 0.34446130500758726 Hits@3 0.669195751138088 Hits@10 0.9408194233687405 MRR 0.5399198654865333 rank 0 total_num 658 865\n",
      "checkcorrect (4378, 112, 4197) (4378, 112, 4197) real score 0.7282744526863099 Hits@1 0.34393939393939393 Hits@3 0.6681818181818182 Hits@10 0.9409090909090909 MRR 0.5393182553007312 rank 6 total_num 659 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3904, 50, 3954) (3904, 50, 3954) real score 0.9695924729108811 Hits@1 0.34493192133131617 Hits@3 0.6686838124054463 Hits@10 0.9409984871406959 MRR 0.5400152019644214 rank 0 total_num 660 865\n",
      "checkcorrect (6005, 290, 3752) (6005, 290, 3752) real score 0.960573673248291 Hits@1 0.3459214501510574 Hits@3 0.6691842900302115 Hits@10 0.9410876132930514 MRR 0.5407100430490673 rank 0 total_num 661 865\n",
      "checkcorrect (5756, 54, 3669) (5756, 54, 3669) real score 0.9446549981832504 Hits@1 0.3469079939668175 Hits@3 0.669683257918552 Hits@10 0.9411764705882353 MRR 0.5414027880821759 rank 0 total_num 662 865\n",
      "checkcorrect (4179, 86, 5267) (4179, 86, 5267) real score 0.7996506363153457 Hits@1 0.3463855421686747 Hits@3 0.6686746987951807 Hits@10 0.9412650602409639 MRR 0.5409639284615702 rank 3 total_num 663 865\n",
      "checkcorrect (3757, 78, 3799) (3757, 78, 3799) real score 0.9786615967750549 Hits@1 0.3473684210526316 Hits@3 0.6691729323308271 Hits@10 0.9413533834586466 MRR 0.5416542082683949 rank 0 total_num 664 865\n",
      "checkcorrect (4270, 62, 4595) (4270, 62, 4595) real score 0.891791582107544 Hits@1 0.34684684684684686 Hits@3 0.6681681681681682 Hits@10 0.9414414414414415 MRR 0.5410286013490729 rank 7 total_num 665 865\n",
      "checkcorrect (4221, 34, 3986) (4221, 34, 3986) real score 0.8984470963478088 Hits@1 0.34632683658170915 Hits@3 0.6671664167916042 Hits@10 0.9415292353823088 MRR 0.5405173140906785 rank 4 total_num 666 865\n",
      "checkcorrect (4582, 26, 4055) (4582, 26, 4055) real score 0.9778223872184754 Hits@1 0.3473053892215569 Hits@3 0.6676646706586826 Hits@10 0.9416167664670658 MRR 0.5412051624228781 rank 0 total_num 667 865\n",
      "checkcorrect (5630, 88, 3888) (5630, 88, 3888) real score 0.9930811047554016 Hits@1 0.3482810164424514 Hits@3 0.6681614349775785 Hits@10 0.9417040358744395 MRR 0.5418909544072983 rank 0 total_num 668 865\n",
      "checkcorrect (4666, 24, 4022) (4666, 24, 4022) real score 0.8451718762516975 Hits@1 0.34776119402985073 Hits@3 0.6686567164179105 Hits@10 0.9417910447761194 MRR 0.5415796743758446 rank 2 total_num 669 865\n",
      "checkcorrect (5107, 26, 4239) (5107, 26, 4239) real score 0.9786294341087342 Hits@1 0.34873323397913564 Hits@3 0.669150521609538 Hits@10 0.9418777943368107 MRR 0.5422628641308732 rank 0 total_num 670 865\n",
      "checkcorrect (4024, 162, 5017) (4024, 162, 5017) real score 0.7697582751512527 Hits@1 0.3482142857142857 Hits@3 0.6681547619047619 Hits@10 0.9419642857142857 MRR 0.5417535443925832 rank 4 total_num 671 865\n",
      "checkcorrect (4466, 50, 3673) (4466, 50, 3673) real score 0.9479444324970245 Hits@1 0.3491827637444279 Hits@3 0.6686478454680534 Hits@10 0.9420505200594353 MRR 0.5424344455153283 rank 0 total_num 672 865\n",
      "checkcorrect (4537, 204, 4786) (4537, 204, 4786) real score 0.45190312564373014 Hits@1 0.3486646884272997 Hits@3 0.6676557863501483 Hits@10 0.9421364985163204 MRR 0.5418416008526307 rank 6 total_num 673 865\n",
      "checkcorrect (5005, 178, 4774) (5005, 178, 4774) real score 0.9678774744272232 Hits@1 0.3496296296296296 Hits@3 0.6681481481481482 Hits@10 0.9422222222222222 MRR 0.5425203540365526 rank 0 total_num 674 865\n",
      "checkcorrect (3858, 20, 3851) (3858, 20, 3851) real score 0.9743027180433272 Hits@1 0.3505917159763314 Hits@3 0.6686390532544378 Hits@10 0.9423076923076923 MRR 0.5431970990749602 rank 0 total_num 675 865\n",
      "checkcorrect (4359, 220, 4377) (4359, 220, 4377) real score 0.9006793677806855 Hits@1 0.3500738552437223 Hits@3 0.6676514032496307 Hits@10 0.9423929098966026 MRR 0.5427640162107431 rank 3 total_num 676 865\n",
      "checkcorrect (4247, 16, 5877) (4247, 16, 5877) real score 0.9347480982542038 Hits@1 0.3495575221238938 Hits@3 0.6666666666666666 Hits@10 0.9424778761061947 MRR 0.5422584645644145 rank 4 total_num 677 865\n",
      "checkcorrect (5550, 238, 4174) (5550, 238, 4174) real score 0.6820022590458393 Hits@1 0.35051546391752575 Hits@3 0.6671575846833578 Hits@10 0.9425625920471281 MRR 0.5429326052646142 rank 0 total_num 678 865\n",
      "checkcorrect (4664, 50, 4522) (4664, 50, 4522) real score 0.813195438683033 Hits@1 0.35 Hits@3 0.6661764705882353 Hits@10 0.9426470588235294 MRR 0.5422812337862839 rank 9 total_num 679 865\n",
      "checkcorrect (5411, 114, 4140) (5411, 114, 4140) real score 0.9592900454998017 Hits@1 0.34948604992657856 Hits@3 0.6666666666666666 Hits@10 0.9427312775330396 MRR 0.5422191468056873 rank 1 total_num 680 865\n",
      "checkcorrect (3896, 16, 4139) (3896, 16, 4139) real score 0.9834450244903565 Hits@1 0.35043988269794724 Hits@3 0.6671554252199413 Hits@10 0.9428152492668622 MRR 0.5428903797282596 rank 0 total_num 681 865\n",
      "checkcorrect (5317, 72, 5637) (5317, 72, 5637) real score 0.9016679644584655 Hits@1 0.34992679355783307 Hits@3 0.6661786237188873 Hits@10 0.9428989751098097 MRR 0.5424615504753633 rank 3 total_num 682 865\n",
      "checkcorrect (4341, 4, 3864) (4341, 4, 3864) real score 0.9323979705572129 Hits@1 0.34941520467836257 Hits@3 0.6652046783625731 Hits@10 0.9429824561403509 MRR 0.5420339751091712 rank 3 total_num 683 865\n",
      "checkcorrect (5088, 96, 4720) (5088, 96, 4720) real score 0.8574880421161652 Hits@1 0.34890510948905107 Hits@3 0.6642335766423357 Hits@10 0.9430656934306569 MRR 0.5413886700360191 rank 9 total_num 684 865\n",
      "checkcorrect (4878, 26, 3723) (4878, 26, 3723) real score 0.9475328356027604 Hits@1 0.34839650145772594 Hits@3 0.6632653061224489 Hits@10 0.9431486880466472 MRR 0.5408910189135177 rank 4 total_num 685 865\n",
      "checkcorrect (5868, 32, 5290) (5868, 32, 5290) real score 0.922189462184906 Hits@1 0.34788937409024745 Hits@3 0.6637554585152838 Hits@10 0.9432314410480349 MRR 0.5408314977797279 rank 1 total_num 686 865\n",
      "checkcorrect (4955, 44, 4138) (4955, 44, 4138) real score 0.9266598284244538 Hits@1 0.3488372093023256 Hits@3 0.6642441860465116 Hits@10 0.9433139534883721 MRR 0.5414988938585364 rank 0 total_num 687 865\n",
      "checkcorrect (4652, 86, 4651) (4652, 86, 4651) real score 0.776733623445034 Hits@1 0.3483309143686502 Hits@3 0.6632801161103048 Hits@10 0.941944847605225 MRR 0.5408449173665923 rank 10 total_num 688 865\n",
      "checkcorrect (4582, 56, 3826) (4582, 56, 3826) real score 0.9879921168088912 Hits@1 0.3492753623188406 Hits@3 0.663768115942029 Hits@10 0.9420289855072463 MRR 0.5415103595153364 rank 0 total_num 689 865\n",
      "checkcorrect (5182, 58, 3873) (5182, 58, 3873) real score 0.8754023373126983 Hits@1 0.34876989869753977 Hits@3 0.6642547033285094 Hits@10 0.9421128798842258 MRR 0.5412090903023379 rank 2 total_num 690 865\n",
      "checkcorrect (4932, 50, 5812) (4932, 50, 5812) real score 0.9578465819358826 Hits@1 0.34971098265895956 Hits@3 0.6647398843930635 Hits@10 0.9421965317919075 MRR 0.5418720829464097 rank 0 total_num 691 865\n",
      "checkcorrect (4126, 50, 5160) (4126, 50, 5160) real score 0.9354314237833024 Hits@1 0.35064935064935066 Hits@3 0.6652236652236653 Hits@10 0.9422799422799423 MRR 0.5425331621917973 rank 0 total_num 692 865\n",
      "checkcorrect (4721, 54, 3669) (4721, 54, 3669) real score 0.924249815940857 Hits@1 0.35014409221902015 Hits@3 0.6642651296829971 Hits@10 0.9423631123919308 MRR 0.54193152939325 rank 7 total_num 693 865\n",
      "checkcorrect (3738, 54, 5354) (3738, 54, 5354) real score 0.9572436720132828 Hits@1 0.3496402877697842 Hits@3 0.6633093525179856 Hits@10 0.9424460431654677 MRR 0.5415114840272165 rank 3 total_num 694 865\n",
      "checkcorrect (3771, 172, 4307) (3771, 172, 4307) real score 0.9257263988256454 Hits@1 0.34913793103448276 Hits@3 0.6637931034482759 Hits@10 0.9425287356321839 MRR 0.5414518410903958 rank 1 total_num 695 865\n",
      "checkcorrect (5517, 348, 3790) (5517, 348, 3790) real score 0.8975011587142945 Hits@1 0.3500717360114778 Hits@3 0.6642754662840746 Hits@10 0.9426111908177905 MRR 0.5421097294102087 rank 0 total_num 696 865\n",
      "checkcorrect (3736, 268, 4149) (3736, 268, 4149) real score 0.7032630711793899 Hits@1 0.3495702005730659 Hits@3 0.664756446991404 Hits@10 0.9426934097421203 MRR 0.5420494002849792 rank 1 total_num 697 865\n",
      "checkcorrect (4340, 16, 4725) (4340, 16, 4725) real score 0.9746031433343887 Hits@1 0.35050071530758226 Hits@3 0.6652360515021459 Hits@10 0.9427753934191703 MRR 0.5427045513575328 rank 0 total_num 698 865\n",
      "checkcorrect (4125, 20, 3717) (4125, 20, 3717) real score 0.9013522118330002 Hits@1 0.35 Hits@3 0.6642857142857143 Hits@10 0.9428571428571428 MRR 0.5422149734270221 rank 4 total_num 699 865\n",
      "checkcorrect (4878, 26, 4244) (4878, 26, 4244) real score 0.9565715014934539 Hits@1 0.34950071326676174 Hits@3 0.6647646219686163 Hits@10 0.9429386590584878 MRR 0.5419169967649768 rank 2 total_num 700 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5957, 362, 5994) (5957, 362, 5994) real score 0.9666447669267655 Hits@1 0.3504273504273504 Hits@3 0.6652421652421653 Hits@10 0.9430199430199431 MRR 0.542569536655625 rank 0 total_num 701 865\n",
      "checkcorrect (3912, 50, 4698) (3912, 50, 4698) real score 0.9052482530474664 Hits@1 0.35135135135135137 Hits@3 0.6657183499288762 Hits@10 0.9431009957325747 MRR 0.543220220102772 rank 0 total_num 702 865\n",
      "checkcorrect (4037, 118, 5130) (4037, 118, 5130) real score 0.9882775753736496 Hits@1 0.3522727272727273 Hits@3 0.6661931818181818 Hits@10 0.9431818181818182 MRR 0.5438690550173988 rank 0 total_num 703 865\n",
      "checkcorrect (4309, 28, 5511) (4309, 28, 5511) real score 0.9552206218242645 Hits@1 0.3517730496453901 Hits@3 0.6652482269503546 Hits@10 0.9432624113475178 MRR 0.5433812974925514 rank 4 total_num 704 865\n",
      "checkcorrect (3801, 346, 4129) (3801, 346, 4129) real score 0.8395580947399139 Hits@1 0.35127478753541075 Hits@3 0.6657223796033994 Hits@10 0.943342776203966 MRR 0.5433198508955365 rank 1 total_num 705 865\n",
      "checkcorrect (5879, 194, 5937) (5879, 194, 5937) real score 0.4220069169998169 Hits@1 0.3521923620933522 Hits@3 0.6661951909476662 Hits@10 0.9434229137199435 MRR 0.5439657917004933 rank 0 total_num 706 865\n",
      "checkcorrect (4357, 84, 3695) (4357, 84, 3695) real score 0.8962991833686829 Hits@1 0.3516949152542373 Hits@3 0.6652542372881356 Hits@10 0.943502824858757 MRR 0.5435505857800124 rank 3 total_num 707 865\n",
      "checkcorrect (6013, 276, 4427) (6013, 276, 4427) real score 0.8486974447965622 Hits@1 0.3511988716502116 Hits@3 0.6657263751763046 Hits@10 0.9435825105782792 MRR 0.5434891604121985 rank 1 total_num 708 865\n",
      "checkcorrect (3953, 24, 3948) (3953, 24, 3948) real score 0.9681896537542343 Hits@1 0.352112676056338 Hits@3 0.6661971830985915 Hits@10 0.9436619718309859 MRR 0.5441321334257024 rank 0 total_num 709 865\n",
      "checkcorrect (4047, 60, 4619) (4047, 60, 4619) real score 0.889678817987442 Hits@1 0.35161744022503516 Hits@3 0.6652601969057665 Hits@10 0.9423347398030942 MRR 0.5434946889214597 rank 10 total_num 710 865\n",
      "checkcorrect (3668, 34, 3746) (3668, 34, 3746) real score 0.9235776394605637 Hits@1 0.35252808988764045 Hits@3 0.6657303370786517 Hits@10 0.9424157303370787 MRR 0.5441358480662329 rank 0 total_num 711 865\n",
      "checkcorrect (3881, 20, 4305) (3881, 20, 4305) real score 0.9797293454408647 Hits@1 0.3534361851332398 Hits@3 0.6661991584852734 Hits@10 0.9424964936886395 MRR 0.5447752087281316 rank 0 total_num 712 865\n",
      "checkcorrect (5095, 34, 6071) (5095, 34, 6071) real score 0.8897070825099944 Hits@1 0.35294117647058826 Hits@3 0.665266106442577 Hits@10 0.9425770308123249 MRR 0.5442122982717297 rank 6 total_num 713 865\n",
      "checkcorrect (4139, 236, 4321) (4139, 236, 4321) real score 0.8054641142487526 Hits@1 0.35384615384615387 Hits@3 0.6657342657342658 Hits@10 0.9426573426573427 MRR 0.5448497635888322 rank 0 total_num 714 865\n",
      "checkcorrect (5200, 220, 4836) (5200, 220, 4836) real score 0.9635352849960327 Hits@1 0.35335195530726254 Hits@3 0.6662011173184358 Hits@10 0.9427374301675978 MRR 0.5447871242542108 rank 1 total_num 715 865\n",
      "checkcorrect (3745, 172, 5423) (3745, 172, 5423) real score 0.9594613969326019 Hits@1 0.3542538354253835 Hits@3 0.6666666666666666 Hits@10 0.9428172942817294 MRR 0.545422009715502 rank 0 total_num 716 865\n",
      "checkcorrect (3984, 100, 3895) (3984, 100, 3895) real score 0.8722161531448365 Hits@1 0.35376044568245124 Hits@3 0.6657381615598886 Hits@10 0.9415041782729805 MRR 0.5447552195441249 rank 14 total_num 717 865\n",
      "checkcorrect (4220, 4, 3864) (4220, 4, 3864) real score 0.9441165000200271 Hits@1 0.3532684283727399 Hits@3 0.6662030598052852 Hits@10 0.9415855354659249 MRR 0.5446929730635349 rank 1 total_num 718 865\n",
      "checkcorrect (4558, 14, 5185) (4558, 14, 5185) real score 0.9833800584077834 Hits@1 0.3541666666666667 Hits@3 0.6666666666666666 Hits@10 0.9416666666666667 MRR 0.5453253439342801 rank 0 total_num 719 865\n",
      "checkcorrect (4144, 248, 4143) (4144, 248, 4143) real score 0.8804318234324455 Hits@1 0.3550624133148405 Hits@3 0.6671289875173371 Hits@10 0.941747572815534 MRR 0.5459559606555917 rank 0 total_num 720 865\n",
      "checkcorrect (6101, 40, 3697) (6101, 40, 3697) real score 0.41325320601463317 Hits@1 0.3545706371191136 Hits@3 0.6662049861495845 Hits@10 0.9418282548476454 MRR 0.5454767972751823 rank 4 total_num 721 865\n",
      "checkcorrect (3752, 348, 4796) (3752, 348, 4796) real score 0.9450568199157715 Hits@1 0.355463347164592 Hits@3 0.6666666666666666 Hits@10 0.941908713692946 MRR 0.5461054600728653 rank 0 total_num 722 865\n",
      "checkcorrect (4626, 4, 3864) (4626, 4, 3864) real score 0.9369100600481033 Hits@1 0.35497237569060774 Hits@3 0.6657458563535912 Hits@10 0.9419889502762431 MRR 0.5455813733416414 rank 5 total_num 723 865\n",
      "checkcorrect (4846, 2, 4344) (4846, 2, 4344) real score 0.9308694183826447 Hits@1 0.3544827586206897 Hits@3 0.6662068965517242 Hits@10 0.9420689655172414 MRR 0.5455185024818597 rank 1 total_num 724 865\n",
      "checkcorrect (5080, 110, 5857) (5080, 110, 5857) real score 0.9542664647102357 Hits@1 0.35537190082644626 Hits@3 0.6666666666666666 Hits@10 0.9421487603305785 MRR 0.5461445100541988 rank 0 total_num 725 865\n",
      "checkcorrect (5034, 50, 4938) (5034, 50, 4938) real score 0.9155972138047219 Hits@1 0.35488308115543327 Hits@3 0.6657496561210454 Hits@10 0.9422283356258597 MRR 0.5456683828051558 rank 4 total_num 726 865\n",
      "checkcorrect (4351, 50, 3901) (4351, 50, 3901) real score 0.8337966859340668 Hits@1 0.3543956043956044 Hits@3 0.6648351648351648 Hits@10 0.9409340659340659 MRR 0.5450437134481557 rank 10 total_num 727 865\n",
      "checkcorrect (3719, 80, 5526) (3719, 80, 5526) real score 0.4230325438082218 Hits@1 0.35390946502057613 Hits@3 0.663923182441701 Hits@10 0.9410150891632373 MRR 0.5444484698235507 rank 8 total_num 728 865\n",
      "checkcorrect (4504, 328, 4464) (4504, 328, 4464) real score 0.9869717508554459 Hits@1 0.3547945205479452 Hits@3 0.6643835616438356 Hits@10 0.9410958904109589 MRR 0.5450725130155732 rank 0 total_num 729 865\n",
      "checkcorrect (4226, 56, 3752) (4226, 56, 3752) real score 0.916220909357071 Hits@1 0.3543091655266758 Hits@3 0.66484268125855 Hits@10 0.9411764705882353 MRR 0.5450108543110376 rank 1 total_num 730 865\n",
      "checkcorrect (3751, 124, 3807) (3751, 124, 3807) real score 0.9855973958969116 Hits@1 0.3551912568306011 Hits@3 0.6653005464480874 Hits@10 0.9412568306010929 MRR 0.5456324241821974 rank 0 total_num 731 865\n",
      "checkcorrect (4254, 214, 3789) (4254, 214, 3789) real score 0.9364343881607056 Hits@1 0.35607094133697137 Hits@3 0.6657571623465212 Hits@10 0.9413369713506139 MRR 0.5462522980919079 rank 0 total_num 732 865\n",
      "checkcorrect (5480, 420, 5130) (5480, 420, 5130) real score 0.8431269407272339 Hits@1 0.3555858310626703 Hits@3 0.6648501362397821 Hits@10 0.94141689373297 MRR 0.5457351514550888 rank 5 total_num 733 865\n",
      "checkcorrect (5537, 236, 4321) (5537, 236, 4321) real score 0.812326292693615 Hits@1 0.3551020408163265 Hits@3 0.6653061224489796 Hits@10 0.9414965986394558 MRR 0.5456729267592315 rank 1 total_num 734 865\n",
      "checkcorrect (5434, 100, 5551) (5434, 100, 5551) real score 0.4399840712547302 Hits@1 0.3546195652173913 Hits@3 0.6644021739130435 Hits@10 0.9415760869565217 MRR 0.5451013602826564 rank 7 total_num 735 865\n",
      "checkcorrect (4430, 56, 3888) (4430, 56, 3888) real score 0.9880003213882447 Hits@1 0.35549525101763907 Hits@3 0.6648575305291723 Hits@10 0.9416553595658074 MRR 0.5457185904586637 rank 0 total_num 736 865\n",
      "checkcorrect (3969, 20, 3717) (3969, 20, 3717) real score 0.954060509800911 Hits@1 0.35501355013550134 Hits@3 0.6653116531165312 Hits@10 0.9417344173441734 MRR 0.5456566411490991 rank 1 total_num 737 865\n",
      "checkcorrect (5709, 100, 3752) (5709, 100, 3752) real score 0.0 Hits@1 0.35453315290933696 Hits@3 0.6644113667117727 Hits@10 0.9404600811907984 MRR 0.5449483401762617 rank 44 total_num 738 865\n",
      "checkcorrect (5891, 14, 5300) (5891, 14, 5300) real score 0.9732357680797576 Hits@1 0.3554054054054054 Hits@3 0.6648648648648648 Hits@10 0.9405405405405406 MRR 0.5455632748516992 rank 0 total_num 739 865\n",
      "checkcorrect (4131, 60, 3954) (4131, 60, 3954) real score 0.8692388534545898 Hits@1 0.3549257759784076 Hits@3 0.6639676113360324 Hits@10 0.9406207827260459 MRR 0.5449619748856376 rank 9 total_num 740 865\n",
      "checkcorrect (3808, 102, 3801) (3808, 102, 3801) real score 0.992433351278305 Hits@1 0.3557951482479784 Hits@3 0.6644204851752021 Hits@10 0.9407008086253369 MRR 0.5455752336795922 rank 0 total_num 741 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4509, 78, 3799) (4509, 78, 3799) real score 0.980502513051033 Hits@1 0.3553162853297443 Hits@3 0.6648721399730821 Hits@10 0.9407806191117093 MRR 0.5452895783628409 rank 2 total_num 742 865\n",
      "checkcorrect (4202, 92, 4069) (4202, 92, 4069) real score 0.9531191766262055 Hits@1 0.35618279569892475 Hits@3 0.6653225806451613 Hits@10 0.9408602150537635 MRR 0.5459007482843962 rank 0 total_num 743 865\n",
      "checkcorrect (6004, 228, 4567) (6004, 228, 4567) real score 0.8890231102705002 Hits@1 0.35704697986577183 Hits@3 0.6657718120805369 Hits@10 0.9409395973154362 MRR 0.5465102774813299 rank 0 total_num 744 865\n",
      "checkcorrect (6154, 172, 3866) (6154, 172, 3866) real score 0.9588949799537658 Hits@1 0.35656836461126007 Hits@3 0.6662198391420912 Hits@10 0.9410187667560321 MRR 0.5462245175025792 rank 2 total_num 745 865\n",
      "checkcorrect (5149, 240, 4245) (5149, 240, 4245) real score 0.872126892209053 Hits@1 0.35609103078982596 Hits@3 0.6666666666666666 Hits@10 0.9410977242302544 MRR 0.5461626372917323 rank 1 total_num 746 865\n",
      "checkcorrect (3993, 50, 4813) (3993, 50, 4813) real score 0.9288580060005188 Hits@1 0.35561497326203206 Hits@3 0.6671122994652406 Hits@10 0.9411764705882353 MRR 0.5461009225359947 rank 1 total_num 747 865\n",
      "checkcorrect (4244, 28, 4620) (4244, 28, 4620) real score 0.9569904863834382 Hits@1 0.35647530040053405 Hits@3 0.6675567423230975 Hits@10 0.9412550066755674 MRR 0.5467069293149853 rank 0 total_num 748 865\n",
      "checkcorrect (3844, 102, 3801) (3844, 102, 3801) real score 0.9926056325435639 Hits@1 0.35733333333333334 Hits@3 0.668 Hits@10 0.9413333333333334 MRR 0.5473113200758987 rank 0 total_num 749 865\n",
      "checkcorrect (5475, 30, 5817) (5475, 30, 5817) real score 0.4433469146490097 Hits@1 0.35685752330226367 Hits@3 0.6684420772303595 Hits@10 0.9414114513981359 MRR 0.547248322312815 rank 1 total_num 750 865\n",
      "checkcorrect (4004, 16, 4804) (4004, 16, 4804) real score 0.9554514318704606 Hits@1 0.35638297872340424 Hits@3 0.6688829787234043 Hits@10 0.9414893617021277 MRR 0.5471854920969734 rank 1 total_num 751 865\n",
      "checkcorrect (4679, 62, 4065) (4679, 62, 4065) real score 0.8950753390789032 Hits@1 0.35723771580345287 Hits@3 0.6693227091633466 Hits@10 0.9415670650730412 MRR 0.5477868393850253 rank 0 total_num 752 865\n",
      "checkcorrect (5322, 248, 4149) (5322, 248, 4149) real score 0.831325364112854 Hits@1 0.356763925729443 Hits@3 0.669761273209549 Hits@10 0.9416445623342176 MRR 0.547502418289466 rank 2 total_num 753 865\n",
      "checkcorrect (4728, 30, 4543) (4728, 30, 4543) real score 0.8390428572893143 Hits@1 0.3562913907284768 Hits@3 0.6701986754966888 Hits@10 0.9417218543046357 MRR 0.5474395011791489 rank 1 total_num 754 865\n",
      "checkcorrect (4229, 78, 3799) (4229, 78, 3799) real score 0.9818555623292923 Hits@1 0.35714285714285715 Hits@3 0.6706349206349206 Hits@10 0.9417989417989417 MRR 0.5480381261775891 rank 0 total_num 755 865\n",
      "checkcorrect (4168, 46, 3798) (4168, 46, 3798) real score 0.8820609062910081 Hits@1 0.35667107001321 Hits@3 0.6697490092470277 Hits@10 0.9418758256274768 MRR 0.5474792911364034 rank 7 total_num 756 865\n",
      "checkcorrect (3927, 46, 3870) (3927, 46, 3870) real score 0.8782465294003486 Hits@1 0.3562005277044855 Hits@3 0.6688654353562006 Hits@10 0.941952506596306 MRR 0.5470868382457221 rank 3 total_num 757 865\n",
      "checkcorrect (3732, 326, 5687) (3732, 326, 5687) real score 0.37538017332553864 Hits@1 0.3557312252964427 Hits@3 0.6679841897233202 Hits@10 0.9420289855072463 MRR 0.5466954194865051 rank 3 total_num 758 865\n",
      "checkcorrect (5724, 2, 5309) (5724, 2, 5309) real score 0.9324236869812013 Hits@1 0.35657894736842105 Hits@3 0.6684210526315789 Hits@10 0.9421052631578948 MRR 0.5472918728819176 rank 0 total_num 759 865\n",
      "checkcorrect (4234, 116, 3877) (4234, 116, 3877) real score 0.9945314288139343 Hits@1 0.35742444152431013 Hits@3 0.668856767411301 Hits@10 0.9421813403416557 MRR 0.5478867587256996 rank 0 total_num 760 865\n",
      "checkcorrect (4531, 24, 3705) (4531, 24, 3705) real score 0.888715061545372 Hits@1 0.35826771653543305 Hits@3 0.6692913385826772 Hits@10 0.9422572178477691 MRR 0.5484800831893141 rank 0 total_num 761 865\n",
      "checkcorrect (3787, 24, 3788) (3787, 24, 3788) real score 0.9664590984582901 Hits@1 0.35910878112712974 Hits@3 0.6697247706422018 Hits@10 0.9423328964613368 MRR 0.5490718524118707 rank 0 total_num 762 865\n",
      "checkcorrect (4510, 50, 4882) (4510, 50, 4882) real score 0.8746978521347046 Hits@1 0.3586387434554974 Hits@3 0.6701570680628273 Hits@10 0.9424083769633508 MRR 0.5490076222385567 rank 1 total_num 763 865\n",
      "checkcorrect (4001, 44, 3734) (4001, 44, 3734) real score 0.9400204867124557 Hits@1 0.3581699346405229 Hits@3 0.6705882352941176 Hits@10 0.9424836601307189 MRR 0.5487256950635172 rank 2 total_num 764 865\n",
      "checkcorrect (4019, 100, 4187) (4019, 100, 4187) real score 0.7825449526309967 Hits@1 0.3577023498694517 Hits@3 0.6697127937336814 Hits@10 0.9425587467362925 MRR 0.548335713738369 rank 3 total_num 765 865\n",
      "checkcorrect (5365, 280, 4273) (5365, 280, 4273) real score 0.9560471713542938 Hits@1 0.35853976531942633 Hits@3 0.6701434159061278 Hits@10 0.9426336375488917 MRR 0.5489245850372759 rank 0 total_num 766 865\n",
      "checkcorrect (5648, 420, 4074) (5648, 420, 4074) real score 0.8603411585092544 Hits@1 0.3580729166666667 Hits@3 0.6705729166666666 Hits@10 0.9427083333333334 MRR 0.5486438672616197 rank 2 total_num 767 865\n",
      "checkcorrect (3814, 120, 4643) (3814, 120, 4643) real score 0.8961786836385728 Hits@1 0.3589076723016905 Hits@3 0.6710013003901171 Hits@10 0.9427828348504551 MRR 0.5492308063158959 rank 0 total_num 768 865\n",
      "checkcorrect (3902, 58, 4170) (3902, 58, 4170) real score 0.8762999385595321 Hits@1 0.35844155844155845 Hits@3 0.6714285714285714 Hits@10 0.9428571428571428 MRR 0.5491668702037974 rank 1 total_num 769 865\n",
      "checkcorrect (4572, 50, 4952) (4572, 50, 4952) real score 0.9583748251199722 Hits@1 0.35797665369649806 Hits@3 0.6718547341115434 Hits@10 0.9429312581063554 MRR 0.5491030999441296 rank 1 total_num 770 865\n",
      "checkcorrect (4547, 24, 5443) (4547, 24, 5443) real score 0.9629377394914627 Hits@1 0.3588082901554404 Hits@3 0.6722797927461139 Hits@10 0.9430051813471503 MRR 0.549687163286171 rank 0 total_num 771 865\n",
      "checkcorrect (6154, 172, 3996) (6154, 172, 3996) real score 0.9602749228477478 Hits@1 0.35834411384217335 Hits@3 0.6727037516170763 Hits@10 0.943078913324709 MRR 0.549622884937806 rank 1 total_num 772 865\n",
      "checkcorrect (4447, 428, 4284) (4447, 428, 4284) real score 0.3320233481004834 Hits@1 0.3578811369509044 Hits@3 0.6731266149870802 Hits@10 0.9431524547803618 MRR 0.5493434410726838 rank 2 total_num 773 865\n",
      "checkcorrect (3865, 54, 3669) (3865, 54, 3669) real score 0.9488223493099213 Hits@1 0.3574193548387097 Hits@3 0.672258064516129 Hits@10 0.9432258064516129 MRR 0.5489571914712997 rank 3 total_num 774 865\n",
      "checkcorrect (4951, 236, 3746) (4951, 236, 3746) real score 0.5085484262555837 Hits@1 0.35695876288659795 Hits@3 0.6713917525773195 Hits@10 0.9432989690721649 MRR 0.5483929568316603 rank 8 total_num 775 865\n",
      "checkcorrect (3880, 16, 5172) (3880, 16, 5172) real score 0.9667182564735413 Hits@1 0.3564993564993565 Hits@3 0.6718146718146718 Hits@10 0.9433719433719434 MRR 0.5483306750339362 rank 1 total_num 776 865\n",
      "checkcorrect (4022, 54, 3669) (4022, 54, 3669) real score 0.9656600058078766 Hits@1 0.35732647814910024 Hits@3 0.6722365038560412 Hits@10 0.9434447300771208 MRR 0.5489112268655121 rank 0 total_num 777 865\n",
      "checkcorrect (4437, 128, 3678) (4437, 128, 3678) real score 0.8932820051908492 Hits@1 0.35686777920410784 Hits@3 0.6713735558408216 Hits@10 0.9435173299101413 MRR 0.5485275154061212 rank 3 total_num 778 865\n",
      "checkcorrect (4055, 28, 4554) (4055, 28, 4554) real score 0.9533901154994964 Hits@1 0.3564102564102564 Hits@3 0.6705128205128205 Hits@10 0.9435897435897436 MRR 0.5481447878222672 rank 3 total_num 779 865\n",
      "checkcorrect (3774, 26, 3723) (3774, 26, 3723) real score 0.9695662587881089 Hits@1 0.3559539052496799 Hits@3 0.6709346991037132 Hits@10 0.9436619718309859 MRR 0.5480831427674371 rank 1 total_num 780 865\n",
      "checkcorrect (5806, 100, 4374) (5806, 100, 4374) real score 0.9355219572782516 Hits@1 0.3554987212276215 Hits@3 0.6713554987212276 Hits@10 0.9437340153452686 MRR 0.5480216553725938 rank 1 total_num 781 865\n",
      "checkcorrect (5712, 344, 4974) (5712, 344, 4974) real score 0.930118864774704 Hits@1 0.3563218390804598 Hits@3 0.6717752234993615 Hits@10 0.9438058748403576 MRR 0.5485988946377629 rank 0 total_num 782 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4363, 44, 3785) (4363, 44, 3785) real score 0.9205920010805131 Hits@1 0.35586734693877553 Hits@3 0.6709183673469388 Hits@10 0.9438775510204082 MRR 0.5481542531905209 rank 4 total_num 783 865\n",
      "checkcorrect (3710, 174, 4779) (3710, 174, 4779) real score 0.7690177053213119 Hits@1 0.3554140127388535 Hits@3 0.6700636942675159 Hits@10 0.9439490445859873 MRR 0.5477744388552463 rank 3 total_num 784 865\n",
      "checkcorrect (3734, 16, 3871) (3734, 16, 3871) real score 0.9629804164171218 Hits@1 0.3549618320610687 Hits@3 0.6692111959287532 Hits@10 0.9440203562340967 MRR 0.5473955909686621 rank 3 total_num 785 865\n",
      "checkcorrect (4078, 36, 5008) (4078, 36, 5008) real score 0.4231640636920929 Hits@1 0.3545108005082592 Hits@3 0.6696315120711563 Hits@10 0.9440914866581956 MRR 0.5471235931825943 rank 2 total_num 786 865\n",
      "checkcorrect (5889, 344, 4857) (5889, 344, 4857) real score 0.9400939643383026 Hits@1 0.3553299492385787 Hits@3 0.6700507614213198 Hits@10 0.9441624365482234 MRR 0.5476983094349006 rank 0 total_num 787 865\n",
      "checkcorrect (4188, 56, 3695) (4188, 56, 3695) real score 0.9437509417533875 Hits@1 0.3561470215462611 Hits@3 0.670468948035488 Hits@10 0.944233206590621 MRR 0.5482715688652746 rank 0 total_num 788 865\n",
      "checkcorrect (4506, 36, 4507) (4506, 36, 4507) real score 0.0 Hits@1 0.3556962025316456 Hits@3 0.669620253164557 Hits@10 0.9430379746835443 MRR 0.5476127159651639 rank 35 total_num 789 865\n",
      "checkcorrect (3847, 50, 3993) (3847, 50, 3993) real score 0.9405196577310562 Hits@1 0.35651074589127685 Hits@3 0.6700379266750948 Hits@10 0.943109987357775 MRR 0.5481846341497844 rank 0 total_num 790 865\n",
      "checkcorrect (5227, 78, 3799) (5227, 78, 3799) real score 0.9828446745872498 Hits@1 0.3573232323232323 Hits@3 0.6704545454545454 Hits@10 0.9431818181818182 MRR 0.548755108096565 rank 0 total_num 791 865\n",
      "checkcorrect (5799, 72, 4108) (5799, 72, 4108) real score 0.8678494811058044 Hits@1 0.35687263556116017 Hits@3 0.669609079445145 Hits@10 0.9432534678436317 MRR 0.5483153160308695 rank 4 total_num 792 865\n",
      "checkcorrect (3830, 158, 4480) (3830, 158, 4480) real score 0.9454214245080947 Hits@1 0.35642317380352645 Hits@3 0.6687657430730478 Hits@10 0.9433249370277078 MRR 0.5479396040459439 rank 3 total_num 793 865\n",
      "checkcorrect (4676, 26, 4244) (4676, 26, 4244) real score 0.9632507145404816 Hits@1 0.3559748427672956 Hits@3 0.6691823899371069 Hits@10 0.9433962264150944 MRR 0.5476696590513368 rank 2 total_num 794 865\n",
      "checkcorrect (4271, 62, 4270) (4271, 62, 4270) real score 0.8913690745830536 Hits@1 0.3555276381909548 Hits@3 0.6683417085427136 Hits@10 0.9434673366834171 MRR 0.5471910120759792 rank 5 total_num 795 865\n",
      "checkcorrect (4693, 56, 3826) (4693, 56, 3826) real score 0.9545238614082336 Hits@1 0.35633626097867 Hits@3 0.6687578419071518 Hits@10 0.9435382685069009 MRR 0.5477591538425087 rank 0 total_num 796 865\n",
      "checkcorrect (4466, 50, 4682) (4466, 50, 4682) real score 0.9476680546998978 Hits@1 0.3558897243107769 Hits@3 0.6679197994987469 Hits@10 0.943609022556391 MRR 0.5472815943347696 rank 5 total_num 797 865\n",
      "checkcorrect (4669, 36, 5412) (4669, 36, 5412) real score 0.3160549759864807 Hits@1 0.35544430538172717 Hits@3 0.6670838548185232 Hits@10 0.9424280350438048 MRR 0.5466661675027555 rank 17 total_num 798 865\n",
      "checkcorrect (4092, 2, 5227) (4092, 2, 5227) real score 0.9038149625062943 Hits@1 0.355 Hits@3 0.6675 Hits@10 0.9425 MRR 0.5463995014600438 rank 2 total_num 799 865\n",
      "checkcorrect (5687, 380, 5688) (5687, 380, 5688) real score 0.6412370756268502 Hits@1 0.35580524344569286 Hits@3 0.6679151061173533 Hits@10 0.9425717852684145 MRR 0.5469657942172721 rank 0 total_num 800 865\n",
      "checkcorrect (5319, 236, 3746) (5319, 236, 3746) real score 0.8537743389606476 Hits@1 0.3566084788029925 Hits@3 0.6683291770573566 Hits@10 0.942643391521197 MRR 0.547530674773111 rank 0 total_num 801 865\n",
      "checkcorrect (6026, 38, 5590) (6026, 38, 5590) real score 0.3562814861536026 Hits@1 0.3561643835616438 Hits@3 0.6674968866749689 Hits@10 0.9414694894146949 MRR 0.5469446130074198 rank 12 total_num 802 865\n",
      "checkcorrect (5709, 34, 5710) (5709, 34, 5710) real score 0.0 Hits@1 0.35572139303482586 Hits@3 0.6666666666666666 Hits@10 0.9402985074626866 MRR 0.5462907970655507 rank 46 total_num 803 865\n",
      "checkcorrect (5250, 178, 3688) (5250, 178, 3688) real score 0.9677508771419525 Hits@1 0.3565217391304348 Hits@3 0.6670807453416149 Hits@10 0.9403726708074535 MRR 0.5468544109822394 rank 0 total_num 804 865\n",
      "checkcorrect (3975, 32, 4551) (3975, 32, 4551) real score 0.8976265698671342 Hits@1 0.3560794044665012 Hits@3 0.6662531017369727 Hits@10 0.9404466501240695 MRR 0.5464861052614178 rank 3 total_num 805 865\n",
      "checkcorrect (4475, 120, 4419) (4475, 120, 4419) real score 0.8097361832857132 Hits@1 0.355638166047088 Hits@3 0.6654275092936803 Hits@10 0.9405204460966543 MRR 0.5461187123180951 rank 3 total_num 806 865\n",
      "checkcorrect (4004, 16, 4264) (4004, 16, 4264) real score 0.972113162279129 Hits@1 0.3564356435643564 Hits@3 0.6658415841584159 Hits@10 0.9405940594059405 MRR 0.5466804465850281 rank 0 total_num 807 865\n",
      "checkcorrect (3728, 24, 3858) (3728, 24, 3858) real score 0.9628605812788009 Hits@1 0.3572311495673671 Hits@3 0.6662546353522868 Hits@10 0.9406674907292955 MRR 0.5472407921393112 rank 0 total_num 808 865\n",
      "checkcorrect (4127, 420, 4193) (4127, 420, 4193) real score 0.8201774328947067 Hits@1 0.3567901234567901 Hits@3 0.6654320987654321 Hits@10 0.9407407407407408 MRR 0.5467415530661234 rank 6 total_num 809 865\n",
      "checkcorrect (5043, 172, 4161) (5043, 172, 4161) real score 0.9316813558340072 Hits@1 0.3563501849568434 Hits@3 0.6658446362515413 Hits@10 0.9408138101109741 MRR 0.5464784109949362 rank 2 total_num 810 865\n",
      "checkcorrect (4785, 52, 3927) (4785, 52, 3927) real score 0.9470353543758392 Hits@1 0.35591133004926107 Hits@3 0.666256157635468 Hits@10 0.9408866995073891 MRR 0.5464211715725286 rank 1 total_num 811 865\n",
      "checkcorrect (4378, 112, 5592) (4378, 112, 5592) real score 0.7755631983280182 Hits@1 0.35547355473554737 Hits@3 0.6666666666666666 Hits@10 0.940959409594096 MRR 0.5461590709104878 rank 2 total_num 812 865\n",
      "checkcorrect (5164, 54, 3669) (5164, 54, 3669) real score 0.9284939169883728 Hits@1 0.35503685503685506 Hits@3 0.6658476658476659 Hits@10 0.941031941031941 MRR 0.5457952391280424 rank 3 total_num 813 865\n",
      "checkcorrect (6126, 236, 3746) (6126, 236, 3746) real score 0.7330701619386673 Hits@1 0.35460122699386504 Hits@3 0.6650306748466258 Hits@10 0.9411042944785276 MRR 0.5454323001843271 rank 3 total_num 814 865\n",
      "checkcorrect (5182, 78, 3799) (5182, 78, 3799) real score 0.982734739780426 Hits@1 0.3541666666666667 Hits@3 0.6654411764705882 Hits@10 0.9411764705882353 MRR 0.5453766233458659 rank 1 total_num 815 865\n",
      "checkcorrect (5503, 46, 3834) (5503, 46, 3834) real score 0.4094922751188278 Hits@1 0.3537331701346389 Hits@3 0.6646266829865362 Hits@10 0.9400244798041616 MRR 0.5447906870463809 rank 14 total_num 816 865\n",
      "checkcorrect (4953, 26, 4055) (4953, 26, 4055) real score 0.9197872817516327 Hits@1 0.3533007334963325 Hits@3 0.6638141809290954 Hits@10 0.9400977995110025 MRR 0.5442993257454161 rank 6 total_num 817 865\n",
      "checkcorrect (3750, 20, 4412) (3750, 20, 4412) real score 0.9774332255125046 Hits@1 0.3528693528693529 Hits@3 0.6642246642246642 Hits@10 0.9401709401709402 MRR 0.5442452362145914 rank 1 total_num 818 865\n",
      "checkcorrect (3879, 122, 3733) (3879, 122, 3733) real score 0.9650003373622894 Hits@1 0.3524390243902439 Hits@3 0.6646341463414634 Hits@10 0.9402439024390243 MRR 0.5441912786094517 rank 1 total_num 819 865\n",
      "checkcorrect (5349, 44, 3880) (5349, 44, 3880) real score 0.9376594305038453 Hits@1 0.3520097442143727 Hits@3 0.6650426309378806 Hits@10 0.9403166869671132 MRR 0.5441374524479298 rank 1 total_num 820 865\n",
      "checkcorrect (3954, 24, 3987) (3954, 24, 3987) real score 0.9488295316696167 Hits@1 0.35279805352798055 Hits@3 0.6654501216545012 Hits@10 0.940389294403893 MRR 0.5446920297563873 rank 0 total_num 821 865\n",
      "checkcorrect (4262, 100, 4971) (4262, 100, 4971) real score 0.43465715944766997 Hits@1 0.35236938031591736 Hits@3 0.6646415552855407 Hits@10 0.9404617253948967 MRR 0.5442037735147115 rank 6 total_num 822 865\n",
      "checkcorrect (4087, 56, 3752) (4087, 56, 3752) real score 0.9422611862421035 Hits@1 0.35315533980582525 Hits@3 0.6650485436893204 Hits@10 0.9405339805825242 MRR 0.5447569242750091 rank 0 total_num 823 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4731, 118, 3713) (4731, 118, 3713) real score 0.9881061285734176 Hits@1 0.35393939393939394 Hits@3 0.6654545454545454 Hits@10 0.9406060606060606 MRR 0.5453087340637667 rank 0 total_num 824 865\n",
      "checkcorrect (5503, 4, 3864) (5503, 4, 3864) real score 0.899427130818367 Hits@1 0.35351089588377727 Hits@3 0.6646489104116223 Hits@10 0.940677966101695 MRR 0.5449512174365708 rank 3 total_num 825 865\n",
      "checkcorrect (6120, 2, 4582) (6120, 2, 4582) real score 0.7708973571658135 Hits@1 0.35308343409915355 Hits@3 0.6638452237001209 Hits@10 0.9407496977025392 MRR 0.5444434166899729 rank 7 total_num 826 865\n",
      "checkcorrect (5415, 30, 5394) (5415, 30, 5394) real score 0.43712673187255857 Hits@1 0.3526570048309179 Hits@3 0.6630434782608695 Hits@10 0.9408212560386473 MRR 0.5439368425152264 rank 7 total_num 827 865\n",
      "checkcorrect (4998, 54, 3712) (4998, 54, 3712) real score 0.9291364043951035 Hits@1 0.35223160434258144 Hits@3 0.6622436670687576 Hits@10 0.9396863691194209 MRR 0.5433903675434458 rank 10 total_num 828 865\n",
      "checkcorrect (4722, 222, 5464) (4722, 222, 5464) real score 0.8371761947870255 Hits@1 0.35180722891566263 Hits@3 0.6626506024096386 Hits@10 0.9397590361445783 MRR 0.5431372867793373 rank 2 total_num 829 865\n",
      "checkcorrect (5413, 2, 3780) (5413, 2, 3780) real score 0.9556410998106003 Hits@1 0.3525872442839952 Hits@3 0.6630565583634176 Hits@10 0.9398315282791817 MRR 0.5436870614041516 rank 0 total_num 830 865\n",
      "checkcorrect (5292, 126, 4413) (5292, 126, 4413) real score 0.9151635229587555 Hits@1 0.35216346153846156 Hits@3 0.6634615384615384 Hits@10 0.9399038461538461 MRR 0.5436345529168869 rank 1 total_num 831 865\n",
      "checkcorrect (3879, 30, 5083) (3879, 30, 5083) real score 0.4102978527545929 Hits@1 0.3517406962785114 Hits@3 0.6626650660264105 Hits@10 0.9399759903961584 MRR 0.5431534275746783 rank 6 total_num 832 865\n",
      "checkcorrect (3973, 54, 3669) (3973, 54, 3669) real score 0.9057347565889358 Hits@1 0.3513189448441247 Hits@3 0.6618705035971223 Hits@10 0.9400479616306955 MRR 0.5426220685488095 rank 9 total_num 833 865\n",
      "checkcorrect (4754, 168, 4774) (4754, 168, 4774) real score 0.9788752883672714 Hits@1 0.3520958083832335 Hits@3 0.6622754491017964 Hits@10 0.9401197604790419 MRR 0.5431698265505475 rank 0 total_num 834 865\n",
      "checkcorrect (3673, 4, 3864) (3673, 4, 3864) real score 0.9424082875251769 Hits@1 0.35167464114832536 Hits@3 0.6614832535885168 Hits@10 0.9401913875598086 MRR 0.5428191449398411 rank 3 total_num 835 865\n",
      "checkcorrect (4900, 4, 3864) (4900, 4, 3864) real score 0.9422521114349365 Hits@1 0.35125448028673834 Hits@3 0.6618876941457587 Hits@10 0.94026284348865 MRR 0.5427679870605819 rank 1 total_num 836 865\n",
      "checkcorrect (4114, 16, 4113) (4114, 16, 4113) real score 0.9622639030218124 Hits@1 0.35083532219570407 Hits@3 0.6610978520286396 Hits@10 0.9403341288782816 MRR 0.5424186219208915 rank 3 total_num 837 865\n",
      "checkcorrect (4024, 162, 5230) (4024, 162, 5230) real score 0.8169737130403518 Hits@1 0.3504171632896305 Hits@3 0.6603098927294399 Hits@10 0.9404052443384983 MRR 0.5420700895944066 rank 3 total_num 838 865\n",
      "checkcorrect (4387, 56, 3826) (4387, 56, 3826) real score 0.9173862934112549 Hits@1 0.35 Hits@3 0.6607142857142857 Hits@10 0.9404761904761905 MRR 0.5420200061544133 rank 1 total_num 839 865\n",
      "checkcorrect (4336, 2, 3902) (4336, 2, 3902) real score 0.9217052757740021 Hits@1 0.34958382877526756 Hits@3 0.6599286563614745 Hits@10 0.9405469678953626 MRR 0.5416133236262867 rank 4 total_num 840 865\n",
      "checkcorrect (5379, 52, 5264) (5379, 52, 5264) real score 0.9464901894330979 Hits@1 0.3491686460807601 Hits@3 0.6591448931116389 Hits@10 0.9406175771971497 MRR 0.5412076070899134 rank 4 total_num 841 865\n",
      "checkcorrect (3999, 56, 3888) (3999, 56, 3888) real score 0.9262282878160477 Hits@1 0.3487544483985765 Hits@3 0.6595492289442467 Hits@10 0.9406880189798339 MRR 0.5409610183903207 rank 2 total_num 842 865\n",
      "checkcorrect (5466, 0, 3741) (5466, 0, 3741) real score 0.7579005993902683 Hits@1 0.34834123222748814 Hits@3 0.6587677725118484 Hits@10 0.9395734597156398 MRR 0.5404188054933338 rank 11 total_num 843 865\n",
      "checkcorrect (4462, 24, 4081) (4462, 24, 4081) real score 0.8579139500856399 Hits@1 0.3479289940828402 Hits@3 0.6579881656804734 Hits@10 0.9396449704142011 MRR 0.5399764952698703 rank 5 total_num 844 865\n",
      "checkcorrect (3684, 24, 4010) (3684, 24, 4010) real score 0.9240581974387169 Hits@1 0.3475177304964539 Hits@3 0.6583924349881797 Hits@10 0.9397163120567376 MRR 0.5397322362132078 rank 2 total_num 845 865\n",
      "checkcorrect (4033, 50, 4565) (4033, 50, 4565) real score 0.9235050648450851 Hits@1 0.34710743801652894 Hits@3 0.6587957497048406 Hits@10 0.9397874852420307 MRR 0.5394885539193708 rank 2 total_num 846 865\n",
      "checkcorrect (3678, 162, 4961) (3678, 162, 4961) real score 0.9373695433139801 Hits@1 0.34787735849056606 Hits@3 0.6591981132075472 Hits@10 0.9398584905660378 MRR 0.5400316098699376 rank 0 total_num 847 865\n",
      "checkcorrect (4855, 2, 4502) (4855, 2, 4502) real score 0.9416431874036788 Hits@1 0.3486454652532391 Hits@3 0.6595995288574794 Hits@10 0.9399293286219081 MRR 0.5405733865367573 rank 0 total_num 848 865\n",
      "checkcorrect (3720, 92, 5249) (3720, 92, 5249) real score 0.9725704520940781 Hits@1 0.34941176470588237 Hits@3 0.66 Hits@10 0.94 MRR 0.5411138884349495 rank 0 total_num 849 865\n",
      "checkcorrect (5929, 240, 4422) (5929, 240, 4422) real score 0.8315686970949172 Hits@1 0.3490011750881316 Hits@3 0.6603995299647474 Hits@10 0.9400705052878966 MRR 0.5408697279706702 rank 2 total_num 850 865\n",
      "checkcorrect (4152, 202, 5994) (4152, 202, 5994) real score 0.8484562933444977 Hits@1 0.34976525821596244 Hits@3 0.6607981220657277 Hits@10 0.9401408450704225 MRR 0.5414086132664793 rank 0 total_num 851 865\n",
      "checkcorrect (4059, 126, 3839) (4059, 126, 3839) real score 0.7905343890190124 Hits@1 0.3493552168815944 Hits@3 0.6600234466588512 Hits@10 0.94021101992966 MRR 0.5409204437315831 rank 7 total_num 852 865\n",
      "checkcorrect (4549, 56, 4371) (4549, 56, 4371) real score 0.938153651356697 Hits@1 0.35011709601873536 Hits@3 0.6604215456674473 Hits@10 0.9402810304449649 MRR 0.5414580076148013 rank 0 total_num 853 865\n",
      "checkcorrect (5795, 100, 6150) (5795, 100, 6150) real score 0.9241938620805741 Hits@1 0.3497076023391813 Hits@3 0.6596491228070176 Hits@10 0.9403508771929825 MRR 0.5411171210561876 rank 3 total_num 854 865\n",
      "checkcorrect (4843, 26, 4230) (4843, 26, 4230) real score 0.9790119349956512 Hits@1 0.35046728971962615 Hits@3 0.6600467289719626 Hits@10 0.9404205607476636 MRR 0.5416531991857948 rank 0 total_num 855 865\n",
      "checkcorrect (5098, 100, 6150) (5098, 100, 6150) real score 0.4439147114753723 Hits@1 0.3500583430571762 Hits@3 0.6592765460910152 Hits@10 0.9393232205367561 MRR 0.5410940939358697 rank 15 total_num 856 865\n",
      "checkcorrect (4258, 176, 3809) (4258, 176, 3809) real score 0.9826251685619354 Hits@1 0.3508158508158508 Hits@3 0.6596736596736597 Hits@10 0.9393939393939394 MRR 0.5416289493042429 rank 0 total_num 857 865\n",
      "checkcorrect (4228, 74, 3787) (4228, 74, 3787) real score 0.9540180563926697 Hits@1 0.35157159487776485 Hits@3 0.660069848661234 Hits@10 0.9394644935972061 MRR 0.5421625593749014 rank 0 total_num 858 865\n",
      "checkcorrect (4723, 364, 4217) (4723, 364, 4217) real score 0.9598780453205109 Hits@1 0.35232558139534886 Hits@3 0.6604651162790698 Hits@10 0.9395348837209302 MRR 0.5426949284919074 rank 0 total_num 859 865\n",
      "checkcorrect (3914, 54, 3712) (3914, 54, 3712) real score 0.9064129948616029 Hits@1 0.3519163763066202 Hits@3 0.6596980255516841 Hits@10 0.9396051103368177 MRR 0.5421807648118936 rank 9 total_num 860 865\n",
      "checkcorrect (4730, 54, 3669) (4730, 54, 3669) real score 0.9812941759824753 Hits@1 0.35266821345707655 Hits@3 0.660092807424594 Hits@10 0.9396751740139211 MRR 0.542711877613736 rank 0 total_num 861 865\n",
      "checkcorrect (4725, 126, 3681) (4725, 126, 3681) real score 0.902661269903183 Hits@1 0.3522595596755504 Hits@3 0.660486674391657 Hits@10 0.9397450753186558 MRR 0.5426623852874164 rank 1 total_num 862 865\n",
      "checkcorrect (4098, 4, 3864) (4098, 4, 3864) real score 0.9393864095211029 Hits@1 0.35185185185185186 Hits@3 0.6608796296296297 Hits@10 0.9398148148148148 MRR 0.5426130075266671 rank 1 total_num 863 865\n",
      "checkcorrect (4694, 110, 4360) (4694, 110, 4360) real score 0.9418247878551483 Hits@1 0.35260115606936415 Hits@3 0.661271676300578 Hits@10 0.9398843930635838 MRR 0.5431417786162317 rank 0 total_num 864 865\n"
     ]
    }
   ],
   "source": [
    "######################################################\n",
    "#obtain the Hits@N for entity prediction##############\n",
    "\n",
    "#we select all the triples in the inductive test set\n",
    "selected = list(data_ind_test)\n",
    "\n",
    "###Hit at 1#############################\n",
    "#generate the negative samples by randomly replace relation with all the other relaiton\n",
    "Hits_at_1 = 0\n",
    "Hits_at_3 = 0\n",
    "Hits_at_10 = 0\n",
    "MRR_raw = 0.\n",
    "\n",
    "for i in range(len(selected)):\n",
    "    \n",
    "    triple_list = list()\n",
    "    \n",
    "    #score the true triple\n",
    "    s_pos, r_pos, t_pos = selected[i][0], selected[i][1], selected[i][2]\n",
    "\n",
    "    path_score = path_based_triple_scoring(s_pos, r_pos, t_pos, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "\n",
    "    subg_score = subgraph_triple_scoring(s_pos, r_pos, t_pos, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "    \n",
    "    ave_score = (path_score + subg_score)/float(2)\n",
    "    \n",
    "    triple_list.append([(s_pos, r_pos, t_pos), ave_score])\n",
    "    \n",
    "    #generate the 50 random samples\n",
    "    for sub_i in range(50):\n",
    "        \n",
    "        #decide to replace the head or tail entity\n",
    "        number_0 = random.uniform(0, 1)\n",
    "\n",
    "        if number_0 < 0.5: #replace head entity\n",
    "            \n",
    "            s_neg = random.choice(list(new_ent_set))\n",
    "            \n",
    "            while ((s_neg, r_pos, t_pos) in data_test) or (\n",
    "                   (s_neg, r_pos, t_pos) in data_valid) or (\n",
    "                   (s_neg, r_pos, t_pos) in data) or (\n",
    "                   (s_neg, r_pos, t_pos) in data_ind) or (\n",
    "                   (s_neg, r_pos, t_pos) in data_ind_valid) or (\n",
    "                   (s_neg, r_pos, t_pos) in data_ind_test):\n",
    "\n",
    "                s_neg = random.choice(list(new_ent_set))\n",
    "            \n",
    "            path_score = path_based_triple_scoring(s_neg, r_pos, t_pos, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "\n",
    "            subg_score = subgraph_triple_scoring(s_neg, r_pos, t_pos, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "\n",
    "            ave_score = (path_score + subg_score)/float(2)\n",
    "\n",
    "            triple_list.append([(s_neg, r_pos, t_pos), ave_score])\n",
    "            \n",
    "        else: #replace tail entity\n",
    "\n",
    "            t_neg = random.choice(list(new_ent_set))\n",
    "            \n",
    "            #filter out the existing triples\n",
    "            while ((s_pos, r_pos, t_neg) in data_test) or (\n",
    "                   (s_pos, r_pos, t_neg) in data_valid) or (\n",
    "                   (s_pos, r_pos, t_neg) in data) or (\n",
    "                   (s_pos, r_pos, t_neg) in data_ind) or (\n",
    "                   (s_pos, r_pos, t_neg) in data_ind_valid) or (\n",
    "                   (s_pos, r_pos, t_neg) in data_ind_test):\n",
    "\n",
    "                t_neg = random.choice(list(new_ent_set))\n",
    "            \n",
    "            path_score = path_based_triple_scoring(s_pos, r_pos, t_neg, lower_bound, upper_bound_path, one_hop_ind, id2relation, model)\n",
    "\n",
    "            subg_score = subgraph_triple_scoring(s_pos, r_pos, t_neg, lower_bound, upper_bound_subg, one_hop_ind, id2relation, model_2)\n",
    "\n",
    "            ave_score = (path_score + subg_score)/float(2)\n",
    "\n",
    "            triple_list.append([(s_pos, r_pos, t_neg), ave_score])\n",
    "            \n",
    "    #random shuffle!\n",
    "    random.shuffle(triple_list)\n",
    "    \n",
    "    #sort\n",
    "    sorted_list = sorted(triple_list, key = lambda x: x[-1], reverse=True)\n",
    "    \n",
    "    p = 0\n",
    "    \n",
    "    while p < len(sorted_list) and sorted_list[p][0] != (s_pos, r_pos, t_pos):\n",
    "            \n",
    "        p += 1\n",
    "    \n",
    "    if p == 0:\n",
    "        \n",
    "        Hits_at_1 += 1\n",
    "        \n",
    "    if p < 3:\n",
    "        \n",
    "        Hits_at_3 += 1\n",
    "        \n",
    "    if p < 10:\n",
    "        \n",
    "        Hits_at_10 += 1\n",
    "        \n",
    "    MRR_raw += 1./float(p + 1.) \n",
    "        \n",
    "    print('checkcorrect', (s_pos, r_pos, t_pos), sorted_list[p][0],\n",
    "          'real score', sorted_list[p][-1],\n",
    "          'Hits@1', Hits_at_1/(i+1),\n",
    "          'Hits@3', Hits_at_3/(i+1),\n",
    "          'Hits@10', Hits_at_10/(i+1),\n",
    "          'MRR', MRR_raw/(i+1),\n",
    "          'rank', p,\n",
    "          'total_num', i, len(selected))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a50b1482",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36c0464d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c23edb1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a10052e8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ee5bc67",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "99b6af14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "998880eb",
   "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.9.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
