{
 "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_6_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:33.944270: 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",
    "source_path_4 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "source_path_5 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "source_path_6 = 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",
    "target_path_4 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "target_path_5 = keras.Input(shape=(None,), dtype=\"int32\")\n",
    "target_path_6 = 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",
    "#the source and target embedding and separate\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",
    "source_embd_4 = in_embd_var_(source_path_4)\n",
    "source_embd_5 = in_embd_var_(source_path_5)\n",
    "source_embd_6 = in_embd_var_(source_path_6)\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",
    "target_embd_4 = in_embd_var_(target_path_4)\n",
    "target_embd_5 = in_embd_var_(target_path_5)\n",
    "target_embd_6 = in_embd_var_(target_path_6)\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",
    "source_mid_4 = lstm_1(source_embd_4)\n",
    "source_mid_5 = lstm_1(source_embd_5)\n",
    "source_mid_6 = lstm_1(source_embd_6)\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",
    "source_out_4 = lstm_2(source_mid_4)\n",
    "source_out_5 = lstm_2(source_mid_5)\n",
    "source_out_6 = lstm_2(source_mid_6)\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",
    "source_max_4 = tf.reduce_max(source_out_4, axis=1)\n",
    "source_max_5 = tf.reduce_max(source_out_5, axis=1)\n",
    "source_max_6 = tf.reduce_max(source_out_6, axis=1)\n",
    "\n",
    "#concatenate the output vector from both siamese tunnel: (Batch, 900)\n",
    "source_concat = layers.concatenate([source_max_1, \n",
    "                                    source_max_2, \n",
    "                                    source_max_3,\n",
    "                                    source_max_4,\n",
    "                                    source_max_5,\n",
    "                                    source_max_6], 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",
    "target_mid_4 = lstm_1(target_embd_4)\n",
    "target_mid_5 = lstm_1(target_embd_5)\n",
    "target_mid_6 = lstm_1(target_embd_6)\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",
    "target_out_4 = lstm_2(target_mid_4)\n",
    "target_out_5 = lstm_2(target_mid_5)\n",
    "target_out_6 = lstm_2(target_mid_6)\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",
    "target_max_4 = tf.reduce_max(target_out_4, axis=1)\n",
    "target_max_5 = tf.reduce_max(target_out_5, axis=1)\n",
    "target_max_6 = tf.reduce_max(target_out_6, axis=1)\n",
    "\n",
    "#concatenate the output vector from both siamese tunnel: (Batch, 900)\n",
    "target_concat = layers.concatenate([target_max_1, \n",
    "                                    target_max_2, \n",
    "                                    target_max_3,\n",
    "                                    target_max_4,\n",
    "                                    target_max_5,\n",
    "                                    target_max_6], 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, source_path_4,\n",
    "                       source_path_5, source_path_6,\n",
    "                       target_path_1, target_path_2, target_path_3, target_path_4, \n",
    "                       target_path_5, target_path_6,\n",
    "                       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]) >= 6:\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, 6)\n",
    "                temp_t = random.sample(path_t, 6)\n",
    "                s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\n",
    "                t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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, 6)\n",
    "                temp_t = random.sample(path_t, 6)\n",
    "                s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\n",
    "                t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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, 6)\n",
    "                s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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, 6)\n",
    "                temp_t = random.sample(path_t, 6)\n",
    "                s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\n",
    "                t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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, 6)\n",
    "                t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "                x_s_list['4'].append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                x_s_list['5'].append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                x_s_list['6'].append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                x_t_list['4'].append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))\n",
    "                x_t_list['5'].append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))\n",
    "                x_t_list['6'].append(list(t_p_6) + [num_r]*abs(len(t_p_6)-upper_bd))\n",
    "\n",
    "                #append relation\n",
    "                x_r_list.append([r])\n",
    "                y_list.append(0.)\n",
    "\n",
    "            if i_0 % 2000 == 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_6_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_6_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_6_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",
      "2853/2853 [==============================] - 249s 84ms/step - loss: 0.3199 - binary_accuracy: 0.8916 - val_loss: 0.2748 - val_binary_accuracy: 0.9044\n",
      "Epoch 2/10\n",
      "2853/2853 [==============================] - 241s 84ms/step - loss: 0.2389 - binary_accuracy: 0.9272 - val_loss: 0.2593 - val_binary_accuracy: 0.9310\n",
      "Epoch 3/10\n",
      "2853/2853 [==============================] - 240s 84ms/step - loss: 0.2166 - binary_accuracy: 0.9375 - val_loss: 0.2148 - val_binary_accuracy: 0.9373\n",
      "Epoch 4/10\n",
      "2853/2853 [==============================] - 244s 85ms/step - loss: 0.1956 - binary_accuracy: 0.9446 - val_loss: 0.2165 - val_binary_accuracy: 0.9366\n",
      "Epoch 5/10\n",
      "2853/2853 [==============================] - 242s 85ms/step - loss: 0.1713 - binary_accuracy: 0.9509 - val_loss: 0.1966 - val_binary_accuracy: 0.9353\n",
      "Epoch 6/10\n",
      "2853/2853 [==============================] - 228s 80ms/step - loss: 0.1536 - binary_accuracy: 0.9569 - val_loss: 0.1877 - val_binary_accuracy: 0.9506\n",
      "Epoch 7/10\n",
      "2853/2853 [==============================] - 214s 75ms/step - loss: 0.1304 - binary_accuracy: 0.9642 - val_loss: 0.1940 - val_binary_accuracy: 0.9474\n",
      "Epoch 8/10\n",
      "2853/2853 [==============================] - 215s 75ms/step - loss: 0.1150 - binary_accuracy: 0.9691 - val_loss: 0.2095 - val_binary_accuracy: 0.9479\n",
      "Epoch 9/10\n",
      "2853/2853 [==============================] - 2146s 752ms/step - loss: 0.1024 - binary_accuracy: 0.9733 - val_loss: 0.2187 - val_binary_accuracy: 0.9469\n",
      "Epoch 10/10\n",
      "2853/2853 [==============================] - 217s 76ms/step - loss: 0.0930 - binary_accuracy: 0.9766 - val_loss: 0.2212 - val_binary_accuracy: 0.9484\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 2000 7940 0\n",
      "generating big-batches for subgraph-based model 4000 7940 0\n",
      "generating big-batches for subgraph-based model 6000 7940 0\n",
      "generating big-batches for subgraph-based model 0 7940 1\n",
      "generating big-batches for subgraph-based model 2000 7940 1\n",
      "generating big-batches for subgraph-based model 4000 7940 1\n",
      "generating big-batches for subgraph-based model 6000 7940 1\n",
      "generating big-batches for subgraph-based model 0 7940 2\n",
      "generating big-batches for subgraph-based model 2000 7940 2\n",
      "generating big-batches for subgraph-based model 4000 7940 2\n",
      "generating big-batches for subgraph-based model 6000 7940 2\n",
      "generating big-batches for subgraph-based model 0 7940 3\n",
      "generating big-batches for subgraph-based model 2000 7940 3\n",
      "generating big-batches for subgraph-based model 4000 7940 3\n",
      "generating big-batches for subgraph-based model 6000 7940 3\n",
      "generating big-batches for subgraph-based model 0 7940 4\n",
      "generating big-batches for subgraph-based model 2000 7940 4\n",
      "generating big-batches for subgraph-based model 4000 7940 4\n",
      "generating big-batches for subgraph-based model 6000 7940 4\n",
      "generating big-batches for subgraph-based model 0 7940 5\n",
      "generating big-batches for subgraph-based model 2000 7940 5\n",
      "generating big-batches for subgraph-based model 4000 7940 5\n",
      "generating big-batches for subgraph-based model 6000 7940 5\n",
      "generating big-batches for subgraph-based model 0 7940 6\n",
      "generating big-batches for subgraph-based model 2000 7940 6\n",
      "generating big-batches for subgraph-based model 4000 7940 6\n",
      "generating big-batches for subgraph-based model 6000 7940 6\n",
      "generating big-batches for subgraph-based model 0 7940 7\n",
      "generating big-batches for subgraph-based model 2000 7940 7\n",
      "generating big-batches for subgraph-based model 4000 7940 7\n",
      "generating big-batches for subgraph-based model 6000 7940 7\n",
      "generating big-batches for subgraph-based model 0 7940 8\n",
      "generating big-batches for subgraph-based model 2000 7940 8\n",
      "generating big-batches for subgraph-based model 4000 7940 8\n",
      "generating big-batches for subgraph-based model 6000 7940 8\n",
      "generating big-batches for subgraph-based model 0 7940 9\n",
      "generating big-batches for subgraph-based model 2000 7940 9\n",
      "generating big-batches for subgraph-based model 4000 7940 9\n",
      "generating big-batches for subgraph-based model 6000 7940 9\n",
      "generating big-batches for subgraph-based model 0 934 0\n",
      "generating big-batches for subgraph-based model 0 934 1\n",
      "generating big-batches for subgraph-based model 0 934 2\n",
      "generating big-batches for subgraph-based model 0 934 3\n",
      "generating big-batches for subgraph-based model 0 934 4\n",
      "generating big-batches for subgraph-based model 0 934 5\n",
      "generating big-batches for subgraph-based model 0 934 6\n",
      "generating big-batches for subgraph-based model 0 934 7\n",
      "generating big-batches for subgraph-based model 0 934 8\n",
      "generating big-batches for subgraph-based model 0 934 9\n",
      "Epoch 1/10\n",
      "14680/14680 [==============================] - 1561s 104ms/step - loss: 0.5072 - binary_accuracy: 0.7731 - val_loss: 0.4159 - val_binary_accuracy: 0.7900\n",
      "Epoch 2/10\n",
      "14680/14680 [==============================] - 1513s 103ms/step - loss: 0.4168 - binary_accuracy: 0.8079 - val_loss: 0.3984 - val_binary_accuracy: 0.8167\n",
      "Epoch 3/10\n",
      "14680/14680 [==============================] - 1515s 103ms/step - loss: 0.4019 - binary_accuracy: 0.8172 - val_loss: 0.3945 - val_binary_accuracy: 0.8053\n",
      "Epoch 4/10\n",
      "14680/14680 [==============================] - 1510s 103ms/step - loss: 0.3956 - binary_accuracy: 0.8214 - val_loss: 0.4221 - val_binary_accuracy: 0.7813\n",
      "Epoch 5/10\n",
      "14680/14680 [==============================] - 1521s 104ms/step - loss: 0.3917 - binary_accuracy: 0.8238 - val_loss: 0.3697 - val_binary_accuracy: 0.8233\n",
      "Epoch 6/10\n",
      "14680/14680 [==============================] - 1039s 71ms/step - loss: 0.3879 - binary_accuracy: 0.8255 - val_loss: 0.3727 - val_binary_accuracy: 0.8250\n",
      "Epoch 7/10\n",
      "14680/14680 [==============================] - 751s 51ms/step - loss: 0.3849 - binary_accuracy: 0.8271 - val_loss: 0.3740 - val_binary_accuracy: 0.8233\n",
      "Epoch 8/10\n",
      "14680/14680 [==============================] - 750s 51ms/step - loss: 0.3828 - binary_accuracy: 0.8282 - val_loss: 0.3648 - val_binary_accuracy: 0.8290\n",
      "Epoch 9/10\n",
      "14680/14680 [==============================] - 771s 53ms/step - loss: 0.3809 - binary_accuracy: 0.8297 - val_loss: 0.3720 - val_binary_accuracy: 0.8277\n",
      "Epoch 10/10\n",
      "14680/14680 [==============================] - 775s 53ms/step - loss: 0.3789 - binary_accuracy: 0.8309 - val_loss: 0.3625 - val_binary_accuracy: 0.8343\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': [], '4': [], '5': [], '6': []}, {'1': [], '2': [], '3': [], '4': [], '5': [], '6': []}, list(), list()\n",
    "\n",
    "#define the validation lists\n",
    "valid_s_list, valid_t_list, valid_r_list, valid_y_list = {'1': [], '2': [], '3': [], '4': [], '5': [], '6': []}, {'1': [], '2': [], '3': [], '4': [], '5': [], '6': []}, 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",
    "    x_train_s_4 = np.asarray(train_s_list['4'], dtype='int')\n",
    "    x_train_s_5 = np.asarray(train_s_list['5'], dtype='int')\n",
    "    x_train_s_6 = np.asarray(train_s_list['6'], 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",
    "    x_train_t_4 = np.asarray(train_t_list['4'], dtype='int')\n",
    "    x_train_t_5 = np.asarray(train_t_list['5'], dtype='int')\n",
    "    x_train_t_6 = np.asarray(train_t_list['6'], 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",
    "    x_valid_s_4 = np.asarray(valid_s_list['4'], dtype='int')\n",
    "    x_valid_s_5 = np.asarray(valid_s_list['5'], dtype='int')\n",
    "    x_valid_s_6 = np.asarray(valid_s_list['6'], 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",
    "    x_valid_t_4 = np.asarray(valid_t_list['4'], dtype='int')\n",
    "    x_valid_t_5 = np.asarray(valid_t_list['5'], dtype='int')\n",
    "    x_valid_t_6 = np.asarray(valid_t_list['6'], 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",
    "    x_train_s_4 = np.asarray(train_s_list['4'][:split], dtype='int')\n",
    "    x_train_s_5 = np.asarray(train_s_list['5'][:split], dtype='int')\n",
    "    x_train_s_6 = np.asarray(train_s_list['6'][: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",
    "    x_train_t_4 = np.asarray(train_t_list['4'][:split], dtype='int')\n",
    "    x_train_t_5 = np.asarray(train_t_list['5'][:split], dtype='int')\n",
    "    x_train_t_6 = np.asarray(train_t_list['6'][: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",
    "    x_valid_s_4 = np.asarray(train_s_list['4'][split:], dtype='int')\n",
    "    x_valid_s_5 = np.asarray(train_s_list['5'][split:], dtype='int')\n",
    "    x_valid_s_6 = np.asarray(train_s_list['6'][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",
    "    x_valid_t_4 = np.asarray(train_t_list['4'][split:], dtype='int')\n",
    "    x_valid_t_5 = np.asarray(train_t_list['5'][split:], dtype='int')\n",
    "    x_valid_t_6 = np.asarray(train_t_list['6'][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_s_4, x_train_s_5, x_train_s_6,\n",
    "             x_train_t_1, x_train_t_2, x_train_t_3, x_train_t_4, x_train_t_5, x_train_t_6,\n",
    "             x_train_r], y_train, \n",
    "          validation_data=([x_valid_s_1, x_valid_s_2, x_valid_s_3, x_valid_s_4, x_valid_s_5, x_valid_s_6,\n",
    "                            x_valid_t_1, x_valid_t_2, x_valid_t_3, x_valid_t_4, x_valid_t_5, x_valid_t_6,\n",
    "                            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_6_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_6_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_6_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_6_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_6_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_6_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:12:08.835144: 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) >= 6 and len(path_t) >= 6:\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_s_4 = list()\n",
    "            list_s_5 = list()\n",
    "            list_s_6 = list()\n",
    "            \n",
    "            list_t_1 = list()\n",
    "            list_t_2 = list()\n",
    "            list_t_3 = list()\n",
    "            list_t_4 = list()\n",
    "            list_t_5 = list()\n",
    "            list_t_6 = list()\n",
    "\n",
    "            list_r = list()\n",
    "\n",
    "            #randomly obtain three paths\n",
    "            temp_s = random.sample(path_s, 6)\n",
    "            temp_t = random.sample(path_t, 6)\n",
    "            s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\n",
    "            t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "                    list_s_4.append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "                    list_s_5.append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "                    list_s_6.append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "                    list_t_4.append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))                    \n",
    "                    list_t_5.append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))                    \n",
    "                    list_t_6.append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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_s_4 = np.array(list_s_4)\n",
    "            input_s_5 = np.array(list_s_5)\n",
    "            input_s_6 = np.array(list_s_6)\n",
    "            \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_t_4 = np.array(list_t_4)\n",
    "            input_t_5 = np.array(list_t_5)\n",
    "            input_t_6 = np.array(list_t_6)\n",
    "            \n",
    "            input_r = np.array(list_r)\n",
    "            \n",
    "            pred = model_2.predict([input_s_1, input_s_2, input_s_3, input_s_4,\n",
    "                                    input_s_5, input_s_6,\n",
    "                                    input_t_1, input_t_2, input_t_3, input_t_4,\n",
    "                                    input_t_5, input_t_6,\n",
    "                                    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) >= 6 and len(path_t) >= 6:\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_s_4 = list()\n",
    "        list_s_5 = list()\n",
    "        list_s_6 = list()\n",
    "\n",
    "        list_t_1 = list()\n",
    "        list_t_2 = list()\n",
    "        list_t_3 = list()\n",
    "        list_t_4 = list()\n",
    "        list_t_5 = list()\n",
    "        list_t_6 = list()\n",
    "        \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, 6)\n",
    "            temp_t = random.sample(path_t, 6)\n",
    "            s_p_1, s_p_2, s_p_3, s_p_4, s_p_5, s_p_6 = temp_s[0], temp_s[1], temp_s[2], temp_s[3], temp_s[4], temp_s[5]\n",
    "            t_p_1, t_p_2, t_p_3, t_p_4, t_p_5, t_p_6 = temp_t[0], temp_t[1], temp_t[2], temp_t[3], temp_t[4], temp_t[5]\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",
    "            list_s_4.append(list(s_p_4) + [num_r]*abs(len(s_p_4)-upper_bd))\n",
    "            list_s_5.append(list(s_p_5) + [num_r]*abs(len(s_p_5)-upper_bd))\n",
    "            list_s_6.append(list(s_p_6) + [num_r]*abs(len(s_p_6)-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",
    "            list_t_4.append(list(t_p_4) + [num_r]*abs(len(t_p_4)-upper_bd))                    \n",
    "            list_t_5.append(list(t_p_5) + [num_r]*abs(len(t_p_5)-upper_bd))                    \n",
    "            list_t_6.append(list(t_p_6) + [num_r]*abs(len(t_p_6)-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_s_4 = np.array(list_s_4)\n",
    "        input_s_5 = np.array(list_s_5)\n",
    "        input_s_6 = np.array(list_s_6)\n",
    "\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_t_4 = np.array(list_t_4)\n",
    "        input_t_5 = np.array(list_t_5)\n",
    "        input_t_6 = np.array(list_t_6)\n",
    "        \n",
    "        input_r = np.array(list_r)\n",
    "\n",
    "        pred = model_2.predict([input_s_1, input_s_2, input_s_3, input_s_4,\n",
    "                                input_s_5, input_s_6, \n",
    "                                input_t_1, input_t_2, input_t_3, input_t_4,\n",
    "                                input_t_5, input_t_6, \n",
    "                                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 323 698\n",
      "checkcorrect 6 6 real score 1.9839630663394927 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 cur_rank 0 abs_cur_rank 0 total_num 0 865\n",
      "215 150\n",
      "215 639 419\n",
      "checkcorrect 32 32 real score 1.9668365836143493 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 cur_rank 0 abs_cur_rank 0 total_num 1 865\n",
      "215 150\n",
      "215 267 761\n",
      "checkcorrect 44 44 real score 1.8877506375312805 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 cur_rank 0 abs_cur_rank 0 total_num 2 865\n",
      "215 150\n",
      "215 896 943\n",
      "checkcorrect 54 54 real score 1.9115858733654023 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 cur_rank 0 abs_cur_rank 0 total_num 3 865\n",
      "215 108\n",
      "215 240 199\n",
      "checkcorrect 32 32 real score 1.9595883667469023 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 cur_rank 0 abs_cur_rank 0 total_num 4 865\n",
      "215 149\n",
      "215 595 475\n",
      "checkcorrect 50 50 real score 1.7865378201007842 Hits@1 0.8333333333333334 Hits@3 1.0 Hits@10 1.0 MRR 0.9166666666666666 cur_rank 1 abs_cur_rank 1 total_num 5 865\n",
      "215 146\n",
      "215 453 404\n",
      "checkcorrect 40 40 real score 1.9168377280235291 Hits@1 0.8571428571428571 Hits@3 1.0 Hits@10 1.0 MRR 0.9285714285714286 cur_rank 0 abs_cur_rank 0 total_num 6 865\n",
      "215 150\n",
      "215 262 472\n",
      "checkcorrect 54 54 real score 1.3186963886022567 Hits@1 0.75 Hits@3 0.875 Hits@10 1.0 MRR 0.8375 cur_rank 4 abs_cur_rank 4 total_num 7 865\n",
      "215 150\n",
      "215 114 371\n",
      "checkcorrect 72 72 real score 1.7142203390598296 Hits@1 0.7777777777777778 Hits@3 0.8888888888888888 Hits@10 1.0 MRR 0.8555555555555556 cur_rank 0 abs_cur_rank 0 total_num 8 865\n",
      "0 1\n",
      "0 3 52\n",
      "checkcorrect 378 378 real score 0.0 Hits@1 0.7 Hits@3 0.8 Hits@10 0.9 MRR 0.7705263157894737 cur_rank 189 abs_cur_rank 189 total_num 9 865\n",
      "215 150\n",
      "215 744 692\n",
      "checkcorrect 0 0 real score 1.6831502825021745 Hits@1 0.7272727272727273 Hits@3 0.8181818181818182 Hits@10 0.9090909090909091 MRR 0.7913875598086125 cur_rank 0 abs_cur_rank 0 total_num 10 865\n",
      "215 150\n",
      "215 21 1604\n",
      "checkcorrect 312 312 real score 1.7700285017490387 Hits@1 0.75 Hits@3 0.8333333333333334 Hits@10 0.9166666666666666 MRR 0.8087719298245615 cur_rank 0 abs_cur_rank 0 total_num 11 865\n",
      "215 111\n",
      "215 21 828\n",
      "checkcorrect 96 96 real score 1.912877804040909 Hits@1 0.7692307692307693 Hits@3 0.8461538461538461 Hits@10 0.9230769230769231 MRR 0.8234817813765183 cur_rank 0 abs_cur_rank 0 total_num 12 865\n",
      "215 150\n",
      "215 512 446\n",
      "checkcorrect 40 40 real score 1.9347671091556549 Hits@1 0.7857142857142857 Hits@3 0.8571428571428571 Hits@10 0.9285714285714286 MRR 0.8360902255639099 cur_rank 0 abs_cur_rank 0 total_num 13 865\n",
      "215 96\n",
      "215 482 65\n",
      "checkcorrect 78 78 real score 1.928106278181076 Hits@1 0.8 Hits@3 0.8666666666666667 Hits@10 0.9333333333333333 MRR 0.8470175438596492 cur_rank 0 abs_cur_rank 0 total_num 14 865\n",
      "215 101\n",
      "215 417 240\n",
      "checkcorrect 186 186 real score 1.740577843785286 Hits@1 0.8125 Hits@3 0.875 Hits@10 0.9375 MRR 0.8565789473684211 cur_rank 0 abs_cur_rank 0 total_num 15 865\n",
      "215 150\n",
      "215 75 834\n",
      "checkcorrect 96 96 real score 1.8769066035747528 Hits@1 0.8235294117647058 Hits@3 0.8823529411764706 Hits@10 0.9411764705882353 MRR 0.865015479876161 cur_rank 0 abs_cur_rank 0 total_num 16 865\n",
      "215 31\n",
      "215 52 64\n",
      "checkcorrect 326 326 real score 1.8941374957561492 Hits@1 0.8333333333333334 Hits@3 0.8888888888888888 Hits@10 0.9444444444444444 MRR 0.872514619883041 cur_rank 0 abs_cur_rank 0 total_num 17 865\n",
      "215 150\n",
      "215 361 399\n",
      "checkcorrect 40 40 real score 1.9332623183727264 Hits@1 0.8421052631578947 Hits@3 0.8947368421052632 Hits@10 0.9473684210526315 MRR 0.8792243767313019 cur_rank 0 abs_cur_rank 0 total_num 18 865\n",
      "215 92\n",
      "215 257 210\n",
      "checkcorrect 290 290 real score 1.8266681730747223 Hits@1 0.85 Hits@3 0.9 Hits@10 0.95 MRR 0.8852631578947369 cur_rank 0 abs_cur_rank 0 total_num 19 865\n",
      "215 150\n",
      "215 546 202\n",
      "checkcorrect 6 6 real score 1.9840090751647947 Hits@1 0.8571428571428571 Hits@3 0.9047619047619048 Hits@10 0.9523809523809523 MRR 0.8907268170426066 cur_rank 0 abs_cur_rank 0 total_num 20 865\n",
      "215 150\n",
      "215 437 394\n",
      "checkcorrect 64 64 real score 1.8695675551891329 Hits@1 0.8636363636363636 Hits@3 0.9090909090909091 Hits@10 0.9545454545454546 MRR 0.8956937799043062 cur_rank 0 abs_cur_rank 0 total_num 21 865\n",
      "215 5\n",
      "215 48 119\n",
      "checkcorrect 402 402 real score 1.2213776588439942 Hits@1 0.8260869565217391 Hits@3 0.8695652173913043 Hits@10 0.9565217391304348 MRR 0.8676201372997712 cur_rank 3 abs_cur_rank 4 total_num 22 865\n",
      "215 4\n",
      "0 6 4\n",
      "checkcorrect 160 160 real score 0.9728541553020478 Hits@1 0.8333333333333334 Hits@3 0.875 Hits@10 0.9583333333333334 MRR 0.8731359649122807 cur_rank 0 abs_cur_rank 0 total_num 23 865\n",
      "215 93\n",
      "215 63 46\n",
      "checkcorrect 96 96 real score 1.8048466742038727 Hits@1 0.84 Hits@3 0.88 Hits@10 0.96 MRR 0.8782105263157896 cur_rank 0 abs_cur_rank 0 total_num 24 865\n",
      "215 97\n",
      "215 97 164\n",
      "checkcorrect 78 78 real score 1.6571310997009276 Hits@1 0.8461538461538461 Hits@3 0.8846153846153846 Hits@10 0.9615384615384616 MRR 0.8828947368421053 cur_rank 0 abs_cur_rank 0 total_num 25 865\n",
      "215 150\n",
      "215 506 586\n",
      "checkcorrect 116 116 real score 1.7501297652721406 Hits@1 0.8148148148148148 Hits@3 0.8888888888888888 Hits@10 0.9629629629629629 MRR 0.8625406107862248 cur_rank 2 abs_cur_rank 2 total_num 26 865\n",
      "215 150\n",
      "215 305 998\n",
      "checkcorrect 54 54 real score 1.8816791415214538 Hits@1 0.8214285714285714 Hits@3 0.8928571428571429 Hits@10 0.9642857142857143 MRR 0.8674498746867167 cur_rank 0 abs_cur_rank 0 total_num 27 865\n",
      "215 70\n",
      "215 495 167\n",
      "checkcorrect 30 30 real score 1.8250791490077973 Hits@1 0.8275862068965517 Hits@3 0.896551724137931 Hits@10 0.9655172413793104 MRR 0.8720205686630369 cur_rank 0 abs_cur_rank 0 total_num 28 865\n",
      "215 150\n",
      "215 322 395\n",
      "checkcorrect 54 54 real score 1.9404710590839387 Hits@1 0.8333333333333334 Hits@3 0.9 Hits@10 0.9666666666666667 MRR 0.8762865497076023 cur_rank 0 abs_cur_rank 0 total_num 29 865\n",
      "215 11\n",
      "215 89 122\n",
      "checkcorrect 424 424 real score 1.0153988026082517 Hits@1 0.8064516129032258 Hits@3 0.8709677419354839 Hits@10 0.9354838709677419 MRR 0.850707413695529 cur_rank 11 abs_cur_rank 11 total_num 30 865\n",
      "215 150\n",
      "215 446 688\n",
      "checkcorrect 6 6 real score 1.984292984008789 Hits@1 0.8125 Hits@3 0.875 Hits@10 0.9375 MRR 0.8553728070175438 cur_rank 0 abs_cur_rank 0 total_num 31 865\n",
      "215 12\n",
      "215 7 30\n",
      "checkcorrect 40 40 real score 1.9645714938640595 Hits@1 0.8181818181818182 Hits@3 0.8787878787878788 Hits@10 0.9393939393939394 MRR 0.8597554492291334 cur_rank 0 abs_cur_rank 0 total_num 32 865\n",
      "215 150\n",
      "215 328 497\n",
      "checkcorrect 12 12 real score 1.9448876321315764 Hits@1 0.8235294117647058 Hits@3 0.8823529411764706 Hits@10 0.9411764705882353 MRR 0.8638802889576883 cur_rank 0 abs_cur_rank 0 total_num 33 865\n",
      "215 43\n",
      "215 10 848\n",
      "checkcorrect 96 96 real score 1.9044083535671235 Hits@1 0.8285714285714286 Hits@3 0.8857142857142857 Hits@10 0.9428571428571428 MRR 0.8677694235588972 cur_rank 0 abs_cur_rank 0 total_num 34 865\n",
      "215 144\n",
      "215 321 430\n",
      "checkcorrect 0 0 real score 1.9800369381904601 Hits@1 0.8333333333333334 Hits@3 0.8888888888888888 Hits@10 0.9444444444444444 MRR 0.8714424951267056 cur_rank 0 abs_cur_rank 0 total_num 35 865\n",
      "215 150\n",
      "215 157 732\n",
      "checkcorrect 44 44 real score 1.8690747141838073 Hits@1 0.8378378378378378 Hits@3 0.8918918918918919 Hits@10 0.9459459459459459 MRR 0.8749170222854434 cur_rank 0 abs_cur_rank 0 total_num 36 865\n",
      "215 33\n",
      "215 18 73\n",
      "checkcorrect 410 410 real score 1.7662773132324219 Hits@1 0.8421052631578947 Hits@3 0.8947368421052632 Hits@10 0.9473684210526315 MRR 0.8782086795937212 cur_rank 0 abs_cur_rank 0 total_num 37 865\n",
      "215 150\n",
      "215 118 651\n",
      "checkcorrect 96 96 real score 1.879149430990219 Hits@1 0.8461538461538461 Hits@3 0.8974358974358975 Hits@10 0.9487179487179487 MRR 0.8813315339631129 cur_rank 0 abs_cur_rank 0 total_num 38 865\n",
      "215 150\n",
      "215 525 699\n",
      "checkcorrect 114 114 real score 1.8843870997428893 Hits@1 0.85 Hits@3 0.9 Hits@10 0.95 MRR 0.8842982456140351 cur_rank 0 abs_cur_rank 0 total_num 39 865\n",
      "215 48\n",
      "215 280 43\n",
      "checkcorrect 78 78 real score 1.9304610013961792 Hits@1 0.8536585365853658 Hits@3 0.9024390243902439 Hits@10 0.9512195121951219 MRR 0.8871202396234489 cur_rank 0 abs_cur_rank 0 total_num 40 865\n",
      "215 13\n",
      "215 12 63\n",
      "checkcorrect 76 76 real score 1.8785386443138123 Hits@1 0.8571428571428571 Hits@3 0.9047619047619048 Hits@10 0.9523809523809523 MRR 0.8898078529657477 cur_rank 0 abs_cur_rank 1 total_num 41 865\n",
      "215 150\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 360 374\n",
      "checkcorrect 36 36 real score 1.8384552359580995 Hits@1 0.8604651162790697 Hits@3 0.9069767441860465 Hits@10 0.9534883720930233 MRR 0.8923704610363118 cur_rank 0 abs_cur_rank 0 total_num 42 865\n",
      "215 120\n",
      "215 444 97\n",
      "checkcorrect 40 40 real score 1.9112165987491607 Hits@1 0.8636363636363636 Hits@3 0.9090909090909091 Hits@10 0.9545454545454546 MRR 0.8948165869218502 cur_rank 0 abs_cur_rank 0 total_num 43 865\n",
      "215 42\n",
      "215 416 89\n",
      "checkcorrect 110 110 real score 1.7174048393964767 Hits@1 0.8666666666666667 Hits@3 0.9111111111111111 Hits@10 0.9555555555555556 MRR 0.8971539961013646 cur_rank 0 abs_cur_rank 0 total_num 44 865\n",
      "215 150\n",
      "215 295 765\n",
      "checkcorrect 36 36 real score 1.8850740849971772 Hits@1 0.8695652173913043 Hits@3 0.9130434782608695 Hits@10 0.9565217391304348 MRR 0.8993897787948132 cur_rank 0 abs_cur_rank 0 total_num 45 865\n",
      "215 86\n",
      "215 161 207\n",
      "checkcorrect 290 290 real score 1.8092424988746643 Hits@1 0.8723404255319149 Hits@3 0.9148936170212766 Hits@10 0.9574468085106383 MRR 0.9015304217991789 cur_rank 0 abs_cur_rank 0 total_num 46 865\n",
      "215 150\n",
      "215 886 651\n",
      "checkcorrect 24 24 real score 1.8653115510940552 Hits@1 0.8541666666666666 Hits@3 0.9166666666666666 Hits@10 0.9583333333333334 MRR 0.8931652046783626 cur_rank 1 abs_cur_rank 1 total_num 47 865\n",
      "215 144\n",
      "215 270 261\n",
      "checkcorrect 2 2 real score 1.8816756367683412 Hits@1 0.8571428571428571 Hits@3 0.9183673469387755 Hits@10 0.9591836734693877 MRR 0.8953455066237022 cur_rank 0 abs_cur_rank 0 total_num 48 865\n",
      "215 126\n",
      "215 626 509\n",
      "checkcorrect 154 154 real score 1.6505442440509794 Hits@1 0.86 Hits@3 0.92 Hits@10 0.96 MRR 0.8974385964912281 cur_rank 0 abs_cur_rank 0 total_num 49 865\n",
      "215 61\n",
      "215 241 425\n",
      "checkcorrect 18 18 real score 1.9529038190841674 Hits@1 0.8627450980392157 Hits@3 0.9215686274509803 Hits@10 0.9607843137254902 MRR 0.8994496044031648 cur_rank 0 abs_cur_rank 0 total_num 50 865\n",
      "215 139\n",
      "215 98 245\n",
      "checkcorrect 208 208 real score 1.9876740753650666 Hits@1 0.8653846153846154 Hits@3 0.9230769230769231 Hits@10 0.9615384615384616 MRR 0.9013832658569501 cur_rank 0 abs_cur_rank 0 total_num 51 865\n",
      "215 150\n",
      "215 157 215\n",
      "checkcorrect 172 172 real score 1.9846117854118348 Hits@1 0.8679245283018868 Hits@3 0.9245283018867925 Hits@10 0.9622641509433962 MRR 0.9032439589539888 cur_rank 0 abs_cur_rank 0 total_num 52 865\n",
      "215 150\n",
      "215 711 567\n",
      "checkcorrect 54 54 real score 1.8951602339744569 Hits@1 0.8703703703703703 Hits@3 0.9259259259259259 Hits@10 0.9629629629629629 MRR 0.9050357374918779 cur_rank 0 abs_cur_rank 0 total_num 53 865\n",
      "0 1\n",
      "215 7 8\n",
      "checkcorrect 128 128 real score 0.8584818542003632 Hits@1 0.8727272727272727 Hits@3 0.9272727272727272 Hits@10 0.9636363636363636 MRR 0.906762360446571 cur_rank 0 abs_cur_rank 0 total_num 54 865\n",
      "215 150\n",
      "215 609 295\n",
      "checkcorrect 22 22 real score 1.9555518984794618 Hits@1 0.875 Hits@3 0.9285714285714286 Hits@10 0.9642857142857143 MRR 0.9084273182957394 cur_rank 0 abs_cur_rank 0 total_num 55 865\n",
      "215 149\n",
      "215 747 190\n",
      "checkcorrect 382 382 real score 1.942542517185211 Hits@1 0.8771929824561403 Hits@3 0.9298245614035088 Hits@10 0.9649122807017544 MRR 0.9100338565712527 cur_rank 0 abs_cur_rank 0 total_num 56 865\n",
      "215 132\n",
      "215 274 137\n",
      "checkcorrect 314 314 real score 1.8284244596958161 Hits@1 0.8793103448275862 Hits@3 0.9310344827586207 Hits@10 0.9655172413793104 MRR 0.9115849969751967 cur_rank 0 abs_cur_rank 0 total_num 57 865\n",
      "215 150\n",
      "215 159 303\n",
      "checkcorrect 8 8 real score 1.9482172548770904 Hits@1 0.8813559322033898 Hits@3 0.9322033898305084 Hits@10 0.9661016949152542 MRR 0.9130835563484984 cur_rank 0 abs_cur_rank 0 total_num 58 865\n",
      "215 76\n",
      "215 66 300\n",
      "checkcorrect 110 110 real score 1.820691740512848 Hits@1 0.8833333333333333 Hits@3 0.9333333333333333 Hits@10 0.9666666666666667 MRR 0.9145321637426901 cur_rank 0 abs_cur_rank 0 total_num 59 865\n",
      "215 150\n",
      "215 472 587\n",
      "checkcorrect 0 0 real score 1.9333500385284423 Hits@1 0.8852459016393442 Hits@3 0.9344262295081968 Hits@10 0.9672131147540983 MRR 0.9159332758124821 cur_rank 0 abs_cur_rank 0 total_num 60 865\n",
      "215 150\n",
      "215 799 466\n",
      "checkcorrect 64 64 real score 1.8688793003559114 Hits@1 0.8870967741935484 Hits@3 0.9354838709677419 Hits@10 0.967741935483871 MRR 0.9172891907187324 cur_rank 0 abs_cur_rank 1 total_num 61 865\n",
      "215 150\n",
      "215 341 738\n",
      "checkcorrect 0 0 real score 1.5858252465724947 Hits@1 0.873015873015873 Hits@3 0.9365079365079365 Hits@10 0.9682539682539683 MRR 0.910665552770816 cur_rank 1 abs_cur_rank 1 total_num 62 865\n",
      "215 150\n",
      "215 96 425\n",
      "checkcorrect 32 32 real score 1.9653377890586854 Hits@1 0.875 Hits@3 0.9375 Hits@10 0.96875 MRR 0.912061403508772 cur_rank 0 abs_cur_rank 0 total_num 63 865\n",
      "215 6\n",
      "215 37 45\n",
      "checkcorrect 112 112 real score 1.6787951976060866 Hits@1 0.8769230769230769 Hits@3 0.9384615384615385 Hits@10 0.9692307692307692 MRR 0.9134143049932524 cur_rank 0 abs_cur_rank 0 total_num 64 865\n",
      "215 150\n",
      "215 379 890\n",
      "checkcorrect 40 40 real score 1.8779629468917847 Hits@1 0.8787878787878788 Hits@3 0.9393939393939394 Hits@10 0.9696969696969697 MRR 0.9147262094630516 cur_rank 0 abs_cur_rank 0 total_num 65 865\n",
      "215 150\n",
      "215 159 588\n",
      "checkcorrect 220 220 real score 1.8863523483276365 Hits@1 0.8805970149253731 Hits@3 0.9402985074626866 Hits@10 0.9701492537313433 MRR 0.9159989526053941 cur_rank 0 abs_cur_rank 0 total_num 66 865\n",
      "215 150\n",
      "215 289 542\n",
      "checkcorrect 12 12 real score 1.9475336849689484 Hits@1 0.8823529411764706 Hits@3 0.9411764705882353 Hits@10 0.9705882352941176 MRR 0.917234262125903 cur_rank 0 abs_cur_rank 0 total_num 67 865\n",
      "215 145\n",
      "215 588 426\n",
      "checkcorrect 28 28 real score 1.8653722286224363 Hits@1 0.8695652173913043 Hits@3 0.9420289855072463 Hits@10 0.9710144927536232 MRR 0.9111873887617595 cur_rank 1 abs_cur_rank 1 total_num 68 865\n",
      "215 51\n",
      "215 1006 262\n",
      "checkcorrect 54 54 real score 1.9109443128108978 Hits@1 0.8714285714285714 Hits@3 0.9428571428571428 Hits@10 0.9714285714285714 MRR 0.9124561403508772 cur_rank 0 abs_cur_rank 1 total_num 69 865\n",
      "215 150\n",
      "215 194 320\n",
      "checkcorrect 180 180 real score 1.9389205098152162 Hits@1 0.8732394366197183 Hits@3 0.9436619718309859 Hits@10 0.971830985915493 MRR 0.9136891524586114 cur_rank 0 abs_cur_rank 0 total_num 70 865\n",
      "215 150\n",
      "215 675 680\n",
      "checkcorrect 54 54 real score 1.9598034024238586 Hits@1 0.875 Hits@3 0.9444444444444444 Hits@10 0.9722222222222222 MRR 0.9148879142300195 cur_rank 0 abs_cur_rank 0 total_num 71 865\n",
      "215 112\n",
      "215 15 84\n",
      "checkcorrect 98 98 real score 1.9402340412139893 Hits@1 0.8767123287671232 Hits@3 0.9452054794520548 Hits@10 0.9726027397260274 MRR 0.9160538332131699 cur_rank 0 abs_cur_rank 0 total_num 72 865\n",
      "215 5\n",
      "215 72 43\n",
      "checkcorrect 320 320 real score 1.432673579454422 Hits@1 0.8648648648648649 Hits@3 0.9324324324324325 Hits@10 0.972972972972973 MRR 0.9070531057373163 cur_rank 3 abs_cur_rank 3 total_num 73 865\n",
      "215 126\n",
      "215 565 465\n",
      "checkcorrect 50 50 real score 1.8768418431282043 Hits@1 0.8666666666666667 Hits@3 0.9333333333333333 Hits@10 0.9733333333333334 MRR 0.9082923976608187 cur_rank 0 abs_cur_rank 1 total_num 74 865\n",
      "215 66\n",
      "215 243 246\n",
      "checkcorrect 142 142 real score 1.8363938212394713 Hits@1 0.868421052631579 Hits@3 0.9342105263157895 Hits@10 0.9736842105263158 MRR 0.9094990766389659 cur_rank 0 abs_cur_rank 0 total_num 75 865\n",
      "215 140\n",
      "215 595 303\n",
      "checkcorrect 88 88 real score 1.5420937895774842 Hits@1 0.8571428571428571 Hits@3 0.935064935064935 Hits@10 0.974025974025974 MRR 0.9020164046479836 cur_rank 2 abs_cur_rank 2 total_num 76 865\n",
      "215 41\n",
      "215 270 170\n",
      "checkcorrect 2 2 real score 1.895396500825882 Hits@1 0.8589743589743589 Hits@3 0.9358974358974359 Hits@10 0.9743589743589743 MRR 0.903272604588394 cur_rank 0 abs_cur_rank 0 total_num 77 865\n",
      "215 142\n",
      "215 66 202\n",
      "checkcorrect 386 386 real score 1.6887117862701415 Hits@1 0.8607594936708861 Hits@3 0.9367088607594937 Hits@10 0.9746835443037974 MRR 0.9044970019986676 cur_rank 0 abs_cur_rank 0 total_num 78 865\n",
      "215 79\n",
      "215 424 277\n",
      "checkcorrect 24 24 real score 1.866462379693985 Hits@1 0.8625 Hits@3 0.9375 Hits@10 0.975 MRR 0.9056907894736842 cur_rank 0 abs_cur_rank 0 total_num 79 865\n",
      "215 144\n",
      "215 733 208\n",
      "checkcorrect 382 382 real score 1.9567329943180085 Hits@1 0.8641975308641975 Hits@3 0.9382716049382716 Hits@10 0.9753086419753086 MRR 0.9068551007147498 cur_rank 0 abs_cur_rank 0 total_num 80 865\n",
      "215 150\n",
      "215 206 400\n",
      "checkcorrect 32 32 real score 1.9584147036075592 Hits@1 0.8658536585365854 Hits@3 0.9390243902439024 Hits@10 0.975609756097561 MRR 0.9079910141206675 cur_rank 0 abs_cur_rank 0 total_num 81 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 144\n",
      "215 105 260\n",
      "checkcorrect 32 32 real score 1.9349276423454285 Hits@1 0.8674698795180723 Hits@3 0.9397590361445783 Hits@10 0.9759036144578314 MRR 0.9090995561192137 cur_rank 0 abs_cur_rank 0 total_num 82 865\n",
      "215 149\n",
      "215 19 574\n",
      "checkcorrect 8 8 real score 1.931020349264145 Hits@1 0.8690476190476191 Hits@3 0.9404761904761905 Hits@10 0.9761904761904762 MRR 0.9101817042606516 cur_rank 0 abs_cur_rank 0 total_num 83 865\n",
      "215 150\n",
      "215 197 1492\n",
      "checkcorrect 60 60 real score 0.6411841817200183 Hits@1 0.8588235294117647 Hits@3 0.9294117647058824 Hits@10 0.9764705882352941 MRR 0.9009442724458204 cur_rank 7 abs_cur_rank 7 total_num 84 865\n",
      "215 150\n",
      "215 228 183\n",
      "checkcorrect 54 54 real score 1.936099076271057 Hits@1 0.8604651162790697 Hits@3 0.9302325581395349 Hits@10 0.9767441860465116 MRR 0.9020960832313342 cur_rank 0 abs_cur_rank 0 total_num 85 865\n",
      "215 150\n",
      "215 880 887\n",
      "checkcorrect 54 54 real score 1.8858651757240295 Hits@1 0.8620689655172413 Hits@3 0.9310344827586207 Hits@10 0.9770114942528736 MRR 0.9032214156079854 cur_rank 0 abs_cur_rank 0 total_num 86 865\n",
      "0 2\n",
      "215 94 95\n",
      "checkcorrect 352 352 real score 0.7047505021095276 Hits@1 0.8522727272727273 Hits@3 0.9204545454545454 Hits@10 0.9772727272727273 MRR 0.8957984449760765 cur_rank 3 abs_cur_rank 4 total_num 87 865\n",
      "215 85\n",
      "215 158 73\n",
      "checkcorrect 300 300 real score 1.2485563114285467 Hits@1 0.8426966292134831 Hits@3 0.9101123595505618 Hits@10 0.9775280898876404 MRR 0.8879804849201656 cur_rank 4 abs_cur_rank 4 total_num 88 865\n",
      "215 3\n",
      "0 3 3\n",
      "checkcorrect 230 230 real score 0.9953386962413788 Hits@1 0.8444444444444444 Hits@3 0.9111111111111111 Hits@10 0.9777777777777777 MRR 0.8892251461988304 cur_rank 0 abs_cur_rank 0 total_num 89 865\n",
      "215 150\n",
      "215 412 1512\n",
      "checkcorrect 48 48 real score 1.9031086683273317 Hits@1 0.8461538461538461 Hits@3 0.9120879120879121 Hits@10 0.978021978021978 MRR 0.8904424522845575 cur_rank 0 abs_cur_rank 0 total_num 90 865\n",
      "215 121\n",
      "215 584 496\n",
      "checkcorrect 114 114 real score 1.7944847285747527 Hits@1 0.8478260869565217 Hits@3 0.9130434782608695 Hits@10 0.9782608695652174 MRR 0.891633295194508 cur_rank 0 abs_cur_rank 0 total_num 91 865\n",
      "215 29\n",
      "215 161 172\n",
      "checkcorrect 24 24 real score 1.7500850379467012 Hits@1 0.8494623655913979 Hits@3 0.9139784946236559 Hits@10 0.978494623655914 MRR 0.8927985285795133 cur_rank 0 abs_cur_rank 1 total_num 92 865\n",
      "215 150\n",
      "215 491 440\n",
      "checkcorrect 134 134 real score 1.8629965662956236 Hits@1 0.851063829787234 Hits@3 0.9148936170212766 Hits@10 0.9787234042553191 MRR 0.8939389697648377 cur_rank 0 abs_cur_rank 0 total_num 93 865\n",
      "215 150\n",
      "215 598 950\n",
      "checkcorrect 54 54 real score 1.9479207754135133 Hits@1 0.8526315789473684 Hits@3 0.9157894736842105 Hits@10 0.9789473684210527 MRR 0.8950554016620499 cur_rank 0 abs_cur_rank 0 total_num 94 865\n",
      "0 1\n",
      "215 979 120\n",
      "checkcorrect 198 198 real score 0.8944915354251861 Hits@1 0.84375 Hits@3 0.9166666666666666 Hits@10 0.9791666666666666 MRR 0.8909402412280701 cur_rank 1 abs_cur_rank 1 total_num 95 865\n",
      "215 30\n",
      "215 120 54\n",
      "checkcorrect 140 140 real score 1.864470398426056 Hits@1 0.8350515463917526 Hits@3 0.9175257731958762 Hits@10 0.979381443298969 MRR 0.8869099294628323 cur_rank 1 abs_cur_rank 1 total_num 96 865\n",
      "215 85\n",
      "215 463 121\n",
      "checkcorrect 134 134 real score 1.7037848562002182 Hits@1 0.8367346938775511 Hits@3 0.9183673469387755 Hits@10 0.9795918367346939 MRR 0.888063909774436 cur_rank 0 abs_cur_rank 0 total_num 97 865\n",
      "215 150\n",
      "215 48 718\n",
      "checkcorrect 44 44 real score 1.7754733204841613 Hits@1 0.8383838383838383 Hits@3 0.9191919191919192 Hits@10 0.9797979797979798 MRR 0.8891945773524721 cur_rank 0 abs_cur_rank 0 total_num 98 865\n",
      "215 141\n",
      "215 417 168\n",
      "checkcorrect 154 154 real score 1.5558479607105256 Hits@1 0.83 Hits@3 0.92 Hits@10 0.98 MRR 0.8836359649122807 cur_rank 2 abs_cur_rank 3 total_num 99 865\n",
      "215 142\n",
      "215 280 253\n",
      "checkcorrect 314 314 real score 1.9666566908359528 Hits@1 0.8316831683168316 Hits@3 0.9207920792079208 Hits@10 0.9801980198019802 MRR 0.884788084071565 cur_rank 0 abs_cur_rank 0 total_num 100 865\n",
      "0 1\n",
      "215 119 21\n",
      "checkcorrect 140 140 real score 0.8671224415302277 Hits@1 0.8235294117647058 Hits@3 0.9215686274509803 Hits@10 0.9803921568627451 MRR 0.8810156518747849 cur_rank 1 abs_cur_rank 2 total_num 101 865\n",
      "215 14\n",
      "215 79 45\n",
      "checkcorrect 40 40 real score 1.8220806300640107 Hits@1 0.8252427184466019 Hits@3 0.9223300970873787 Hits@10 0.9805825242718447 MRR 0.8821708397206608 cur_rank 0 abs_cur_rank 0 total_num 102 865\n",
      "215 104\n",
      "215 480 252\n",
      "checkcorrect 28 28 real score 1.755136674642563 Hits@1 0.8269230769230769 Hits@3 0.9230769230769231 Hits@10 0.9807692307692307 MRR 0.8833038124156545 cur_rank 0 abs_cur_rank 0 total_num 103 865\n",
      "215 147\n",
      "215 760 364\n",
      "checkcorrect 22 22 real score 1.9291657745838164 Hits@1 0.8285714285714286 Hits@3 0.9238095238095239 Hits@10 0.9809523809523809 MRR 0.8844152046783625 cur_rank 0 abs_cur_rank 0 total_num 104 865\n",
      "215 126\n",
      "215 1558 1508\n",
      "checkcorrect 50 50 real score 1.7274747788906097 Hits@1 0.8207547169811321 Hits@3 0.9245283018867925 Hits@10 0.9811320754716981 MRR 0.880788646143661 cur_rank 1 abs_cur_rank 3 total_num 105 865\n",
      "215 150\n",
      "215 306 792\n",
      "checkcorrect 54 54 real score 1.8640205085277557 Hits@1 0.822429906542056 Hits@3 0.9252336448598131 Hits@10 0.9813084112149533 MRR 0.8819027709460567 cur_rank 0 abs_cur_rank 0 total_num 106 865\n",
      "215 111\n",
      "215 12 141\n",
      "checkcorrect 158 158 real score 1.9428157210350037 Hits@1 0.8240740740740741 Hits@3 0.9259259259259259 Hits@10 0.9814814814814815 MRR 0.8829962638076673 cur_rank 0 abs_cur_rank 0 total_num 107 865\n",
      "0 1\n",
      "0 2 3\n",
      "checkcorrect 112 112 real score 0.0 Hits@1 0.8165137614678899 Hits@3 0.9174311926605505 Hits@10 0.9724770642201835 MRR 0.8750563334942861 cur_rank 56 abs_cur_rank 56 total_num 108 865\n",
      "215 150\n",
      "215 169 420\n",
      "checkcorrect 32 32 real score 1.9678316831588745 Hits@1 0.8181818181818182 Hits@3 0.9181818181818182 Hits@10 0.9727272727272728 MRR 0.8761921850079745 cur_rank 0 abs_cur_rank 0 total_num 109 865\n",
      "215 3\n",
      "215 875 229\n",
      "checkcorrect 112 112 real score 1.9165576934814452 Hits@1 0.8198198198198198 Hits@3 0.918918918918919 Hits@10 0.972972972972973 MRR 0.8773075707286233 cur_rank 0 abs_cur_rank 0 total_num 110 865\n",
      "215 150\n",
      "215 69 872\n",
      "checkcorrect 10 10 real score 1.8648871541023255 Hits@1 0.8214285714285714 Hits@3 0.9196428571428571 Hits@10 0.9732142857142857 MRR 0.8784030388471178 cur_rank 0 abs_cur_rank 0 total_num 111 865\n",
      "215 123\n",
      "215 474 115\n",
      "checkcorrect 88 88 real score 1.2077700659632682 Hits@1 0.8141592920353983 Hits@3 0.9203539823008849 Hits@10 0.9734513274336283 MRR 0.8750543393882937 cur_rank 1 abs_cur_rank 1 total_num 112 865\n",
      "215 148\n",
      "215 836 351\n",
      "checkcorrect 64 64 real score 1.8552460074424744 Hits@1 0.8157894736842105 Hits@3 0.9210526315789473 Hits@10 0.9736842105263158 MRR 0.876150353955063 cur_rank 0 abs_cur_rank 0 total_num 113 865\n",
      "215 45\n",
      "215 62 118\n",
      "checkcorrect 32 32 real score 1.965810912847519 Hits@1 0.8173913043478261 Hits@3 0.9217391304347826 Hits@10 0.9739130434782609 MRR 0.8772273073989321 cur_rank 0 abs_cur_rank 0 total_num 114 865\n",
      "0 2\n",
      "0 4 9\n",
      "checkcorrect 400 400 real score 0.0 Hits@1 0.8103448275862069 Hits@3 0.9137931034482759 Hits@10 0.9655172413793104 MRR 0.8697078920280629 cur_rank 200 abs_cur_rank 200 total_num 115 865\n",
      "0 2\n",
      "215 164 19\n",
      "checkcorrect 88 88 real score 0.8284545958042144 Hits@1 0.811965811965812 Hits@3 0.9145299145299145 Hits@10 0.9658119658119658 MRR 0.8708214997885068 cur_rank 0 abs_cur_rank 0 total_num 116 865\n",
      "215 23\n",
      "215 43 55\n",
      "checkcorrect 88 88 real score 1.9469797790050507 Hits@1 0.8135593220338984 Hits@3 0.9152542372881356 Hits@10 0.9661016949152542 MRR 0.8719162328411466 cur_rank 0 abs_cur_rank 0 total_num 117 865\n",
      "215 37\n",
      "215 467 166\n",
      "checkcorrect 112 112 real score 1.8805843532085418 Hits@1 0.8151260504201681 Hits@3 0.9159663865546218 Hits@10 0.9663865546218487 MRR 0.872992567018952 cur_rank 0 abs_cur_rank 0 total_num 118 865\n",
      "215 150\n",
      "215 1142 1080\n",
      "checkcorrect 54 54 real score 1.885287380218506 Hits@1 0.8166666666666667 Hits@3 0.9166666666666666 Hits@10 0.9666666666666667 MRR 0.8740509622937941 cur_rank 0 abs_cur_rank 0 total_num 119 865\n",
      "215 9\n",
      "215 15 12\n",
      "checkcorrect 218 218 real score 1.8497691690921783 Hits@1 0.8181818181818182 Hits@3 0.9173553719008265 Hits@10 0.9669421487603306 MRR 0.875091863431862 cur_rank 0 abs_cur_rank 0 total_num 120 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 105 935\n",
      "checkcorrect 142 142 real score 1.7893110454082488 Hits@1 0.8114754098360656 Hits@3 0.9180327868852459 Hits@10 0.9672131147540983 MRR 0.872017339961109 cur_rank 1 abs_cur_rank 1 total_num 121 865\n",
      "215 150\n",
      "215 968 481\n",
      "checkcorrect 22 22 real score 1.939193171262741 Hits@1 0.8130081300813008 Hits@3 0.9186991869918699 Hits@10 0.967479674796748 MRR 0.8730578493923195 cur_rank 0 abs_cur_rank 0 total_num 122 865\n",
      "215 150\n",
      "215 48 874\n",
      "checkcorrect 96 96 real score 1.9478249609470368 Hits@1 0.8145161290322581 Hits@3 0.9193548387096774 Hits@10 0.967741935483871 MRR 0.8740815764133492 cur_rank 0 abs_cur_rank 0 total_num 123 865\n",
      "215 150\n",
      "215 648 803\n",
      "checkcorrect 36 36 real score 1.893031692504883 Hits@1 0.816 Hits@3 0.92 Hits@10 0.968 MRR 0.8750889238020424 cur_rank 0 abs_cur_rank 0 total_num 124 865\n",
      "215 123\n",
      "215 159 167\n",
      "checkcorrect 290 290 real score 1.8239955484867094 Hits@1 0.8174603174603174 Hits@3 0.9206349206349206 Hits@10 0.9682539682539683 MRR 0.8760802815496452 cur_rank 0 abs_cur_rank 0 total_num 125 865\n",
      "215 68\n",
      "215 541 141\n",
      "checkcorrect 32 32 real score 1.9639261960983276 Hits@1 0.8188976377952756 Hits@3 0.9212598425196851 Hits@10 0.968503937007874 MRR 0.877056027364215 cur_rank 0 abs_cur_rank 0 total_num 126 865\n",
      "215 150\n",
      "215 444 328\n",
      "checkcorrect 54 54 real score 1.7149594843387606 Hits@1 0.8125 Hits@3 0.9140625 Hits@10 0.96875 MRR 0.872157152150432 cur_rank 3 abs_cur_rank 3 total_num 127 865\n",
      "215 150\n",
      "215 22 260\n",
      "checkcorrect 32 32 real score 1.9008563876152038 Hits@1 0.813953488372093 Hits@3 0.9147286821705426 Hits@10 0.9689922480620154 MRR 0.8731481819787232 cur_rank 0 abs_cur_rank 0 total_num 128 865\n",
      "215 150\n",
      "215 386 746\n",
      "checkcorrect 0 0 real score 1.9710908770561217 Hits@1 0.8153846153846154 Hits@3 0.9153846153846154 Hits@10 0.9692307692307692 MRR 0.8741239651942715 cur_rank 0 abs_cur_rank 0 total_num 129 865\n",
      "215 150\n",
      "215 662 510\n",
      "checkcorrect 64 64 real score 1.8851765990257263 Hits@1 0.816793893129771 Hits@3 0.916030534351145 Hits@10 0.9694656488549618 MRR 0.8750848509561473 cur_rank 0 abs_cur_rank 0 total_num 130 865\n",
      "215 127\n",
      "215 318 206\n",
      "checkcorrect 64 64 real score 1.868881392478943 Hits@1 0.8106060606060606 Hits@3 0.9166666666666666 Hits@10 0.9696969696969697 MRR 0.8722432990549643 cur_rank 1 abs_cur_rank 1 total_num 131 865\n",
      "215 102\n",
      "215 537 485\n",
      "checkcorrect 212 212 real score 1.7564221680164338 Hits@1 0.8120300751879699 Hits@3 0.9172932330827067 Hits@10 0.9699248120300752 MRR 0.8732038757537992 cur_rank 0 abs_cur_rank 0 total_num 132 865\n",
      "215 128\n",
      "215 111 121\n",
      "checkcorrect 292 292 real score 1.8753288030624389 Hits@1 0.8134328358208955 Hits@3 0.917910447761194 Hits@10 0.9701492537313433 MRR 0.8741501154869799 cur_rank 0 abs_cur_rank 0 total_num 133 865\n",
      "215 96\n",
      "215 1178 388\n",
      "checkcorrect 54 54 real score 1.8422771275043486 Hits@1 0.8148148148148148 Hits@3 0.9185185185185185 Hits@10 0.9703703703703703 MRR 0.8750823368537429 cur_rank 0 abs_cur_rank 0 total_num 134 865\n",
      "215 150\n",
      "215 613 799\n",
      "checkcorrect 96 96 real score 1.8164735198020936 Hits@1 0.8161764705882353 Hits@3 0.9191176470588235 Hits@10 0.9705882352941176 MRR 0.8760008490827595 cur_rank 0 abs_cur_rank 0 total_num 135 865\n",
      "215 116\n",
      "215 366 192\n",
      "checkcorrect 24 24 real score 1.823132300376892 Hits@1 0.8175182481751825 Hits@3 0.9197080291970803 Hits@10 0.9708029197080292 MRR 0.8769059523741263 cur_rank 0 abs_cur_rank 1 total_num 136 865\n",
      "215 41\n",
      "215 44 58\n",
      "checkcorrect 78 78 real score 1.4644821763038636 Hits@1 0.8188405797101449 Hits@3 0.9202898550724637 Hits@10 0.9710144927536232 MRR 0.8777979382264877 cur_rank 0 abs_cur_rank 0 total_num 137 865\n",
      "215 150\n",
      "215 137 116\n",
      "checkcorrect 78 78 real score 1.896979695558548 Hits@1 0.8201438848920863 Hits@3 0.920863309352518 Hits@10 0.9712230215827338 MRR 0.8786770897500381 cur_rank 0 abs_cur_rank 0 total_num 138 865\n",
      "215 149\n",
      "215 601 725\n",
      "checkcorrect 22 22 real score 1.940901243686676 Hits@1 0.8214285714285714 Hits@3 0.9214285714285714 Hits@10 0.9714285714285714 MRR 0.8795436819661092 cur_rank 0 abs_cur_rank 0 total_num 139 865\n",
      "215 149\n",
      "215 495 669\n",
      "checkcorrect 50 50 real score 1.9398428559303285 Hits@1 0.8226950354609929 Hits@3 0.9219858156028369 Hits@10 0.9716312056737588 MRR 0.8803979820940092 cur_rank 0 abs_cur_rank 1 total_num 140 865\n",
      "215 150\n",
      "215 238 943\n",
      "checkcorrect 40 40 real score 1.9732214987277985 Hits@1 0.823943661971831 Hits@3 0.9225352112676056 Hits@10 0.971830985915493 MRR 0.8812402498257416 cur_rank 0 abs_cur_rank 0 total_num 141 865\n",
      "215 150\n",
      "215 428 391\n",
      "checkcorrect 24 24 real score 1.5733956396579742 Hits@1 0.8251748251748252 Hits@3 0.9230769230769231 Hits@10 0.972027972027972 MRR 0.8820707375891979 cur_rank 0 abs_cur_rank 1 total_num 142 865\n",
      "215 120\n",
      "215 461 118\n",
      "checkcorrect 32 32 real score 1.9529655575752258 Hits@1 0.8263888888888888 Hits@3 0.9236111111111112 Hits@10 0.9722222222222222 MRR 0.882889690800384 cur_rank 0 abs_cur_rank 0 total_num 143 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 298 298 real score 1.9133579790592194 Hits@1 0.8206896551724138 Hits@3 0.9241379310344827 Hits@10 0.9724137931034482 MRR 0.88024907224314 cur_rank 1 abs_cur_rank 2 total_num 144 865\n",
      "215 150\n",
      "215 130 935\n",
      "checkcorrect 40 40 real score 1.9485686361789702 Hits@1 0.821917808219178 Hits@3 0.9246575342465754 Hits@10 0.9726027397260274 MRR 0.881069284077091 cur_rank 0 abs_cur_rank 0 total_num 145 865\n",
      "215 150\n",
      "215 314 798\n",
      "checkcorrect 96 96 real score 1.9044064998626709 Hits@1 0.8231292517006803 Hits@3 0.9251700680272109 Hits@10 0.9727891156462585 MRR 0.8818783365663625 cur_rank 0 abs_cur_rank 0 total_num 146 865\n",
      "215 150\n",
      "215 363 1541\n",
      "checkcorrect 146 146 real score 1.8408097565174102 Hits@1 0.8243243243243243 Hits@3 0.9256756756756757 Hits@10 0.972972972972973 MRR 0.882676455913887 cur_rank 0 abs_cur_rank 1 total_num 147 865\n",
      "215 11\n",
      "215 82 45\n",
      "checkcorrect 54 54 real score 1.2594658240675927 Hits@1 0.8187919463087249 Hits@3 0.9194630872483222 Hits@10 0.9731543624161074 MRR 0.8780947347332568 cur_rank 4 abs_cur_rank 4 total_num 148 865\n",
      "215 150\n",
      "215 155 886\n",
      "checkcorrect 96 96 real score 1.922934538125992 Hits@1 0.82 Hits@3 0.92 Hits@10 0.9733333333333334 MRR 0.8789074365017018 cur_rank 0 abs_cur_rank 0 total_num 149 865\n",
      "215 22\n",
      "215 280 27\n",
      "checkcorrect 78 78 real score 1.918839591741562 Hits@1 0.8211920529801324 Hits@3 0.9205298013245033 Hits@10 0.9735099337748344 MRR 0.8797093740083131 cur_rank 0 abs_cur_rank 0 total_num 150 865\n",
      "215 114\n",
      "215 72 161\n",
      "checkcorrect 146 146 real score 1.7898525595664978 Hits@1 0.8157894736842105 Hits@3 0.9210526315789473 Hits@10 0.9736842105263158 MRR 0.8772112860214163 cur_rank 1 abs_cur_rank 1 total_num 151 865\n",
      "215 150\n",
      "215 620 404\n",
      "checkcorrect 54 54 real score 1.946837103366852 Hits@1 0.8169934640522876 Hits@3 0.9215686274509803 Hits@10 0.9738562091503268 MRR 0.8780138266356553 cur_rank 0 abs_cur_rank 0 total_num 152 865\n",
      "215 107\n",
      "215 416 521\n",
      "checkcorrect 28 28 real score 1.7731418788433075 Hits@1 0.8181818181818182 Hits@3 0.922077922077922 Hits@10 0.974025974025974 MRR 0.8788059446445148 cur_rank 0 abs_cur_rank 1 total_num 153 865\n",
      "215 127\n",
      "215 980 339\n",
      "checkcorrect 328 328 real score 1.9797783613204956 Hits@1 0.8193548387096774 Hits@3 0.9225806451612903 Hits@10 0.9741935483870968 MRR 0.8795878417758405 cur_rank 0 abs_cur_rank 0 total_num 154 865\n",
      "215 96\n",
      "215 325 711\n",
      "checkcorrect 18 18 real score 1.8664008498191833 Hits@1 0.8205128205128205 Hits@3 0.9230769230769231 Hits@10 0.9743589743589743 MRR 0.8803597145849696 cur_rank 0 abs_cur_rank 0 total_num 155 865\n",
      "215 111\n",
      "215 227 309\n",
      "checkcorrect 54 54 real score 1.9530484855175019 Hits@1 0.821656050955414 Hits@3 0.9235668789808917 Hits@10 0.9745222929936306 MRR 0.8811217546194603 cur_rank 0 abs_cur_rank 0 total_num 156 865\n",
      "215 142\n",
      "215 139 308\n",
      "checkcorrect 220 220 real score 1.9070320188999177 Hits@1 0.8227848101265823 Hits@3 0.9240506329113924 Hits@10 0.9746835443037974 MRR 0.881874148577565 cur_rank 0 abs_cur_rank 0 total_num 157 865\n",
      "215 88\n",
      "215 387 637\n",
      "checkcorrect 50 50 real score 1.8684151887893676 Hits@1 0.8238993710691824 Hits@3 0.9245283018867925 Hits@10 0.9748427672955975 MRR 0.882617078460725 cur_rank 0 abs_cur_rank 1 total_num 158 865\n",
      "215 150\n",
      "215 955 917\n",
      "checkcorrect 54 54 real score 1.9159481227397919 Hits@1 0.825 Hits@3 0.925 Hits@10 0.975 MRR 0.8833507217203455 cur_rank 0 abs_cur_rank 0 total_num 159 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 124\n",
      "215 208 200\n",
      "checkcorrect 24 24 real score 1.8734449744224548 Hits@1 0.8260869565217391 Hits@3 0.9254658385093167 Hits@10 0.9751552795031055 MRR 0.884075251399101 cur_rank 0 abs_cur_rank 0 total_num 160 865\n",
      "215 84\n",
      "215 350 162\n",
      "checkcorrect 70 70 real score 1.918363094329834 Hits@1 0.8271604938271605 Hits@3 0.9259259259259259 Hits@10 0.9753086419753086 MRR 0.8847908362670078 cur_rank 0 abs_cur_rank 0 total_num 161 865\n",
      "215 131\n",
      "215 256 319\n",
      "checkcorrect 24 24 real score 1.9000222086906433 Hits@1 0.8282208588957055 Hits@3 0.9263803680981595 Hits@10 0.9754601226993865 MRR 0.8854976409524863 cur_rank 0 abs_cur_rank 0 total_num 162 865\n",
      "215 47\n",
      "215 57 81\n",
      "checkcorrect 64 64 real score 1.3837938547134399 Hits@1 0.8292682926829268 Hits@3 0.926829268292683 Hits@10 0.975609756097561 MRR 0.8861958260686297 cur_rank 0 abs_cur_rank 0 total_num 163 865\n",
      "215 113\n",
      "215 111 77\n",
      "checkcorrect 188 188 real score 1.9425578355789184 Hits@1 0.8303030303030303 Hits@3 0.9272727272727272 Hits@10 0.9757575757575757 MRR 0.8868855483348804 cur_rank 0 abs_cur_rank 0 total_num 164 865\n",
      "0 1\n",
      "215 28 122\n",
      "checkcorrect 50 50 real score 0.5316301822662354 Hits@1 0.8253012048192772 Hits@3 0.927710843373494 Hits@10 0.9759036144578314 MRR 0.8845549125015377 cur_rank 1 abs_cur_rank 1 total_num 165 865\n",
      "215 150\n",
      "215 585 633\n",
      "checkcorrect 22 22 real score 1.9434157013893127 Hits@1 0.8263473053892215 Hits@3 0.9281437125748503 Hits@10 0.9760479041916168 MRR 0.8852462004506304 cur_rank 0 abs_cur_rank 0 total_num 166 865\n",
      "215 148\n",
      "215 154 202\n",
      "checkcorrect 298 298 real score 1.9137799739837646 Hits@1 0.8273809523809523 Hits@3 0.9285714285714286 Hits@10 0.9761904761904762 MRR 0.8859292587812814 cur_rank 0 abs_cur_rank 2 total_num 167 865\n",
      "0 1\n",
      "215 311 44\n",
      "checkcorrect 130 130 real score 0.7596952557563782 Hits@1 0.8224852071005917 Hits@3 0.9230769230769231 Hits@10 0.9763313609467456 MRR 0.8821663637589069 cur_rank 3 abs_cur_rank 4 total_num 168 865\n",
      "215 142\n",
      "215 95 139\n",
      "checkcorrect 382 382 real score 1.9476390540599824 Hits@1 0.8235294117647058 Hits@3 0.9235294117647059 Hits@10 0.9764705882352941 MRR 0.8828595027956192 cur_rank 0 abs_cur_rank 0 total_num 169 865\n",
      "215 150\n",
      "215 173 419\n",
      "checkcorrect 32 32 real score 1.9636858701705933 Hits@1 0.8245614035087719 Hits@3 0.9239766081871345 Hits@10 0.9766081871345029 MRR 0.8835445349430132 cur_rank 0 abs_cur_rank 0 total_num 170 865\n",
      "215 150\n",
      "215 212 937\n",
      "checkcorrect 96 96 real score 1.7481565296649935 Hits@1 0.8255813953488372 Hits@3 0.9244186046511628 Hits@10 0.9767441860465116 MRR 0.8842216016003214 cur_rank 0 abs_cur_rank 0 total_num 171 865\n",
      "215 6\n",
      "215 195 9\n",
      "checkcorrect 356 356 real score 0.8729341492056847 Hits@1 0.8208092485549133 Hits@3 0.9190751445086706 Hits@10 0.976878612716763 MRR 0.8805555807818224 cur_rank 3 abs_cur_rank 3 total_num 172 865\n",
      "215 150\n",
      "215 453 515\n",
      "checkcorrect 56 56 real score 1.5738962948322297 Hits@1 0.8160919540229885 Hits@3 0.9137931034482759 Hits@10 0.9770114942528736 MRR 0.876931698133651 cur_rank 3 abs_cur_rank 3 total_num 173 865\n",
      "215 150\n",
      "215 580 521\n",
      "checkcorrect 12 12 real score 1.9467591881752013 Hits@1 0.8171428571428572 Hits@3 0.9142857142857143 Hits@10 0.9771428571428571 MRR 0.8776349455728872 cur_rank 0 abs_cur_rank 0 total_num 174 865\n",
      "215 150\n",
      "215 127 174\n",
      "checkcorrect 298 298 real score 1.912818193435669 Hits@1 0.8125 Hits@3 0.9147727272727273 Hits@10 0.9772727272727273 MRR 0.8754892924730413 cur_rank 1 abs_cur_rank 2 total_num 175 865\n",
      "215 150\n",
      "215 613 547\n",
      "checkcorrect 70 70 real score 1.9470047771930696 Hits@1 0.8135593220338984 Hits@3 0.9152542372881356 Hits@10 0.9774011299435028 MRR 0.8761927427980524 cur_rank 0 abs_cur_rank 0 total_num 176 865\n",
      "215 42\n",
      "215 118 142\n",
      "checkcorrect 140 140 real score 1.8259143710136412 Hits@1 0.8089887640449438 Hits@3 0.9157303370786517 Hits@10 0.9775280898876404 MRR 0.8740793004227824 cur_rank 1 abs_cur_rank 1 total_num 177 865\n",
      "215 134\n",
      "215 52 844\n",
      "checkcorrect 0 0 real score 1.5502603232860566 Hits@1 0.8044692737430168 Hits@3 0.9162011173184358 Hits@10 0.9776536312849162 MRR 0.8719894719288004 cur_rank 1 abs_cur_rank 1 total_num 178 865\n",
      "215 150\n",
      "215 202 132\n",
      "checkcorrect 160 160 real score 1.950962495803833 Hits@1 0.8055555555555556 Hits@3 0.9166666666666666 Hits@10 0.9777777777777777 MRR 0.8727006415291959 cur_rank 0 abs_cur_rank 0 total_num 179 865\n",
      "215 144\n",
      "215 893 178\n",
      "checkcorrect 22 22 real score 1.8902706801891327 Hits@1 0.8066298342541437 Hits@3 0.9171270718232044 Hits@10 0.9779005524861878 MRR 0.8734039529019628 cur_rank 0 abs_cur_rank 0 total_num 180 865\n",
      "0 1\n",
      "0 2 3\n",
      "checkcorrect 218 218 real score 0.0 Hits@1 0.8021978021978022 Hits@3 0.9120879120879121 Hits@10 0.9725274725274725 MRR 0.8686554383911093 cur_rank 108 abs_cur_rank 109 total_num 181 865\n",
      "215 150\n",
      "215 889 475\n",
      "checkcorrect 22 22 real score 1.9022843658924102 Hits@1 0.8032786885245902 Hits@3 0.912568306010929 Hits@10 0.9726775956284153 MRR 0.8693731682359666 cur_rank 0 abs_cur_rank 0 total_num 182 865\n",
      "215 150\n",
      "215 338 777\n",
      "checkcorrect 96 96 real score 1.9299553096294404 Hits@1 0.8043478260869565 Hits@3 0.9130434782608695 Hits@10 0.9728260869565217 MRR 0.8700830966694667 cur_rank 0 abs_cur_rank 0 total_num 183 865\n",
      "215 150\n",
      "215 138 252\n",
      "checkcorrect 32 32 real score 1.9540475368499757 Hits@1 0.8054054054054054 Hits@3 0.9135135135135135 Hits@10 0.972972972972973 MRR 0.8707853502009831 cur_rank 0 abs_cur_rank 0 total_num 184 865\n",
      "215 150\n",
      "215 398 318\n",
      "checkcorrect 54 54 real score 1.9073086023330688 Hits@1 0.8064516129032258 Hits@3 0.9139784946236559 Hits@10 0.9731182795698925 MRR 0.8714800526192574 cur_rank 0 abs_cur_rank 0 total_num 185 865\n",
      "215 3\n",
      "215 27 15\n",
      "checkcorrect 402 402 real score 1.6194846272468566 Hits@1 0.8074866310160428 Hits@3 0.9144385026737968 Hits@10 0.9732620320855615 MRR 0.8721673250651437 cur_rank 0 abs_cur_rank 1 total_num 186 865\n",
      "215 150\n",
      "215 222 426\n",
      "checkcorrect 32 32 real score 1.9656995773315429 Hits@1 0.8085106382978723 Hits@3 0.9148936170212766 Hits@10 0.973404255319149 MRR 0.8728472861020313 cur_rank 0 abs_cur_rank 0 total_num 187 865\n",
      "215 28\n",
      "215 72 84\n",
      "checkcorrect 198 198 real score 1.7791970729827882 Hits@1 0.8095238095238095 Hits@3 0.9153439153439153 Hits@10 0.9735449735449735 MRR 0.8735200517840311 cur_rank 0 abs_cur_rank 0 total_num 188 865\n",
      "215 150\n",
      "215 530 507\n",
      "checkcorrect 12 12 real score 1.9525828957557678 Hits@1 0.8105263157894737 Hits@3 0.9157894736842105 Hits@10 0.9736842105263158 MRR 0.8741857357220099 cur_rank 0 abs_cur_rank 0 total_num 189 865\n",
      "215 150\n",
      "215 161 1484\n",
      "checkcorrect 312 312 real score 1.8263419449329377 Hits@1 0.8115183246073299 Hits@3 0.9162303664921466 Hits@10 0.9738219895287958 MRR 0.8748444491475491 cur_rank 0 abs_cur_rank 0 total_num 190 865\n",
      "215 140\n",
      "215 174 130\n",
      "checkcorrect 160 160 real score 1.950961709022522 Hits@1 0.8125 Hits@3 0.9166666666666666 Hits@10 0.9739583333333334 MRR 0.8754963009749056 cur_rank 0 abs_cur_rank 0 total_num 191 865\n",
      "215 89\n",
      "215 490 45\n",
      "checkcorrect 210 210 real score 1.9413097977638243 Hits@1 0.8134715025906736 Hits@3 0.917098445595855 Hits@10 0.9740932642487047 MRR 0.8761413978610461 cur_rank 0 abs_cur_rank 0 total_num 192 865\n",
      "215 150\n",
      "215 543 211\n",
      "checkcorrect 40 40 real score 1.9435114443302153 Hits@1 0.8144329896907216 Hits@3 0.9175257731958762 Hits@10 0.9742268041237113 MRR 0.8767798442638242 cur_rank 0 abs_cur_rank 0 total_num 193 865\n",
      "215 107\n",
      "215 416 386\n",
      "checkcorrect 320 320 real score 1.0032628059387207 Hits@1 0.8102564102564103 Hits@3 0.9128205128205128 Hits@10 0.9743589743589743 MRR 0.8729245630111891 cur_rank 7 abs_cur_rank 7 total_num 194 865\n",
      "215 150\n",
      "215 525 492\n",
      "checkcorrect 50 50 real score 1.9126132905483246 Hits@1 0.8112244897959183 Hits@3 0.9132653061224489 Hits@10 0.9744897959183674 MRR 0.8735729070774586 cur_rank 0 abs_cur_rank 1 total_num 195 865\n",
      "215 49\n",
      "215 758 197\n",
      "checkcorrect 48 48 real score 1.6585618019104005 Hits@1 0.8121827411167513 Hits@3 0.9137055837563451 Hits@10 0.9746192893401016 MRR 0.8742146689704664 cur_rank 0 abs_cur_rank 0 total_num 196 865\n",
      "215 150\n",
      "215 60 817\n",
      "checkcorrect 96 96 real score 1.9405029833316803 Hits@1 0.8131313131313131 Hits@3 0.9141414141414141 Hits@10 0.9747474747474747 MRR 0.8748499484201105 cur_rank 0 abs_cur_rank 0 total_num 197 865\n",
      "215 150\n",
      "215 199 990\n",
      "checkcorrect 96 96 real score 1.8607880055904389 Hits@1 0.8140703517587939 Hits@3 0.914572864321608 Hits@10 0.9748743718592965 MRR 0.8754788431516678 cur_rank 0 abs_cur_rank 0 total_num 198 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 14\n",
      "215 759 54\n",
      "checkcorrect 64 64 real score 0.7386250881478191 Hits@1 0.81 Hits@3 0.91 Hits@10 0.975 MRR 0.8719347822692427 cur_rank 5 abs_cur_rank 5 total_num 199 865\n",
      "215 150\n",
      "215 889 697\n",
      "checkcorrect 96 96 real score 1.8275405287742614 Hits@1 0.8109452736318408 Hits@3 0.9104477611940298 Hits@10 0.9751243781094527 MRR 0.8725719226559628 cur_rank 0 abs_cur_rank 0 total_num 200 865\n",
      "215 150\n",
      "215 463 228\n",
      "checkcorrect 40 40 real score 1.9470044732093812 Hits@1 0.8118811881188119 Hits@3 0.9108910891089109 Hits@10 0.9752475247524752 MRR 0.8732027547220225 cur_rank 0 abs_cur_rank 0 total_num 201 865\n",
      "215 50\n",
      "215 352 105\n",
      "checkcorrect 22 22 real score 1.9450085878372194 Hits@1 0.812807881773399 Hits@3 0.9113300492610837 Hits@10 0.9753694581280788 MRR 0.8738273716938352 cur_rank 0 abs_cur_rank 0 total_num 202 865\n",
      "215 27\n",
      "215 69 21\n",
      "checkcorrect 14 14 real score 1.9015584349632264 Hits@1 0.8137254901960784 Hits@3 0.9117647058823529 Hits@10 0.9754901960784313 MRR 0.8744458649698458 cur_rank 0 abs_cur_rank 0 total_num 203 865\n",
      "215 150\n",
      "215 988 587\n",
      "checkcorrect 164 164 real score 1.735922396183014 Hits@1 0.8097560975609757 Hits@3 0.9121951219512195 Hits@10 0.975609756097561 MRR 0.872619299774871 cur_rank 1 abs_cur_rank 2 total_num 204 865\n",
      "215 150\n",
      "215 247 427\n",
      "checkcorrect 32 32 real score 1.9464365661144258 Hits@1 0.8106796116504854 Hits@3 0.912621359223301 Hits@10 0.9757281553398058 MRR 0.8732376526885851 cur_rank 0 abs_cur_rank 0 total_num 205 865\n",
      "215 144\n",
      "215 201 157\n",
      "checkcorrect 172 172 real score 1.9854569911956788 Hits@1 0.8115942028985508 Hits@3 0.9130434782608695 Hits@10 0.9758454106280193 MRR 0.8738500311780123 cur_rank 0 abs_cur_rank 0 total_num 206 865\n",
      "215 102\n",
      "215 216 363\n",
      "checkcorrect 142 142 real score 1.656237655878067 Hits@1 0.8076923076923077 Hits@3 0.9086538461538461 Hits@10 0.9759615384615384 MRR 0.8706103675665795 cur_rank 4 abs_cur_rank 4 total_num 207 865\n",
      "215 54\n",
      "215 61 444\n",
      "checkcorrect 56 56 real score 1.3262439206242562 Hits@1 0.8038277511961722 Hits@3 0.9043062200956937 Hits@10 0.9760765550239234 MRR 0.8676409399705671 cur_rank 3 abs_cur_rank 3 total_num 208 865\n",
      "215 150\n",
      "215 32 823\n",
      "checkcorrect 94 94 real score 1.9838729023933412 Hits@1 0.8047619047619048 Hits@3 0.9047619047619048 Hits@10 0.9761904761904762 MRR 0.8682712212088025 cur_rank 0 abs_cur_rank 0 total_num 209 865\n",
      "215 83\n",
      "215 333 355\n",
      "checkcorrect 50 50 real score 1.9140711903572083 Hits@1 0.8056872037914692 Hits@3 0.9052132701421801 Hits@10 0.976303317535545 MRR 0.8688955282172917 cur_rank 0 abs_cur_rank 1 total_num 210 865\n",
      "215 150\n",
      "215 325 826\n",
      "checkcorrect 96 96 real score 1.9084714293479919 Hits@1 0.8066037735849056 Hits@3 0.9056603773584906 Hits@10 0.9764150943396226 MRR 0.8695139455370213 cur_rank 0 abs_cur_rank 0 total_num 211 865\n",
      "0 1\n",
      "215 221 36\n",
      "checkcorrect 218 218 real score 0.7371869385242462 Hits@1 0.8075117370892019 Hits@3 0.9061032863849765 Hits@10 0.9765258215962441 MRR 0.8701265561213546 cur_rank 0 abs_cur_rank 1 total_num 212 865\n",
      "215 150\n",
      "215 1003 891\n",
      "checkcorrect 50 50 real score 1.9072529435157777 Hits@1 0.8037383177570093 Hits@3 0.9065420560747663 Hits@10 0.9766355140186916 MRR 0.8683969927749932 cur_rank 1 abs_cur_rank 1 total_num 213 865\n",
      "215 150\n",
      "215 349 364\n",
      "checkcorrect 22 22 real score 1.9536142170429232 Hits@1 0.8046511627906977 Hits@3 0.9069767441860465 Hits@10 0.9767441860465116 MRR 0.869009099785342 cur_rank 0 abs_cur_rank 0 total_num 214 865\n",
      "215 150\n",
      "215 108 388\n",
      "checkcorrect 36 36 real score 1.895452046394348 Hits@1 0.8055555555555556 Hits@3 0.9074074074074074 Hits@10 0.9768518518518519 MRR 0.8696155391381877 cur_rank 0 abs_cur_rank 0 total_num 215 865\n",
      "215 24\n",
      "215 124 250\n",
      "checkcorrect 50 50 real score 1.5100977823138235 Hits@1 0.8064516129032258 Hits@3 0.9078341013824884 Hits@10 0.9769585253456221 MRR 0.8702163891882421 cur_rank 0 abs_cur_rank 0 total_num 216 865\n",
      "215 34\n",
      "215 442 54\n",
      "checkcorrect 54 54 real score 1.3626817882061004 Hits@1 0.8027522935779816 Hits@3 0.9036697247706422 Hits@10 0.9770642201834863 MRR 0.867142002081874 cur_rank 4 abs_cur_rank 4 total_num 217 865\n",
      "215 145\n",
      "215 1269 354\n",
      "checkcorrect 40 40 real score 1.9345075726509093 Hits@1 0.8036529680365296 Hits@3 0.9041095890410958 Hits@10 0.9771689497716894 MRR 0.8677486596066143 cur_rank 0 abs_cur_rank 0 total_num 218 865\n",
      "215 150\n",
      "215 395 804\n",
      "checkcorrect 40 40 real score 1.932710212469101 Hits@1 0.8045454545454546 Hits@3 0.9045454545454545 Hits@10 0.9772727272727273 MRR 0.8683498020629478 cur_rank 0 abs_cur_rank 0 total_num 219 865\n",
      "215 150\n",
      "215 216 246\n",
      "checkcorrect 382 382 real score 1.9300437569618225 Hits@1 0.8054298642533937 Hits@3 0.9049773755656109 Hits@10 0.9773755656108597 MRR 0.8689455043160567 cur_rank 0 abs_cur_rank 0 total_num 220 865\n",
      "215 93\n",
      "215 342 349\n",
      "checkcorrect 54 54 real score 1.4308511406183242 Hits@1 0.8018018018018018 Hits@3 0.9054054054054054 Hits@10 0.9774774774774775 MRR 0.8672835876299483 cur_rank 1 abs_cur_rank 1 total_num 221 865\n",
      "215 113\n",
      "215 426 279\n",
      "checkcorrect 54 54 real score 1.9575130939483643 Hits@1 0.8026905829596412 Hits@3 0.905829596412556 Hits@10 0.9775784753363229 MRR 0.8678787284925943 cur_rank 0 abs_cur_rank 0 total_num 222 865\n",
      "215 150\n",
      "215 472 295\n",
      "checkcorrect 0 0 real score 1.9716301202774047 Hits@1 0.8035714285714286 Hits@3 0.90625 Hits@10 0.9776785714285714 MRR 0.868468555597538 cur_rank 0 abs_cur_rank 0 total_num 223 865\n",
      "215 59\n",
      "215 9 428\n",
      "checkcorrect 342 342 real score 1.914827287197113 Hits@1 0.8044444444444444 Hits@3 0.9066666666666666 Hits@10 0.9777777777777777 MRR 0.8690531397948823 cur_rank 0 abs_cur_rank 0 total_num 224 865\n",
      "215 150\n",
      "215 240 502\n",
      "checkcorrect 12 12 real score 1.948039072751999 Hits@1 0.8053097345132744 Hits@3 0.9070796460176991 Hits@10 0.9778761061946902 MRR 0.8696325506807456 cur_rank 0 abs_cur_rank 0 total_num 225 865\n",
      "215 65\n",
      "215 40 74\n",
      "checkcorrect 190 190 real score 1.5383331239223481 Hits@1 0.801762114537445 Hits@3 0.9030837004405287 Hits@10 0.9779735682819384 MRR 0.866430896901787 cur_rank 6 abs_cur_rank 6 total_num 226 865\n",
      "215 150\n",
      "215 484 492\n",
      "checkcorrect 20 20 real score 1.9501484453678133 Hits@1 0.7982456140350878 Hits@3 0.9035087719298246 Hits@10 0.9780701754385965 MRR 0.8648237438452002 cur_rank 1 abs_cur_rank 1 total_num 227 865\n",
      "215 142\n",
      "215 420 486\n",
      "checkcorrect 268 268 real score 1.8926546037197114 Hits@1 0.7991266375545851 Hits@3 0.9039301310043668 Hits@10 0.9781659388646288 MRR 0.8654140331733872 cur_rank 0 abs_cur_rank 2 total_num 228 865\n",
      "215 150\n",
      "215 352 288\n",
      "checkcorrect 78 78 real score 1.8679184436798095 Hits@1 0.8 Hits@3 0.9043478260869565 Hits@10 0.9782608695652174 MRR 0.8659991895508942 cur_rank 0 abs_cur_rank 0 total_num 229 865\n",
      "215 150\n",
      "215 751 1041\n",
      "checkcorrect 320 320 real score 1.2931807339191437 Hits@1 0.7965367965367965 Hits@3 0.9004329004329005 Hits@10 0.9783549783549783 MRR 0.8627914008515396 cur_rank 7 abs_cur_rank 9 total_num 230 865\n",
      "215 9\n",
      "215 61 15\n",
      "checkcorrect 48 48 real score 1.802795034646988 Hits@1 0.7974137931034483 Hits@3 0.9008620689655172 Hits@10 0.978448275862069 MRR 0.8633828172271796 cur_rank 0 abs_cur_rank 0 total_num 231 865\n",
      "215 150\n",
      "215 449 850\n",
      "checkcorrect 360 360 real score 1.4810641556978226 Hits@1 0.7939914163090128 Hits@3 0.8969957081545065 Hits@10 0.9785407725321889 MRR 0.8603926191561043 cur_rank 5 abs_cur_rank 5 total_num 232 865\n",
      "215 56\n",
      "215 217 187\n",
      "checkcorrect 24 24 real score 1.8740362763404845 Hits@1 0.7948717948717948 Hits@3 0.8974358974358975 Hits@10 0.9786324786324786 MRR 0.8609892318947535 cur_rank 0 abs_cur_rank 0 total_num 233 865\n",
      "215 88\n",
      "215 280 188\n",
      "checkcorrect 2 2 real score 1.924592286348343 Hits@1 0.7957446808510639 Hits@3 0.8978723404255319 Hits@10 0.9787234042553191 MRR 0.8615807670781801 cur_rank 0 abs_cur_rank 0 total_num 234 865\n",
      "215 38\n",
      "215 115 90\n",
      "checkcorrect 54 54 real score 1.7486351132392883 Hits@1 0.7966101694915254 Hits@3 0.8983050847457628 Hits@10 0.9788135593220338 MRR 0.8621672892515776 cur_rank 0 abs_cur_rank 0 total_num 235 865\n",
      "215 138\n",
      "215 891 190\n",
      "checkcorrect 70 70 real score 1.9574718832969666 Hits@1 0.7974683544303798 Hits@3 0.8987341772151899 Hits@10 0.9789029535864979 MRR 0.8627488618707693 cur_rank 0 abs_cur_rank 0 total_num 236 865\n",
      "215 107\n",
      "215 201 750\n",
      "checkcorrect 56 56 real score 1.565873521566391 Hits@1 0.7941176470588235 Hits@3 0.8949579831932774 Hits@10 0.9789915966386554 MRR 0.860174286820892 cur_rank 3 abs_cur_rank 3 total_num 237 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 892 544\n",
      "checkcorrect 70 70 real score 1.9441433429718018 Hits@1 0.7949790794979079 Hits@3 0.895397489539749 Hits@10 0.9790794979079498 MRR 0.8607593316459092 cur_rank 0 abs_cur_rank 0 total_num 238 865\n",
      "215 7\n",
      "215 56 56\n",
      "checkcorrect 198 198 real score 1.8786766946315765 Hits@1 0.7958333333333333 Hits@3 0.8958333333333334 Hits@10 0.9791666666666666 MRR 0.8613395010973847 cur_rank 0 abs_cur_rank 0 total_num 239 865\n",
      "215 3\n",
      "215 218 35\n",
      "checkcorrect 48 48 real score 1.8956827640533447 Hits@1 0.7966804979253111 Hits@3 0.8962655601659751 Hits@10 0.979253112033195 MRR 0.8619148558646154 cur_rank 0 abs_cur_rank 0 total_num 240 865\n",
      "215 144\n",
      "215 882 263\n",
      "checkcorrect 382 382 real score 1.9482719182968138 Hits@1 0.7975206611570248 Hits@3 0.8966942148760331 Hits@10 0.9793388429752066 MRR 0.8624854556337699 cur_rank 0 abs_cur_rank 0 total_num 241 865\n",
      "215 150\n",
      "215 301 1382\n",
      "checkcorrect 48 48 real score 1.8715071856975556 Hits@1 0.7983539094650206 Hits@3 0.897119341563786 Hits@10 0.9794238683127572 MRR 0.863051359108528 cur_rank 0 abs_cur_rank 0 total_num 242 865\n",
      "215 150\n",
      "215 215 412\n",
      "checkcorrect 70 70 real score 1.8975850701332093 Hits@1 0.7991803278688525 Hits@3 0.8975409836065574 Hits@10 0.9795081967213115 MRR 0.8636126240302144 cur_rank 0 abs_cur_rank 0 total_num 243 865\n",
      "215 88\n",
      "215 9 148\n",
      "checkcorrect 64 64 real score 1.8570685386657715 Hits@1 0.8 Hits@3 0.8979591836734694 Hits@10 0.9795918367346939 MRR 0.864169307197438 cur_rank 0 abs_cur_rank 0 total_num 244 865\n",
      "215 16\n",
      "215 33 74\n",
      "checkcorrect 50 50 real score 1.7718075096607206 Hits@1 0.8008130081300813 Hits@3 0.8983739837398373 Hits@10 0.9796747967479674 MRR 0.8647214644852533 cur_rank 0 abs_cur_rank 1 total_num 245 865\n",
      "215 150\n",
      "215 361 600\n",
      "checkcorrect 40 40 real score 1.894219660758972 Hits@1 0.8016194331983806 Hits@3 0.8987854251012146 Hits@10 0.979757085020243 MRR 0.8652691508638555 cur_rank 0 abs_cur_rank 0 total_num 246 865\n",
      "215 150\n",
      "215 288 444\n",
      "checkcorrect 64 64 real score 1.7730886042118073 Hits@1 0.8024193548387096 Hits@3 0.8991935483870968 Hits@10 0.9798387096774194 MRR 0.8658124204168238 cur_rank 0 abs_cur_rank 0 total_num 247 865\n",
      "215 82\n",
      "215 515 182\n",
      "checkcorrect 56 56 real score 1.6275665342807768 Hits@1 0.7991967871485943 Hits@3 0.8995983935742972 Hits@10 0.9799196787148594 MRR 0.8636739501875729 cur_rank 2 abs_cur_rank 2 total_num 248 865\n",
      "215 150\n",
      "215 211 226\n",
      "checkcorrect 68 68 real score 1.9652029275894165 Hits@1 0.8 Hits@3 0.9 Hits@10 0.98 MRR 0.8642192543868227 cur_rank 0 abs_cur_rank 0 total_num 249 865\n",
      "215 150\n",
      "215 155 489\n",
      "checkcorrect 18 18 real score 1.956522488594055 Hits@1 0.8007968127490039 Hits@3 0.900398406374502 Hits@10 0.9800796812749004 MRR 0.8647602135326918 cur_rank 0 abs_cur_rank 0 total_num 250 865\n",
      "215 150\n",
      "215 263 1313\n",
      "checkcorrect 0 0 real score 0.776960339397192 Hits@1 0.7976190476190477 Hits@3 0.8968253968253969 Hits@10 0.9801587301587301 MRR 0.8621222761774033 cur_rank 4 abs_cur_rank 5 total_num 251 865\n",
      "215 149\n",
      "215 32 291\n",
      "checkcorrect 58 58 real score 1.8269811630249024 Hits@1 0.7984189723320159 Hits@3 0.8972332015810277 Hits@10 0.9802371541501976 MRR 0.8626672474178089 cur_rank 0 abs_cur_rank 0 total_num 252 865\n",
      "215 81\n",
      "215 600 182\n",
      "checkcorrect 22 22 real score 1.9557296931743622 Hits@1 0.7992125984251969 Hits@3 0.8976377952755905 Hits@10 0.9803149606299213 MRR 0.8632079275460852 cur_rank 0 abs_cur_rank 0 total_num 253 865\n",
      "215 149\n",
      "215 115 692\n",
      "checkcorrect 94 94 real score 1.9823139369487763 Hits@1 0.8 Hits@3 0.8980392156862745 Hits@10 0.9803921568627451 MRR 0.8637443670459045 cur_rank 0 abs_cur_rank 0 total_num 254 865\n",
      "215 12\n",
      "215 179 129\n",
      "checkcorrect 292 292 real score 1.8699327647686004 Hits@1 0.80078125 Hits@3 0.8984375 Hits@10 0.98046875 MRR 0.8642766156121314 cur_rank 0 abs_cur_rank 0 total_num 255 865\n",
      "0 1\n",
      "215 437 52\n",
      "checkcorrect 146 146 real score 0.8764736711978912 Hits@1 0.8015564202334631 Hits@3 0.8988326848249028 Hits@10 0.980544747081712 MRR 0.8648047221661699 cur_rank 0 abs_cur_rank 1 total_num 256 865\n",
      "215 71\n",
      "215 119 243\n",
      "checkcorrect 390 390 real score 1.7727904200553892 Hits@1 0.8023255813953488 Hits@3 0.8992248062015504 Hits@10 0.9806201550387597 MRR 0.8653287348709521 cur_rank 0 abs_cur_rank 0 total_num 257 865\n",
      "215 40\n",
      "215 31 75\n",
      "checkcorrect 142 142 real score 1.331285098567605 Hits@1 0.803088803088803 Hits@3 0.8996138996138996 Hits@10 0.9806949806949807 MRR 0.8658487011455817 cur_rank 0 abs_cur_rank 0 total_num 258 865\n",
      "215 137\n",
      "215 483 335\n",
      "checkcorrect 50 50 real score 1.9264171719551086 Hits@1 0.8 Hits@3 0.9 Hits@10 0.9807692307692307 MRR 0.8644415907565601 cur_rank 1 abs_cur_rank 1 total_num 259 865\n",
      "215 150\n",
      "215 603 701\n",
      "checkcorrect 114 114 real score 1.8717558920383452 Hits@1 0.8007662835249042 Hits@3 0.9003831417624522 Hits@10 0.9808429118773946 MRR 0.8649609716348875 cur_rank 0 abs_cur_rank 0 total_num 260 865\n",
      "215 150\n",
      "215 242 194\n",
      "checkcorrect 78 78 real score 1.8967697978019715 Hits@1 0.8015267175572519 Hits@3 0.9007633587786259 Hits@10 0.9809160305343512 MRR 0.8654763877736856 cur_rank 0 abs_cur_rank 0 total_num 261 865\n",
      "215 129\n",
      "215 599 463\n",
      "checkcorrect 50 50 real score 1.9140397548675536 Hits@1 0.8022813688212928 Hits@3 0.9011406844106464 Hits@10 0.9809885931558935 MRR 0.8659878843981204 cur_rank 0 abs_cur_rank 1 total_num 262 865\n",
      "215 150\n",
      "215 427 566\n",
      "checkcorrect 50 50 real score 1.944296956062317 Hits@1 0.803030303030303 Hits@3 0.9015151515151515 Hits@10 0.9810606060606061 MRR 0.8664955060481274 cur_rank 0 abs_cur_rank 1 total_num 263 865\n",
      "215 150\n",
      "215 90 916\n",
      "checkcorrect 96 96 real score 1.93860205411911 Hits@1 0.8037735849056604 Hits@3 0.9018867924528302 Hits@10 0.9811320754716981 MRR 0.866999296591342 cur_rank 0 abs_cur_rank 0 total_num 264 865\n",
      "215 91\n",
      "215 73 68\n",
      "checkcorrect 72 72 real score 1.86102437376976 Hits@1 0.8045112781954887 Hits@3 0.9022556390977443 Hits@10 0.981203007518797 MRR 0.8674992992357355 cur_rank 0 abs_cur_rank 0 total_num 265 865\n",
      "215 86\n",
      "215 891 166\n",
      "checkcorrect 70 70 real score 1.8255597591400146 Hits@1 0.8052434456928839 Hits@3 0.9026217228464419 Hits@10 0.9812734082397003 MRR 0.8679955565419687 cur_rank 0 abs_cur_rank 0 total_num 266 865\n",
      "215 150\n",
      "215 190 813\n",
      "checkcorrect 96 96 real score 1.8729881167411804 Hits@1 0.8059701492537313 Hits@3 0.9029850746268657 Hits@10 0.9813432835820896 MRR 0.8684881104354688 cur_rank 0 abs_cur_rank 0 total_num 267 865\n",
      "215 3\n",
      "0 3 3\n",
      "checkcorrect 230 230 real score 0.9953387081623077 Hits@1 0.8066914498141264 Hits@3 0.9033457249070632 Hits@10 0.9814126394052045 MRR 0.8689770022182366 cur_rank 0 abs_cur_rank 0 total_num 268 865\n",
      "215 149\n",
      "215 226 332\n",
      "checkcorrect 50 50 real score 1.9340555787086486 Hits@1 0.8074074074074075 Hits@3 0.9037037037037037 Hits@10 0.9814814814814815 MRR 0.8694622725803913 cur_rank 0 abs_cur_rank 1 total_num 269 865\n",
      "215 46\n",
      "215 226 59\n",
      "checkcorrect 2 2 real score 1.6749837100505829 Hits@1 0.8081180811808119 Hits@3 0.9040590405904059 Hits@10 0.981549815498155 MRR 0.8699439616114599 cur_rank 0 abs_cur_rank 0 total_num 270 865\n",
      "215 10\n",
      "215 90 30\n",
      "checkcorrect 224 224 real score 1.7467877805233 Hits@1 0.8088235294117647 Hits@3 0.9044117647058824 Hits@10 0.9816176470588235 MRR 0.8704221088114178 cur_rank 0 abs_cur_rank 0 total_num 271 865\n",
      "215 134\n",
      "215 336 1014\n",
      "checkcorrect 50 50 real score 1.9233366429805754 Hits@1 0.8058608058608059 Hits@3 0.9047619047619048 Hits@10 0.9816849816849816 MRR 0.869065251269984 cur_rank 1 abs_cur_rank 1 total_num 272 865\n",
      "215 92\n",
      "215 205 148\n",
      "checkcorrect 36 36 real score 1.886653470993042 Hits@1 0.8065693430656934 Hits@3 0.9051094890510949 Hits@10 0.9817518248175182 MRR 0.869543115316444 cur_rank 0 abs_cur_rank 0 total_num 273 865\n",
      "215 7\n",
      "215 176 117\n",
      "checkcorrect 50 50 real score 1.320611299574375 Hits@1 0.8072727272727273 Hits@3 0.9054545454545454 Hits@10 0.9818181818181818 MRR 0.8700175039880206 cur_rank 0 abs_cur_rank 0 total_num 274 865\n",
      "215 8\n",
      "215 92 17\n",
      "checkcorrect 216 216 real score 1.8521269977092742 Hits@1 0.8079710144927537 Hits@3 0.9057971014492754 Hits@10 0.9818840579710145 MRR 0.8704884550605277 cur_rank 0 abs_cur_rank 0 total_num 275 865\n",
      "215 150\n",
      "215 724 588\n",
      "checkcorrect 36 36 real score 1.8921649158000946 Hits@1 0.8086642599277978 Hits@3 0.9061371841155235 Hits@10 0.9819494584837545 MRR 0.8709560057642803 cur_rank 0 abs_cur_rank 0 total_num 276 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 571 274\n",
      "checkcorrect 50 50 real score 1.6995950281620025 Hits@1 0.8057553956834532 Hits@3 0.9064748201438849 Hits@10 0.9820143884892086 MRR 0.869621631642826 cur_rank 1 abs_cur_rank 1 total_num 277 865\n",
      "215 150\n",
      "215 174 99\n",
      "checkcorrect 160 160 real score 1.9509626030921936 Hits@1 0.8064516129032258 Hits@3 0.9068100358422939 Hits@10 0.982078853046595 MRR 0.8700889376226009 cur_rank 0 abs_cur_rank 0 total_num 278 865\n",
      "215 150\n",
      "215 174 508\n",
      "checkcorrect 12 12 real score 1.942299556732178 Hits@1 0.8071428571428572 Hits@3 0.9071428571428571 Hits@10 0.9821428571428571 MRR 0.8705529057025202 cur_rank 0 abs_cur_rank 0 total_num 279 865\n",
      "215 139\n",
      "215 237 218\n",
      "checkcorrect 12 12 real score 1.947059804201126 Hits@1 0.8078291814946619 Hits@3 0.9074733096085409 Hits@10 0.9822064056939501 MRR 0.8710135715185254 cur_rank 0 abs_cur_rank 0 total_num 280 865\n",
      "215 143\n",
      "215 262 361\n",
      "checkcorrect 168 168 real score 1.9537635624408722 Hits@1 0.8085106382978723 Hits@3 0.9078014184397163 Hits@10 0.9822695035460993 MRR 0.8714709702010839 cur_rank 0 abs_cur_rank 0 total_num 281 865\n",
      "215 150\n",
      "215 388 277\n",
      "checkcorrect 22 22 real score 1.9439577162265778 Hits@1 0.8091872791519434 Hits@3 0.9081272084805654 Hits@10 0.9823321554770318 MRR 0.8719251363841188 cur_rank 0 abs_cur_rank 0 total_num 282 865\n",
      "215 150\n",
      "215 939 466\n",
      "checkcorrect 70 70 real score 1.9210492432117463 Hits@1 0.8098591549295775 Hits@3 0.9084507042253521 Hits@10 0.9823943661971831 MRR 0.8723761042137522 cur_rank 0 abs_cur_rank 0 total_num 283 865\n",
      "215 150\n",
      "215 350 197\n",
      "checkcorrect 264 264 real score 0.7929749973118305 Hits@1 0.8070175438596491 Hits@3 0.9052631578947369 Hits@10 0.9824561403508771 MRR 0.8698163885598694 cur_rank 6 abs_cur_rank 6 total_num 284 865\n",
      "215 48\n",
      "215 922 96\n",
      "checkcorrect 24 24 real score 1.8247718095779417 Hits@1 0.8076923076923077 Hits@3 0.9055944055944056 Hits@10 0.9825174825174825 MRR 0.8702715760124573 cur_rank 0 abs_cur_rank 0 total_num 285 865\n",
      "215 150\n",
      "215 762 986\n",
      "checkcorrect 22 22 real score 1.9163933634757995 Hits@1 0.8083623693379791 Hits@3 0.9059233449477352 Hits@10 0.9825783972125436 MRR 0.870723591427048 cur_rank 0 abs_cur_rank 0 total_num 286 865\n",
      "215 5\n",
      "0 14 5\n",
      "checkcorrect 132 132 real score 0.9969563364982605 Hits@1 0.8090277777777778 Hits@3 0.90625 Hits@10 0.9826388888888888 MRR 0.8711724678457041 cur_rank 0 abs_cur_rank 0 total_num 287 865\n",
      "215 136\n",
      "215 141 75\n",
      "checkcorrect 98 98 real score 1.9410983502864838 Hits@1 0.8096885813148789 Hits@3 0.9065743944636678 Hits@10 0.9826989619377162 MRR 0.8716182378531584 cur_rank 0 abs_cur_rank 0 total_num 288 865\n",
      "215 97\n",
      "215 102 126\n",
      "checkcorrect 36 36 real score 0.9599024085327983 Hits@1 0.8103448275862069 Hits@3 0.906896551724138 Hits@10 0.9827586206896551 MRR 0.8720609335846993 cur_rank 0 abs_cur_rank 0 total_num 289 865\n",
      "215 11\n",
      "215 262 115\n",
      "checkcorrect 50 50 real score 1.6624429762363433 Hits@1 0.8109965635738832 Hits@3 0.9072164948453608 Hits@10 0.9828178694158075 MRR 0.8725005867338927 cur_rank 0 abs_cur_rank 0 total_num 290 865\n",
      "215 150\n",
      "215 651 442\n",
      "checkcorrect 6 6 real score 1.9841574788093568 Hits@1 0.8116438356164384 Hits@3 0.9075342465753424 Hits@10 0.9828767123287672 MRR 0.8729372285601465 cur_rank 0 abs_cur_rank 0 total_num 291 865\n",
      "215 10\n",
      "215 9 58\n",
      "checkcorrect 362 362 real score 1.567831039428711 Hits@1 0.8122866894197952 Hits@3 0.9078498293515358 Hits@10 0.9829351535836177 MRR 0.8733708898961187 cur_rank 0 abs_cur_rank 0 total_num 292 865\n",
      "215 149\n",
      "215 937 352\n",
      "checkcorrect 22 22 real score 1.8985103726387025 Hits@1 0.8129251700680272 Hits@3 0.9081632653061225 Hits@10 0.9829931972789115 MRR 0.8738016011549754 cur_rank 0 abs_cur_rank 0 total_num 293 865\n",
      "215 150\n",
      "215 727 390\n",
      "checkcorrect 54 54 real score 1.7843269467353822 Hits@1 0.8135593220338984 Hits@3 0.9084745762711864 Hits@10 0.9830508474576272 MRR 0.874229392337501 cur_rank 0 abs_cur_rank 0 total_num 294 865\n",
      "215 106\n",
      "215 300 205\n",
      "checkcorrect 54 54 real score 1.803138417005539 Hits@1 0.8141891891891891 Hits@3 0.9087837837837838 Hits@10 0.9831081081081081 MRR 0.8746542930390635 cur_rank 0 abs_cur_rank 0 total_num 295 865\n",
      "215 149\n",
      "215 436 204\n",
      "checkcorrect 22 22 real score 1.950419509410858 Hits@1 0.8148148148148148 Hits@3 0.9090909090909091 Hits@10 0.9831649831649831 MRR 0.8750763324564403 cur_rank 0 abs_cur_rank 0 total_num 296 865\n",
      "215 134\n",
      "215 208 176\n",
      "checkcorrect 32 32 real score 1.9645511209964752 Hits@1 0.8154362416107382 Hits@3 0.9093959731543624 Hits@10 0.9832214765100671 MRR 0.875495539394506 cur_rank 0 abs_cur_rank 0 total_num 297 865\n",
      "215 11\n",
      "215 176 9\n",
      "checkcorrect 216 216 real score 1.838906568288803 Hits@1 0.8160535117056856 Hits@3 0.9096989966555183 Hits@10 0.9832775919732442 MRR 0.8759119422727852 cur_rank 0 abs_cur_rank 0 total_num 298 865\n",
      "215 150\n",
      "215 607 652\n",
      "checkcorrect 22 22 real score 1.9198575615882874 Hits@1 0.8166666666666667 Hits@3 0.91 Hits@10 0.9833333333333333 MRR 0.876325569131876 cur_rank 0 abs_cur_rank 0 total_num 299 865\n",
      "0 2\n",
      "215 260 79\n",
      "checkcorrect 28 28 real score 0.724083536863327 Hits@1 0.813953488372093 Hits@3 0.9069767441860465 Hits@10 0.9833887043189369 MRR 0.874244753287584 cur_rank 3 abs_cur_rank 4 total_num 300 865\n",
      "0 1\n",
      "215 200 27\n",
      "checkcorrect 104 104 real score 0.7843273699283599 Hits@1 0.8112582781456954 Hits@3 0.9039735099337748 Hits@10 0.9834437086092715 MRR 0.8720121547667642 cur_rank 4 abs_cur_rank 4 total_num 301 865\n",
      "215 144\n",
      "215 21 686\n",
      "checkcorrect 96 96 real score 1.8436697185039521 Hits@1 0.8118811881188119 Hits@3 0.9042904290429042 Hits@10 0.9834983498349835 MRR 0.8724345568962468 cur_rank 0 abs_cur_rank 0 total_num 302 865\n",
      "215 94\n",
      "215 126 396\n",
      "checkcorrect 24 24 real score 1.88950474858284 Hits@1 0.8125 Hits@3 0.9046052631578947 Hits@10 0.9835526315789473 MRR 0.8728541800643512 cur_rank 0 abs_cur_rank 0 total_num 303 865\n",
      "215 109\n",
      "215 515 275\n",
      "checkcorrect 24 24 real score 1.4515335738658903 Hits@1 0.8131147540983606 Hits@3 0.9049180327868852 Hits@10 0.9836065573770492 MRR 0.8732710516051239 cur_rank 0 abs_cur_rank 1 total_num 304 865\n",
      "215 88\n",
      "215 893 280\n",
      "checkcorrect 286 286 real score 0.931171202659607 Hits@1 0.8104575163398693 Hits@3 0.9019607843137255 Hits@10 0.9836601307189542 MRR 0.8709618869484623 cur_rank 5 abs_cur_rank 5 total_num 305 865\n",
      "215 136\n",
      "215 66 69\n",
      "checkcorrect 386 386 real score 1.693185293674469 Hits@1 0.8110749185667753 Hits@3 0.9022801302931596 Hits@10 0.9837133550488599 MRR 0.8713822065349494 cur_rank 0 abs_cur_rank 0 total_num 306 865\n",
      "215 150\n",
      "215 448 947\n",
      "checkcorrect 56 56 real score 1.8989438891410826 Hits@1 0.8116883116883117 Hits@3 0.9025974025974026 Hits@10 0.9837662337662337 MRR 0.8717997967734723 cur_rank 0 abs_cur_rank 0 total_num 307 865\n",
      "215 118\n",
      "215 391 640\n",
      "checkcorrect 216 216 real score 1.7403734147548675 Hits@1 0.8090614886731392 Hits@3 0.9029126213592233 Hits@10 0.9838187702265372 MRR 0.8700571868594265 cur_rank 2 abs_cur_rank 3 total_num 308 865\n",
      "215 86\n",
      "215 28 154\n",
      "checkcorrect 418 418 real score 0.08197295106947422 Hits@1 0.8064516129032258 Hits@3 0.9 Hits@10 0.9806451612903225 MRR 0.8673150669018154 cur_rank 49 abs_cur_rank 49 total_num 309 865\n",
      "215 104\n",
      "0 4 896\n",
      "checkcorrect 96 96 real score 0.9993319690227509 Hits@1 0.8070739549839229 Hits@3 0.9003215434083601 Hits@10 0.9807073954983923 MRR 0.8677417065580796 cur_rank 0 abs_cur_rank 0 total_num 310 865\n",
      "215 150\n",
      "215 888 658\n",
      "checkcorrect 50 50 real score 1.9424940824508667 Hits@1 0.8076923076923077 Hits@3 0.9006410256410257 Hits@10 0.9807692307692307 MRR 0.8681656113447525 cur_rank 0 abs_cur_rank 1 total_num 311 865\n",
      "215 150\n",
      "215 515 591\n",
      "checkcorrect 50 50 real score 1.9446201801300047 Hits@1 0.805111821086262 Hits@3 0.9009584664536742 Hits@10 0.9808306709265175 MRR 0.8669893633851845 cur_rank 1 abs_cur_rank 1 total_num 312 865\n",
      "215 117\n",
      "215 424 588\n",
      "checkcorrect 102 102 real score 1.7433395206928253 Hits@1 0.8057324840764332 Hits@3 0.9012738853503185 Hits@10 0.9808917197452229 MRR 0.8674129641387349 cur_rank 0 abs_cur_rank 0 total_num 313 865\n",
      "215 137\n",
      "215 691 242\n",
      "checkcorrect 382 382 real score 1.8836592018604277 Hits@1 0.8063492063492064 Hits@3 0.9015873015873016 Hits@10 0.9809523809523809 MRR 0.8678338753636913 cur_rank 0 abs_cur_rank 0 total_num 314 865\n",
      "215 9\n",
      "215 59 30\n",
      "checkcorrect 40 40 real score 1.6991051137447357 Hits@1 0.8069620253164557 Hits@3 0.9018987341772152 Hits@10 0.9810126582278481 MRR 0.868252122593553 cur_rank 0 abs_cur_rank 0 total_num 315 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 333 784\n",
      "checkcorrect 96 96 real score 1.8449232459068297 Hits@1 0.807570977917981 Hits@3 0.9022082018927445 Hits@10 0.9810725552050473 MRR 0.8686677310396301 cur_rank 0 abs_cur_rank 0 total_num 316 865\n",
      "215 126\n",
      "215 195 198\n",
      "checkcorrect 32 32 real score 1.9645063519477843 Hits@1 0.8081761006289309 Hits@3 0.9025157232704403 Hits@10 0.9811320754716981 MRR 0.8690807255961093 cur_rank 0 abs_cur_rank 0 total_num 317 865\n",
      "215 138\n",
      "215 389 291\n",
      "checkcorrect 22 22 real score 1.9430204153060915 Hits@1 0.8087774294670846 Hits@3 0.9028213166144201 Hits@10 0.9811912225705329 MRR 0.8694911308450243 cur_rank 0 abs_cur_rank 0 total_num 318 865\n",
      "215 150\n",
      "215 222 259\n",
      "checkcorrect 284 284 real score 1.9518767476081849 Hits@1 0.809375 Hits@3 0.903125 Hits@10 0.98125 MRR 0.8698989710611336 cur_rank 0 abs_cur_rank 1 total_num 319 865\n",
      "215 78\n",
      "215 334 150\n",
      "checkcorrect 40 40 real score 1.925175940990448 Hits@1 0.8099688473520249 Hits@3 0.9034267912772586 Hits@10 0.9813084112149533 MRR 0.8703042702167064 cur_rank 0 abs_cur_rank 0 total_num 320 865\n",
      "215 150\n",
      "215 46 716\n",
      "checkcorrect 96 96 real score 1.8315032482147218 Hits@1 0.8105590062111802 Hits@3 0.9037267080745341 Hits@10 0.9813664596273292 MRR 0.8707070519862198 cur_rank 0 abs_cur_rank 0 total_num 321 865\n",
      "215 150\n",
      "215 586 735\n",
      "checkcorrect 0 0 real score 1.9169895112514497 Hits@1 0.8111455108359134 Hits@3 0.9040247678018576 Hits@10 0.9814241486068112 MRR 0.8711073397509683 cur_rank 0 abs_cur_rank 0 total_num 322 865\n",
      "215 104\n",
      "215 995 44\n",
      "checkcorrect 40 40 real score 1.7543160021305084 Hits@1 0.8117283950617284 Hits@3 0.904320987654321 Hits@10 0.9814814814814815 MRR 0.8715051566035887 cur_rank 0 abs_cur_rank 0 total_num 323 865\n",
      "215 150\n",
      "215 906 989\n",
      "checkcorrect 50 50 real score 1.9311316311359406 Hits@1 0.8123076923076923 Hits@3 0.9046153846153846 Hits@10 0.9815384615384616 MRR 0.8719005253525007 cur_rank 0 abs_cur_rank 1 total_num 324 865\n",
      "215 150\n",
      "215 184 821\n",
      "checkcorrect 0 0 real score 1.93125062584877 Hits@1 0.8128834355828221 Hits@3 0.9049079754601227 Hits@10 0.9815950920245399 MRR 0.8722934685262661 cur_rank 0 abs_cur_rank 0 total_num 325 865\n",
      "0 1\n",
      "215 306 29\n",
      "checkcorrect 28 28 real score 0.883848923444748 Hits@1 0.8103975535168195 Hits@3 0.9021406727828746 Hits@10 0.981651376146789 MRR 0.8703904303962163 cur_rank 3 abs_cur_rank 3 total_num 326 865\n",
      "215 30\n",
      "215 353 57\n",
      "checkcorrect 64 64 real score 1.8450093150138853 Hits@1 0.8109756097560976 Hits@3 0.9024390243902439 Hits@10 0.9817073170731707 MRR 0.8707855815230572 cur_rank 0 abs_cur_rank 0 total_num 327 865\n",
      "215 150\n",
      "215 452 444\n",
      "checkcorrect 0 0 real score 1.8888876348733903 Hits@1 0.8115501519756839 Hits@3 0.9027355623100304 Hits@10 0.9817629179331308 MRR 0.8711783305153883 cur_rank 0 abs_cur_rank 0 total_num 328 865\n",
      "215 150\n",
      "215 108 747\n",
      "checkcorrect 44 44 real score 1.8392475724220276 Hits@1 0.8121212121212121 Hits@3 0.9030303030303031 Hits@10 0.9818181818181818 MRR 0.8715686992107963 cur_rank 0 abs_cur_rank 0 total_num 329 865\n",
      "215 146\n",
      "215 269 589\n",
      "checkcorrect 2 2 real score 1.9003190636634826 Hits@1 0.8126888217522659 Hits@3 0.9033232628398792 Hits@10 0.9818731117824774 MRR 0.8719567091829691 cur_rank 0 abs_cur_rank 0 total_num 330 865\n",
      "215 89\n",
      "215 356 271\n",
      "checkcorrect 22 22 real score 1.949111658334732 Hits@1 0.8132530120481928 Hits@3 0.9036144578313253 Hits@10 0.9819277108433735 MRR 0.8723423817456709 cur_rank 0 abs_cur_rank 0 total_num 331 865\n",
      "215 150\n",
      "215 21 1605\n",
      "checkcorrect 146 146 real score 1.7038649380207063 Hits@1 0.8108108108108109 Hits@3 0.9039039039039038 Hits@10 0.9819819819819819 MRR 0.8712242364551434 cur_rank 1 abs_cur_rank 1 total_num 332 865\n",
      "215 149\n",
      "215 270 761\n",
      "checkcorrect 2 2 real score 1.878085619211197 Hits@1 0.811377245508982 Hits@3 0.9041916167664671 Hits@10 0.9820359281437125 MRR 0.8716097926334214 cur_rank 0 abs_cur_rank 0 total_num 333 865\n",
      "215 11\n",
      "215 49 27\n",
      "checkcorrect 110 110 real score 1.0780587762594223 Hits@1 0.808955223880597 Hits@3 0.9044776119402985 Hits@10 0.982089552238806 MRR 0.8705005096703365 cur_rank 1 abs_cur_rank 1 total_num 334 865\n",
      "215 9\n",
      "215 51 14\n",
      "checkcorrect 4 4 real score 1.8717330813407898 Hits@1 0.8095238095238095 Hits@3 0.9047619047619048 Hits@10 0.9821428571428571 MRR 0.8708859248201273 cur_rank 0 abs_cur_rank 0 total_num 335 865\n",
      "215 137\n",
      "215 249 162\n",
      "checkcorrect 98 98 real score 1.6368700504302978 Hits@1 0.8100890207715133 Hits@3 0.9050445103857567 Hits@10 0.9821958456973294 MRR 0.871269052639652 cur_rank 0 abs_cur_rank 0 total_num 336 865\n",
      "215 139\n",
      "215 316 118\n",
      "checkcorrect 32 32 real score 1.9607971251010894 Hits@1 0.8106508875739645 Hits@3 0.9053254437869822 Hits@10 0.9822485207100592 MRR 0.871649913430659 cur_rank 0 abs_cur_rank 0 total_num 337 865\n",
      "215 103\n",
      "215 465 293\n",
      "checkcorrect 24 24 real score 1.2774577215313911 Hits@1 0.8112094395280236 Hits@3 0.9056047197640118 Hits@10 0.9823008849557522 MRR 0.8720285272553474 cur_rank 0 abs_cur_rank 1 total_num 338 865\n",
      "215 150\n",
      "215 295 654\n",
      "checkcorrect 6 6 real score 1.9839388072490691 Hits@1 0.8117647058823529 Hits@3 0.9058823529411765 Hits@10 0.9823529411764705 MRR 0.8724049139398905 cur_rank 0 abs_cur_rank 0 total_num 339 865\n",
      "215 144\n",
      "215 888 1257\n",
      "checkcorrect 24 24 real score 1.5769397795200348 Hits@1 0.8123167155425219 Hits@3 0.906158357771261 Hits@10 0.9824046920821115 MRR 0.8727790930778967 cur_rank 0 abs_cur_rank 0 total_num 340 865\n",
      "215 143\n",
      "215 26 801\n",
      "checkcorrect 40 40 real score 1.7056636750698089 Hits@1 0.8128654970760234 Hits@3 0.9064327485380117 Hits@10 0.9824561403508771 MRR 0.8731510840338093 cur_rank 0 abs_cur_rank 0 total_num 341 865\n",
      "215 149\n",
      "215 240 108\n",
      "checkcorrect 2 2 real score 1.826999968290329 Hits@1 0.8134110787172012 Hits@3 0.9067055393586005 Hits@10 0.9825072886297376 MRR 0.8735209059462471 cur_rank 0 abs_cur_rank 0 total_num 342 865\n",
      "215 149\n",
      "0 4 262\n",
      "checkcorrect 78 78 real score 0.9981460094451904 Hits@1 0.813953488372093 Hits@3 0.9069767441860465 Hits@10 0.9825581395348837 MRR 0.873888577731287 cur_rank 0 abs_cur_rank 0 total_num 343 865\n",
      "215 150\n",
      "215 146 777\n",
      "checkcorrect 44 44 real score 1.8869251549243926 Hits@1 0.8144927536231884 Hits@3 0.9072463768115943 Hits@10 0.9826086956521739 MRR 0.8742541180856891 cur_rank 0 abs_cur_rank 0 total_num 344 865\n",
      "215 150\n",
      "215 1038 466\n",
      "checkcorrect 54 54 real score 1.7250812530517579 Hits@1 0.8121387283236994 Hits@3 0.9075144508670521 Hits@10 0.9826589595375722 MRR 0.8731724587848635 cur_rank 1 abs_cur_rank 1 total_num 345 865\n",
      "215 65\n",
      "215 280 235\n",
      "checkcorrect 78 78 real score 1.4466351956129073 Hits@1 0.8126801152737753 Hits@3 0.9077809798270894 Hits@10 0.9827089337175793 MRR 0.8735379560217947 cur_rank 0 abs_cur_rank 0 total_num 346 865\n",
      "215 149\n",
      "215 433 352\n",
      "checkcorrect 6 6 real score 1.98399760723114 Hits@1 0.8132183908045977 Hits@3 0.9080459770114943 Hits@10 0.9827586206896551 MRR 0.873901352699893 cur_rank 0 abs_cur_rank 0 total_num 347 865\n",
      "215 132\n",
      "215 200 106\n",
      "checkcorrect 54 54 real score 1.9600728452205658 Hits@1 0.8137535816618912 Hits@3 0.9083094555873925 Hits@10 0.9828080229226361 MRR 0.874262666875538 cur_rank 0 abs_cur_rank 0 total_num 348 865\n",
      "215 150\n",
      "215 242 83\n",
      "checkcorrect 78 78 real score 1.9274442434310912 Hits@1 0.8142857142857143 Hits@3 0.9085714285714286 Hits@10 0.9828571428571429 MRR 0.8746219163987508 cur_rank 0 abs_cur_rank 0 total_num 349 865\n",
      "215 150\n",
      "215 103 825\n",
      "checkcorrect 124 124 real score 1.5796028554439545 Hits@1 0.8148148148148148 Hits@3 0.9088319088319088 Hits@10 0.9829059829059829 MRR 0.8749791189161332 cur_rank 0 abs_cur_rank 0 total_num 350 865\n",
      "215 52\n",
      "215 40 73\n",
      "checkcorrect 262 262 real score 1.8759796679019929 Hits@1 0.8125 Hits@3 0.90625 Hits@10 0.9829545454545454 MRR 0.8730615646010306 cur_rank 4 abs_cur_rank 4 total_num 351 865\n",
      "215 128\n",
      "215 533 159\n",
      "checkcorrect 22 22 real score 1.8303829848766326 Hits@1 0.8130311614730878 Hits@3 0.9065155807365439 Hits@10 0.9830028328611898 MRR 0.8734211635681665 cur_rank 0 abs_cur_rank 0 total_num 352 865\n",
      "215 150\n",
      "215 222 252\n",
      "checkcorrect 208 208 real score 1.9877130925655364 Hits@1 0.8135593220338984 Hits@3 0.9067796610169492 Hits@10 0.9830508474576272 MRR 0.8737787309027196 cur_rank 0 abs_cur_rank 0 total_num 353 865\n",
      "215 150\n",
      "215 285 828\n",
      "checkcorrect 0 0 real score 1.8199741691350937 Hits@1 0.8140845070422535 Hits@3 0.9070422535211268 Hits@10 0.9830985915492958 MRR 0.8741342837734162 cur_rank 0 abs_cur_rank 0 total_num 354 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 392 595\n",
      "checkcorrect 78 78 real score 1.9031240165233614 Hits@1 0.8146067415730337 Hits@3 0.9073033707865169 Hits@10 0.9831460674157303 MRR 0.8744878391560751 cur_rank 0 abs_cur_rank 0 total_num 355 865\n",
      "215 57\n",
      "215 212 127\n",
      "checkcorrect 110 110 real score 1.7793379545211792 Hits@1 0.8151260504201681 Hits@3 0.907563025210084 Hits@10 0.9831932773109243 MRR 0.8748394138363103 cur_rank 0 abs_cur_rank 0 total_num 356 865\n",
      "215 150\n",
      "215 549 353\n",
      "checkcorrect 40 40 real score 1.9184991061687469 Hits@1 0.8156424581005587 Hits@3 0.9078212290502793 Hits@10 0.9832402234636871 MRR 0.8751890244121864 cur_rank 0 abs_cur_rank 0 total_num 357 865\n",
      "215 150\n",
      "215 161 490\n",
      "checkcorrect 64 64 real score 1.7894309043884278 Hits@1 0.8161559888579387 Hits@3 0.9080779944289693 Hits@10 0.9832869080779945 MRR 0.8755366872968322 cur_rank 0 abs_cur_rank 0 total_num 358 865\n",
      "0 0\n",
      "0 1 727\n",
      "checkcorrect 48 48 real score 0.0 Hits@1 0.8138888888888889 Hits@3 0.9055555555555556 Hits@10 0.9805555555555555 MRR 0.873215752054341 cur_rank 24 abs_cur_rank 24 total_num 359 865\n",
      "215 150\n",
      "215 160 750\n",
      "checkcorrect 44 44 real score 1.8349284708499907 Hits@1 0.814404432132964 Hits@3 0.9058171745152355 Hits@10 0.9806094182825484 MRR 0.8735669549572376 cur_rank 0 abs_cur_rank 0 total_num 360 865\n",
      "215 150\n",
      "215 337 592\n",
      "checkcorrect 152 152 real score 1.3981679260730742 Hits@1 0.8121546961325967 Hits@3 0.9033149171270718 Hits@10 0.9806629834254144 MRR 0.8718443943081844 cur_rank 3 abs_cur_rank 4 total_num 361 865\n",
      "215 122\n",
      "215 417 1450\n",
      "checkcorrect 48 48 real score 1.8855152666568755 Hits@1 0.8126721763085399 Hits@3 0.9035812672176309 Hits@10 0.9807162534435262 MRR 0.8721974400538919 cur_rank 0 abs_cur_rank 0 total_num 362 865\n",
      "0 0\n",
      "0 2 19\n",
      "checkcorrect 112 112 real score 0.0 Hits@1 0.8104395604395604 Hits@3 0.9010989010989011 Hits@10 0.978021978021978 MRR 0.8698494906571754 cur_rank 56 abs_cur_rank 56 total_num 363 865\n",
      "215 150\n",
      "215 361 760\n",
      "checkcorrect 44 44 real score 1.8596403300762177 Hits@1 0.810958904109589 Hits@3 0.9013698630136986 Hits@10 0.9780821917808219 MRR 0.870206067395101 cur_rank 0 abs_cur_rank 0 total_num 364 865\n",
      "215 150\n",
      "215 39 731\n",
      "checkcorrect 44 44 real score 1.866840845346451 Hits@1 0.8114754098360656 Hits@3 0.9016393442622951 Hits@10 0.9781420765027322 MRR 0.8705606956262619 cur_rank 0 abs_cur_rank 0 total_num 365 865\n",
      "215 150\n",
      "215 315 431\n",
      "checkcorrect 54 54 real score 1.7945429056882858 Hits@1 0.8092643051771117 Hits@3 0.9019073569482289 Hits@10 0.9782016348773842 MRR 0.869550993458343 cur_rank 1 abs_cur_rank 1 total_num 366 865\n",
      "215 133\n",
      "215 164 232\n",
      "checkcorrect 68 68 real score 1.9601975440979005 Hits@1 0.8097826086956522 Hits@3 0.9021739130434783 Hits@10 0.9782608695652174 MRR 0.86990547445438 cur_rank 0 abs_cur_rank 0 total_num 367 865\n",
      "215 150\n",
      "215 226 1222\n",
      "checkcorrect 2 2 real score 1.8826939642429352 Hits@1 0.8102981029810298 Hits@3 0.9024390243902439 Hits@10 0.978319783197832 MRR 0.8702580341442056 cur_rank 0 abs_cur_rank 0 total_num 368 865\n",
      "215 150\n",
      "215 82 1576\n",
      "checkcorrect 312 312 real score 1.7127702176570891 Hits@1 0.8108108108108109 Hits@3 0.9027027027027027 Hits@10 0.9783783783783784 MRR 0.870608688105978 cur_rank 0 abs_cur_rank 0 total_num 369 865\n",
      "215 96\n",
      "215 531 77\n",
      "checkcorrect 22 22 real score 1.7473289847373963 Hits@1 0.8113207547169812 Hits@3 0.9029649595687331 Hits@10 0.9784366576819407 MRR 0.8709574517498971 cur_rank 0 abs_cur_rank 0 total_num 370 865\n",
      "215 9\n",
      "215 17 21\n",
      "checkcorrect 218 218 real score 1.8498734474182128 Hits@1 0.8118279569892473 Hits@3 0.9032258064516129 Hits@10 0.978494623655914 MRR 0.871304340320462 cur_rank 0 abs_cur_rank 0 total_num 371 865\n",
      "215 96\n",
      "215 237 198\n",
      "checkcorrect 32 32 real score 1.9671972930431365 Hits@1 0.8123324396782842 Hits@3 0.903485254691689 Hits@10 0.9785522788203753 MRR 0.8716493688986913 cur_rank 0 abs_cur_rank 0 total_num 372 865\n",
      "215 141\n",
      "215 332 337\n",
      "checkcorrect 40 40 real score 1.902848708629608 Hits@1 0.8128342245989305 Hits@3 0.9037433155080213 Hits@10 0.9786096256684492 MRR 0.8719925524043097 cur_rank 0 abs_cur_rank 0 total_num 373 865\n",
      "215 109\n",
      "215 389 640\n",
      "checkcorrect 24 24 real score 1.8569064617156983 Hits@1 0.8133333333333334 Hits@3 0.904 Hits@10 0.9786666666666667 MRR 0.8723339055978983 cur_rank 0 abs_cur_rank 1 total_num 374 865\n",
      "215 150\n",
      "215 572 516\n",
      "checkcorrect 50 50 real score 1.9292570352554321 Hits@1 0.8111702127659575 Hits@3 0.9042553191489362 Hits@10 0.9787234042553191 MRR 0.8713436558489677 cur_rank 1 abs_cur_rank 1 total_num 375 865\n",
      "215 93\n",
      "215 397 158\n",
      "checkcorrect 334 334 real score 1.728065627813339 Hits@1 0.8116710875331565 Hits@3 0.9045092838196287 Hits@10 0.9787798408488063 MRR 0.8716849193613047 cur_rank 0 abs_cur_rank 0 total_num 376 865\n",
      "215 150\n",
      "215 330 317\n",
      "checkcorrect 24 24 real score 1.8953914403915406 Hits@1 0.8121693121693122 Hits@3 0.9047619047619048 Hits@10 0.9788359788359788 MRR 0.8720243772465922 cur_rank 0 abs_cur_rank 0 total_num 377 865\n",
      "215 150\n",
      "215 521 378\n",
      "checkcorrect 24 24 real score 1.8870048940181734 Hits@1 0.8126649076517151 Hits@3 0.9050131926121372 Hits@10 0.978891820580475 MRR 0.8723620437973928 cur_rank 0 abs_cur_rank 0 total_num 378 865\n",
      "215 93\n",
      "215 642 126\n",
      "checkcorrect 36 36 real score 1.88474640250206 Hits@1 0.8131578947368421 Hits@3 0.9052631578947369 Hits@10 0.9789473684210527 MRR 0.8726979331558207 cur_rank 0 abs_cur_rank 0 total_num 379 865\n",
      "215 150\n",
      "215 142 695\n",
      "checkcorrect 96 96 real score 1.8941320717334746 Hits@1 0.8136482939632546 Hits@3 0.905511811023622 Hits@10 0.979002624671916 MRR 0.8730320593155166 cur_rank 0 abs_cur_rank 0 total_num 380 865\n",
      "215 3\n",
      "215 57 45\n",
      "checkcorrect 350 350 real score 1.4400556266307831 Hits@1 0.8115183246073299 Hits@3 0.9031413612565445 Hits@10 0.9790575916230366 MRR 0.8712701952858949 cur_rank 4 abs_cur_rank 5 total_num 381 865\n",
      "215 150\n",
      "215 517 1426\n",
      "checkcorrect 146 146 real score 1.8364824652671814 Hits@1 0.8120104438642297 Hits@3 0.9033942558746736 Hits@10 0.97911227154047 MRR 0.8716063044365845 cur_rank 0 abs_cur_rank 1 total_num 382 865\n",
      "215 94\n",
      "215 58 207\n",
      "checkcorrect 64 64 real score 1.3429946035146714 Hits@1 0.8125 Hits@3 0.9036458333333334 Hits@10 0.9791666666666666 MRR 0.8719406630187808 cur_rank 0 abs_cur_rank 0 total_num 383 865\n",
      "215 150\n",
      "215 240 1528\n",
      "checkcorrect 312 312 real score 1.8119143903255464 Hits@1 0.812987012987013 Hits@3 0.9038961038961039 Hits@10 0.9792207792207792 MRR 0.8722732846732775 cur_rank 0 abs_cur_rank 0 total_num 384 865\n",
      "0 1\n",
      "215 24 6\n",
      "checkcorrect 246 246 real score 0.8871169447898865 Hits@1 0.8134715025906736 Hits@3 0.9041450777202072 Hits@10 0.9792746113989638 MRR 0.8726041828995126 cur_rank 0 abs_cur_rank 0 total_num 385 865\n",
      "215 150\n",
      "215 188 468\n",
      "checkcorrect 54 54 real score 1.8488612234592439 Hits@1 0.813953488372093 Hits@3 0.9043927648578811 Hits@10 0.979328165374677 MRR 0.872933371057395 cur_rank 0 abs_cur_rank 0 total_num 386 865\n",
      "215 58\n",
      "215 165 183\n",
      "checkcorrect 54 54 real score 1.581516569852829 Hits@1 0.8144329896907216 Hits@3 0.904639175257732 Hits@10 0.979381443298969 MRR 0.8732608623691027 cur_rank 0 abs_cur_rank 1 total_num 387 865\n",
      "0 1\n",
      "215 45 13\n",
      "checkcorrect 70 70 real score 0.9639705359935761 Hits@1 0.8149100257069408 Hits@3 0.9048843187660668 Hits@10 0.9794344473007712 MRR 0.8735866699208531 cur_rank 0 abs_cur_rank 0 total_num 388 865\n",
      "215 150\n",
      "215 63 626\n",
      "checkcorrect 96 96 real score 1.9481973707675935 Hits@1 0.8153846153846154 Hits@3 0.9051282051282051 Hits@10 0.9794871794871794 MRR 0.8739108066646457 cur_rank 0 abs_cur_rank 0 total_num 389 865\n",
      "215 146\n",
      "215 377 348\n",
      "checkcorrect 22 22 real score 1.924237072467804 Hits@1 0.8158567774936062 Hits@3 0.9053708439897699 Hits@10 0.979539641943734 MRR 0.8742332854199791 cur_rank 0 abs_cur_rank 0 total_num 390 865\n",
      "215 72\n",
      "215 205 175\n",
      "checkcorrect 48 48 real score 1.3415286719799042 Hits@1 0.8137755102040817 Hits@3 0.9056122448979592 Hits@10 0.9795918367346939 MRR 0.8728534386034316 cur_rank 2 abs_cur_rank 2 total_num 391 865\n",
      "215 5\n",
      "215 158 98\n",
      "checkcorrect 54 54 real score 1.8837273955345153 Hits@1 0.8142493638676844 Hits@3 0.905852417302799 Hits@10 0.9796437659033079 MRR 0.8731769667494788 cur_rank 0 abs_cur_rank 0 total_num 392 865\n",
      "215 150\n",
      "215 420 310\n",
      "checkcorrect 198 198 real score 1.8494631707668305 Hits@1 0.8121827411167513 Hits@3 0.9060913705583756 Hits@10 0.9796954314720813 MRR 0.8722298170876781 cur_rank 1 abs_cur_rank 1 total_num 393 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 149\n",
      "215 262 247\n",
      "checkcorrect 382 382 real score 1.9170681834220886 Hits@1 0.8126582278481013 Hits@3 0.9063291139240506 Hits@10 0.979746835443038 MRR 0.8725532859051777 cur_rank 0 abs_cur_rank 0 total_num 394 865\n",
      "215 146\n",
      "215 394 297\n",
      "checkcorrect 78 78 real score 1.81382058262825 Hits@1 0.8131313131313131 Hits@3 0.9065656565656566 Hits@10 0.9797979797979798 MRR 0.8728751210417807 cur_rank 0 abs_cur_rank 0 total_num 395 865\n",
      "215 150\n",
      "215 430 820\n",
      "checkcorrect 0 0 real score 1.6835501492023468 Hits@1 0.8136020151133502 Hits@3 0.906801007556675 Hits@10 0.9798488664987406 MRR 0.8731953348426831 cur_rank 0 abs_cur_rank 0 total_num 396 865\n",
      "215 108\n",
      "215 32 428\n",
      "checkcorrect 94 94 real score 1.9863360643386843 Hits@1 0.8140703517587939 Hits@3 0.907035175879397 Hits@10 0.9798994974874372 MRR 0.8735139395290079 cur_rank 0 abs_cur_rank 0 total_num 397 865\n",
      "215 150\n",
      "215 513 588\n",
      "checkcorrect 64 64 real score 1.8787233769893645 Hits@1 0.8145363408521303 Hits@3 0.9072681704260651 Hits@10 0.9799498746867168 MRR 0.8738309471993613 cur_rank 0 abs_cur_rank 0 total_num 398 865\n",
      "215 70\n",
      "215 383 340\n",
      "checkcorrect 24 24 real score 1.87636256814003 Hits@1 0.815 Hits@3 0.9075 Hits@10 0.98 MRR 0.874146369831363 cur_rank 0 abs_cur_rank 0 total_num 399 865\n",
      "215 77\n",
      "215 471 173\n",
      "checkcorrect 356 356 real score 1.129395416378975 Hits@1 0.8129675810473815 Hits@3 0.9052369077306733 Hits@10 0.9800498753117207 MRR 0.8723820812947927 cur_rank 5 abs_cur_rank 6 total_num 400 865\n",
      "215 150\n",
      "215 328 296\n",
      "checkcorrect 0 0 real score 1.9800608694553374 Hits@1 0.8134328358208955 Hits@3 0.9054726368159204 Hits@10 0.9800995024875622 MRR 0.8726995388040095 cur_rank 0 abs_cur_rank 0 total_num 401 865\n",
      "215 69\n",
      "215 362 147\n",
      "checkcorrect 36 36 real score 1.8903623044490814 Hits@1 0.8138957816377171 Hits@3 0.9057071960297767 Hits@10 0.9801488833746899 MRR 0.8730154208417168 cur_rank 0 abs_cur_rank 0 total_num 402 865\n",
      "215 150\n",
      "215 523 791\n",
      "checkcorrect 0 0 real score 1.8082087278366088 Hits@1 0.8143564356435643 Hits@3 0.905940594059406 Hits@10 0.9801980198019802 MRR 0.87332973910696 cur_rank 0 abs_cur_rank 0 total_num 403 865\n",
      "215 9\n",
      "215 52 54\n",
      "checkcorrect 54 54 real score 1.9311601996421812 Hits@1 0.8148148148148148 Hits@3 0.9061728395061729 Hits@10 0.980246913580247 MRR 0.8736425051832392 cur_rank 0 abs_cur_rank 0 total_num 404 865\n",
      "215 63\n",
      "215 59 85\n",
      "checkcorrect 24 24 real score 1.3401311576366424 Hits@1 0.8152709359605911 Hits@3 0.9064039408866995 Hits@10 0.9802955665024631 MRR 0.8739537305399306 cur_rank 0 abs_cur_rank 1 total_num 405 865\n",
      "215 133\n",
      "215 79 204\n",
      "checkcorrect 240 240 real score 1.9079869925975799 Hits@1 0.8157248157248157 Hits@3 0.9066339066339066 Hits@10 0.9803439803439803 MRR 0.87426342653369 cur_rank 0 abs_cur_rank 0 total_num 406 865\n",
      "215 150\n",
      "215 660 559\n",
      "checkcorrect 54 54 real score 1.956966471672058 Hits@1 0.8161764705882353 Hits@3 0.9068627450980392 Hits@10 0.9803921568627451 MRR 0.874571604409833 cur_rank 0 abs_cur_rank 0 total_num 407 865\n",
      "215 122\n",
      "215 239 146\n",
      "checkcorrect 98 98 real score 1.8475150883197786 Hits@1 0.8166259168704156 Hits@3 0.9070904645476773 Hits@10 0.980440097799511 MRR 0.8748782753036964 cur_rank 0 abs_cur_rank 0 total_num 408 865\n",
      "215 97\n",
      "215 19 292\n",
      "checkcorrect 58 58 real score 1.757178384065628 Hits@1 0.8170731707317073 Hits@3 0.9073170731707317 Hits@10 0.9804878048780488 MRR 0.8751834502419801 cur_rank 0 abs_cur_rank 0 total_num 409 865\n",
      "215 17\n",
      "215 228 22\n",
      "checkcorrect 96 96 real score 1.8638793110847474 Hits@1 0.8175182481751825 Hits@3 0.9075425790754258 Hits@10 0.9805352798053528 MRR 0.8754871401440677 cur_rank 0 abs_cur_rank 0 total_num 410 865\n",
      "215 150\n",
      "215 207 731\n",
      "checkcorrect 96 96 real score 1.8814624726772309 Hits@1 0.8179611650485437 Hits@3 0.9077669902912622 Hits@10 0.9805825242718447 MRR 0.8757893558233297 cur_rank 0 abs_cur_rank 0 total_num 411 865\n",
      "215 150\n",
      "215 121 802\n",
      "checkcorrect 96 96 real score 1.945712411403656 Hits@1 0.8184019370460048 Hits@3 0.9079903147699758 Hits@10 0.9806295399515739 MRR 0.8760901079884064 cur_rank 0 abs_cur_rank 0 total_num 412 865\n",
      "215 150\n",
      "215 66 225\n",
      "checkcorrect 40 40 real score 1.971834796667099 Hits@1 0.8188405797101449 Hits@3 0.9082125603864735 Hits@10 0.9806763285024155 MRR 0.876389407244473 cur_rank 0 abs_cur_rank 0 total_num 413 865\n",
      "215 77\n",
      "215 435 83\n",
      "checkcorrect 334 334 real score 1.7811498403549195 Hits@1 0.8192771084337349 Hits@3 0.908433734939759 Hits@10 0.980722891566265 MRR 0.8766872640944864 cur_rank 0 abs_cur_rank 0 total_num 414 865\n",
      "215 150\n",
      "215 392 333\n",
      "checkcorrect 88 88 real score 1.7504762768745423 Hits@1 0.8197115384615384 Hits@3 0.9086538461538461 Hits@10 0.9807692307692307 MRR 0.8769836889404131 cur_rank 0 abs_cur_rank 0 total_num 415 865\n",
      "215 20\n",
      "215 274 224\n",
      "checkcorrect 154 154 real score 1.6514122486114502 Hits@1 0.8177458033573142 Hits@3 0.9088729016786571 Hits@10 0.9808153477218226 MRR 0.8760796513170548 cur_rank 1 abs_cur_rank 2 total_num 416 865\n",
      "215 106\n",
      "215 188 784\n",
      "checkcorrect 414 414 real score 1.113513308763504 Hits@1 0.8157894736842105 Hits@3 0.9090909090909091 Hits@10 0.9808612440191388 MRR 0.8747812151496296 cur_rank 2 abs_cur_rank 2 total_num 417 865\n",
      "215 150\n",
      "215 476 278\n",
      "checkcorrect 152 152 real score 1.3793645203113556 Hits@1 0.8138424821002387 Hits@3 0.9093078758949881 Hits@10 0.9809069212410502 MRR 0.8734889767682064 cur_rank 2 abs_cur_rank 4 total_num 418 865\n",
      "215 36\n",
      "215 292 105\n",
      "checkcorrect 322 322 real score 1.6617672383785247 Hits@1 0.8142857142857143 Hits@3 0.9095238095238095 Hits@10 0.9809523809523809 MRR 0.8737901934901868 cur_rank 0 abs_cur_rank 0 total_num 419 865\n",
      "215 50\n",
      "215 234 228\n",
      "checkcorrect 360 360 real score 1.4218008905649184 Hits@1 0.8123515439429929 Hits@3 0.9073634204275535 Hits@10 0.9809976247030879 MRR 0.8721897417241768 cur_rank 4 abs_cur_rank 4 total_num 420 865\n",
      "215 4\n",
      "215 19 9\n",
      "checkcorrect 388 388 real score 1.7385105967521666 Hits@1 0.8127962085308057 Hits@3 0.9075829383886256 Hits@10 0.981042654028436 MRR 0.8724926096347831 cur_rank 0 abs_cur_rank 0 total_num 421 865\n",
      "0 1\n",
      "0 1 1\n",
      "checkcorrect 372 372 real score 0.0 Hits@1 0.8108747044917257 Hits@3 0.9054373522458629 Hits@10 0.9787234042553191 MRR 0.8704426214171663 cur_rank 186 abs_cur_rank 186 total_num 422 865\n",
      "215 66\n",
      "215 185 75\n",
      "checkcorrect 270 270 real score 1.6361734986305236 Hits@1 0.8113207547169812 Hits@3 0.9056603773584906 Hits@10 0.9787735849056604 MRR 0.8707481812723145 cur_rank 0 abs_cur_rank 0 total_num 423 865\n",
      "215 42\n",
      "215 139 112\n",
      "checkcorrect 118 118 real score 1.241572231054306 Hits@1 0.8094117647058824 Hits@3 0.9035294117647059 Hits@10 0.9788235294117648 MRR 0.8689607999307587 cur_rank 8 abs_cur_rank 8 total_num 424 865\n",
      "215 57\n",
      "215 317 406\n",
      "checkcorrect 28 28 real score 1.7382873952388764 Hits@1 0.8075117370892019 Hits@3 0.9014084507042254 Hits@10 0.9788732394366197 MRR 0.8675078403065081 cur_rank 3 abs_cur_rank 3 total_num 425 865\n",
      "215 77\n",
      "215 394 113\n",
      "checkcorrect 146 146 real score 1.8458510637283325 Hits@1 0.8079625292740047 Hits@3 0.9016393442622951 Hits@10 0.9789227166276346 MRR 0.8678181263947832 cur_rank 0 abs_cur_rank 1 total_num 426 865\n",
      "215 150\n",
      "215 96 831\n",
      "checkcorrect 96 96 real score 1.9499394416809082 Hits@1 0.8084112149532711 Hits@3 0.9018691588785047 Hits@10 0.9789719626168224 MRR 0.8681269625480664 cur_rank 0 abs_cur_rank 0 total_num 427 865\n",
      "215 150\n",
      "215 266 492\n",
      "checkcorrect 6 6 real score 1.9840671062469482 Hits@1 0.8088578088578089 Hits@3 0.9020979020979021 Hits@10 0.9790209790209791 MRR 0.8684343589057633 cur_rank 0 abs_cur_rank 0 total_num 428 865\n",
      "215 150\n",
      "215 208 823\n",
      "checkcorrect 0 0 real score 1.9789834201335905 Hits@1 0.8093023255813954 Hits@3 0.9023255813953488 Hits@10 0.9790697674418605 MRR 0.8687403255129591 cur_rank 0 abs_cur_rank 0 total_num 429 865\n",
      "215 115\n",
      "215 70 195\n",
      "checkcorrect 78 78 real score 1.9102957606315614 Hits@1 0.8097447795823666 Hits@3 0.9025522041763341 Hits@10 0.9791183294663574 MRR 0.8690448723215137 cur_rank 0 abs_cur_rank 0 total_num 430 865\n",
      "215 150\n",
      "215 49 403\n",
      "checkcorrect 32 32 real score 1.9657528460025788 Hits@1 0.8101851851851852 Hits@3 0.9027777777777778 Hits@10 0.9791666666666666 MRR 0.8693480091911399 cur_rank 0 abs_cur_rank 0 total_num 431 865\n",
      "215 27\n",
      "215 629 265\n",
      "checkcorrect 56 56 real score 1.8383233785629272 Hits@1 0.8106235565819861 Hits@3 0.9030023094688222 Hits@10 0.9792147806004619 MRR 0.8696497458904675 cur_rank 0 abs_cur_rank 0 total_num 432 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 106\n",
      "215 68 142\n",
      "checkcorrect 158 158 real score 1.9381706774234773 Hits@1 0.8110599078341014 Hits@3 0.9032258064516129 Hits@10 0.9792626728110599 MRR 0.8699500920980932 cur_rank 0 abs_cur_rank 0 total_num 433 865\n",
      "215 148\n",
      "215 101 133\n",
      "checkcorrect 78 78 real score 1.9306022942066192 Hits@1 0.8114942528735632 Hits@3 0.903448275862069 Hits@10 0.9793103448275862 MRR 0.8702490574036148 cur_rank 0 abs_cur_rank 0 total_num 434 865\n",
      "215 141\n",
      "215 903 280\n",
      "checkcorrect 64 64 real score 1.8893453896045687 Hits@1 0.8119266055045872 Hits@3 0.9036697247706422 Hits@10 0.9793577981651376 MRR 0.8705466513086524 cur_rank 0 abs_cur_rank 0 total_num 435 865\n",
      "215 76\n",
      "215 35 75\n",
      "checkcorrect 410 410 real score 1.6520630657672881 Hits@1 0.8123569794050344 Hits@3 0.9038901601830663 Hits@10 0.9794050343249427 MRR 0.8708428832278545 cur_rank 0 abs_cur_rank 0 total_num 436 865\n",
      "215 150\n",
      "215 342 942\n",
      "checkcorrect 40 40 real score 1.9625363528728486 Hits@1 0.8127853881278538 Hits@3 0.9041095890410958 Hits@10 0.9794520547945206 MRR 0.8711377624898914 cur_rank 0 abs_cur_rank 0 total_num 437 865\n",
      "215 64\n",
      "215 171 262\n",
      "checkcorrect 188 188 real score 1.2383907601237296 Hits@1 0.8132118451025057 Hits@3 0.9043280182232346 Hits@10 0.979498861047836 MRR 0.8714312983384338 cur_rank 0 abs_cur_rank 0 total_num 438 865\n",
      "215 99\n",
      "215 285 188\n",
      "checkcorrect 58 58 real score 1.7711870551109314 Hits@1 0.8136363636363636 Hits@3 0.9045454545454545 Hits@10 0.9795454545454545 MRR 0.8717234999331192 cur_rank 0 abs_cur_rank 0 total_num 439 865\n",
      "215 150\n",
      "215 332 713\n",
      "checkcorrect 44 44 real score 1.8971335887908936 Hits@1 0.8140589569160998 Hits@3 0.9047619047619048 Hits@10 0.9795918367346939 MRR 0.8720143763505044 cur_rank 0 abs_cur_rank 0 total_num 440 865\n",
      "215 150\n",
      "215 675 587\n",
      "checkcorrect 54 54 real score 1.8945801198482513 Hits@1 0.8144796380090498 Hits@3 0.9049773755656109 Hits@10 0.9796380090497737 MRR 0.8723039365850055 cur_rank 0 abs_cur_rank 0 total_num 441 865\n",
      "215 150\n",
      "215 930 888\n",
      "checkcorrect 96 96 real score 1.8809088170528412 Hits@1 0.8148984198645598 Hits@3 0.9051918735891648 Hits@10 0.9796839729119639 MRR 0.8725921895498249 cur_rank 0 abs_cur_rank 0 total_num 442 865\n",
      "215 150\n",
      "215 759 475\n",
      "checkcorrect 22 22 real score 1.9007989108562469 Hits@1 0.8153153153153153 Hits@3 0.9054054054054054 Hits@10 0.9797297297297297 MRR 0.8728791440778658 cur_rank 0 abs_cur_rank 0 total_num 443 865\n",
      "215 150\n",
      "215 490 692\n",
      "checkcorrect 20 20 real score 1.9499253034591675 Hits@1 0.8157303370786517 Hits@3 0.9056179775280899 Hits@10 0.9797752808988764 MRR 0.8731648089226347 cur_rank 0 abs_cur_rank 1 total_num 444 865\n",
      "215 100\n",
      "215 280 74\n",
      "checkcorrect 78 78 real score 1.8995022833347321 Hits@1 0.8161434977578476 Hits@3 0.905829596412556 Hits@10 0.9798206278026906 MRR 0.873449192759131 cur_rank 0 abs_cur_rank 0 total_num 445 865\n",
      "215 136\n",
      "215 197 176\n",
      "checkcorrect 134 134 real score 1.655140221118927 Hits@1 0.8165548098434005 Hits@3 0.9060402684563759 Hits@10 0.9798657718120806 MRR 0.8737323041847258 cur_rank 0 abs_cur_rank 0 total_num 446 865\n",
      "215 150\n",
      "215 444 608\n",
      "checkcorrect 40 40 real score 1.9138072788715363 Hits@1 0.8169642857142857 Hits@3 0.90625 Hits@10 0.9799107142857143 MRR 0.8740141517200277 cur_rank 0 abs_cur_rank 0 total_num 447 865\n",
      "215 6\n",
      "215 9 17\n",
      "checkcorrect 4 4 real score 1.9665107131004333 Hits@1 0.8173719376391982 Hits@3 0.9064587973273942 Hits@10 0.9799554565701559 MRR 0.8742947438097382 cur_rank 0 abs_cur_rank 0 total_num 448 865\n",
      "215 150\n",
      "215 378 488\n",
      "checkcorrect 28 28 real score 1.7699922800064087 Hits@1 0.8177777777777778 Hits@3 0.9066666666666666 Hits@10 0.98 MRR 0.8745740888234943 cur_rank 0 abs_cur_rank 1 total_num 449 865\n",
      "215 111\n",
      "215 472 747\n",
      "checkcorrect 186 186 real score 1.5013894468545914 Hits@1 0.8181818181818182 Hits@3 0.9068736141906873 Hits@10 0.9800443458980045 MRR 0.8748521950567016 cur_rank 0 abs_cur_rank 0 total_num 450 865\n",
      "215 150\n",
      "215 246 720\n",
      "checkcorrect 44 44 real score 1.8848418235778808 Hits@1 0.8185840707964602 Hits@3 0.9070796460176991 Hits@10 0.9800884955752213 MRR 0.8751290707313549 cur_rank 0 abs_cur_rank 0 total_num 451 865\n",
      "215 150\n",
      "215 699 200\n",
      "checkcorrect 210 210 real score 1.6191827088594435 Hits@1 0.8167770419426048 Hits@3 0.9072847682119205 Hits@10 0.9801324503311258 MRR 0.8743009712374668 cur_rank 1 abs_cur_rank 1 total_num 452 865\n",
      "215 150\n",
      "215 608 323\n",
      "checkcorrect 22 22 real score 1.8320745825767517 Hits@1 0.8171806167400881 Hits@3 0.9074889867841409 Hits@10 0.9801762114537445 MRR 0.8745778413448732 cur_rank 0 abs_cur_rank 0 total_num 453 865\n",
      "215 141\n",
      "215 364 531\n",
      "checkcorrect 70 70 real score 1.9010447919368745 Hits@1 0.8175824175824176 Hits@3 0.9076923076923077 Hits@10 0.9802197802197802 MRR 0.8748534944408185 cur_rank 0 abs_cur_rank 0 total_num 454 865\n",
      "215 39\n",
      "215 173 18\n",
      "checkcorrect 188 188 real score 1.3511163651943208 Hits@1 0.8179824561403509 Hits@3 0.9078947368421053 Hits@10 0.9802631578947368 MRR 0.8751279385319571 cur_rank 0 abs_cur_rank 0 total_num 455 865\n",
      "215 150\n",
      "215 250 827\n",
      "checkcorrect 96 96 real score 1.9498971104621887 Hits@1 0.8183807439824945 Hits@3 0.9080962800875274 Hits@10 0.9803063457330415 MRR 0.8754011815548631 cur_rank 0 abs_cur_rank 0 total_num 456 865\n",
      "215 148\n",
      "215 34 292\n",
      "checkcorrect 58 58 real score 1.8874694466590882 Hits@1 0.8187772925764192 Hits@3 0.9082969432314411 Hits@10 0.980349344978166 MRR 0.8756732313767958 cur_rank 0 abs_cur_rank 0 total_num 457 865\n",
      "215 6\n",
      "215 94 14\n",
      "checkcorrect 246 246 real score 1.8658554613590241 Hits@1 0.8191721132897604 Hits@3 0.9084967320261438 Hits@10 0.9803921568627451 MRR 0.875944095796454 cur_rank 0 abs_cur_rank 0 total_num 458 865\n",
      "215 150\n",
      "215 650 704\n",
      "checkcorrect 6 6 real score 1.9841762840747834 Hits@1 0.8195652173913044 Hits@3 0.908695652173913 Hits@10 0.9804347826086957 MRR 0.8762137825447227 cur_rank 0 abs_cur_rank 0 total_num 459 865\n",
      "215 84\n",
      "215 90 433\n",
      "checkcorrect 50 50 real score 1.4957052707672118 Hits@1 0.8199566160520607 Hits@3 0.9088937093275488 Hits@10 0.9804772234273319 MRR 0.8764822992854066 cur_rank 0 abs_cur_rank 0 total_num 460 865\n",
      "215 143\n",
      "215 338 346\n",
      "checkcorrect 64 64 real score 1.8938235819339753 Hits@1 0.8203463203463204 Hits@3 0.9090909090909091 Hits@10 0.9805194805194806 MRR 0.8767496536159577 cur_rank 0 abs_cur_rank 0 total_num 461 865\n",
      "215 150\n",
      "215 69 800\n",
      "checkcorrect 96 96 real score 1.957116162776947 Hits@1 0.8207343412526998 Hits@3 0.9092872570194385 Hits@10 0.980561555075594 MRR 0.877015853068191 cur_rank 0 abs_cur_rank 0 total_num 462 865\n",
      "0 1\n",
      "0 3 718\n",
      "checkcorrect 96 96 real score 0.0 Hits@1 0.8189655172413793 Hits@3 0.9073275862068966 Hits@10 0.978448275862069 MRR 0.8751697158056848 cur_rank 48 abs_cur_rank 48 total_num 463 865\n",
      "215 29\n",
      "215 280 42\n",
      "checkcorrect 96 96 real score 1.7468425393104554 Hits@1 0.8193548387096774 Hits@3 0.9075268817204301 Hits@10 0.978494623655914 MRR 0.8754381680297586 cur_rank 0 abs_cur_rank 0 total_num 464 865\n",
      "0 0\n",
      "0 18 1\n",
      "checkcorrect 240 240 real score 0.0 Hits@1 0.8175965665236051 Hits@3 0.9055793991416309 Hits@10 0.9763948497854077 MRR 0.8735772802503168 cur_rank 120 abs_cur_rank 120 total_num 465 865\n",
      "215 106\n",
      "215 583 1187\n",
      "checkcorrect 54 54 real score 1.9123210608959198 Hits@1 0.8179871520342612 Hits@3 0.9057815845824411 Hits@10 0.9764453961456103 MRR 0.8738479927123076 cur_rank 0 abs_cur_rank 0 total_num 466 865\n",
      "215 114\n",
      "215 360 176\n",
      "checkcorrect 312 312 real score 1.5489945024251939 Hits@1 0.8183760683760684 Hits@3 0.905982905982906 Hits@10 0.9764957264957265 MRR 0.8741175482834351 cur_rank 0 abs_cur_rank 0 total_num 467 865\n",
      "215 52\n",
      "215 129 124\n",
      "checkcorrect 54 54 real score 1.3117696672677994 Hits@1 0.8166311300639659 Hits@3 0.9040511727078892 Hits@10 0.976545842217484 MRR 0.8726091242288152 cur_rank 5 abs_cur_rank 5 total_num 468 865\n",
      "215 125\n",
      "215 609 980\n",
      "checkcorrect 146 146 real score 1.81604260802269 Hits@1 0.8170212765957446 Hits@3 0.9042553191489362 Hits@10 0.9765957446808511 MRR 0.8728801686453497 cur_rank 0 abs_cur_rank 1 total_num 469 865\n",
      "215 51\n",
      "215 496 158\n",
      "checkcorrect 334 334 real score 1.635034453868866 Hits@1 0.8152866242038217 Hits@3 0.9023354564755839 Hits@10 0.9766454352441614 MRR 0.8714515483297544 cur_rank 4 abs_cur_rank 4 total_num 470 865\n",
      "215 9\n",
      "215 311 57\n",
      "checkcorrect 198 198 real score 1.8826040387153626 Hits@1 0.815677966101695 Hits@3 0.902542372881356 Hits@10 0.9766949152542372 MRR 0.87172389674431 cur_rank 0 abs_cur_rank 0 total_num 471 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 532 722\n",
      "checkcorrect 22 22 real score 1.9509424805641173 Hits@1 0.8160676532769556 Hits@3 0.9027484143763214 Hits@10 0.9767441860465116 MRR 0.8719950935799456 cur_rank 0 abs_cur_rank 0 total_num 472 865\n",
      "215 41\n",
      "215 80 126\n",
      "checkcorrect 248 248 real score 1.9148137092590332 Hits@1 0.8164556962025317 Hits@3 0.9029535864978903 Hits@10 0.9767932489451476 MRR 0.8722651461251357 cur_rank 0 abs_cur_rank 0 total_num 473 865\n",
      "215 112\n",
      "215 647 175\n",
      "checkcorrect 0 0 real score 1.9436236083507539 Hits@1 0.8168421052631579 Hits@3 0.9031578947368422 Hits@10 0.9768421052631578 MRR 0.8725340616069776 cur_rank 0 abs_cur_rank 0 total_num 474 865\n",
      "215 147\n",
      "215 142 202\n",
      "checkcorrect 206 206 real score 1.919972378015518 Hits@1 0.8172268907563025 Hits@3 0.9033613445378151 Hits@10 0.976890756302521 MRR 0.8728018471918368 cur_rank 0 abs_cur_rank 1 total_num 475 865\n",
      "215 98\n",
      "215 53 328\n",
      "checkcorrect 64 64 real score 1.9151392519474029 Hits@1 0.8176100628930818 Hits@3 0.9035639412997903 Hits@10 0.9769392033542977 MRR 0.8730685099859838 cur_rank 0 abs_cur_rank 0 total_num 476 865\n",
      "215 111\n",
      "215 438 362\n",
      "checkcorrect 50 50 real score 1.945687049627304 Hits@1 0.8179916317991632 Hits@3 0.9037656903765691 Hits@10 0.9769874476987448 MRR 0.8733340570362225 cur_rank 0 abs_cur_rank 1 total_num 477 865\n",
      "215 99\n",
      "215 160 85\n",
      "checkcorrect 58 58 real score 1.9674419939517975 Hits@1 0.8183716075156576 Hits@3 0.9039665970772442 Hits@10 0.9770354906054279 MRR 0.87359849533051 cur_rank 0 abs_cur_rank 0 total_num 478 865\n",
      "215 140\n",
      "215 565 484\n",
      "checkcorrect 54 54 real score 1.9414337158203123 Hits@1 0.81875 Hits@3 0.9041666666666667 Hits@10 0.9770833333333333 MRR 0.8738618317985715 cur_rank 0 abs_cur_rank 0 total_num 479 865\n",
      "215 141\n",
      "215 391 198\n",
      "checkcorrect 32 32 real score 1.9579083740711212 Hits@1 0.8191268191268192 Hits@3 0.9043659043659044 Hits@10 0.9771309771309772 MRR 0.8741240733125037 cur_rank 0 abs_cur_rank 0 total_num 480 865\n",
      "215 150\n",
      "215 190 338\n",
      "checkcorrect 266 266 real score 1.7281554996967317 Hits@1 0.8174273858921162 Hits@3 0.9045643153526971 Hits@10 0.9771784232365145 MRR 0.8733478822890338 cur_rank 1 abs_cur_rank 1 total_num 481 865\n",
      "215 80\n",
      "215 800 350\n",
      "checkcorrect 64 64 real score 1.9014483451843263 Hits@1 0.8178053830227743 Hits@3 0.9047619047619048 Hits@10 0.9772256728778468 MRR 0.8736101019944396 cur_rank 0 abs_cur_rank 0 total_num 482 865\n",
      "215 111\n",
      "215 51 199\n",
      "checkcorrect 32 32 real score 1.9605859160423278 Hits@1 0.8181818181818182 Hits@3 0.9049586776859504 Hits@10 0.9772727272727273 MRR 0.8738712381473436 cur_rank 0 abs_cur_rank 0 total_num 483 865\n",
      "215 136\n",
      "215 148 408\n",
      "checkcorrect 216 216 real score 1.7501282036304473 Hits@1 0.8164948453608247 Hits@3 0.9051546391752577 Hits@10 0.977319587628866 MRR 0.8731003696150811 cur_rank 1 abs_cur_rank 1 total_num 484 865\n",
      "215 150\n",
      "215 193 1227\n",
      "checkcorrect 78 78 real score 1.7116880595684052 Hits@1 0.8168724279835391 Hits@3 0.9053497942386831 Hits@10 0.977366255144033 MRR 0.8733614799656673 cur_rank 0 abs_cur_rank 0 total_num 485 865\n",
      "215 6\n",
      "215 107 22\n",
      "checkcorrect 64 64 real score 1.6439439117908479 Hits@1 0.8151950718685832 Hits@3 0.9055441478439425 Hits@10 0.9774127310061602 MRR 0.8725948239493108 cur_rank 1 abs_cur_rank 1 total_num 486 865\n",
      "215 150\n",
      "215 214 425\n",
      "checkcorrect 32 32 real score 1.9643625795841215 Hits@1 0.8155737704918032 Hits@3 0.9057377049180327 Hits@10 0.9774590163934426 MRR 0.8728559001297425 cur_rank 0 abs_cur_rank 0 total_num 487 865\n",
      "215 150\n",
      "215 346 900\n",
      "checkcorrect 0 0 real score 1.5510611087083817 Hits@1 0.8139059304703476 Hits@3 0.9059304703476483 Hits@10 0.9775051124744376 MRR 0.8720934136264097 cur_rank 1 abs_cur_rank 1 total_num 488 865\n",
      "215 150\n",
      "215 284 364\n",
      "checkcorrect 40 40 real score 1.9388920962810516 Hits@1 0.8142857142857143 Hits@3 0.9061224489795918 Hits@10 0.9775510204081632 MRR 0.8723544474761517 cur_rank 0 abs_cur_rank 0 total_num 489 865\n",
      "215 150\n",
      "215 336 212\n",
      "checkcorrect 70 70 real score 1.918942320346832 Hits@1 0.814663951120163 Hits@3 0.9063136456211812 Hits@10 0.9775967413441955 MRR 0.8726144180515566 cur_rank 0 abs_cur_rank 0 total_num 490 865\n",
      "215 77\n",
      "215 361 425\n",
      "checkcorrect 54 54 real score 1.7790831685066224 Hits@1 0.8150406504065041 Hits@3 0.9065040650406504 Hits@10 0.9776422764227642 MRR 0.8728733318360047 cur_rank 0 abs_cur_rank 1 total_num 491 865\n",
      "215 150\n",
      "215 490 581\n",
      "checkcorrect 50 50 real score 1.9092447102069854 Hits@1 0.8154158215010142 Hits@3 0.9066937119675457 Hits@10 0.9776876267748479 MRR 0.8731311952602725 cur_rank 0 abs_cur_rank 1 total_num 492 865\n",
      "215 150\n",
      "215 221 213\n",
      "checkcorrect 172 172 real score 1.9850251436233521 Hits@1 0.8157894736842105 Hits@3 0.9068825910931174 Hits@10 0.9777327935222672 MRR 0.8733880147030654 cur_rank 0 abs_cur_rank 0 total_num 493 865\n",
      "215 50\n",
      "215 111 63\n",
      "checkcorrect 258 258 real score 1.9667925000190736 Hits@1 0.8161616161616162 Hits@3 0.907070707070707 Hits@10 0.9777777777777777 MRR 0.8736437964915441 cur_rank 0 abs_cur_rank 0 total_num 494 865\n",
      "215 87\n",
      "215 73 134\n",
      "checkcorrect 146 146 real score 1.7423134624958039 Hits@1 0.8145161290322581 Hits@3 0.907258064516129 Hits@10 0.9778225806451613 MRR 0.8728904823857143 cur_rank 1 abs_cur_rank 1 total_num 495 865\n",
      "215 150\n",
      "215 907 663\n",
      "checkcorrect 50 50 real score 1.942252254486084 Hits@1 0.8148893360160966 Hits@3 0.9074446680080482 Hits@10 0.9778672032193159 MRR 0.8731462359422824 cur_rank 0 abs_cur_rank 1 total_num 496 865\n",
      "215 9\n",
      "215 13 29\n",
      "checkcorrect 88 88 real score 1.7773315072059632 Hits@1 0.8152610441767069 Hits@3 0.9076305220883534 Hits@10 0.9779116465863453 MRR 0.8734009623761332 cur_rank 0 abs_cur_rank 0 total_num 497 865\n",
      "0 2\n",
      "215 32 14\n",
      "checkcorrect 144 144 real score 0.9845200538635254 Hits@1 0.8156312625250501 Hits@3 0.9078156312625251 Hits@10 0.9779559118236473 MRR 0.8736546678623534 cur_rank 0 abs_cur_rank 0 total_num 498 865\n",
      "215 150\n",
      "215 129 740\n",
      "checkcorrect 44 44 real score 1.8829087138175964 Hits@1 0.816 Hits@3 0.908 Hits@10 0.978 MRR 0.8739073585266286 cur_rank 0 abs_cur_rank 0 total_num 499 865\n",
      "215 104\n",
      "215 267 542\n",
      "checkcorrect 266 266 real score 1.7898898422718048 Hits@1 0.8163672654690619 Hits@3 0.908183632734531 Hits@10 0.9780439121756487 MRR 0.8741590404457371 cur_rank 0 abs_cur_rank 0 total_num 500 865\n",
      "215 150\n",
      "215 136 394\n",
      "checkcorrect 70 70 real score 1.8480311155319213 Hits@1 0.8167330677290837 Hits@3 0.9083665338645418 Hits@10 0.9780876494023905 MRR 0.8744097196480365 cur_rank 0 abs_cur_rank 0 total_num 501 865\n",
      "215 150\n",
      "215 128 953\n",
      "checkcorrect 146 146 real score 1.8124873399734498 Hits@1 0.8151093439363817 Hits@3 0.9085487077534792 Hits@10 0.9781312127236581 MRR 0.8736653663286567 cur_rank 1 abs_cur_rank 1 total_num 502 865\n",
      "0 1\n",
      "0 40 5\n",
      "checkcorrect 404 404 real score 0.0 Hits@1 0.8134920634920635 Hits@3 0.9067460317460317 Hits@10 0.9761904761904762 MRR 0.8719416773247791 cur_rank 202 abs_cur_rank 202 total_num 503 865\n",
      "0 1\n",
      "215 45 187\n",
      "checkcorrect 142 142 real score 0.5953601956367492 Hits@1 0.8118811881188119 Hits@3 0.904950495049505 Hits@10 0.9762376237623762 MRR 0.8704625848944331 cur_rank 7 abs_cur_rank 7 total_num 504 865\n",
      "215 42\n",
      "215 141 189\n",
      "checkcorrect 30 30 real score 1.8167564392089843 Hits@1 0.8122529644268774 Hits@3 0.9051383399209486 Hits@10 0.9762845849802372 MRR 0.8707185876910843 cur_rank 0 abs_cur_rank 0 total_num 505 865\n",
      "215 150\n",
      "215 227 1380\n",
      "checkcorrect 194 194 real score 1.5742904007434846 Hits@1 0.8106508875739645 Hits@3 0.903353057199211 Hits@10 0.9763313609467456 MRR 0.8693956713445536 cur_rank 4 abs_cur_rank 4 total_num 506 865\n",
      "215 17\n",
      "215 126 90\n",
      "checkcorrect 420 420 real score 0.41227145716547964 Hits@1 0.8090551181102362 Hits@3 0.9015748031496063 Hits@10 0.9763779527559056 MRR 0.8679654773908383 cur_rank 6 abs_cur_rank 8 total_num 507 865\n",
      "215 89\n",
      "215 43 155\n",
      "checkcorrect 78 78 real score 1.9249315202236175 Hits@1 0.8094302554027505 Hits@3 0.9017681728880157 Hits@10 0.9764243614931237 MRR 0.8682248772387934 cur_rank 0 abs_cur_rank 0 total_num 508 865\n",
      "0 1\n",
      "215 232 17\n",
      "checkcorrect 48 48 real score 0.848825353384018 Hits@1 0.8098039215686275 Hits@3 0.9019607843137255 Hits@10 0.9764705882352941 MRR 0.8684832598324428 cur_rank 0 abs_cur_rank 0 total_num 509 865\n",
      "215 150\n",
      "215 465 286\n",
      "checkcorrect 54 54 real score 1.94451584815979 Hits@1 0.8101761252446184 Hits@3 0.9021526418786693 Hits@10 0.9765166340508806 MRR 0.8687406311439253 cur_rank 0 abs_cur_rank 0 total_num 510 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 92\n",
      "215 185 181\n",
      "checkcorrect 12 12 real score 1.9512748658657073 Hits@1 0.810546875 Hits@3 0.90234375 Hits@10 0.9765625 MRR 0.8689969970987224 cur_rank 0 abs_cur_rank 0 total_num 511 865\n",
      "215 150\n",
      "215 935 1479\n",
      "checkcorrect 146 146 real score 1.7853889346122742 Hits@1 0.8109161793372319 Hits@3 0.9025341130604289 Hits@10 0.9766081871345029 MRR 0.8692523635761128 cur_rank 0 abs_cur_rank 1 total_num 512 865\n",
      "215 126\n",
      "215 590 475\n",
      "checkcorrect 22 22 real score 1.9475900411605835 Hits@1 0.811284046692607 Hits@3 0.9027237354085603 Hits@10 0.9766536964980544 MRR 0.8695067364096223 cur_rank 0 abs_cur_rank 0 total_num 513 865\n",
      "215 146\n",
      "215 266 435\n",
      "checkcorrect 6 6 real score 1.9844990253448487 Hits@1 0.8116504854368932 Hits@3 0.9029126213592233 Hits@10 0.9766990291262136 MRR 0.8697601213874676 cur_rank 0 abs_cur_rank 0 total_num 514 865\n",
      "215 150\n",
      "215 949 506\n",
      "checkcorrect 360 360 real score 1.3786975175142289 Hits@1 0.810077519379845 Hits@3 0.9011627906976745 Hits@10 0.9767441860465116 MRR 0.8683513946848895 cur_rank 6 abs_cur_rank 6 total_num 515 865\n",
      "215 109\n",
      "215 45 74\n",
      "checkcorrect 262 262 real score 1.8753071427345276 Hits@1 0.8085106382978723 Hits@3 0.8994197292069632 Hits@10 0.97678916827853 MRR 0.8670586453721528 cur_rank 4 abs_cur_rank 4 total_num 516 865\n",
      "0 1\n",
      "215 154 24\n",
      "checkcorrect 108 108 real score 0.9817175030708313 Hits@1 0.806949806949807 Hits@3 0.8996138996138996 Hits@10 0.9768339768339769 MRR 0.8663500379486544 cur_rank 1 abs_cur_rank 1 total_num 517 865\n",
      "215 24\n",
      "215 325 193\n",
      "checkcorrect 50 50 real score 1.7035542726516724 Hits@1 0.8073217726396917 Hits@3 0.8998073217726397 Hits@10 0.976878612716763 MRR 0.8666075523264027 cur_rank 0 abs_cur_rank 1 total_num 518 865\n",
      "215 150\n",
      "215 170 292\n",
      "checkcorrect 52 52 real score 1.9346700370311738 Hits@1 0.8076923076923077 Hits@3 0.9 Hits@10 0.9769230769230769 MRR 0.8668640762642366 cur_rank 0 abs_cur_rank 0 total_num 519 865\n",
      "215 150\n",
      "215 228 821\n",
      "checkcorrect 96 96 real score 1.7927521884441375 Hits@1 0.8080614203454894 Hits@3 0.9001919385796545 Hits@10 0.9769673704414588 MRR 0.8671196154652648 cur_rank 0 abs_cur_rank 0 total_num 520 865\n",
      "215 150\n",
      "215 401 310\n",
      "checkcorrect 0 0 real score 1.9605746567249298 Hits@1 0.8084291187739464 Hits@3 0.9003831417624522 Hits@10 0.9770114942528736 MRR 0.8673741755888946 cur_rank 0 abs_cur_rank 0 total_num 521 865\n",
      "215 15\n",
      "215 111 85\n",
      "checkcorrect 112 112 real score 1.738748627901077 Hits@1 0.8087954110898662 Hits@3 0.9005736137667304 Hits@10 0.9770554493307839 MRR 0.8676277622512486 cur_rank 0 abs_cur_rank 0 total_num 522 865\n",
      "215 103\n",
      "215 32 434\n",
      "checkcorrect 70 70 real score 1.8576203346252442 Hits@1 0.8091603053435115 Hits@3 0.9007633587786259 Hits@10 0.9770992366412213 MRR 0.8678803810255783 cur_rank 0 abs_cur_rank 0 total_num 523 865\n",
      "215 150\n",
      "215 110 741\n",
      "checkcorrect 322 322 real score 1.9283236682415008 Hits@1 0.8095238095238095 Hits@3 0.900952380952381 Hits@10 0.9771428571428571 MRR 0.8681320374426724 cur_rank 0 abs_cur_rank 0 total_num 524 865\n",
      "215 46\n",
      "215 231 150\n",
      "checkcorrect 24 24 real score 1.8295570135116577 Hits@1 0.8098859315589354 Hits@3 0.9011406844106464 Hits@10 0.9771863117870723 MRR 0.8683827369912605 cur_rank 0 abs_cur_rank 0 total_num 525 865\n",
      "215 61\n",
      "215 307 128\n",
      "checkcorrect 2 2 real score 1.7505005896091461 Hits@1 0.8102466793168881 Hits@3 0.9013282732447818 Hits@10 0.9772296015180265 MRR 0.8686324851184117 cur_rank 0 abs_cur_rank 0 total_num 526 865\n",
      "215 110\n",
      "215 82 191\n",
      "checkcorrect 212 212 real score 1.5086793333292008 Hits@1 0.8087121212121212 Hits@3 0.8996212121212122 Hits@10 0.9772727272727273 MRR 0.8673661357147784 cur_rank 4 abs_cur_rank 4 total_num 527 865\n",
      "0 0\n",
      "0 102 1\n",
      "checkcorrect 78 78 real score 0.0 Hits@1 0.8071833648393195 Hits@3 0.8979206049149339 Hits@10 0.9754253308128544 MRR 0.8657737611671134 cur_rank 39 abs_cur_rank 39 total_num 528 865\n",
      "215 138\n",
      "215 197 191\n",
      "checkcorrect 266 266 real score 1.3467080621048808 Hits@1 0.8056603773584906 Hits@3 0.8962264150943396 Hits@10 0.9754716981132076 MRR 0.8646119238818923 cur_rank 3 abs_cur_rank 3 total_num 529 865\n",
      "215 77\n",
      "215 266 1645\n",
      "checkcorrect 48 48 real score 1.9060568928718566 Hits@1 0.8060263653483992 Hits@3 0.896421845574388 Hits@10 0.975517890772128 MRR 0.8648668920101751 cur_rank 0 abs_cur_rank 0 total_num 530 865\n",
      "215 150\n",
      "215 110 957\n",
      "checkcorrect 96 96 real score 1.871099406480789 Hits@1 0.806390977443609 Hits@3 0.8966165413533834 Hits@10 0.9755639097744361 MRR 0.8651209016116597 cur_rank 0 abs_cur_rank 0 total_num 531 865\n",
      "215 142\n",
      "215 388 211\n",
      "checkcorrect 386 386 real score 1.7894180834293365 Hits@1 0.8067542213883677 Hits@3 0.8968105065666041 Hits@10 0.975609756097561 MRR 0.8653739580814315 cur_rank 0 abs_cur_rank 0 total_num 532 865\n",
      "215 47\n",
      "215 887 531\n",
      "checkcorrect 116 116 real score 1.7767414093017577 Hits@1 0.8071161048689138 Hits@3 0.897003745318352 Hits@10 0.9756554307116105 MRR 0.8656260667741629 cur_rank 0 abs_cur_rank 2 total_num 533 865\n",
      "215 150\n",
      "215 61 835\n",
      "checkcorrect 102 102 real score 1.7464452505111694 Hits@1 0.8074766355140187 Hits@3 0.897196261682243 Hits@10 0.9757009345794393 MRR 0.8658772330044915 cur_rank 0 abs_cur_rank 0 total_num 534 865\n",
      "215 150\n",
      "215 203 713\n",
      "checkcorrect 44 44 real score 1.8863631725311278 Hits@1 0.8078358208955224 Hits@3 0.8973880597014925 Hits@10 0.9757462686567164 MRR 0.8661274620473935 cur_rank 0 abs_cur_rank 0 total_num 535 865\n",
      "215 26\n",
      "215 32 16\n",
      "checkcorrect 354 354 real score 1.8305226504802703 Hits@1 0.8081936685288641 Hits@3 0.8975791433891993 Hits@10 0.9757914338919925 MRR 0.866376759138553 cur_rank 0 abs_cur_rank 0 total_num 536 865\n",
      "215 148\n",
      "215 627 224\n",
      "checkcorrect 0 0 real score 1.8906441152095796 Hits@1 0.8085501858736059 Hits@3 0.8977695167286245 Hits@10 0.9758364312267658 MRR 0.8666251294747267 cur_rank 0 abs_cur_rank 0 total_num 537 865\n",
      "215 150\n",
      "215 24 262\n",
      "checkcorrect 78 78 real score 1.8720233976840972 Hits@1 0.8089053803339518 Hits@3 0.8979591836734694 Hits@10 0.9758812615955473 MRR 0.8668725782141057 cur_rank 0 abs_cur_rank 0 total_num 538 865\n",
      "215 143\n",
      "215 46 100\n",
      "checkcorrect 240 240 real score 1.900717055797577 Hits@1 0.8092592592592592 Hits@3 0.8981481481481481 Hits@10 0.975925925925926 MRR 0.8671191104766721 cur_rank 0 abs_cur_rank 0 total_num 539 865\n",
      "215 56\n",
      "215 21 156\n",
      "checkcorrect 168 168 real score 1.923724389076233 Hits@1 0.8096118299445472 Hits@3 0.8983364140480592 Hits@10 0.9759704251386322 MRR 0.8673647313445526 cur_rank 0 abs_cur_rank 0 total_num 540 865\n",
      "215 118\n",
      "215 765 283\n",
      "checkcorrect 22 22 real score 1.9508082687854766 Hits@1 0.8099630996309963 Hits@3 0.8985239852398524 Hits@10 0.9760147601476015 MRR 0.8676094458623671 cur_rank 0 abs_cur_rank 0 total_num 541 865\n",
      "215 150\n",
      "215 604 740\n",
      "checkcorrect 0 0 real score 1.826172724366188 Hits@1 0.8103130755064457 Hits@3 0.8987108655616943 Hits@10 0.9760589318600368 MRR 0.8678532590375745 cur_rank 0 abs_cur_rank 0 total_num 542 865\n",
      "215 149\n",
      "215 154 64\n",
      "checkcorrect 298 298 real score 1.913512498140335 Hits@1 0.8106617647058824 Hits@3 0.8988970588235294 Hits@10 0.9761029411764706 MRR 0.8680961758408143 cur_rank 0 abs_cur_rank 2 total_num 543 865\n",
      "215 133\n",
      "215 189 767\n",
      "checkcorrect 44 44 real score 1.8615591168403625 Hits@1 0.8110091743119267 Hits@3 0.8990825688073395 Hits@10 0.9761467889908257 MRR 0.8683382012062439 cur_rank 0 abs_cur_rank 0 total_num 544 865\n",
      "215 150\n",
      "215 145 828\n",
      "checkcorrect 96 96 real score 1.947552877664566 Hits@1 0.8113553113553114 Hits@3 0.8992673992673993 Hits@10 0.9761904761904762 MRR 0.8685793400318735 cur_rank 0 abs_cur_rank 0 total_num 545 865\n",
      "215 150\n",
      "215 243 403\n",
      "checkcorrect 32 32 real score 1.8719650268554688 Hits@1 0.8117001828153565 Hits@3 0.8994515539305301 Hits@10 0.9762340036563071 MRR 0.8688195971798958 cur_rank 0 abs_cur_rank 0 total_num 546 865\n",
      "215 104\n",
      "215 172 631\n",
      "checkcorrect 50 50 real score 1.908490628004074 Hits@1 0.8120437956204379 Hits@3 0.8996350364963503 Hits@10 0.9762773722627737 MRR 0.8690589774770127 cur_rank 0 abs_cur_rank 1 total_num 547 865\n",
      "215 150\n",
      "215 530 518\n",
      "checkcorrect 12 12 real score 1.9488549411296845 Hits@1 0.8123861566484517 Hits@3 0.8998178506375227 Hits@10 0.97632058287796 MRR 0.8692974857147595 cur_rank 0 abs_cur_rank 0 total_num 548 865\n",
      "215 38\n",
      "215 95 33\n",
      "checkcorrect 78 78 real score 1.9285639762878417 Hits@1 0.8127272727272727 Hits@3 0.9 Hits@10 0.9763636363636363 MRR 0.8695351266498236 cur_rank 0 abs_cur_rank 0 total_num 549 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 1022 895\n",
      "checkcorrect 36 36 real score 1.8740982115268707 Hits@1 0.8130671506352087 Hits@3 0.9001814882032668 Hits@10 0.9764065335753176 MRR 0.8697719050043611 cur_rank 0 abs_cur_rank 0 total_num 550 865\n",
      "0 1\n",
      "215 17 21\n",
      "checkcorrect 128 128 real score 0.8532412707805633 Hits@1 0.8134057971014492 Hits@3 0.9003623188405797 Hits@10 0.9764492753623188 MRR 0.8700078254663097 cur_rank 0 abs_cur_rank 0 total_num 551 865\n",
      "215 150\n",
      "215 204 238\n",
      "checkcorrect 172 172 real score 1.9851622998714447 Hits@1 0.8137432188065099 Hits@3 0.9005424954792043 Hits@10 0.976491862567812 MRR 0.8702428926896979 cur_rank 0 abs_cur_rank 0 total_num 552 865\n",
      "215 135\n",
      "215 393 301\n",
      "checkcorrect 78 78 real score 1.722356343269348 Hits@1 0.8140794223826715 Hits@3 0.9007220216606499 Hits@10 0.9765342960288809 MRR 0.8704771112949512 cur_rank 0 abs_cur_rank 0 total_num 553 865\n",
      "215 19\n",
      "215 10 63\n",
      "checkcorrect 224 224 real score 1.8100575506687164 Hits@1 0.8144144144144144 Hits@3 0.9009009009009009 Hits@10 0.9765765765765766 MRR 0.8707104858691945 cur_rank 0 abs_cur_rank 0 total_num 554 865\n",
      "0 2\n",
      "215 111 18\n",
      "checkcorrect 112 112 real score 0.8334524035453796 Hits@1 0.814748201438849 Hits@3 0.9010791366906474 Hits@10 0.9766187050359713 MRR 0.8709430209665521 cur_rank 0 abs_cur_rank 0 total_num 555 865\n",
      "215 150\n",
      "215 1190 1567\n",
      "checkcorrect 48 48 real score 1.8688879370689393 Hits@1 0.8150807899461401 Hits@3 0.9012567324955116 Hits@10 0.9766606822262118 MRR 0.8711747211084434 cur_rank 0 abs_cur_rank 0 total_num 556 865\n",
      "215 149\n",
      "215 74 781\n",
      "checkcorrect 96 96 real score 1.7767886996269227 Hits@1 0.8154121863799283 Hits@3 0.9014336917562724 Hits@10 0.9767025089605734 MRR 0.8714055907838762 cur_rank 0 abs_cur_rank 0 total_num 557 865\n",
      "215 147\n",
      "215 548 251\n",
      "checkcorrect 382 382 real score 1.8827369689941407 Hits@1 0.815742397137746 Hits@3 0.9016100178890877 Hits@10 0.9767441860465116 MRR 0.871635634449737 cur_rank 0 abs_cur_rank 0 total_num 558 865\n",
      "215 80\n",
      "215 53 130\n",
      "checkcorrect 190 190 real score 1.6759943068027496 Hits@1 0.8142857142857143 Hits@3 0.9 Hits@10 0.9767857142857143 MRR 0.8704362851025053 cur_rank 4 abs_cur_rank 4 total_num 559 865\n",
      "215 56\n",
      "215 429 90\n",
      "checkcorrect 24 24 real score 1.8926252722740173 Hits@1 0.8128342245989305 Hits@3 0.9001782531194296 Hits@10 0.9768270944741533 MRR 0.869775970868811 cur_rank 1 abs_cur_rank 1 total_num 560 865\n",
      "215 150\n",
      "215 937 650\n",
      "checkcorrect 22 22 real score 1.89593762755394 Hits@1 0.8131672597864769 Hits@3 0.900355871886121 Hits@10 0.9768683274021353 MRR 0.870007686223137 cur_rank 0 abs_cur_rank 0 total_num 561 865\n",
      "215 117\n",
      "215 154 174\n",
      "checkcorrect 206 206 real score 1.9194465756416321 Hits@1 0.8134991119005328 Hits@3 0.9005328596802842 Hits@10 0.9769094138543517 MRR 0.8702385784323321 cur_rank 0 abs_cur_rank 1 total_num 562 865\n",
      "215 53\n",
      "215 322 243\n",
      "checkcorrect 64 64 real score 1.8632607221603394 Hits@1 0.8138297872340425 Hits@3 0.900709219858156 Hits@10 0.9769503546099291 MRR 0.8704686518748279 cur_rank 0 abs_cur_rank 0 total_num 563 865\n",
      "215 150\n",
      "215 48 837\n",
      "checkcorrect 96 96 real score 1.9498937666416167 Hits@1 0.8141592920353983 Hits@3 0.9008849557522124 Hits@10 0.9769911504424779 MRR 0.8706979108980584 cur_rank 0 abs_cur_rank 0 total_num 564 865\n",
      "215 150\n",
      "215 298 433\n",
      "checkcorrect 194 194 real score 1.5828675448894503 Hits@1 0.8127208480565371 Hits@3 0.8992932862190812 Hits@10 0.9770318021201413 MRR 0.8695129322568956 cur_rank 4 abs_cur_rank 4 total_num 565 865\n",
      "215 150\n",
      "215 70 700\n",
      "checkcorrect 96 96 real score 1.9535690128803251 Hits@1 0.8130511463844797 Hits@3 0.8994708994708994 Hits@10 0.9770723104056437 MRR 0.8697430681788412 cur_rank 0 abs_cur_rank 0 total_num 566 865\n",
      "215 150\n",
      "215 73 462\n",
      "checkcorrect 390 390 real score 1.8627220392227173 Hits@1 0.8133802816901409 Hits@3 0.8996478873239436 Hits@10 0.977112676056338 MRR 0.8699723937630334 cur_rank 0 abs_cur_rank 0 total_num 567 865\n",
      "215 39\n",
      "215 498 90\n",
      "checkcorrect 356 356 real score 1.2501714833080768 Hits@1 0.81195079086116 Hits@3 0.8998242530755711 Hits@10 0.9771528998242531 MRR 0.8690292671190444 cur_rank 2 abs_cur_rank 2 total_num 568 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 206 206 real score 1.919059580564499 Hits@1 0.8105263157894737 Hits@3 0.9 Hits@10 0.9771929824561404 MRR 0.8683818473521688 cur_rank 1 abs_cur_rank 1 total_num 569 865\n",
      "215 150\n",
      "215 872 884\n",
      "checkcorrect 50 50 real score 1.776126730442047 Hits@1 0.8108581436077058 Hits@3 0.9001751313485113 Hits@10 0.9772329246935202 MRR 0.8686123519977867 cur_rank 0 abs_cur_rank 1 total_num 570 865\n",
      "0 1\n",
      "215 130 20\n",
      "checkcorrect 264 264 real score 0.6482822120189666 Hits@1 0.8094405594405595 Hits@3 0.9003496503496503 Hits@10 0.9772727272727273 MRR 0.8679679248089794 cur_rank 1 abs_cur_rank 1 total_num 571 865\n",
      "215 41\n",
      "215 181 142\n",
      "checkcorrect 54 54 real score 1.801650422811508 Hits@1 0.8097731239092496 Hits@3 0.900523560209424 Hits@10 0.9773123909249564 MRR 0.8681983472787719 cur_rank 0 abs_cur_rank 0 total_num 572 865\n",
      "215 126\n",
      "215 232 213\n",
      "checkcorrect 40 40 real score 1.9514370024204255 Hits@1 0.8101045296167247 Hits@3 0.9006968641114983 Hits@10 0.9773519163763066 MRR 0.8684279668828158 cur_rank 0 abs_cur_rank 0 total_num 573 865\n",
      "215 147\n",
      "215 248 730\n",
      "checkcorrect 70 70 real score 1.959436446428299 Hits@1 0.8104347826086956 Hits@3 0.9008695652173913 Hits@10 0.9773913043478261 MRR 0.8686567878099761 cur_rank 0 abs_cur_rank 0 total_num 574 865\n",
      "215 150\n",
      "215 85 853\n",
      "checkcorrect 96 96 real score 1.8305717706680298 Hits@1 0.8107638888888888 Hits@3 0.9010416666666666 Hits@10 0.9774305555555556 MRR 0.8688848142200283 cur_rank 0 abs_cur_rank 0 total_num 575 865\n",
      "215 150\n",
      "215 66 735\n",
      "checkcorrect 44 44 real score 1.8006108105182648 Hits@1 0.8110918544194108 Hits@3 0.901213171577123 Hits@10 0.9774696707105719 MRR 0.8691120502439104 cur_rank 0 abs_cur_rank 0 total_num 576 865\n",
      "215 40\n",
      "215 280 33\n",
      "checkcorrect 78 78 real score 1.9246773958206176 Hits@1 0.8114186851211073 Hits@3 0.9013840830449827 Hits@10 0.9775086505190311 MRR 0.8693384999839727 cur_rank 0 abs_cur_rank 0 total_num 577 865\n",
      "215 150\n",
      "215 570 592\n",
      "checkcorrect 164 164 real score 1.573047935962677 Hits@1 0.8100172711571675 Hits@3 0.9015544041450777 Hits@10 0.9775474956822107 MRR 0.8684127570363896 cur_rank 2 abs_cur_rank 3 total_num 578 865\n",
      "215 85\n",
      "215 40 84\n",
      "checkcorrect 204 204 real score 1.983819979429245 Hits@1 0.8103448275862069 Hits@3 0.9017241379310345 Hits@10 0.9775862068965517 MRR 0.8686396315932234 cur_rank 0 abs_cur_rank 0 total_num 579 865\n",
      "215 135\n",
      "215 52 224\n",
      "checkcorrect 148 148 real score 1.9121341288089753 Hits@1 0.8089500860585198 Hits@3 0.9018932874354562 Hits@10 0.9776247848537005 MRR 0.8677182782399361 cur_rank 2 abs_cur_rank 2 total_num 580 865\n",
      "215 129\n",
      "215 284 291\n",
      "checkcorrect 58 58 real score 1.857952284812927 Hits@1 0.8092783505154639 Hits@3 0.9020618556701031 Hits@10 0.9776632302405498 MRR 0.8679455664216544 cur_rank 0 abs_cur_rank 0 total_num 581 865\n",
      "215 134\n",
      "215 431 248\n",
      "checkcorrect 382 382 real score 1.9234417736530305 Hits@1 0.8096054888507719 Hits@3 0.902229845626072 Hits@10 0.9777015437392796 MRR 0.868172074884053 cur_rank 0 abs_cur_rank 0 total_num 582 865\n",
      "215 143\n",
      "215 763 655\n",
      "checkcorrect 22 22 real score 1.8476216852664948 Hits@1 0.809931506849315 Hits@3 0.9023972602739726 Hits@10 0.9777397260273972 MRR 0.8683978076325392 cur_rank 0 abs_cur_rank 0 total_num 583 865\n",
      "215 150\n",
      "215 262 1506\n",
      "checkcorrect 312 312 real score 1.4411607027053832 Hits@1 0.8102564102564103 Hits@3 0.9025641025641026 Hits@10 0.9777777777777777 MRR 0.8686227686451331 cur_rank 0 abs_cur_rank 0 total_num 584 865\n",
      "215 150\n",
      "215 891 424\n",
      "checkcorrect 24 24 real score 1.891473412513733 Hits@1 0.810580204778157 Hits@3 0.9027303754266212 Hits@10 0.9778156996587031 MRR 0.8688469618727012 cur_rank 0 abs_cur_rank 1 total_num 585 865\n",
      "215 136\n",
      "215 28 268\n",
      "checkcorrect 32 32 real score 1.9666245877742767 Hits@1 0.8109028960817717 Hits@3 0.9028960817717206 Hits@10 0.9778534923339012 MRR 0.8690703912391872 cur_rank 0 abs_cur_rank 0 total_num 586 865\n",
      "215 150\n",
      "215 532 429\n",
      "checkcorrect 0 0 real score 1.8483291149139405 Hits@1 0.8112244897959183 Hits@3 0.9030612244897959 Hits@10 0.9778911564625851 MRR 0.8692930606418416 cur_rank 0 abs_cur_rank 0 total_num 587 865\n",
      "215 47\n",
      "215 141 58\n",
      "checkcorrect 98 98 real score 1.8161594867706299 Hits@1 0.8115449915110357 Hits@3 0.9032258064516129 Hits@10 0.9779286926994907 MRR 0.8695149739514481 cur_rank 0 abs_cur_rank 0 total_num 588 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 490 165\n",
      "checkcorrect 20 20 real score 1.95042884349823 Hits@1 0.8101694915254237 Hits@3 0.9033898305084745 Hits@10 0.9779661016949153 MRR 0.8688886773854286 cur_rank 1 abs_cur_rank 1 total_num 589 865\n",
      "215 127\n",
      "215 96 204\n",
      "checkcorrect 240 240 real score 1.901704806089401 Hits@1 0.8104906937394247 Hits@3 0.9035532994923858 Hits@10 0.9780033840947546 MRR 0.8691105239549964 cur_rank 0 abs_cur_rank 0 total_num 590 865\n",
      "215 85\n",
      "215 343 275\n",
      "checkcorrect 146 146 real score 1.8086557745933534 Hits@1 0.8091216216216216 Hits@3 0.9037162162162162 Hits@10 0.9780405405405406 MRR 0.8684870264483157 cur_rank 1 abs_cur_rank 1 total_num 591 865\n",
      "215 150\n",
      "215 65 796\n",
      "checkcorrect 96 96 real score 1.763133978843689 Hits@1 0.8094435075885329 Hits@3 0.9038785834738617 Hits@10 0.9780775716694773 MRR 0.8687088021204096 cur_rank 0 abs_cur_rank 0 total_num 592 865\n",
      "215 133\n",
      "215 597 336\n",
      "checkcorrect 28 28 real score 1.8538523614406586 Hits@1 0.8097643097643098 Hits@3 0.9040404040404041 Hits@10 0.9781144781144782 MRR 0.8689298310730689 cur_rank 0 abs_cur_rank 0 total_num 593 865\n",
      "0 1\n",
      "0 23 3\n",
      "checkcorrect 372 372 real score 0.0 Hits@1 0.8084033613445378 Hits@3 0.9025210084033614 Hits@10 0.9764705882352941 MRR 0.867478432354598 cur_rank 186 abs_cur_rank 186 total_num 594 865\n",
      "215 150\n",
      "215 196 400\n",
      "checkcorrect 40 40 real score 1.9267610907554626 Hits@1 0.8087248322147651 Hits@3 0.9026845637583892 Hits@10 0.9765100671140939 MRR 0.8677007839781641 cur_rank 0 abs_cur_rank 0 total_num 595 865\n",
      "215 150\n",
      "215 209 736\n",
      "checkcorrect 0 0 real score 1.9345519185066222 Hits@1 0.8090452261306532 Hits@3 0.9028475711892797 Hits@10 0.9765494137353434 MRR 0.8679223907051687 cur_rank 0 abs_cur_rank 0 total_num 596 865\n",
      "215 150\n",
      "215 43 706\n",
      "checkcorrect 96 96 real score 1.922916066646576 Hits@1 0.8093645484949833 Hits@3 0.903010033444816 Hits@10 0.9765886287625418 MRR 0.8681432562725515 cur_rank 0 abs_cur_rank 0 total_num 597 865\n",
      "215 133\n",
      "215 372 286\n",
      "checkcorrect 50 50 real score 1.9358704566955565 Hits@1 0.8080133555926544 Hits@3 0.9031719532554258 Hits@10 0.9766277128547579 MRR 0.8675286598513953 cur_rank 1 abs_cur_rank 1 total_num 598 865\n",
      "215 120\n",
      "215 468 173\n",
      "checkcorrect 134 134 real score 1.673905536532402 Hits@1 0.8083333333333333 Hits@3 0.9033333333333333 Hits@10 0.9766666666666667 MRR 0.8677494454183097 cur_rank 0 abs_cur_rank 0 total_num 599 865\n",
      "215 92\n",
      "215 139 340\n",
      "checkcorrect 220 220 real score 1.8597430348396302 Hits@1 0.8086522462562395 Hits@3 0.9034941763727121 Hits@10 0.9767054908485857 MRR 0.8679694962578798 cur_rank 0 abs_cur_rank 0 total_num 600 865\n",
      "215 145\n",
      "215 149 468\n",
      "checkcorrect 64 64 real score 1.770794466137886 Hits@1 0.8089700996677741 Hits@3 0.9036544850498339 Hits@10 0.9767441860465116 MRR 0.8681888160315379 cur_rank 0 abs_cur_rank 0 total_num 601 865\n",
      "215 150\n",
      "215 111 121\n",
      "checkcorrect 188 188 real score 1.9813736975193024 Hits@1 0.8092868988391376 Hits@3 0.9038142620232172 Hits@10 0.9767827529021559 MRR 0.8684074083764275 cur_rank 0 abs_cur_rank 0 total_num 602 865\n",
      "215 150\n",
      "215 455 437\n",
      "checkcorrect 36 36 real score 1.8933850646018984 Hits@1 0.8096026490066225 Hits@3 0.9039735099337748 Hits@10 0.9768211920529801 MRR 0.8686252769056055 cur_rank 0 abs_cur_rank 0 total_num 603 865\n",
      "215 18\n",
      "215 178 56\n",
      "checkcorrect 112 112 real score 1.6330607950687408 Hits@1 0.8082644628099174 Hits@3 0.9041322314049587 Hits@10 0.9768595041322314 MRR 0.8680159789272492 cur_rank 1 abs_cur_rank 1 total_num 604 865\n",
      "215 149\n",
      "215 6 731\n",
      "checkcorrect 44 44 real score 1.8733255803585052 Hits@1 0.8085808580858086 Hits@3 0.9042904290429042 Hits@10 0.976897689768977 MRR 0.8682337743415607 cur_rank 0 abs_cur_rank 0 total_num 605 865\n",
      "215 41\n",
      "215 222 271\n",
      "checkcorrect 340 340 real score 1.077125196158886 Hits@1 0.8072487644151565 Hits@3 0.9028006589785832 Hits@10 0.9769357495881383 MRR 0.8670779800949793 cur_rank 5 abs_cur_rank 8 total_num 606 865\n",
      "215 150\n",
      "215 434 434\n",
      "checkcorrect 22 22 real score 1.955629402399063 Hits@1 0.8075657894736842 Hits@3 0.9029605263157895 Hits@10 0.9769736842105263 MRR 0.8672966018382441 cur_rank 0 abs_cur_rank 0 total_num 607 865\n",
      "215 129\n",
      "215 211 337\n",
      "checkcorrect 40 40 real score 1.945697546005249 Hits@1 0.8078817733990148 Hits@3 0.90311986863711 Hits@10 0.9770114942528736 MRR 0.8675145056119087 cur_rank 0 abs_cur_rank 0 total_num 608 865\n",
      "215 72\n",
      "215 111 220\n",
      "checkcorrect 186 186 real score 1.807716029882431 Hits@1 0.8081967213114755 Hits@3 0.9032786885245901 Hits@10 0.9770491803278688 MRR 0.8677316949469711 cur_rank 0 abs_cur_rank 0 total_num 609 865\n",
      "215 143\n",
      "215 417 136\n",
      "checkcorrect 54 54 real score 1.495385779440403 Hits@1 0.8085106382978723 Hits@3 0.9034369885433715 Hits@10 0.9770867430441899 MRR 0.8679481733513132 cur_rank 0 abs_cur_rank 0 total_num 610 865\n",
      "215 150\n",
      "215 967 618\n",
      "checkcorrect 22 22 real score 1.9270930290222168 Hits@1 0.8088235294117647 Hits@3 0.9035947712418301 Hits@10 0.9771241830065359 MRR 0.8681639443098895 cur_rank 0 abs_cur_rank 0 total_num 611 865\n",
      "215 150\n",
      "215 377 361\n",
      "checkcorrect 70 70 real score 1.880994939804077 Hits@1 0.8091353996737357 Hits@3 0.9037520391517129 Hits@10 0.9771615008156607 MRR 0.8683790112849142 cur_rank 0 abs_cur_rank 0 total_num 612 865\n",
      "215 121\n",
      "215 54 105\n",
      "checkcorrect 178 178 real score 1.9036676585674286 Hits@1 0.8094462540716613 Hits@3 0.9039087947882736 Hits@10 0.9771986970684039 MRR 0.8685933777160463 cur_rank 0 abs_cur_rank 0 total_num 613 865\n",
      "215 61\n",
      "215 15 30\n",
      "checkcorrect 316 316 real score 1.882337749004364 Hits@1 0.8097560975609757 Hits@3 0.9040650406504065 Hits@10 0.9772357723577236 MRR 0.868807047020573 cur_rank 0 abs_cur_rank 0 total_num 614 865\n",
      "215 150\n",
      "215 205 352\n",
      "checkcorrect 6 6 real score 1.984363055229187 Hits@1 0.810064935064935 Hits@3 0.9042207792207793 Hits@10 0.9772727272727273 MRR 0.8690200225935916 cur_rank 0 abs_cur_rank 0 total_num 615 865\n",
      "215 150\n",
      "215 406 750\n",
      "checkcorrect 44 44 real score 1.9020215809345244 Hits@1 0.8103727714748784 Hits@3 0.9043760129659644 Hits@10 0.9773095623987034 MRR 0.8692323078081886 cur_rank 0 abs_cur_rank 0 total_num 616 865\n",
      "215 34\n",
      "215 199 58\n",
      "checkcorrect 110 110 real score 1.8228602945804595 Hits@1 0.8106796116504854 Hits@3 0.9045307443365695 Hits@10 0.9773462783171522 MRR 0.8694439060156187 cur_rank 0 abs_cur_rank 0 total_num 617 865\n",
      "215 150\n",
      "215 101 521\n",
      "checkcorrect 12 12 real score 1.948302263021469 Hits@1 0.8109854604200323 Hits@3 0.9046849757673667 Hits@10 0.9773828756058158 MRR 0.8696548205454805 cur_rank 0 abs_cur_rank 0 total_num 618 865\n",
      "215 147\n",
      "215 599 460\n",
      "checkcorrect 54 54 real score 1.9362855851650238 Hits@1 0.8112903225806452 Hits@3 0.9048387096774193 Hits@10 0.9774193548387097 MRR 0.8698650547058909 cur_rank 0 abs_cur_rank 0 total_num 619 865\n",
      "215 132\n",
      "215 579 762\n",
      "checkcorrect 162 162 real score 1.5433874547481536 Hits@1 0.8099838969404187 Hits@3 0.9049919484702094 Hits@10 0.9774557165861514 MRR 0.8690010744782379 cur_rank 2 abs_cur_rank 3 total_num 620 865\n",
      "215 150\n",
      "215 447 552\n",
      "checkcorrect 20 20 real score 1.949867296218872 Hits@1 0.8086816720257235 Hits@3 0.905144694533762 Hits@10 0.977491961414791 MRR 0.8684078251623566 cur_rank 1 abs_cur_rank 1 total_num 621 865\n",
      "215 113\n",
      "215 197 182\n",
      "checkcorrect 134 134 real score 1.8339145958423613 Hits@1 0.8089887640449438 Hits@3 0.9052969502407705 Hits@10 0.9775280898876404 MRR 0.8686190485569595 cur_rank 0 abs_cur_rank 0 total_num 622 865\n",
      "0 1\n",
      "215 73 12\n",
      "checkcorrect 48 48 real score 0.8453786849975586 Hits@1 0.8092948717948718 Hits@3 0.905448717948718 Hits@10 0.9775641025641025 MRR 0.8688295949535029 cur_rank 0 abs_cur_rank 0 total_num 623 865\n",
      "215 150\n",
      "215 558 401\n",
      "checkcorrect 50 50 real score 1.9318386614322662 Hits@1 0.808 Hits@3 0.9056 Hits@10 0.9776 MRR 0.8682394676015772 cur_rank 1 abs_cur_rank 1 total_num 624 865\n",
      "215 150\n",
      "215 144 557\n",
      "checkcorrect 96 96 real score 1.9505855977535247 Hits@1 0.8083067092651757 Hits@3 0.9057507987220448 Hits@10 0.9776357827476039 MRR 0.8684499476852808 cur_rank 0 abs_cur_rank 0 total_num 625 865\n",
      "215 94\n",
      "215 65 266\n",
      "checkcorrect 382 382 real score 1.9432474315166473 Hits@1 0.8086124401913876 Hits@3 0.9059011164274322 Hits@10 0.9776714513556619 MRR 0.8686597563811576 cur_rank 0 abs_cur_rank 0 total_num 626 865\n",
      "215 136\n",
      "215 164 416\n",
      "checkcorrect 54 54 real score 1.7791379511356356 Hits@1 0.8073248407643312 Hits@3 0.9060509554140127 Hits@10 0.9777070063694268 MRR 0.8680727185525251 cur_rank 1 abs_cur_rank 1 total_num 627 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 82\n",
      "215 211 73\n",
      "checkcorrect 98 98 real score 1.9175973773002624 Hits@1 0.8076311605723371 Hits@3 0.9062003179650239 Hits@10 0.9777424483306836 MRR 0.868282459858483 cur_rank 0 abs_cur_rank 0 total_num 628 865\n",
      "215 150\n",
      "215 77 715\n",
      "checkcorrect 44 44 real score 1.893195390701294 Hits@1 0.807936507936508 Hits@3 0.9063492063492063 Hits@10 0.9777777777777777 MRR 0.868491535319025 cur_rank 0 abs_cur_rank 0 total_num 629 865\n",
      "215 9\n",
      "215 12 47\n",
      "checkcorrect 88 88 real score 1.9275436699390411 Hits@1 0.8082408874801902 Hits@3 0.9064976228209192 Hits@10 0.9778129952456418 MRR 0.868699948099819 cur_rank 0 abs_cur_rank 0 total_num 630 865\n",
      "215 134\n",
      "215 170 179\n",
      "checkcorrect 312 312 real score 1.6307439416646958 Hits@1 0.8085443037974683 Hits@3 0.9066455696202531 Hits@10 0.9778481012658228 MRR 0.8689077013464964 cur_rank 0 abs_cur_rank 0 total_num 631 865\n",
      "215 150\n",
      "215 123 423\n",
      "checkcorrect 32 32 real score 1.9644400060176848 Hits@1 0.8088467614533965 Hits@3 0.9067930489731437 Hits@10 0.9778830963665087 MRR 0.8691147981848116 cur_rank 0 abs_cur_rank 0 total_num 632 865\n",
      "0 1\n",
      "215 170 25\n",
      "checkcorrect 50 50 real score 0.653199028968811 Hits@1 0.8091482649842271 Hits@3 0.9069400630914827 Hits@10 0.9779179810725552 MRR 0.8693212417207977 cur_rank 0 abs_cur_rank 0 total_num 633 865\n",
      "215 150\n",
      "215 472 849\n",
      "checkcorrect 96 96 real score 1.917008501291275 Hits@1 0.8094488188976378 Hits@3 0.9070866141732283 Hits@10 0.9779527559055118 MRR 0.8695270350409224 cur_rank 0 abs_cur_rank 0 total_num 634 865\n",
      "215 80\n",
      "215 928 223\n",
      "checkcorrect 386 386 real score 1.5266812086105346 Hits@1 0.809748427672956 Hits@3 0.9072327044025157 Hits@10 0.9779874213836478 MRR 0.8697321812122418 cur_rank 0 abs_cur_rank 0 total_num 635 865\n",
      "215 150\n",
      "215 445 585\n",
      "checkcorrect 64 64 real score 1.6824456095695495 Hits@1 0.8100470957613815 Hits@3 0.9073783359497645 Hits@10 0.978021978021978 MRR 0.8699366832825522 cur_rank 0 abs_cur_rank 0 total_num 636 865\n",
      "215 81\n",
      "215 54 79\n",
      "checkcorrect 72 72 real score 1.8897919952869415 Hits@1 0.8103448275862069 Hits@3 0.9075235109717869 Hits@10 0.9780564263322884 MRR 0.870140544280542 cur_rank 0 abs_cur_rank 0 total_num 637 865\n",
      "215 127\n",
      "215 306 892\n",
      "checkcorrect 36 36 real score 1.8935554504394532 Hits@1 0.810641627543036 Hits@3 0.9076682316118936 Hits@10 0.9780907668231612 MRR 0.8703437672159402 cur_rank 0 abs_cur_rank 0 total_num 638 865\n",
      "215 134\n",
      "215 202 699\n",
      "checkcorrect 6 6 real score 1.9841357886791229 Hits@1 0.8109375 Hits@3 0.9078125 Hits@10 0.978125 MRR 0.8705463550796653 cur_rank 0 abs_cur_rank 0 total_num 639 865\n",
      "215 150\n",
      "215 95 403\n",
      "checkcorrect 40 40 real score 1.573536992073059 Hits@1 0.8112324492979719 Hits@3 0.9079563182527302 Hits@10 0.9781591263650546 MRR 0.8707483108439715 cur_rank 0 abs_cur_rank 0 total_num 640 865\n",
      "215 126\n",
      "215 13 292\n",
      "checkcorrect 58 58 real score 1.950582367181778 Hits@1 0.8115264797507789 Hits@3 0.9080996884735203 Hits@10 0.9781931464174455 MRR 0.8709496374625947 cur_rank 0 abs_cur_rank 0 total_num 641 865\n",
      "215 86\n",
      "215 21 594\n",
      "checkcorrect 104 104 real score 1.5189197421073914 Hits@1 0.8102643856920684 Hits@3 0.9066874027993779 Hits@10 0.9782270606531882 MRR 0.8699839304058876 cur_rank 3 abs_cur_rank 3 total_num 642 865\n",
      "215 94\n",
      "215 127 170\n",
      "checkcorrect 58 58 real score 1.8619266092777251 Hits@1 0.8105590062111802 Hits@3 0.906832298136646 Hits@10 0.9782608695652174 MRR 0.8701858187127108 cur_rank 0 abs_cur_rank 0 total_num 643 865\n",
      "215 67\n",
      "215 65 97\n",
      "checkcorrect 40 40 real score 1.6714943915605547 Hits@1 0.8108527131782945 Hits@3 0.9069767441860465 Hits@10 0.9782945736434109 MRR 0.8703870810092803 cur_rank 0 abs_cur_rank 0 total_num 644 865\n",
      "215 150\n",
      "215 286 600\n",
      "checkcorrect 36 36 real score 1.888049203157425 Hits@1 0.8111455108359134 Hits@3 0.9071207430340558 Hits@10 0.978328173374613 MRR 0.8705877202027643 cur_rank 0 abs_cur_rank 0 total_num 645 865\n",
      "215 126\n",
      "215 179 225\n",
      "checkcorrect 192 192 real score 0.33933517390396445 Hits@1 0.8098918083462133 Hits@3 0.9057187017001546 Hits@10 0.9768160741885626 MRR 0.8693451837985355 cur_rank 14 abs_cur_rank 14 total_num 646 865\n",
      "215 85\n",
      "215 326 247\n",
      "checkcorrect 22 22 real score 1.8831894993782043 Hits@1 0.8101851851851852 Hits@3 0.9058641975308642 Hits@10 0.9768518518518519 MRR 0.8695468116013155 cur_rank 0 abs_cur_rank 0 total_num 647 865\n",
      "215 150\n",
      "215 266 739\n",
      "checkcorrect 0 0 real score 1.9714321196079254 Hits@1 0.810477657935285 Hits@3 0.9060092449922958 Hits@10 0.9768875192604006 MRR 0.8697478180549345 cur_rank 0 abs_cur_rank 0 total_num 648 865\n",
      "215 148\n",
      "215 258 265\n",
      "checkcorrect 382 382 real score 1.9494300603866577 Hits@1 0.8107692307692308 Hits@3 0.9061538461538462 Hits@10 0.9769230769230769 MRR 0.8699482060271577 cur_rank 0 abs_cur_rank 0 total_num 649 865\n",
      "215 15\n",
      "215 89 13\n",
      "checkcorrect 188 188 real score 1.9667585790157318 Hits@1 0.8110599078341014 Hits@3 0.9062980030721967 Hits@10 0.9769585253456221 MRR 0.8701479783681297 cur_rank 0 abs_cur_rank 0 total_num 650 865\n",
      "215 21\n",
      "215 616 25\n",
      "checkcorrect 48 48 real score 1.8974511682987214 Hits@1 0.8113496932515337 Hits@3 0.906441717791411 Hits@10 0.9769938650306749 MRR 0.87034713791051 cur_rank 0 abs_cur_rank 0 total_num 651 865\n",
      "215 10\n",
      "215 96 45\n",
      "checkcorrect 40 40 real score 1.821068686246872 Hits@1 0.8116385911179173 Hits@3 0.9065849923430321 Hits@10 0.9770290964777948 MRR 0.8705456874696057 cur_rank 0 abs_cur_rank 0 total_num 652 865\n",
      "215 150\n",
      "215 142 115\n",
      "checkcorrect 98 98 real score 1.934358298778534 Hits@1 0.8119266055045872 Hits@3 0.9067278287461774 Hits@10 0.9770642201834863 MRR 0.8707436298435053 cur_rank 0 abs_cur_rank 0 total_num 653 865\n",
      "215 33\n",
      "215 73 41\n",
      "checkcorrect 390 390 real score 1.8610397458076477 Hits@1 0.8122137404580153 Hits@3 0.9068702290076336 Hits@10 0.9770992366412213 MRR 0.87094096781321 cur_rank 0 abs_cur_rank 0 total_num 654 865\n",
      "215 150\n",
      "215 452 432\n",
      "checkcorrect 0 0 real score 1.8356770038604737 Hits@1 0.8125 Hits@3 0.9070121951219512 Hits@10 0.9771341463414634 MRR 0.8711377041427629 cur_rank 0 abs_cur_rank 0 total_num 655 865\n",
      "215 75\n",
      "215 193 50\n",
      "checkcorrect 78 78 real score 1.8466876447200775 Hits@1 0.8127853881278538 Hits@3 0.9071537290715372 Hits@10 0.9771689497716894 MRR 0.8713338415793798 cur_rank 0 abs_cur_rank 0 total_num 656 865\n",
      "215 30\n",
      "215 120 190\n",
      "checkcorrect 266 266 real score 1.7729802966117858 Hits@1 0.8130699088145896 Hits@3 0.9072948328267477 Hits@10 0.9772036474164134 MRR 0.8715293828535752 cur_rank 0 abs_cur_rank 1 total_num 657 865\n",
      "215 37\n",
      "215 69 23\n",
      "checkcorrect 14 14 real score 1.8968783974647523 Hits@1 0.8133535660091047 Hits@3 0.9074355083459787 Hits@10 0.9772382397572079 MRR 0.8717243306792906 cur_rank 0 abs_cur_rank 0 total_num 658 865\n",
      "215 138\n",
      "215 967 119\n",
      "checkcorrect 22 22 real score 1.903140366077423 Hits@1 0.8136363636363636 Hits@3 0.9075757575757576 Hits@10 0.9772727272727273 MRR 0.8719186877540189 cur_rank 0 abs_cur_rank 0 total_num 659 865\n",
      "215 150\n",
      "215 492 378\n",
      "checkcorrect 24 24 real score 1.9076194763183594 Hits@1 0.8139183055975794 Hits@3 0.9077155824508321 Hits@10 0.9773071104387292 MRR 0.8721124567589297 cur_rank 0 abs_cur_rank 0 total_num 660 865\n",
      "215 150\n",
      "215 482 299\n",
      "checkcorrect 78 78 real score 1.8840134978294372 Hits@1 0.8141993957703928 Hits@3 0.9078549848942599 Hits@10 0.9773413897280967 MRR 0.8723056403589917 cur_rank 0 abs_cur_rank 0 total_num 661 865\n",
      "215 93\n",
      "215 17 169\n",
      "checkcorrect 30 30 real score 1.8097851932048798 Hits@1 0.8144796380090498 Hits@3 0.9079939668174962 Hits@10 0.9773755656108597 MRR 0.8724982412030957 cur_rank 0 abs_cur_rank 0 total_num 662 865\n",
      "215 150\n",
      "215 81 186\n",
      "checkcorrect 72 72 real score 1.8162765353918076 Hits@1 0.8147590361445783 Hits@3 0.9081325301204819 Hits@10 0.9774096385542169 MRR 0.8726902619241754 cur_rank 0 abs_cur_rank 0 total_num 663 865\n",
      "215 105\n",
      "215 157 305\n",
      "checkcorrect 28 28 real score 1.7812193870544433 Hits@1 0.8150375939849624 Hits@3 0.9082706766917293 Hits@10 0.9774436090225563 MRR 0.8728817051393271 cur_rank 0 abs_cur_rank 0 total_num 664 865\n",
      "215 118\n",
      "215 639 182\n",
      "checkcorrect 12 12 real score 1.9532806634902955 Hits@1 0.8153153153153153 Hits@3 0.9084084084084084 Hits@10 0.9774774774774775 MRR 0.8730725734499286 cur_rank 0 abs_cur_rank 0 total_num 665 865\n",
      "215 150\n",
      "215 531 834\n",
      "checkcorrect 0 0 real score 1.8918536365032197 Hits@1 0.815592203898051 Hits@3 0.9085457271364318 Hits@10 0.9775112443778111 MRR 0.8732628694417579 cur_rank 0 abs_cur_rank 0 total_num 666 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 84\n",
      "215 218 110\n",
      "checkcorrect 154 154 real score 1.6187338709831238 Hits@1 0.8143712574850299 Hits@3 0.9086826347305389 Hits@10 0.9775449101796407 MRR 0.8727040926910965 cur_rank 1 abs_cur_rank 1 total_num 667 865\n",
      "215 12\n",
      "215 302 34\n",
      "checkcorrect 48 48 real score 1.892115205526352 Hits@1 0.8146487294469357 Hits@3 0.9088191330343797 Hits@10 0.9775784753363229 MRR 0.8728943705794506 cur_rank 0 abs_cur_rank 0 total_num 668 865\n",
      "215 40\n",
      "215 518 53\n",
      "checkcorrect 134 134 real score 1.8331485152244569 Hits@1 0.8149253731343283 Hits@3 0.908955223880597 Hits@10 0.9776119402985075 MRR 0.8730840804741082 cur_rank 0 abs_cur_rank 0 total_num 669 865\n",
      "215 138\n",
      "215 176 328\n",
      "checkcorrect 64 64 real score 1.7575902104377747 Hits@1 0.8152011922503726 Hits@3 0.9090909090909091 Hits@10 0.977645305514158 MRR 0.8732732249145343 cur_rank 0 abs_cur_rank 0 total_num 670 865\n",
      "215 85\n",
      "215 504 244\n",
      "checkcorrect 24 24 real score 1.8068286180496216 Hits@1 0.8154761904761905 Hits@3 0.9092261904761905 Hits@10 0.9776785714285714 MRR 0.8734618064250781 cur_rank 0 abs_cur_rank 1 total_num 671 865\n",
      "215 69\n",
      "215 9 105\n",
      "checkcorrect 126 126 real score 1.711331170797348 Hits@1 0.8157503714710252 Hits@3 0.9093610698365527 Hits@10 0.9777117384843982 MRR 0.8736498275150855 cur_rank 0 abs_cur_rank 0 total_num 672 865\n",
      "215 139\n",
      "215 337 1604\n",
      "checkcorrect 146 146 real score 1.82646946310997 Hits@1 0.8160237388724035 Hits@3 0.9094955489614244 Hits@10 0.9777448071216617 MRR 0.8738372906790096 cur_rank 0 abs_cur_rank 1 total_num 673 865\n",
      "215 150\n",
      "215 38 430\n",
      "checkcorrect 0 0 real score 1.6208218514919281 Hits@1 0.8148148148148148 Hits@3 0.9096296296296297 Hits@10 0.9777777777777777 MRR 0.8732834576557814 cur_rank 1 abs_cur_rank 1 total_num 674 865\n",
      "215 150\n",
      "215 666 314\n",
      "checkcorrect 54 54 real score 1.8874909937381745 Hits@1 0.8150887573964497 Hits@3 0.9097633136094675 Hits@10 0.977810650887574 MRR 0.8734709081622078 cur_rank 0 abs_cur_rank 0 total_num 675 865\n",
      "215 150\n",
      "215 190 892\n",
      "checkcorrect 40 40 real score 1.9649766743183137 Hits@1 0.8153618906942393 Hits@3 0.9098966026587888 Hits@10 0.9778434268833087 MRR 0.8736578049005207 cur_rank 0 abs_cur_rank 0 total_num 676 865\n",
      "215 150\n",
      "215 352 751\n",
      "checkcorrect 44 44 real score 1.9064020037651064 Hits@1 0.8156342182890856 Hits@3 0.9100294985250738 Hits@10 0.9778761061946902 MRR 0.8738441503210214 cur_rank 0 abs_cur_rank 0 total_num 677 865\n",
      "215 150\n",
      "215 234 367\n",
      "checkcorrect 98 98 real score 1.885153430700302 Hits@1 0.8159057437407953 Hits@3 0.9101620029455081 Hits@10 0.9779086892488954 MRR 0.8740299468595766 cur_rank 0 abs_cur_rank 0 total_num 678 865\n",
      "215 89\n",
      "215 160 350\n",
      "checkcorrect 54 54 real score 1.583768790960312 Hits@1 0.8161764705882353 Hits@3 0.9102941176470588 Hits@10 0.9779411764705882 MRR 0.8742151969377242 cur_rank 0 abs_cur_rank 0 total_num 679 865\n",
      "215 50\n",
      "215 179 39\n",
      "checkcorrect 22 22 real score 1.736381584405899 Hits@1 0.8164464023494861 Hits@3 0.9104258443465492 Hits@10 0.9779735682819384 MRR 0.874399902962779 cur_rank 0 abs_cur_rank 0 total_num 680 865\n",
      "215 150\n",
      "215 231 539\n",
      "checkcorrect 12 12 real score 1.953541761636734 Hits@1 0.8167155425219942 Hits@3 0.9105571847507331 Hits@10 0.9780058651026393 MRR 0.8745840673279363 cur_rank 0 abs_cur_rank 0 total_num 681 865\n",
      "0 1\n",
      "0 4 8\n",
      "checkcorrect 128 128 real score 0.0 Hits@1 0.8155197657393851 Hits@3 0.9092240117130308 Hits@10 0.9765739385065886 MRR 0.8733260886281656 cur_rank 64 abs_cur_rank 64 total_num 682 865\n",
      "0 1\n",
      "215 8 17\n",
      "checkcorrect 198 198 real score 0.9239848554134369 Hits@1 0.8157894736842105 Hits@3 0.9093567251461988 Hits@10 0.9766081871345029 MRR 0.873511284405025 cur_rank 0 abs_cur_rank 0 total_num 683 865\n",
      "215 150\n",
      "215 232 877\n",
      "checkcorrect 0 0 real score 1.9796807646751404 Hits@1 0.8160583941605839 Hits@3 0.9094890510948905 Hits@10 0.9766423357664233 MRR 0.8736959394642878 cur_rank 0 abs_cur_rank 0 total_num 684 865\n",
      "215 145\n",
      "215 200 218\n",
      "checkcorrect 50 50 real score 1.9309859037399293 Hits@1 0.8163265306122449 Hits@3 0.9096209912536443 Hits@10 0.9766763848396501 MRR 0.873880056170608 cur_rank 0 abs_cur_rank 1 total_num 685 865\n",
      "215 150\n",
      "215 516 769\n",
      "checkcorrect 44 44 real score 1.9079653441905975 Hits@1 0.8165938864628821 Hits@3 0.9097525473071325 Hits@10 0.9767103347889374 MRR 0.8740636368748721 cur_rank 0 abs_cur_rank 0 total_num 686 865\n",
      "215 93\n",
      "215 43 151\n",
      "checkcorrect 148 148 real score 1.5506506323814393 Hits@1 0.8168604651162791 Hits@3 0.9098837209302325 Hits@10 0.9767441860465116 MRR 0.8742466839142982 cur_rank 0 abs_cur_rank 0 total_num 687 865\n",
      "215 92\n",
      "215 394 156\n",
      "checkcorrect 78 78 real score 1.781998759508133 Hits@1 0.8171262699564587 Hits@3 0.9100145137880987 Hits@10 0.97677793904209 MRR 0.8744291996125357 cur_rank 0 abs_cur_rank 0 total_num 688 865\n",
      "215 47\n",
      "215 222 139\n",
      "checkcorrect 64 64 real score 1.5814430594444275 Hits@1 0.8173913043478261 Hits@3 0.9101449275362319 Hits@10 0.9768115942028985 MRR 0.874611186279764 cur_rank 0 abs_cur_rank 0 total_num 689 865\n",
      "215 73\n",
      "215 333 349\n",
      "checkcorrect 118 118 real score 0.41079163607209923 Hits@1 0.8162083936324168 Hits@3 0.9088277858176556 Hits@10 0.9768451519536903 MRR 0.873490186010184 cur_rank 9 abs_cur_rank 11 total_num 690 865\n",
      "215 31\n",
      "215 415 203\n",
      "checkcorrect 50 50 real score 1.8617243826389314 Hits@1 0.8164739884393064 Hits@3 0.9089595375722543 Hits@10 0.976878612716763 MRR 0.8736730036604583 cur_rank 0 abs_cur_rank 1 total_num 691 865\n",
      "215 150\n",
      "215 1526 467\n",
      "checkcorrect 54 54 real score 1.6663394391536712 Hits@1 0.8167388167388168 Hits@3 0.9090909090909091 Hits@10 0.976911976911977 MRR 0.8738552936984663 cur_rank 0 abs_cur_rank 0 total_num 692 865\n",
      "215 60\n",
      "215 105 108\n",
      "checkcorrect 390 390 real score 1.5289007902145386 Hits@1 0.8155619596541787 Hits@3 0.909221902017291 Hits@10 0.9769452449567724 MRR 0.8733165973098518 cur_rank 1 abs_cur_rank 1 total_num 693 865\n",
      "215 150\n",
      "215 595 456\n",
      "checkcorrect 28 28 real score 1.862869256734848 Hits@1 0.8158273381294964 Hits@3 0.9093525179856116 Hits@10 0.9769784172661871 MRR 0.8734988755871038 cur_rank 0 abs_cur_rank 0 total_num 694 865\n",
      "215 150\n",
      "215 580 188\n",
      "checkcorrect 292 292 real score 1.8506462037563325 Hits@1 0.8160919540229885 Hits@3 0.9094827586206896 Hits@10 0.9770114942528736 MRR 0.8736806300762028 cur_rank 0 abs_cur_rank 0 total_num 695 865\n",
      "215 67\n",
      "215 280 45\n",
      "checkcorrect 78 78 real score 1.9267364025115967 Hits@1 0.8163558106169297 Hits@3 0.9096126255380201 Hits@10 0.9770444763271162 MRR 0.8738618630316172 cur_rank 0 abs_cur_rank 0 total_num 696 865\n",
      "215 121\n",
      "215 78 220\n",
      "checkcorrect 64 64 real score 1.5433175355195998 Hits@1 0.8151862464183381 Hits@3 0.9097421203438395 Hits@10 0.9770773638968482 MRR 0.8733262443166722 cur_rank 1 abs_cur_rank 1 total_num 697 865\n",
      "215 150\n",
      "215 893 522\n",
      "checkcorrect 22 22 real score 1.9541995644569399 Hits@1 0.8154506437768241 Hits@3 0.9098712446351931 Hits@10 0.977110157367668 MRR 0.8735074657124995 cur_rank 0 abs_cur_rank 0 total_num 698 865\n",
      "215 114\n",
      "215 315 155\n",
      "checkcorrect 16 16 real score 1.9634197294712066 Hits@1 0.8157142857142857 Hits@3 0.91 Hits@10 0.9771428571428571 MRR 0.8736881693329102 cur_rank 0 abs_cur_rank 0 total_num 699 865\n",
      "215 91\n",
      "215 127 12\n",
      "checkcorrect 72 72 real score 1.9003545045852661 Hits@1 0.8159771754636234 Hits@3 0.9101283880171184 Hits@10 0.9771754636233951 MRR 0.8738683573937762 cur_rank 0 abs_cur_rank 0 total_num 700 865\n",
      "215 150\n",
      "215 1085 1265\n",
      "checkcorrect 420 420 real score 0.134187089279294 Hits@1 0.8148148148148148 Hits@3 0.9088319088319088 Hits@10 0.9772079772079773 MRR 0.8727818086098977 cur_rank 8 abs_cur_rank 9 total_num 701 865\n",
      "215 150\n",
      "215 222 935\n",
      "checkcorrect 154 154 real score 1.7169201135635377 Hits@1 0.8150782361308677 Hits@3 0.9089615931721194 Hits@10 0.9772403982930299 MRR 0.8729627733202677 cur_rank 0 abs_cur_rank 0 total_num 702 865\n",
      "215 150\n",
      "215 969 999\n",
      "checkcorrect 22 22 real score 1.8568933248519897 Hits@1 0.8153409090909091 Hits@3 0.9090909090909091 Hits@10 0.9772727272727273 MRR 0.8731432239263469 cur_rank 0 abs_cur_rank 0 total_num 703 865\n",
      "215 3\n",
      "0 3 3\n",
      "checkcorrect 230 230 real score 0.9953387320041657 Hits@1 0.8156028368794326 Hits@3 0.9092198581560283 Hits@10 0.9773049645390071 MRR 0.8733231626158131 cur_rank 0 abs_cur_rank 0 total_num 704 865\n",
      "215 150\n",
      "215 287 1413\n",
      "checkcorrect 140 140 real score 1.778509360551834 Hits@1 0.8144475920679887 Hits@3 0.9093484419263456 Hits@10 0.9773371104815864 MRR 0.8725583045006822 cur_rank 2 abs_cur_rank 2 total_num 705 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 33\n",
      "215 467 37\n",
      "checkcorrect 112 112 real score 1.6662915647029877 Hits@1 0.8147100424328148 Hits@3 0.9094766619519095 Hits@10 0.9773691654879774 MRR 0.8727385614957307 cur_rank 0 abs_cur_rank 0 total_num 706 865\n",
      "215 150\n",
      "215 29 831\n",
      "checkcorrect 96 96 real score 1.6605704188346864 Hits@1 0.8149717514124294 Hits@3 0.9096045197740112 Hits@10 0.9774011299435028 MRR 0.8729183092902283 cur_rank 0 abs_cur_rank 0 total_num 707 865\n",
      "215 3\n",
      "0 3 3\n",
      "checkcorrect 230 230 real score 0.9953386962413788 Hits@1 0.8152327221438646 Hits@3 0.9097320169252469 Hits@10 0.9774330042313117 MRR 0.8730975500387611 cur_rank 0 abs_cur_rank 0 total_num 708 865\n",
      "215 149\n",
      "215 150 266\n",
      "checkcorrect 382 382 real score 1.9448222398757933 Hits@1 0.8154929577464789 Hits@3 0.9098591549295775 Hits@10 0.9774647887323944 MRR 0.8732762858837769 cur_rank 0 abs_cur_rank 0 total_num 709 865\n",
      "215 150\n",
      "215 191 1598\n",
      "checkcorrect 48 48 real score 1.8555232346057893 Hits@1 0.8157524613220816 Hits@3 0.909985935302391 Hits@10 0.9774964838255977 MRR 0.8734545189556703 cur_rank 0 abs_cur_rank 0 total_num 710 865\n",
      "215 119\n",
      "215 161 292\n",
      "checkcorrect 56 56 real score 1.4198806285858154 Hits@1 0.8160112359550562 Hits@3 0.9101123595505618 Hits@10 0.9775280898876404 MRR 0.8736322513728674 cur_rank 0 abs_cur_rank 0 total_num 711 865\n",
      "0 1\n",
      "0 7 5\n",
      "checkcorrect 372 372 real score 0.0 Hits@1 0.814866760168303 Hits@3 0.908835904628331 Hits@10 0.9761570827489481 MRR 0.8724144608289824 cur_rank 186 abs_cur_rank 186 total_num 712 865\n",
      "215 52\n",
      "215 7 30\n",
      "checkcorrect 316 316 real score 1.8841407775878904 Hits@1 0.8151260504201681 Hits@3 0.9089635854341737 Hits@10 0.9761904761904762 MRR 0.8725931520603144 cur_rank 0 abs_cur_rank 0 total_num 713 865\n",
      "215 141\n",
      "215 352 318\n",
      "checkcorrect 22 22 real score 1.952673876285553 Hits@1 0.8153846153846154 Hits@3 0.9090909090909091 Hits@10 0.9762237762237762 MRR 0.8727713434560342 cur_rank 0 abs_cur_rank 0 total_num 714 865\n",
      "215 149\n",
      "215 60 213\n",
      "checkcorrect 172 172 real score 1.985330492258072 Hits@1 0.8156424581005587 Hits@3 0.909217877094972 Hits@10 0.9762569832402235 MRR 0.8729490371104253 cur_rank 0 abs_cur_rank 0 total_num 715 865\n",
      "215 129\n",
      "215 28 799\n",
      "checkcorrect 44 44 real score 1.8471747636795044 Hits@1 0.8158995815899581 Hits@3 0.9093444909344491 Hits@10 0.9762900976290098 MRR 0.8731262351060871 cur_rank 0 abs_cur_rank 0 total_num 716 865\n",
      "215 149\n",
      "215 154 174\n",
      "checkcorrect 108 108 real score 1.94963361620903 Hits@1 0.8161559888579387 Hits@3 0.9094707520891365 Hits@10 0.9763231197771588 MRR 0.8733029395140174 cur_rank 0 abs_cur_rank 0 total_num 717 865\n",
      "215 15\n",
      "215 114 190\n",
      "checkcorrect 198 198 real score 1.8728512942790987 Hits@1 0.8164116828929068 Hits@3 0.9095966620305981 Hits@10 0.9763560500695411 MRR 0.8734791523936919 cur_rank 0 abs_cur_rank 0 total_num 718 865\n",
      "215 150\n",
      "215 351 745\n",
      "checkcorrect 96 96 real score 1.8867271959781646 Hits@1 0.8166666666666667 Hits@3 0.9097222222222222 Hits@10 0.9763888888888889 MRR 0.873654875793145 cur_rank 0 abs_cur_rank 0 total_num 719 865\n",
      "215 96\n",
      "215 46 212\n",
      "checkcorrect 98 98 real score 1.9088053941726684 Hits@1 0.8169209431345353 Hits@3 0.9098474341192788 Hits@10 0.9764216366158114 MRR 0.8738301117490492 cur_rank 0 abs_cur_rank 0 total_num 720 865\n",
      "215 71\n",
      "215 109 197\n",
      "checkcorrect 48 48 real score 1.7282109439373015 Hits@1 0.817174515235457 Hits@3 0.909972299168975 Hits@10 0.9764542936288089 MRR 0.8740048622867929 cur_rank 0 abs_cur_rank 0 total_num 721 865\n",
      "215 150\n",
      "215 321 825\n",
      "checkcorrect 0 0 real score 1.9405976831912994 Hits@1 0.8174273858921162 Hits@3 0.9100968188105117 Hits@10 0.9764868603042877 MRR 0.8741791294205594 cur_rank 0 abs_cur_rank 0 total_num 722 865\n",
      "215 150\n",
      "215 40 850\n",
      "checkcorrect 124 124 real score 1.571347641944885 Hits@1 0.8176795580110497 Hits@3 0.9102209944751382 Hits@10 0.9765193370165746 MRR 0.874352915153404 cur_rank 0 abs_cur_rank 0 total_num 723 865\n",
      "215 150\n",
      "215 367 799\n",
      "checkcorrect 96 96 real score 1.8729167640209199 Hits@1 0.8179310344827586 Hits@3 0.9103448275862069 Hits@10 0.976551724137931 MRR 0.8745262214773303 cur_rank 0 abs_cur_rank 0 total_num 724 865\n",
      "215 150\n",
      "215 907 430\n",
      "checkcorrect 54 54 real score 1.9327496647834779 Hits@1 0.8181818181818182 Hits@3 0.9104683195592287 Hits@10 0.9765840220385675 MRR 0.874699050373367 cur_rank 0 abs_cur_rank 0 total_num 725 865\n",
      "215 28\n",
      "215 121 62\n",
      "checkcorrect 54 54 real score 1.6713499218225478 Hits@1 0.8184319119669876 Hits@3 0.9105914718019257 Hits@10 0.9766162310866575 MRR 0.874871403811643 cur_rank 0 abs_cur_rank 0 total_num 726 865\n",
      "215 150\n",
      "215 185 858\n",
      "checkcorrect 96 96 real score 1.8505049526691435 Hits@1 0.8186813186813187 Hits@3 0.9107142857142857 Hits@10 0.9766483516483516 MRR 0.8750432837514622 cur_rank 0 abs_cur_rank 0 total_num 727 865\n",
      "215 117\n",
      "215 317 264\n",
      "checkcorrect 0 0 real score 1.9789585590362548 Hits@1 0.8189300411522634 Hits@3 0.9108367626886146 Hits@10 0.9766803840877915 MRR 0.8752146921413779 cur_rank 0 abs_cur_rank 0 total_num 728 865\n",
      "0 1\n",
      "215 8 6\n",
      "checkcorrect 218 218 real score 0.8649643719196319 Hits@1 0.8191780821917808 Hits@3 0.910958904109589 Hits@10 0.9767123287671233 MRR 0.8753856309192664 cur_rank 0 abs_cur_rank 1 total_num 729 865\n",
      "215 150\n",
      "215 643 172\n",
      "checkcorrect 210 210 real score 1.9193708419799804 Hits@1 0.8194254445964432 Hits@3 0.9110807113543091 Hits@10 0.9767441860465116 MRR 0.8755561020124001 cur_rank 0 abs_cur_rank 0 total_num 730 865\n",
      "215 82\n",
      "215 185 257\n",
      "checkcorrect 290 290 real score 1.8200573861598968 Hits@1 0.819672131147541 Hits@3 0.9112021857923497 Hits@10 0.976775956284153 MRR 0.8757261073375198 cur_rank 0 abs_cur_rank 0 total_num 731 865\n",
      "215 85\n",
      "215 764 87\n",
      "checkcorrect 360 360 real score 1.1584025353193284 Hits@1 0.8185538881309686 Hits@3 0.9099590723055935 Hits@10 0.9768076398362893 MRR 0.8747262861035765 cur_rank 6 abs_cur_rank 6 total_num 732 865\n",
      "215 80\n",
      "215 18 155\n",
      "checkcorrect 2 2 real score 1.8388079583644867 Hits@1 0.8188010899182562 Hits@3 0.9100817438692098 Hits@10 0.9768392370572208 MRR 0.8748969587383127 cur_rank 0 abs_cur_rank 0 total_num 733 865\n",
      "215 150\n",
      "215 495 266\n",
      "checkcorrect 6 6 real score 1.98410621881485 Hits@1 0.819047619047619 Hits@3 0.9102040816326531 Hits@10 0.9768707482993197 MRR 0.8750671669577165 cur_rank 0 abs_cur_rank 0 total_num 734 865\n",
      "215 113\n",
      "215 764 139\n",
      "checkcorrect 22 22 real score 1.8285186529159545 Hits@1 0.8192934782608695 Hits@3 0.9103260869565217 Hits@10 0.9769021739130435 MRR 0.8752369126547848 cur_rank 0 abs_cur_rank 0 total_num 735 865\n",
      "215 150\n",
      "215 70 831\n",
      "checkcorrect 96 96 real score 1.8017274975776671 Hits@1 0.819538670284939 Hits@3 0.9104477611940298 Hits@10 0.9769335142469471 MRR 0.8754061977122409 cur_rank 0 abs_cur_rank 0 total_num 736 865\n",
      "215 114\n",
      "215 370 259\n",
      "checkcorrect 32 32 real score 1.955441105365753 Hits@1 0.8197831978319783 Hits@3 0.9105691056910569 Hits@10 0.9769647696476965 MRR 0.8755750240026038 cur_rank 0 abs_cur_rank 0 total_num 737 865\n",
      "215 81\n",
      "215 162 303\n",
      "checkcorrect 290 290 real score 1.7966560482978822 Hits@1 0.8200270635994588 Hits@3 0.9106901217861976 Hits@10 0.9769959404600812 MRR 0.8757433933882566 cur_rank 0 abs_cur_rank 0 total_num 738 865\n",
      "215 63\n",
      "215 801 332\n",
      "checkcorrect 54 54 real score 1.9465978562831878 Hits@1 0.8202702702702702 Hits@3 0.9108108108108108 Hits@10 0.977027027027027 MRR 0.8759113077215157 cur_rank 0 abs_cur_rank 0 total_num 739 865\n",
      "215 150\n",
      "215 185 554\n",
      "checkcorrect 110 110 real score 1.7374900549650192 Hits@1 0.8205128205128205 Hits@3 0.9109311740890689 Hits@10 0.9770580296896086 MRR 0.8760787688446985 cur_rank 0 abs_cur_rank 0 total_num 740 865\n",
      "215 113\n",
      "215 26 222\n",
      "checkcorrect 258 258 real score 1.36164790391922 Hits@1 0.8207547169811321 Hits@3 0.9110512129380054 Hits@10 0.977088948787062 MRR 0.8762457785901908 cur_rank 0 abs_cur_rank 0 total_num 741 865\n",
      "0 1\n",
      "0 4 3\n",
      "checkcorrect 198 198 real score 0.0 Hits@1 0.819650067294751 Hits@3 0.9098250336473755 Hits@10 0.9757738896366084 MRR 0.875079902710527 cur_rank 99 abs_cur_rank 99 total_num 742 865\n",
      "215 150\n",
      "215 265 790\n",
      "checkcorrect 44 44 real score 1.8318397164344788 Hits@1 0.8198924731182796 Hits@3 0.9099462365591398 Hits@10 0.9758064516129032 MRR 0.8752478060670988 cur_rank 0 abs_cur_rank 0 total_num 743 865\n",
      "215 149\n",
      "215 151 196\n",
      "checkcorrect 298 298 real score 1.9134725153446197 Hits@1 0.8201342281879195 Hits@3 0.9100671140939597 Hits@10 0.9758389261744966 MRR 0.8754152586764048 cur_rank 0 abs_cur_rank 2 total_num 744 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 394 275\n",
      "checkcorrect 78 78 real score 1.925958091020584 Hits@1 0.8203753351206434 Hits@3 0.9101876675603218 Hits@10 0.9758713136729222 MRR 0.8755822623511013 cur_rank 0 abs_cur_rank 0 total_num 745 865\n",
      "215 85\n",
      "215 73 201\n",
      "checkcorrect 64 64 real score 1.5926397025585175 Hits@1 0.8192771084337349 Hits@3 0.9103078982597055 Hits@10 0.9759036144578314 MRR 0.8750794748513007 cur_rank 1 abs_cur_rank 1 total_num 746 865\n",
      "215 88\n",
      "215 64 140\n",
      "checkcorrect 158 158 real score 1.8498303711414337 Hits@1 0.81951871657754 Hits@3 0.910427807486631 Hits@10 0.9759358288770054 MRR 0.8752464809009647 cur_rank 0 abs_cur_rank 0 total_num 747 865\n",
      "0 1\n",
      "0 3 105\n",
      "checkcorrect 126 126 real score 0.0 Hits@1 0.8184245660881175 Hits@3 0.9092122830440588 Hits@10 0.9746328437917223 MRR 0.8740987886701223 cur_rank 63 abs_cur_rank 63 total_num 748 865\n",
      "215 150\n",
      "215 166 685\n",
      "checkcorrect 96 96 real score 1.945528072118759 Hits@1 0.8186666666666667 Hits@3 0.9093333333333333 Hits@10 0.9746666666666667 MRR 0.8742666569518954 cur_rank 0 abs_cur_rank 0 total_num 749 865\n",
      "215 51\n",
      "215 456 1477\n",
      "checkcorrect 48 48 real score 1.8875175714492798 Hits@1 0.8189081225033289 Hits@3 0.9094540612516645 Hits@10 0.9747003994673769 MRR 0.8744340781809874 cur_rank 0 abs_cur_rank 0 total_num 750 865\n",
      "215 150\n",
      "215 150 431\n",
      "checkcorrect 0 0 real score 1.979764848947525 Hits@1 0.8191489361702128 Hits@3 0.9095744680851063 Hits@10 0.9747340425531915 MRR 0.8746010541408532 cur_rank 0 abs_cur_rank 0 total_num 751 865\n",
      "215 14\n",
      "215 54 51\n",
      "checkcorrect 50 50 real score 1.9424879014492036 Hits@1 0.8193891102257637 Hits@3 0.9096945551128818 Hits@10 0.9747675962815405 MRR 0.8747675866054735 cur_rank 0 abs_cur_rank 1 total_num 752 865\n",
      "215 150\n",
      "215 392 588\n",
      "checkcorrect 0 0 real score 1.9309707641601563 Hits@1 0.8196286472148541 Hits@3 0.9098143236074271 Hits@10 0.9748010610079576 MRR 0.8749336773394185 cur_rank 0 abs_cur_rank 0 total_num 753 865\n",
      "215 150\n",
      "215 281 539\n",
      "checkcorrect 54 54 real score 1.783033400774002 Hits@1 0.8198675496688742 Hits@3 0.909933774834437 Hits@10 0.9748344370860927 MRR 0.8750993280979094 cur_rank 0 abs_cur_rank 0 total_num 754 865\n",
      "215 150\n",
      "215 682 771\n",
      "checkcorrect 44 44 real score 1.860378235578537 Hits@1 0.8201058201058201 Hits@3 0.91005291005291 Hits@10 0.9748677248677249 MRR 0.8752645406268804 cur_rank 0 abs_cur_rank 0 total_num 755 865\n",
      "215 136\n",
      "215 610 398\n",
      "checkcorrect 64 64 real score 1.8660825192928314 Hits@1 0.8203434610303831 Hits@3 0.9101717305151915 Hits@10 0.9749009247027741 MRR 0.8754293166630404 cur_rank 0 abs_cur_rank 0 total_num 756 865\n",
      "215 119\n",
      "215 323 226\n",
      "checkcorrect 340 340 real score 1.251564410328865 Hits@1 0.8192612137203166 Hits@3 0.9089709762532981 Hits@10 0.974934036939314 MRR 0.8744393043719282 cur_rank 7 abs_cur_rank 7 total_num 757 865\n",
      "215 65\n",
      "215 284 53\n",
      "checkcorrect 314 314 real score 1.8411568403244019 Hits@1 0.8194993412384717 Hits@3 0.9090909090909091 Hits@10 0.9749670619235836 MRR 0.8746047334834276 cur_rank 0 abs_cur_rank 0 total_num 758 865\n",
      "215 133\n",
      "215 16 105\n",
      "checkcorrect 178 178 real score 1.9216538608074187 Hits@1 0.8197368421052632 Hits@3 0.9092105263157895 Hits@10 0.975 MRR 0.87476972725516 cur_rank 0 abs_cur_rank 0 total_num 759 865\n",
      "215 150\n",
      "215 488 584\n",
      "checkcorrect 54 54 real score 1.9451754987239838 Hits@1 0.8199737187910644 Hits@3 0.9093298291721419 Hits@10 0.9750328515111695 MRR 0.8749342874033135 cur_rank 0 abs_cur_rank 0 total_num 760 865\n",
      "0 1\n",
      "215 80 8\n",
      "checkcorrect 48 48 real score 0.8354342699050903 Hits@1 0.8202099737532809 Hits@3 0.9094488188976378 Hits@10 0.9750656167979003 MRR 0.8750984156350676 cur_rank 0 abs_cur_rank 0 total_num 761 865\n",
      "215 150\n",
      "215 207 879\n",
      "checkcorrect 0 0 real score 1.979760009050369 Hits@1 0.8204456094364351 Hits@3 0.90956749672346 Hits@10 0.9750982961992136 MRR 0.8752621136486521 cur_rank 0 abs_cur_rank 0 total_num 762 865\n",
      "0 0\n",
      "0 1 41\n",
      "checkcorrect 126 126 real score 0.0 Hits@1 0.819371727748691 Hits@3 0.9083769633507853 Hits@10 0.9738219895287958 MRR 0.8741369341805256 cur_rank 63 abs_cur_rank 63 total_num 763 865\n",
      "215 150\n",
      "215 417 1489\n",
      "checkcorrect 312 312 real score 1.7896117687225344 Hits@1 0.8196078431372549 Hits@3 0.9084967320261438 Hits@10 0.9738562091503268 MRR 0.8743014610639498 cur_rank 0 abs_cur_rank 0 total_num 764 865\n",
      "215 53\n",
      "215 41 261\n",
      "checkcorrect 310 310 real score 1.1341351628303529 Hits@1 0.8185378590078329 Hits@3 0.9073107049608355 Hits@10 0.9738903394255874 MRR 0.8734211719502893 cur_rank 4 abs_cur_rank 5 total_num 765 865\n",
      "215 150\n",
      "215 34 202\n",
      "checkcorrect 108 108 real score 1.9456921458244323 Hits@1 0.81877444589309 Hits@3 0.9074315514993481 Hits@10 0.9739243807040417 MRR 0.873586203016847 cur_rank 0 abs_cur_rank 0 total_num 766 865\n",
      "215 72\n",
      "215 555 202\n",
      "checkcorrect 116 116 real score 1.7599989593029024 Hits@1 0.8177083333333334 Hits@3 0.9075520833333334 Hits@10 0.9739583333333334 MRR 0.8730997626483354 cur_rank 1 abs_cur_rank 2 total_num 767 865\n",
      "215 133\n",
      "215 600 513\n",
      "checkcorrect 54 54 real score 1.9464879870414733 Hits@1 0.8179453836150845 Hits@3 0.9076723016905072 Hits@10 0.9739921976592978 MRR 0.873264782462837 cur_rank 0 abs_cur_rank 0 total_num 768 865\n",
      "215 150\n",
      "215 99 64\n",
      "checkcorrect 206 206 real score 1.919749879837036 Hits@1 0.8168831168831169 Hits@3 0.9077922077922078 Hits@10 0.974025974025974 MRR 0.872780023005093 cur_rank 1 abs_cur_rank 1 total_num 769 865\n",
      "215 150\n",
      "215 272 752\n",
      "checkcorrect 44 44 real score 1.838345158100128 Hits@1 0.8171206225680934 Hits@3 0.9079118028534371 Hits@10 0.9740596627756161 MRR 0.8729450294603394 cur_rank 0 abs_cur_rank 0 total_num 770 865\n",
      "215 150\n",
      "215 494 433\n",
      "checkcorrect 6 6 real score 1.9843497216701507 Hits@1 0.8173575129533679 Hits@3 0.9080310880829016 Hits@10 0.9740932642487047 MRR 0.8731096084377223 cur_rank 0 abs_cur_rank 0 total_num 771 865\n",
      "215 90\n",
      "215 234 248\n",
      "checkcorrect 110 110 real score 1.6977668583393097 Hits@1 0.8175937904269082 Hits@3 0.908150064683053 Hits@10 0.9741267787839586 MRR 0.8732737615962763 cur_rank 0 abs_cur_rank 0 total_num 772 865\n",
      "215 18\n",
      "215 487 303\n",
      "checkcorrect 54 54 real score 1.5641269922256469 Hits@1 0.8165374677002584 Hits@3 0.9082687338501292 Hits@10 0.9741602067183462 MRR 0.8725761641437403 cur_rank 2 abs_cur_rank 3 total_num 773 865\n",
      "215 11\n",
      "215 126 26\n",
      "checkcorrect 112 112 real score 1.6585760533809661 Hits@1 0.8154838709677419 Hits@3 0.9083870967741936 Hits@10 0.9741935483870968 MRR 0.8720954207061354 cur_rank 1 abs_cur_rank 1 total_num 774 865\n",
      "215 150\n",
      "215 191 301\n",
      "checkcorrect 8 8 real score 1.918829196691513 Hits@1 0.8157216494845361 Hits@3 0.9085051546391752 Hits@10 0.9742268041237113 MRR 0.8722602461949163 cur_rank 0 abs_cur_rank 0 total_num 775 865\n",
      "215 150\n",
      "215 113 857\n",
      "checkcorrect 96 96 real score 1.8213653266429901 Hits@1 0.8159588159588159 Hits@3 0.9086229086229086 Hits@10 0.9742599742599742 MRR 0.8724246474224646 cur_rank 0 abs_cur_rank 0 total_num 776 865\n",
      "215 149\n",
      "215 286 235\n",
      "checkcorrect 314 314 real score 1.881188225746155 Hits@1 0.8161953727506427 Hits@3 0.9087403598971723 Hits@10 0.974293059125964 MRR 0.8725886260247493 cur_rank 0 abs_cur_rank 0 total_num 777 865\n",
      "215 150\n",
      "215 231 731\n",
      "checkcorrect 216 216 real score 1.6103820264339448 Hits@1 0.8151476251604621 Hits@3 0.9075738125802311 Hits@10 0.9743260590500642 MRR 0.8717252259913415 cur_rank 4 abs_cur_rank 4 total_num 778 865\n",
      "215 150\n",
      "215 489 566\n",
      "checkcorrect 54 54 real score 1.9549970746040344 Hits@1 0.8153846153846154 Hits@3 0.9076923076923077 Hits@10 0.9743589743589743 MRR 0.8718896808298141 cur_rank 0 abs_cur_rank 0 total_num 779 865\n",
      "215 71\n",
      "0 4 129\n",
      "checkcorrect 78 78 real score 0.9980639517307281 Hits@1 0.8156209987195903 Hits@3 0.9078104993597952 Hits@10 0.9743918053777209 MRR 0.8720537145291357 cur_rank 0 abs_cur_rank 0 total_num 780 865\n",
      "215 138\n",
      "215 174 99\n",
      "checkcorrect 160 160 real score 1.9509585499763489 Hits@1 0.8158567774936062 Hits@3 0.907928388746803 Hits@10 0.9744245524296675 MRR 0.8722173287049297 cur_rank 0 abs_cur_rank 0 total_num 781 865\n",
      "215 141\n",
      "215 35 334\n",
      "checkcorrect 98 98 real score 1.9374436616897581 Hits@1 0.8160919540229885 Hits@3 0.9080459770114943 Hits@10 0.9744572158365262 MRR 0.8723805249645659 cur_rank 0 abs_cur_rank 0 total_num 782 865\n",
      "215 138\n",
      "215 496 195\n",
      "checkcorrect 134 134 real score 1.8575141489505769 Hits@1 0.8163265306122449 Hits@3 0.9081632653061225 Hits@10 0.9744897959183674 MRR 0.8725433049072131 cur_rank 0 abs_cur_rank 0 total_num 783 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 149\n",
      "215 482 655\n",
      "checkcorrect 54 54 real score 1.949459195137024 Hits@1 0.8165605095541402 Hits@3 0.9082802547770701 Hits@10 0.9745222929936306 MRR 0.8727056701238918 cur_rank 0 abs_cur_rank 0 total_num 784 865\n",
      "215 150\n",
      "215 297 699\n",
      "checkcorrect 96 96 real score 1.9266780972480775 Hits@1 0.816793893129771 Hits@3 0.9083969465648855 Hits@10 0.9745547073791349 MRR 0.8728676221975255 cur_rank 0 abs_cur_rank 0 total_num 785 865\n",
      "215 147\n",
      "0 4 691\n",
      "checkcorrect 44 44 real score 0.9999084234237671 Hits@1 0.8170266836086404 Hits@3 0.9085133418043202 Hits@10 0.974587039390089 MRR 0.8730291627029925 cur_rank 0 abs_cur_rank 0 total_num 786 865\n",
      "215 150\n",
      "215 401 871\n",
      "checkcorrect 96 96 real score 1.9344708144664766 Hits@1 0.817258883248731 Hits@3 0.9086294416243654 Hits@10 0.9746192893401016 MRR 0.8731902932071764 cur_rank 0 abs_cur_rank 0 total_num 787 865\n",
      "215 150\n",
      "215 1206 1518\n",
      "checkcorrect 50 50 real score 1.6820945024490357 Hits@1 0.8162230671736375 Hits@3 0.908745247148289 Hits@10 0.9746514575411914 MRR 0.8727173017075476 cur_rank 1 abs_cur_rank 2 total_num 788 865\n",
      "215 150\n",
      "215 482 692\n",
      "checkcorrect 20 20 real score 1.9498866140842437 Hits@1 0.8164556962025317 Hits@3 0.9088607594936708 Hits@10 0.9746835443037974 MRR 0.8728784190471582 cur_rank 0 abs_cur_rank 1 total_num 789 865\n",
      "215 150\n",
      "215 114 468\n",
      "checkcorrect 112 112 real score 1.7403739273548127 Hits@1 0.8166877370417194 Hits@3 0.9089759797724399 Hits@10 0.9747155499367889 MRR 0.8730391290104362 cur_rank 0 abs_cur_rank 0 total_num 790 865\n",
      "215 127\n",
      "215 283 413\n",
      "checkcorrect 64 64 real score 1.799179458618164 Hits@1 0.8169191919191919 Hits@3 0.9090909090909091 Hits@10 0.9747474747474747 MRR 0.8731994331404735 cur_rank 0 abs_cur_rank 0 total_num 791 865\n",
      "215 143\n",
      "215 456 333\n",
      "checkcorrect 54 54 real score 1.823955851793289 Hits@1 0.8171500630517023 Hits@3 0.9092055485498108 Hits@10 0.9747793190416141 MRR 0.8733593329725788 cur_rank 0 abs_cur_rank 0 total_num 792 865\n",
      "215 82\n",
      "215 205 415\n",
      "checkcorrect 50 50 real score 1.7462342381477356 Hits@1 0.8161209068010076 Hits@3 0.9093198992443325 Hits@10 0.9748110831234257 MRR 0.8728891071124119 cur_rank 1 abs_cur_rank 1 total_num 793 865\n",
      "215 60\n",
      "215 160 54\n",
      "checkcorrect 64 64 real score 1.830795556306839 Hits@1 0.8163522012578617 Hits@3 0.909433962264151 Hits@10 0.9748427672955975 MRR 0.8730489950279937 cur_rank 0 abs_cur_rank 0 total_num 794 865\n",
      "215 150\n",
      "215 650 950\n",
      "checkcorrect 28 28 real score 1.8189492285251618 Hits@1 0.8153266331658291 Hits@3 0.9095477386934674 Hits@10 0.9748743718592965 MRR 0.8723709602771211 cur_rank 2 abs_cur_rank 2 total_num 795 865\n",
      "215 150\n",
      "215 278 450\n",
      "checkcorrect 16 16 real score 1.907797598838806 Hits@1 0.8155583437892095 Hits@3 0.9096612296110415 Hits@10 0.9749058971141782 MRR 0.8725310970898223 cur_rank 0 abs_cur_rank 0 total_num 796 865\n",
      "215 150\n",
      "215 84 580\n",
      "checkcorrect 8 8 real score 1.9219367027282717 Hits@1 0.8157894736842105 Hits@3 0.9097744360902256 Hits@10 0.974937343358396 MRR 0.8726908325571283 cur_rank 0 abs_cur_rank 0 total_num 797 865\n",
      "215 124\n",
      "215 319 559\n",
      "checkcorrect 64 64 real score 1.8734978914260865 Hits@1 0.8160200250312891 Hits@3 0.9098873591989988 Hits@10 0.9749687108886108 MRR 0.872850168185968 cur_rank 0 abs_cur_rank 0 total_num 798 865\n",
      "215 54\n",
      "215 108 92\n",
      "checkcorrect 64 64 real score 1.8592040061950683 Hits@1 0.81625 Hits@3 0.91 Hits@10 0.975 MRR 0.8730091054757355 cur_rank 0 abs_cur_rank 0 total_num 799 865\n",
      "0 1\n",
      "215 21 178\n",
      "checkcorrect 24 24 real score 0.7013251483440399 Hits@1 0.815230961298377 Hits@3 0.9101123595505618 Hits@10 0.9750312109862672 MRR 0.8725434261929943 cur_rank 1 abs_cur_rank 1 total_num 800 865\n",
      "215 144\n",
      "215 64 208\n",
      "checkcorrect 96 96 real score 1.9511582791805266 Hits@1 0.8154613466334164 Hits@3 0.9102244389027432 Hits@10 0.9750623441396509 MRR 0.8727023496017312 cur_rank 0 abs_cur_rank 0 total_num 801 865\n",
      "215 148\n",
      "215 130 196\n",
      "checkcorrect 298 298 real score 1.9136784791946413 Hits@1 0.8156911581569116 Hits@3 0.9103362391033624 Hits@10 0.975093399750934 MRR 0.8728608771862869 cur_rank 0 abs_cur_rank 2 total_num 802 865\n",
      "215 150\n",
      "215 493 456\n",
      "checkcorrect 56 56 real score 1.69014852643013 Hits@1 0.8146766169154229 Hits@3 0.9092039800995025 Hits@10 0.9751243781094527 MRR 0.8720861746027219 cur_rank 3 abs_cur_rank 3 total_num 803 865\n",
      "215 82\n",
      "215 196 192\n",
      "checkcorrect 24 24 real score 1.78824742436409 Hits@1 0.8136645962732919 Hits@3 0.9093167701863354 Hits@10 0.9751552795031055 MRR 0.8716239557522837 cur_rank 1 abs_cur_rank 1 total_num 804 865\n",
      "215 76\n",
      "215 444 161\n",
      "checkcorrect 112 112 real score 1.3563392758369446 Hits@1 0.8126550868486352 Hits@3 0.9081885856079405 Hits@10 0.9751861042183623 MRR 0.8707493189171899 cur_rank 5 abs_cur_rank 6 total_num 805 865\n",
      "215 94\n",
      "215 46 79\n",
      "checkcorrect 240 240 real score 1.907175076007843 Hits@1 0.8128872366790583 Hits@3 0.9083023543990086 Hits@10 0.9752168525402726 MRR 0.8709094808516171 cur_rank 0 abs_cur_rank 0 total_num 806 865\n",
      "0 1\n",
      "215 151 15\n",
      "checkcorrect 48 48 real score 0.8832785844802856 Hits@1 0.8131188118811881 Hits@3 0.9084158415841584 Hits@10 0.9752475247524752 MRR 0.8710692463456127 cur_rank 0 abs_cur_rank 0 total_num 807 865\n",
      "215 150\n",
      "215 888 228\n",
      "checkcorrect 40 40 real score 1.9159124195575714 Hits@1 0.8133498145859085 Hits@3 0.9085290482076638 Hits@10 0.9752781211372065 MRR 0.8712286168692893 cur_rank 0 abs_cur_rank 0 total_num 808 865\n",
      "215 150\n",
      "215 158 243\n",
      "checkcorrect 382 382 real score 1.8758285522460936 Hits@1 0.8135802469135802 Hits@3 0.908641975308642 Hits@10 0.9753086419753086 MRR 0.8713875938855 cur_rank 0 abs_cur_rank 0 total_num 809 865\n",
      "215 30\n",
      "215 144 100\n",
      "checkcorrect 36 36 real score 1.8641908645629883 Hits@1 0.813810110974106 Hits@3 0.9087546239210851 Hits@10 0.9753390875462392 MRR 0.871546178849883 cur_rank 0 abs_cur_rank 0 total_num 810 865\n",
      "215 150\n",
      "215 885 518\n",
      "checkcorrect 54 54 real score 1.9303085923194887 Hits@1 0.8140394088669951 Hits@3 0.9088669950738916 Hits@10 0.9753694581280788 MRR 0.8717043732109052 cur_rank 0 abs_cur_rank 0 total_num 811 865\n",
      "215 65\n",
      "215 172 178\n",
      "checkcorrect 56 56 real score 1.6435641169548034 Hits@1 0.8142681426814268 Hits@3 0.9089790897908979 Hits@10 0.97539975399754 MRR 0.8718621784099078 cur_rank 0 abs_cur_rank 0 total_num 812 865\n",
      "215 20\n",
      "215 169 83\n",
      "checkcorrect 364 364 real score 0.4083487782627344 Hits@1 0.8132678132678133 Hits@3 0.9078624078624079 Hits@10 0.9754299754299754 MRR 0.8709275947891476 cur_rank 8 abs_cur_rank 8 total_num 813 865\n",
      "215 150\n",
      "215 542 753\n",
      "checkcorrect 40 40 real score 1.967102748155594 Hits@1 0.8134969325153374 Hits@3 0.9079754601226994 Hits@10 0.9754601226993865 MRR 0.8710859658384861 cur_rank 0 abs_cur_rank 0 total_num 814 865\n",
      "215 139\n",
      "215 356 104\n",
      "checkcorrect 22 22 real score 1.9508235275745391 Hits@1 0.8137254901960784 Hits@3 0.9080882352941176 Hits@10 0.9754901960784313 MRR 0.8712439487234879 cur_rank 0 abs_cur_rank 0 total_num 815 865\n",
      "215 150\n",
      "215 298 527\n",
      "checkcorrect 12 12 real score 1.9513294994831085 Hits@1 0.813953488372093 Hits@3 0.9082007343941249 Hits@10 0.9755201958384333 MRR 0.8714015448694812 cur_rank 0 abs_cur_rank 0 total_num 816 865\n",
      "215 146\n",
      "215 189 448\n",
      "checkcorrect 270 270 real score 1.5698965549468995 Hits@1 0.8141809290953546 Hits@3 0.9083129584352079 Hits@10 0.9755501222493888 MRR 0.8715587556948241 cur_rank 0 abs_cur_rank 0 total_num 817 865\n",
      "215 150\n",
      "215 351 421\n",
      "checkcorrect 32 32 real score 1.957027292251587 Hits@1 0.8144078144078144 Hits@3 0.9084249084249084 Hits@10 0.9755799755799756 MRR 0.8717155826109476 cur_rank 0 abs_cur_rank 0 total_num 818 865\n",
      "215 135\n",
      "215 15 293\n",
      "checkcorrect 58 58 real score 1.8947690427303314 Hits@1 0.8146341463414634 Hits@3 0.9085365853658537 Hits@10 0.975609756097561 MRR 0.8718720270223977 cur_rank 0 abs_cur_rank 0 total_num 819 865\n",
      "215 54\n",
      "215 79 156\n",
      "checkcorrect 220 220 real score 1.9029975235462189 Hits@1 0.8148599269183922 Hits@3 0.9086479902557856 Hits@10 0.9756394640682094 MRR 0.8720280903268771 cur_rank 0 abs_cur_rank 0 total_num 820 865\n",
      "215 149\n",
      "215 887 446\n",
      "checkcorrect 40 40 real score 1.9616164207458495 Hits@1 0.8150851581508516 Hits@3 0.9087591240875912 Hits@10 0.975669099756691 MRR 0.8721837739152872 cur_rank 0 abs_cur_rank 0 total_num 821 865\n",
      "215 150\n",
      "215 280 287\n",
      "checkcorrect 78 78 real score 1.9283703446388245 Hits@1 0.8153098420413123 Hits@3 0.9088699878493317 Hits@10 0.9756986634264885 MRR 0.8723390791717693 cur_rank 0 abs_cur_rank 0 total_num 822 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 150\n",
      "215 127 422\n",
      "checkcorrect 32 32 real score 1.9661504745483398 Hits@1 0.8155339805825242 Hits@3 0.9089805825242718 Hits@10 0.9757281553398058 MRR 0.8724940074737453 cur_rank 0 abs_cur_rank 0 total_num 823 865\n",
      "215 150\n",
      "215 679 573\n",
      "checkcorrect 50 50 real score 1.9365806818008422 Hits@1 0.8157575757575758 Hits@3 0.9090909090909091 Hits@10 0.9757575757575757 MRR 0.8726485601919589 cur_rank 0 abs_cur_rank 1 total_num 824 865\n",
      "215 124\n",
      "215 528 221\n",
      "checkcorrect 22 22 real score 1.9509704828262329 Hits@1 0.8159806295399515 Hits@3 0.9092009685230025 Hits@10 0.9757869249394673 MRR 0.8728027386905158 cur_rank 0 abs_cur_rank 0 total_num 825 865\n",
      "215 118\n",
      "215 539 138\n",
      "checkcorrect 30 30 real score 1.875330513715744 Hits@1 0.8162031438935913 Hits@3 0.909310761789601 Hits@10 0.9758162031438936 MRR 0.8729565443269239 cur_rank 0 abs_cur_rank 0 total_num 826 865\n",
      "215 124\n",
      "215 515 132\n",
      "checkcorrect 134 134 real score 1.8997666835784912 Hits@1 0.8164251207729468 Hits@3 0.9094202898550725 Hits@10 0.9758454106280193 MRR 0.873109978452133 cur_rank 0 abs_cur_rank 0 total_num 827 865\n",
      "215 144\n",
      "215 251 251\n",
      "checkcorrect 32 32 real score 1.9677810490131378 Hits@1 0.8166465621230398 Hits@3 0.9095295536791315 Hits@10 0.9758745476477684 MRR 0.8732630424105743 cur_rank 0 abs_cur_rank 0 total_num 828 865\n",
      "215 150\n",
      "215 381 333\n",
      "checkcorrect 54 54 real score 1.809830939769745 Hits@1 0.8168674698795181 Hits@3 0.9096385542168675 Hits@10 0.9759036144578314 MRR 0.8734157375402002 cur_rank 0 abs_cur_rank 0 total_num 829 865\n",
      "0 1\n",
      "0 61 4\n",
      "checkcorrect 48 48 real score 0.0 Hits@1 0.8158844765342961 Hits@3 0.9085439229843562 Hits@10 0.9747292418772563 MRR 0.8724128305154827 cur_rank 24 abs_cur_rank 24 total_num 830 865\n",
      "215 139\n",
      "215 361 284\n",
      "checkcorrect 24 24 real score 1.8573882460594178 Hits@1 0.8161057692307693 Hits@3 0.9086538461538461 Hits@10 0.9747596153846154 MRR 0.8725661804788054 cur_rank 0 abs_cur_rank 1 total_num 831 865\n",
      "215 150\n",
      "215 120 934\n",
      "checkcorrect 96 96 real score 1.8332766115665435 Hits@1 0.8163265306122449 Hits@3 0.9087635054021609 Hits@10 0.9747899159663865 MRR 0.8727191622549413 cur_rank 0 abs_cur_rank 0 total_num 832 865\n",
      "215 15\n",
      "215 186 75\n",
      "checkcorrect 216 216 real score 1.2402468204498291 Hits@1 0.815347721822542 Hits@3 0.907673860911271 Hits@10 0.9748201438848921 MRR 0.8719724965927651 cur_rank 3 abs_cur_rank 3 total_num 833 865\n",
      "0 0\n",
      "215 288 6\n",
      "checkcorrect 190 190 real score 0.7450079500675202 Hits@1 0.8155688622754491 Hits@3 0.9077844311377246 Hits@10 0.9748502994011976 MRR 0.872125822944151 cur_rank 0 abs_cur_rank 0 total_num 834 865\n",
      "215 150\n",
      "215 332 524\n",
      "checkcorrect 2 2 real score 1.8881144165992736 Hits@1 0.8157894736842105 Hits@3 0.9078947368421053 Hits@10 0.9748803827751196 MRR 0.8722787824860838 cur_rank 0 abs_cur_rank 0 total_num 835 865\n",
      "215 33\n",
      "215 204 41\n",
      "checkcorrect 78 78 real score 1.9344494581222533 Hits@1 0.8160095579450418 Hits@3 0.9080047789725209 Hits@10 0.974910394265233 MRR 0.8724313765332928 cur_rank 0 abs_cur_rank 0 total_num 836 865\n",
      "215 131\n",
      "215 466 601\n",
      "checkcorrect 50 50 real score 1.8845201432704926 Hits@1 0.8162291169451074 Hits@3 0.9081145584725537 Hits@10 0.9749403341288783 MRR 0.8725836063942316 cur_rank 0 abs_cur_rank 1 total_num 837 865\n",
      "215 150\n",
      "215 117 169\n",
      "checkcorrect 386 386 real score 1.8063776969909668 Hits@1 0.8164481525625745 Hits@3 0.9082240762812872 Hits@10 0.9749702026221693 MRR 0.8727354733711157 cur_rank 0 abs_cur_rank 0 total_num 838 865\n",
      "215 150\n",
      "215 472 427\n",
      "checkcorrect 0 0 real score 1.9696236610412599 Hits@1 0.8166666666666667 Hits@3 0.9083333333333333 Hits@10 0.975 MRR 0.8728869787599596 cur_rank 0 abs_cur_rank 0 total_num 839 865\n",
      "215 150\n",
      "215 69 980\n",
      "checkcorrect 146 146 real score 1.7102567911148072 Hits@1 0.8156956004756243 Hits@3 0.9084423305588585 Hits@10 0.9750297265160524 MRR 0.8724435935295672 cur_rank 1 abs_cur_rank 1 total_num 840 865\n",
      "215 150\n",
      "215 127 505\n",
      "checkcorrect 12 12 real score 1.9557380855083466 Hits@1 0.815914489311164 Hits@3 0.9085510688836105 Hits@10 0.9750593824228029 MRR 0.8725950856987721 cur_rank 0 abs_cur_rank 0 total_num 841 865\n",
      "215 141\n",
      "0 4 129\n",
      "checkcorrect 78 78 real score 0.998153704404831 Hits@1 0.8161328588374852 Hits@3 0.9086595492289442 Hits@10 0.9750889679715302 MRR 0.8727462184559502 cur_rank 0 abs_cur_rank 0 total_num 842 865\n",
      "215 150\n",
      "215 456 482\n",
      "checkcorrect 40 40 real score 1.928910678625107 Hits@1 0.816350710900474 Hits@3 0.9087677725118484 Hits@10 0.9751184834123223 MRR 0.8728969930786328 cur_rank 0 abs_cur_rank 0 total_num 843 865\n",
      "215 25\n",
      "215 73 19\n",
      "checkcorrect 14 14 real score 1.9043469190597535 Hits@1 0.8165680473372781 Hits@3 0.9088757396449704 Hits@10 0.9751479289940829 MRR 0.8730474108383031 cur_rank 0 abs_cur_rank 0 total_num 844 865\n",
      "0 1\n",
      "0 1 1\n",
      "checkcorrect 146 146 real score 0.0 Hits@1 0.8156028368794326 Hits@3 0.9078014184397163 Hits@10 0.9739952718676123 MRR 0.8720316321377105 cur_rank 72 abs_cur_rank 73 total_num 845 865\n",
      "215 150\n",
      "215 646 471\n",
      "checkcorrect 6 6 real score 1.9842435598373411 Hits@1 0.8158205430932703 Hits@3 0.9079102715466352 Hits@10 0.974025974025974 MRR 0.8721827163972882 cur_rank 0 abs_cur_rank 0 total_num 846 865\n",
      "215 35\n",
      "215 28 114\n",
      "checkcorrect 48 48 real score 1.8415299832820893 Hits@1 0.8160377358490566 Hits@3 0.9080188679245284 Hits@10 0.9740566037735849 MRR 0.872333444326065 cur_rank 0 abs_cur_rank 0 total_num 847 865\n",
      "215 150\n",
      "215 279 919\n",
      "checkcorrect 0 0 real score 1.979611301422119 Hits@1 0.8162544169611308 Hits@3 0.9081272084805654 Hits@10 0.9740871613663133 MRR 0.8724838171831603 cur_rank 0 abs_cur_rank 0 total_num 848 865\n",
      "215 37\n",
      "215 54 23\n",
      "checkcorrect 14 14 real score 1.9016746461391447 Hits@1 0.8164705882352942 Hits@3 0.908235294117647 Hits@10 0.9741176470588235 MRR 0.8726338362217684 cur_rank 0 abs_cur_rank 0 total_num 849 865\n",
      "215 66\n",
      "215 709 350\n",
      "checkcorrect 54 54 real score 1.8192752599716187 Hits@1 0.8166862514688602 Hits@3 0.9083431257344301 Hits@10 0.9741480611045829 MRR 0.8727835026891928 cur_rank 0 abs_cur_rank 1 total_num 850 865\n",
      "215 150\n",
      "215 403 477\n",
      "checkcorrect 168 168 real score 1.9021469891071319 Hits@1 0.8169014084507042 Hits@3 0.9084507042253521 Hits@10 0.9741784037558685 MRR 0.8729328178268816 cur_rank 0 abs_cur_rank 0 total_num 851 865\n",
      "215 150\n",
      "215 151 434\n",
      "checkcorrect 284 284 real score 1.9518423855304718 Hits@1 0.8171160609613131 Hits@3 0.9085580304806565 Hits@10 0.9742086752637749 MRR 0.8730817828704609 cur_rank 0 abs_cur_rank 1 total_num 852 865\n",
      "215 3\n",
      "0 3 3\n",
      "checkcorrect 230 230 real score 0.9953386723995209 Hits@1 0.8173302107728337 Hits@3 0.9086651053864169 Hits@10 0.9742388758782201 MRR 0.8732303990497694 cur_rank 0 abs_cur_rank 0 total_num 853 865\n",
      "215 150\n",
      "215 469 262\n",
      "checkcorrect 54 54 real score 1.556288343667984 Hits@1 0.816374269005848 Hits@3 0.9076023391812865 Hits@10 0.9742690058479532 MRR 0.8725014746064363 cur_rank 3 abs_cur_rank 3 total_num 854 865\n",
      "215 150\n",
      "215 21 740\n",
      "checkcorrect 44 44 real score 1.8515660226345063 Hits@1 0.8165887850467289 Hits@3 0.9077102803738317 Hits@10 0.9742990654205608 MRR 0.8726504214818962 cur_rank 0 abs_cur_rank 0 total_num 855 865\n",
      "215 147\n",
      "215 209 256\n",
      "checkcorrect 98 98 real score 1.9370337307453154 Hits@1 0.8168028004667445 Hits@3 0.9078179696616102 Hits@10 0.9743290548424738 MRR 0.8727990207567131 cur_rank 0 abs_cur_rank 0 total_num 856 865\n",
      "215 82\n",
      "215 493 319\n",
      "checkcorrect 134 134 real score 1.7243160516023637 Hits@1 0.817016317016317 Hits@3 0.9079254079254079 Hits@10 0.9743589743589743 MRR 0.872947273646274 cur_rank 0 abs_cur_rank 0 total_num 857 865\n",
      "215 150\n",
      "215 294 750\n",
      "checkcorrect 36 36 real score 1.8511578381061553 Hits@1 0.8172293364377182 Hits@3 0.9080325960419092 Hits@10 0.9743888242142026 MRR 0.8730951813603063 cur_rank 0 abs_cur_rank 0 total_num 858 865\n",
      "215 93\n",
      "215 166 142\n",
      "checkcorrect 158 158 real score 1.6806055426597597 Hits@1 0.8174418604651162 Hits@3 0.9081395348837209 Hits@10 0.9744186046511628 MRR 0.8732427451029106 cur_rank 0 abs_cur_rank 0 total_num 859 865\n",
      "215 150\n",
      "215 253 424\n",
      "checkcorrect 32 32 real score 1.96060511469841 Hits@1 0.8176538908246226 Hits@3 0.908246225319396 Hits@10 0.9744483159117305 MRR 0.8733899660725936 cur_rank 0 abs_cur_rank 0 total_num 860 865\n",
      "215 83\n",
      "215 668 340\n",
      "checkcorrect 54 54 real score 1.9361667454242708 Hits@1 0.8178654292343387 Hits@3 0.9083526682134571 Hits@10 0.974477958236659 MRR 0.8735368454623006 cur_rank 0 abs_cur_rank 0 total_num 861 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215 43\n",
      "215 51 183\n",
      "checkcorrect 96 96 real score 1.829619586467743 Hits@1 0.8180764774044033 Hits@3 0.9084588644264194 Hits@10 0.9745075318655851 MRR 0.8736833844594474 cur_rank 0 abs_cur_rank 0 total_num 862 865\n",
      "215 63\n",
      "215 28 65\n",
      "checkcorrect 418 418 real score 0.18934890478849412 Hits@1 0.8171296296296297 Hits@3 0.9074074074074074 Hits@10 0.9733796296296297 MRR 0.872722498899737 cur_rank 22 abs_cur_rank 22 total_num 863 865\n",
      "215 150\n",
      "215 105 422\n",
      "checkcorrect 32 32 real score 1.9584471762180327 Hits@1 0.8173410404624277 Hits@3 0.9075144508670521 Hits@10 0.9734104046242774 MRR 0.872869640519506 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.9146081349206349\n",
      "evaluating scores 40 1730\n",
      "AUC-PR is: 0.952178154167739\n",
      "evaluating scores 60 1730\n",
      "AUC-PR is: 0.9434951239412182\n",
      "evaluating scores 80 1730\n",
      "AUC-PR is: 0.9611032540229625\n",
      "evaluating scores 100 1730\n",
      "AUC-PR is: 0.9668484887798527\n",
      "evaluating scores 120 1730\n",
      "AUC-PR is: 0.973279756722939\n",
      "evaluating scores 140 1730\n",
      "AUC-PR is: 0.9735632277843105\n",
      "evaluating scores 160 1730\n",
      "AUC-PR is: 0.9704524865773986\n",
      "evaluating scores 180 1730\n",
      "AUC-PR is: 0.9497144116256058\n",
      "evaluating scores 200 1730\n",
      "AUC-PR is: 0.9423278053513167\n",
      "evaluating scores 220 1730\n",
      "AUC-PR is: 0.9446454088809971\n",
      "evaluating scores 240 1730\n",
      "AUC-PR is: 0.9460570168328499\n",
      "evaluating scores 260 1730\n",
      "AUC-PR is: 0.948892080442706\n",
      "evaluating scores 280 1730\n",
      "AUC-PR is: 0.9471270915928109\n",
      "evaluating scores 300 1730\n",
      "AUC-PR is: 0.9491235660805095\n",
      "evaluating scores 320 1730\n",
      "AUC-PR is: 0.9490861807789355\n",
      "evaluating scores 340 1730\n",
      "AUC-PR is: 0.9490763137382958\n",
      "evaluating scores 360 1730\n",
      "AUC-PR is: 0.9461570946043639\n",
      "evaluating scores 380 1730\n",
      "AUC-PR is: 0.9429598464850149\n",
      "evaluating scores 400 1730\n",
      "AUC-PR is: 0.9462199025872865\n",
      "evaluating scores 420 1730\n",
      "AUC-PR is: 0.9479990507066749\n",
      "evaluating scores 440 1730\n",
      "AUC-PR is: 0.9480485999062536\n",
      "evaluating scores 460 1730\n",
      "AUC-PR is: 0.9477349309162861\n",
      "evaluating scores 480 1730\n",
      "AUC-PR is: 0.9464945908591512\n",
      "evaluating scores 500 1730\n",
      "AUC-PR is: 0.9478307386729441\n",
      "evaluating scores 520 1730\n",
      "AUC-PR is: 0.9496753026404312\n",
      "evaluating scores 540 1730\n",
      "AUC-PR is: 0.9494532521934117\n",
      "evaluating scores 560 1730\n",
      "AUC-PR is: 0.9485485692889286\n",
      "evaluating scores 580 1730\n",
      "AUC-PR is: 0.94929936168706\n",
      "evaluating scores 600 1730\n",
      "AUC-PR is: 0.9516194315906751\n",
      "evaluating scores 620 1730\n",
      "AUC-PR is: 0.9515853487914663\n",
      "evaluating scores 640 1730\n",
      "AUC-PR is: 0.9494223074012142\n",
      "evaluating scores 660 1730\n",
      "AUC-PR is: 0.9500817736095238\n",
      "evaluating scores 680 1730\n",
      "AUC-PR is: 0.9457616494826372\n",
      "evaluating scores 700 1730\n",
      "AUC-PR is: 0.9438115060470949\n",
      "evaluating scores 720 1730\n",
      "AUC-PR is: 0.9451332153487615\n",
      "evaluating scores 740 1730\n",
      "AUC-PR is: 0.9456753942627963\n",
      "evaluating scores 760 1730\n",
      "AUC-PR is: 0.944965691395006\n",
      "evaluating scores 780 1730\n",
      "AUC-PR is: 0.9449285336210264\n",
      "evaluating scores 800 1730\n",
      "AUC-PR is: 0.944517485795181\n",
      "evaluating scores 820 1730\n",
      "AUC-PR is: 0.942794042498297\n",
      "evaluating scores 840 1730\n",
      "AUC-PR is: 0.9441314711497288\n",
      "evaluating scores 860 1730\n",
      "AUC-PR is: 0.9435997188029219\n",
      "evaluating scores 880 1730\n",
      "AUC-PR is: 0.9430379028980617\n",
      "evaluating scores 900 1730\n",
      "AUC-PR is: 0.9424748341343615\n",
      "evaluating scores 920 1730\n",
      "AUC-PR is: 0.9427125608161407\n",
      "evaluating scores 940 1730\n",
      "AUC-PR is: 0.9438985839987407\n",
      "evaluating scores 960 1730\n",
      "AUC-PR is: 0.9436889166946881\n",
      "evaluating scores 980 1730\n",
      "AUC-PR is: 0.9372990067523169\n",
      "evaluating scores 1000 1730\n",
      "AUC-PR is: 0.9366751346588083\n",
      "evaluating scores 1020 1730\n",
      "AUC-PR is: 0.9369992596324151\n",
      "evaluating scores 1040 1730\n",
      "AUC-PR is: 0.9376091934246937\n",
      "evaluating scores 1060 1730\n",
      "AUC-PR is: 0.9373866040513921\n",
      "evaluating scores 1080 1730\n",
      "AUC-PR is: 0.9370320680249301\n",
      "evaluating scores 1100 1730\n",
      "AUC-PR is: 0.9367992431376835\n",
      "evaluating scores 1120 1730\n",
      "AUC-PR is: 0.938495362025973\n",
      "evaluating scores 1140 1730\n",
      "AUC-PR is: 0.9384551079265138\n",
      "evaluating scores 1160 1730\n",
      "AUC-PR is: 0.9399078694527561\n",
      "evaluating scores 1180 1730\n",
      "AUC-PR is: 0.9394593521468707\n",
      "evaluating scores 1200 1730\n",
      "AUC-PR is: 0.9389232881864131\n",
      "evaluating scores 1220 1730\n",
      "AUC-PR is: 0.9379540102848226\n",
      "evaluating scores 1240 1730\n",
      "AUC-PR is: 0.938321154518667\n",
      "evaluating scores 1260 1730\n",
      "AUC-PR is: 0.93684818169226\n",
      "evaluating scores 1280 1730\n",
      "AUC-PR is: 0.9376364123317995\n",
      "evaluating scores 1300 1730\n",
      "AUC-PR is: 0.9375521767297582\n",
      "evaluating scores 1320 1730\n",
      "AUC-PR is: 0.9377319910829531\n",
      "evaluating scores 1340 1730\n",
      "AUC-PR is: 0.9390780673835157\n",
      "evaluating scores 1360 1730\n",
      "AUC-PR is: 0.9406644100806036\n",
      "evaluating scores 1380 1730\n",
      "AUC-PR is: 0.9405375466774535\n",
      "evaluating scores 1400 1730\n",
      "AUC-PR is: 0.9408517446703011\n",
      "evaluating scores 1420 1730\n",
      "AUC-PR is: 0.9409790829249649\n",
      "evaluating scores 1440 1730\n",
      "AUC-PR is: 0.9413627809046424\n",
      "evaluating scores 1460 1730\n",
      "AUC-PR is: 0.9409728484549865\n",
      "evaluating scores 1480 1730\n",
      "AUC-PR is: 0.9422576871522521\n",
      "evaluating scores 1500 1730\n",
      "AUC-PR is: 0.9414842525921177\n",
      "evaluating scores 1520 1730\n",
      "AUC-PR is: 0.9410380181211854\n",
      "evaluating scores 1540 1730\n",
      "AUC-PR is: 0.9381903383781409\n",
      "evaluating scores 1560 1730\n",
      "AUC-PR is: 0.9373679133723158\n",
      "evaluating scores 1580 1730\n",
      "AUC-PR is: 0.9373751287980914\n",
      "evaluating scores 1600 1730\n",
      "AUC-PR is: 0.9379520084538484\n",
      "evaluating scores 1620 1730\n",
      "AUC-PR is: 0.9384977702552311\n",
      "evaluating scores 1640 1730\n",
      "AUC-PR is: 0.9388832867648919\n",
      "evaluating scores 1660 1730\n",
      "AUC-PR is: 0.9395928224300246\n",
      "evaluating scores 1680 1730\n",
      "AUC-PR is: 0.9404398404881442\n",
      "evaluating scores 1700 1730\n",
      "AUC-PR is: 0.9398252345488836\n",
      "evaluating scores 1720 1730\n",
      "AUC-PR is: 0.9403512055140738\n",
      "AUC-PR is: 0.9398237643645295\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",
    "        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",
    "        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": "9a4cc917",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "evaluating scores 20 1730\n",
      "auc, auc-pr 1.0 1.0\n",
      "evaluating scores 40 1730\n",
      "auc, auc-pr 0.9448621553884713 0.9443231476126213\n",
      "evaluating scores 60 1730\n",
      "auc, auc-pr 0.9375 0.9123577214401528\n",
      "evaluating scores 80 1730\n",
      "auc, auc-pr 0.941213258286429 0.9192303284536726\n",
      "evaluating scores 100 1730\n",
      "auc, auc-pr 0.9524959742351047 0.9291994351614037\n",
      "evaluating scores 120 1730\n",
      "auc, auc-pr 0.9404296875 0.9265768851115518\n",
      "evaluating scores 140 1730\n",
      "auc, auc-pr 0.9414828431372548 0.9307847438402312\n",
      "evaluating scores 160 1730\n",
      "auc, auc-pr 0.9441838649155723 0.9364035780034294\n",
      "evaluating scores 180 1730\n",
      "auc, auc-pr 0.9343209876543209 0.9303179636355795\n",
      "evaluating scores 200 1730\n",
      "auc, auc-pr 0.9366429786808127 0.9265305357882393\n",
      "evaluating scores 220 1730\n",
      "auc, auc-pr 0.9290381275328756 0.9152592454001831\n",
      "evaluating scores 240 1730\n",
      "auc, auc-pr 0.9161976235146967 0.8923021052167291\n",
      "evaluating scores 260 1730\n",
      "auc, auc-pr 0.9157938339546718 0.8949330580468743\n",
      "evaluating scores 280 1730\n",
      "auc, auc-pr 0.921622173446991 0.9072928976010551\n",
      "evaluating scores 300 1730\n",
      "auc, auc-pr 0.9237235367372354 0.9097563025008699\n",
      "evaluating scores 320 1730\n",
      "auc, auc-pr 0.9286663280059396 0.9142998948722766\n",
      "evaluating scores 340 1730\n",
      "auc, auc-pr 0.9255820399113082 0.9162941292211485\n",
      "evaluating scores 360 1730\n",
      "auc, auc-pr 0.9235881425612809 0.9163902858282864\n",
      "evaluating scores 380 1730\n",
      "auc, auc-pr 0.9252616674532885 0.9207894171482522\n",
      "evaluating scores 400 1730\n",
      "auc, auc-pr 0.9270147047771737 0.9219876852841736\n",
      "evaluating scores 420 1730\n",
      "auc, auc-pr 0.9303740014524328 0.9233707088315503\n",
      "evaluating scores 440 1730\n",
      "auc, auc-pr 0.9336906806846168 0.9289892872551443\n",
      "evaluating scores 460 1730\n",
      "auc, auc-pr 0.9335416666666666 0.9292063567466322\n",
      "evaluating scores 480 1730\n",
      "auc, auc-pr 0.9309739130434783 0.9218686662532493\n",
      "evaluating scores 500 1730\n",
      "auc, auc-pr 0.9310295037782162 0.9234841931829597\n",
      "evaluating scores 520 1730\n",
      "auc, auc-pr 0.9315479720113852 0.9232726035141219\n",
      "evaluating scores 540 1730\n",
      "auc, auc-pr 0.9331456043956045 0.9243471866826471\n",
      "evaluating scores 560 1730\n",
      "auc, auc-pr 0.9323797471590546 0.9257670367986781\n",
      "evaluating scores 580 1730\n",
      "auc, auc-pr 0.9327142857142857 0.9250876800410606\n",
      "evaluating scores 600 1730\n",
      "auc, auc-pr 0.9294537927350428 0.92072588283202\n",
      "evaluating scores 620 1730\n",
      "auc, auc-pr 0.9288007003209805 0.9169484092601431\n",
      "evaluating scores 640 1730\n",
      "auc, auc-pr 0.9284169317347688 0.9181516382520957\n",
      "evaluating scores 660 1730\n",
      "auc, auc-pr 0.9291612903225808 0.9211819063575359\n",
      "evaluating scores 680 1730\n",
      "auc, auc-pr 0.9281254613186984 0.9201334703056276\n",
      "evaluating scores 700 1730\n",
      "auc, auc-pr 0.9242174899090381 0.9114633942891337\n",
      "evaluating scores 720 1730\n",
      "auc, auc-pr 0.9256938642903556 0.91251642031222\n",
      "evaluating scores 740 1730\n",
      "auc, auc-pr 0.9276983133024264 0.9145435536416922\n",
      "evaluating scores 760 1730\n",
      "auc, auc-pr 0.9277487347176806 0.915662674580852\n",
      "evaluating scores 780 1730\n",
      "auc, auc-pr 0.9298308032890574 0.9174481602519352\n",
      "evaluating scores 800 1730\n",
      "auc, auc-pr 0.9298535338025433 0.9189260281169177\n",
      "evaluating scores 820 1730\n",
      "auc, auc-pr 0.9306390798014508 0.9200455325743819\n",
      "evaluating scores 840 1730\n",
      "auc, auc-pr 0.929307169330817 0.9169578278771995\n",
      "evaluating scores 860 1730\n",
      "auc, auc-pr 0.9309360359187924 0.9184247045925309\n",
      "evaluating scores 880 1730\n",
      "auc, auc-pr 0.9326552795031056 0.9194724286977528\n",
      "evaluating scores 900 1730\n",
      "auc, auc-pr 0.9340450272142503 0.921126099283633\n",
      "evaluating scores 920 1730\n",
      "auc, auc-pr 0.9333210178290607 0.9218498076940633\n",
      "evaluating scores 940 1730\n",
      "auc, auc-pr 0.9333768630491659 0.9212960231987505\n",
      "evaluating scores 960 1730\n",
      "auc, auc-pr 0.9326899680200222 0.920311377025525\n",
      "evaluating scores 980 1730\n",
      "auc, auc-pr 0.934290036506693 0.9212023236098326\n",
      "evaluating scores 1000 1730\n",
      "auc, auc-pr 0.9355182072829132 0.9221498257316467\n",
      "evaluating scores 1020 1730\n",
      "auc, auc-pr 0.9341586576365574 0.9207421221104525\n",
      "evaluating scores 1040 1730\n",
      "auc, auc-pr 0.9345807873829355 0.92099144968526\n",
      "evaluating scores 1060 1730\n",
      "auc, auc-pr 0.9356777621102708 0.9230119967705213\n",
      "evaluating scores 1080 1730\n",
      "auc, auc-pr 0.9362599674183316 0.9230920214721765\n",
      "evaluating scores 1100 1730\n",
      "auc, auc-pr 0.937394213477203 0.9236207489749221\n",
      "evaluating scores 1120 1730\n",
      "auc, auc-pr 0.9382685341088831 0.9250980402101542\n",
      "evaluating scores 1140 1730\n",
      "auc, auc-pr 0.9383331640457875 0.9248976771878126\n",
      "evaluating scores 1160 1730\n",
      "auc, auc-pr 0.9391927845869835 0.9261310263603797\n",
      "evaluating scores 1180 1730\n",
      "auc, auc-pr 0.9397242171789715 0.9262993616994618\n",
      "evaluating scores 1200 1730\n",
      "auc, auc-pr 0.9397500000000001 0.9263694864137489\n",
      "evaluating scores 1220 1730\n",
      "auc, auc-pr 0.9390741736092447 0.9261877841208411\n",
      "evaluating scores 1240 1730\n",
      "auc, auc-pr 0.93866091218431 0.9239051254565123\n",
      "evaluating scores 1260 1730\n",
      "auc, auc-pr 0.9398021119148583 0.9248811845395506\n",
      "evaluating scores 1280 1730\n",
      "auc, auc-pr 0.9399742670127029 0.925125117604525\n",
      "evaluating scores 1300 1730\n",
      "auc, auc-pr 0.9401255432158377 0.9253288717959163\n",
      "evaluating scores 1320 1730\n",
      "auc, auc-pr 0.9404533151511395 0.9258709262413393\n",
      "evaluating scores 1340 1730\n",
      "auc, auc-pr 0.9395143684562264 0.9252150993121109\n",
      "evaluating scores 1360 1730\n",
      "auc, auc-pr 0.9379087511678605 0.9250199167726956\n",
      "evaluating scores 1380 1730\n",
      "auc, auc-pr 0.9380865561539561 0.9253047822445798\n",
      "evaluating scores 1400 1730\n",
      "auc, auc-pr 0.9385898315047021 0.9258495419332107\n",
      "evaluating scores 1420 1730\n",
      "auc, auc-pr 0.9389615619618952 0.9267355072740415\n",
      "evaluating scores 1440 1730\n",
      "auc, auc-pr 0.9385537311244686 0.9263374874152642\n",
      "evaluating scores 1460 1730\n",
      "auc, auc-pr 0.9375791660333385 0.9247084221345223\n",
      "evaluating scores 1480 1730\n",
      "auc, auc-pr 0.9365298504737068 0.9228386411738279\n",
      "evaluating scores 1500 1730\n",
      "auc, auc-pr 0.9366185539885404 0.9230380118699749\n",
      "evaluating scores 1520 1730\n",
      "auc, auc-pr 0.9373821614256455 0.9235977470879856\n",
      "evaluating scores 1540 1730\n",
      "auc, auc-pr 0.9371491606844066 0.9222611340816549\n",
      "evaluating scores 1560 1730\n",
      "auc, auc-pr 0.9370519827409082 0.9226146121528412\n",
      "evaluating scores 1580 1730\n",
      "auc, auc-pr 0.9371090345075117 0.9236907687465444\n",
      "evaluating scores 1600 1730\n",
      "auc, auc-pr 0.936193351208445 0.9235424288214675\n",
      "evaluating scores 1620 1730\n",
      "auc, auc-pr 0.9365252950787689 0.924030102794977\n",
      "evaluating scores 1640 1730\n",
      "auc, auc-pr 0.9373892028554431 0.9253813800726096\n",
      "evaluating scores 1660 1730\n",
      "auc, auc-pr 0.9379997096821019 0.9261401922974732\n",
      "evaluating scores 1680 1730\n",
      "auc, auc-pr 0.9373285147392291 0.9259210957494151\n",
      "evaluating scores 1700 1730\n",
      "auc, auc-pr 0.9375625433391602 0.9261936897539602\n",
      "evaluating scores 1720 1730\n",
      "auc, auc-pr 0.9384855847560638 0.9271699592878\n",
      "evaluating scores 1729 1730\n",
      "(final) auc, auc-pr 0.9387096127501754 0.9276740846572455\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",
    "        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",
    "        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 (3935, 6, 4075) (3935, 6, 4075) real score 0.9920010834932327 Hits@1 1.0 Hits@3 1.0 Hits@10 1.0 MRR 1.0 rank 0 total_num 0 865\n",
      "checkcorrect (4489, 32, 4118) (4489, 32, 4118) real score 0.9745378106832504 Hits@1 0.5 Hits@3 1.0 Hits@10 1.0 MRR 0.75 rank 1 total_num 1 865\n",
      "checkcorrect (5047, 44, 3669) (5047, 44, 3669) real score 0.944369775056839 Hits@1 0.3333333333333333 Hits@3 0.6666666666666666 Hits@10 1.0 MRR 0.5833333333333334 rank 3 total_num 2 865\n",
      "checkcorrect (4441, 54, 4442) (4441, 54, 4442) real score 0.9385454803705215 Hits@1 0.25 Hits@3 0.75 Hits@10 1.0 MRR 0.5208333333333334 rank 2 total_num 3 865\n",
      "checkcorrect (4469, 32, 4593) (4469, 32, 4593) real score 0.9793678283691407 Hits@1 0.2 Hits@3 0.8 Hits@10 1.0 MRR 0.5166666666666667 rank 1 total_num 4 865\n",
      "checkcorrect (4357, 50, 4571) (4357, 50, 4571) real score 0.90095996260643 Hits@1 0.16666666666666666 Hits@3 0.8333333333333334 Hits@10 1.0 MRR 0.48611111111111116 rank 2 total_num 5 865\n",
      "checkcorrect (3922, 40, 3879) (3922, 40, 3879) real score 0.9381433129310608 Hits@1 0.14285714285714285 Hits@3 0.8571428571428571 Hits@10 1.0 MRR 0.46428571428571436 rank 2 total_num 6 865\n",
      "checkcorrect (4690, 54, 4541) (4690, 54, 4541) real score 0.7291030541062355 Hits@1 0.125 Hits@3 0.75 Hits@10 1.0 MRR 0.41875000000000007 rank 9 total_num 7 865\n",
      "checkcorrect (4512, 72, 3966) (4512, 72, 3966) real score 0.8534014031291008 Hits@1 0.1111111111111111 Hits@3 0.7777777777777778 Hits@10 1.0 MRR 0.4277777777777778 rank 1 total_num 8 865\n",
      "checkcorrect (5543, 378, 5542) (5543, 378, 5542) real score 0.0 Hits@1 0.1 Hits@3 0.7 Hits@10 0.9 MRR 0.38803030303030306 rank 32 total_num 9 865\n",
      "checkcorrect (4562, 0, 3980) (4562, 0, 3980) real score 0.9137377992272377 Hits@1 0.09090909090909091 Hits@3 0.7272727272727273 Hits@10 0.9090909090909091 MRR 0.38305785123966946 rank 2 total_num 10 865\n",
      "checkcorrect (4838, 312, 3770) (4838, 312, 3770) real score 0.8575201153755188 Hits@1 0.08333333333333333 Hits@3 0.6666666666666666 Hits@10 0.9166666666666666 MRR 0.36780303030303035 rank 4 total_num 11 865\n",
      "checkcorrect (4836, 96, 3727) (4836, 96, 3727) real score 0.9566113978624344 Hits@1 0.07692307692307693 Hits@3 0.6923076923076923 Hits@10 0.9230769230769231 MRR 0.36515151515151517 rank 2 total_num 12 865\n",
      "checkcorrect (4367, 40, 5129) (4367, 40, 5129) real score 0.9709581524133682 Hits@1 0.14285714285714285 Hits@3 0.7142857142857143 Hits@10 0.9285714285714286 MRR 0.41049783549783553 rank 0 total_num 13 865\n",
      "checkcorrect (3794, 78, 4333) (3794, 78, 4333) real score 0.964158895611763 Hits@1 0.2 Hits@3 0.7333333333333333 Hits@10 0.9333333333333333 MRR 0.4497979797979798 rank 0 total_num 14 865\n",
      "checkcorrect (4547, 186, 4546) (4547, 186, 4546) real score 0.861700814962387 Hits@1 0.1875 Hits@3 0.6875 Hits@10 0.9375 MRR 0.43731060606060607 rank 3 total_num 15 865\n",
      "checkcorrect (5209, 96, 3727) (5209, 96, 3727) real score 0.9244224667549134 Hits@1 0.17647058823529413 Hits@3 0.6470588235294118 Hits@10 0.9411764705882353 MRR 0.4262923351158645 rank 3 total_num 16 865\n",
      "checkcorrect (4979, 326, 4905) (4979, 326, 4905) real score 0.9442708998918533 Hits@1 0.16666666666666666 Hits@3 0.6666666666666666 Hits@10 0.9444444444444444 MRR 0.4303872053872054 rank 1 total_num 17 865\n",
      "checkcorrect (3991, 40, 3879) (3991, 40, 3879) real score 0.9658105343580246 Hits@1 0.21052631578947367 Hits@3 0.6842105263157895 Hits@10 0.9473684210526315 MRR 0.4603668261562998 rank 0 total_num 18 865\n",
      "checkcorrect (4116, 290, 4115) (4116, 290, 4115) real score 0.9047529369592666 Hits@1 0.2 Hits@3 0.65 Hits@10 0.95 MRR 0.44234848484848477 rank 9 total_num 19 865\n",
      "checkcorrect (4040, 6, 4427) (4040, 6, 4427) real score 0.9920613199472428 Hits@1 0.23809523809523808 Hits@3 0.6666666666666666 Hits@10 0.9523809523809523 MRR 0.4689033189033188 rank 0 total_num 20 865\n",
      "checkcorrect (4194, 64, 4785) (4194, 64, 4785) real score 0.9122835904359817 Hits@1 0.22727272727272727 Hits@3 0.6363636363636364 Hits@10 0.9545454545454546 MRR 0.4566804407713498 rank 4 total_num 21 865\n",
      "checkcorrect (4028, 402, 5083) (4028, 402, 5083) real score 0.49941173121333127 Hits@1 0.21739130434782608 Hits@3 0.6086956521739131 Hits@10 0.9565217391304348 MRR 0.44407114624505917 rank 5 total_num 22 865\n",
      "checkcorrect (4918, 160, 5903) (4918, 160, 5903) real score 0.4864265203475952 Hits@1 0.25 Hits@3 0.625 Hits@10 0.9583333333333334 MRR 0.46723484848484836 rank 0 total_num 23 865\n",
      "checkcorrect (4794, 96, 5207) (4794, 96, 5207) real score 0.895325344800949 Hits@1 0.24 Hits@3 0.6 Hits@10 0.96 MRR 0.45521212121212107 rank 5 total_num 24 865\n",
      "checkcorrect (4860, 78, 5192) (4860, 78, 5192) real score 0.7761216744780541 Hits@1 0.23076923076923078 Hits@3 0.5769230769230769 Hits@10 0.9615384615384616 MRR 0.4431984681984681 rank 6 total_num 25 865\n",
      "checkcorrect (4373, 116, 4372) (4373, 116, 4372) real score 0.8782118111848831 Hits@1 0.25925925925925924 Hits@3 0.5925925925925926 Hits@10 0.9629629629629629 MRR 0.46382074715408034 rank 0 total_num 26 865\n",
      "checkcorrect (4614, 54, 4050) (4614, 54, 4050) real score 0.9503283500671387 Hits@1 0.25 Hits@3 0.6071428571428571 Hits@10 0.9642857142857143 MRR 0.4651128633271489 rank 1 total_num 27 865\n",
      "checkcorrect (4982, 30, 5142) (4982, 30, 5142) real score 0.9255692660808563 Hits@1 0.2413793103448276 Hits@3 0.6206896551724138 Hits@10 0.9655172413793104 MRR 0.46056874160322425 rank 2 total_num 28 865\n",
      "checkcorrect (4738, 54, 3998) (4738, 54, 3998) real score 0.9389334380626679 Hits@1 0.23333333333333334 Hits@3 0.6 Hits@10 0.9666666666666667 MRR 0.4518831168831168 rank 4 total_num 29 865\n",
      "checkcorrect (5168, 424, 4060) (5168, 424, 4060) real score 0.4611143338028342 Hits@1 0.22580645161290322 Hits@3 0.5806451612903226 Hits@10 0.967741935483871 MRR 0.4437578550481775 rank 4 total_num 30 865\n",
      "checkcorrect (4500, 6, 4075) (4500, 6, 4075) real score 0.99202561378479 Hits@1 0.21875 Hits@3 0.59375 Hits@10 0.96875 MRR 0.44551542207792194 rank 1 total_num 31 865\n",
      "checkcorrect (6150, 40, 6025) (6150, 40, 6025) real score 0.983303615450859 Hits@1 0.24242424242424243 Hits@3 0.6060606060606061 Hits@10 0.9696969696969697 MRR 0.4623179850452576 rank 0 total_num 32 865\n",
      "checkcorrect (5219, 12, 3687) (5219, 12, 3687) real score 0.9725996047258377 Hits@1 0.23529411764705882 Hits@3 0.6176470588235294 Hits@10 0.9705882352941176 MRR 0.46342627960275007 rank 1 total_num 33 865\n",
      "checkcorrect (4935, 96, 3727) (4935, 96, 3727) real score 0.9440618932247162 Hits@1 0.22857142857142856 Hits@3 0.6285714285714286 Hits@10 0.9714285714285714 MRR 0.4644712430426715 rank 1 total_num 34 865\n",
      "checkcorrect (5019, 0, 4003) (5019, 0, 4003) real score 0.9896187454462051 Hits@1 0.25 Hits@3 0.6388888888888888 Hits@10 0.9722222222222222 MRR 0.47934704184704174 rank 0 total_num 35 865\n",
      "checkcorrect (4084, 44, 3669) (4084, 44, 3669) real score 0.9414636731147766 Hits@1 0.24324324324324326 Hits@3 0.6216216216216216 Hits@10 0.972972972972973 MRR 0.473148473148473 rank 3 total_num 36 865\n",
      "checkcorrect (5909, 410, 3780) (5909, 410, 3780) real score 0.8830163270235062 Hits@1 0.2631578947368421 Hits@3 0.631578947368421 Hits@10 0.9736842105263158 MRR 0.4870129870129869 rank 0 total_num 37 865\n",
      "checkcorrect (4201, 96, 3993) (4201, 96, 3993) real score 0.9409310579299927 Hits@1 0.2564102564102564 Hits@3 0.6153846153846154 Hits@10 0.9743589743589743 MRR 0.4796536796536795 rank 4 total_num 38 865\n",
      "checkcorrect (4129, 114, 3961) (4129, 114, 3961) real score 0.8457642138004303 Hits@1 0.275 Hits@3 0.625 Hits@10 0.975 MRR 0.4926623376623375 rank 0 total_num 39 865\n",
      "checkcorrect (3746, 78, 4844) (3746, 78, 4844) real score 0.9631170123815537 Hits@1 0.2926829268292683 Hits@3 0.6341463414634146 Hits@10 0.975609756097561 MRR 0.5050364269876464 rank 0 total_num 40 865\n",
      "checkcorrect (4490, 76, 6040) (4490, 76, 6040) real score 0.9284317433834076 Hits@1 0.30952380952380953 Hits@3 0.6428571428571429 Hits@10 0.9761904761904762 MRR 0.516821273964131 rank 0 total_num 41 865\n",
      "checkcorrect (3932, 36, 4051) (3932, 36, 4051) real score 0.916558313369751 Hits@1 0.3023255813953488 Hits@3 0.6511627906976745 Hits@10 0.9767441860465116 MRR 0.5164300815463605 rank 1 total_num 42 865\n",
      "checkcorrect (4390, 40, 5302) (4390, 40, 5302) real score 0.965401804447174 Hits@1 0.3181818181818182 Hits@3 0.6590909090909091 Hits@10 0.9772727272727273 MRR 0.5274203069657614 rank 0 total_num 43 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4578, 110, 5046) (4578, 110, 5046) real score 0.9230109274387359 Hits@1 0.3111111111111111 Hits@3 0.6666666666666666 Hits@10 0.9777777777777777 MRR 0.5268109668109667 rank 1 total_num 44 865\n",
      "checkcorrect (4869, 36, 4344) (4869, 36, 4344) real score 0.941147443652153 Hits@1 0.30434782608695654 Hits@3 0.6739130434782609 Hits@10 0.9782608695652174 MRR 0.5262281197063805 rank 1 total_num 45 865\n",
      "checkcorrect (4328, 290, 4669) (4328, 290, 4669) real score 0.9047014385461807 Hits@1 0.2978723404255319 Hits@3 0.6595744680851063 Hits@10 0.9787234042553191 MRR 0.5176913512019894 rank 7 total_num 46 865\n",
      "checkcorrect (4441, 24, 4009) (4441, 24, 4009) real score 0.9427716463804245 Hits@1 0.3125 Hits@3 0.6666666666666666 Hits@10 0.9791666666666666 MRR 0.527739448051948 rank 0 total_num 47 865\n",
      "checkcorrect (5951, 2, 5414) (5951, 2, 5414) real score 0.9518037974834441 Hits@1 0.32653061224489793 Hits@3 0.673469387755102 Hits@10 0.9795918367346939 MRR 0.5373774184998674 rank 0 total_num 48 865\n",
      "checkcorrect (4293, 154, 4367) (4293, 154, 4367) real score 0.8375815868377685 Hits@1 0.32 Hits@3 0.68 Hits@10 0.98 MRR 0.5332965367965367 rank 2 total_num 49 865\n",
      "checkcorrect (5110, 18, 4547) (5110, 18, 4547) real score 0.9692338734865189 Hits@1 0.3333333333333333 Hits@3 0.6862745098039216 Hits@10 0.9803921568627451 MRR 0.5424475850946437 rank 0 total_num 50 865\n",
      "checkcorrect (4750, 208, 4751) (4750, 208, 4751) real score 0.9938441127538682 Hits@1 0.34615384615384615 Hits@3 0.6923076923076923 Hits@10 0.9807692307692307 MRR 0.5512466699966698 rank 0 total_num 51 865\n",
      "checkcorrect (3782, 172, 4506) (3782, 172, 4506) real score 0.9926599055528641 Hits@1 0.3584905660377358 Hits@3 0.6981132075471698 Hits@10 0.9811320754716981 MRR 0.5597137139589968 rank 0 total_num 52 865\n",
      "checkcorrect (4511, 54, 4231) (4511, 54, 4231) real score 0.9197186172008515 Hits@1 0.35185185185185186 Hits@3 0.6851851851851852 Hits@10 0.9814814814814815 MRR 0.553978274811608 rank 3 total_num 53 865\n",
      "checkcorrect (5102, 128, 4274) (5102, 128, 4274) real score 0.43022642135620115 Hits@1 0.34545454545454546 Hits@3 0.6909090909090909 Hits@10 0.9818181818181818 MRR 0.5529968516332151 rank 1 total_num 54 865\n",
      "checkcorrect (3969, 22, 4869) (3969, 22, 4869) real score 0.9757951229810715 Hits@1 0.35714285714285715 Hits@3 0.6964285714285714 Hits@10 0.9821428571428571 MRR 0.5609790507111935 rank 0 total_num 55 865\n",
      "checkcorrect (3904, 382, 4095) (3904, 382, 4095) real score 0.9736473619937898 Hits@1 0.3508771929824561 Hits@3 0.7017543859649122 Hits@10 0.9824561403508771 MRR 0.5599092428039796 rank 1 total_num 56 865\n",
      "checkcorrect (4318, 314, 3761) (4318, 314, 3761) real score 0.9083033621311187 Hits@1 0.3620689655172414 Hits@3 0.7068965517241379 Hits@10 0.9827586206896551 MRR 0.567497014479773 rank 0 total_num 57 865\n",
      "checkcorrect (3782, 8, 4403) (3782, 8, 4403) real score 0.9641752928495406 Hits@1 0.3728813559322034 Hits@3 0.711864406779661 Hits@10 0.9830508474576272 MRR 0.5748275735563869 rank 0 total_num 58 865\n",
      "checkcorrect (5896, 110, 5750) (5896, 110, 5750) real score 0.9113737940788269 Hits@1 0.36666666666666664 Hits@3 0.7 Hits@10 0.9833333333333333 MRR 0.5670989658489657 rank 8 total_num 59 865\n",
      "checkcorrect (4451, 0, 3867) (4451, 0, 3867) real score 0.9587811410427094 Hits@1 0.3770491803278688 Hits@3 0.7049180327868853 Hits@10 0.9836065573770492 MRR 0.5741957041137368 rank 0 total_num 60 865\n",
      "checkcorrect (4049, 64, 4405) (4049, 64, 4405) real score 0.9326153963804245 Hits@1 0.3870967741935484 Hits@3 0.7096774193548387 Hits@10 0.9838709677419355 MRR 0.5810635153377087 rank 0 total_num 61 865\n",
      "checkcorrect (4504, 0, 3904) (4504, 0, 3904) real score 0.7738810673356056 Hits@1 0.38095238095238093 Hits@3 0.6984126984126984 Hits@10 0.9841269841269841 MRR 0.5758085389037769 rank 3 total_num 62 865\n",
      "checkcorrect (3686, 32, 4118) (3686, 32, 4118) real score 0.9829475969076157 Hits@1 0.375 Hits@3 0.703125 Hits@10 0.984375 MRR 0.5746240304834054 rank 1 total_num 63 865\n",
      "checkcorrect (4102, 112, 4101) (4102, 112, 4101) real score 0.8839013308286667 Hits@1 0.38461538461538464 Hits@3 0.7076923076923077 Hits@10 0.9846153846153847 MRR 0.581168276168276 rank 0 total_num 64 865\n",
      "checkcorrect (4349, 40, 4313) (4349, 40, 4313) real score 0.9432776480913162 Hits@1 0.3787878787878788 Hits@3 0.696969696969697 Hits@10 0.9848484848484849 MRR 0.5745271983908347 rank 6 total_num 65 865\n",
      "checkcorrect (3836, 220, 4337) (3836, 220, 4337) real score 0.9498259335756303 Hits@1 0.373134328358209 Hits@3 0.7014925373134329 Hits@10 0.9850746268656716 MRR 0.5709272899571407 rank 2 total_num 66 865\n",
      "checkcorrect (4928, 12, 3687) (4928, 12, 3687) real score 0.9745021343231202 Hits@1 0.36764705882352944 Hits@3 0.7058823529411765 Hits@10 0.9852941176470589 MRR 0.5698842415754181 rank 1 total_num 67 865\n",
      "checkcorrect (4372, 28, 3976) (4372, 28, 3976) real score 0.8968997061252595 Hits@1 0.36231884057971014 Hits@3 0.6956521739130435 Hits@10 0.9855072463768116 MRR 0.565248238074325 rank 3 total_num 68 865\n",
      "checkcorrect (4050, 54, 5414) (4050, 54, 5414) real score 0.9639093309640885 Hits@1 0.35714285714285715 Hits@3 0.6857142857142857 Hits@10 0.9857142857142858 MRR 0.5607446918161204 rank 3 total_num 69 865\n",
      "checkcorrect (5620, 180, 4059) (5620, 180, 4059) real score 0.9679732233285905 Hits@1 0.352112676056338 Hits@3 0.6901408450704225 Hits@10 0.9859154929577465 MRR 0.5575417149360812 rank 2 total_num 70 865\n",
      "checkcorrect (4413, 54, 4329) (4413, 54, 4329) real score 0.9790947765111924 Hits@1 0.3611111111111111 Hits@3 0.6944444444444444 Hits@10 0.9861111111111112 MRR 0.5636869688953022 rank 0 total_num 71 865\n",
      "checkcorrect (4365, 98, 4919) (4365, 98, 4919) real score 0.9703195810317993 Hits@1 0.3561643835616438 Hits@3 0.6986301369863014 Hits@10 0.9863013698630136 MRR 0.5628145446638597 rank 1 total_num 72 865\n",
      "checkcorrect (4655, 320, 4654) (4655, 320, 4654) real score 0.7381550222635269 Hits@1 0.35135135135135137 Hits@3 0.7027027027027027 Hits@10 0.9864864864864865 MRR 0.5597134472134473 rank 2 total_num 73 865\n",
      "checkcorrect (3940, 50, 3887) (3940, 50, 3887) real score 0.9560856997966767 Hits@1 0.3466666666666667 Hits@3 0.7066666666666667 Hits@10 0.9866666666666667 MRR 0.5566950456950458 rank 2 total_num 74 865\n",
      "checkcorrect (4680, 142, 4187) (4680, 142, 4187) real score 0.9241028636693954 Hits@1 0.35526315789473684 Hits@3 0.7105263157894737 Hits@10 0.9868421052631579 MRR 0.562528005620111 rank 0 total_num 75 865\n",
      "checkcorrect (4357, 88, 5324) (4357, 88, 5324) real score 0.7879754975438118 Hits@1 0.35064935064935066 Hits@3 0.7012987012987013 Hits@10 0.987012987012987 MRR 0.5573869492700662 rank 5 total_num 76 865\n",
      "checkcorrect (3975, 2, 3722) (3975, 2, 3722) real score 0.9553214132785797 Hits@1 0.358974358974359 Hits@3 0.7051282051282052 Hits@10 0.9871794871794872 MRR 0.5630614755614756 rank 0 total_num 77 865\n",
      "checkcorrect (5624, 386, 5086) (5624, 386, 5086) real score 0.9051965028047562 Hits@1 0.3670886075949367 Hits@3 0.7088607594936709 Hits@10 0.9873417721518988 MRR 0.5685923429594316 rank 0 total_num 78 865\n",
      "checkcorrect (3968, 24, 4252) (3968, 24, 4252) real score 0.9389556318521499 Hits@1 0.3625 Hits@3 0.7125 Hits@10 0.9875 MRR 0.5677349386724387 rank 1 total_num 79 865\n",
      "checkcorrect (3904, 382, 4216) (3904, 382, 4216) real score 0.9788932144641876 Hits@1 0.37037037037037035 Hits@3 0.7160493827160493 Hits@10 0.9876543209876543 MRR 0.5730715443678407 rank 0 total_num 80 865\n",
      "checkcorrect (6062, 32, 3797) (6062, 32, 3797) real score 0.9771641194820404 Hits@1 0.36585365853658536 Hits@3 0.7195121951219512 Hits@10 0.9878048780487805 MRR 0.5701479076479077 rank 2 total_num 81 865\n",
      "checkcorrect (5876, 32, 4355) (5876, 32, 4355) real score 0.9788462132215501 Hits@1 0.3614457831325301 Hits@3 0.7228915662650602 Hits@10 0.9879518072289156 MRR 0.5693027521340775 rank 1 total_num 82 865\n",
      "checkcorrect (6153, 8, 3818) (6153, 8, 3818) real score 0.9710735946893692 Hits@1 0.36904761904761907 Hits@3 0.7261904761904762 Hits@10 0.9880952380952381 MRR 0.5744301003229575 rank 0 total_num 83 865\n",
      "checkcorrect (4517, 60, 3770) (4517, 60, 3770) real score 0.7401307359337806 Hits@1 0.36470588235294116 Hits@3 0.7294117647058823 Hits@10 0.9882352941176471 MRR 0.5735544520838639 rank 1 total_num 84 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4175, 54, 3674) (4175, 54, 3674) real score 0.9722801297903061 Hits@1 0.37209302325581395 Hits@3 0.7325581395348837 Hits@10 0.9883720930232558 MRR 0.5785131212456794 rank 0 total_num 85 865\n",
      "checkcorrect (5295, 54, 4441) (5295, 54, 4441) real score 0.9465280234813691 Hits@1 0.367816091954023 Hits@3 0.7241379310344828 Hits@10 0.9885057471264368 MRR 0.5747371083577981 rank 3 total_num 86 865\n",
      "checkcorrect (4364, 352, 6078) (4364, 352, 6078) real score 0.3398534804582596 Hits@1 0.36363636363636365 Hits@3 0.7159090909090909 Hits@10 0.9886363636363636 MRR 0.5700999442476715 rank 5 total_num 87 865\n",
      "checkcorrect (5198, 300, 5921) (5198, 300, 5921) real score 0.7068981669843197 Hits@1 0.3707865168539326 Hits@3 0.7191011235955056 Hits@10 0.9887640449438202 MRR 0.5749302819527539 rank 0 total_num 88 865\n",
      "checkcorrect (4004, 230, 5512) (4004, 230, 5512) real score 0.4976693123579025 Hits@1 0.37777777777777777 Hits@3 0.7222222222222222 Hits@10 0.9888888888888889 MRR 0.5796532788199455 rank 0 total_num 89 865\n",
      "checkcorrect (3951, 48, 3770) (3951, 48, 3770) real score 0.9504752516746521 Hits@1 0.38461538461538464 Hits@3 0.7252747252747253 Hits@10 0.989010989010989 MRR 0.5842724735581879 rank 0 total_num 90 865\n",
      "checkcorrect (3844, 114, 3843) (3844, 114, 3843) real score 0.8813256591558456 Hits@1 0.3804347826086957 Hits@3 0.717391304347826 Hits@10 0.9891304347826086 MRR 0.5794744808331765 rank 6 total_num 91 865\n",
      "checkcorrect (3749, 24, 4375) (3749, 24, 4375) real score 0.9014160245656968 Hits@1 0.3763440860215054 Hits@3 0.7096774193548387 Hits@10 0.989247311827957 MRR 0.5753941100715295 rank 4 total_num 92 865\n",
      "checkcorrect (3843, 134, 3769) (3843, 134, 3769) real score 0.89101502597332 Hits@1 0.3829787234042553 Hits@3 0.7127659574468085 Hits@10 0.9893617021276596 MRR 0.5799111940069388 rank 0 total_num 93 865\n",
      "checkcorrect (3963, 54, 4442) (3963, 54, 4442) real score 0.9793327510356904 Hits@1 0.3894736842105263 Hits@3 0.7157894736842105 Hits@10 0.9894736842105263 MRR 0.5843331814384447 rank 0 total_num 94 865\n",
      "checkcorrect (4097, 198, 5796) (4097, 198, 5796) real score 0.44576361775398254 Hits@1 0.3854166666666667 Hits@3 0.7083333333333334 Hits@10 0.9895833333333334 MRR 0.5797344727032229 rank 6 total_num 95 865\n",
      "checkcorrect (5838, 140, 5953) (5838, 140, 5953) real score 0.9237108439207078 Hits@1 0.3917525773195876 Hits@3 0.711340206185567 Hits@10 0.9896907216494846 MRR 0.5840671070052514 rank 0 total_num 96 865\n",
      "checkcorrect (3852, 134, 5143) (3852, 134, 5143) real score 0.8508445858955384 Hits@1 0.3877551020408163 Hits@3 0.7142857142857143 Hits@10 0.9897959183673469 MRR 0.5832092793827489 rank 1 total_num 97 865\n",
      "checkcorrect (3802, 44, 3669) (3802, 44, 3669) real score 0.8867152154445648 Hits@1 0.3838383838383838 Hits@3 0.7070707070707071 Hits@10 0.98989898989899 MRR 0.5793384785809029 rank 4 total_num 98 865\n",
      "checkcorrect (4230, 154, 4674) (4230, 154, 4674) real score 0.746371690183878 Hits@1 0.38 Hits@3 0.7 Hits@10 0.99 MRR 0.5760450937950939 rank 3 total_num 99 865\n",
      "checkcorrect (4318, 314, 5068) (4318, 314, 5068) real score 0.9809012711048126 Hits@1 0.38613861386138615 Hits@3 0.7029702970297029 Hits@10 0.9900990099009901 MRR 0.5802426671238554 rank 0 total_num 100 865\n",
      "checkcorrect (5563, 140, 5664) (5563, 140, 5664) real score 0.4338742524385452 Hits@1 0.38235294117647056 Hits@3 0.696078431372549 Hits@10 0.9901960784313726 MRR 0.5756433381433383 rank 8 total_num 101 865\n",
      "checkcorrect (5844, 40, 5370) (5844, 40, 5370) real score 0.9155651420354843 Hits@1 0.3786407766990291 Hits@3 0.6990291262135923 Hits@10 0.9902912621359223 MRR 0.5732908138247946 rank 2 total_num 102 865\n",
      "checkcorrect (4534, 28, 3907) (4534, 28, 3907) real score 0.8809064656496048 Hits@1 0.375 Hits@3 0.6923076923076923 Hits@10 0.9903846153846154 MRR 0.5689803252303254 rank 7 total_num 103 865\n",
      "checkcorrect (3875, 22, 5127) (3875, 22, 5127) real score 0.9754975467920304 Hits@1 0.38095238095238093 Hits@3 0.6952380952380952 Hits@10 0.9904761904761905 MRR 0.5730852745138462 rank 0 total_num 104 865\n",
      "checkcorrect (3974, 50, 4198) (3974, 50, 4198) real score 0.8456894487142563 Hits@1 0.37735849056603776 Hits@3 0.6886792452830188 Hits@10 0.9905660377358491 MRR 0.5692511367039671 rank 5 total_num 105 865\n",
      "checkcorrect (4614, 54, 4049) (4614, 54, 4049) real score 0.9403502345085144 Hits@1 0.38317757009345793 Hits@3 0.6915887850467289 Hits@10 0.9906542056074766 MRR 0.5732768270151449 rank 0 total_num 106 865\n",
      "checkcorrect (5117, 158, 3885) (5117, 158, 3885) real score 0.9714944779872894 Hits@1 0.3888888888888889 Hits@3 0.6944444444444444 Hits@10 0.9907407407407407 MRR 0.5772279675057455 rank 0 total_num 107 865\n",
      "checkcorrect (4359, 112, 4358) (4359, 112, 4358) real score 0.0 Hits@1 0.3853211009174312 Hits@3 0.6880733944954128 Hits@10 0.981651376146789 MRR 0.572331181206331 rank 22 total_num 108 865\n",
      "checkcorrect (4508, 32, 4118) (4508, 32, 4118) real score 0.9842495292425155 Hits@1 0.38181818181818183 Hits@3 0.6909090909090909 Hits@10 0.9818181818181818 MRR 0.5716736250135461 rank 1 total_num 109 865\n",
      "checkcorrect (3808, 112, 4134) (3808, 112, 4134) real score 0.9594837069511414 Hits@1 0.38738738738738737 Hits@3 0.6936936936936937 Hits@10 0.9819819819819819 MRR 0.5755324211845952 rank 0 total_num 110 865\n",
      "checkcorrect (3948, 10, 3808) (3948, 10, 3808) real score 0.9510539203882218 Hits@1 0.39285714285714285 Hits@3 0.6964285714285714 Hits@10 0.9821428571428571 MRR 0.5793223102811613 rank 0 total_num 111 865\n",
      "checkcorrect (4571, 88, 3735) (4571, 88, 3735) real score 0.6513639882206916 Hits@1 0.3893805309734513 Hits@3 0.6902654867256637 Hits@10 0.9823008849557522 MRR 0.575459786675639 rank 6 total_num 112 865\n",
      "checkcorrect (3845, 64, 4642) (3845, 64, 4642) real score 0.9172866463661193 Hits@1 0.38596491228070173 Hits@3 0.6929824561403509 Hits@10 0.9824561403508771 MRR 0.5733358704182503 rank 2 total_num 113 865\n",
      "checkcorrect (5967, 32, 4636) (5967, 32, 4636) real score 0.9827118605375289 Hits@1 0.391304347826087 Hits@3 0.6956521739130435 Hits@10 0.9826086956521739 MRR 0.5770459932841786 rank 0 total_num 114 865\n",
      "checkcorrect (5817, 400, 5841) (5817, 400, 5841) real score 0.09680648446083069 Hits@1 0.3879310344827586 Hits@3 0.6896551724137931 Hits@10 0.9827586206896551 MRR 0.5742266312731081 rank 3 total_num 115 865\n",
      "checkcorrect (4505, 88, 5795) (4505, 88, 5795) real score 0.8756503939628602 Hits@1 0.38461538461538464 Hits@3 0.6837606837606838 Hits@10 0.9829059829059829 MRR 0.5714554634844491 rank 3 total_num 116 865\n",
      "checkcorrect (5963, 88, 3892) (5963, 88, 3892) real score 0.9711621522903442 Hits@1 0.3898305084745763 Hits@3 0.6864406779661016 Hits@10 0.9830508474576272 MRR 0.5750871968447503 rank 0 total_num 117 865\n",
      "checkcorrect (4477, 112, 3956) (4477, 112, 3956) real score 0.9121157735586166 Hits@1 0.3949579831932773 Hits@3 0.6890756302521008 Hits@10 0.9831932773109243 MRR 0.5786578926695843 rank 0 total_num 118 865\n",
      "checkcorrect (4136, 54, 3871) (4136, 54, 3871) real score 0.9689964085817337 Hits@1 0.4 Hits@3 0.6916666666666667 Hits@10 0.9833333333333333 MRR 0.5821690768973379 rank 0 total_num 119 865\n",
      "checkcorrect (4146, 218, 4147) (4146, 218, 4147) real score 0.9247431725263595 Hits@1 0.4049586776859504 Hits@3 0.6942148760330579 Hits@10 0.9834710743801653 MRR 0.5856222250221532 rank 0 total_num 120 865\n",
      "checkcorrect (5496, 142, 4599) (5496, 142, 4599) real score 0.9246371924877166 Hits@1 0.4098360655737705 Hits@3 0.6967213114754098 Hits@10 0.9836065573770492 MRR 0.5890187641613159 rank 0 total_num 121 865\n",
      "checkcorrect (3757, 22, 4478) (3757, 22, 4478) real score 0.9674454063177109 Hits@1 0.4065040650406504 Hits@3 0.6991869918699187 Hits@10 0.983739837398374 MRR 0.5882950343713865 rank 1 total_num 122 865\n",
      "checkcorrect (5139, 96, 3727) (5139, 96, 3727) real score 0.9770044356584549 Hits@1 0.4112903225806452 Hits@3 0.7016129032258065 Hits@10 0.9838709677419355 MRR 0.5916152357071012 rank 0 total_num 123 865\n",
      "checkcorrect (4009, 36, 3765) (4009, 36, 3765) real score 0.945309254527092 Hits@1 0.408 Hits@3 0.704 Hits@10 0.984 MRR 0.5908823138214443 rank 1 total_num 124 865\n",
      "checkcorrect (4328, 290, 4668) (4328, 290, 4668) real score 0.913464167714119 Hits@1 0.4126984126984127 Hits@3 0.7063492063492064 Hits@10 0.9841269841269841 MRR 0.5941292795847661 rank 0 total_num 125 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4234, 32, 3700) (4234, 32, 3700) real score 0.9819239020347594 Hits@1 0.4094488188976378 Hits@3 0.7007874015748031 Hits@10 0.984251968503937 MRR 0.590575955673525 rank 6 total_num 126 865\n",
      "checkcorrect (4390, 54, 5065) (4390, 54, 5065) real score 0.9029180735349656 Hits@1 0.40625 Hits@3 0.703125 Hits@10 0.984375 MRR 0.5898683310198256 rank 1 total_num 127 865\n",
      "checkcorrect (4409, 32, 4355) (4409, 32, 4355) real score 0.9255763977766037 Hits@1 0.40310077519379844 Hits@3 0.6976744186046512 Hits@10 0.9844961240310077 MRR 0.5872336927948657 rank 3 total_num 128 865\n",
      "checkcorrect (5575, 0, 3904) (5575, 0, 3904) real score 0.9317592263221741 Hits@1 0.4076923076923077 Hits@3 0.7 Hits@10 0.9846153846153847 MRR 0.5904088182349052 rank 0 total_num 129 865\n",
      "checkcorrect (4080, 64, 4386) (4080, 64, 4386) real score 0.949147391319275 Hits@1 0.4122137404580153 Hits@3 0.7022900763358778 Hits@10 0.9847328244274809 MRR 0.5935354684773868 rank 0 total_num 130 865\n",
      "checkcorrect (4482, 64, 4098) (4482, 64, 4098) real score 0.9139232933521271 Hits@1 0.4090909090909091 Hits@3 0.696969696969697 Hits@10 0.9848484848484849 MRR 0.59055413917074 rank 4 total_num 131 865\n",
      "checkcorrect (4234, 212, 3905) (4234, 212, 3905) real score 0.8817143470048905 Hits@1 0.40601503759398494 Hits@3 0.6917293233082706 Hits@10 0.9849624060150376 MRR 0.587993581733366 rank 3 total_num 132 865\n",
      "checkcorrect (4657, 292, 4682) (4657, 292, 4682) real score 0.937494882941246 Hits@1 0.41044776119402987 Hits@3 0.6940298507462687 Hits@10 0.9850746268656716 MRR 0.5910682564965498 rank 0 total_num 133 865\n",
      "checkcorrect (4197, 54, 4346) (4197, 54, 4346) real score 0.9183080285787583 Hits@1 0.4074074074074074 Hits@3 0.6962962962962963 Hits@10 0.9851851851851852 MRR 0.5891591089175631 rank 2 total_num 134 865\n",
      "checkcorrect (4158, 96, 3727) (4158, 96, 3727) real score 0.9234255343675613 Hits@1 0.40441176470588236 Hits@3 0.6985294117647058 Hits@10 0.9852941176470589 MRR 0.5872780370382672 rank 2 total_num 135 865\n",
      "checkcorrect (3880, 24, 5738) (3880, 24, 5738) real score 0.9109654605388642 Hits@1 0.40145985401459855 Hits@3 0.6934306569343066 Hits@10 0.9854014598540146 MRR 0.5842078810501533 rank 5 total_num 136 865\n",
      "checkcorrect (5235, 78, 3886) (5235, 78, 3886) real score 0.7032146334648133 Hits@1 0.39855072463768115 Hits@3 0.6884057971014492 Hits@10 0.9855072463768116 MRR 0.5817860848106595 rank 3 total_num 137 865\n",
      "checkcorrect (5527, 78, 5882) (5527, 78, 5882) real score 0.955684757232666 Hits@1 0.39568345323741005 Hits@3 0.6906474820143885 Hits@10 0.9856115107913669 MRR 0.5811976957113022 rank 1 total_num 138 865\n",
      "checkcorrect (4000, 22, 3908) (4000, 22, 3908) real score 0.977702659368515 Hits@1 0.4 Hits@3 0.6928571428571428 Hits@10 0.9857142857142858 MRR 0.5841891407419357 rank 0 total_num 139 865\n",
      "checkcorrect (4144, 50, 4329) (4144, 50, 4329) real score 0.9686892569065094 Hits@1 0.3971631205673759 Hits@3 0.6950354609929078 Hits@10 0.9858156028368794 MRR 0.5835920546373831 rank 1 total_num 140 865\n",
      "checkcorrect (4055, 40, 4583) (4055, 40, 4583) real score 0.9842912912368774 Hits@1 0.4014084507042254 Hits@3 0.6971830985915493 Hits@10 0.9859154929577465 MRR 0.586524504956838 rank 0 total_num 141 865\n",
      "checkcorrect (4219, 24, 4352) (4219, 24, 4352) real score 0.8313010692596436 Hits@1 0.3986013986013986 Hits@3 0.6923076923076923 Hits@10 0.986013986013986 MRR 0.5834219359911059 rank 6 total_num 142 865\n",
      "checkcorrect (5429, 32, 4636) (5429, 32, 4636) real score 0.980229166150093 Hits@1 0.3958333333333333 Hits@3 0.6875 Hits@10 0.9861111111111112 MRR 0.5807592836578344 rank 4 total_num 143 865\n",
      "checkcorrect (4017, 298, 4067) (4017, 298, 4067) real score 0.9562730967998505 Hits@1 0.4 Hits@3 0.6896551724137931 Hits@10 0.9862068965517241 MRR 0.5836505989429528 rank 0 total_num 144 865\n",
      "checkcorrect (4553, 40, 4583) (4553, 40, 4583) real score 0.9296769291162491 Hits@1 0.3972602739726027 Hits@3 0.6917808219178082 Hits@10 0.9863013698630136 MRR 0.5819360971237088 rank 2 total_num 145 865\n",
      "checkcorrect (4926, 96, 3727) (4926, 96, 3727) real score 0.9384351700544358 Hits@1 0.3945578231292517 Hits@3 0.6938775510204082 Hits@10 0.9863945578231292 MRR 0.5802449218598287 rank 2 total_num 146 865\n",
      "checkcorrect (4564, 146, 3770) (4564, 146, 3770) real score 0.9187913507223129 Hits@1 0.3918918918918919 Hits@3 0.6959459459459459 Hits@10 0.9864864864864865 MRR 0.5785766003157307 rank 2 total_num 147 865\n",
      "checkcorrect (5844, 54, 4235) (5844, 54, 4235) real score 0.6038624942302704 Hits@1 0.38926174496644295 Hits@3 0.6912751677852349 Hits@10 0.9798657718120806 MRR 0.5753036640109881 rank 10 total_num 148 865\n",
      "checkcorrect (4610, 96, 3727) (4610, 96, 3727) real score 0.9564976662397384 Hits@1 0.3933333333333333 Hits@3 0.6933333333333334 Hits@10 0.98 MRR 0.5781349729175815 rank 0 total_num 149 865\n",
      "checkcorrect (3746, 78, 5476) (3746, 78, 5476) real score 0.9598701268434524 Hits@1 0.39072847682119205 Hits@3 0.695364238410596 Hits@10 0.9801324503311258 MRR 0.5776175227658095 rank 1 total_num 150 865\n",
      "checkcorrect (4908, 146, 6053) (4908, 146, 6053) real score 0.8768814682960511 Hits@1 0.3881578947368421 Hits@3 0.6907894736842105 Hits@10 0.9802631578947368 MRR 0.5747572571085156 rank 6 total_num 151 865\n",
      "checkcorrect (4158, 54, 4525) (4158, 54, 4525) real score 0.9682200789451599 Hits@1 0.38562091503267976 Hits@3 0.6928104575163399 Hits@10 0.9803921568627451 MRR 0.5742686475849306 rank 1 total_num 152 865\n",
      "checkcorrect (4588, 28, 4587) (4588, 28, 4587) real score 0.926602128148079 Hits@1 0.38961038961038963 Hits@3 0.6948051948051948 Hits@10 0.9805194805194806 MRR 0.5770331368863271 rank 0 total_num 153 865\n",
      "checkcorrect (4097, 328, 4054) (4097, 328, 4054) real score 0.9878805100917816 Hits@1 0.3935483870967742 Hits@3 0.6967741935483871 Hits@10 0.9806451612903225 MRR 0.5797619553580282 rank 0 total_num 154 865\n",
      "checkcorrect (4267, 18, 4075) (4267, 18, 4075) real score 0.9195477604866028 Hits@1 0.391025641025641 Hits@3 0.6987179487179487 Hits@10 0.9807692307692307 MRR 0.5781822847040237 rank 2 total_num 155 865\n",
      "checkcorrect (4761, 54, 4522) (4761, 54, 4522) real score 0.9568080872297287 Hits@1 0.3885350318471338 Hits@3 0.7006369426751592 Hits@10 0.9808917197452229 MRR 0.5766227372430639 rank 2 total_num 156 865\n",
      "checkcorrect (5398, 220, 5750) (5398, 220, 5750) real score 0.9559462457895278 Hits@1 0.3924050632911392 Hits@3 0.7025316455696202 Hits@10 0.9810126582278481 MRR 0.5793023401719052 rank 0 total_num 157 865\n",
      "checkcorrect (4774, 50, 4023) (4774, 50, 4023) real score 0.9672562807798386 Hits@1 0.39622641509433965 Hits@3 0.7044025157232704 Hits@10 0.9811320754716981 MRR 0.5819482374035284 rank 0 total_num 158 865\n",
      "checkcorrect (4442, 54, 3707) (4442, 54, 3707) real score 0.9665369510650634 Hits@1 0.39375 Hits@3 0.70625 Hits@10 0.98125 MRR 0.5803943942530897 rank 2 total_num 159 865\n",
      "checkcorrect (5243, 24, 5459) (5243, 24, 5459) real score 0.9291973084211349 Hits@1 0.391304347826087 Hits@3 0.7080745341614907 Hits@10 0.9813664596273292 MRR 0.5798950501894059 rank 1 total_num 160 865\n",
      "checkcorrect (4037, 70, 5085) (4037, 70, 5085) real score 0.9628989428281785 Hits@1 0.3950617283950617 Hits@3 0.7098765432098766 Hits@10 0.9814814814814815 MRR 0.5824882906203355 rank 0 total_num 161 865\n",
      "checkcorrect (5153, 24, 4059) (5153, 24, 4059) real score 0.938620388507843 Hits@1 0.39263803680981596 Hits@3 0.7116564417177914 Hits@10 0.9815950920245399 MRR 0.5819822274876955 rank 1 total_num 162 865\n",
      "checkcorrect (6128, 64, 5179) (6128, 64, 5179) real score 0.6753604456782341 Hits@1 0.3902439024390244 Hits@3 0.7073170731707317 Hits@10 0.9817073170731707 MRR 0.579043311466429 rank 9 total_num 163 865\n",
      "checkcorrect (4171, 188, 4324) (4171, 188, 4324) real score 0.9714504837989807 Hits@1 0.3878787878787879 Hits@3 0.7090909090909091 Hits@10 0.9818181818181818 MRR 0.5785642610939051 rank 1 total_num 164 865\n",
      "checkcorrect (5267, 50, 4060) (5267, 50, 4060) real score 0.28059102296829225 Hits@1 0.3855421686746988 Hits@3 0.7048192771084337 Hits@10 0.9759036144578314 MRR 0.5753527567828247 rank 21 total_num 165 865\n",
      "checkcorrect (4353, 22, 4717) (4353, 22, 4717) real score 0.9757032334804535 Hits@1 0.38922155688622756 Hits@3 0.7065868263473054 Hits@10 0.9760479041916168 MRR 0.5778955546464005 rank 0 total_num 166 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4609, 298, 4509) (4609, 298, 4509) real score 0.9568120688199997 Hits@1 0.39285714285714285 Hits@3 0.7083333333333334 Hits@10 0.9761904761904762 MRR 0.5804080811068386 rank 0 total_num 167 865\n",
      "checkcorrect (5750, 130, 6144) (5750, 130, 6144) real score 0.38222226202487947 Hits@1 0.3905325443786982 Hits@3 0.7041420118343196 Hits@10 0.9704142011834319 MRR 0.5774288798986508 rank 12 total_num 168 865\n",
      "checkcorrect (4148, 382, 3762) (4148, 382, 3762) real score 0.9732595026493073 Hits@1 0.38823529411764707 Hits@3 0.7058823529411765 Hits@10 0.9705882352941176 MRR 0.5769734158992469 rank 1 total_num 169 865\n",
      "checkcorrect (5930, 32, 4118) (5930, 32, 4118) real score 0.9814521312713623 Hits@1 0.38596491228070173 Hits@3 0.7076023391812866 Hits@10 0.9707602339181286 MRR 0.5765232789641636 rank 1 total_num 170 865\n",
      "checkcorrect (4909, 96, 3727) (4909, 96, 3727) real score 0.918452912569046 Hits@1 0.38372093023255816 Hits@3 0.7034883720930233 Hits@10 0.9709302325581395 MRR 0.5743341901329766 rank 4 total_num 171 865\n",
      "checkcorrect (5510, 356, 5710) (5510, 356, 5710) real score 0.44393864721059795 Hits@1 0.3815028901734104 Hits@3 0.7052023121387283 Hits@10 0.9710982658959537 MRR 0.5739045127333641 rank 1 total_num 172 865\n",
      "checkcorrect (4737, 56, 4163) (4737, 56, 4163) real score 0.8409905791282655 Hits@1 0.3793103448275862 Hits@3 0.7068965517241379 Hits@10 0.9712643678160919 MRR 0.5725219197483064 rank 2 total_num 173 865\n",
      "checkcorrect (3844, 12, 3687) (3844, 12, 3687) real score 0.9782553225755692 Hits@1 0.37714285714285717 Hits@3 0.7085714285714285 Hits@10 0.9714285714285714 MRR 0.5721075087783161 rank 1 total_num 174 865\n",
      "checkcorrect (4316, 298, 4285) (4316, 298, 4285) real score 0.9562723755836486 Hits@1 0.3806818181818182 Hits@3 0.7102272727272727 Hits@10 0.9715909090909091 MRR 0.5745387161148029 rank 0 total_num 175 865\n",
      "checkcorrect (3969, 70, 3857) (3969, 70, 3857) real score 0.9793329209089279 Hits@1 0.384180790960452 Hits@3 0.711864406779661 Hits@10 0.9717514124293786 MRR 0.5769424521819508 rank 0 total_num 176 865\n",
      "checkcorrect (5233, 140, 4694) (5233, 140, 4694) real score 0.899841696023941 Hits@1 0.38202247191011235 Hits@3 0.7134831460674157 Hits@10 0.9719101123595506 MRR 0.5755738616266215 rank 2 total_num 177 865\n",
      "checkcorrect (4979, 0, 3808) (4979, 0, 3808) real score 0.8366243079304695 Hits@1 0.37988826815642457 Hits@3 0.7150837988826816 Hits@10 0.9720670391061452 MRR 0.574220562585877 rank 2 total_num 178 865\n",
      "checkcorrect (4509, 160, 4300) (4509, 160, 4300) real score 0.9754811465740204 Hits@1 0.38333333333333336 Hits@3 0.7166666666666667 Hits@10 0.9722222222222222 MRR 0.5765860039048443 rank 0 total_num 179 865\n",
      "checkcorrect (4313, 22, 5561) (4313, 22, 5561) real score 0.952432268857956 Hits@1 0.3812154696132597 Hits@3 0.712707182320442 Hits@10 0.9723756906077348 MRR 0.5745054182479115 rank 4 total_num 180 865\n",
      "checkcorrect (4726, 218, 4727) (4726, 218, 4727) real score 0.0 Hits@1 0.3791208791208791 Hits@3 0.7087912087912088 Hits@10 0.967032967032967 MRR 0.5715382607774322 rank 28 total_num 181 865\n",
      "checkcorrect (4313, 22, 4478) (4313, 22, 4478) real score 0.9606336772441864 Hits@1 0.3770491803278688 Hits@3 0.7049180327868853 Hits@10 0.9672131147540983 MRR 0.5697812211010528 rank 3 total_num 182 865\n",
      "checkcorrect (4493, 96, 3727) (4493, 96, 3727) real score 0.9585670799016952 Hits@1 0.3804347826086957 Hits@3 0.7065217391304348 Hits@10 0.967391304347826 MRR 0.572119366638547 rank 0 total_num 183 865\n",
      "checkcorrect (5475, 32, 4214) (5475, 32, 4214) real score 0.979273146390915 Hits@1 0.3783783783783784 Hits@3 0.7081081081081081 Hits@10 0.9675675675675676 MRR 0.5708286313233837 rank 2 total_num 184 865\n",
      "checkcorrect (3998, 54, 4738) (3998, 54, 4738) real score 0.9636340588331223 Hits@1 0.3817204301075269 Hits@3 0.7096774193548387 Hits@10 0.967741935483871 MRR 0.573136004273258 rank 0 total_num 185 865\n",
      "checkcorrect (4857, 402, 5986) (4857, 402, 5986) real score 0.8131305336952209 Hits@1 0.3850267379679144 Hits@3 0.7112299465240641 Hits@10 0.9679144385026738 MRR 0.5754186994375721 rank 0 total_num 186 865\n",
      "checkcorrect (5163, 32, 4118) (5163, 32, 4118) real score 0.9827226251363754 Hits@1 0.3829787234042553 Hits@3 0.7127659574468085 Hits@10 0.9680851063829787 MRR 0.5750175361426914 rank 1 total_num 187 865\n",
      "checkcorrect (4732, 198, 4823) (4732, 198, 4823) real score 0.7681060254573822 Hits@1 0.38095238095238093 Hits@3 0.708994708994709 Hits@10 0.9682539682539683 MRR 0.5730333163747406 rank 4 total_num 188 865\n",
      "checkcorrect (5188, 12, 3687) (5188, 12, 3687) real score 0.9758156388998032 Hits@1 0.37894736842105264 Hits@3 0.7105263157894737 Hits@10 0.968421052631579 MRR 0.5717717375166279 rank 2 total_num 189 865\n",
      "checkcorrect (5113, 312, 3770) (5113, 312, 3770) real score 0.8772716581821443 Hits@1 0.3769633507853403 Hits@3 0.7068062827225131 Hits@10 0.9685863874345549 MRR 0.5696507685592983 rank 5 total_num 190 865\n",
      "checkcorrect (4285, 160, 5141) (4285, 160, 5141) real score 0.9754771441221237 Hits@1 0.3802083333333333 Hits@3 0.7083333333333334 Hits@10 0.96875 MRR 0.5718921708063853 rank 0 total_num 191 865\n",
      "checkcorrect (4523, 210, 5822) (4523, 210, 5822) real score 0.9687491536140442 Hits@1 0.38341968911917096 Hits@3 0.7098445595854922 Hits@10 0.9689119170984456 MRR 0.5741103460871813 rank 0 total_num 192 865\n",
      "checkcorrect (4758, 40, 4621) (4758, 40, 4621) real score 0.9625716894865035 Hits@1 0.3865979381443299 Hits@3 0.711340206185567 Hits@10 0.9690721649484536 MRR 0.5763056535815773 rank 0 total_num 193 865\n",
      "checkcorrect (3811, 320, 4564) (3811, 320, 4564) real score 0.5035594686865806 Hits@1 0.38461538461538464 Hits@3 0.7076923076923077 Hits@10 0.9692307692307692 MRR 0.5739912656144922 rank 7 total_num 194 865\n",
      "checkcorrect (3837, 50, 4144) (3837, 50, 4144) real score 0.9660756886005402 Hits@1 0.3877551020408163 Hits@3 0.7091836734693877 Hits@10 0.9693877551020408 MRR 0.5761647795654387 rank 0 total_num 195 865\n",
      "checkcorrect (3715, 48, 4110) (3715, 48, 4110) real score 0.8359791219234467 Hits@1 0.38578680203045684 Hits@3 0.7055837563451777 Hits@10 0.9644670050761421 MRR 0.5736305577246146 rank 12 total_num 196 865\n",
      "checkcorrect (5849, 96, 3727) (5849, 96, 3727) real score 0.9724437087774277 Hits@1 0.3888888888888889 Hits@3 0.7070707070707071 Hits@10 0.9646464646464646 MRR 0.5757839387462074 rank 0 total_num 197 865\n",
      "checkcorrect (5131, 96, 3727) (5131, 96, 3727) real score 0.9166622757911682 Hits@1 0.3869346733668342 Hits@3 0.7085427135678392 Hits@10 0.964824120603015 MRR 0.5754031149334123 rank 1 total_num 198 865\n",
      "checkcorrect (4033, 64, 3759) (4033, 64, 3759) real score 0.560913336649537 Hits@1 0.385 Hits@3 0.705 Hits@10 0.965 MRR 0.5733594326920787 rank 5 total_num 199 865\n",
      "checkcorrect (3710, 96, 3993) (3710, 96, 3993) real score 0.9160367280244828 Hits@1 0.38308457711442784 Hits@3 0.7014925373134329 Hits@10 0.9651741293532339 MRR 0.5715019230766952 rank 4 total_num 200 865\n",
      "checkcorrect (4524, 40, 4056) (4524, 40, 4056) real score 0.963308972120285 Hits@1 0.3811881188118812 Hits@3 0.7029702970297029 Hits@10 0.9653465346534653 MRR 0.571147953160474 rank 1 total_num 201 865\n",
      "checkcorrect (4063, 22, 5496) (4063, 22, 5496) real score 0.9727859884500504 Hits@1 0.3793103448275862 Hits@3 0.7044334975369458 Hits@10 0.9655172413793104 MRR 0.5707974706325898 rank 1 total_num 202 865\n",
      "checkcorrect (5626, 14, 4531) (5626, 14, 4531) real score 0.9517667829990386 Hits@1 0.38235294117647056 Hits@3 0.7058823529411765 Hits@10 0.9656862745098039 MRR 0.5729014046000771 rank 0 total_num 203 865\n",
      "checkcorrect (3868, 164, 3982) (3868, 164, 3982) real score 0.8020699769258499 Hits@1 0.3804878048780488 Hits@3 0.7073170731707317 Hits@10 0.9658536585365853 MRR 0.5717327798621905 rank 2 total_num 204 865\n",
      "checkcorrect (4996, 32, 4118) (4996, 32, 4118) real score 0.9755542546510696 Hits@1 0.3786407766990291 Hits@3 0.7038834951456311 Hits@10 0.9660194174757282 MRR 0.5699282518046072 rank 4 total_num 205 865\n",
      "checkcorrect (5086, 172, 3782) (5086, 172, 3782) real score 0.9927172988653183 Hits@1 0.38164251207729466 Hits@3 0.7053140096618358 Hits@10 0.966183574879227 MRR 0.5720058931002371 rank 0 total_num 206 865\n",
      "checkcorrect (5069, 142, 3880) (5069, 142, 3880) real score 0.8399470567703247 Hits@1 0.3798076923076923 Hits@3 0.7067307692307693 Hits@10 0.9663461538461539 MRR 0.5716597109218705 rank 1 total_num 207 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5849, 56, 4194) (5849, 56, 4194) real score 0.7340659826993943 Hits@1 0.37799043062200954 Hits@3 0.7033492822966507 Hits@10 0.9665071770334929 MRR 0.5701206692428185 rank 3 total_num 208 865\n",
      "checkcorrect (5061, 94, 3808) (5061, 94, 3808) real score 0.9931437790393829 Hits@1 0.3761904761904762 Hits@3 0.7047619047619048 Hits@10 0.9666666666666667 MRR 0.5697867612940432 rank 1 total_num 209 865\n",
      "checkcorrect (3952, 50, 3726) (3952, 50, 3726) real score 0.9217156231403351 Hits@1 0.3744075829383886 Hits@3 0.7014218009478673 Hits@10 0.966824644549763 MRR 0.567876239518558 rank 5 total_num 210 865\n",
      "checkcorrect (4573, 96, 3727) (4573, 96, 3727) real score 0.940683376789093 Hits@1 0.37735849056603776 Hits@3 0.7028301886792453 Hits@10 0.9669811320754716 MRR 0.5699145591434704 rank 0 total_num 211 865\n",
      "checkcorrect (3696, 218, 5009) (3696, 218, 5009) real score 0.3715605974197388 Hits@1 0.3755868544600939 Hits@3 0.6995305164319249 Hits@10 0.9624413145539906 MRR 0.5675323311662711 rank 15 total_num 212 865\n",
      "checkcorrect (4050, 50, 4332) (4050, 50, 4332) real score 0.9666229426860808 Hits@1 0.37850467289719625 Hits@3 0.7009345794392523 Hits@10 0.9626168224299065 MRR 0.569553208123438 rank 0 total_num 213 865\n",
      "checkcorrect (4037, 22, 4123) (4037, 22, 4123) real score 0.9642141789197922 Hits@1 0.3767441860465116 Hits@3 0.7023255813953488 Hits@10 0.9627906976744186 MRR 0.5692297048298407 rank 1 total_num 214 865\n",
      "checkcorrect (5756, 36, 3915) (5756, 36, 3915) real score 0.9435308754444123 Hits@1 0.375 Hits@3 0.7037037037037037 Hits@10 0.9629629629629629 MRR 0.5681375919988383 rank 2 total_num 215 865\n",
      "checkcorrect (5619, 50, 5171) (5619, 50, 5171) real score 0.765623715519905 Hits@1 0.37327188940092165 Hits@3 0.7004608294930875 Hits@10 0.9631336405529954 MRR 0.5661777742608581 rank 6 total_num 216 865\n",
      "checkcorrect (3922, 54, 6116) (3922, 54, 6116) real score 0.6492064088582993 Hits@1 0.37155963302752293 Hits@3 0.6972477064220184 Hits@10 0.9587155963302753 MRR 0.56399764268585 rank 10 total_num 217 865\n",
      "checkcorrect (3788, 40, 4037) (3788, 40, 4037) real score 0.9538018614053726 Hits@1 0.3744292237442922 Hits@3 0.6986301369863014 Hits@10 0.958904109589041 MRR 0.5659885210297503 rank 0 total_num 218 865\n",
      "checkcorrect (5190, 40, 3765) (5190, 40, 3765) real score 0.9747218519449234 Hits@1 0.37727272727272726 Hits@3 0.7 Hits@10 0.9590909090909091 MRR 0.567961300479615 rank 0 total_num 219 865\n",
      "checkcorrect (3840, 382, 4088) (3840, 382, 4088) real score 0.9488018542528152 Hits@1 0.38009049773755654 Hits@3 0.7013574660633484 Hits@10 0.9592760180995475 MRR 0.5699162267217887 rank 0 total_num 220 865\n",
      "checkcorrect (4573, 54, 4493) (4573, 54, 4493) real score 0.8352866858243942 Hits@1 0.3783783783783784 Hits@3 0.6981981981981982 Hits@10 0.9594594594594594 MRR 0.5679120995743933 rank 7 total_num 221 865\n",
      "checkcorrect (3790, 54, 5452) (3790, 54, 5452) real score 0.9745231002569199 Hits@1 0.37668161434977576 Hits@3 0.6995515695067265 Hits@10 0.9596412556053812 MRR 0.5668601768558235 rank 2 total_num 222 865\n",
      "checkcorrect (4451, 0, 4094) (4451, 0, 4094) real score 0.9666029274463654 Hits@1 0.375 Hits@3 0.7008928571428571 Hits@10 0.9598214285714286 MRR 0.5665616939234314 rank 1 total_num 223 865\n",
      "checkcorrect (5981, 342, 4003) (5981, 342, 4003) real score 0.957563829421997 Hits@1 0.37777777777777777 Hits@3 0.7022222222222222 Hits@10 0.96 MRR 0.5684880863948828 rank 0 total_num 224 865\n",
      "checkcorrect (5240, 12, 3687) (5240, 12, 3687) real score 0.9768516719341278 Hits@1 0.37610619469026546 Hits@3 0.7035398230088495 Hits@10 0.9601769911504425 MRR 0.5681850417648169 rank 1 total_num 225 865\n",
      "checkcorrect (6009, 190, 4224) (6009, 190, 4224) real score 0.7460695624351501 Hits@1 0.3744493392070485 Hits@3 0.7004405286343612 Hits@10 0.960352422907489 MRR 0.5664162383502875 rank 5 total_num 226 865\n",
      "checkcorrect (3911, 20, 4523) (3911, 20, 4523) real score 0.9751977443695068 Hits@1 0.37719298245614036 Hits@3 0.7017543859649122 Hits@10 0.9605263157894737 MRR 0.5683179215154178 rank 0 total_num 227 865\n",
      "checkcorrect (4547, 268, 4523) (4547, 268, 4523) real score 0.9463018476963043 Hits@1 0.3799126637554585 Hits@3 0.7030567685589519 Hits@10 0.9606986899563319 MRR 0.5702029960939532 rank 0 total_num 228 865\n",
      "checkcorrect (4188, 78, 3791) (4188, 78, 3791) real score 0.9561857759952546 Hits@1 0.3782608695652174 Hits@3 0.7043478260869566 Hits@10 0.9608695652173913 MRR 0.5698977656761534 rank 1 total_num 229 865\n",
      "checkcorrect (3861, 320, 4385) (3861, 320, 4385) real score 0.6086683958768844 Hits@1 0.37662337662337664 Hits@3 0.7056277056277056 Hits@10 0.961038961038961 MRR 0.5695951779459536 rank 1 total_num 230 865\n",
      "checkcorrect (4078, 48, 5328) (4078, 48, 5328) real score 0.8949191242456436 Hits@1 0.375 Hits@3 0.7025862068965517 Hits@10 0.9612068965517241 MRR 0.5677557898636741 rank 6 total_num 231 865\n",
      "checkcorrect (5294, 360, 4961) (5294, 360, 4961) real score 0.7566035568714142 Hits@1 0.37339055793991416 Hits@3 0.703862660944206 Hits@10 0.9613733905579399 MRR 0.567464992482285 rank 1 total_num 232 865\n",
      "checkcorrect (4464, 24, 4686) (4464, 24, 4686) real score 0.9568455338478088 Hits@1 0.37606837606837606 Hits@3 0.7051282051282052 Hits@10 0.9615384615384616 MRR 0.5693134326853522 rank 0 total_num 233 865\n",
      "checkcorrect (4338, 2, 5079) (4338, 2, 5079) real score 0.958335092663765 Hits@1 0.37872340425531914 Hits@3 0.7063829787234043 Hits@10 0.9617021276595744 MRR 0.5711461414824358 rank 0 total_num 234 865\n",
      "checkcorrect (5619, 54, 4103) (5619, 54, 4103) real score 0.8702993988990784 Hits@1 0.3771186440677966 Hits@3 0.7033898305084746 Hits@10 0.961864406779661 MRR 0.5694322454027079 rank 5 total_num 235 865\n",
      "checkcorrect (4313, 70, 4513) (4313, 70, 4513) real score 0.9768723249435425 Hits@1 0.379746835443038 Hits@3 0.7046413502109705 Hits@10 0.9620253164556962 MRR 0.5712489869832872 rank 0 total_num 236 865\n",
      "checkcorrect (5269, 56, 4257) (5269, 56, 4257) real score 0.8893442839384079 Hits@1 0.37815126050420167 Hits@3 0.7058823529411765 Hits@10 0.9621848739495799 MRR 0.5709496214917608 rank 1 total_num 237 865\n",
      "checkcorrect (4313, 70, 3857) (4313, 70, 3857) real score 0.9762542843818665 Hits@1 0.3807531380753138 Hits@3 0.7071129707112971 Hits@10 0.9623430962343096 MRR 0.5727448113599961 rank 0 total_num 238 865\n",
      "checkcorrect (4520, 198, 5645) (4520, 198, 5645) real score 0.8611247301101685 Hits@1 0.37916666666666665 Hits@3 0.7083333333333334 Hits@10 0.9625 MRR 0.571747263534885 rank 2 total_num 239 865\n",
      "checkcorrect (5277, 48, 5337) (5277, 48, 5337) real score 0.9509948581457138 Hits@1 0.3775933609958506 Hits@3 0.7095435684647303 Hits@10 0.9626556016597511 MRR 0.5714495570471885 rank 1 total_num 240 865\n",
      "checkcorrect (3808, 382, 3863) (3808, 382, 3863) real score 0.9748768329620361 Hits@1 0.38016528925619836 Hits@3 0.7107438016528925 Hits@10 0.9628099173553719 MRR 0.573220426646167 rank 0 total_num 241 865\n",
      "checkcorrect (3964, 48, 3770) (3964, 48, 3770) real score 0.9316104531288147 Hits@1 0.3786008230452675 Hits@3 0.7078189300411523 Hits@10 0.9629629629629629 MRR 0.5718903014336313 rank 3 total_num 242 865\n",
      "checkcorrect (4076, 70, 3979) (4076, 70, 3979) real score 0.9435129284858703 Hits@1 0.3770491803278688 Hits@3 0.7090163934426229 Hits@10 0.9631147540983607 MRR 0.570912608941417 rank 2 total_num 243 865\n",
      "checkcorrect (5860, 64, 5055) (5860, 64, 5055) real score 0.9247662812471389 Hits@1 0.37551020408163266 Hits@3 0.710204081632653 Hits@10 0.963265306122449 MRR 0.5706231697212479 rank 1 total_num 244 865\n",
      "checkcorrect (4291, 50, 4290) (4291, 50, 4290) real score 0.8562890201807023 Hits@1 0.37398373983739835 Hits@3 0.7073170731707317 Hits@10 0.9634146341463414 MRR 0.568981070115335 rank 5 total_num 245 865\n",
      "checkcorrect (4902, 40, 4000) (4902, 40, 4000) real score 0.9176869601011276 Hits@1 0.3724696356275304 Hits@3 0.7044534412955465 Hits@10 0.9635627530364372 MRR 0.567487219629038 rank 4 total_num 246 865\n",
      "checkcorrect (3925, 64, 4433) (3925, 64, 4433) real score 0.9288437902927399 Hits@1 0.3709677419354839 Hits@3 0.7016129032258065 Hits@10 0.9637096774193549 MRR 0.566207029227308 rank 3 total_num 247 865\n",
      "checkcorrect (4885, 56, 5232) (4885, 56, 5232) real score 0.8647251337766647 Hits@1 0.37349397590361444 Hits@3 0.7028112449799196 Hits@10 0.963855421686747 MRR 0.5679491696721783 rank 0 total_num 248 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4776, 68, 4925) (4776, 68, 4925) real score 0.9786686331033707 Hits@1 0.376 Hits@3 0.704 Hits@10 0.964 MRR 0.5696773729934896 rank 0 total_num 249 865\n",
      "checkcorrect (4039, 18, 3911) (4039, 18, 3911) real score 0.9808944970369339 Hits@1 0.3784860557768924 Hits@3 0.7051792828685259 Hits@10 0.9641434262948207 MRR 0.5713918057704079 rank 0 total_num 250 865\n",
      "checkcorrect (4029, 0, 3770) (4029, 0, 3770) real score 0.542476324364543 Hits@1 0.38095238095238093 Hits@3 0.7063492063492064 Hits@10 0.9642857142857143 MRR 0.5730926319379858 rank 0 total_num 251 865\n",
      "checkcorrect (4172, 58, 3943) (4172, 58, 3943) real score 0.9131658494472503 Hits@1 0.383399209486166 Hits@3 0.7075098814229249 Hits@10 0.9644268774703557 MRR 0.5747800128394166 rank 0 total_num 252 865\n",
      "checkcorrect (4000, 22, 4387) (4000, 22, 4387) real score 0.9752354234457016 Hits@1 0.38188976377952755 Hits@3 0.7086614173228346 Hits@10 0.9645669291338582 MRR 0.5738294353610462 rank 2 total_num 253 865\n",
      "checkcorrect (4590, 94, 3980) (4590, 94, 3980) real score 0.9875448077917099 Hits@1 0.3803921568627451 Hits@3 0.7098039215686275 Hits@10 0.9647058823529412 MRR 0.5735399081635519 rank 1 total_num 254 865\n",
      "checkcorrect (5005, 292, 4650) (5005, 292, 4650) real score 0.9231994837522507 Hits@1 0.37890625 Hits@3 0.7109375 Hits@10 0.96484375 MRR 0.5732526428972881 rank 1 total_num 255 865\n",
      "checkcorrect (3747, 146, 4315) (3747, 146, 4315) real score 0.43859577775001524 Hits@1 0.377431906614786 Hits@3 0.708171206225681 Hits@10 0.9610894941634242 MRR 0.5712166403957423 rank 19 total_num 256 865\n",
      "checkcorrect (5383, 390, 4469) (5383, 390, 4469) real score 0.8958052754402162 Hits@1 0.375968992248062 Hits@3 0.7054263565891473 Hits@10 0.9612403100775194 MRR 0.5699716146577742 rank 3 total_num 257 865\n",
      "checkcorrect (5815, 142, 5915) (5815, 142, 5915) real score 0.38984401165507737 Hits@1 0.3745173745173745 Hits@3 0.7027027027027027 Hits@10 0.9613899613899614 MRR 0.5682535775355434 rank 7 total_num 258 865\n",
      "checkcorrect (3887, 50, 4190) (3887, 50, 4190) real score 0.9677306920289994 Hits@1 0.3769230769230769 Hits@3 0.7038461538461539 Hits@10 0.9615384615384616 MRR 0.5699141406988683 rank 0 total_num 259 865\n",
      "checkcorrect (3865, 114, 3961) (3865, 114, 3961) real score 0.9437390297651291 Hits@1 0.3793103448275862 Hits@3 0.7049808429118773 Hits@10 0.9616858237547893 MRR 0.571561979240252 rank 0 total_num 260 865\n",
      "checkcorrect (4800, 78, 5062) (4800, 78, 5062) real score 0.9566877812147141 Hits@1 0.37786259541984735 Hits@3 0.7061068702290076 Hits@10 0.9618320610687023 MRR 0.5712888419149075 rank 1 total_num 261 865\n",
      "checkcorrect (4948, 50, 4422) (4948, 50, 4422) real score 0.9458588302135467 Hits@1 0.38022813688212925 Hits@3 0.7072243346007605 Hits@10 0.9619771863117871 MRR 0.5729189223639002 rank 0 total_num 262 865\n",
      "checkcorrect (4526, 50, 4139) (4526, 50, 4139) real score 0.9706383973360062 Hits@1 0.38257575757575757 Hits@3 0.7083333333333334 Hits@10 0.9621212121212122 MRR 0.5745366537185824 rank 0 total_num 263 865\n",
      "checkcorrect (5046, 96, 3727) (5046, 96, 3727) real score 0.9761330544948578 Hits@1 0.3849056603773585 Hits@3 0.7094339622641509 Hits@10 0.9622641509433962 MRR 0.5761421757800217 rank 0 total_num 264 865\n",
      "checkcorrect (4702, 72, 6127) (4702, 72, 6127) real score 0.9303143799304963 Hits@1 0.38721804511278196 Hits@3 0.7105263157894737 Hits@10 0.9624060150375939 MRR 0.5777356262470141 rank 0 total_num 265 865\n",
      "checkcorrect (4313, 70, 4881) (4313, 70, 4881) real score 0.8852374821901321 Hits@1 0.3857677902621723 Hits@3 0.7078651685393258 Hits@10 0.9625468164794008 MRR 0.5763208860738043 rank 4 total_num 266 865\n",
      "checkcorrect (4513, 96, 3727) (4513, 96, 3727) real score 0.9240087002515793 Hits@1 0.3843283582089552 Hits@3 0.7052238805970149 Hits@10 0.9626865671641791 MRR 0.5751032708272602 rank 3 total_num 267 865\n",
      "checkcorrect (5434, 230, 6082) (5434, 230, 6082) real score 0.49766936898231506 Hits@1 0.38661710037174724 Hits@3 0.7063197026022305 Hits@10 0.9628252788104089 MRR 0.5766828125713969 rank 0 total_num 268 865\n",
      "checkcorrect (4761, 50, 3952) (4761, 50, 3952) real score 0.9527581453323364 Hits@1 0.3888888888888889 Hits@3 0.7074074074074074 Hits@10 0.9629629629629629 MRR 0.5782506540063176 rank 0 total_num 269 865\n",
      "checkcorrect (4925, 2, 3927) (4925, 2, 3927) real score 0.866426819562912 Hits@1 0.3874538745387454 Hits@3 0.7047970479704797 Hits@10 0.9630996309963099 MRR 0.5765268918554127 rank 8 total_num 270 865\n",
      "checkcorrect (5593, 224, 4742) (5593, 224, 4742) real score 0.8779026389122009 Hits@1 0.3897058823529412 Hits@3 0.7058823529411765 Hits@10 0.9632352941176471 MRR 0.5780837782824149 rank 0 total_num 271 865\n",
      "checkcorrect (4190, 50, 3868) (4190, 50, 3868) real score 0.9568949788808823 Hits@1 0.39194139194139194 Hits@3 0.706959706959707 Hits@10 0.9633699633699634 MRR 0.5796292589480471 rank 0 total_num 272 865\n",
      "checkcorrect (4098, 36, 5021) (4098, 36, 5021) real score 0.94311566054821 Hits@1 0.39416058394160586 Hits@3 0.708029197080292 Hits@10 0.9635036496350365 MRR 0.5811634587329082 rank 0 total_num 273 865\n",
      "checkcorrect (4202, 50, 4201) (4202, 50, 4201) real score 0.6261314313858748 Hits@1 0.3927272727272727 Hits@3 0.7054545454545454 Hits@10 0.96 MRR 0.5792640408081041 rank 16 total_num 274 865\n",
      "checkcorrect (6008, 216, 5557) (6008, 216, 5557) real score 0.9274629473686218 Hits@1 0.39492753623188404 Hits@3 0.7065217391304348 Hits@10 0.9601449275362319 MRR 0.5807884464573501 rank 0 total_num 275 865\n",
      "checkcorrect (3908, 36, 4353) (3908, 36, 4353) real score 0.9481631487607955 Hits@1 0.3935018050541516 Hits@3 0.7075812274368231 Hits@10 0.9602888086642599 MRR 0.5804967914159879 rank 1 total_num 276 865\n",
      "checkcorrect (4231, 50, 4843) (4231, 50, 4843) real score 0.7931856006383896 Hits@1 0.3920863309352518 Hits@3 0.7050359712230215 Hits@10 0.960431654676259 MRR 0.5788583137490239 rank 7 total_num 277 865\n",
      "checkcorrect (4285, 160, 4066) (4285, 160, 4066) real score 0.9754312247037887 Hits@1 0.3942652329749104 Hits@3 0.7060931899641577 Hits@10 0.9605734767025089 MRR 0.5803677821585256 rank 0 total_num 278 865\n",
      "checkcorrect (4048, 12, 3687) (4048, 12, 3687) real score 0.9746575474739074 Hits@1 0.39285714285714285 Hits@3 0.7071428571428572 Hits@10 0.9607142857142857 MRR 0.5800807543651022 rank 1 total_num 279 865\n",
      "checkcorrect (4964, 12, 3918) (4964, 12, 3918) real score 0.9751495569944382 Hits@1 0.3914590747330961 Hits@3 0.708185053380783 Hits@10 0.9608540925266904 MRR 0.5792026496639215 rank 2 total_num 280 865\n",
      "checkcorrect (4355, 168, 5387) (4355, 168, 5387) real score 0.9723214089870453 Hits@1 0.3900709219858156 Hits@3 0.7092198581560284 Hits@10 0.9609929078014184 MRR 0.5783307726556571 rank 2 total_num 281 865\n",
      "checkcorrect (3915, 22, 3736) (3915, 22, 3736) real score 0.9763807356357574 Hits@1 0.392226148409894 Hits@3 0.7102473498233216 Hits@10 0.9611307420494699 MRR 0.5798207699254251 rank 0 total_num 282 865\n",
      "checkcorrect (4583, 70, 4524) (4583, 70, 4524) real score 0.9588005781173706 Hits@1 0.39436619718309857 Hits@3 0.7112676056338029 Hits@10 0.9612676056338029 MRR 0.5813002742566736 rank 0 total_num 283 865\n",
      "checkcorrect (4277, 264, 4517) (4277, 264, 4517) real score 0.3684541708789766 Hits@1 0.3929824561403509 Hits@3 0.712280701754386 Hits@10 0.9614035087719298 MRR 0.5804302148148374 rank 2 total_num 284 865\n",
      "checkcorrect (3707, 24, 6051) (3707, 24, 6051) real score 0.9047461897134781 Hits@1 0.3916083916083916 Hits@3 0.7097902097902098 Hits@10 0.9615384615384616 MRR 0.5789834891220116 rank 5 total_num 285 865\n",
      "checkcorrect (3875, 22, 3916) (3875, 22, 3916) real score 0.954150378704071 Hits@1 0.3902439024390244 Hits@3 0.710801393728223 Hits@10 0.9616724738675958 MRR 0.5781275652342461 rank 2 total_num 286 865\n",
      "checkcorrect (5819, 132, 4853) (5819, 132, 4853) real score 0.4984787702560425 Hits@1 0.3888888888888889 Hits@3 0.7083333333333334 Hits@10 0.9618055555555556 MRR 0.5765542056327384 rank 7 total_num 287 865\n",
      "checkcorrect (4356, 98, 4802) (4356, 98, 4802) real score 0.9687711983919143 Hits@1 0.3875432525951557 Hits@3 0.7093425605536332 Hits@10 0.9619377162629758 MRR 0.5762893121876423 rank 1 total_num 288 865\n",
      "checkcorrect (5266, 36, 3681) (5266, 36, 3681) real score 0.8214207023382187 Hits@1 0.38620689655172413 Hits@3 0.7068965517241379 Hits@10 0.9620689655172414 MRR 0.5751641766283747 rank 3 total_num 289 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5194, 50, 4882) (5194, 50, 4882) real score 0.76556576192379 Hits@1 0.3848797250859107 Hits@3 0.7044673539518901 Hits@10 0.9621993127147767 MRR 0.5737604051164787 rank 5 total_num 290 865\n",
      "checkcorrect (3912, 6, 4500) (3912, 6, 4500) real score 0.9921229273080825 Hits@1 0.386986301369863 Hits@3 0.7054794520547946 Hits@10 0.9623287671232876 MRR 0.5752201297564908 rank 0 total_num 291 865\n",
      "checkcorrect (5841, 362, 5080) (5841, 362, 5080) real score 0.7912752479314804 Hits@1 0.3856655290102389 Hits@3 0.7030716723549488 Hits@10 0.962457337883959 MRR 0.5736361399317625 rank 8 total_num 292 865\n",
      "checkcorrect (4583, 22, 4889) (4583, 22, 4889) real score 0.9337345898151398 Hits@1 0.3843537414965986 Hits@3 0.7040816326530612 Hits@10 0.9625850340136054 MRR 0.5728187834467339 rank 2 total_num 293 865\n",
      "checkcorrect (3724, 54, 3817) (3724, 54, 3817) real score 0.8989828884601594 Hits@1 0.38305084745762713 Hits@3 0.7050847457627119 Hits@10 0.9627118644067797 MRR 0.5720069683616038 rank 2 total_num 294 865\n",
      "checkcorrect (4614, 54, 4644) (4614, 54, 4644) real score 0.8733338207006455 Hits@1 0.38175675675675674 Hits@3 0.706081081081081 Hits@10 0.9628378378378378 MRR 0.5717637015765984 rank 1 total_num 295 865\n",
      "checkcorrect (4450, 22, 4098) (4450, 22, 4098) real score 0.9775946617126465 Hits@1 0.3838383838383838 Hits@3 0.7070707070707071 Hits@10 0.9629629629629629 MRR 0.573205574635263 rank 0 total_num 296 865\n",
      "checkcorrect (4669, 32, 4380) (4669, 32, 4380) real score 0.9816448479890824 Hits@1 0.3825503355704698 Hits@3 0.7080536912751678 Hits@10 0.9630872483221476 MRR 0.5724006342282095 rank 2 total_num 297 865\n",
      "checkcorrect (5930, 216, 5172) (5930, 216, 5172) real score 0.9183807969093323 Hits@1 0.38127090301003347 Hits@3 0.705685618729097 Hits@10 0.9632107023411371 MRR 0.5713223712374798 rank 3 total_num 298 865\n",
      "checkcorrect (3969, 22, 3756) (3969, 22, 3756) real score 0.9477762132883072 Hits@1 0.38 Hits@3 0.7066666666666667 Hits@10 0.9633333333333334 MRR 0.570529074444466 rank 2 total_num 299 865\n",
      "checkcorrect (4029, 28, 5166) (4029, 28, 5166) real score 0.38758116364479067 Hits@1 0.3787375415282392 Hits@3 0.7043189368770764 Hits@10 0.9601328903654485 MRR 0.5688290560224304 rank 16 total_num 300 865\n",
      "checkcorrect (4858, 104, 4857) (4858, 104, 4857) real score 0.39300776124000547 Hits@1 0.37748344370860926 Hits@3 0.7019867549668874 Hits@10 0.956953642384106 MRR 0.5672465395816578 rank 10 total_num 301 865\n",
      "checkcorrect (6088, 96, 3993) (6088, 96, 3993) real score 0.9393499255180359 Hits@1 0.37623762376237624 Hits@3 0.6996699669966997 Hits@10 0.9570957095709571 MRR 0.5657411421279597 rank 8 total_num 302 865\n",
      "checkcorrect (4861, 24, 4462) (4861, 24, 4462) real score 0.9448119848966599 Hits@1 0.375 Hits@3 0.7006578947368421 Hits@10 0.9572368421052632 MRR 0.5655248883709598 rank 1 total_num 303 865\n",
      "checkcorrect (4233, 24, 3736) (4233, 24, 3736) real score 0.7414166122674942 Hits@1 0.3737704918032787 Hits@3 0.6983606557377049 Hits@10 0.9573770491803278 MRR 0.5640805444746615 rank 7 total_num 304 865\n",
      "checkcorrect (4332, 286, 4533) (4332, 286, 4533) real score 0.4779508322477341 Hits@1 0.37254901960784315 Hits@3 0.696078431372549 Hits@10 0.954248366013072 MRR 0.5625342325349048 rank 10 total_num 305 865\n",
      "checkcorrect (5624, 386, 5258) (5624, 386, 5258) real score 0.8666179239749909 Hits@1 0.3713355048859935 Hits@3 0.6970684039087948 Hits@10 0.9543973941368078 MRR 0.5623305379663872 rank 1 total_num 306 865\n",
      "checkcorrect (5294, 56, 4247) (5294, 56, 4247) real score 0.9610572218894958 Hits@1 0.37337662337662336 Hits@3 0.698051948051948 Hits@10 0.9545454545454546 MRR 0.5637515427132496 rank 0 total_num 307 865\n",
      "checkcorrect (3962, 216, 3967) (3962, 216, 3967) real score 0.890484219789505 Hits@1 0.37540453074433655 Hits@3 0.6990291262135923 Hits@10 0.9546925566343042 MRR 0.5651633500183847 rank 0 total_num 308 865\n",
      "checkcorrect (5514, 418, 5458) (5514, 418, 5458) real score 0.050952025910373774 Hits@1 0.3741935483870968 Hits@3 0.6967741935483871 Hits@10 0.9548387096774194 MRR 0.5637434682441318 rank 7 total_num 309 865\n",
      "checkcorrect (5868, 96, 3727) (5868, 96, 3727) real score 0.49966594874858855 Hits@1 0.3729903536977492 Hits@3 0.6945337620578779 Hits@10 0.954983922829582 MRR 0.5625738750986523 rank 4 total_num 310 865\n",
      "checkcorrect (3710, 50, 5040) (3710, 50, 5040) real score 0.9657896488904953 Hits@1 0.3717948717948718 Hits@3 0.6955128205128205 Hits@10 0.9551282051282052 MRR 0.5623733178066694 rank 1 total_num 311 865\n",
      "checkcorrect (4206, 50, 3854) (4206, 50, 3854) real score 0.9716686278581619 Hits@1 0.3738019169329074 Hits@3 0.6964856230031949 Hits@10 0.9552715654952076 MRR 0.5637714861203861 rank 0 total_num 312 865\n",
      "checkcorrect (3968, 102, 3867) (3968, 102, 3867) real score 0.8713025957345963 Hits@1 0.37261146496815284 Hits@3 0.697452229299363 Hits@10 0.9554140127388535 MRR 0.5630376066529115 rank 2 total_num 313 865\n",
      "checkcorrect (3980, 382, 4088) (3980, 382, 4088) real score 0.9524586349725723 Hits@1 0.3746031746031746 Hits@3 0.6984126984126984 Hits@10 0.9555555555555556 MRR 0.5644247888540134 rank 0 total_num 314 865\n",
      "checkcorrect (5482, 40, 4677) (5482, 40, 4677) real score 0.859569138288498 Hits@1 0.37341772151898733 Hits@3 0.6962025316455697 Hits@10 0.9525316455696202 MRR 0.5629263214554534 rank 10 total_num 315 865\n",
      "checkcorrect (4062, 96, 3727) (4062, 96, 3727) real score 0.922651931643486 Hits@1 0.3722397476340694 Hits@3 0.694006309148265 Hits@10 0.9526813880126183 MRR 0.5615448504098527 rank 7 total_num 316 865\n",
      "checkcorrect (4077, 32, 4593) (4077, 32, 4593) real score 0.984005656838417 Hits@1 0.3742138364779874 Hits@3 0.6949685534591195 Hits@10 0.9528301886792453 MRR 0.562923640188438 rank 0 total_num 317 865\n",
      "checkcorrect (3915, 22, 4378) (3915, 22, 4378) real score 0.967839351296425 Hits@1 0.3730407523510972 Hits@3 0.6959247648902821 Hits@10 0.9529780564263323 MRR 0.5627263873978786 rank 1 total_num 318 865\n",
      "checkcorrect (4417, 284, 4751) (4417, 284, 4751) real score 0.9759407550096513 Hits@1 0.375 Hits@3 0.696875 Hits@10 0.953125 MRR 0.5640928674372603 rank 0 total_num 319 865\n",
      "checkcorrect (3999, 40, 5021) (3999, 40, 5021) real score 0.9537681639194489 Hits@1 0.37383177570093457 Hits@3 0.6978193146417445 Hits@10 0.9532710280373832 MRR 0.5638932011835617 rank 1 total_num 320 865\n",
      "checkcorrect (4984, 96, 3993) (4984, 96, 3993) real score 0.9159860134124755 Hits@1 0.37267080745341613 Hits@3 0.6956521739130435 Hits@10 0.953416149068323 MRR 0.5626595784055588 rank 5 total_num 321 865\n",
      "checkcorrect (3844, 0, 3904) (3844, 0, 3904) real score 0.9872753977775575 Hits@1 0.3746130030959752 Hits@3 0.6965944272445821 Hits@10 0.9535603715170279 MRR 0.5640135735188543 rank 0 total_num 322 865\n",
      "checkcorrect (3868, 40, 4557) (3868, 40, 4557) real score 0.8553088635206223 Hits@1 0.3734567901234568 Hits@3 0.6944444444444444 Hits@10 0.9537037037037037 MRR 0.5625814328598455 rank 9 total_num 323 865\n",
      "checkcorrect (4332, 50, 4050) (4332, 50, 4050) real score 0.9645760804414749 Hits@1 0.37538461538461537 Hits@3 0.6953846153846154 Hits@10 0.9538461538461539 MRR 0.5639273361433537 rank 0 total_num 324 865\n",
      "checkcorrect (4018, 0, 4281) (4018, 0, 4281) real score 0.9882585048675537 Hits@1 0.3773006134969325 Hits@3 0.696319018404908 Hits@10 0.9539877300613497 MRR 0.5652649823515029 rank 0 total_num 325 865\n",
      "checkcorrect (4287, 28, 5074) (4287, 28, 5074) real score 0.44070551097393035 Hits@1 0.3761467889908257 Hits@3 0.6941896024464832 Hits@10 0.9510703363914373 MRR 0.563716231730892 rank 16 total_num 326 865\n",
      "checkcorrect (4540, 64, 4250) (4540, 64, 4250) real score 0.9319281578063965 Hits@1 0.375 Hits@3 0.6951219512195121 Hits@10 0.9512195121951219 MRR 0.5630138448455337 rank 2 total_num 327 865\n",
      "checkcorrect (4841, 0, 4638) (4841, 0, 4638) real score 0.9096097260713578 Hits@1 0.3738601823708207 Hits@3 0.6960486322188449 Hits@10 0.9513677811550152 MRR 0.5628223134022342 rank 1 total_num 328 865\n",
      "checkcorrect (5501, 44, 3669) (5501, 44, 3669) real score 0.9178409159183503 Hits@1 0.37272727272727274 Hits@3 0.693939393939394 Hits@10 0.9515151515151515 MRR 0.5614955791191971 rank 7 total_num 329 865\n",
      "checkcorrect (3975, 2, 4024) (3975, 2, 4024) real score 0.9433122783899308 Hits@1 0.3716012084592145 Hits@3 0.6948640483383686 Hits@10 0.9516616314199395 MRR 0.5613097918711029 rank 1 total_num 330 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4105, 22, 3860) (4105, 22, 3860) real score 0.9660636782646179 Hits@1 0.3704819277108434 Hits@3 0.6957831325301205 Hits@10 0.9518072289156626 MRR 0.5606231157911699 rank 2 total_num 331 865\n",
      "checkcorrect (5713, 146, 3770) (5713, 146, 3770) real score 0.853843829035759 Hits@1 0.36936936936936937 Hits@3 0.6936936936936937 Hits@10 0.9519519519519519 MRR 0.5593149382662714 rank 7 total_num 332 865\n",
      "checkcorrect (3975, 2, 4033) (3975, 2, 4033) real score 0.9419449836015701 Hits@1 0.36826347305389223 Hits@3 0.6946107784431138 Hits@10 0.9520958083832335 MRR 0.5591373486307437 rank 1 total_num 333 865\n",
      "checkcorrect (5870, 110, 5582) (5870, 110, 5582) real score 0.4416459932923317 Hits@1 0.36716417910447763 Hits@3 0.6955223880597015 Hits@10 0.9522388059701492 MRR 0.5589608192318459 rank 1 total_num 334 865\n",
      "checkcorrect (4704, 4, 3805) (4704, 4, 3805) real score 0.9743974000215531 Hits@1 0.36904761904761907 Hits@3 0.6964285714285714 Hits@10 0.9523809523809523 MRR 0.560273435841275 rank 0 total_num 335 865\n",
      "checkcorrect (5696, 98, 4674) (5696, 98, 4674) real score 0.7982146218419075 Hits@1 0.36795252225519287 Hits@3 0.6943620178041543 Hits@10 0.9525222551928784 MRR 0.5590348118264853 rank 6 total_num 336 865\n",
      "checkcorrect (4592, 32, 4636) (4592, 32, 4636) real score 0.9801649630069733 Hits@1 0.3668639053254438 Hits@3 0.6952662721893491 Hits@10 0.9526627218934911 MRR 0.5583670559729552 rank 2 total_num 337 865\n",
      "checkcorrect (3852, 24, 4576) (3852, 24, 4576) real score 0.6918839484453201 Hits@1 0.36578171091445427 Hits@3 0.6932153392330384 Hits@10 0.9528023598820059 MRR 0.5573099260143329 rank 4 total_num 338 865\n",
      "checkcorrect (4336, 6, 3912) (4336, 6, 3912) real score 0.9919923961162567 Hits@1 0.36764705882352944 Hits@3 0.6941176470588235 Hits@10 0.9529411764705882 MRR 0.5586119556437026 rank 0 total_num 339 865\n",
      "checkcorrect (3869, 24, 3870) (3869, 24, 3870) real score 0.7526508401613683 Hits@1 0.36656891495601174 Hits@3 0.6920821114369502 Hits@10 0.9530791788856305 MRR 0.5572670525479732 rank 9 total_num 340 865\n",
      "checkcorrect (4169, 40, 3765) (4169, 40, 3765) real score 0.8790110766887664 Hits@1 0.3654970760233918 Hits@3 0.6929824561403509 Hits@10 0.9532163742690059 MRR 0.5566122755912053 rank 2 total_num 341 865\n",
      "checkcorrect (3677, 2, 5000) (3677, 2, 5000) real score 0.908829540014267 Hits@1 0.36443148688046645 Hits@3 0.6909620991253644 Hits@10 0.9533527696793003 MRR 0.5554754079267022 rank 5 total_num 342 865\n",
      "checkcorrect (3688, 78, 4690) (3688, 78, 4690) real score 0.49907245934009553 Hits@1 0.3633720930232558 Hits@3 0.6918604651162791 Hits@10 0.9534883720930233 MRR 0.5548296460819541 rank 2 total_num 343 865\n",
      "checkcorrect (5669, 44, 3669) (5669, 44, 3669) real score 0.9465946137905121 Hits@1 0.36231884057971014 Hits@3 0.6927536231884058 Hits@10 0.9536231884057971 MRR 0.5546707195715715 rank 1 total_num 344 865\n",
      "checkcorrect (4385, 54, 4524) (4385, 54, 4524) real score 0.9293073952198029 Hits@1 0.36127167630057805 Hits@3 0.6936416184971098 Hits@10 0.953757225433526 MRR 0.5545127117115382 rank 1 total_num 345 865\n",
      "checkcorrect (3746, 78, 3874) (3746, 78, 3874) real score 0.7345610409975052 Hits@1 0.36023054755043227 Hits@3 0.69164265129683 Hits@10 0.9538904899135446 MRR 0.5532028768074703 rank 9 total_num 346 865\n",
      "checkcorrect (4917, 6, 4753) (4917, 6, 4753) real score 0.9920460134744644 Hits@1 0.35919540229885055 Hits@3 0.6925287356321839 Hits@10 0.9540229885057471 MRR 0.5530499949775638 rank 1 total_num 347 865\n",
      "checkcorrect (4302, 54, 4301) (4302, 54, 4301) real score 0.9787012964487076 Hits@1 0.36103151862464183 Hits@3 0.6934097421203438 Hits@10 0.9541547277936963 MRR 0.5543306540177427 rank 0 total_num 348 865\n",
      "checkcorrect (4800, 78, 3740) (4800, 78, 3740) real score 0.9634271174669267 Hits@1 0.3628571428571429 Hits@3 0.6942857142857143 Hits@10 0.9542857142857143 MRR 0.5556039950062635 rank 0 total_num 349 865\n",
      "checkcorrect (5227, 124, 4281) (5227, 124, 4281) real score 0.7989824473857879 Hits@1 0.36182336182336183 Hits@3 0.6923076923076923 Hits@10 0.9544159544159544 MRR 0.5544959114497403 rank 5 total_num 350 865\n",
      "checkcorrect (4455, 262, 4487) (4455, 262, 4487) real score 0.9376965850591659 Hits@1 0.36363636363636365 Hits@3 0.6931818181818182 Hits@10 0.9545454545454546 MRR 0.5557615480649399 rank 0 total_num 351 865\n",
      "checkcorrect (3864, 22, 4328) (3864, 22, 4328) real score 0.9180696576833725 Hits@1 0.3626062322946176 Hits@3 0.6940509915014165 Hits@10 0.9546742209631728 MRR 0.5556035833395435 rank 1 total_num 352 865\n",
      "checkcorrect (4417, 208, 4751) (4417, 208, 4751) real score 0.9938566029071807 Hits@1 0.3644067796610169 Hits@3 0.6949152542372882 Hits@10 0.9548022598870056 MRR 0.5568589404487538 rank 0 total_num 353 865\n",
      "checkcorrect (5637, 0, 4281) (5637, 0, 4281) real score 0.9136167913675308 Hits@1 0.36619718309859156 Hits@3 0.6957746478873239 Hits@10 0.9549295774647887 MRR 0.558107225123546 rank 0 total_num 354 865\n",
      "checkcorrect (3813, 78, 4357) (3813, 78, 4357) real score 0.9598105758428573 Hits@1 0.3651685393258427 Hits@3 0.6966292134831461 Hits@10 0.9550561797752809 MRR 0.5579440025810642 rank 1 total_num 355 865\n",
      "checkcorrect (4310, 110, 4138) (4310, 110, 4138) real score 0.8580747812986373 Hits@1 0.3641456582633053 Hits@3 0.6946778711484594 Hits@10 0.9551820728291317 MRR 0.5570814143385402 rank 3 total_num 356 865\n",
      "checkcorrect (4656, 40, 4037) (4656, 40, 4037) real score 0.9415584683418274 Hits@1 0.36312849162011174 Hits@3 0.6927374301675978 Hits@10 0.9553072625698324 MRR 0.556083980220276 rank 4 total_num 357 865\n",
      "checkcorrect (4881, 64, 5602) (4881, 64, 5602) real score 0.9255970627069473 Hits@1 0.362116991643454 Hits@3 0.6935933147632312 Hits@10 0.9554317548746518 MRR 0.5554635048807581 rank 2 total_num 358 865\n",
      "checkcorrect (6129, 48, 3904) (6129, 48, 3904) real score 0.0 Hits@1 0.3611111111111111 Hits@3 0.6916666666666667 Hits@10 0.9527777777777777 MRR 0.5540468133267964 rank 21 total_num 359 865\n",
      "checkcorrect (4245, 44, 3669) (4245, 44, 3669) real score 0.9181358933448791 Hits@1 0.3601108033240997 Hits@3 0.6897506925207756 Hits@10 0.9529085872576177 MRR 0.5530660742317083 rank 4 total_num 360 865\n",
      "checkcorrect (4190, 152, 3982) (4190, 152, 3982) real score 0.6928750067949294 Hits@1 0.36187845303867405 Hits@3 0.6906077348066298 Hits@10 0.9530386740331491 MRR 0.5543006983360407 rank 0 total_num 361 865\n",
      "checkcorrect (3690, 48, 3770) (3690, 48, 3770) real score 0.9441806823015213 Hits@1 0.3608815426997245 Hits@3 0.6914600550964187 Hits@10 0.953168044077135 MRR 0.5541511096353904 rank 1 total_num 362 865\n",
      "checkcorrect (4359, 112, 5972) (4359, 112, 5972) real score 0.0 Hits@1 0.3598901098901099 Hits@3 0.6895604395604396 Hits@10 0.9505494505494505 MRR 0.5527304665788015 rank 26 total_num 363 865\n",
      "checkcorrect (5332, 44, 3669) (5332, 44, 3669) real score 0.9289101600646972 Hits@1 0.3589041095890411 Hits@3 0.6876712328767123 Hits@10 0.9506849315068493 MRR 0.5516075259658655 rank 6 total_num 364 865\n",
      "checkcorrect (4402, 44, 3669) (4402, 44, 3669) real score 0.9267272502183914 Hits@1 0.35792349726775957 Hits@3 0.6857923497267759 Hits@10 0.9508196721311475 MRR 0.5505557749841736 rank 5 total_num 365 865\n",
      "checkcorrect (4482, 54, 3748) (4482, 54, 3748) real score 0.9085303962230682 Hits@1 0.3569482288828338 Hits@3 0.6866485013623979 Hits@10 0.9509536784741145 MRR 0.5499638882221822 rank 2 total_num 366 865\n",
      "checkcorrect (5917, 68, 5590) (5917, 68, 5590) real score 0.9808546394109726 Hits@1 0.358695652173913 Hits@3 0.6875 Hits@10 0.9510869565217391 MRR 0.5511868124389698 rank 0 total_num 367 865\n",
      "checkcorrect (4925, 2, 3764) (4925, 2, 3764) real score 0.947414892911911 Hits@1 0.35772357723577236 Hits@3 0.6883468834688347 Hits@10 0.9512195121951219 MRR 0.5505964236067052 rank 2 total_num 368 865\n",
      "checkcorrect (5179, 312, 3770) (5179, 312, 3770) real score 0.9136710911989212 Hits@1 0.35945945945945945 Hits@3 0.6891891891891891 Hits@10 0.9513513513513514 MRR 0.5518110278672277 rank 0 total_num 369 865\n",
      "checkcorrect (3864, 22, 4602) (3864, 22, 4602) real score 0.8744891196489335 Hits@1 0.3584905660377358 Hits@3 0.6873315363881402 Hits@10 0.9514824797843666 MRR 0.5509975210535694 rank 3 total_num 370 865\n",
      "checkcorrect (4691, 218, 5652) (4691, 218, 5652) real score 0.9249558031558991 Hits@1 0.3602150537634409 Hits@3 0.6881720430107527 Hits@10 0.9516129032258065 MRR 0.5522045169647156 rank 0 total_num 371 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4518, 32, 4593) (4518, 32, 4593) real score 0.9837887287139893 Hits@1 0.36193029490616624 Hits@3 0.6890080428954424 Hits@10 0.9517426273458445 MRR 0.5534050410479202 rank 0 total_num 372 865\n",
      "checkcorrect (3809, 40, 3787) (3809, 40, 3787) real score 0.9433442533016205 Hits@1 0.36363636363636365 Hits@3 0.6898395721925134 Hits@10 0.9518716577540107 MRR 0.5545991452162412 rank 0 total_num 373 865\n",
      "checkcorrect (4346, 24, 4489) (4346, 24, 4489) real score 0.9345145732164383 Hits@1 0.36533333333333334 Hits@3 0.6906666666666667 Hits@10 0.952 MRR 0.555786880828998 rank 0 total_num 374 865\n",
      "checkcorrect (4231, 50, 5165) (4231, 50, 5165) real score 0.9585790872573852 Hits@1 0.3670212765957447 Hits@3 0.6914893617021277 Hits@10 0.9521276595744681 MRR 0.5569682986991336 rank 0 total_num 375 865\n",
      "checkcorrect (4462, 334, 5581) (4462, 334, 5581) real score 0.8941116511821747 Hits@1 0.3687002652519894 Hits@3 0.6923076923076923 Hits@10 0.9522546419098143 MRR 0.5581434491004621 rank 0 total_num 376 865\n",
      "checkcorrect (3949, 24, 4754) (3949, 24, 4754) real score 0.9381269991397858 Hits@1 0.37037037037037035 Hits@3 0.6931216931216931 Hits@10 0.9523809523809523 MRR 0.5593123817747996 rank 0 total_num 377 865\n",
      "checkcorrect (4206, 24, 4106) (4206, 24, 4106) real score 0.9473243802785873 Hits@1 0.3720316622691293 Hits@3 0.6939313984168866 Hits@10 0.9525065963060686 MRR 0.5604751459389822 rank 0 total_num 378 865\n",
      "checkcorrect (3756, 36, 3681) (3756, 36, 3681) real score 0.9457103043794632 Hits@1 0.3736842105263158 Hits@3 0.6947368421052632 Hits@10 0.9526315789473684 MRR 0.5616317902917742 rank 0 total_num 379 865\n",
      "checkcorrect (4145, 96, 3993) (4145, 96, 3993) real score 0.9405394673347474 Hits@1 0.37270341207349084 Hits@3 0.6955380577427821 Hits@10 0.952755905511811 MRR 0.5610325817433269 rank 2 total_num 380 865\n",
      "checkcorrect (5785, 350, 5033) (5785, 350, 5033) real score 0.719556701183319 Hits@1 0.3743455497382199 Hits@3 0.6963350785340314 Hits@10 0.9528795811518325 MRR 0.562181711110491 rank 0 total_num 381 865\n",
      "checkcorrect (4373, 146, 3770) (4373, 146, 3770) real score 0.9186435878276824 Hits@1 0.3733681462140992 Hits@3 0.6971279373368147 Hits@10 0.9530026109660574 MRR 0.5620193567733879 rank 1 total_num 382 865\n",
      "checkcorrect (5376, 64, 6062) (5376, 64, 6062) real score 0.6768580913543701 Hits@1 0.3723958333333333 Hits@3 0.6953125 Hits@10 0.953125 MRR 0.560927788507981 rank 6 total_num 383 865\n",
      "checkcorrect (5240, 312, 3770) (5240, 312, 3770) real score 0.9005402356386185 Hits@1 0.37402597402597404 Hits@3 0.6961038961038961 Hits@10 0.9532467532467532 MRR 0.5620682358105576 rank 0 total_num 384 865\n",
      "checkcorrect (3947, 246, 5318) (3947, 246, 5318) real score 0.4434848815202713 Hits@1 0.37305699481865284 Hits@3 0.694300518134715 Hits@10 0.9533678756476683 MRR 0.5609821967096421 rank 6 total_num 385 865\n",
      "checkcorrect (5079, 54, 4571) (5079, 54, 4571) real score 0.9243295401334762 Hits@1 0.37209302325581395 Hits@3 0.6950904392764858 Hits@10 0.9534883720930233 MRR 0.5608246199739583 rank 1 total_num 386 865\n",
      "checkcorrect (5397, 54, 5018) (5397, 54, 5018) real score 0.8576127350330354 Hits@1 0.3711340206185567 Hits@3 0.6932989690721649 Hits@10 0.9536082474226805 MRR 0.5598946596132006 rank 4 total_num 387 865\n",
      "checkcorrect (4557, 70, 4556) (4557, 70, 4556) real score 0.4825551867485046 Hits@1 0.37017994858611825 Hits@3 0.6915167095115681 Hits@10 0.9537275064267352 MRR 0.5588225837346503 rank 6 total_num 388 865\n",
      "checkcorrect (6106, 96, 3993) (6106, 96, 3993) real score 0.9759975790977478 Hits@1 0.3717948717948718 Hits@3 0.6923076923076923 Hits@10 0.9538461538461539 MRR 0.5599538078789205 rank 0 total_num 389 865\n",
      "checkcorrect (4051, 22, 4721) (4051, 22, 4721) real score 0.9724794328212738 Hits@1 0.3734015345268542 Hits@3 0.6930946291560103 Hits@10 0.9539641943734015 MRR 0.5610792457104321 rank 0 total_num 390 865\n",
      "checkcorrect (4803, 48, 4100) (4803, 48, 4100) real score 0.720452219247818 Hits@1 0.37244897959183676 Hits@3 0.6913265306122449 Hits@10 0.9540816326530612 MRR 0.5600730911720552 rank 5 total_num 391 865\n",
      "checkcorrect (3810, 54, 5601) (3810, 54, 5601) real score 0.9473492324352264 Hits@1 0.37404580152671757 Hits@3 0.6921119592875318 Hits@10 0.9541984732824428 MRR 0.5611924980647471 rank 0 total_num 392 865\n",
      "checkcorrect (4798, 198, 4400) (4798, 198, 4400) real score 0.9349260061979294 Hits@1 0.3730964467005076 Hits@3 0.6928934010152284 Hits@10 0.9543147208121827 MRR 0.5610371871559534 rank 1 total_num 393 865\n",
      "checkcorrect (5068, 382, 4088) (5068, 382, 4088) real score 0.9565141499042511 Hits@1 0.37468354430379747 Hits@3 0.6936708860759494 Hits@10 0.9544303797468354 MRR 0.562148485416318 rank 0 total_num 394 865\n",
      "checkcorrect (3813, 78, 5282) (3813, 78, 5282) real score 0.9485887616872788 Hits@1 0.37373737373737376 Hits@3 0.6919191919191919 Hits@10 0.9545454545454546 MRR 0.5613602316652667 rank 3 total_num 395 865\n",
      "checkcorrect (4244, 0, 4281) (4244, 0, 4281) real score 0.8233854621648788 Hits@1 0.37531486146095716 Hits@3 0.6926952141057935 Hits@10 0.9546599496221663 MRR 0.5624651177316011 rank 0 total_num 396 865\n",
      "checkcorrect (5061, 94, 4003) (5061, 94, 4003) real score 0.993168556690216 Hits@1 0.3768844221105528 Hits@3 0.6934673366834171 Hits@10 0.9547738693467337 MRR 0.5635644516066474 rank 0 total_num 397 865\n",
      "checkcorrect (3785, 64, 4372) (3785, 64, 4372) real score 0.9359820544719696 Hits@1 0.37593984962406013 Hits@3 0.6942355889724311 Hits@10 0.9548872180451128 MRR 0.5629874312600976 rank 2 total_num 398 865\n",
      "checkcorrect (3979, 24, 4504) (3979, 24, 4504) real score 0.9022241204977035 Hits@1 0.375 Hits@3 0.6925 Hits@10 0.955 MRR 0.5619371055390903 rank 6 total_num 399 865\n",
      "checkcorrect (3876, 356, 4398) (3876, 356, 4398) real score 0.5301344722509385 Hits@1 0.3765586034912718 Hits@3 0.6932668329177057 Hits@10 0.9551122194513716 MRR 0.5630295317098157 rank 0 total_num 400 865\n",
      "checkcorrect (4207, 0, 4094) (4207, 0, 4094) real score 0.9899227797985077 Hits@1 0.3781094527363184 Hits@3 0.6940298507462687 Hits@10 0.9552238805970149 MRR 0.5641165229244679 rank 0 total_num 401 865\n",
      "checkcorrect (3932, 36, 5021) (3932, 36, 5021) real score 0.9458175957202912 Hits@1 0.3771712158808933 Hits@3 0.6947890818858561 Hits@10 0.9553349875930521 MRR 0.5639574248526951 rank 1 total_num 402 865\n",
      "checkcorrect (4856, 0, 3808) (4856, 0, 3808) real score 0.9235045790672303 Hits@1 0.3787128712871287 Hits@3 0.6955445544554455 Hits@10 0.9554455445544554 MRR 0.5650367381575151 rank 0 total_num 403 865\n",
      "checkcorrect (4304, 54, 4303) (4304, 54, 4303) real score 0.9758414059877396 Hits@1 0.3802469135802469 Hits@3 0.6962962962962963 Hits@10 0.9555555555555556 MRR 0.5661107215200891 rank 0 total_num 404 865\n",
      "checkcorrect (6128, 24, 5179) (6128, 24, 5179) real score 0.6880734816193581 Hits@1 0.3793103448275862 Hits@3 0.6945812807881774 Hits@10 0.9532019704433498 MRR 0.5648922925789771 rank 13 total_num 405 865\n",
      "checkcorrect (5609, 240, 4140) (5609, 240, 4140) real score 0.9537578999996186 Hits@1 0.3808353808353808 Hits@3 0.6953316953316954 Hits@10 0.9533169533169533 MRR 0.5659613532851713 rank 0 total_num 406 865\n",
      "checkcorrect (4157, 54, 4229) (4157, 54, 4229) real score 0.9701018989086151 Hits@1 0.3799019607843137 Hits@3 0.6936274509803921 Hits@10 0.9534313725490197 MRR 0.5651869382035899 rank 3 total_num 407 865\n",
      "checkcorrect (5147, 98, 5077) (5147, 98, 5077) real score 0.9195715397596359 Hits@1 0.37897310513447435 Hits@3 0.6943765281173594 Hits@10 0.9535452322738386 MRR 0.5646200589740783 rank 2 total_num 408 865\n",
      "checkcorrect (5260, 58, 3943) (5260, 58, 3943) real score 0.899080178141594 Hits@1 0.3780487804878049 Hits@3 0.6951219512195121 Hits@10 0.9536585365853658 MRR 0.5644624490741416 rank 1 total_num 409 865\n",
      "checkcorrect (4770, 96, 6113) (4770, 96, 6113) real score 0.9313618987798691 Hits@1 0.3771289537712895 Hits@3 0.6958637469586375 Hits@10 0.9537712895377128 MRR 0.5643056061323554 rank 1 total_num 410 865\n",
      "checkcorrect (5488, 96, 3727) (5488, 96, 3727) real score 0.9172410160303115 Hits@1 0.3762135922330097 Hits@3 0.6966019417475728 Hits@10 0.9538834951456311 MRR 0.5641495245640729 rank 1 total_num 411 865\n",
      "checkcorrect (5857, 96, 3727) (5857, 96, 3727) real score 0.9751757770776749 Hits@1 0.37772397094430993 Hits@3 0.6973365617433414 Hits@10 0.9539951573849879 MRR 0.5652048525917628 rank 0 total_num 412 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4787, 40, 5152) (4787, 40, 5152) real score 0.9765867292881012 Hits@1 0.37922705314009664 Hits@3 0.6980676328502415 Hits@10 0.9541062801932367 MRR 0.5662550824164204 rank 0 total_num 413 865\n",
      "checkcorrect (3877, 334, 5170) (3877, 334, 5170) real score 0.8924918740987777 Hits@1 0.38072289156626504 Hits@3 0.6987951807228916 Hits@10 0.9542168674698795 MRR 0.5673002508925254 rank 0 total_num 414 865\n",
      "checkcorrect (5244, 88, 3809) (5244, 88, 3809) real score 0.881271705031395 Hits@1 0.38221153846153844 Hits@3 0.6995192307692307 Hits@10 0.9543269230769231 MRR 0.5683403945201876 rank 0 total_num 415 865\n",
      "checkcorrect (4843, 154, 3753) (4843, 154, 3753) real score 0.8476547449827194 Hits@1 0.38369304556354916 Hits@3 0.7002398081534772 Hits@10 0.9544364508393285 MRR 0.5693755494493957 rank 0 total_num 416 865\n",
      "checkcorrect (4686, 414, 4281) (4686, 414, 4281) real score 0.5952367782592773 Hits@1 0.3827751196172249 Hits@3 0.6985645933014354 Hits@10 0.9545454545454546 MRR 0.5686114931110001 rank 3 total_num 417 865\n",
      "checkcorrect (3887, 152, 4577) (3887, 152, 4577) real score 0.7129339635372163 Hits@1 0.38424821002386633 Hits@3 0.6992840095465394 Hits@10 0.954653937947494 MRR 0.5696410599532172 rank 0 total_num 418 865\n",
      "checkcorrect (3717, 322, 5862) (3717, 322, 5862) real score 0.8738761126995087 Hits@1 0.38571428571428573 Hits@3 0.7 Hits@10 0.9547619047619048 MRR 0.5706657240961858 rank 0 total_num 419 865\n",
      "checkcorrect (4833, 360, 5605) (4833, 360, 5605) real score 0.7582576230168343 Hits@1 0.38717339667458434 Hits@3 0.7007125890736342 Hits@10 0.9548693586698337 MRR 0.5716855204760048 rank 0 total_num 420 865\n",
      "checkcorrect (5795, 388, 6165) (5795, 388, 6165) real score 0.8672868818044663 Hits@1 0.3886255924170616 Hits@3 0.7014218009478673 Hits@10 0.9549763033175356 MRR 0.5727004836976257 rank 0 total_num 421 865\n",
      "checkcorrect (5471, 372, 5470) (5471, 372, 5470) real score 0.0 Hits@1 0.3877068557919622 Hits@3 0.6997635933806147 Hits@10 0.9527186761229315 MRR 0.5714411444926667 rank 24 total_num 422 865\n",
      "checkcorrect (3851, 270, 4200) (3851, 270, 4200) real score 0.8060578405857086 Hits@1 0.3891509433962264 Hits@3 0.7004716981132075 Hits@10 0.9528301886792453 MRR 0.5724518965103728 rank 0 total_num 423 865\n",
      "checkcorrect (5962, 118, 4420) (5962, 118, 4420) real score 0.5472592234611511 Hits@1 0.3905882352941176 Hits@3 0.7011764705882353 Hits@10 0.9529411764705882 MRR 0.5734578920479954 rank 0 total_num 424 865\n",
      "checkcorrect (4207, 28, 4151) (4207, 28, 4151) real score 0.8792014300823212 Hits@1 0.38967136150234744 Hits@3 0.7018779342723005 Hits@10 0.9530516431924883 MRR 0.5728942193749563 rank 2 total_num 425 865\n",
      "checkcorrect (3998, 146, 4485) (3998, 146, 4485) real score 0.9235094696283341 Hits@1 0.38875878220140514 Hits@3 0.702576112412178 Hits@10 0.9531615925058547 MRR 0.5723331868549525 rank 2 total_num 426 865\n",
      "checkcorrect (5690, 96, 3727) (5690, 96, 3727) real score 0.9570110052824021 Hits@1 0.3878504672897196 Hits@3 0.7032710280373832 Hits@10 0.9532710280373832 MRR 0.5717747759822385 rank 2 total_num 427 865\n",
      "checkcorrect (4428, 6, 4523) (4428, 6, 4523) real score 0.9920856773853302 Hits@1 0.38927738927738925 Hits@3 0.703962703962704 Hits@10 0.9533799533799534 MRR 0.5727729699776178 rank 0 total_num 428 865\n",
      "checkcorrect (5023, 0, 3808) (5023, 0, 3808) real score 0.9751652121543884 Hits@1 0.3883720930232558 Hits@3 0.7046511627906977 Hits@10 0.9534883720930233 MRR 0.5726037305125536 rank 1 total_num 429 865\n",
      "checkcorrect (5130, 78, 5346) (5130, 78, 5346) real score 0.9590066969394684 Hits@1 0.3874709976798144 Hits@3 0.7053364269141531 Hits@10 0.9535962877030162 MRR 0.5720485787789592 rank 2 total_num 430 865\n",
      "checkcorrect (4898, 32, 3797) (4898, 32, 3797) real score 0.9800436317920684 Hits@1 0.38657407407407407 Hits@3 0.7060185185185185 Hits@10 0.9537037037037037 MRR 0.5718817996614153 rank 1 total_num 431 865\n",
      "checkcorrect (3959, 56, 3958) (3959, 56, 3958) real score 0.9156802684068679 Hits@1 0.38799076212471134 Hits@3 0.7066974595842956 Hits@10 0.953810623556582 MRR 0.5728705252973012 rank 0 total_num 432 865\n",
      "checkcorrect (6127, 158, 3885) (6127, 158, 3885) real score 0.9702747315168381 Hits@1 0.3870967741935484 Hits@3 0.7073732718894009 Hits@10 0.9539170506912442 MRR 0.5727026208611322 rank 1 total_num 433 865\n",
      "checkcorrect (3694, 78, 4730) (3694, 78, 4730) real score 0.9661716133356095 Hits@1 0.38850574712643676 Hits@3 0.7080459770114943 Hits@10 0.9540229885057471 MRR 0.5736849136867389 rank 0 total_num 434 865\n",
      "checkcorrect (4332, 64, 4320) (4332, 64, 4320) real score 0.9500303387641906 Hits@1 0.3876146788990826 Hits@3 0.7087155963302753 Hits@10 0.9541284403669725 MRR 0.573515911591127 rank 1 total_num 435 865\n",
      "checkcorrect (5993, 410, 3780) (5993, 410, 3780) real score 0.8306837111711503 Hits@1 0.38672768878718533 Hits@3 0.7093821510297483 Hits@10 0.954233409610984 MRR 0.572966294707242 rank 2 total_num 436 865\n",
      "checkcorrect (3758, 40, 4583) (3758, 40, 4583) real score 0.9841299861669541 Hits@1 0.3881278538812785 Hits@3 0.7100456621004566 Hits@10 0.954337899543379 MRR 0.573941257504714 rank 0 total_num 437 865\n",
      "checkcorrect (3822, 188, 4552) (3822, 188, 4552) real score 0.6464193567633629 Hits@1 0.3895216400911162 Hits@3 0.7107061503416856 Hits@10 0.9544419134396356 MRR 0.574911778558234 rank 0 total_num 438 865\n",
      "checkcorrect (4362, 58, 3851) (4362, 58, 3851) real score 0.9157259672880174 Hits@1 0.39090909090909093 Hits@3 0.7113636363636363 Hits@10 0.9545454545454546 MRR 0.5758778881524199 rank 0 total_num 439 865\n",
      "checkcorrect (4062, 44, 3669) (4062, 44, 3669) real score 0.9437629669904709 Hits@1 0.3922902494331066 Hits@3 0.7120181405895691 Hits@10 0.9546485260770975 MRR 0.5768396162971989 rank 0 total_num 440 865\n",
      "checkcorrect (4413, 54, 4337) (4413, 54, 4337) real score 0.9573797941207886 Hits@1 0.3914027149321267 Hits@3 0.7126696832579186 Hits@10 0.9547511312217195 MRR 0.5762886971049731 rank 2 total_num 441 865\n",
      "checkcorrect (3869, 96, 3727) (3869, 96, 3727) real score 0.9397782176733017 Hits@1 0.3905191873589165 Hits@3 0.7133182844243793 Hits@10 0.9548532731376975 MRR 0.5757402651325766 rank 2 total_num 442 865\n",
      "checkcorrect (3875, 22, 3846) (3875, 22, 3846) real score 0.967880380153656 Hits@1 0.38963963963963966 Hits@3 0.713963963963964 Hits@10 0.954954954954955 MRR 0.5755696789498456 rank 1 total_num 443 865\n",
      "checkcorrect (3911, 20, 4075) (3911, 20, 4075) real score 0.974983486533165 Hits@1 0.3887640449438202 Hits@3 0.7146067415730337 Hits@10 0.9550561797752809 MRR 0.5753998594465874 rank 1 total_num 444 865\n",
      "checkcorrect (3746, 78, 4191) (3746, 78, 4191) real score 0.9496754735708237 Hits@1 0.38789237668161436 Hits@3 0.7152466367713004 Hits@10 0.9551569506726457 MRR 0.5752308014657656 rank 1 total_num 445 865\n",
      "checkcorrect (4517, 134, 5561) (4517, 134, 5561) real score 0.8403788000345229 Hits@1 0.3870246085011186 Hits@3 0.7158836689038032 Hits@10 0.9552572706935123 MRR 0.5746896438189368 rank 2 total_num 446 865\n",
      "checkcorrect (4390, 40, 4240) (4390, 40, 4240) real score 0.9462954550981522 Hits@1 0.3861607142857143 Hits@3 0.7142857142857143 Hits@10 0.9553571428571429 MRR 0.5738532830068409 rank 4 total_num 447 865\n",
      "checkcorrect (5710, 4, 3776) (5710, 4, 3776) real score 0.983223482966423 Hits@1 0.38752783964365256 Hits@3 0.7149220489977728 Hits@10 0.955456570155902 MRR 0.5748023848264248 rank 0 total_num 448 865\n",
      "checkcorrect (4106, 28, 4065) (4106, 28, 4065) real score 0.9003218412399292 Hits@1 0.38666666666666666 Hits@3 0.7155555555555555 Hits@10 0.9555555555555556 MRR 0.5746361573045883 rank 1 total_num 449 865\n",
      "checkcorrect (4976, 186, 4369) (4976, 186, 4369) real score 0.7675319567322731 Hits@1 0.3858093126385809 Hits@3 0.7139689578713969 Hits@10 0.9556541019955654 MRR 0.5736083855835384 rank 8 total_num 450 865\n",
      "checkcorrect (4331, 44, 3669) (4331, 44, 3669) real score 0.9468981474637985 Hits@1 0.38495575221238937 Hits@3 0.7146017699115044 Hits@10 0.9557522123893806 MRR 0.5730768036095335 rank 2 total_num 451 865\n",
      "checkcorrect (4075, 210, 4923) (4075, 210, 4923) real score 0.9144234657287598 Hits@1 0.38631346578366443 Hits@3 0.7152317880794702 Hits@10 0.9558498896247241 MRR 0.5740192389216537 rank 0 total_num 452 865\n",
      "checkcorrect (4240, 22, 5019) (4240, 22, 5019) real score 0.9295262128114701 Hits@1 0.3854625550660793 Hits@3 0.7136563876651982 Hits@10 0.9559471365638766 MRR 0.5731954079989188 rank 4 total_num 453 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3763, 70, 4758) (3763, 70, 4758) real score 0.9591563105583191 Hits@1 0.38461538461538464 Hits@3 0.7142857142857143 Hits@10 0.9560439560439561 MRR 0.5730345389703497 rank 1 total_num 454 865\n",
      "checkcorrect (3822, 188, 5347) (3822, 188, 5347) real score 0.6809671610593796 Hits@1 0.38596491228070173 Hits@3 0.7149122807017544 Hits@10 0.956140350877193 MRR 0.5739708667357656 rank 0 total_num 455 865\n",
      "checkcorrect (4718, 96, 3727) (4718, 96, 3727) real score 0.971587061882019 Hits@1 0.387308533916849 Hits@3 0.7155361050328227 Hits@10 0.9562363238512035 MRR 0.5749030967866721 rank 0 total_num 456 865\n",
      "checkcorrect (5331, 58, 3943) (5331, 58, 3943) real score 0.9281045913696289 Hits@1 0.3864628820960699 Hits@3 0.7161572052401747 Hits@10 0.9563318777292577 MRR 0.5743756518883023 rank 2 total_num 457 865\n",
      "checkcorrect (5247, 246, 5298) (5247, 246, 5298) real score 0.925379729270935 Hits@1 0.3877995642701525 Hits@3 0.7167755991285403 Hits@10 0.9564270152505446 MRR 0.5753029380497656 rank 0 total_num 458 865\n",
      "checkcorrect (3912, 6, 4075) (3912, 6, 4075) real score 0.9920493811368942 Hits@1 0.38913043478260867 Hits@3 0.717391304347826 Hits@10 0.9565217391304348 MRR 0.5762261925322661 rank 0 total_num 459 865\n",
      "checkcorrect (4275, 50, 3671) (4275, 50, 3671) real score 0.7998061358928681 Hits@1 0.3882863340563991 Hits@3 0.7158351409978309 Hits@10 0.9566160520607375 MRR 0.575518543524604 rank 3 total_num 460 865\n",
      "checkcorrect (5300, 64, 4808) (5300, 64, 4808) real score 0.9353598177433013 Hits@1 0.3874458874458874 Hits@3 0.7164502164502164 Hits@10 0.9567099567099567 MRR 0.5749943331129346 rank 2 total_num 461 865\n",
      "checkcorrect (5472, 96, 3727) (5472, 96, 3727) real score 0.9787490099668503 Hits@1 0.38876889848812096 Hits@3 0.7170626349892009 Hits@10 0.9568034557235421 MRR 0.5759122719183062 rank 0 total_num 462 865\n",
      "checkcorrect (5543, 96, 3993) (5543, 96, 3993) real score 0.0 Hits@1 0.3879310344827586 Hits@3 0.7155172413793104 Hits@10 0.9547413793103449 MRR 0.5747263425082259 rank 38 total_num 463 865\n",
      "checkcorrect (4032, 96, 4756) (4032, 96, 4756) real score 0.8541196495294571 Hits@1 0.3870967741935484 Hits@3 0.7139784946236559 Hits@10 0.9548387096774194 MRR 0.5737293205052213 rank 8 total_num 464 865\n",
      "checkcorrect (5533, 240, 5864) (5533, 240, 5864) real score 0.0 Hits@1 0.38626609442060084 Hits@3 0.7124463519313304 Hits@10 0.9527896995708155 MRR 0.5725914426948443 rank 22 total_num 465 865\n",
      "checkcorrect (4024, 54, 4197) (4024, 54, 4197) real score 0.9527577549219131 Hits@1 0.3875802997858672 Hits@3 0.7130620985010707 Hits@10 0.9528907922912205 MRR 0.5735066644449625 rank 0 total_num 466 865\n",
      "checkcorrect (4123, 312, 5005) (4123, 312, 5005) real score 0.7494067534804344 Hits@1 0.38675213675213677 Hits@3 0.7115384615384616 Hits@10 0.9529914529914529 MRR 0.5726373482103935 rank 5 total_num 467 865\n",
      "checkcorrect (4942, 54, 5178) (4942, 54, 5178) real score 0.6365881443023682 Hits@1 0.3859275053304904 Hits@3 0.7100213219616205 Hits@10 0.9509594882729211 MRR 0.571568672780155 rank 13 total_num 468 865\n",
      "checkcorrect (3714, 146, 4097) (3714, 146, 4097) real score 0.9180059611797333 Hits@1 0.3851063829787234 Hits@3 0.7106382978723405 Hits@10 0.951063829787234 MRR 0.5714163990082823 rank 1 total_num 469 865\n",
      "checkcorrect (4817, 334, 5581) (4817, 334, 5581) real score 0.8643897861242295 Hits@1 0.386411889596603 Hits@3 0.7112526539278131 Hits@10 0.9511677282377919 MRR 0.5723263429594325 rank 0 total_num 470 865\n",
      "checkcorrect (5224, 198, 5745) (5224, 198, 5745) real score 0.9291878581047057 Hits@1 0.3855932203389831 Hits@3 0.711864406779661 Hits@10 0.951271186440678 MRR 0.5721731091819761 rank 1 total_num 471 865\n",
      "checkcorrect (3864, 22, 3908) (3864, 22, 3908) real score 0.9707918018102646 Hits@1 0.386892177589852 Hits@3 0.7124735729386892 Hits@10 0.9513742071881607 MRR 0.5730776057799 rank 0 total_num 472 865\n",
      "checkcorrect (5377, 248, 4411) (5377, 248, 4411) real score 0.9580114841461181 Hits@1 0.3881856540084388 Hits@3 0.7130801687763713 Hits@10 0.9514767932489452 MRR 0.5739782859364825 rank 0 total_num 473 865\n",
      "checkcorrect (4260, 0, 4100) (4260, 0, 4100) real score 0.9733391880989075 Hits@1 0.3894736842105263 Hits@3 0.7136842105263158 Hits@10 0.9515789473684211 MRR 0.5748751737555635 rank 0 total_num 474 865\n",
      "checkcorrect (5140, 206, 4509) (5140, 206, 4509) real score 0.9580441176891327 Hits@1 0.38865546218487396 Hits@3 0.7142857142857143 Hits@10 0.9516806722689075 MRR 0.5747178729703628 rank 1 total_num 475 865\n",
      "checkcorrect (5801, 64, 3703) (5801, 64, 3703) real score 0.9565261781215668 Hits@1 0.38784067085953877 Hits@3 0.7148846960167715 Hits@10 0.9517819706498952 MRR 0.574211825717455 rank 2 total_num 476 865\n",
      "checkcorrect (3747, 50, 5332) (3747, 50, 5332) real score 0.9665139943361283 Hits@1 0.3891213389121339 Hits@3 0.7154811715481172 Hits@10 0.9518828451882845 MRR 0.5751025959565398 rank 0 total_num 477 865\n",
      "checkcorrect (3789, 58, 3944) (3789, 58, 3944) real score 0.961094132065773 Hits@1 0.3903966597077244 Hits@3 0.7160751565762005 Hits@10 0.9519832985386222 MRR 0.5759896469044384 rank 0 total_num 478 865\n",
      "checkcorrect (3940, 54, 3887) (3940, 54, 3887) real score 0.970293989777565 Hits@1 0.39166666666666666 Hits@3 0.7166666666666667 Hits@10 0.9520833333333333 MRR 0.5768730018067209 rank 0 total_num 479 865\n",
      "checkcorrect (4352, 32, 4593) (4352, 32, 4593) real score 0.978653484582901 Hits@1 0.3908523908523909 Hits@3 0.7151767151767152 Hits@10 0.9521829521829522 MRR 0.5761934321563951 rank 3 total_num 480 865\n",
      "checkcorrect (4238, 266, 4160) (4238, 266, 4160) real score 0.9044092416763305 Hits@1 0.3900414937759336 Hits@3 0.7157676348547718 Hits@10 0.9522821576763485 MRR 0.5756895730302061 rank 2 total_num 481 865\n",
      "checkcorrect (4049, 64, 4767) (4049, 64, 4767) real score 0.93659747838974 Hits@1 0.38923395445134573 Hits@3 0.7163561076604554 Hits@10 0.9523809523809523 MRR 0.5751878002772104 rank 2 total_num 482 865\n",
      "checkcorrect (4873, 32, 4593) (4873, 32, 4593) real score 0.9789799571037292 Hits@1 0.3884297520661157 Hits@3 0.7169421487603306 Hits@10 0.9524793388429752 MRR 0.5746881009653428 rank 2 total_num 483 865\n",
      "checkcorrect (5055, 216, 4443) (5055, 216, 4443) real score 0.8476457476615906 Hits@1 0.38762886597938145 Hits@3 0.7175257731958763 Hits@10 0.9525773195876288 MRR 0.5745341048808782 rank 1 total_num 484 865\n",
      "checkcorrect (3701, 78, 3764) (3701, 78, 3764) real score 0.8569825768470765 Hits@1 0.3868312757201646 Hits@3 0.7160493827160493 Hits@10 0.9526748971193416 MRR 0.5737634585745389 rank 4 total_num 485 865\n",
      "checkcorrect (3910, 64, 4409) (3910, 64, 4409) real score 0.3350315272808075 Hits@1 0.3860369609856263 Hits@3 0.7145790554414785 Hits@10 0.9507186858316222 MRR 0.572706087056751 rank 16 total_num 486 865\n",
      "checkcorrect (3848, 32, 4118) (3848, 32, 4118) real score 0.9815663039684295 Hits@1 0.38729508196721313 Hits@3 0.7151639344262295 Hits@10 0.9508196721311475 MRR 0.5735816893373723 rank 0 total_num 487 865\n",
      "checkcorrect (4504, 0, 3808) (4504, 0, 3808) real score 0.8015993162989616 Hits@1 0.38650306748466257 Hits@3 0.7157464212678937 Hits@10 0.950920245398773 MRR 0.5730903839058712 rank 2 total_num 488 865\n",
      "checkcorrect (5136, 40, 3763) (5136, 40, 3763) real score 0.959693220257759 Hits@1 0.38571428571428573 Hits@3 0.7163265306122449 Hits@10 0.9510204081632653 MRR 0.5729412198570837 rank 1 total_num 489 865\n",
      "checkcorrect (3787, 70, 5193) (3787, 70, 5193) real score 0.9654447346925736 Hits@1 0.384928716904277 Hits@3 0.7169042769857433 Hits@10 0.9511201629327902 MRR 0.572792663401163 rank 1 total_num 490 865\n",
      "checkcorrect (4902, 54, 3976) (4902, 54, 3976) real score 0.9659238368272782 Hits@1 0.3861788617886179 Hits@3 0.717479674796748 Hits@10 0.9512195121951219 MRR 0.5736609709958761 rank 0 total_num 491 865\n",
      "checkcorrect (4144, 50, 4337) (4144, 50, 4337) real score 0.9469571143388749 Hits@1 0.385395537525355 Hits@3 0.716024340770791 Hits@10 0.9513184584178499 MRR 0.5730044578701238 rank 3 total_num 492 865\n",
      "checkcorrect (4473, 172, 4612) (4473, 172, 4612) real score 0.9925448805093766 Hits@1 0.3866396761133603 Hits@3 0.7165991902834008 Hits@10 0.951417004048583 MRR 0.5738688213157308 rank 0 total_num 493 865\n",
      "checkcorrect (4171, 258, 5520) (4171, 258, 5520) real score 0.9849510133266449 Hits@1 0.3878787878787879 Hits@3 0.7171717171717171 Hits@10 0.9515151515151515 MRR 0.5747296923837798 rank 0 total_num 494 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4030, 146, 5325) (4030, 146, 5325) real score 0.8660205930471421 Hits@1 0.3870967741935484 Hits@3 0.7157258064516129 Hits@10 0.9516129032258065 MRR 0.5738229792942964 rank 7 total_num 495 865\n",
      "checkcorrect (4332, 50, 5040) (4332, 50, 5040) real score 0.9704994171857835 Hits@1 0.38832997987927564 Hits@3 0.716297786720322 Hits@10 0.9517102615694165 MRR 0.5746804783299215 rank 0 total_num 496 865\n",
      "checkcorrect (5364, 88, 5923) (5364, 88, 5923) real score 0.9008889466524124 Hits@1 0.38755020080321284 Hits@3 0.7168674698795181 Hits@10 0.9518072289156626 MRR 0.5745305175300622 rank 1 total_num 497 865\n",
      "checkcorrect (5061, 144, 5678) (5061, 144, 5678) real score 0.49206445813179017 Hits@1 0.38877755511022044 Hits@3 0.717434869739479 Hits@10 0.9519038076152304 MRR 0.575383161783509 rank 0 total_num 498 865\n",
      "checkcorrect (3997, 44, 3669) (3997, 44, 3669) real score 0.9430035799741745 Hits@1 0.388 Hits@3 0.718 Hits@10 0.952 MRR 0.5752323954599421 rank 1 total_num 499 865\n",
      "checkcorrect (4124, 266, 4587) (4124, 266, 4587) real score 0.9300246298313141 Hits@1 0.38922155688622756 Hits@3 0.718562874251497 Hits@10 0.9520958083832335 MRR 0.5760802349899621 rank 0 total_num 500 865\n",
      "checkcorrect (5477, 70, 3979) (5477, 70, 3979) real score 0.9514745891094207 Hits@1 0.3884462151394422 Hits@3 0.7191235059760956 Hits@10 0.952191235059761 MRR 0.575596675424909 rank 2 total_num 501 865\n",
      "checkcorrect (4942, 146, 4097) (4942, 146, 4097) real score 0.9036938816308975 Hits@1 0.38767395626242546 Hits@3 0.7176938369781312 Hits@10 0.952286282306163 MRR 0.5749493659310225 rank 3 total_num 502 865\n",
      "checkcorrect (5288, 404, 5287) (5288, 404, 5287) real score 0.0 Hits@1 0.3869047619047619 Hits@3 0.7162698412698413 Hits@10 0.9503968253968254 MRR 0.5738547358675751 rank 42 total_num 503 865\n",
      "checkcorrect (5869, 142, 4341) (5869, 142, 4341) real score 0.7188120394945146 Hits@1 0.38613861386138615 Hits@3 0.7148514851485148 Hits@10 0.9504950495049505 MRR 0.5732134393609065 rank 3 total_num 504 865\n",
      "checkcorrect (4681, 30, 4111) (4681, 30, 4111) real score 0.9220862090587616 Hits@1 0.38537549407114624 Hits@3 0.7154150197628458 Hits@10 0.950592885375494 MRR 0.5727393680051208 rank 2 total_num 505 865\n",
      "checkcorrect (4226, 194, 3770) (4226, 194, 3770) real score 0.78529012799263 Hits@1 0.38461538461538464 Hits@3 0.7140039447731755 Hits@10 0.9506903353057199 MRR 0.5720041818749332 rank 4 total_num 506 865\n",
      "checkcorrect (4812, 420, 5617) (4812, 420, 5617) real score 0.33921860009431837 Hits@1 0.3838582677165354 Hits@3 0.7145669291338582 Hits@10 0.9507874015748031 MRR 0.5718624413594313 rank 1 total_num 507 865\n",
      "checkcorrect (5919, 78, 4039) (5919, 78, 4039) real score 0.9642166346311569 Hits@1 0.3850687622789784 Hits@3 0.7151277013752456 Hits@10 0.9508840864440079 MRR 0.5727035760522419 rank 0 total_num 508 865\n",
      "checkcorrect (5066, 48, 5443) (5066, 48, 5443) real score 0.4361056059598923 Hits@1 0.3843137254901961 Hits@3 0.7137254901960784 Hits@10 0.9490196078431372 MRR 0.5717206838863131 rank 13 total_num 509 865\n",
      "checkcorrect (4298, 54, 5452) (4298, 54, 5452) real score 0.9733078330755234 Hits@1 0.38551859099804303 Hits@3 0.7142857142857143 Hits@10 0.949119373776908 MRR 0.5725588038787078 rank 0 total_num 510 865\n",
      "checkcorrect (4038, 12, 4035) (4038, 12, 4035) real score 0.9752342849969864 Hits@1 0.384765625 Hits@3 0.71484375 Hits@10 0.94921875 MRR 0.5720915666315488 rank 2 total_num 511 865\n",
      "checkcorrect (4247, 146, 3770) (4247, 146, 3770) real score 0.8996964454650879 Hits@1 0.3840155945419103 Hits@3 0.7153996101364523 Hits@10 0.949317738791423 MRR 0.571626150972098 rank 2 total_num 512 865\n",
      "checkcorrect (4353, 22, 4478) (4353, 22, 4478) real score 0.9688549429178238 Hits@1 0.3832684824902724 Hits@3 0.7159533073929961 Hits@10 0.9494163424124513 MRR 0.5711625462685207 rank 2 total_num 513 865\n",
      "checkcorrect (4428, 6, 4917) (4428, 6, 4917) real score 0.9920796900987625 Hits@1 0.3825242718446602 Hits@3 0.7165048543689321 Hits@10 0.9495145631067962 MRR 0.5710243665670284 rank 1 total_num 514 865\n",
      "checkcorrect (4247, 360, 4367) (4247, 360, 4367) real score 0.6913444325327873 Hits@1 0.3817829457364341 Hits@3 0.7170542635658915 Hits@10 0.9496124031007752 MRR 0.5705637250297537 rank 2 total_num 515 865\n",
      "checkcorrect (6005, 262, 4487) (6005, 262, 4487) real score 0.9377142488956451 Hits@1 0.3829787234042553 Hits@3 0.7176015473887815 Hits@10 0.9497098646034816 MRR 0.5713943561225395 rank 0 total_num 516 865\n",
      "checkcorrect (4649, 108, 5924) (4649, 108, 5924) real score 0.4879623383283615 Hits@1 0.3841698841698842 Hits@3 0.7181467181467182 Hits@10 0.9498069498069498 MRR 0.572221780145469 rank 0 total_num 517 865\n",
      "checkcorrect (5195, 50, 5081) (5195, 50, 5081) real score 0.8448764532804489 Hits@1 0.3834296724470135 Hits@3 0.7167630057803468 Hits@10 0.9499036608863198 MRR 0.5715045898176356 rank 4 total_num 518 865\n",
      "checkcorrect (3988, 52, 3943) (3988, 52, 3943) real score 0.9711229234933854 Hits@1 0.38461538461538464 Hits@3 0.7173076923076923 Hits@10 0.95 MRR 0.5723286194526018 rank 0 total_num 519 865\n",
      "checkcorrect (4761, 96, 3727) (4761, 96, 3727) real score 0.9023533761501312 Hits@1 0.3838771593090211 Hits@3 0.7159309021113244 Hits@10 0.9500959692898272 MRR 0.5715499976622257 rank 5 total_num 520 865\n",
      "checkcorrect (4874, 0, 4400) (4874, 0, 4400) real score 0.9793752193450928 Hits@1 0.3850574712643678 Hits@3 0.7164750957854407 Hits@10 0.9501915708812261 MRR 0.5723707831073173 rank 0 total_num 521 865\n",
      "checkcorrect (4657, 112, 5419) (4657, 112, 5419) real score 0.8564458638429642 Hits@1 0.384321223709369 Hits@3 0.7170172084130019 Hits@10 0.9502868068833652 MRR 0.5722324068489859 rank 1 total_num 522 865\n",
      "checkcorrect (4899, 70, 4388) (4899, 70, 4388) real score 0.9274211287498474 Hits@1 0.383587786259542 Hits@3 0.7156488549618321 Hits@10 0.950381679389313 MRR 0.571617459507671 rank 3 total_num 523 865\n",
      "checkcorrect (5992, 322, 3904) (5992, 322, 3904) real score 0.9652066707611084 Hits@1 0.38476190476190475 Hits@3 0.7161904761904762 Hits@10 0.9504761904761905 MRR 0.5724334262514659 rank 0 total_num 524 865\n",
      "checkcorrect (4366, 24, 4739) (4366, 24, 4739) real score 0.8776390224695205 Hits@1 0.3840304182509506 Hits@3 0.714828897338403 Hits@10 0.9505703422053232 MRR 0.5716620065564378 rank 5 total_num 525 865\n",
      "checkcorrect (4994, 2, 4861) (4994, 2, 4861) real score 0.8197756320238114 Hits@1 0.38330170777988615 Hits@3 0.713472485768501 Hits@10 0.9506641366223909 MRR 0.5709567655572795 rank 4 total_num 526 865\n",
      "checkcorrect (3902, 212, 3931) (3902, 212, 3931) real score 0.8422734439373016 Hits@1 0.38257575757575757 Hits@3 0.7121212121212122 Hits@10 0.9507575757575758 MRR 0.5702541959255422 rank 4 total_num 527 865\n",
      "checkcorrect (3694, 78, 5865) (3694, 78, 5865) real score 0.0 Hits@1 0.3818525519848771 Hits@3 0.7107750472589792 Hits@10 0.9489603024574669 MRR 0.5692182186595623 rank 44 total_num 528 865\n",
      "checkcorrect (4220, 266, 3931) (4220, 266, 3931) real score 0.8249473094940185 Hits@1 0.38113207547169814 Hits@3 0.7094339622641509 Hits@10 0.9490566037735849 MRR 0.5686159201337896 rank 3 total_num 529 865\n",
      "checkcorrect (5830, 48, 3770) (5830, 48, 3770) real score 0.9500619262456894 Hits@1 0.3804143126177024 Hits@3 0.7099811676082862 Hits@10 0.9491525423728814 MRR 0.5684866999452137 rank 1 total_num 530 865\n",
      "checkcorrect (4604, 96, 3727) (4604, 96, 3727) real score 0.9251930445432663 Hits@1 0.37969924812030076 Hits@3 0.7086466165413534 Hits@10 0.9492481203007519 MRR 0.5677940557723844 rank 4 total_num 531 865\n",
      "checkcorrect (4687, 386, 4506) (4687, 386, 4506) real score 0.885340964794159 Hits@1 0.3808630393996248 Hits@3 0.7091932457786116 Hits@10 0.949343339587242 MRR 0.5686049487259072 rank 0 total_num 532 865\n",
      "checkcorrect (3710, 116, 5188) (3710, 116, 5188) real score 0.8849161475896836 Hits@1 0.3801498127340824 Hits@3 0.7097378277153558 Hits@10 0.949438202247191 MRR 0.5681643651764828 rank 2 total_num 533 865\n",
      "checkcorrect (5810, 102, 3808) (5810, 102, 3808) real score 0.8778481662273407 Hits@1 0.3794392523364486 Hits@3 0.708411214953271 Hits@10 0.9495327102803738 MRR 0.5674762074845641 rank 4 total_num 534 865\n",
      "checkcorrect (4803, 44, 3669) (4803, 44, 3669) real score 0.9501014202833176 Hits@1 0.3787313432835821 Hits@3 0.7089552238805971 Hits@10 0.9496268656716418 MRR 0.5670393737641327 rank 2 total_num 535 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5144, 354, 5206) (5144, 354, 5206) real score 0.9142474263906479 Hits@1 0.3780260707635009 Hits@3 0.7094972067039106 Hits@10 0.9497206703910615 MRR 0.5669145332170858 rank 1 total_num 536 865\n",
      "checkcorrect (4834, 0, 4791) (4834, 0, 4791) real score 0.9309058874845504 Hits@1 0.37732342007434944 Hits@3 0.7100371747211895 Hits@10 0.949814126394052 MRR 0.5667901567612921 rank 1 total_num 537 865\n",
      "checkcorrect (5213, 78, 4690) (5213, 78, 4690) real score 0.9141891598701477 Hits@1 0.37662337662337664 Hits@3 0.7105751391465677 Hits@10 0.9499072356215214 MRR 0.566357027218754 rank 2 total_num 538 865\n",
      "checkcorrect (6001, 240, 3694) (6001, 240, 3694) real score 0.9493356078863144 Hits@1 0.37592592592592594 Hits@3 0.7111111111111111 Hits@10 0.95 MRR 0.5662341438350156 rank 1 total_num 539 865\n",
      "checkcorrect (6003, 168, 3924) (6003, 168, 3924) real score 0.9734711229801178 Hits@1 0.3752310536044362 Hits@3 0.711645101663586 Hits@10 0.9500924214417745 MRR 0.5658036432610754 rank 2 total_num 540 865\n",
      "checkcorrect (3875, 22, 5637) (3875, 22, 5637) real score 0.9604832589626313 Hits@1 0.3763837638376384 Hits@3 0.7121771217712177 Hits@10 0.9501845018450185 MRR 0.5666047435502615 rank 0 total_num 541 865\n",
      "checkcorrect (3865, 0, 3904) (3865, 0, 3904) real score 0.8991123884916306 Hits@1 0.3756906077348066 Hits@3 0.712707182320442 Hits@10 0.9502762430939227 MRR 0.5664820828807399 rank 1 total_num 542 865\n",
      "checkcorrect (4649, 298, 4067) (4649, 298, 4067) real score 0.9563755869865418 Hits@1 0.37683823529411764 Hits@3 0.7132352941176471 Hits@10 0.9503676470588235 MRR 0.5672789908166208 rank 0 total_num 543 865\n",
      "checkcorrect (4186, 44, 3669) (4186, 44, 3669) real score 0.92524696290493 Hits@1 0.3761467889908257 Hits@3 0.7119266055045872 Hits@10 0.9504587155963303 MRR 0.5665439223319421 rank 5 total_num 544 865\n",
      "checkcorrect (5711, 96, 3727) (5711, 96, 3727) real score 0.9765871286392211 Hits@1 0.3772893772893773 Hits@3 0.7124542124542125 Hits@10 0.9505494505494505 MRR 0.5673377979320667 rank 0 total_num 545 865\n",
      "checkcorrect (4414, 32, 3797) (4414, 32, 3797) real score 0.9519884973764419 Hits@1 0.376599634369287 Hits@3 0.7111517367458866 Hits@10 0.9506398537477148 MRR 0.5666662480272548 rank 4 total_num 546 865\n",
      "checkcorrect (4955, 50, 4023) (4955, 50, 4023) real score 0.966167116165161 Hits@1 0.3777372262773723 Hits@3 0.7116788321167883 Hits@10 0.9507299270072993 MRR 0.567457003049103 rank 0 total_num 547 865\n",
      "checkcorrect (4129, 12, 3687) (4129, 12, 3687) real score 0.9759026527404785 Hits@1 0.3770491803278688 Hits@3 0.7122040072859745 Hits@10 0.9508196721311475 MRR 0.5670305482773074 rank 2 total_num 548 865\n",
      "checkcorrect (3694, 78, 5339) (3694, 78, 5339) real score 0.9660513252019882 Hits@1 0.3781818181818182 Hits@3 0.7127272727272728 Hits@10 0.9509090909090909 MRR 0.5678177654622577 rank 0 total_num 549 865\n",
      "checkcorrect (3916, 36, 4313) (3916, 36, 4313) real score 0.9272010654211045 Hits@1 0.3793103448275862 Hits@3 0.7132486388384754 Hits@10 0.9509981851179673 MRR 0.5686021252345586 rank 0 total_num 550 865\n",
      "checkcorrect (4273, 128, 5789) (4273, 128, 5789) real score 0.4282547354698181 Hits@1 0.3804347826086957 Hits@3 0.7137681159420289 Hits@10 0.9510869565217391 MRR 0.5693836431236263 rank 0 total_num 551 865\n",
      "checkcorrect (5086, 172, 3781) (5086, 172, 3781) real score 0.9904593437910081 Hits@1 0.38155515370705245 Hits@3 0.7142857142857143 Hits@10 0.9511754068716094 MRR 0.5701623345465493 rank 0 total_num 552 865\n",
      "checkcorrect (3813, 78, 5324) (3813, 78, 5324) real score 0.8991563379764558 Hits@1 0.38267148014440433 Hits@3 0.7148014440433214 Hits@10 0.9512635379061372 MRR 0.5709382148091006 rank 0 total_num 553 865\n",
      "checkcorrect (3920, 224, 5330) (3920, 224, 5330) real score 0.9046169251203537 Hits@1 0.3837837837837838 Hits@3 0.7153153153153153 Hits@10 0.9513513513513514 MRR 0.5717112991067419 rank 0 total_num 554 865\n",
      "checkcorrect (4657, 112, 6061) (4657, 112, 6061) real score 0.4342306673526764 Hits@1 0.3830935251798561 Hits@3 0.7140287769784173 Hits@10 0.9514388489208633 MRR 0.5708828815024332 rank 8 total_num 555 865\n",
      "checkcorrect (3764, 48, 3770) (3764, 48, 3770) real score 0.9334532588720321 Hits@1 0.38240574506283664 Hits@3 0.7145421903052065 Hits@10 0.9515260323159784 MRR 0.570755623187348 rank 1 total_num 556 865\n",
      "checkcorrect (4224, 96, 3727) (4224, 96, 3727) real score 0.9163249433040619 Hits@1 0.3817204301075269 Hits@3 0.7132616487455197 Hits@10 0.9516129032258065 MRR 0.5700911865866538 rank 4 total_num 557 865\n",
      "checkcorrect (4629, 382, 4088) (4629, 382, 4088) real score 0.9641640961170197 Hits@1 0.3828264758497317 Hits@3 0.7137745974955277 Hits@10 0.9516994633273703 MRR 0.5708602542314004 rank 0 total_num 558 865\n",
      "checkcorrect (4938, 190, 4138) (4938, 190, 4138) real score 0.8479059427976607 Hits@1 0.3821428571428571 Hits@3 0.7142857142857143 Hits@10 0.9517857142857142 MRR 0.57073371806313 rank 1 total_num 559 865\n",
      "checkcorrect (3748, 24, 5646) (3748, 24, 5646) real score 0.9318135440349579 Hits@1 0.38146167557932265 Hits@3 0.714795008912656 Hits@10 0.9518716577540107 MRR 0.5703105444718113 rank 2 total_num 560 865\n",
      "checkcorrect (4583, 22, 4260) (4583, 22, 4260) real score 0.9548398017883301 Hits@1 0.38256227758007116 Hits@3 0.7153024911032029 Hits@10 0.9519572953736655 MRR 0.5710751164567369 rank 0 total_num 561 865\n",
      "checkcorrect (4609, 206, 4285) (4609, 206, 4285) real score 0.9595595836639403 Hits@1 0.3836589698046181 Hits@3 0.7158081705150977 Hits@10 0.9520426287744227 MRR 0.5718369723777729 rank 0 total_num 562 865\n",
      "checkcorrect (4926, 64, 5642) (4926, 64, 5642) real score 0.925045871734619 Hits@1 0.3829787234042553 Hits@3 0.7145390070921985 Hits@10 0.9521276595744681 MRR 0.5712663394480251 rank 3 total_num 563 865\n",
      "checkcorrect (3802, 96, 3727) (3802, 96, 3727) real score 0.9777566701173782 Hits@1 0.384070796460177 Hits@3 0.7150442477876107 Hits@10 0.952212389380531 MRR 0.5720251600861701 rank 0 total_num 564 865\n",
      "checkcorrect (5324, 194, 3990) (5324, 194, 3990) real score 0.7949655443429946 Hits@1 0.3833922261484099 Hits@3 0.715547703180212 Hits@10 0.9522968197879859 MRR 0.5718979071531557 rank 1 total_num 565 865\n",
      "checkcorrect (5357, 96, 3993) (5357, 96, 3993) real score 0.9774393141269684 Hits@1 0.3844797178130511 Hits@3 0.7160493827160493 Hits@10 0.9523809523809523 MRR 0.57265293729927 rank 0 total_num 566 865\n",
      "checkcorrect (4613, 390, 5429) (4613, 390, 5429) real score 0.9298214167356491 Hits@1 0.38380281690140844 Hits@3 0.7165492957746479 Hits@10 0.9524647887323944 MRR 0.572525027198391 rank 1 total_num 567 865\n",
      "checkcorrect (3876, 356, 5617) (3876, 356, 5617) real score 0.6302369616925716 Hits@1 0.38488576449912126 Hits@3 0.7170474516695958 Hits@10 0.9525483304042179 MRR 0.5732763013157929 rank 0 total_num 568 865\n",
      "checkcorrect (4017, 206, 4067) (4017, 206, 4067) real score 0.9598639070987702 Hits@1 0.38596491228070173 Hits@3 0.7175438596491228 Hits@10 0.9526315789473684 MRR 0.5740249393836598 rank 0 total_num 569 865\n",
      "checkcorrect (5295, 50, 4441) (5295, 50, 4441) real score 0.8874625742435456 Hits@1 0.38528896672504376 Hits@3 0.7162872154115587 Hits@10 0.9527145359019265 MRR 0.5733699044635484 rank 4 total_num 570 865\n",
      "checkcorrect (5385, 264, 4452) (5385, 264, 4452) real score 0.32894967794418334 Hits@1 0.38461538461538464 Hits@3 0.715034965034965 Hits@10 0.9527972027972028 MRR 0.5725423347005002 rank 9 total_num 571 865\n",
      "checkcorrect (4949, 54, 3897) (4949, 54, 3897) real score 0.9120435118675232 Hits@1 0.38394415357766143 Hits@3 0.7155322862129145 Hits@10 0.9528795811518325 MRR 0.5724157337673406 rank 1 total_num 572 865\n",
      "checkcorrect (3719, 40, 4621) (3719, 40, 4621) real score 0.9851607322692871 Hits@1 0.38501742160278746 Hits@3 0.7160278745644599 Hits@10 0.9529616724738676 MRR 0.5731606540917877 rank 0 total_num 573 865\n",
      "checkcorrect (3801, 70, 3724) (3801, 70, 3724) real score 0.9779490500688552 Hits@1 0.38608695652173913 Hits@3 0.7165217391304348 Hits@10 0.9530434782608695 MRR 0.5739029833890193 rank 0 total_num 574 865\n",
      "checkcorrect (5442, 96, 3727) (5442, 96, 3727) real score 0.9040864735841752 Hits@1 0.3854166666666667 Hits@3 0.7152777777777778 Hits@10 0.953125 MRR 0.5733406518206356 rank 3 total_num 575 865\n",
      "checkcorrect (5112, 44, 3669) (5112, 44, 3669) real score 0.8998467087745666 Hits@1 0.3847487001733102 Hits@3 0.7140381282495667 Hits@10 0.9532062391681109 MRR 0.5727802694084682 rank 3 total_num 576 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3746, 78, 5339) (3746, 78, 5339) real score 0.9604073852300644 Hits@1 0.38408304498269896 Hits@3 0.7145328719723183 Hits@10 0.9532871972318339 MRR 0.5723660013529748 rank 2 total_num 577 865\n",
      "checkcorrect (3940, 164, 3982) (3940, 164, 3982) real score 0.8056634932756424 Hits@1 0.385146804835924 Hits@3 0.7150259067357513 Hits@10 0.9533678756476683 MRR 0.5731045747530561 rank 0 total_num 578 865\n",
      "checkcorrect (4455, 204, 5377) (4455, 204, 5377) real score 0.9919013679027557 Hits@1 0.38620689655172413 Hits@3 0.7155172413793104 Hits@10 0.9534482758620689 MRR 0.5738406013483094 rank 0 total_num 579 865\n",
      "checkcorrect (4637, 148, 4791) (4637, 148, 4791) real score 0.9556611895561218 Hits@1 0.387263339070568 Hits@3 0.7160068846815835 Hits@10 0.9535283993115319 MRR 0.5745740942891902 rank 0 total_num 580 865\n",
      "checkcorrect (4362, 58, 3943) (4362, 58, 3943) real score 0.9613660275936127 Hits@1 0.38831615120274915 Hits@3 0.7164948453608248 Hits@10 0.9536082474226805 MRR 0.5753050666357723 rank 0 total_num 581 865\n",
      "checkcorrect (4003, 382, 4088) (4003, 382, 4088) real score 0.9559032261371612 Hits@1 0.3893653516295026 Hits@3 0.7169811320754716 Hits@10 0.9536878216123499 MRR 0.576033531358524 rank 0 total_num 582 865\n",
      "checkcorrect (3875, 22, 3691) (3875, 22, 3691) real score 0.9333552896976471 Hits@1 0.3886986301369863 Hits@3 0.7174657534246576 Hits@10 0.9537671232876712 MRR 0.5756179488276588 rank 2 total_num 583 865\n",
      "checkcorrect (4029, 312, 3770) (4029, 312, 3770) real score 0.5852124385535717 Hits@1 0.38803418803418804 Hits@3 0.7162393162393162 Hits@10 0.9538461538461539 MRR 0.5748239200452373 rank 8 total_num 584 865\n",
      "checkcorrect (4441, 24, 5169) (4441, 24, 5169) real score 0.9395803213119507 Hits@1 0.3873720136518771 Hits@3 0.7167235494880546 Hits@10 0.9539249146757679 MRR 0.5746962341748529 rank 1 total_num 585 865\n",
      "checkcorrect (3682, 32, 3826) (3682, 32, 3826) real score 0.9831975132226944 Hits@1 0.38671209540034074 Hits@3 0.717206132879046 Hits@10 0.9540034071550255 MRR 0.5745689833500236 rank 1 total_num 586 865\n",
      "checkcorrect (4423, 0, 4003) (4423, 0, 4003) real score 0.945734940469265 Hits@1 0.3877551020408163 Hits@3 0.717687074829932 Hits@10 0.9540816326530612 MRR 0.5752925054871835 rank 0 total_num 587 865\n",
      "checkcorrect (4356, 98, 5080) (4356, 98, 5080) real score 0.9022879123687744 Hits@1 0.3870967741935484 Hits@3 0.7181663837011885 Hits@10 0.9541595925297114 MRR 0.5748817089300461 rank 2 total_num 588 865\n",
      "checkcorrect (4523, 20, 4635) (4523, 20, 4635) real score 0.9751051932573318 Hits@1 0.38813559322033897 Hits@3 0.7186440677966102 Hits@10 0.9542372881355933 MRR 0.5756022484064359 rank 0 total_num 589 865\n",
      "checkcorrect (4860, 240, 4140) (4860, 240, 4140) real score 0.948480761051178 Hits@1 0.38917089678510997 Hits@3 0.7191201353637902 Hits@10 0.9543147208121827 MRR 0.576320349508963 rank 0 total_num 590 865\n",
      "checkcorrect (3949, 146, 5239) (3949, 146, 5239) real score 0.8920621812343598 Hits@1 0.3885135135135135 Hits@3 0.7179054054054054 Hits@10 0.9543918918918919 MRR 0.5755579840537114 rank 7 total_num 591 865\n",
      "checkcorrect (5056, 96, 3727) (5056, 96, 3727) real score 0.8680754899978638 Hits@1 0.38954468802698144 Hits@3 0.718381112984823 Hits@10 0.954468802698145 MRR 0.5762737378748687 rank 0 total_num 592 865\n",
      "checkcorrect (3982, 28, 4190) (3982, 28, 4190) real score 0.9221249669790268 Hits@1 0.39057239057239057 Hits@3 0.7188552188552189 Hits@10 0.9545454545454546 MRR 0.5769870817505003 rank 0 total_num 593 865\n",
      "checkcorrect (6074, 372, 6073) (6074, 372, 6073) real score 0.0 Hits@1 0.3899159663865546 Hits@3 0.7176470588235294 Hits@10 0.9529411764705882 MRR 0.5760538919163563 rank 45 total_num 594 865\n",
      "checkcorrect (4923, 40, 3879) (4923, 40, 3879) real score 0.9506436198949814 Hits@1 0.38926174496644295 Hits@3 0.7181208053691275 Hits@10 0.9530201342281879 MRR 0.5759262847151543 rank 1 total_num 595 865\n",
      "checkcorrect (5023, 0, 3904) (5023, 0, 3904) real score 0.9900044471025466 Hits@1 0.39028475711892796 Hits@3 0.7185929648241206 Hits@10 0.9530988274706867 MRR 0.5766366259467872 rank 0 total_num 596 865\n",
      "checkcorrect (5994, 96, 3993) (5994, 96, 3993) real score 0.9600428134202957 Hits@1 0.3896321070234114 Hits@3 0.7190635451505016 Hits@10 0.9531772575250836 MRR 0.5765084710538996 rank 1 total_num 597 865\n",
      "checkcorrect (3992, 50, 5452) (3992, 50, 5452) real score 0.9617157310247422 Hits@1 0.38898163606010017 Hits@3 0.7195325542570952 Hits@10 0.9532554257095158 MRR 0.5763807440571486 rank 1 total_num 598 865\n",
      "checkcorrect (3852, 134, 5252) (3852, 134, 5252) real score 0.7789374478161335 Hits@1 0.3883333333333333 Hits@3 0.7183333333333334 Hits@10 0.9533333333333334 MRR 0.5757534428170533 rank 4 total_num 599 865\n",
      "checkcorrect (5398, 220, 5078) (5398, 220, 5078) real score 0.9458262950181962 Hits@1 0.3876871880199667 Hits@3 0.7171381031613977 Hits@10 0.9534109816971714 MRR 0.5751282291018834 rank 4 total_num 600 865\n",
      "checkcorrect (4558, 64, 4433) (4558, 64, 4433) real score 0.9315566748380661 Hits@1 0.38870431893687707 Hits@3 0.717607973421927 Hits@10 0.9534883720930233 MRR 0.575833996163176 rank 0 total_num 601 865\n",
      "checkcorrect (4171, 188, 4317) (4171, 188, 4317) real score 0.9908871442079544 Hits@1 0.38971807628524047 Hits@3 0.7180762852404643 Hits@10 0.9535655058043118 MRR 0.5765374223718606 rank 0 total_num 602 865\n",
      "checkcorrect (4892, 36, 4450) (4892, 36, 4450) real score 0.9482376515865326 Hits@1 0.39072847682119205 Hits@3 0.7185430463576159 Hits@10 0.9536423841059603 MRR 0.5772385193546886 rank 0 total_num 603 865\n",
      "checkcorrect (3937, 112, 5645) (3937, 112, 5645) real score 0.8004099607467652 Hits@1 0.39008264462809916 Hits@3 0.7173553719008264 Hits@10 0.9537190082644628 MRR 0.5766976292400529 rank 3 total_num 604 865\n",
      "checkcorrect (5159, 44, 3669) (5159, 44, 3669) real score 0.9381444752216339 Hits@1 0.38943894389438943 Hits@3 0.7161716171617162 Hits@10 0.9537953795379538 MRR 0.5761585242413069 rank 3 total_num 605 865\n",
      "checkcorrect (3753, 340, 4843) (3753, 340, 4843) real score 0.5132365889847279 Hits@1 0.38879736408566723 Hits@3 0.71499176276771 Hits@10 0.9538714991762768 MRR 0.5753740785671038 rank 9 total_num 606 865\n",
      "checkcorrect (4450, 22, 3877) (4450, 22, 3877) real score 0.9716766327619553 Hits@1 0.3881578947368421 Hits@3 0.7138157894736842 Hits@10 0.9539473684210527 MRR 0.5748389238326184 rank 3 total_num 607 865\n",
      "checkcorrect (5193, 40, 3787) (5193, 40, 3787) real score 0.9699033141136169 Hits@1 0.38752052545155996 Hits@3 0.7142857142857143 Hits@10 0.9540229885057471 MRR 0.5747160356161445 rank 1 total_num 608 865\n",
      "checkcorrect (5424, 186, 5712) (5424, 186, 5712) real score 0.8470003426074981 Hits@1 0.38688524590163936 Hits@3 0.7131147540983607 Hits@10 0.9540983606557377 MRR 0.574047102224424 rank 5 total_num 609 865\n",
      "checkcorrect (4230, 54, 4975) (4230, 54, 4975) real score 0.6774273011833429 Hits@1 0.3862520458265139 Hits@3 0.7119476268412439 Hits@10 0.9525368248772504 MRR 0.5732563689816821 rank 10 total_num 610 865\n",
      "checkcorrect (3757, 22, 4834) (3757, 22, 4834) real score 0.9689622163772582 Hits@1 0.38562091503267976 Hits@3 0.7124183006535948 Hits@10 0.9526143790849673 MRR 0.5731366690323656 rank 1 total_num 611 865\n",
      "checkcorrect (4051, 70, 3880) (4051, 70, 3880) real score 0.9262124866247177 Hits@1 0.38499184339314846 Hits@3 0.7112561174551386 Hits@10 0.9526916802610114 MRR 0.5724735858311165 rank 5 total_num 612 865\n",
      "checkcorrect (4565, 178, 4204) (4565, 178, 4204) real score 0.9464432895183563 Hits@1 0.38436482084690554 Hits@3 0.7117263843648208 Hits@10 0.9527687296416938 MRR 0.5723555506750397 rank 1 total_num 613 865\n",
      "checkcorrect (4334, 316, 4742) (4334, 316, 4742) real score 0.9444037914276122 Hits@1 0.3853658536585366 Hits@3 0.7121951219512195 Hits@10 0.9528455284552846 MRR 0.5730509075032104 rank 0 total_num 614 865\n",
      "checkcorrect (4212, 6, 4753) (4212, 6, 4753) real score 0.9921121656894684 Hits@1 0.3847402597402597 Hits@3 0.7126623376623377 Hits@10 0.952922077922078 MRR 0.5729323183676532 rank 1 total_num 615 865\n",
      "checkcorrect (4151, 44, 3669) (4151, 44, 3669) real score 0.9453441351652145 Hits@1 0.3841166936790924 Hits@3 0.7115072933549432 Hits@10 0.9529983792544571 MRR 0.5724089272519844 rank 3 total_num 616 865\n",
      "checkcorrect (4820, 110, 3886) (4820, 110, 3886) real score 0.9006255745887757 Hits@1 0.38349514563106796 Hits@3 0.7103559870550162 Hits@10 0.9530744336569579 MRR 0.5716849645865282 rank 7 total_num 617 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4589, 12, 3687) (4589, 12, 3687) real score 0.9758603423833847 Hits@1 0.38449111470113084 Hits@3 0.7108239095315024 Hits@10 0.9531502423263328 MRR 0.5723769113319457 rank 0 total_num 618 865\n",
      "checkcorrect (4948, 54, 4422) (4948, 54, 4422) real score 0.9334500253200531 Hits@1 0.38387096774193546 Hits@3 0.7112903225806452 Hits@10 0.9532258064516129 MRR 0.5719913571738834 rank 2 total_num 619 865\n",
      "checkcorrect (4256, 162, 4699) (4256, 162, 4699) real score 0.8342469543218614 Hits@1 0.3832528180354267 Hits@3 0.711755233494364 Hits@10 0.9533011272141707 MRR 0.5718754290624923 rank 1 total_num 620 865\n",
      "checkcorrect (4500, 20, 4040) (4500, 20, 4040) real score 0.9749775528907776 Hits@1 0.3842443729903537 Hits@3 0.7122186495176849 Hits@10 0.9533762057877814 MRR 0.5725637322312022 rank 0 total_num 621 865\n",
      "checkcorrect (4517, 134, 4686) (4517, 134, 4686) real score 0.9480809956789017 Hits@1 0.3852327447833066 Hits@3 0.7126805778491172 Hits@10 0.9534510433386838 MRR 0.5732498257589209 rank 0 total_num 622 865\n",
      "checkcorrect (5834, 48, 5996) (5834, 48, 5996) real score 0.4175645262002945 Hits@1 0.38461538461538464 Hits@3 0.7115384615384616 Hits@10 0.9519230769230769 MRR 0.5724544303280943 rank 12 total_num 623 865\n",
      "checkcorrect (4229, 50, 4525) (4229, 50, 4525) real score 0.9644444197416305 Hits@1 0.3856 Hits@3 0.712 Hits@10 0.952 MRR 0.5731385032395693 rank 0 total_num 624 865\n",
      "checkcorrect (5184, 96, 3803) (5184, 96, 3803) real score 0.9776603311300278 Hits@1 0.3865814696485623 Hits@3 0.7124600638977636 Hits@10 0.952076677316294 MRR 0.573820390614586 rank 0 total_num 625 865\n",
      "checkcorrect (4195, 382, 3863) (4195, 382, 3863) real score 0.9688707023859024 Hits@1 0.3875598086124402 Hits@3 0.7129186602870813 Hits@10 0.9521531100478469 MRR 0.5745001029102564 rank 0 total_num 626 865\n",
      "checkcorrect (4674, 54, 4230) (4674, 54, 4230) real score 0.9092118799686433 Hits@1 0.3869426751592357 Hits@3 0.7133757961783439 Hits@10 0.9522292993630573 MRR 0.5741160793918219 rank 2 total_num 627 865\n",
      "checkcorrect (3752, 98, 5751) (3752, 98, 5751) real score 0.9715417712926865 Hits@1 0.38791732909379967 Hits@3 0.7138314785373608 Hits@10 0.9523052464228935 MRR 0.5747931603466838 rank 0 total_num 628 865\n",
      "checkcorrect (5716, 44, 3669) (5716, 44, 3669) real score 0.9389519721269608 Hits@1 0.3873015873015873 Hits@3 0.7126984126984127 Hits@10 0.9523809523809523 MRR 0.5742776156477208 rank 3 total_num 629 865\n",
      "checkcorrect (6071, 88, 4164) (6071, 88, 4164) real score 0.9651144117116928 Hits@1 0.38827258320126784 Hits@3 0.7131537242472267 Hits@10 0.9524564183835182 MRR 0.5749522945452681 rank 0 total_num 630 865\n",
      "checkcorrect (5873, 312, 5005) (5873, 312, 5005) real score 0.7623024336993693 Hits@1 0.3876582278481013 Hits@3 0.7120253164556962 Hits@10 0.9525316455696202 MRR 0.5742403447121268 rank 7 total_num 631 865\n",
      "checkcorrect (3709, 32, 4118) (3709, 32, 4118) real score 0.9804025918245316 Hits@1 0.38704581358609796 Hits@3 0.7124802527646129 Hits@10 0.95260663507109 MRR 0.5738597649153199 rank 2 total_num 632 865\n",
      "checkcorrect (4561, 50, 4560) (4561, 50, 4560) real score 0.383307084441185 Hits@1 0.3864353312302839 Hits@3 0.7113564668769716 Hits@10 0.9511041009463722 MRR 0.5730597758013629 rank 14 total_num 633 865\n",
      "checkcorrect (4571, 96, 3727) (4571, 96, 3727) real score 0.9637353032827377 Hits@1 0.3858267716535433 Hits@3 0.7118110236220473 Hits@10 0.9511811023622048 MRR 0.5729447210363214 rank 1 total_num 634 865\n",
      "checkcorrect (3869, 386, 4648) (3869, 386, 4648) real score 0.7534349232912063 Hits@1 0.38522012578616355 Hits@3 0.710691823899371 Hits@10 0.9512578616352201 MRR 0.5723059190640422 rank 5 total_num 635 865\n",
      "checkcorrect (5695, 64, 4372) (5695, 64, 4372) real score 0.7693310797214508 Hits@1 0.38461538461538464 Hits@3 0.7095761381475667 Hits@10 0.9497645211930926 MRR 0.5715121368781749 rank 14 total_num 636 865\n",
      "checkcorrect (4565, 72, 4703) (4565, 72, 4703) real score 0.9403754562139511 Hits@1 0.38557993730407525 Hits@3 0.7100313479623824 Hits@10 0.9498432601880877 MRR 0.5721837479488988 rank 0 total_num 637 865\n",
      "checkcorrect (4287, 36, 4313) (4287, 36, 4313) real score 0.9437476456165313 Hits@1 0.38497652582159625 Hits@3 0.7104851330203443 Hits@10 0.9499217527386542 MRR 0.5720707843370852 rank 1 total_num 638 865\n",
      "checkcorrect (4427, 6, 4075) (4427, 6, 4075) real score 0.992059975862503 Hits@1 0.3859375 Hits@3 0.7109375 Hits@10 0.95 MRR 0.5727394237365585 rank 0 total_num 639 865\n",
      "checkcorrect (4900, 40, 3879) (4900, 40, 3879) real score 0.7844686135649681 Hits@1 0.38533541341653665 Hits@3 0.7098283931357254 Hits@10 0.9485179407176287 MRR 0.5719877383499322 rank 10 total_num 640 865\n",
      "checkcorrect (6095, 58, 3943) (6095, 58, 3943) real score 0.9549590528011322 Hits@1 0.3862928348909657 Hits@3 0.7102803738317757 Hits@10 0.9485981308411215 MRR 0.5726544241157423 rank 0 total_num 641 865\n",
      "checkcorrect (5664, 104, 3818) (5664, 104, 3818) real score 0.7726325869560242 Hits@1 0.3856920684292379 Hits@3 0.7107309486780715 Hits@10 0.9486780715396579 MRR 0.5722822295733123 rank 2 total_num 642 865\n",
      "checkcorrect (5765, 58, 3988) (5765, 58, 3988) real score 0.9520522266626359 Hits@1 0.38509316770186336 Hits@3 0.7111801242236024 Hits@10 0.9487577639751553 MRR 0.5721699900863972 rank 1 total_num 643 865\n",
      "checkcorrect (4333, 40, 5302) (4333, 40, 5302) real score 0.7412456840276718 Hits@1 0.38449612403100775 Hits@3 0.710077519379845 Hits@10 0.9472868217054263 MRR 0.5714121037968576 rank 11 total_num 644 865\n",
      "checkcorrect (4514, 36, 4000) (4514, 36, 4000) real score 0.9467497736215591 Hits@1 0.38390092879256965 Hits@3 0.7105263157894737 Hits@10 0.9473684210526315 MRR 0.5710435608085239 rank 2 total_num 645 865\n",
      "checkcorrect (5280, 192, 4306) (5280, 192, 4306) real score 0.1660662361071445 Hits@1 0.38330757341576505 Hits@3 0.7094281298299846 Hits@10 0.9459041731066461 MRR 0.5702345584697458 rank 20 total_num 646 865\n",
      "checkcorrect (4345, 22, 4943) (4345, 22, 4943) real score 0.9568432867527008 Hits@1 0.38425925925925924 Hits@3 0.7098765432098766 Hits@10 0.9459876543209876 MRR 0.5708977767437122 rank 0 total_num 647 865\n",
      "checkcorrect (5003, 0, 3904) (5003, 0, 3904) real score 0.9489729225635528 Hits@1 0.38366718027734975 Hits@3 0.7103235747303543 Hits@10 0.9460708782742681 MRR 0.570788535177081 rank 1 total_num 648 865\n",
      "checkcorrect (5068, 382, 3863) (5068, 382, 3863) real score 0.9741849660873413 Hits@1 0.38461538461538464 Hits@3 0.7107692307692308 Hits@10 0.9461538461538461 MRR 0.5714488605075777 rank 0 total_num 649 865\n",
      "checkcorrect (4801, 188, 6095) (4801, 188, 6095) real score 0.9828295022249222 Hits@1 0.38556067588325654 Hits@3 0.7112135176651305 Hits@10 0.946236559139785 MRR 0.5721071571888257 rank 0 total_num 650 865\n",
      "checkcorrect (4510, 48, 5884) (4510, 48, 5884) real score 0.9468475341796875 Hits@1 0.38650306748466257 Hits@3 0.7116564417177914 Hits@10 0.946319018404908 MRR 0.5727634345551005 rank 0 total_num 651 865\n",
      "checkcorrect (5727, 40, 5370) (5727, 40, 5370) real score 0.9181039750576019 Hits@1 0.38591117917304746 Hits@3 0.7105666156202144 Hits@10 0.9464012251148545 MRR 0.5722691567073898 rank 3 total_num 652 865\n",
      "checkcorrect (4356, 98, 3735) (4356, 98, 3735) real score 0.9686889678239823 Hits@1 0.38685015290519875 Hits@3 0.7110091743119266 Hits@10 0.9464831804281345 MRR 0.5729231794035559 rank 0 total_num 653 865\n",
      "checkcorrect (4613, 390, 4888) (4613, 390, 4888) real score 0.9241359680891037 Hits@1 0.38625954198473283 Hits@3 0.7114503816793893 Hits@10 0.9465648854961832 MRR 0.5728118463052297 rank 1 total_num 654 865\n",
      "checkcorrect (4841, 0, 4003) (4841, 0, 4003) real score 0.8939718529582024 Hits@1 0.3856707317073171 Hits@3 0.711890243902439 Hits@10 0.9466463414634146 MRR 0.5727008526370816 rank 1 total_num 655 865\n",
      "checkcorrect (3701, 78, 5787) (3701, 78, 5787) real score 0.9130360096693039 Hits@1 0.3850837138508371 Hits@3 0.710806697108067 Hits@10 0.9467275494672754 MRR 0.5722096793453965 rank 3 total_num 656 865\n",
      "checkcorrect (5050, 266, 4693) (5050, 266, 4693) real score 0.7522727131843567 Hits@1 0.3844984802431611 Hits@3 0.709726443768997 Hits@10 0.9468085106382979 MRR 0.5715300293767864 rank 7 total_num 657 865\n",
      "checkcorrect (5626, 14, 6105) (5626, 14, 6105) real score 0.9511671930551528 Hits@1 0.38543247344461307 Hits@3 0.7101669195751138 Hits@10 0.9468892261001517 MRR 0.5721802114262906 rank 0 total_num 658 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (3757, 22, 5889) (3757, 22, 5889) real score 0.9482290476560593 Hits@1 0.38484848484848483 Hits@3 0.7090909090909091 Hits@10 0.946969696969697 MRR 0.5716920595907962 rank 3 total_num 659 865\n",
      "checkcorrect (3853, 24, 4106) (3853, 24, 4106) real score 0.9418337345123291 Hits@1 0.3857791225416036 Hits@3 0.7095310136157338 Hits@10 0.9470499243570348 MRR 0.5723400292434576 rank 0 total_num 660 865\n",
      "checkcorrect (3794, 78, 3878) (3794, 78, 3878) real score 0.9399947345256805 Hits@1 0.3851963746223565 Hits@3 0.7099697885196374 Hits@10 0.947129909365559 MRR 0.572230754274812 rank 1 total_num 661 865\n",
      "checkcorrect (5369, 30, 5142) (5369, 30, 5142) real score 0.911125847697258 Hits@1 0.38461538461538464 Hits@3 0.7088989441930619 Hits@10 0.947209653092006 MRR 0.5715831319348155 rank 6 total_num 662 865\n",
      "checkcorrect (5895, 72, 4536) (5895, 72, 4536) real score 0.926170340180397 Hits@1 0.38403614457831325 Hits@3 0.7093373493975904 Hits@10 0.947289156626506 MRR 0.5712243219971627 rank 2 total_num 663 865\n",
      "checkcorrect (4419, 28, 4614) (4419, 28, 4614) real score 0.9081811219453813 Hits@1 0.38345864661654133 Hits@3 0.7097744360902256 Hits@10 0.9473684210526315 MRR 0.5708665911871418 rank 2 total_num 664 865\n",
      "checkcorrect (4489, 12, 4035) (4489, 12, 4035) real score 0.9766771882772446 Hits@1 0.3843843843843844 Hits@3 0.7102102102102102 Hits@10 0.9474474474474475 MRR 0.5715109356448188 rank 0 total_num 665 865\n",
      "checkcorrect (4423, 0, 3808) (4423, 0, 3808) real score 0.9232642769813537 Hits@1 0.3853073463268366 Hits@3 0.7106446776611695 Hits@10 0.9475262368815592 MRR 0.5721533480351564 rank 0 total_num 666 865\n",
      "checkcorrect (3696, 154, 4604) (3696, 154, 4604) real score 0.8342947751283646 Hits@1 0.3847305389221557 Hits@3 0.7110778443113772 Hits@10 0.9476047904191617 MRR 0.5717958330430878 rank 2 total_num 667 865\n",
      "checkcorrect (4614, 48, 6163) (4614, 48, 6163) real score 0.9434434384107591 Hits@1 0.3841554559043348 Hits@3 0.7115097159940209 Hits@10 0.9476831091180867 MRR 0.5714393868551808 rank 2 total_num 668 865\n",
      "checkcorrect (4233, 134, 5848) (4233, 134, 5848) real score 0.883295899629593 Hits@1 0.3835820895522388 Hits@3 0.7119402985074627 Hits@10 0.9477611940298507 MRR 0.5710840046857452 rank 2 total_num 669 865\n",
      "checkcorrect (4970, 64, 5219) (4970, 64, 5219) real score 0.8956890612840652 Hits@1 0.3830104321907601 Hits@3 0.7123695976154992 Hits@10 0.9478390461997019 MRR 0.5707296817776193 rank 2 total_num 670 865\n",
      "checkcorrect (4163, 24, 4819) (4163, 24, 4819) real score 0.889344123005867 Hits@1 0.38244047619047616 Hits@3 0.7113095238095238 Hits@10 0.9479166666666666 MRR 0.5702524054654502 rank 3 total_num 671 865\n",
      "checkcorrect (5407, 126, 4047) (5407, 126, 4047) real score 0.8583285003900527 Hits@1 0.3818722139673105 Hits@3 0.7102526002971769 Hits@10 0.9479940564635958 MRR 0.5697765475078492 rank 3 total_num 672 865\n",
      "checkcorrect (5506, 146, 3770) (5506, 146, 3770) real score 0.9217314630746841 Hits@1 0.38130563798219586 Hits@3 0.7106824925816023 Hits@10 0.9480712166172107 MRR 0.5696730214729712 rank 1 total_num 673 865\n",
      "checkcorrect (5936, 0, 4003) (5936, 0, 4003) real score 0.8200014024972915 Hits@1 0.38222222222222224 Hits@3 0.7111111111111111 Hits@10 0.9481481481481482 MRR 0.5703105429226408 rank 0 total_num 674 865\n",
      "checkcorrect (4080, 54, 5621) (4080, 54, 5621) real score 0.9233461230993271 Hits@1 0.3816568047337278 Hits@3 0.7115384615384616 Hits@10 0.9482248520710059 MRR 0.5699599849202898 rank 2 total_num 675 865\n",
      "checkcorrect (4513, 40, 4313) (4513, 40, 4313) real score 0.9852566063404083 Hits@1 0.3825701624815362 Hits@3 0.7119645494830132 Hits@10 0.948301329394387 MRR 0.5705951991227709 rank 0 total_num 676 865\n",
      "checkcorrect (4540, 44, 3669) (4540, 44, 3669) real score 0.9484004139900208 Hits@1 0.38200589970501475 Hits@3 0.7123893805309734 Hits@10 0.948377581120944 MRR 0.5702452553679191 rank 2 total_num 677 865\n",
      "checkcorrect (5147, 98, 3814) (5147, 98, 3814) real score 0.8793392047286034 Hits@1 0.38291605301914583 Hits@3 0.7128129602356407 Hits@10 0.9484536082474226 MRR 0.5708781784086144 rank 0 total_num 678 865\n",
      "checkcorrect (4084, 54, 4814) (4084, 54, 4814) real score 0.7503367274999619 Hits@1 0.38235294117647056 Hits@3 0.711764705882353 Hits@10 0.9485294117647058 MRR 0.5702224752050723 rank 7 total_num 679 865\n",
      "checkcorrect (3737, 22, 6009) (3737, 22, 6009) real score 0.8693613439798356 Hits@1 0.38179148311306904 Hits@3 0.7121879588839941 Hits@10 0.9486049926578561 MRR 0.5701193585013938 rank 1 total_num 680 865\n",
      "checkcorrect (4775, 12, 3687) (4775, 12, 3687) real score 0.9768193185329437 Hits@1 0.38269794721407624 Hits@3 0.7126099706744868 Hits@10 0.9486803519061584 MRR 0.5707496820226527 rank 0 total_num 681 865\n",
      "checkcorrect (4208, 128, 4209) (4208, 128, 4209) real score 0.0 Hits@1 0.3821376281112738 Hits@3 0.7115666178623719 Hits@10 0.9472913616398243 MRR 0.5699612609135657 rank 30 total_num 682 865\n",
      "checkcorrect (4826, 198, 5976) (4826, 198, 5976) real score 0.4610976010560989 Hits@1 0.3815789473684211 Hits@3 0.7105263157894737 Hits@10 0.9473684210526315 MRR 0.5693716489336725 rank 5 total_num 683 865\n",
      "checkcorrect (4434, 0, 3808) (4434, 0, 3808) real score 0.9900189369916916 Hits@1 0.38248175182481753 Hits@3 0.710948905109489 Hits@10 0.9474452554744526 MRR 0.5700003034607767 rank 0 total_num 684 865\n",
      "checkcorrect (3675, 50, 5174) (3675, 50, 5174) real score 0.9619463503360748 Hits@1 0.38338192419825073 Hits@3 0.7113702623906706 Hits@10 0.9475218658892128 MRR 0.5706271251758485 rank 0 total_num 685 865\n",
      "checkcorrect (4885, 44, 3669) (4885, 44, 3669) real score 0.954396703839302 Hits@1 0.38427947598253276 Hits@3 0.7117903930131004 Hits@10 0.9475982532751092 MRR 0.5712521220824338 rank 0 total_num 686 865\n",
      "checkcorrect (5585, 148, 3777) (5585, 148, 3777) real score 0.8278566241264342 Hits@1 0.38372093023255816 Hits@3 0.7122093023255814 Hits@10 0.9476744186046512 MRR 0.5711485579515 rank 1 total_num 687 865\n",
      "checkcorrect (3813, 78, 3731) (3813, 78, 3731) real score 0.8767171844840049 Hits@1 0.38316400580551524 Hits@3 0.7111756168359942 Hits@10 0.9477503628447025 MRR 0.5706098807991756 rank 4 total_num 688 865\n",
      "checkcorrect (4226, 64, 3743) (4226, 64, 3743) real score 0.8959938049316406 Hits@1 0.3826086956521739 Hits@3 0.7101449275362319 Hits@10 0.9478260869565217 MRR 0.5700244558511576 rank 5 total_num 689 865\n",
      "checkcorrect (4160, 118, 4277) (4160, 118, 4277) real score 0.1918405151925981 Hits@1 0.38205499276411 Hits@3 0.7091172214182344 Hits@10 0.9464544138929089 MRR 0.5692846571153553 rank 16 total_num 690 865\n",
      "checkcorrect (4786, 50, 5336) (4786, 50, 5336) real score 0.9092785537242889 Hits@1 0.3829479768786127 Hits@3 0.7095375722543352 Hits@10 0.9465317919075145 MRR 0.5699070781310845 rank 0 total_num 691 865\n",
      "checkcorrect (4198, 54, 4524) (4198, 54, 4524) real score 0.861790181696415 Hits@1 0.3823953823953824 Hits@3 0.70995670995671 Hits@10 0.9466089466089466 MRR 0.569565701875965 rank 2 total_num 692 865\n",
      "checkcorrect (4782, 390, 5756) (4782, 390, 5756) real score 0.891508761048317 Hits@1 0.38328530259365995 Hits@3 0.7103746397694525 Hits@10 0.946685878962536 MRR 0.5701859242075559 rank 0 total_num 693 865\n",
      "checkcorrect (3982, 28, 3887) (3982, 28, 3887) real score 0.9330183207988738 Hits@1 0.3841726618705036 Hits@3 0.7107913669064748 Hits@10 0.9467625899280575 MRR 0.5708043617266817 rank 0 total_num 694 865\n",
      "checkcorrect (3818, 292, 4111) (3818, 292, 4111) real score 0.9278807669878006 Hits@1 0.3850574712643678 Hits@3 0.7112068965517241 Hits@10 0.9468390804597702 MRR 0.5714210221264997 rank 0 total_num 695 865\n",
      "checkcorrect (3746, 78, 5822) (3746, 78, 5822) real score 0.960679942369461 Hits@1 0.38450502152080346 Hits@3 0.7116212338593975 Hits@10 0.9469153515064562 MRR 0.5713185529412393 rank 1 total_num 696 865\n",
      "checkcorrect (4200, 64, 5223) (4200, 64, 5223) real score 0.7745166823267937 Hits@1 0.3839541547277937 Hits@3 0.7106017191977078 Hits@10 0.9469914040114613 MRR 0.5706592299586746 rank 8 total_num 697 865\n",
      "checkcorrect (4313, 22, 4856) (4313, 22, 4856) real score 0.9755152404308318 Hits@1 0.3834048640915594 Hits@3 0.7110157367668097 Hits@10 0.9470672389127325 MRR 0.5705581437927824 rank 1 total_num 698 865\n",
      "checkcorrect (4592, 16, 5025) (4592, 16, 5025) real score 0.9770039170980453 Hits@1 0.38285714285714284 Hits@3 0.7114285714285714 Hits@10 0.9471428571428572 MRR 0.570457346444507 rank 1 total_num 699 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4316, 72, 4445) (4316, 72, 4445) real score 0.9465841978788376 Hits@1 0.38231098430813126 Hits@3 0.7118402282453637 Hits@10 0.9472182596291013 MRR 0.5703568366778243 rank 1 total_num 700 865\n",
      "checkcorrect (3871, 420, 3870) (3871, 420, 3870) real score 0.03246877337805926 Hits@1 0.3817663817663818 Hits@3 0.7108262108262108 Hits@10 0.9472934472934473 MRR 0.5696868126939528 rank 9 total_num 701 865\n",
      "checkcorrect (3696, 154, 4599) (3696, 154, 4599) real score 0.8117227435112 Hits@1 0.3812233285917496 Hits@3 0.7098150782361309 Hits@10 0.9473684210526315 MRR 0.5690796581138151 rank 6 total_num 702 865\n",
      "checkcorrect (3757, 22, 3916) (3757, 22, 3916) real score 0.933824935555458 Hits@1 0.3806818181818182 Hits@3 0.7088068181818182 Hits@10 0.9474431818181818 MRR 0.5686264199630853 rank 3 total_num 703 865\n",
      "checkcorrect (3893, 230, 4371) (3893, 230, 4371) real score 0.4976693242788315 Hits@1 0.38156028368794326 Hits@3 0.7092198581560284 Hits@10 0.9475177304964539 MRR 0.5692382973815774 rank 0 total_num 704 865\n",
      "checkcorrect (4626, 140, 3770) (4626, 140, 3770) real score 0.9012521147727967 Hits@1 0.3810198300283286 Hits@3 0.7082152974504249 Hits@10 0.9475920679886686 MRR 0.5687861184901021 rank 3 total_num 705 865\n",
      "checkcorrect (4477, 112, 5627) (4477, 112, 5627) real score 0.8387965232133865 Hits@1 0.38048090523338046 Hits@3 0.7072135785007072 Hits@10 0.9476661951909476 MRR 0.5682173498170845 rank 5 total_num 706 865\n",
      "checkcorrect (3933, 96, 3727) (3933, 96, 3727) real score 0.8323915630578995 Hits@1 0.3799435028248588 Hits@3 0.7076271186440678 Hits@10 0.9477401129943502 MRR 0.5681209976280773 rank 1 total_num 707 865\n",
      "checkcorrect (5434, 230, 6043) (5434, 230, 6043) real score 0.4976693421602249 Hits@1 0.38081805359661497 Hits@3 0.7080394922425952 Hits@10 0.9478138222849083 MRR 0.5687301358542719 rank 0 total_num 708 865\n",
      "checkcorrect (5458, 382, 3863) (5458, 382, 3863) real score 0.9695517897605896 Hits@1 0.3816901408450704 Hits@3 0.7084507042253522 Hits@10 0.9478873239436619 MRR 0.569337558198139 rank 0 total_num 709 865\n",
      "checkcorrect (5081, 48, 3770) (5081, 48, 3770) real score 0.928476944565773 Hits@1 0.38115330520393814 Hits@3 0.7074542897327707 Hits@10 0.9479606188466948 MRR 0.5687377263903459 rank 6 total_num 710 865\n",
      "checkcorrect (5002, 56, 4468) (5002, 56, 4468) real score 0.8085887625813484 Hits@1 0.3806179775280899 Hits@3 0.7078651685393258 Hits@10 0.9480337078651685 MRR 0.5684071022427939 rank 2 total_num 711 865\n",
      "checkcorrect (4793, 372, 5464) (4793, 372, 5464) real score 0.0 Hits@1 0.3800841514726508 Hits@3 0.7068723702664796 Hits@10 0.9467040673211781 MRR 0.5676566481489518 rank 29 total_num 712 865\n",
      "checkcorrect (6138, 316, 4742) (6138, 316, 4742) real score 0.9439935982227325 Hits@1 0.38095238095238093 Hits@3 0.7072829131652661 Hits@10 0.9467787114845938 MRR 0.5682621710507039 rank 0 total_num 713 865\n",
      "checkcorrect (4063, 22, 4059) (4063, 22, 4059) real score 0.9702751129865645 Hits@1 0.3804195804195804 Hits@3 0.7076923076923077 Hits@10 0.9468531468531468 MRR 0.5679335992497005 rank 2 total_num 714 865\n",
      "checkcorrect (5409, 172, 4506) (5409, 172, 4506) real score 0.9927103370428085 Hits@1 0.3812849162011173 Hits@3 0.7081005586592178 Hits@10 0.946927374301676 MRR 0.5685370439434859 rank 0 total_num 715 865\n",
      "checkcorrect (5514, 44, 3669) (5514, 44, 3669) real score 0.9260622680187225 Hits@1 0.3807531380753138 Hits@3 0.708507670850767 Hits@10 0.9470013947001394 MRR 0.568441455318739 rank 1 total_num 716 865\n",
      "checkcorrect (4649, 108, 4285) (4649, 108, 4285) real score 0.974860394001007 Hits@1 0.3816155988857939 Hits@3 0.7089136490250696 Hits@10 0.947075208913649 MRR 0.5690425117876544 rank 0 total_num 717 865\n",
      "checkcorrect (4974, 198, 3685) (4974, 198, 3685) real score 0.9088992923498154 Hits@1 0.38247566063977745 Hits@3 0.7093184979137691 Hits@10 0.9471488178025035 MRR 0.5696418963331514 rank 0 total_num 718 865\n",
      "checkcorrect (4962, 96, 3727) (4962, 96, 3727) real score 0.9377807796001434 Hits@1 0.3819444444444444 Hits@3 0.7097222222222223 Hits@10 0.9472222222222222 MRR 0.5695451714771332 rank 1 total_num 719 865\n",
      "checkcorrect (5715, 98, 4435) (5715, 98, 4435) real score 0.905077975988388 Hits@1 0.3814147018030513 Hits@3 0.710124826629681 Hits@10 0.9472954230235784 MRR 0.5694487149286213 rank 1 total_num 720 865\n",
      "checkcorrect (4420, 48, 4110) (4420, 48, 4110) real score 0.8172881364822389 Hits@1 0.3808864265927978 Hits@3 0.7091412742382271 Hits@10 0.9473684210526315 MRR 0.5689370131073904 rank 4 total_num 721 865\n",
      "checkcorrect (5019, 0, 3808) (5019, 0, 3808) real score 0.9703424423933029 Hits@1 0.38035961272475793 Hits@3 0.7095435684647303 Hits@10 0.9474412171507607 MRR 0.5688416645415434 rank 1 total_num 722 865\n",
      "checkcorrect (4449, 124, 3808) (4449, 124, 3808) real score 0.790161806344986 Hits@1 0.3812154696132597 Hits@3 0.7099447513812155 Hits@10 0.9475138121546961 MRR 0.5694371871043313 rank 0 total_num 723 865\n",
      "checkcorrect (3880, 96, 3727) (3880, 96, 3727) real score 0.9480335384607315 Hits@1 0.38068965517241377 Hits@3 0.7103448275862069 Hits@10 0.9475862068965517 MRR 0.5691115266163713 rank 2 total_num 724 865\n",
      "checkcorrect (4332, 54, 3748) (4332, 54, 3748) real score 0.9728768736124038 Hits@1 0.38154269972451793 Hits@3 0.7107438016528925 Hits@10 0.9476584022038568 MRR 0.5697050369102882 rank 0 total_num 725 865\n",
      "checkcorrect (5619, 54, 4104) (5619, 54, 4104) real score 0.9437951475381852 Hits@1 0.3810178817056396 Hits@3 0.7111416781292985 Hits@10 0.9477303988995873 MRR 0.5693799038929883 rank 2 total_num 726 865\n",
      "checkcorrect (5303, 96, 3727) (5303, 96, 3727) real score 0.9142728745937347 Hits@1 0.3804945054945055 Hits@3 0.7115384615384616 Hits@10 0.9478021978021978 MRR 0.5690556640982635 rank 2 total_num 727 865\n",
      "checkcorrect (4207, 0, 4735) (4207, 0, 4735) real score 0.9898680239915847 Hits@1 0.3813443072702332 Hits@3 0.7119341563786008 Hits@10 0.9478737997256516 MRR 0.5696468085919558 rank 0 total_num 728 865\n",
      "checkcorrect (5567, 218, 6167) (5567, 218, 6167) real score 0.432482448220253 Hits@1 0.38082191780821917 Hits@3 0.7123287671232876 Hits@10 0.947945205479452 MRR 0.5693230915025604 rank 2 total_num 729 865\n",
      "checkcorrect (3912, 210, 5041) (3912, 210, 5041) real score 0.9652198791503905 Hits@1 0.3803009575923393 Hits@3 0.7127222982216143 Hits@10 0.948016415868673 MRR 0.5690002600960362 rank 2 total_num 730 865\n",
      "checkcorrect (3946, 290, 4116) (3946, 290, 4116) real score 0.910535192489624 Hits@1 0.3797814207650273 Hits@3 0.7117486338797814 Hits@10 0.9480874316939891 MRR 0.568564467390987 rank 3 total_num 731 865\n",
      "checkcorrect (3784, 360, 4010) (3784, 360, 4010) real score 0.5132403492927551 Hits@1 0.3792633015006821 Hits@3 0.7107776261937244 Hits@10 0.9481582537517054 MRR 0.5679403836852845 rank 8 total_num 732 865\n",
      "checkcorrect (5752, 2, 4039) (5752, 2, 4039) real score 0.9119486749172211 Hits@1 0.3787465940054496 Hits@3 0.7098092643051771 Hits@10 0.9482288828337875 MRR 0.5675072223996097 rank 3 total_num 733 865\n",
      "checkcorrect (4523, 6, 4428) (4523, 6, 4428) real score 0.9920458614826202 Hits@1 0.3795918367346939 Hits@3 0.710204081632653 Hits@10 0.9482993197278912 MRR 0.5680956479473653 rank 0 total_num 734 865\n",
      "checkcorrect (3875, 22, 4407) (3875, 22, 4407) real score 0.91582533121109 Hits@1 0.37907608695652173 Hits@3 0.7092391304347826 Hits@10 0.9483695652173914 MRR 0.5675955179909151 rank 4 total_num 735 865\n",
      "checkcorrect (5039, 96, 3727) (5039, 96, 3727) real score 0.9152430981397628 Hits@1 0.37991858887381275 Hits@3 0.7096336499321574 Hits@10 0.9484396200814111 MRR 0.568182226921728 rank 0 total_num 736 865\n",
      "checkcorrect (5387, 32, 4355) (5387, 32, 4355) real score 0.9752313166856765 Hits@1 0.3794037940379404 Hits@3 0.7086720867208672 Hits@10 0.948509485094851 MRR 0.5677510856928367 rank 3 total_num 737 865\n",
      "checkcorrect (4328, 290, 4757) (4328, 290, 4757) real score 0.8961598068475723 Hits@1 0.37889039242219213 Hits@3 0.7077131258457375 Hits@10 0.9485791610284168 MRR 0.5671331696243905 rank 8 total_num 738 865\n",
      "checkcorrect (4049, 54, 3999) (4049, 54, 3999) real score 0.9764565080404282 Hits@1 0.3783783783783784 Hits@3 0.7081081081081081 Hits@10 0.9486486486486486 MRR 0.5670424491248981 rank 1 total_num 739 865\n",
      "checkcorrect (4536, 110, 4229) (4536, 110, 4229) real score 0.8864090114831924 Hits@1 0.37786774628879893 Hits@3 0.708502024291498 Hits@10 0.9487179487179487 MRR 0.5667270522075006 rank 2 total_num 740 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5985, 258, 3914) (5985, 258, 3914) real score 0.7160769443958998 Hits@1 0.37870619946091644 Hits@3 0.7088948787061995 Hits@10 0.9487870619946092 MRR 0.5673109780131509 rank 0 total_num 741 865\n",
      "checkcorrect (5201, 198, 5200) (5201, 198, 5200) real score 0.0 Hits@1 0.3781965006729475 Hits@3 0.7079407806191117 Hits@10 0.9475100942126514 MRR 0.5665972849566554 rank 26 total_num 742 865\n",
      "checkcorrect (3958, 44, 3669) (3958, 44, 3669) real score 0.9205027133226396 Hits@1 0.37768817204301075 Hits@3 0.706989247311828 Hits@10 0.9475806451612904 MRR 0.5661717509714986 rank 3 total_num 743 865\n",
      "checkcorrect (4649, 298, 4014) (4649, 298, 4014) real score 0.9565898329019547 Hits@1 0.3785234899328859 Hits@3 0.7073825503355705 Hits@10 0.9476510067114094 MRR 0.5667540707688523 rank 0 total_num 744 865\n",
      "checkcorrect (3813, 78, 5653) (3813, 78, 5653) real score 0.9633917897939681 Hits@1 0.37935656836461124 Hits@3 0.707774798927614 Hits@10 0.9477211796246648 MRR 0.5673348293871245 rank 0 total_num 745 865\n",
      "checkcorrect (5834, 64, 4389) (5834, 64, 4389) real score 0.7643644720315933 Hits@1 0.3788487282463186 Hits@3 0.7068273092369478 Hits@10 0.9464524765729585 MRR 0.5666645908828134 rank 14 total_num 746 865\n",
      "checkcorrect (5164, 158, 3885) (5164, 158, 3885) real score 0.7824446260929108 Hits@1 0.3783422459893048 Hits@3 0.7072192513368984 Hits@10 0.946524064171123 MRR 0.5665754670982107 rank 1 total_num 747 865\n",
      "checkcorrect (6073, 126, 4047) (6073, 126, 4047) real score 0.0 Hits@1 0.37783711615487314 Hits@3 0.7062750333778371 Hits@10 0.945260347129506 MRR 0.5658457268217111 rank 49 total_num 748 865\n",
      "checkcorrect (5085, 96, 3993) (5085, 96, 3993) real score 0.9655416071414947 Hits@1 0.37866666666666665 Hits@3 0.7066666666666667 Hits@10 0.9453333333333334 MRR 0.5664245991859488 rank 0 total_num 749 865\n",
      "checkcorrect (4711, 48, 3770) (4711, 48, 3770) real score 0.9491675049066544 Hits@1 0.3794940079893475 Hits@3 0.7070572569906791 Hits@10 0.9454061251664447 MRR 0.5670019299460207 rank 0 total_num 750 865\n",
      "checkcorrect (4222, 0, 4003) (4222, 0, 4003) real score 0.9892001867294311 Hits@1 0.3803191489361702 Hits@3 0.7074468085106383 Hits@10 0.9454787234042553 MRR 0.5675777252519436 rank 0 total_num 751 865\n",
      "checkcorrect (4303, 50, 5382) (4303, 50, 5382) real score 0.9692484378814697 Hits@1 0.38114209827357237 Hits@3 0.7078353253652059 Hits@10 0.9455511288180611 MRR 0.5681519912210645 rank 0 total_num 752 865\n",
      "checkcorrect (3807, 0, 3867) (3807, 0, 3867) real score 0.9792395949363708 Hits@1 0.3819628647214854 Hits@3 0.7082228116710876 Hits@10 0.9456233421750663 MRR 0.5687247339382779 rank 0 total_num 753 865\n",
      "checkcorrect (5136, 54, 4758) (5136, 54, 4758) real score 0.8640556246042252 Hits@1 0.3827814569536424 Hits@3 0.7086092715231788 Hits@10 0.9456953642384106 MRR 0.5692959594562406 rank 0 total_num 754 865\n",
      "checkcorrect (4329, 44, 3669) (4329, 44, 3669) real score 0.9361798107624054 Hits@1 0.38227513227513227 Hits@3 0.7076719576719577 Hits@10 0.9457671957671958 MRR 0.5688074727373831 rank 4 total_num 755 865\n",
      "checkcorrect (4052, 64, 4915) (4052, 64, 4915) real score 0.9456676572561264 Hits@1 0.3817701453104359 Hits@3 0.7080581241743725 Hits@10 0.9458388375165125 MRR 0.5687165777932122 rank 1 total_num 756 865\n",
      "checkcorrect (4165, 340, 4226) (4165, 340, 4226) real score 0.6842365130782126 Hits@1 0.3812664907651715 Hits@3 0.7084432717678101 Hits@10 0.945910290237467 MRR 0.5684060458084366 rank 2 total_num 757 865\n",
      "checkcorrect (4318, 314, 4087) (4318, 314, 4087) real score 0.8185218274593353 Hits@1 0.3820816864295125 Hits@3 0.7088274044795784 Hits@10 0.9459815546772069 MRR 0.5689746807941962 rank 0 total_num 758 865\n",
      "checkcorrect (4840, 178, 4204) (4840, 178, 4204) real score 0.9612788915634155 Hits@1 0.3828947368421053 Hits@3 0.7092105263157895 Hits@10 0.9460526315789474 MRR 0.5695418193720986 rank 0 total_num 759 865\n",
      "checkcorrect (4065, 54, 3854) (4065, 54, 3854) real score 0.9770884364843369 Hits@1 0.38370565045992117 Hits@3 0.709592641261498 Hits@10 0.9461235216819974 MRR 0.5701074674412547 rank 0 total_num 760 865\n",
      "checkcorrect (4697, 48, 4698) (4697, 48, 4698) real score 0.4246515780687332 Hits@1 0.38320209973753283 Hits@3 0.7086614173228346 Hits@10 0.9448818897637795 MRR 0.5694785981807139 rank 10 total_num 761 865\n",
      "checkcorrect (6062, 0, 3808) (6062, 0, 3808) real score 0.974898025393486 Hits@1 0.3840104849279161 Hits@3 0.709043250327654 Hits@10 0.944954128440367 MRR 0.5700428464137667 rank 0 total_num 762 865\n",
      "checkcorrect (5600, 126, 4073) (5600, 126, 4073) real score 0.0 Hits@1 0.38350785340314136 Hits@3 0.7081151832460733 Hits@10 0.943717277486911 MRR 0.5693258037119453 rank 44 total_num 763 865\n",
      "checkcorrect (4588, 312, 3770) (4588, 312, 3770) real score 0.5289787113666534 Hits@1 0.38300653594771245 Hits@3 0.7071895424836602 Hits@10 0.9437908496732026 MRR 0.5688430248835636 rank 4 total_num 764 865\n",
      "checkcorrect (4543, 310, 4296) (4543, 310, 4296) real score 0.5765710324048996 Hits@1 0.3825065274151436 Hits@3 0.706266318537859 Hits@10 0.943864229765013 MRR 0.5683179904733588 rank 5 total_num 765 865\n",
      "checkcorrect (4205, 108, 4509) (4205, 108, 4509) real score 0.9746375441551209 Hits@1 0.3833116036505867 Hits@3 0.7066492829204694 Hits@10 0.9439374185136897 MRR 0.5688808092602254 rank 0 total_num 766 865\n",
      "checkcorrect (4656, 116, 5202) (4656, 116, 5202) real score 0.8881368935108185 Hits@1 0.3841145833333333 Hits@3 0.70703125 Hits@10 0.9440104166666666 MRR 0.5694421623731678 rank 0 total_num 767 865\n",
      "checkcorrect (3963, 54, 4885) (3963, 54, 4885) real score 0.974539366364479 Hits@1 0.3836150845253576 Hits@3 0.7074122236671001 Hits@10 0.9440832249674902 MRR 0.5693518604715122 rank 1 total_num 768 865\n",
      "checkcorrect (4066, 206, 4067) (4066, 206, 4067) real score 0.9599729835987091 Hits@1 0.38441558441558443 Hits@3 0.7077922077922078 Hits@10 0.9441558441558442 MRR 0.5699111437696012 rank 0 total_num 769 865\n",
      "checkcorrect (4843, 44, 3669) (4843, 44, 3669) real score 0.9068506598472595 Hits@1 0.383916990920882 Hits@3 0.7068741893644618 Hits@10 0.9442282749675746 MRR 0.5693340865143877 rank 7 total_num 770 865\n",
      "checkcorrect (4523, 6, 4917) (4523, 6, 4917) real score 0.9919966459274292 Hits@1 0.38471502590673573 Hits@3 0.7072538860103627 Hits@10 0.944300518134715 MRR 0.5698919439152758 rank 0 total_num 771 865\n",
      "checkcorrect (4906, 110, 4187) (4906, 110, 4187) real score 0.8994914025068284 Hits@1 0.3855109961190168 Hits@3 0.7076326002587322 Hits@10 0.944372574385511 MRR 0.5704483579593699 rank 0 total_num 772 865\n",
      "checkcorrect (5264, 54, 5778) (5264, 54, 5778) real score 0.8460445061326027 Hits@1 0.3850129198966408 Hits@3 0.7080103359173127 Hits@10 0.9444444444444444 MRR 0.5701420077983542 rank 2 total_num 773 865\n",
      "checkcorrect (4168, 112, 5706) (4168, 112, 5706) real score 0.8148908734321594 Hits@1 0.38451612903225807 Hits@3 0.7083870967741935 Hits@10 0.944516129032258 MRR 0.5698364482183994 rank 2 total_num 774 865\n",
      "checkcorrect (5024, 8, 4403) (5024, 8, 4403) real score 0.9539684891700745 Hits@1 0.3853092783505155 Hits@3 0.7087628865979382 Hits@10 0.9445876288659794 MRR 0.5703907826923447 rank 0 total_num 775 865\n",
      "checkcorrect (4985, 96, 3727) (4985, 96, 3727) real score 0.9378881961107254 Hits@1 0.3861003861003861 Hits@3 0.7091377091377091 Hits@10 0.9446589446589446 MRR 0.5709436903079272 rank 0 total_num 776 865\n",
      "checkcorrect (4318, 314, 4446) (4318, 314, 4446) real score 0.9533230900764466 Hits@1 0.38688946015424164 Hits@3 0.7095115681233933 Hits@10 0.9447300771208226 MRR 0.5714951765671716 rank 0 total_num 777 865\n",
      "checkcorrect (4775, 216, 4369) (4775, 216, 4369) real score 0.8446545869112014 Hits@1 0.386392811296534 Hits@3 0.7098844672657253 Hits@10 0.944801026957638 MRR 0.571403398420102 rank 1 total_num 778 865\n",
      "checkcorrect (4288, 54, 4139) (4288, 54, 4139) real score 0.9732042700052261 Hits@1 0.3858974358974359 Hits@3 0.7102564102564103 Hits@10 0.9448717948717948 MRR 0.5713118556016148 rank 1 total_num 779 865\n",
      "checkcorrect (3688, 78, 4763) (3688, 78, 4763) real score 0.4990846931934357 Hits@1 0.3854033290653009 Hits@3 0.7106274007682458 Hits@10 0.9449423815620999 MRR 0.5710071455859063 rank 2 total_num 780 865\n",
      "checkcorrect (4285, 160, 4017) (4285, 160, 4017) real score 0.9754788339138032 Hits@1 0.38618925831202044 Hits@3 0.710997442455243 Hits@10 0.9450127877237852 MRR 0.571555729798712 rank 0 total_num 781 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5686, 98, 4210) (5686, 98, 4210) real score 0.9713623791933059 Hits@1 0.38697318007662834 Hits@3 0.7113665389527458 Hits@10 0.9450830140485313 MRR 0.5721029127747035 rank 0 total_num 782 865\n",
      "checkcorrect (3843, 134, 4077) (3843, 134, 4077) real score 0.9153230488300323 Hits@1 0.3864795918367347 Hits@3 0.7104591836734694 Hits@10 0.9451530612244898 MRR 0.5716282917124909 rank 4 total_num 783 865\n",
      "checkcorrect (4288, 54, 4157) (4288, 54, 4157) real score 0.9770827978849411 Hits@1 0.3872611464968153 Hits@3 0.710828025477707 Hits@10 0.9452229299363057 MRR 0.5721739881561692 rank 0 total_num 784 865\n",
      "checkcorrect (4468, 96, 3993) (4468, 96, 3993) real score 0.9481698870658875 Hits@1 0.38676844783715014 Hits@3 0.7099236641221374 Hits@10 0.94529262086514 MRR 0.5716277835183842 rank 6 total_num 785 865\n",
      "checkcorrect (5991, 44, 3669) (5991, 44, 3669) real score 0.49995426535606385 Hits@1 0.386277001270648 Hits@3 0.7090216010165185 Hits@10 0.9440914866581956 MRR 0.570999187957272 rank 12 total_num 786 865\n",
      "checkcorrect (3951, 96, 3727) (3951, 96, 3727) real score 0.9545992165803909 Hits@1 0.38578680203045684 Hits@3 0.7093908629441624 Hits@10 0.9441624365482234 MRR 0.5706975815427746 rank 2 total_num 787 865\n",
      "checkcorrect (3973, 50, 4198) (3973, 50, 4198) real score 0.8466354936361313 Hits@1 0.385297845373891 Hits@3 0.7084917617237009 Hits@10 0.944233206590621 MRR 0.5701553249664937 rank 6 total_num 788 865\n",
      "checkcorrect (4976, 20, 4075) (4976, 20, 4075) real score 0.9750565052032472 Hits@1 0.3860759493670886 Hits@3 0.7088607594936709 Hits@10 0.9443037974683545 MRR 0.5706994321500805 rank 0 total_num 789 865\n",
      "checkcorrect (4150, 112, 4477) (4150, 112, 4477) real score 0.9021475940942765 Hits@1 0.38558786346396967 Hits@3 0.7092288242730721 Hits@10 0.9443742098609356 MRR 0.5706100523369957 rank 1 total_num 790 865\n",
      "checkcorrect (4032, 64, 4588) (4032, 64, 4588) real score 0.8990697979927063 Hits@1 0.3851010101010101 Hits@3 0.7083333333333334 Hits@10 0.9444444444444444 MRR 0.5701421103517217 rank 4 total_num 791 865\n",
      "checkcorrect (4737, 54, 4062) (4737, 54, 4062) real score 0.933462843298912 Hits@1 0.38461538461538464 Hits@3 0.7087011349306431 Hits@10 0.9445145018915511 MRR 0.5698434864210553 rank 2 total_num 792 865\n",
      "checkcorrect (5336, 50, 4786) (5336, 50, 4786) real score 0.8766864269971848 Hits@1 0.38413098236775817 Hits@3 0.7090680100755667 Hits@10 0.9445843828715366 MRR 0.5697555223323638 rank 1 total_num 793 865\n",
      "checkcorrect (4881, 64, 5846) (4881, 64, 5846) real score 0.9259544223546982 Hits@1 0.3836477987421384 Hits@3 0.7094339622641509 Hits@10 0.9446540880503145 MRR 0.5694581359311072 rank 2 total_num 794 865\n",
      "checkcorrect (4009, 28, 4442) (4009, 28, 4442) real score 0.8989973694086075 Hits@1 0.38316582914572866 Hits@3 0.7085427135678392 Hits@10 0.9447236180904522 MRR 0.5690568066146108 rank 3 total_num 795 865\n",
      "checkcorrect (3736, 16, 4007) (3736, 16, 4007) real score 0.9736623555421828 Hits@1 0.38268506900878296 Hits@3 0.7089084065244667 Hits@10 0.944792973651192 MRR 0.5689701606841031 rank 1 total_num 796 865\n",
      "checkcorrect (5340, 8, 3818) (5340, 8, 3818) real score 0.9610009163618087 Hits@1 0.38220551378446116 Hits@3 0.7092731829573935 Hits@10 0.9448621553884712 MRR 0.5686748764393026 rank 2 total_num 797 865\n",
      "checkcorrect (5621, 64, 3899) (5621, 64, 3899) real score 0.9107105940580368 Hits@1 0.38172715894868586 Hits@3 0.7083854818523154 Hits@10 0.9449311639549437 MRR 0.5681717372531041 rank 5 total_num 798 865\n",
      "checkcorrect (5138, 64, 6008) (5138, 64, 6008) real score 0.9303887635469437 Hits@1 0.38125 Hits@3 0.70875 Hits@10 0.945 MRR 0.5680865225815377 rank 1 total_num 799 865\n",
      "checkcorrect (4729, 24, 5561) (4729, 24, 5561) real score 0.30441448241472246 Hits@1 0.3807740324594257 Hits@3 0.7078651685393258 Hits@10 0.9438202247191011 MRR 0.5674466587026039 rank 17 total_num 800 865\n",
      "checkcorrect (6034, 96, 5126) (6034, 96, 5126) real score 0.9784873098134994 Hits@1 0.3802992518703242 Hits@3 0.7082294264339152 Hits@10 0.9438902743142145 MRR 0.5671547468255849 rank 2 total_num 801 865\n",
      "checkcorrect (5141, 298, 4014) (5141, 298, 4014) real score 0.9566555678844453 Hits@1 0.38107098381070986 Hits@3 0.7085927770859277 Hits@10 0.9439601494396015 MRR 0.5676937820101109 rank 0 total_num 802 865\n",
      "checkcorrect (4163, 56, 4737) (4163, 56, 4737) real score 0.8422489553689957 Hits@1 0.3805970149253731 Hits@3 0.7089552238805971 Hits@10 0.9440298507462687 MRR 0.5676095857638296 rank 1 total_num 803 865\n",
      "checkcorrect (4973, 24, 5082) (4973, 24, 5082) real score 0.9067121475934983 Hits@1 0.3813664596273292 Hits@3 0.7093167701863354 Hits@10 0.9440993788819876 MRR 0.5681467167131913 rank 0 total_num 804 865\n",
      "checkcorrect (4638, 112, 5045) (4638, 112, 5045) real score 0.7306846648454666 Hits@1 0.38089330024813894 Hits@3 0.7096774193548387 Hits@10 0.9441687344913151 MRR 0.5678553849720253 rank 2 total_num 805 865\n",
      "checkcorrect (6001, 240, 3824) (6001, 240, 3824) real score 0.9541066527366638 Hits@1 0.38166047087980176 Hits@3 0.7100371747211895 Hits@10 0.9442379182156134 MRR 0.5683908801579335 rank 0 total_num 806 865\n",
      "checkcorrect (4792, 48, 5328) (4792, 48, 5328) real score 0.44485695064067843 Hits@1 0.3811881188118812 Hits@3 0.7091584158415841 Hits@10 0.943069306930693 MRR 0.5677905614118635 rank 11 total_num 807 865\n",
      "checkcorrect (3710, 40, 4056) (3710, 40, 4056) real score 0.9820236831903457 Hits@1 0.380716934487021 Hits@3 0.7095179233621756 Hits@10 0.9431396786155748 MRR 0.5677067659095002 rank 1 total_num 808 865\n",
      "checkcorrect (3862, 382, 4088) (3862, 382, 4088) real score 0.9433933317661285 Hits@1 0.3814814814814815 Hits@3 0.7098765432098766 Hits@10 0.9432098765432099 MRR 0.5682404612602292 rank 0 total_num 809 865\n",
      "checkcorrect (4463, 36, 4019) (4463, 36, 4019) real score 0.9311147004365921 Hits@1 0.3810110974106042 Hits@3 0.7102342786683107 Hits@10 0.9432799013563502 MRR 0.5681563176581821 rank 1 total_num 810 865\n",
      "checkcorrect (3710, 54, 4885) (3710, 54, 4885) real score 0.965745598077774 Hits@1 0.3817733990147783 Hits@3 0.7105911330049262 Hits@10 0.9433497536945813 MRR 0.5686881448531843 rank 0 total_num 811 865\n",
      "checkcorrect (4429, 56, 4430) (4429, 56, 4430) real score 0.7656371161341666 Hits@1 0.3813038130381304 Hits@3 0.7097170971709718 Hits@10 0.9434194341943419 MRR 0.5681643674829555 rank 6 total_num 812 865\n",
      "checkcorrect (4399, 364, 6131) (4399, 364, 6131) real score 0.5080178719013929 Hits@1 0.3808353808353808 Hits@3 0.7100737100737101 Hits@10 0.9434889434889435 MRR 0.5680806274737626 rank 1 total_num 813 865\n",
      "checkcorrect (3857, 40, 4269) (3857, 40, 4269) real score 0.9832272142171861 Hits@1 0.3815950920245399 Hits@3 0.7104294478527607 Hits@10 0.943558282208589 MRR 0.5686105898940402 rank 0 total_num 814 865\n",
      "checkcorrect (4105, 22, 5496) (4105, 22, 5496) real score 0.9749616801738739 Hits@1 0.38235294117647056 Hits@3 0.7107843137254902 Hits@10 0.9436274509803921 MRR 0.5691392533868171 rank 0 total_num 815 865\n",
      "checkcorrect (4124, 12, 3687) (4124, 12, 3687) real score 0.9728282719850541 Hits@1 0.3818849449204406 Hits@3 0.7099143206854345 Hits@10 0.9436964504283966 MRR 0.5687486300656582 rank 3 total_num 816 865\n",
      "checkcorrect (3851, 270, 4737) (3851, 270, 4737) real score 0.8235237956047058 Hits@1 0.38141809290953543 Hits@3 0.7102689486552567 Hits@10 0.9437652811735942 MRR 0.5686645852856269 rank 1 total_num 817 865\n",
      "checkcorrect (4071, 32, 4118) (4071, 32, 4118) real score 0.9788011282682418 Hits@1 0.38095238095238093 Hits@3 0.7094017094017094 Hits@10 0.9438339438339438 MRR 0.5682754954379033 rank 3 total_num 818 865\n",
      "checkcorrect (6132, 58, 3943) (6132, 58, 3943) real score 0.9400300234556198 Hits@1 0.38170731707317074 Hits@3 0.7097560975609756 Hits@10 0.9439024390243902 MRR 0.5688019887361497 rank 0 total_num 819 865\n",
      "checkcorrect (5647, 220, 4085) (5647, 220, 4085) real score 0.9460080057382584 Hits@1 0.3812423873325213 Hits@3 0.7088915956151035 Hits@10 0.9439707673568819 MRR 0.5683527780312336 rank 4 total_num 820 865\n",
      "checkcorrect (4332, 40, 5129) (4332, 40, 5129) real score 0.9662941515445709 Hits@1 0.38077858880778587 Hits@3 0.7092457420924574 Hits@10 0.9440389294403893 MRR 0.5682696238000521 rank 1 total_num 821 865\n",
      "checkcorrect (3746, 78, 4607) (3746, 78, 4607) real score 0.9645213454961776 Hits@1 0.38031591737545567 Hits@3 0.7095990279465371 Hits@10 0.9441069258809235 MRR 0.5681866716447664 rank 1 total_num 822 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (4689, 32, 4118) (4689, 32, 4118) real score 0.9829989790916442 Hits@1 0.38106796116504854 Hits@3 0.7099514563106796 Hits@10 0.9441747572815534 MRR 0.5687107169461685 rank 0 total_num 823 865\n",
      "checkcorrect (4329, 50, 4139) (4329, 50, 4139) real score 0.9716067045927048 Hits@1 0.38181818181818183 Hits@3 0.7103030303030303 Hits@10 0.9442424242424242 MRR 0.5692334918347186 rank 0 total_num 824 865\n",
      "checkcorrect (3864, 22, 5223) (3864, 22, 5223) real score 0.9762540012598038 Hits@1 0.3813559322033898 Hits@3 0.7106537530266344 Hits@10 0.9443099273607748 MRR 0.5691496740479937 rank 1 total_num 825 865\n",
      "checkcorrect (3798, 30, 3742) (3798, 30, 3742) real score 0.9349582195281982 Hits@1 0.3808948004836759 Hits@3 0.7110036275695284 Hits@10 0.9443772672309553 MRR 0.568864527324034 rank 2 total_num 826 865\n",
      "checkcorrect (4233, 134, 5028) (4233, 134, 5028) real score 0.9393447428941727 Hits@1 0.3804347826086957 Hits@3 0.711352657004831 Hits@10 0.9444444444444444 MRR 0.568580069360277 rank 2 total_num 827 865\n",
      "checkcorrect (5335, 32, 4214) (5335, 32, 4214) real score 0.9842503011226654 Hits@1 0.37997587454764775 Hits@3 0.7117008443908324 Hits@10 0.9445114595898673 MRR 0.5682962976642253 rank 2 total_num 828 865\n",
      "checkcorrect (5010, 54, 4062) (5010, 54, 4062) real score 0.9493961572647095 Hits@1 0.3795180722891566 Hits@3 0.7120481927710843 Hits@10 0.944578313253012 MRR 0.5682140129682443 rank 1 total_num 829 865\n",
      "checkcorrect (3886, 48, 6112) (3886, 48, 6112) real score 0.0 Hits@1 0.37906137184115524 Hits@3 0.7111913357400722 Hits@10 0.9434416365824309 MRR 0.5675970954502988 rank 17 total_num 830 865\n",
      "checkcorrect (5332, 24, 4320) (5332, 24, 4320) real score 0.9364651054143905 Hits@1 0.3786057692307692 Hits@3 0.7115384615384616 Hits@10 0.9435096153846154 MRR 0.5675158489413441 rank 1 total_num 831 865\n",
      "checkcorrect (5908, 96, 3727) (5908, 96, 3727) real score 0.9207176148891449 Hits@1 0.37815126050420167 Hits@3 0.7106842737094838 Hits@10 0.943577430972389 MRR 0.5670746534444157 rank 4 total_num 832 865\n",
      "checkcorrect (3888, 216, 4959) (3888, 216, 4959) real score 0.6034758493304253 Hits@1 0.3776978417266187 Hits@3 0.709832134292566 Hits@10 0.9424460431654677 MRR 0.5664696478647462 rank 15 total_num 833 865\n",
      "checkcorrect (4576, 190, 4606) (4576, 190, 4606) real score 0.37036378085613253 Hits@1 0.3772455089820359 Hits@3 0.7089820359281437 Hits@10 0.9413173652694611 MRR 0.5659001142636017 rank 10 total_num 834 865\n",
      "checkcorrect (4608, 2, 3837) (4608, 2, 3837) real score 0.9482072710990905 Hits@1 0.37679425837320574 Hits@3 0.7093301435406698 Hits@10 0.9413875598086124 MRR 0.5658212863757265 rank 1 total_num 835 865\n",
      "checkcorrect (4140, 78, 4180) (4140, 78, 4180) real score 0.9654352337121963 Hits@1 0.3763440860215054 Hits@3 0.7096774193548387 Hits@10 0.9414575866188769 MRR 0.5657426468460064 rank 1 total_num 836 865\n",
      "checkcorrect (4422, 50, 4948) (4422, 50, 4948) real score 0.9202120751142502 Hits@1 0.37589498806682575 Hits@3 0.7100238663484487 Hits@10 0.9415274463007159 MRR 0.5656641950001281 rank 1 total_num 837 865\n",
      "checkcorrect (5563, 386, 4167) (5563, 386, 4167) real score 0.8986566990613938 Hits@1 0.3766388557806913 Hits@3 0.7103694874851013 Hits@10 0.9415971394517283 MRR 0.5661818777236083 rank 0 total_num 838 865\n",
      "checkcorrect (4451, 0, 4003) (4451, 0, 4003) real score 0.9744782805442811 Hits@1 0.3773809523809524 Hits@3 0.7107142857142857 Hits@10 0.9416666666666667 MRR 0.5666983278691754 rank 0 total_num 839 865\n",
      "checkcorrect (5659, 146, 4097) (5659, 146, 4097) real score 0.8559966623783112 Hits@1 0.3769322235434007 Hits@3 0.7098692033293698 Hits@10 0.9417360285374554 MRR 0.5661943549975796 rank 6 total_num 840 865\n",
      "checkcorrect (4689, 12, 3687) (4689, 12, 3687) real score 0.9781079798936844 Hits@1 0.37767220902612825 Hits@3 0.7102137767220903 Hits@10 0.9418052256532067 MRR 0.5667095636020957 rank 0 total_num 841 865\n",
      "checkcorrect (3688, 78, 5544) (3688, 78, 5544) real score 0.499083811044693 Hits@1 0.37722419928825623 Hits@3 0.7093712930011863 Hits@10 0.9418742586002372 MRR 0.5662350168678899 rank 5 total_num 842 865\n",
      "checkcorrect (3922, 40, 4549) (3922, 40, 4549) real score 0.9305961698293685 Hits@1 0.3767772511848341 Hits@3 0.7097156398104265 Hits@10 0.9419431279620853 MRR 0.5661565393597526 rank 1 total_num 843 865\n",
      "checkcorrect (4702, 14, 5898) (4702, 14, 5898) real score 0.9518206268548965 Hits@1 0.37751479289940826 Hits@3 0.7100591715976331 Hits@10 0.9420118343195266 MRR 0.5666699635735281 rank 0 total_num 844 865\n",
      "checkcorrect (6129, 146, 6130) (6129, 146, 6130) real score 0.0 Hits@1 0.37706855791962174 Hits@3 0.7092198581560284 Hits@10 0.942080378250591 MRR 0.5661314779323194 rank 8 total_num 845 865\n",
      "checkcorrect (3912, 6, 4976) (3912, 6, 4976) real score 0.9921148657798767 Hits@1 0.3778040141676505 Hits@3 0.7095631641086186 Hits@10 0.9421487603305785 MRR 0.5666437193987512 rank 0 total_num 846 865\n",
      "checkcorrect (5095, 48, 4485) (5095, 48, 4485) real score 0.9237007796764374 Hits@1 0.37735849056603776 Hits@3 0.7087264150943396 Hits@10 0.9422169811320755 MRR 0.5661720483460011 rank 5 total_num 847 865\n",
      "checkcorrect (4312, 0, 3808) (4312, 0, 3808) real score 0.9897793859243393 Hits@1 0.37809187279151946 Hits@3 0.7090694935217904 Hits@10 0.9422850412249706 MRR 0.5666830353326372 rank 0 total_num 848 865\n",
      "checkcorrect (4565, 14, 6105) (4565, 14, 6105) real score 0.950132492184639 Hits@1 0.3776470588235294 Hits@3 0.7094117647058824 Hits@10 0.9423529411764706 MRR 0.566604584702834 rank 1 total_num 849 865\n",
      "checkcorrect (4239, 54, 3815) (4239, 54, 3815) real score 0.9519592761993408 Hits@1 0.3772032902467685 Hits@3 0.7097532314923619 Hits@10 0.9424206815511164 MRR 0.5663304704239039 rank 2 total_num 850 865\n",
      "checkcorrect (3797, 168, 3846) (3797, 168, 3846) real score 0.9594921946525574 Hits@1 0.3767605633802817 Hits@3 0.7089201877934272 Hits@10 0.9424882629107981 MRR 0.5659591905290402 rank 3 total_num 851 865\n",
      "checkcorrect (4783, 284, 4418) (4783, 284, 4418) real score 0.9759601444005966 Hits@1 0.37749120750293086 Hits@3 0.7092614302461899 Hits@10 0.9425556858147714 MRR 0.5664680308683966 rank 0 total_num 852 865\n",
      "checkcorrect (4004, 230, 6057) (4004, 230, 6057) real score 0.4976693481206894 Hits@1 0.37822014051522246 Hits@3 0.7096018735362998 Hits@10 0.9426229508196722 MRR 0.5669756795441947 rank 0 total_num 853 865\n",
      "checkcorrect (4541, 54, 4690) (4541, 54, 4690) real score 0.6814990304410458 Hits@1 0.37777777777777777 Hits@3 0.7087719298245614 Hits@10 0.9426900584795321 MRR 0.5664295091587629 rank 9 total_num 854 865\n",
      "checkcorrect (4729, 44, 3669) (4729, 44, 3669) real score 0.9298061579465866 Hits@1 0.3773364485981308 Hits@3 0.7091121495327103 Hits@10 0.9427570093457944 MRR 0.5661572005421445 rank 2 total_num 855 865\n",
      "checkcorrect (3752, 98, 5653) (3752, 98, 5653) real score 0.9686136096715927 Hits@1 0.37689614935822635 Hits@3 0.7094515752625438 Hits@10 0.9428238039673279 MRR 0.5658855274182134 rank 2 total_num 856 865\n",
      "checkcorrect (3843, 134, 4305) (3843, 134, 4305) real score 0.8004059575498104 Hits@1 0.3764568764568765 Hits@3 0.7086247086247086 Hits@10 0.9428904428904429 MRR 0.5654590874095675 rank 4 total_num 857 865\n",
      "checkcorrect (4576, 36, 4269) (4576, 36, 4269) real score 0.9141684323549271 Hits@1 0.3760186263096624 Hits@3 0.7077997671711292 Hits@10 0.9429569266589057 MRR 0.5650918474940733 rank 3 total_num 858 865\n",
      "checkcorrect (4708, 158, 3885) (4708, 158, 3885) real score 0.4228236973285675 Hits@1 0.3755813953488372 Hits@3 0.7069767441860465 Hits@10 0.9430232558139535 MRR 0.5647254616248941 rank 3 total_num 859 865\n",
      "checkcorrect (4268, 32, 4118) (4268, 32, 4118) real score 0.9786098033189774 Hits@1 0.37514518002322883 Hits@3 0.7061556329849012 Hits@10 0.943089430894309 MRR 0.5643018548169674 rank 4 total_num 860 865\n",
      "checkcorrect (3706, 54, 3831) (3706, 54, 3831) real score 0.9287782073020936 Hits@1 0.37470997679814383 Hits@3 0.7053364269141531 Hits@10 0.9431554524361949 MRR 0.5638405610952153 rank 5 total_num 861 865\n",
      "checkcorrect (5382, 96, 4981) (5382, 96, 4981) real score 0.9118477344512939 Hits@1 0.3742757821552723 Hits@3 0.7045191193511008 Hits@10 0.9432213209733488 MRR 0.5633527471690993 rank 6 total_num 862 865\n",
      "checkcorrect (5514, 418, 4195) (5514, 418, 4195) real score 0.07548443577252328 Hits@1 0.3738425925925926 Hits@3 0.7037037037037037 Hits@10 0.9432870370370371 MRR 0.5628660624418865 rank 6 total_num 863 865\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkcorrect (5876, 32, 4118) (5876, 32, 4118) real score 0.9758860737085342 Hits@1 0.37341040462427744 Hits@3 0.7040462427745665 Hits@10 0.9433526011560693 MRR 0.5626007066856916 rank 2 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": "ac7d4853",
   "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": "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
}
