{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_rel = 279\n",
    "num_ent = 12842\n",
    "num_att = 30\n",
    "num_all_rel = num_att + 7\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train.pickle\",'rb') as f:\n",
    "    train = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid.pickle\",'rb') as f:\n",
    "    valid = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test.pickle\",'rb') as f:\n",
    "    test = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train_num.pickle\",'rb') as f:\n",
    "    train_num = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid_num.pickle\",'rb') as f:\n",
    "    valid_num = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test_num.pickle\",'rb') as f:\n",
    "    test_num = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train_np.pickle\",'rb') as f:\n",
    "    train_np = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid_np.pickle\",'rb') as f:\n",
    "    valid_np = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test_np.pickle\",'rb') as f:\n",
    "    test_np = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/to_skip_num.pickle\",'rb') as f:\n",
    "    to_num = pickle.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/to_skip_np.pickle\",'rb') as f:\n",
    "    to_np = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(len(train_num)):\n",
    "    train_num[i][2] = train_num[i][2] + num_ent\n",
    "for i in range(len(valid_num)):\n",
    "    valid_num[i][2] = valid_num[i][2] + num_ent\n",
    "for i in range(len(test_num)):\n",
    "    test_num[i][2] = test_num[i][2] + num_ent\n",
    "for i in range(len(train_np)):\n",
    "    train_np[i][2] = train_np[i][2] + num_ent\n",
    "    train_np[i][1] = train_np[i][1] + num_att\n",
    "    train_np[i][0] = train_np[i][0] + num_ent\n",
    "for i in range(len(valid_np)):\n",
    "    valid_np[i][2] = valid_np[i][2] + num_ent\n",
    "    valid_np[i][1] = valid_np[i][1] + num_att\n",
    "    valid_np[i][0] = valid_np[i][0] + num_ent\n",
    "for i in range(len(test_np)):\n",
    "    test_np[i][2] = test_np[i][2] + num_ent\n",
    "    test_np[i][1] = test_np[i][1] + num_att\n",
    "    test_np[i][0] = test_np[i][0] + num_ent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_toskipfile(attribute_relation_list,name,num_att):\n",
    "    to_skip_lhs = {}\n",
    "    to_skip_rhs = {}\n",
    "    for rel in attribute_relation_list:\n",
    "        temp = list()\n",
    "        temp.append(rel[2])\n",
    "        temp.append(rel[1]+num_att)\n",
    "        temp1 = []\n",
    "        temp1.append(rel[0])\n",
    "        to_skip_lhs[tuple(temp)] = temp1\n",
    "        temp = list()\n",
    "        temp.append(rel[0])\n",
    "        temp.append(rel[1])\n",
    "        temp1 = []\n",
    "        temp1.append(rel[2])\n",
    "        to_skip_rhs[tuple(temp)] = temp1\n",
    "    to_skip = {}\n",
    "    to_skip['lhs'] = to_skip_lhs\n",
    "    to_skip['rhs'] = to_skip_rhs\n",
    "    with open(name,'wb') as f:\n",
    "        pickle.dump(to_skip,f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_toskipfile(np.concatenate((train_num,valid_num,test_num)),\"/home/zhangjun/QTO/kbc/data/DB15K/to_skip_num1.pickle\",num_all_rel)\n",
    "get_toskipfile(np.concatenate((train,valid,test)),\"/home/zhangjun/QTO/kbc/data/DB15K/to_skip1.pickle\",num_rel)\n",
    "get_toskipfile(np.concatenate((train_np,valid_np,test_np)),\"/home/zhangjun/QTO/kbc/data/DB15K/to_skip_np1.pickle\",num_all_rel)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train1.pickle\",'wb') as f:\n",
    "    pickle.dump(train,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid1.pickle\",'wb') as f:\n",
    "    pickle.dump(valid,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test1.pickle\",'wb') as f:\n",
    "    pickle.dump(test,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train_num1.pickle\",'wb') as f:\n",
    "    pickle.dump(train_num,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid_num1.pickle\",'wb') as f:\n",
    "    pickle.dump(valid_num,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test_num1.pickle\",'wb') as f:\n",
    "    pickle.dump(test_num,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/train_np1.pickle\",'wb') as f:\n",
    "    pickle.dump(train_np,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/valid_np1.pickle\",'wb') as f:\n",
    "    pickle.dump(valid_np,f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/test_np1.pickle\",'wb') as f:\n",
    "    pickle.dump(test_np,f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"/home/zhangjun/QTO/data/DB15k-number/test-easy-answer.pkl\",'rb') as f:\n",
    "    ans = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{(1169, (4,)),\n",
       " (368, (0,)),\n",
       " (8179, (0,)),\n",
       " (2993, (3,)),\n",
       " (1952, (4,)),\n",
       " (1333, (2,)),\n",
       " (4771, (3,)),\n",
       " (695, (4,)),\n",
       " (4164, (4,)),\n",
       " (1727, (3,)),\n",
       " (4850, (3,)),\n",
       " (11685, (5,)),\n",
       " (1170, (4,)),\n",
       " (9236, (3,)),\n",
       " (3769, (4,)),\n",
       " (6454, (3,)),\n",
       " (1443, (0,)),\n",
       " (6192, (3,)),\n",
       " (6690, (0,)),\n",
       " (5165, (0,)),\n",
       " (329, (4,)),\n",
       " (4170, (0,)),\n",
       " (10048, (3,)),\n",
       " (3544, (3,)),\n",
       " (5948, (0,)),\n",
       " (2153, (3,)),\n",
       " (2663, (1,)),\n",
       " (4356, (3,)),\n",
       " (2366, (3,)),\n",
       " (8635, (0,)),\n",
       " (9085, (2,)),\n",
       " (6586, (0,)),\n",
       " (10091, (4,)),\n",
       " (3836, (3,)),\n",
       " (5329, (0,)),\n",
       " (1404, (4,)),\n",
       " (7443, (4,)),\n",
       " (8202, (1,)),\n",
       " (6435, (3,)),\n",
       " (6166, (2,)),\n",
       " (11944, (3,)),\n",
       " (1179, (3,)),\n",
       " (11967, (6,)),\n",
       " (2396, (3,)),\n",
       " (4800, (0,)),\n",
       " (8790, (0,)),\n",
       " (10918, (0,)),\n",
       " (8007, (6,)),\n",
       " (4429, (4,)),\n",
       " (7510, (3,)),\n",
       " (10084, (5,)),\n",
       " (3172, (4,)),\n",
       " (6590, (3,)),\n",
       " (2157, (2,)),\n",
       " (4466, (3,)),\n",
       " (11468, (0,)),\n",
       " (5899, (4,)),\n",
       " (4306, (0,)),\n",
       " (5375, (4,)),\n",
       " (4246, (4,)),\n",
       " (165, (3,)),\n",
       " (8608, (0,)),\n",
       " (11681, (0,)),\n",
       " (7241, (4,)),\n",
       " (4846, (4,)),\n",
       " (2156, (3,)),\n",
       " (1525, (0,)),\n",
       " (3990, (0,)),\n",
       " (10568, (4,)),\n",
       " (9177, (4,)),\n",
       " (8376, (0,)),\n",
       " (6663, (4,)),\n",
       " (4337, (0,)),\n",
       " (3742, (2,)),\n",
       " (6005, (4,)),\n",
       " (8091, (3,)),\n",
       " (7829, (3,)),\n",
       " (2770, (5,)),\n",
       " (4052, (3,)),\n",
       " (1680, (0,)),\n",
       " (10732, (4,)),\n",
       " (3436, (4,)),\n",
       " (8346, (4,)),\n",
       " (10124, (4,)),\n",
       " (10903, (3,)),\n",
       " (922, (4,)),\n",
       " (4117, (1,)),\n",
       " (4754, (0,)),\n",
       " (8904, (3,)),\n",
       " (7901, (4,)),\n",
       " (1972, (0,)),\n",
       " (11170, (5,)),\n",
       " (5962, (0,)),\n",
       " (4511, (4,)),\n",
       " (9085, (0,)),\n",
       " (666, (0,)),\n",
       " (5070, (4,)),\n",
       " (11758, (4,)),\n",
       " (10427, (0,)),\n",
       " (3163, (3,)),\n",
       " (2767, (3,)),\n",
       " (8041, (0,)),\n",
       " (11795, (3,)),\n",
       " (6927, (4,)),\n",
       " (8428, (0,)),\n",
       " (11635, (0,)),\n",
       " (5804, (4,)),\n",
       " (11962, (4,)),\n",
       " (198, (3,)),\n",
       " (2626, (4,)),\n",
       " (10967, (4,)),\n",
       " (7346, (1,)),\n",
       " (3409, (4,)),\n",
       " (4948, (0,)),\n",
       " (10093, (3,)),\n",
       " (6988, (0,)),\n",
       " (2598, (5,)),\n",
       " (9066, (0,)),\n",
       " (2535, (3,)),\n",
       " (8440, (3,)),\n",
       " (9414, (5,)),\n",
       " (6270, (4,)),\n",
       " (513, (0,)),\n",
       " (2687, (0,)),\n",
       " (10821, (3,)),\n",
       " (5050, (3,)),\n",
       " (9964, (5,)),\n",
       " (9928, (0,)),\n",
       " (5092, (4,)),\n",
       " (8707, (5,)),\n",
       " (5226, (4,)),\n",
       " (3701, (4,)),\n",
       " (8671, (0,)),\n",
       " (1411, (5,)),\n",
       " (9082, (4,)),\n",
       " (6023, (0,)),\n",
       " (9381, (3,)),\n",
       " (529, (4,)),\n",
       " (10141, (0,)),\n",
       " (5439, (4,)),\n",
       " (1612, (4,)),\n",
       " (1999, (4,)),\n",
       " (6909, (4,)),\n",
       " (5518, (4,)),\n",
       " (11161, (4,)),\n",
       " (2668, (0,)),\n",
       " (3142, (6,)),\n",
       " (7071, (3,)),\n",
       " (3742, (0,)),\n",
       " (8652, (0,)),\n",
       " (10692, (0,)),\n",
       " (6501, (3,)),\n",
       " (9102, (2,)),\n",
       " (2425, (4,)),\n",
       " (772, (4,)),\n",
       " (6962, (1,)),\n",
       " (10570, (3,)),\n",
       " (7861, (0,)),\n",
       " (7599, (0,)),\n",
       " (5844, (3,)),\n",
       " (6604, (0,)),\n",
       " (10073, (0,)),\n",
       " (5237, (4,)),\n",
       " (7143, (4,)),\n",
       " (8682, (0,)),\n",
       " (6665, (3,)),\n",
       " (10910, (2,)),\n",
       " (10783, (3,)),\n",
       " (7678, (0,)),\n",
       " (9915, (2,)),\n",
       " (9714, (5,)),\n",
       " (6609, (2,)),\n",
       " (7629, (0,)),\n",
       " (9669, (0,)),\n",
       " (1798, (4,)),\n",
       " (4617, (3,)),\n",
       " (11967, (5,)),\n",
       " (2333, (0,)),\n",
       " (3268, (4,)),\n",
       " (7446, (0,)),\n",
       " (3977, (0,)),\n",
       " (7580, (0,)),\n",
       " (8948, (3,)),\n",
       " (5617, (5,)),\n",
       " (9002, (5,)),\n",
       " (11030, (4,)),\n",
       " (8007, (5,)),\n",
       " (7944, (3,)),\n",
       " (2173, (3,)),\n",
       " (6553, (3,)),\n",
       " (6080, (4,)),\n",
       " (5034, (3,)),\n",
       " (7872, (0,)),\n",
       " (4403, (0,)),\n",
       " (5472, (4,)),\n",
       " (6117, (3,)),\n",
       " (3146, (0,)),\n",
       " (1505, (1,)),\n",
       " (4628, (1,)),\n",
       " (9365, (3,)),\n",
       " (8746, (1,)),\n",
       " (3225, (0,)),\n",
       " (2203, (3,)),\n",
       " (1208, (3,)),\n",
       " (6321, (3,)),\n",
       " (8210, (0,)),\n",
       " (12027, (5,)),\n",
       " (5326, (3,)),\n",
       " (3350, (0,)),\n",
       " (7925, (3,)),\n",
       " (2914, (0,)),\n",
       " (12043, (3,)),\n",
       " (9468, (0,)),\n",
       " (1261, (0,)),\n",
       " (11781, (3,)),\n",
       " (9791, (3,)),\n",
       " (4771, (0,)),\n",
       " (11496, (6,)),\n",
       " (318, (3,)),\n",
       " (2013, (4,)),\n",
       " (9958, (4,)),\n",
       " (1363, (3,)),\n",
       " (5542, (6,)),\n",
       " (2226, (4,)),\n",
       " (9102, (0,)),\n",
       " (6454, (0,)),\n",
       " (3431, (1,)),\n",
       " (6192, (0,)),\n",
       " (5459, (0,)),\n",
       " (9747, (5,)),\n",
       " (2784, (3,)),\n",
       " (3544, (0,)),\n",
       " (12074, (3,)),\n",
       " (762, (0,)),\n",
       " (6667, (0,)),\n",
       " (2341, (2,)),\n",
       " (8891, (1,)),\n",
       " (6009, (0,)),\n",
       " (586, (5,)),\n",
       " (10025, (3,)),\n",
       " (10201, (4,)),\n",
       " (8870, (0,)),\n",
       " (2366, (0,)),\n",
       " (1970, (0,)),\n",
       " (9915, (0,)),\n",
       " (451, (0,)),\n",
       " (8262, (0,)),\n",
       " (653, (4,)),\n",
       " (9976, (3,)),\n",
       " (11817, (5,)),\n",
       " (8981, (3,)),\n",
       " (8585, (3,)),\n",
       " (6010, (0,)),\n",
       " (11123, (0,)),\n",
       " (9023, (4,)),\n",
       " (10801, (4,)),\n",
       " (4680, (3,)),\n",
       " (6125, (5,)),\n",
       " (8932, (3,)),\n",
       " (857, (4,)),\n",
       " (7333, (5,)),\n",
       " (3475, (6,)),\n",
       " (2473, (5,)),\n",
       " (1526, (0,)),\n",
       " (1089, (6,)),\n",
       " (6317, (4,)),\n",
       " (11287, (0,)),\n",
       " (5456, (4,)),\n",
       " (4703, (2,)),\n",
       " (3130, (0,)),\n",
       " (2734, (0,)),\n",
       " (7510, (0,)),\n",
       " (3050, (2,)),\n",
       " (1343, (0,)),\n",
       " (7260, (1,)),\n",
       " (6265, (1,)),\n",
       " (5607, (1,)),\n",
       " (5595, (0,)),\n",
       " (8616, (3,)),\n",
       " (2187, (3,)),\n",
       " (1192, (3,)),\n",
       " (972, (4,)),\n",
       " (10322, (0,)),\n",
       " (10060, (0,)),\n",
       " (8996, (4,)),\n",
       " (789, (4,)),\n",
       " (9513, (3,)),\n",
       " (3650, (4,)),\n",
       " (8771, (3,)),\n",
       " (2405, (5,)),\n",
       " (1711, (0,)),\n",
       " (9196, (3,)),\n",
       " (3142, (5,)),\n",
       " (10679, (4,)),\n",
       " (8091, (0,)),\n",
       " (8764, (4,)),\n",
       " (12033, (5,)),\n",
       " (4052, (0,)),\n",
       " (12021, (4,)),\n",
       " (1804, (2,)),\n",
       " (2077, (4,)),\n",
       " (8715, (4,)),\n",
       " (11796, (3,)),\n",
       " (8618, (3,)),\n",
       " (1852, (3,)),\n",
       " (7141, (4,)),\n",
       " (11351, (3,)),\n",
       " (8047, (2,)),\n",
       " (5896, (5,)),\n",
       " (3060, (3,)),\n",
       " (11005, (3,)),\n",
       " (2167, (0,)),\n",
       " (2950, (0,)),\n",
       " (11195, (0,)),\n",
       " (1583, (4,)),\n",
       " (10173, (3,)),\n",
       " (6097, (4,)),\n",
       " (11716, (0,)),\n",
       " (5738, (3,)),\n",
       " (3163, (0,)),\n",
       " (4117, (6,)),\n",
       " (3090, (3,)),\n",
       " (9644, (3,)),\n",
       " (435, (2,)),\n",
       " (6301, (4,)),\n",
       " (10815, (4,)),\n",
       " (3653, (4,)),\n",
       " (6734, (3,)),\n",
       " (1735, (1,)),\n",
       " (1267, (4,)),\n",
       " (10590, (3,)),\n",
       " (4,),\n",
       " (5781, (4,)),\n",
       " (4054, (0,)),\n",
       " (11290, (4,)),\n",
       " (10766, (4,)),\n",
       " (10033, (4,)),\n",
       " (2535, (0,)),\n",
       " (6328, (1,)),\n",
       " (2225, (5,)),\n",
       " (1429, (3,)),\n",
       " (1230, (5,)),\n",
       " (9850, (4,)),\n",
       " (5050, (0,)),\n",
       " (7202, (4,)),\n",
       " (8846, (4,)),\n",
       " (3075, (4,)),\n",
       " (10408, (3,)),\n",
       " (5263, (0,)),\n",
       " (3896, (4,)),\n",
       " (11707, (4,)),\n",
       " (3112, (3,)),\n",
       " (11841, (4,)),\n",
       " (10311, (2,)),\n",
       " (4928, (3,)),\n",
       " (11878, (3,)),\n",
       " (6107, (3,)),\n",
       " (4320, (3,)),\n",
       " (5537, (3,)),\n",
       " (10401, (4,)),\n",
       " (3367, (4,)),\n",
       " (11496, (5,)),\n",
       " (1860, (5,)),\n",
       " (5662, (3,)),\n",
       " (10176, (3,)),\n",
       " (6100, (4,)),\n",
       " (6897, (0,)),\n",
       " (6501, (0,)),\n",
       " (5542, (5,)),\n",
       " (1665, (4,)),\n",
       " (2770, (0,)),\n",
       " (3705, (4,)),\n",
       " (5244, (0,)),\n",
       " (11149, (0,)),\n",
       " (6179, (4,)),\n",
       " (10887, (0,)),\n",
       " (11402, (0,)),\n",
       " (10818, (4,)),\n",
       " (7399, (5,)),\n",
       " (1878, (4,)),\n",
       " (4301, (3,)),\n",
       " (6839, (0,)),\n",
       " (8207, (3,)),\n",
       " (7987, (4,)),\n",
       " (4690, (4,)),\n",
       " (6730, (4,)),\n",
       " (6767, (3,)),\n",
       " (651, (4,)),\n",
       " (1360, (0,)),\n",
       " (10388, (0,)),\n",
       " (9793, (2,)),\n",
       " (3226, (0,)),\n",
       " (2204, (3,)),\n",
       " (1209, (3,)),\n",
       " (7755, (4,)),\n",
       " (5825, (0,)),\n",
       " (6760, (4,)),\n",
       " (11334, (0,)),\n",
       " (3475, (5,)),\n",
       " (5503, (4,)),\n",
       " (2063, (4,)),\n",
       " (7944, (0,)),\n",
       " (806, (4,)),\n",
       " (5927, (3,)),\n",
       " (8503, (0,)),\n",
       " (4464, (0,)),\n",
       " (9213, (3,)),\n",
       " (5533, (4,)),\n",
       " (11814, (2,)),\n",
       " (6182, (4,)),\n",
       " (9365, (0,)),\n",
       " (1098, (4,)),\n",
       " (9055, (5,)),\n",
       " (2203, (0,)),\n",
       " (3521, (3,)),\n",
       " (7786, (4,)),\n",
       " (4566, (3,)),\n",
       " (6455, (0,)),\n",
       " (8941, (1,)),\n",
       " (8454, (6,)),\n",
       " (11642, (4,)),\n",
       " (2702, (4,)),\n",
       " (7925, (0,)),\n",
       " (826, (2,)),\n",
       " (12075, (3,)),\n",
       " (8994, (4,)),\n",
       " (4955, (4,)),\n",
       " (10202, (4,)),\n",
       " (5342, (4,)),\n",
       " (7158, (4,)),\n",
       " (8746, (6,)),\n",
       " (2943, (3,)),\n",
       " (3726, (3,)),\n",
       " (10391, (0,)),\n",
       " (3119, (4,)),\n",
       " (1189, (0,)),\n",
       " (3229, (0,)),\n",
       " (6983, (3,)),\n",
       " (10056, (3,)),\n",
       " (4062, (1,)),\n",
       " (6886, (2,)),\n",
       " (4050, (0,)),\n",
       " (6911, (0,)),\n",
       " (10918, (3,)),\n",
       " (6976, (4,)),\n",
       " (2622, (1,)),\n",
       " (3545, (4,)),\n",
       " (5585, (4,)),\n",
       " (11490, (4,)),\n",
       " (2863, (0,)),\n",
       " (1868, (0,)),\n",
       " (8708, (4,)),\n",
       " (6805, (5,)),\n",
       " (8483, (3,)),\n",
       " (7226, (3,)),\n",
       " (8671, (5,)),\n",
       " (7066, (0,)),\n",
       " (5937, (0,)),\n",
       " (1509, (5,)),\n",
       " (10335, (1,)),\n",
       " (9879, (5,)),\n",
       " (4358, (4,)),\n",
       " (2967, (4,)),\n",
       " (9605, (4,)),\n",
       " (3477, (2,)),\n",
       " (4395, (3,)),\n",
       " (5828, (4,)),\n",
       " (9642, (3,)),\n",
       " (3475, (3,)),\n",
       " (9684, (4,)),\n",
       " (9830, (5,)),\n",
       " (444, (4,)),\n",
       " (10467, (4,)),\n",
       " (4945, (3,)),\n",
       " (7680, (2,)),\n",
       " (219, (3,)),\n",
       " (1537, (6,)),\n",
       " (6428, (4,)),\n",
       " (2735, (4,)),\n",
       " (5158, (3,)),\n",
       " (10418, (4,)),\n",
       " (4673, (1,)),\n",
       " (11754, (4,)),\n",
       " (3931, (1,)),\n",
       " (5250, (4,)),\n",
       " (3919, (0,)),\n",
       " (4288, (3,)),\n",
       " (5444, (0,)),\n",
       " (3073, (4,)),\n",
       " (1944, (4,)),\n",
       " (7453, (4,)),\n",
       " (11705, (4,)),\n",
       " (1074, (4,)),\n",
       " (9069, (5,)),\n",
       " (1484, (0,)),\n",
       " (6034, (5,)),\n",
       " (8834, (2,)),\n",
       " (826, (0,)),\n",
       " (11614, (3,)),\n",
       " (5751, (4,)),\n",
       " (11695, (2,)),\n",
       " (9117, (6,)),\n",
       " (3377, (5,)),\n",
       " (3710, (3,)),\n",
       " (9270, (4,)),\n",
       " (5143, (4,)),\n",
       " (6682, (0,)),\n",
       " (11196, (0,)),\n",
       " (11735, (4,)),\n",
       " (2495, (4,)),\n",
       " (8649, (3,)),\n",
       " (11857, (1,)),\n",
       " (12033, (2,)),\n",
       " (1937, (5,)),\n",
       " (990, (0,)),\n",
       " (7148, (0,)),\n",
       " (5393, (3,)),\n",
       " (4786, (4,)),\n",
       " (1055, (4,)),\n",
       " (7931, (0,)),\n",
       " (1092, (3,)),\n",
       " (9821, (4,)),\n",
       " (5467, (1,)),\n",
       " (10470, (4,)),\n",
       " (2263, (4,)),\n",
       " (1530, (4,)),\n",
       " (11961, (5,)),\n",
       " (10222, (0,)),\n",
       " (8467, (3,)),\n",
       " (4403, (5,)),\n",
       " (6491, (0,)),\n",
       " (8601, (3,)),\n",
       " (9900, (4,)),\n",
       " (5819, (3,)),\n",
       " (8643, (4,)),\n",
       " (4530, (0,)),\n",
       " (11715, (3,)),\n",
       " (3508, (3,)),\n",
       " (127, (3,)),\n",
       " (8460, (4,)),\n",
       " (6023, (3,)),\n",
       " (3090, (0,)),\n",
       " (7590, (4,)),\n",
       " (3509, (3,)),\n",
       " (2118, (3,)),\n",
       " (120, (4,)),\n",
       " (11534, (4,)),\n",
       " (8179, (2,)),\n",
       " (3952, (0,)),\n",
       " (6795, (3,)),\n",
       " (4778, (6,)),\n",
       " (9273, (4,)),\n",
       " (11958, (3,)),\n",
       " (282, (3,)),\n",
       " (7680, (0,)),\n",
       " (5192, (3,)),\n",
       " (11077, (1,)),\n",
       " (10701, (3,)),\n",
       " (2250, (0,)),\n",
       " (9486, (4,)),\n",
       " (11130, (4,)),\n",
       " (3968, (4,)),\n",
       " (4351, (3,)),\n",
       " (6180, (4,)),\n",
       " (6690, (2,)),\n",
       " (4170, (2,)),\n",
       " (4826, (3,)),\n",
       " (750, (4,)),\n",
       " (1656, (2,)),\n",
       " (2924, (4,)),\n",
       " (3611, (4,)),\n",
       " (9516, (4,)),\n",
       " (3361, (5,)),\n",
       " (11294, (4,)),\n",
       " (3998, (4,)),\n",
       " (6222, (5,)),\n",
       " (10063, (1,)),\n",
       " (11695, (0,)),\n",
       " (9029, (3,)),\n",
       " (2516, (3,)),\n",
       " (10116, (4,)),\n",
       " (8859, (4,)),\n",
       " (2558, (4,)),\n",
       " (3751, (0,)),\n",
       " (8301, (5,)),\n",
       " (9406, (1,)),\n",
       " (3489, (0,)),\n",
       " (11799, (4,)),\n",
       " (8713, (3,)),\n",
       " (11537, (4,)),\n",
       " (5766, (4,)),\n",
       " (3130, (5,)),\n",
       " (2734, (5,)),\n",
       " (5407, (3,)),\n",
       " (7248, (5,)),\n",
       " (396, (0,)),\n",
       " (5449, (4,)),\n",
       " (6190, (3,)),\n",
       " (5187, (4,)),\n",
       " (10359, (4,)),\n",
       " (11092, (4,)),\n",
       " (3796, (4,)),\n",
       " (9701, (4,)),\n",
       " (1240, (3,)),\n",
       " (347, (0,)),\n",
       " (11293, (1,)),\n",
       " (1, (0,)),\n",
       " (9130, (3,)),\n",
       " (6828, (3,)),\n",
       " (4852, (0,)),\n",
       " (6482, (3,)),\n",
       " (8311, (4,)),\n",
       " (7915, (4,)),\n",
       " (7653, (4,)),\n",
       " (6000, (4,)),\n",
       " (2965, (4,)),\n",
       " (3475, (2,)),\n",
       " (1574, (4,)),\n",
       " (7824, (3,)),\n",
       " (10551, (3,)),\n",
       " (966, (4,)),\n",
       " (7604, (4,)),\n",
       " (716, (5,)),\n",
       " (7254, (3,)),\n",
       " (10054, (0,)),\n",
       " (1537, (5,)),\n",
       " (1778, (4,)),\n",
       " (5726, (3,)),\n",
       " (4731, (3,)),\n",
       " (5035, (4,)),\n",
       " (12045, (0,)),\n",
       " (10282, (4,)),\n",
       " (1705, (0,)),\n",
       " (11079, (0,)),\n",
       " (4944, (3,)),\n",
       " (6676, (3,)),\n",
       " (1942, (4,)),\n",
       " (9887, (4,)),\n",
       " (10666, (3,)),\n",
       " (1656, (0,)),\n",
       " (6060, (4,)),\n",
       " (6182, (1,)),\n",
       " (9275, (3,)),\n",
       " (5806, (3,)),\n",
       " (6843, (4,)),\n",
       " (9117, (5,)),\n",
       " (666, (2,)),\n",
       " (3708, (3,)),\n",
       " (7865, (1,)),\n",
       " (10847, (6,)),\n",
       " (691, (0,)),\n",
       " (10350, (3,)),\n",
       " (7007, (4,)),\n",
       " (11783, (4,)),\n",
       " (6983, (0,)),\n",
       " (8799, (0,)),\n",
       " (9710, (0,)),\n",
       " (5901, (1,)),\n",
       " (5168, (1,)),\n",
       " (4134, (3,)),\n",
       " (7735, (4,)),\n",
       " (5567, (4,)),\n",
       " (9959, (5,)),\n",
       " (6478, (4,)),\n",
       " (2481, (3,)),\n",
       " (707, (4,)),\n",
       " (8690, (4,)),\n",
       " (8270, (0,)),\n",
       " (744, (3,)),\n",
       " (6649, (3,)),\n",
       " (7037, (4,)),\n",
       " (513, (2,)),\n",
       " (10505, (3,)),\n",
       " (1169, (3,)),\n",
       " (7512, (4,)),\n",
       " (10285, (4,)),\n",
       " (1333, (1,)),\n",
       " (8671, (2,)),\n",
       " (10718, (3,)),\n",
       " (11755, (4,)),\n",
       " (9065, (3,)),\n",
       " (7936, (3,)),\n",
       " (2663, (0,)),\n",
       " (6519, (0,)),\n",
       " (11033, (0,)),\n",
       " (5080, (5,)),\n",
       " (2420, (4,)),\n",
       " (1089, (0,)),\n",
       " (7929, (4,)),\n",
       " (2668, (2,)),\n",
       " (12028, (6,)),\n",
       " (481, (0,)),\n",
       " (1550, (4,)),\n",
       " (219, (0,)),\n",
       " (11439, (4,)),\n",
       " (8202, (0,)),\n",
       " (9137, (4,)),\n",
       " (1325, (3,)),\n",
       " (6227, (4,)),\n",
       " (9085, (1,)),\n",
       " (9758, (5,)),\n",
       " (4582, (3,)),\n",
       " (3841, (4,)),\n",
       " (9460, (0,)),\n",
       " (6398, (3,)),\n",
       " (7443, (3,)),\n",
       " (7346, (2,)),\n",
       " (6166, (1,)),\n",
       " (11330, (2,)),\n",
       " (6154, (0,)),\n",
       " (1184, (4,)),\n",
       " (6604, (2,)),\n",
       " (8682, (2,)),\n",
       " (9411, (0,)),\n",
       " (402, (4,)),\n",
       " (11816, (4,)),\n",
       " (9526, (5,)),\n",
       " (10485, (0,)),\n",
       " (4258, (4,)),\n",
       " (3931, (6,)),\n",
       " (7860, (3,)),\n",
       " (7119, (4,)),\n",
       " (7265, (5,)),\n",
       " (4531, (0,)),\n",
       " (2157, (1,)),\n",
       " (4209, (4,)),\n",
       " (6894, (3,)),\n",
       " (7654, (0,)),\n",
       " (1883, (0,)),\n",
       " (4246, (3,)),\n",
       " (10649, (0,)),\n",
       " (6858, (4,)),\n",
       " (10976, (4,)),\n",
       " (3418, (4,)),\n",
       " (6633, (3,)),\n",
       " (4239, (4,)),\n",
       " (11922, (4,)),\n",
       " (5041, (6,)),\n",
       " (4403, (2,)),\n",
       " (545, (3,)),\n",
       " (4464, (5,)),\n",
       " (5101, (4,)),\n",
       " (1816, (5,)),\n",
       " (2465, (5,)),\n",
       " (3742, (1,)),\n",
       " (5770, (0,)),\n",
       " (6309, (4,)),\n",
       " (7611, (2,)),\n",
       " (8893, (0,)),\n",
       " (340, (0,)),\n",
       " (5587, (0,)),\n",
       " (30, (5,)),\n",
       " (8696, (4,)),\n",
       " (3934, (0,)),\n",
       " (3874, (4,)),\n",
       " (4219, (3,)),\n",
       " (10488, (0,)),\n",
       " (10032, (4,)),\n",
       " (3722, (0,)),\n",
       " (6795, (0,)),\n",
       " (1998, (2,)),\n",
       " (2870, (4,)),\n",
       " (568, (4,)),\n",
       " (8909, (4,)),\n",
       " (4087, (4,)),\n",
       " (4432, (3,)),\n",
       " (739, (3,)),\n",
       " (4870, (4,)),\n",
       " (9983, (4,)),\n",
       " (1784, (3,)),\n",
       " (11522, (0,)),\n",
       " (9721, (4,)),\n",
       " (6897, (3,)),\n",
       " (1826, (4,)),\n",
       " (4511, (3,)),\n",
       " (10887, (3,)),\n",
       " (11849, (4,)),\n",
       " (9547, (4,)),\n",
       " (3752, (0,)),\n",
       " (5070, (3,)),\n",
       " (3296, (4,)),\n",
       " (7560, (5,)),\n",
       " (6613, (0,)),\n",
       " (7346, (0,)),\n",
       " (5895, (4,)),\n",
       " (9885, (4,)),\n",
       " (921, (0,)),\n",
       " (11962, (3,)),\n",
       " (10967, (3,)),\n",
       " (2364, (3,)),\n",
       " (12004, (4,)),\n",
       " (8683, (0,)),\n",
       " (226, (1,)),\n",
       " (6920, (4,)),\n",
       " (1149, (4,)),\n",
       " (10847, (5,)),\n",
       " (11568, (4,)),\n",
       " (803, (4,)),\n",
       " (10302, (4,)),\n",
       " (6745, (3,)),\n",
       " (3798, (4,)),\n",
       " (8178, (4,)),\n",
       " (8324, (5,)),\n",
       " (11781, (4,)),\n",
       " (9082, (3,)),\n",
       " (2620, (4,)),\n",
       " (3130, (2,)),\n",
       " (7867, (4,)),\n",
       " (32, (0,)),\n",
       " (571, (4,)),\n",
       " (397, (4,)),\n",
       " (4537, (0,)),\n",
       " (4994, (3,)),\n",
       " (6689, (4,)),\n",
       " (3469, (3,)),\n",
       " (561, (2,)),\n",
       " (9770, (3,)),\n",
       " (11414, (3,)),\n",
       " (3907, (4,)),\n",
       " (7076, (4,)),\n",
       " (10157, (3,)),\n",
       " (1217, (3,)),\n",
       " (7095, (6,)),\n",
       " (9130, (0,)),\n",
       " (6962, (0,)),\n",
       " (7611, (0,)),\n",
       " (9102, (1,)),\n",
       " (2425, (3,)),\n",
       " (3968, (0,)),\n",
       " (4507, (4,)),\n",
       " (1555, (3,)),\n",
       " (6323, (4,)),\n",
       " (5066, (4,)),\n",
       " (11882, (4,)),\n",
       " (716, (2,)),\n",
       " (9294, (0,)),\n",
       " (7143, (3,)),\n",
       " (1768, (3,)),\n",
       " (9234, (4,)),\n",
       " (1537, (2,)),\n",
       " (7319, (4,)),\n",
       " (2193, (3,)),\n",
       " (1152, (4,)),\n",
       " (10910, (1,)),\n",
       " (10898, (0,)),\n",
       " (9915, (1,)),\n",
       " (4731, (0,)),\n",
       " (2842, (3,)),\n",
       " (2795, (2,)),\n",
       " (8265, (4,)),\n",
       " (5483, (4,)),\n",
       " (3109, (5,)),\n",
       " (3231, (4,)),\n",
       " (6676, (0,)),\n",
       " (187, (4,)),\n",
       " (9275, (0,)),\n",
       " (4043, (4,)),\n",
       " (3048, (4,)),\n",
       " (7300, (4,)),\n",
       " (3435, (4,)),\n",
       " (4214, (3,)),\n",
       " (1505, (0,)),\n",
       " (10768, (3,)),\n",
       " (11528, (0,)),\n",
       " (4628, (0,)),\n",
       " (5684, (3,)),\n",
       " (11716, (2,)),\n",
       " (3708, (0,)),\n",
       " (1821, (4,)),\n",
       " (8301, (0,)),\n",
       " (6182, (6,)),\n",
       " (1797, (0,)),\n",
       " (1079, (4,)),\n",
       " (5331, (4,)),\n",
       " (10253, (5,)),\n",
       " (4134, (0,)),\n",
       " (4336, (4,)),\n",
       " (3416, (4,)),\n",
       " (7257, (0,)),\n",
       " (5866, (0,)),\n",
       " (2458, (3,)),\n",
       " (9096, (3,)),\n",
       " (7967, (3,)),\n",
       " (11836, (4,)),\n",
       " (2694, (0,)),\n",
       " (6710, (3,)),\n",
       " (9534, (4,)),\n",
       " (7160, (5,)),\n",
       " (3021, (4,)),\n",
       " (11016, (5,)),\n",
       " (4315, (3,)),\n",
       " (10021, (5,)),\n",
       " (2013, (3,)),\n",
       " (10354, (3,)),\n",
       " (10718, (0,)),\n",
       " (2907, (0,)),\n",
       " (4753, (4,)),\n",
       " (5532, (3,)),\n",
       " (8305, (3,)),\n",
       " (7936, (0,)),\n",
       " (5062, (5,)),\n",
       " (598, (5,)),\n",
       " (2268, (4,)),\n",
       " (5087, (3,)),\n",
       " (9218, (4,)),\n",
       " (5239, (0,)),\n",
       " (2341, (1,)),\n",
       " (1325, (0,)),\n",
       " (11411, (2,)),\n",
       " (4734, (4,)),\n",
       " (1284, (6,)),\n",
       " (3489, (5,)),\n",
       " (1386, (3,)),\n",
       " (9957, (0,)),\n",
       " (3215, (4,)),\n",
       " (841, (5,)),\n",
       " (1404, (0,)),\n",
       " (5292, (3,)),\n",
       " (3294, (4,)),\n",
       " (5615, (6,)),\n",
       " (9452, (4,)),\n",
       " (7260, (0,)),\n",
       " (6265, (0,)),\n",
       " (6542, (4,)),\n",
       " (5607, (0,)),\n",
       " (11116, (0,)),\n",
       " (11464, (5,)),\n",
       " (3245, (4,)),\n",
       " (2959, (0,)),\n",
       " (2515, (5,)),\n",
       " (808, (3,)),\n",
       " (4703, (1,)),\n",
       " (10596, (0,)),\n",
       " (7860, (0,)),\n",
       " (3050, (1,)),\n",
       " (8317, (3,)),\n",
       " (11334, (2,)),\n",
       " (5702, (4,)),\n",
       " (1276, (4,)),\n",
       " (11943, (2,)),\n",
       " (8996, (3,)),\n",
       " (7707, (0,)),\n",
       " (11250, (4,)),\n",
       " (11396, (5,)),\n",
       " (4299, (3,)),\n",
       " (10568, (0,)),\n",
       " (8813, (3,)),\n",
       " (7095, (5,)),\n",
       " (6898, (3,)),\n",
       " (40, (4,)),\n",
       " (10519, (0,)),\n",
       " (2770, (1,)),\n",
       " (7737, (0,)),\n",
       " (11402, (1,)),\n",
       " (6218, (0,)),\n",
       " (649, (4,)),\n",
       " (1804, (1,)),\n",
       " (3072, (3,)),\n",
       " (8623, (4,)),\n",
       " (11442, (3,)),\n",
       " (1857, (4,)),\n",
       " (3897, (4,)),\n",
       " (8047, (1,)),\n",
       " (11272, (4,)),\n",
       " (5750, (3,)),\n",
       " (691, (5,)),\n",
       " (1024, (3,)),\n",
       " (1189, (2,)),\n",
       " (11411, (0,)),\n",
       " (4645, (0,)),\n",
       " (1583, (3,)),\n",
       " (6097, (3,)),\n",
       " (1625, (4,)),\n",
       " (5070, (0,)),\n",
       " (6911, (2,)),\n",
       " (1735, (0,)),\n",
       " (6788, (4,)),\n",
       " (2311, (3,)),\n",
       " (435, (1,)),\n",
       " (6328, (0,)),\n",
       " (1096, (4,)),\n",
       " (6605, (4,)),\n",
       " (101, (4,)),\n",
       " (5804, (0,)),\n",
       " (3653, (3,)),\n",
       " (10595, (4,)),\n",
       " (7905, (3,)),\n",
       " (1005, (3,)),\n",
       " (5781, (3,)),\n",
       " (10766, (3,)),\n",
       " 4395,\n",
       " (5165, (4,)),\n",
       " (5299, (4,)),\n",
       " (5948, (4,)),\n",
       " (3185, (6,)),\n",
       " (11283, (4,)),\n",
       " (8707, (1,)),\n",
       " (1297, (3,)),\n",
       " (8846, (3,)),\n",
       " (3701, (0,)),\n",
       " ...}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[('nv', ('np',))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[2009.66666667, 2009.58333333, 2003.0, 2004.75, 2004.5, 2004.16666667, 2005.66666667, 2005.58333333, 2006.83333333, 2006.75, 2006.08333333, 2007.58333333, 2007.75, 2007.33333333, 2007.91666667, 2007.16666667, 2007.08333333, 2008.58333333, 2002.25, 2002.83333333, 2002.5, 2003.25, 2003.08333333, 2003.66666667, 2003.33333333, 2003.91666667, 2004.83333333, 2004.25, 2003.16666667, 2004.58333333, 2003.75, 2005.16666667, 2005.75, 2005.0, 2005.91666667, 2005.25, 2006.16666667, 2006.25, 2006.66666667, 2005.5, 2005.83333333, 2007.25, 2007.0, 2007.83333333, 2007.41666667, 2006.5, 2008.16666667, 2008.41666667, 2008.66666667, 2008.08333333, 2008.0, 2009.5, 2008.25, 2009.41666667, 2009.75, 2008.75, 2010.75, 2009.33333333, 2009.25, 2009.0, 2009.08333333, 2011.0, 2011.33333333, 2011.5, 2011.16666667, 2012.5, 2002.16666667, 2003.41666667, 2004.0, 2005.08333333, 2005.33333333, 2006.0, 2008.91666667, 2009.16666667, 2010.83333333, 2010.58333333, 2010.5, 2010.08333333, 2010.16666667, 2011.83333333, 2011.08333333, 2010.25, 2011.75, 2012.08333333, 2012.75, 2012.16666667, 2009.91666667, 2009.66666667, 2009.58333333, 2003.0, 2004.75, 2004.91666667, 2004.5, 2004.16666667, 2005.08333333, 2005.83333333, 2005.66666667, 2006.75, 2009.25, 2007.58333333, 2007.75, 2007.33333333, 2007.91666667, 2007.16666667, 2007.25, 2007.0, 2008.08333333, 2008.58333333, 2002.16666667, 2002.83333333, 2002.5, 2002.25, 2003.25, 2003.08333333, 2003.66666667, 2003.33333333, 2003.91666667, 2004.0, 2004.25, 2004.83333333, 2003.16666667, 2004.58333333, 2005.16666667, 2005.75, 2005.0, 2005.91666667, 2005.25, 2006.08333333, 2006.0, 2006.16666667, 2006.66666667, 2005.5, 2007.08333333, 2007.83333333, 2007.41666667, 2006.5, 2006.83333333, 2008.41666667, 2008.66666667, 2008.75, 2008.83333333, 2008.0, 2009.5, 2009.75, 2009.0, 2008.25, 2009.41666667, 2010.75, 2010.16666667, 2009.33333333, 2009.16666667, 2009.08333333, 2011.0, 2011.5, 2011.16666667, 2012.5, 2002.58333333, 2003.41666667, 2003.75, 2005.58333333, 2005.33333333, 2006.25, 2008.91666667, 2008.16666667, 2010.83333333, 2010.25, 2010.58333333, 2010.5, 2010.08333333, 2011.33333333, 2011.83333333, 2011.08333333, 2011.75, 2012.08333333, 2012.75, 2012.16666667, 2013.16666667]\n",
      "[25793.6915908, 26061.0, 25711.0, 25713.0, 26110.5, 25793.6915908, 26061.0, 25711.0, 25713.0, 26110.5]\n"
     ]
    }
   ],
   "source": [
    "for i in data[('e', ('rp',))]:\n",
    "    if(not isinstance(i,tuple) or len(i) == 1):\n",
    "        continue\n",
    "    if isinstance(ans[i][0],float):\n",
    "        print(ans[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[140.0,\n",
       " 140.2,\n",
       " 140.73,\n",
       " 141.180251894,\n",
       " 140.21,\n",
       " 141.5,\n",
       " 141.8,\n",
       " 140.833,\n",
       " 140.0,\n",
       " 140.2,\n",
       " 140.73,\n",
       " 141.180251894,\n",
       " 140.21,\n",
       " 141.5,\n",
       " 141.8,\n",
       " 140.833]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ans[(1169, (4,))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "fname must be a string or file handle",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-23-49a7aa1fb46b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     21\u001b[0m         \u001b[0;32mcontinue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m     \u001b[0mtemp_value\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mentity2id\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mli\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0matt2id\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mli\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfloat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mli\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 23\u001b[0;31m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msavetxt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtemp_value\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\"number_array.txt\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mfmt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"%f\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36msavetxt\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/numpy/lib/npyio.py\u001b[0m in \u001b[0;36msavetxt\u001b[0;34m(fname, X, fmt, delimiter, newline, header, footer, comments, encoding)\u001b[0m\n\u001b[1;32m   1385\u001b[0m         \u001b[0mfh\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mWriteWrap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfname\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoding\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0;34m'latin1'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1386\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1387\u001b[0;31m         \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'fname must be a string or file handle'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1388\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1389\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: fname must be a string or file handle"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/DB15K_NumericalTriples_Tab.txt\",'r') as f:\n",
    "    data = f.readlines()\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/id2number.json\",'r') as f:\n",
    "    id2num = json.load(f)\n",
    "with open(\"/home/zhangjun/QTO/kbc/data/DB15K/att2id.json\",'r') as f:\n",
    "    att2id = json.load(f)\n",
    "with open(\"/home/zhangjun/QTO/data/DB15k-number/entity2id.json\",'r') as f:\n",
    "    entity2id = json.load(f)\n",
    "num2id = {}\n",
    "for id in id2num:\n",
    "    num2id[id2num[id]] = id\n",
    "id2att = {}\n",
    "for att in att2id:\n",
    "    id2att[att2id[att]] = att\n",
    "temp_value = np.zeros((14951,15))\n",
    "for da in data:\n",
    "    li = da.split(\"\\t\")\n",
    "    if(li[1] not in att2id):\n",
    "        continue\n",
    "    temp_value[int(entity2id[li[0]])][int(att2id[li[1]])] = float(li[2])\n",
    "np.savetxt(temp_value,\"num_array.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "with open(\"num_array.pkl\",'wb') as f:\n",
    "    pickle.dump(temp_value,f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MaxMinNormalization(x):\n",
    "    Max = max(x)\n",
    "    Min = min(x)\n",
    "    x = (x - Min) / (Max - Min)\n",
    "    return x\n",
    "out_value = {}\n",
    "for i in temp_value:\n",
    "    value_now = temp_value[i]\n",
    "    value_new = MaxMinNormalization(np.array(list(map(float, value_now))))\n",
    "    for j in range(len(value_now)):\n",
    "        out_value[int(num2id[str(value_now[j]).replace(\"\\n\",\"\")])] = value_new[j]\n",
    "with open(\"id2num.json\",'w') as f:\n",
    "    json.dump(out_value,f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.75261578, 0.952     , 0.77416147, ..., 0.50699351, 0.96583319,\n",
       "       0.84416056])"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "out_value"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.8.3"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
