{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "from sklearn.metrics import roc_auc_score, mean_squared_error as mse\n",
    "from sklearn.decomposition import NMF\n",
    "import pickle\n",
    "\n",
    "# resultdir = os.path.join('..', 'dat', 'citation-results')\n",
    "resultdir = os.path.join('..', 'citation-results')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def mask_items(N,M):\n",
    "    items = np.arange(M)\n",
    "    random_items = np.random.choice(items, size=N)\n",
    "    return random_items"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50 [0.86358958 0.84422267 0.7549631 ]\n",
      "100 [0.82045844 0.76037608 0.87069369]\n",
      "200 [0.57087943 0.83397026 0.7389127 ]\n"
     ]
    }
   ],
   "source": [
    "for K in [50,100,200]:\n",
    "    holdout_eval = np.load(os.path.join(resultdir, 'K=' + str(K) + ';holdout_eval.npy'))\n",
    "    print(K, holdout_eval)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "K=100\n",
    "fitted_influence = np.load(os.path.join(resultdir, 'K=' + str(K) + ';fitted_influence.npy'))\n",
    "fitted_z = np.load(os.path.join(resultdir, 'K=' + str(K) + ';fitted_z.npy'))\n",
    "fitted_gamma = np.load(os.path.join(resultdir, 'K=' + str(K) + ';fitted_gamma.npy'))\n",
    "holdout_eval = np.load(os.path.join(resultdir, 'K=' + str(K) + ';holdout_eval.npy'))\n",
    "\n",
    "with open(os.path.join('..', 'dat', 'OpenResearchCorpus', 'author_id_map'), 'rb') as f:\n",
    "    aid_map = pickle.load(f)\n",
    "with open(os.path.join('..', 'dat', 'OpenResearchCorpus', 'author_name_map'), 'rb') as f:\n",
    "    author_name_map = pickle.load(f)\n",
    "    \n",
    "with open(os.path.join('..', 'dat', 'OpenResearchCorpus', 'paper_info_map'), 'rb') as f:\n",
    "    paper_info = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "arrays = np.load(os.path.join('..', 'dat', 'citation-influence.npz'))\n",
    "Y_past = arrays['past']\n",
    "Y = arrays['current']\n",
    "A = arrays['adj']\n",
    "N = Y.shape[0]\n",
    "M = Y.shape[1]\n",
    "yp_heldout = mask_items(N,M)\n",
    "y_heldout = mask_items(N,M)\n",
    "a_heldout = mask_items(N,N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1218"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "target_venues = {'Journal of Machine Learning Research'}\n",
    "recent_ml_auth_ids = set()\n",
    "for paper, attr in paper_info.items():\n",
    "    paper_venue = attr['venue']\n",
    "    paper_year = attr['year']\n",
    "    authors = attr['authors']\n",
    "    aids = [author['ids'][0] for author in authors if len(author['ids']) > 0]\n",
    "    if paper_venue in target_venues and paper_year >= 2015:\n",
    "#     if paper_year >= 2015:\n",
    "        recent_ml_auth_ids |= set(aids)\n",
    "len(recent_ml_auth_ids)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Michael I. Jordan\n",
      "Bernhard Schölkopf\n",
      "Jieping Ye\n",
      "Francis R. Bach\n",
      "Eric P. Xing\n",
      "Zoubin Ghahramani\n",
      "Noah A. Smith\n",
      "Dale Schuurmans\n",
      "Tong Zhang\n",
      "Yoshua Bengio\n",
      "Thorsten Joachims\n",
      "Klaus-Robert Müller\n",
      "Yoram Singer\n",
      "David M. Blei\n",
      "Andreas Krause\n",
      "Hongyuan Zha\n",
      "Mehryar Mohri\n",
      "Martin J. Wainwright\n",
      "Lawrence Carin\n",
      "Koby Crammer\n",
      "Csaba Szepesvári\n",
      "Masashi Sugiyama\n",
      "Yee Whye Teh\n",
      "Shie Mannor\n",
      "Xiaojin Zhu\n",
      "Arthur Gretton\n",
      "Tobias Scheffer\n",
      "Max Welling\n",
      "Trevor Darrell\n",
      "Shipeng Yu\n",
      "Alan Fern\n",
      "Eric Horvitz\n",
      "Thomas G. Dietterich\n",
      "Joshua B. Tenenbaum\n",
      "Shai Shalev-Shwartz\n",
      "Ivor W. Tsang\n",
      "Massimiliano Pontil\n",
      "Jure Leskovec\n",
      "Samy Bengio\n",
      "Lise Getoor\n",
      "Chih-Jen Lin\n",
      "Doina Precup\n",
      "Rémi Munos\n",
      "Russell Greiner\n",
      "Nathan Srebro\n",
      "S. Sathiya Keerthi\n",
      "Richard S. Sutton\n",
      "Lyle H. Ungar\n",
      "Ran El-Yaniv\n",
      "Bin Yu\n",
      "Deepayan Chakrabarti\n",
      "Naonori Ueda\n",
      "Neil D. Lawrence\n",
      "Nuno Vasconcelos\n",
      "Pieter Abbeel\n",
      "Vikas Sindhwani\n",
      "Philip M. Long\n",
      "Pradeep Ravikumar\n",
      "Mauro Maggioni\n",
      "Trevor J. Hastie\n",
      "Alan L. Yuille\n",
      "Yann LeCun\n",
      "Guillermo Sapiro\n",
      "Zhihua Zhang\n",
      "Steven C. H. Hoi\n",
      "Wei Xu\n",
      "Kristian Kersting\n",
      "Michael W. Mahoney\n",
      "Jennifer G. Dy\n",
      "Manfred K. Warmuth\n",
      "Joelle Pineau\n",
      "Petros Drineas\n",
      "Dengyong Zhou\n",
      "Sofus A. Macskassy\n",
      "Carla E. Brodley\n",
      "Le Song\n",
      "Alexandre Bouchard-Côté\n",
      "David B. Dunson\n",
      "Kenji Fukumizu\n",
      "Brendan J. Frey\n",
      "Fei Sha\n",
      "Nando de Freitas\n",
      "Erik B. Sudderth\n",
      "Ambuj Tewari\n",
      "Hugo Larochelle\n",
      "Barnabás Póczos\n",
      "Robert C. Williamson\n",
      "John C. Duchi\n",
      "Gavin C. Cawley\n",
      "Kilian Q. Weinberger\n",
      "Mário A. T. Figueiredo\n",
      "Kevin Leyton-Brown\n",
      "Jinbo Bi\n",
      "Stephen P. Boyd\n",
      "Ioannis Tsamardinos\n",
      "Constantin F. Aliferis\n",
      "Ole Winther\n",
      "Alexander R. Statnikov\n",
      "Mohammad Ghavamzadeh\n",
      "Samuel Kaski\n",
      "Bharath K. Sriperumbudur\n",
      "Ingo Steinwart\n",
      "Massih-Reza Amini\n",
      "Ulrike von Luxburg\n",
      "Tianbao Yang\n",
      "Konrad Rieck\n",
      "Karthik Sridharan\n",
      "Arindam Banerjee\n",
      "Joris M. Mooij\n",
      "Geoffrey I. Webb\n",
      "Sayan Mukherjee\n",
      "M. Pawan Kumar\n",
      "Xindong Wu\n",
      "Lorenzo Rosasco\n",
      "Olivier Cappé\n",
      "Arnaud Doucet\n",
      "Han Liu\n",
      "Frank D. Wood\n",
      "Alexander Rakhlin\n",
      "Benjamin Recht\n",
      "Raquel Urtasun\n",
      "Jan Peters\n",
      "Aapo Hyvärinen\n",
      "Issei Sato\n",
      "Guy Lebanon\n",
      "Marina Meila\n",
      "Ryan P. Adams\n",
      "Mikio L. Braun\n",
      "Vladimir Vapnik\n",
      "Maya R. Gupta\n",
      "Iain Murray\n",
      "Holger H. Hoos\n",
      "Lei Shi\n",
      "Soumya Ray\n",
      "Daniel J. Hsu\n",
      "Finale Doshi-Velez\n",
      "Éric Gaussier\n",
      "Xinhua Zhang\n",
      "Joseph Keshet\n",
      "Liu Yang\n",
      "Ryota Tomioka\n",
      "Wei Pan\n",
      "James Bailey\n",
      "Risi Kondor\n",
      "Alessandro Lazaric\n",
      "Xiaotong Shen\n",
      "Ding-Xuan Zhou\n",
      "Ohad Shamir\n",
      "Marcus Hutter\n",
      "Cynthia Rudin\n",
      "André F. T. Martins\n",
      "David Barber\n",
      "Benjamin Van Roy\n",
      "Gábor Lugosi\n",
      "Stéphane Canu\n",
      "Mario Marchand\n",
      "Cheng Soon Ong\n",
      "Jonathan Chang\n",
      "S. Sundararajan\n",
      "Niels Landwehr\n",
      "François Fleuret\n",
      "Tamir Hazan\n",
      "Mark Herbster\n",
      "Manuel Gomez-Rodriguez\n",
      "Shivani Agarwal\n",
      "Huan Xu\n",
      "Hariharan Narayanan\n",
      "Martha White\n",
      "Xi Chen\n",
      "Stéphan Clémençon\n",
      "John V. Guttag\n",
      "David Page\n",
      "Yaacov Ritov\n",
      "Hongbin Zha\n",
      "Ganesh Ramakrishnan\n",
      "Bin Li\n",
      "Shinichi Nakajima\n",
      "David Madigan\n",
      "Dominik Janzing\n",
      "Matthew D. Hoffman\n",
      "Yi Li\n",
      "Pedro M. Q. Aguiar\n",
      "Peilin Zhao\n",
      "Karol Gregor\n",
      "Alexandre d'Aspremont\n",
      "Lars Kai Hansen\n",
      "Todd K. Leen\n",
      "Victor S. Sheng\n",
      "Guillaume Bouchard\n",
      "Parikshit Ram\n",
      "Alain Rakotomamonjy\n",
      "Luis E. Ortiz\n",
      "Dinh Q. Phung\n",
      "Vittorio Murino\n",
      "Garvesh Raskutti\n",
      "Chao Liu\n",
      "Takafumi Kanamori\n",
      "Florence d'Alché-Buc\n",
      "Matthijs T. J. Spaan\n",
      "Johannes Fürnkranz\n",
      "Sébastien Bubeck\n",
      "Marie Szafranski\n",
      "Geoff Holmes\n",
      "Bernhard Pfahringer\n",
      "Junhui Wang\n",
      "Samuel Gershman\n",
      "Nir Ailon\n",
      "Daniil Ryabko\n",
      "Stephen J. Roberts\n",
      "Katsumi Inoue\n",
      "Shohei Shimizu\n",
      "Sebastian Riedel\n",
      "François Laviolette\n",
      "Steve Hanneke\n",
      "Laurens van der Maaten\n",
      "Maria-Florina Balcan\n",
      "Lester W. Mackey\n",
      "Albert Bifet\n",
      "Samuel Gerber\n",
      "Mark D. Reid\n",
      "Daniel Lowd\n",
      "David Mease\n",
      "Ming Yuan\n",
      "Elad Hazan\n",
      "Yaakov Engel\n",
      "Vladimir Vovk\n",
      "Janez Demsar\n",
      "Mathieu Salzmann\n",
      "Joseph K. Bradley\n",
      "Abraham J. Wyner\n",
      "Aarti Singh\n",
      "Bruno Scherrer\n",
      "Daniel J. Lizotte\n",
      "Shai Ben-David\n",
      "Tammo Krueger\n",
      "William B. March\n",
      "Sylvain Arlot\n",
      "Volkan Cevher\n",
      "Dongryeol Lee\n",
      "Michalis K. Titsias\n",
      "Zhirong Yang\n",
      "Richard E. Turner\n",
      "Dean P. Foster\n",
      "Yair Wiener\n",
      "Ameet Talwalkar\n",
      "Hamed Masnadi-Shirazi\n",
      "Yutian Chen\n",
      "J. Saketha Nath\n",
      "Jinzhu Jia\n",
      "Jean Honorio\n",
      "Rajesh Ranganath\n",
      "Nahum Shimkin\n",
      "Yaoliang Yu\n",
      "Andreas Buja\n",
      "Vladimir Koltchinskii\n",
      "Yichao Wu\n",
      "Qiang Wu\n",
      "Byron C. Wallace\n",
      "Sujay Sanghavi\n",
      "Le Lu\n",
      "Jianqing Fan\n",
      "Christian Igel\n",
      "Vitaly Feldman\n",
      "Fernando Pérez-Cruz\n",
      "H. Brendan McMahan\n",
      "Jin Tian\n",
      "Jonas Peters\n",
      "Arnak S. Dalalyan\n",
      "Wojciech Kotlowski\n",
      "Emily B. Fox\n",
      "Christoph Sawade\n",
      "Mingyuan Zhou\n",
      "Peter Grünwald\n",
      "Deniz Erdogmus\n",
      "Stephen E. Fienberg\n",
      "Kate Saenko\n",
      "Yuchen Zhang\n",
      "Michael Mitzenmacher\n",
      "Mikko Koivisto\n",
      "András György\n",
      "Tobias Glasmachers\n",
      "Rahul Mazumder\n",
      "Aryeh Kontorovich\n",
      "Nan Du\n",
      "Jason K. Johnson\n",
      "François Caron\n",
      "Sivan Sabato\n",
      "Leonidas Lefakis\n",
      "Jia Li\n",
      "Frank Hutter\n",
      "Andreas Maurer\n",
      "Yajun Wang\n",
      "Nguyen Xuan Vinh\n",
      "Elena Marchiori\n",
      "Gianluca Bontempi\n",
      "Sinead Williamson\n",
      "Padraig Cunningham\n",
      "Zoltán Szabó\n",
      "Malik Magdon-Ismail\n",
      "Grégoire Montavon\n",
      "Elizabeth S. Burnside\n",
      "Dotan Di Castro\n",
      "Bharath Hariharan\n",
      "Jacob Bien\n",
      "Erkki Oja\n",
      "Gérard Biau\n",
      "Alexandre Gramfort\n",
      "Carey E. Priebe\n",
      "Ana M. Martínez\n",
      "Dan Shen\n",
      "Alexander Gammerman\n",
      "Vladimir G. Spokoiny\n",
      "Aki Vehtari\n",
      "Eric Moulines\n",
      "Fen Xia\n",
      "Justin Bedo\n",
      "Pascal Germain\n",
      "Ali Shojaie\n",
      "George Michailidis\n",
      "Ricardo Henao\n",
      "Shahar Mendelson\n",
      "Samory Kpotufe\n",
      "Jason D. Lee\n",
      "Alexandre Lacasse\n",
      "Gerhard Neumann\n",
      "Olivier Colliot\n",
      "András Antos\n",
      "Tapio Pahikkala\n",
      "Vikas Singh\n",
      "Alborz Geramifard\n",
      "Aurélien Garivier\n",
      "Minghu Song\n",
      "Liwei Wang\n",
      "Alberto Suárez\n",
      "Tianxi Cai\n",
      "Qi Yan\n",
      "Peter Richtárik\n",
      "Artur Dubrawski\n",
      "Minmin Chen\n",
      "Andrew Gordon Wilson\n",
      "Kevin Bleakley\n",
      "Tim van Erven\n",
      "Alexandre B. Tsybakov\n",
      "Stephen H. Bach\n",
      "Jian Zhang\n",
      "Kevin Robert Canini\n",
      "John P. Cunningham\n",
      "Matthias Broecheler\n",
      "Reza Bosagh Zadeh\n",
      "Lei Yang\n",
      "Abdeslam Boularias\n",
      "Teemu Roos\n",
      "Katsuhiko Ishiguro\n",
      "Jaakko Luttinen\n",
      "Huizhen Yu\n",
      "Mykel J. Kochenderfer\n",
      "Blaine Nelson\n",
      "László Györfi\n",
      "Jenna Wiens\n",
      "Fernando Fernández\n",
      "Michael Chertkov\n",
      "Srikanth Jagabathula\n",
      "Irene M. Ong\n",
      "Johan A. K. Suykens\n",
      "Nakul Verma\n",
      "Markus Püschel\n",
      "Sara A. van de Geer\n",
      "Guy Lever\n",
      "Brendan Juba\n",
      "Duy Nguyen-Tuong\n",
      "Xavier Bresson\n",
      "David P. Helmbold\n",
      "Stanislav Funiak\n",
      "Kazuho Watanabe\n",
      "Andrey Bernstein\n",
      "Antonio Artés-Rodríguez\n",
      "Milan Vojnovic\n",
      "Mark J. Schervish\n",
      "Sergey Levine\n",
      "Luc Devroye\n",
      "José Miguel Hernández-Lobato\n",
      "Benjamin I. P. Rubinstein\n",
      "Paramveer S. Dhillon\n",
      "Sophia Ananiadou\n",
      "Vikash K. Mansinghka\n",
      "Marc G. Genton\n",
      "Guillaume Lecué\n",
      "Margareta Ackerman\n",
      "Dan Yang\n",
      "Laurenz Wiskott\n",
      "Jacques Wainer\n",
      "Akiko Takeda\n",
      "Patrick Shafto\n",
      "Alexander Binder\n",
      "Siamak Ravanbakhsh\n",
      "Yann Ollivier\n",
      "William Dabney\n",
      "Giles Hooker\n",
      "Marco Loog\n",
      "Peter Reutemann\n",
      "Carme Torras\n",
      "Rémi Bardenet\n",
      "Sean Luke\n",
      "Austin J. Brockmeier\n",
      "Yonina C. Eldar\n",
      "Torsten Hothorn\n",
      "Barbara E. Engelhardt\n",
      "Cosma Rohilla Shalizi\n",
      "Marco Zaffalon\n",
      "Giorgio Corani\n",
      "Hans W. Guesgen\n",
      "Yufeng Liu\n",
      "Ling Wang\n",
      "Jie Chen\n",
      "Herbert Jaeger\n",
      "Zhiyong Liu\n",
      "Chris Thornton\n"
     ]
    }
   ],
   "source": [
    "id_to_author_map = {idx: aid for aid,idx in aid_map.items()}\n",
    "ranked_by_citations = np.argsort(-Y_past.sum(axis=1))\n",
    "for idx in ranked_by_citations:\n",
    "    aid = id_to_author_map[idx]\n",
    "    if aid in recent_ml_auth_ids:\n",
    "        print(author_name_map[aid])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Eric P. Xing\n",
      "Bernhard Schölkopf\n",
      "Padraig Cunningham\n",
      "Zoubin Ghahramani\n",
      "Yoshua Bengio\n",
      "Klaus-Robert Müller\n",
      "Csaba Szepesvári\n",
      "Hongyuan Zha\n",
      "David M. Blei\n",
      "Francis R. Bach\n",
      "Yann LeCun\n",
      "Le Song\n",
      "Dale Schuurmans\n",
      "Joshua B. Tenenbaum\n",
      "Samy Bengio\n",
      "Eric Horvitz\n",
      "Jure Leskovec\n",
      "Nando de Freitas\n",
      "Max Welling\n",
      "Trevor Darrell\n",
      "Yee Whye Teh\n",
      "Shie Mannor\n",
      "Ivor W. Tsang\n",
      "Lawrence Carin\n",
      "Andreas Krause\n",
      "Xiaojin Zhu\n",
      "Arthur Gretton\n",
      "Yoram Singer\n",
      "Rémi Munos\n",
      "Alan Fern\n",
      "Robert C. Williamson\n",
      "Neil D. Lawrence\n",
      "Ryan P. Adams\n",
      "Shipeng Yu\n",
      "Richard S. Sutton\n",
      "Lise Getoor\n",
      "Daniel J. Hsu\n",
      "Peilin Zhao\n",
      "Steven C. H. Hoi\n",
      "Hugo Larochelle\n",
      "Cheng Soon Ong\n",
      "Pieter Abbeel\n",
      "Deepayan Chakrabarti\n",
      "Naonori Ueda\n",
      "Mehryar Mohri\n",
      "Vikas Sindhwani\n",
      "Kenji Fukumizu\n",
      "Xi Chen\n",
      "Geoff Holmes\n",
      "Ambuj Tewari\n",
      "Barnabás Póczos\n",
      "Mohammad Ghavamzadeh\n",
      "Shai Shalev-Shwartz\n",
      "Tianbao Yang\n",
      "Brendan J. Frey\n",
      "Doina Precup\n",
      "Lei Shi\n",
      "Raquel Urtasun\n",
      "Arindam Banerjee\n",
      "Kevin Leyton-Brown\n",
      "S. Sathiya Keerthi\n",
      "Martin J. Wainwright\n",
      "David B. Dunson\n",
      "Ohad Shamir\n",
      "Wei Xu\n",
      "Massimiliano Pontil\n",
      "Frank D. Wood\n",
      "Michael W. Mahoney\n",
      "H. Brendan McMahan\n",
      "Joris M. Mooij\n",
      "Guy Lebanon\n",
      "Elad Hazan\n",
      "Alan L. Yuille\n",
      "Vladimir Vapnik\n",
      "Yuchen Zhang\n",
      "Jason D. Lee\n",
      "Zhihua Zhang\n",
      "Joseph Keshet\n",
      "Bin Li\n",
      "Éric Gaussier\n",
      "Joelle Pineau\n",
      "Nan Du\n",
      "Manfred K. Warmuth\n",
      "Erik B. Sudderth\n",
      "Arnaud Doucet\n",
      "Sergey Levine\n",
      "Yaoliang Yu\n",
      "Maria-Florina Balcan\n",
      "Karol Gregor\n",
      "Xinhua Zhang\n",
      "Jan Peters\n",
      "David Page\n",
      "Finale Doshi-Velez\n",
      "Liwei Wang\n",
      "Jonathan Chang\n",
      "Samuel Kaski\n",
      "Alexander Rakhlin\n",
      "Andrew Gordon Wilson\n",
      "Carla E. Brodley\n",
      "Aarti Singh\n",
      "Ming Yuan\n",
      "Jonas Peters\n",
      "Issei Sato\n",
      "Alessandro Lazaric\n",
      "Guy Lever\n",
      "Bharath K. Sriperumbudur\n",
      "Iain Murray\n",
      "Sayan Mukherjee\n",
      "Ameet Talwalkar\n",
      "Frank Hutter\n",
      "Sophia Ananiadou\n",
      "Shai Ben-David\n",
      "Sebastian Riedel\n",
      "Soumya Ray\n",
      "Tamir Hazan\n",
      "Huan Xu\n",
      "Chih-Jen Lin\n",
      "Aapo Hyvärinen\n",
      "Byron C. Wallace\n",
      "Laurens van der Maaten\n",
      "Ulrike von Luxburg\n",
      "Jinbo Bi\n",
      "Holger H. Hoos\n",
      "Richard E. Turner\n",
      "Matthew D. Hoffman\n",
      "Guillaume Bouchard\n",
      "Dominik Janzing\n",
      "Manuel Gomez-Rodriguez\n",
      "Martha White\n",
      "Sinead Williamson\n",
      "Rajesh Ranganath\n",
      "Jennifer G. Dy\n",
      "Maya R. Gupta\n",
      "Massih-Reza Amini\n",
      "Alexandre Bouchard-Côté\n",
      "Zhirong Yang\n",
      "Bernhard Pfahringer\n",
      "Benjamin I. P. Rubinstein\n",
      "Jia Li\n",
      "Ole Winther\n",
      "Alexandre d'Aspremont\n",
      "Shivani Agarwal\n",
      "Samuel Gershman\n",
      "Abdeslam Boularias\n",
      "Katsuhiko Ishiguro\n",
      "Lorenzo Rosasco\n",
      "Samory Kpotufe\n",
      "Alexander Binder\n",
      "Yi Li\n",
      "Xiaotong Shen\n",
      "Mingyuan Zhou\n",
      "José Miguel Hernández-Lobato\n",
      "Peter Richtárik\n",
      "Stephen J. Roberts\n",
      "Cynthia Rudin\n",
      "James Bailey\n",
      "Sivan Sabato\n",
      "Yutian Chen\n",
      "Joseph K. Bradley\n",
      "Michael Mitzenmacher\n",
      "Daniil Ryabko\n",
      "Stéphane Canu\n",
      "Mauro Maggioni\n",
      "Stephen H. Bach\n",
      "Grégoire Montavon\n",
      "Katsumi Inoue\n",
      "Petros Drineas\n",
      "Zoltán Szabó\n",
      "Reza Bosagh Zadeh\n",
      "Erkki Oja\n",
      "Rémi Bardenet\n",
      "Stanislav Funiak\n",
      "Akiko Takeda\n",
      "Vladimir G. Spokoiny\n",
      "Elizabeth S. Burnside\n",
      "S. Sundararajan\n",
      "Deniz Erdogmus\n",
      "Ricardo Henao\n",
      "Marina Meila\n",
      "Gerhard Neumann\n",
      "Takafumi Kanamori\n",
      "Sofus A. Macskassy\n",
      "Nakul Verma\n",
      "Dan Shen\n",
      "András György\n",
      "Qiang Wu\n",
      "Michalis K. Titsias\n",
      "Vittorio Murino\n",
      "Yonina C. Eldar\n",
      "Geoffrey I. Webb\n",
      "Benjamin Van Roy\n",
      "Florence d'Alché-Buc\n",
      "Konrad Rieck\n",
      "Mathieu Salzmann\n",
      "Alain Rakotomamonjy\n",
      "Samuel Gerber\n",
      "Blaine Nelson\n",
      "Shohei Shimizu\n",
      "David Barber\n",
      "Stephen P. Boyd\n",
      "Malik Magdon-Ismail\n",
      "David Mease\n",
      "Irene M. Ong\n",
      "Kate Saenko\n",
      "Janez Demsar\n",
      "Justin Bedo\n",
      "Ding-Xuan Zhou\n",
      "John V. Guttag\n",
      "Dinh Q. Phung\n",
      "Alexandre Gramfort\n",
      "Carme Torras\n",
      "Marie Szafranski\n",
      "Jacob Bien\n",
      "M. Pawan Kumar\n",
      "Aurélien Garivier\n",
      "Stephen E. Fienberg\n",
      "Vikash K. Mansinghka\n",
      "Junhui Wang\n",
      "Garvesh Raskutti\n",
      "Lars Kai Hansen\n",
      "Aki Vehtari\n",
      "Steve Hanneke\n",
      "Jason K. Johnson\n",
      "Daniel J. Lizotte\n",
      "Wei Pan\n",
      "Gavin C. Cawley\n",
      "Olivier Cappé\n",
      "Gérard Biau\n",
      "Lei Yang\n",
      "Stéphan Clémençon\n",
      "Margareta Ackerman\n",
      "Dan Yang\n",
      "Yaakov Engel\n",
      "Mikko Koivisto\n",
      "Wojciech Kotlowski\n",
      "Giorgio Corani\n",
      "Chris Thornton\n",
      "David Madigan\n",
      "Rahul Mazumder\n",
      "Kevin Robert Canini\n",
      "Zhiyong Liu\n",
      "Todd K. Leen\n",
      "Jie Chen\n",
      "Arnak S. Dalalyan\n",
      "Jacques Wainer\n",
      "Johannes Fürnkranz\n",
      "Hariharan Narayanan\n",
      "Milan Vojnovic\n",
      "Matthias Broecheler\n",
      "Yaacov Ritov\n",
      "Fen Xia\n",
      "Yufeng Liu\n",
      "Peter Reutemann\n",
      "François Fleuret\n",
      "Andreas Buja\n",
      "Dotan Di Castro\n",
      "Marco Zaffalon\n",
      "Le Lu\n",
      "Artur Dubrawski\n",
      "François Caron\n",
      "Barbara E. Engelhardt\n",
      "Carey E. Priebe\n",
      "Christian Igel\n",
      "Patrick Shafto\n",
      "Giles Hooker\n",
      "Abraham J. Wyner\n",
      "Yajun Wang\n",
      "Yichao Wu\n",
      "Kevin Bleakley\n",
      "Minghu Song\n",
      "Alberto Suárez\n",
      "Eric Moulines\n",
      "Jin Tian\n",
      "Austin J. Brockmeier\n",
      "Brendan Juba\n",
      "Jenna Wiens\n",
      "Duy Nguyen-Tuong\n",
      "Michael Chertkov\n",
      "Bharath Hariharan\n",
      "Matthijs T. J. Spaan\n",
      "Nguyen Xuan Vinh\n",
      "Nahum Shimkin\n",
      "Srikanth Jagabathula\n",
      "Ingo Steinwart\n",
      "Marco Loog\n",
      "Laurenz Wiskott\n",
      "Andreas Maurer\n",
      "Sylvain Arlot\n",
      "Markus Püschel\n",
      "Mark J. Schervish\n",
      "Tapio Pahikkala\n",
      "Xavier Bresson\n",
      "Ana M. Martínez\n",
      "Jaakko Luttinen\n",
      "Mykel J. Kochenderfer\n",
      "Tobias Glasmachers\n",
      "George Michailidis\n",
      "Cosma Rohilla Shalizi\n",
      "Leonidas Lefakis\n",
      "Tianxi Cai\n",
      "Shahar Mendelson\n",
      "Jianqing Fan\n",
      "Guillaume Lecué\n",
      "Yann Ollivier\n",
      "Herbert Jaeger\n",
      "Sean Luke\n",
      "Elena Marchiori\n",
      "Hans W. Guesgen\n",
      "Sara A. van de Geer\n",
      "Huizhen Yu\n",
      "Olivier Colliot\n",
      "Marc G. Genton\n"
     ]
    }
   ],
   "source": [
    "id_to_author_map = {idx: aid for aid,idx in aid_map.items()}\n",
    "ranked_by_coauthors = np.argsort(-A.sum(axis=1))\n",
    "for idx in ranked_by_coauthors:\n",
    "    aid = id_to_author_map[idx]\n",
    "    if aid in recent_ml_auth_ids:\n",
    "        print(author_name_map[aid])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sophia Ananiadou\n",
      "Guy Lever\n",
      "Sergey Levine\n",
      "Jian Zhang\n",
      "Minmin Chen\n",
      "Andrew Gordon Wilson\n",
      "Liwei Wang\n",
      "John P. Cunningham\n",
      "Frank Hutter\n",
      "Jason D. Lee\n",
      "Emily B. Fox\n",
      "Byron C. Wallace\n",
      "Jonas Peters\n",
      "Richard E. Turner\n",
      "Nan Du\n",
      "Ameet Talwalkar\n",
      "Dean P. Foster\n",
      "Yuchen Zhang\n",
      "Albert Bifet\n",
      "Shai Ben-David\n"
     ]
    }
   ],
   "source": [
    "id_to_author_map = {idx: aid for aid,idx in aid_map.items()}\n",
    "ranked_inf = np.argsort(-fitted_influence)\n",
    "influential = []\n",
    "for idx in ranked_inf:\n",
    "    aid = id_to_author_map[idx]\n",
    "    if aid in recent_ml_auth_ids and A[idx,:].sum() >= 10:\n",
    "        print(author_name_map[aid])\n",
    "        influential.append(idx)\n",
    "        if len(influential)==20:\n",
    "            break\n",
    "#         print(author_name_map[aid], fitted_influence[idx], A[idx,:].sum(), Y[idx,:].sum(), Y_past[idx,:].sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.manifold import TSNE\n",
    "tsne_model = TSNE()\n",
    "tsne_embed = tsne_model.fit_transform(fitted_z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_authors = tsne_embed.shape[0]\n",
    "author_names = [author_name_map[id_to_author_map[idx]] for idx in range(num_authors)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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GdSqztkni4gIoEqLyDXxVlQwHz4U6qq+BAY4GNExOE+wERGRvFRpEblGzqy+iIjI+anSIiIiIm5BoUVERETcgkKLiIiIuAWFFhEREXELCi0iIiLiFhRaRERExC0otIiIiIhbUGgRERERt6DQIiIiIm5BoUVERETcgkKLiIiIuAWFFhEREXELCi0iIiLiFhRaRERExC0otIiIiIhbUGgRERERt6DQIiIiIm5BoUVERETcgkKLiIiIuAWFFhEREXELCi0iIiLiFhRaRERExC0otIiIiIhbUGgRERERt6DQIiIiIm5BoUVERETcgkKLiIiIuAWFFhEREXELCi0iIiLiFhRaRERExC0otIiIiIhbUGgRERERt6DQIiIiIm5BoUVERETcgkKLiIiIuAWFFhEREXELBRZajDGexpg4Y8y3Oe+rG2N+NcZsM8bMMMb4FNS9RERE5MZTkJWWAcCm096/C3xora0FHAOeKMB7iYiIyA2mQEKLMaYS0Bb4Iue9AVoAM3MOmQxEFcS9RERE5MZUUJWWj4AXgeyc96WBRGttZs77vUBgAd1LREREbkCXHVqMMe2Ag9ba2NM353OoPcf5vY0xMcaYmEOHDl1uc0RERKSQKohKS1OgvTFmFzAdZ7fQR0CAMcYr55hKwL78TrbWjrfWhltrw8uWLVsAzREREZHC6LJDi7V2iLW2krW2GhANLLbWPgwsATrlHNYdmHe59xIREZEb15Vcp+Ul4HljzHacY1wmXMF7iYiISCHndeFDLp61dimwNOf1H0Cjgry+iIiI3Li0Iq6IiIi4BYUWERERcQsKLSIiIuIWFFpERETELSi0iIiIiFtQaBERERG3oNAiIiIibkGhRURERNyCQouIiIi4BYUWERERcQsKLSIiIuIWFFpERETELSi0iIiIiFtQaBERERG3oNAiIiIibkGhRURERNyCQouIiIi4BYUWERERcQsKLSIiIuIWFFpERETELSi0iIiIiFtQaBERERG3oNAiIiIibkGhRURERNyCQouIiIi4BYUWERERcQsKLSIick5z1u7Fv1owN3UeTtORi5kbl8BXX31F69at//a1KlWqRGJiIllZWTRr1uwKtNbp1KlT1K5dm40bN7q2vfPOO/Tr1++K3VOuDq9r3QAREbk+zY1L4OU5v1Hs7qc5NHcke6uG8NL0NSRPe4mflyy65Ot6enry888/F2BL8ypSpAgffvghffv2ZenSpfz5559MnDiR2NjYK3ZPuTpUaRERkTzmxiXQdORiBs6IJyUjC5+y1ShycyOO/zKTv5b+H151mlOzZk3uv/9+GjZsyK233soXX3zhOv/LL78kODiYevXq8fLLL591/czMTAICAgBISkqiRYsWNGjQgJCQEL799lsAtm/fTr169XjiiSe49dZbue+++0hNTQXgl19+ISQkhNtvv51BgwYRGhp61j3atm1LqVKlmDp1KgMHDuTNN9+kRIkSLFiwgE6dOrmO69WrF9OnTy/Q70+uHIUWERFxmRuXwJDZG0hITAHg+MoZ7PuiL6f+iOH4L19zautKTP0HaDpyMetqPIxf51G89vk8PvjgA44dO8bevXsZOnQoS5YsIS4ujhUrVriCSH4cDgfz5s1j7dq1LFq0iOeee861b8uWLQwcOJDff/8dh8PB3LlzAejZsyfbtm1j5cqVWGvPee3Ro0czaNAgkpOT6dq161n7x40bx7Zt2y71q5JrQN1DIiLC3LgERv24xRVWANISNnFqx2oq9BiN8fLm6OIJGC9vjJc3CYkpJK2Zy5rtv9L9Q4PHyUPs2LGD3bt306JFC8qUKUNmZibdunVj2bJltGvXLt/7Wmt56aWXWL58OR4eHuzZs4fDhw8DcPPNNxMcHAxAw4YN2bVrF4cPHyY9PR1PT08AunXrxqJF+XdVVa5cmebNm+eprJzu6aefJiYm5pK/M7n6VGkREbnBnVldyZV14hieDn+MlzcAHj5+ePgWAyBp7Xckrf0GjMEUCcCzZCCpqam89tprxMbGcueddzJ69GgOHTrEl19+SUREBElJSQQGBrquP2rUKGrXrs2///1vHnjgAeLj4/Hx8eGTTz4BwNfXl1deeYUxY8bg6elJZmbmeSsrhw4d4sEHHyQiIoKIiAhWrFiBMYann36axMREALy8vFiwYAEHDhxg2LBhrF27FoDmzZvz0ksv0ahRI2rXru0ac5OVlcWgQYOIiIggJCSEzz77rIC+dbkUCi0iIjewuXEJvPDVOlIyss7a51c9jMzkwySM782RhZ+SefwgADYrk+SYefgGBlGx58f4VQvjRMJWAPz9/dm5cyezZ89mwIABfPjhhzzyyCOsWbPGVR0B57iWbdu20a9fP3r06EFcXBzvv/8+ycnJfP31167jpk+fzsMPP+x6X7ZsWby9vcnKynLtzzVgwACee+451qxZw6xZs+jVqxfGGBo1asScOXMASExMJDs7m1KlSpGSksKOHTvytGn16tV89NFHDB8+HIAJEyZQokQJ1qxZw5o1a/j888/ZuXPnZX/vcmnUPSQicoPKrbBknaN64eHjoEL3j0jb+zupuzdw/LfZFMlMJ+PoXjJPHCXr5DF2v98R4+GFp29RwFkd6d+/P82bN8day6lTp3jnnXcA56ye9PR0wBkQFi5cyIoVK9i1axdZWVkkJydTq1YtSpYsye+//05ycjJhYWGULl06T7smTpxIZGQkt99+O3fccQclSpQAYNGiRXmmOSclJZGRkUFkZCQzZsygZ8+erFixgttuu83V7XR65adjx47A/7qiABYuXMj69euZOXMmAMePH2fbtm1Ur179sr57uTQKLSIiN6hRP27Jt8JyOuPhiV+VEPyqhOBdtionf/sJAJ+yVanw6PsAOLw9GdExmMgwZwDo0KEDb7/9NkCewLFp0yYqVqyIl5cXzzzzDLVr1+app546654zZsxg8eLFhIeH0717dwAGDx7s2h8SEkKRIkVYuXIlb7/9NuHh4QBkZ2ezatUqHA5HnutZa/niiy84dOgQc+fOJSYmhtKlSzNs2DCKFStGdHQ048aNw9fXF8DVFZV77scff0yrVq0u8luVK0ndQyIiN6h9Z4xhOVPGkb1kHE1wvU8/uBOvEuXwLhVI9qkk0hI2ERjg4M3761LLJzHfazRp0oRZs2YBebtyWrVqxcSJEzlx4gQACQkJHDzo7H7q0KEDCxYsYM2aNfmGhfnz55OSkkK9evVYtWoVQ4YMAaBly5b885//dB0XHx8PgDGGDh068Pzzz3PLLbecVbk5n1atWjF27FgyMjIA2Lp1KydPnrzo86VgKbSIiNygKgY4zrs/OyOVI999yL4v+rBvYj9M4l4CmnajUml//jF2ErV2z+fEtOd4vWdbVq5cme81PvroIz744AMaNWrE/v37XV05LVu2pFu3bq6umk6dOpGcnAyAj48Pd911F126dMkzDiZXt27dsNaSmJhIfHw8oaGhfPDBB4wZM4aYmBhCQkIICgpi3LhxrnMeeughvvzySx566KG/9R316tWLoKAgGjRoQL169XjqqadcVRi5+sz5RmJfbeHh4VbTz0REro7cMS0X6iLKtWtk2799j1OnTuFwODDGMH36dKZNm8a8efPOe052djYNGjTg66+/platWn/7nu7GGBNrrQ2/1u1wB4V2TEvumgP7ElOoGOBgUKs6RIUFXvhEEZEbRO7vxNzflSUc3hxPzSC/f8sGXqAqcy6xsbH069cPay0BAQFMnDjxvMdv3LiRdu3a0aFDhxsisMjfUygrLfn96yF3oJiCi4jIuen359WnSsvFK5RjWvIbEZ+SkcWoH7dcoxaJiLiHqLBARnQMJjDAgcFZYVFgkevFZXcPGWMqA1OA8kA2MN5aO9oYUwqYAVQDdgFdrLXHLvd+F+NcI+IvNFJeREScwUUhRa5HBVFpyQResNbeAjQBnjHGBAGDgZ+stbWAn3LeXxXnGhF/oZHyIiIicv267NBird1vrV2b8zoZ2AQEAg8Ak3MOmwxEXe69LtagVnVweOedJufw9mRQqzpXqwkiIiJSwAp09pAxphoQBvwK3GSt3Q/OYGOMKVeQ9zqfM0fEa/aQiIiI+yuw0GKMKQbMAgZaa5OMMRd7Xm+gN0CVKlUKqjnqkxURESlkCmT2kDHGG2dgmWqtnZ2z+YAxpkLO/grAwfzOtdaOt9aGW2vDy5YtWxDNERERkULoskOLcZZUJgCbrLUfnLZrPtA953V34PxLIIqIiIicR0F0DzUFHgU2GGPic7a9DIwEvjLGPAH8CXQugHuJiIjIDeqyQ4u1djlwrgEsd1/u9UVERESgkK6IKyIiIoWPQouIiIi4BYUWERERcQsKLSIiIuIWFFpERETELSi0iIiIiFtQaBERERG3oNAiIiIibkGhRURERNyCQouIiIi4BYUWERERcQsKLSIicsM5cOAA3bp1o0aNGjRs2JDbbruNOXPmFMi1q1WrxuHDhwvkWpKXQouIiNxQrLVERUVxxx138McffxAbG8v06dPZu3dvnuPmzJmDMYbNmzdf8TYZY0KNMW3y2d7KGBOf898JY8yWnNdTjDH5PvTYGHOzMSb+MtvjZYxJzHl9jzFm7uVcr6AotIiIyA1l8eLF+Pj48PTTT7u2Va1alf79+wMwadIk+vXrx7Rp04iMjKR9+/YsXbqUCRMm8Nxzz7nO+fzzz3n++ecv6p4nT57k8ccfJyIigrCwMObNmwdA48aNAfyAUKCNMWapMaahMaaoMWYi8BZggdeBGGAasA0oCSy8zK/iijtXsLpUCi0iInJD+f3332nQoMF5j0lPT2fFihVMmDCBffv2ARAdHc2MGTO444476NKlC88++yzHjx9n6tSpNGrUiODgYHbs2AHA4cOHefDBB4mIiCAiIoI+ffrQokULli5dyq233spDDz1E/fr1qVevHkAp4A2gK9AEuBl4BVhsrY0A7gJG8b+/s28DugNPGmN+NsbEGWNijTGNz/wcxpiFxpignNcbjDEv57weYYzpYYzxN8YsNsasNcasN8a0O9/3YoxpnHNsNWNME2PMqpz7rzDG1Mo5ppcxZrox5lvghwv9PP6OAk1AIiIi7uaZZ55h+fJrjfRUAAAgAElEQVTl+Pj4sGbNGgB27txJ69atqV27Nt7e3mzdupUVK1aQlJTE8uXLqVGjBlWrVmXBggVUqlSJ1atXM3r0aD7++GMAXnnlFZ577jkiIyP5888/qVOnDmvXruWFF17gxIkTFCtWjPHjx9O1a1dwVk36AE8DJay1M4wxg4D2xpj/l9NMv5z/AP5jrT1qjEkF7gXuA2YD44H6Z3y8ZUAzY8x+IBWIzNkeCXwBpAAPWGuTjTHlgBXAt2dcozYQbIxpBnwItLfW7jXGHAMirbVZxpjWOKtCD+WcEwXcZ61dcgk/knNSaBERkRvC3LgERv24hR3xyaSsXsydjyUQFRbIJ598wuHDhwkPD+ftt99m7NixHDx4kMqVK/Prr79Srlw5BgwYwK233so777zDm2++SZs2bShfvjwLFiygZcuWAAQHB7NkifPv6J9++olly5YRGBgIQFZWFpMnT6Zbt24cPHiQjIwMmjdvjrUWIBuoBFQFWuY01wAPWmu35LbfGLM05+XJnD99gX8C7XK23WKMOQ7sBWoaY5YB3wN3APuBeUBbY0wRINBau8MY4wO8a4yJzGlHZWNMGSAR8DHGPAZsxdlF9SnOkORnjPkNaAtMMcbUzOfrPgokX8KP6bzUPSQiIoXe3LgEhszeQEJiCr5V65OamsrTr4xgblwCAHNW/8HeI0m88en/kdaoOxkZmSSeOEWHDh3Ytm0baWlp/LZzH8+/+jaHjxzh07FjiYiIwMPDg3Xr1hEWFsYTTzxBbGws1lo8PT1JTk4mJCQEHx8fypQpw0cffYS1lptuuokHH3yQsLAw/Pxyiye0wVlJmZbz/hdgiTFmnTHmT2NM95ztxYHWOa9fAP4CTgCNAW/gZ+ABnMGlCPAq0AUYibPqsg6YCZTIqZQcB6JxhhKAdOA/wBHAWmun4KzelMzZ1wWYBdTEOcYmzlpbD3gPqGuMWQ/0xhm6ADDGdM3pmtppjNl+2vYTp73uZIyZdKGfo0KLiIgUeqN+3EJKRhYAf456AJueysHFk+gYUY1qtYN4tk8vitS9E0+HP1knE/EKKM+JbB9q1AsnqEFjLIa0YwfISnZOZfYqXZU9thTHjx9nwIABpKWlcfDgQU6ePElycjLJycmkpaUxe/ZsIiMj6dWrF8uWLWPHjh0cPHiQJUuW8PPPPxMaGgrgwBk6/gICjTFrgGbAbzirKRWAiUAI0AM4YYzpC5QAygELgNtxBg//0z52LeA1IAmojrNL6J6c/w4BPwL7cIalV4BbcIaiAOAZnBWV3O4pm3PcSJwDgXcA2/lfZagfzpATgrO6cxOAMaYi8C7QAugFBBhjoi7tp6juIRERuQHsS0xxvTZePlTs9anzNVDC4Q0pGWSnp/DX1BdJXPwFflXr49+oIzakESUAs74teHgR0DSaY0snkXZ4NyM+n0ExoHr16pQtW5YdO3aQlpZGy5Yteeqpp4iKisLHx4dx48bh5+dHVlYWQUFB/Pbbbxw8eBAvLy88PDxym1EGZzdMCaAszrEmtwOZgGfOMaeAZ4EZOX/2xTmDKANnpSYLCMQZgAJxhpV+QFGc3TVHcIaH3TnbonLuk4mzm8kbOICzStOX/1VLauMcLHwUWAV0yNl+BKhgjEnKuXdmzvaDQBowGWcg22GtPWSMyQIScHZXXdIUalVaRESk0KsY4Djn9sSUDE5sWMSR7z/Cs1hpvEpVwrtMVQ7MeJVfR0Sz5v3HwcsHz6IBHFv6L7DZ4OnNjnnOQbc7d+7kwIEDeHt7U6xYMX7//Xc+/dQZilq2bMmpU6eYOXMmJ0+exNPTkzJlyjBt2jSstXTu3BkAa+1RnFUVi3M8Scmc92/yvzEsh4HHcl5XB8bkHH8QZzjwzNl+L84QsS1nv1fO/ptxVmwycXb1HMHZFfQ1zkByCPgJmJJz3kmcXUxNgTRrbW2coWo1zioLOENICZyBKndtmEo4q0bdcXZPNTTGFM3n67envfbLZ/9ZFFpERKTQG9SqDg5vTwBsZjr7/tWfvyY9S9bCf7iOSUvYTJl2L1Cx5xgC7niU0vc9i0/ZatzU9R1s6glKtX6WMm2fd4aWjFSKV76Fv/76i8zMTIwxWGtJSkri2LFjVKpUCQ8PD4oXLw7Avn378Pb2Jisri2PHjtGzZ08cDgezZ88+vZnpOX9OwzlVeBvOUJABYK0NBQbirGLsA37FGU7Kn3b+MSAcZ7UkDaiGs3qyBrgfmIAzoPTBGWaigI4414nZBzTHORMpV1WgMuCbs2BdbcAHZ6DKADKtczTxApzVHYD2OfedCgzBGXxCcGaOisB/c447YIy5xRjjwf+qN+el0CIiIjcEP2/nX3nGy4egvuOY/sMyBr8/wbXfp0JtslOSnG+sJTl2PmkJmzkwYyjYbI79ZyyJP38JHp4Ybz9qlCtOkSJF8Pf3x8/Pj/T0dIwxvPDCCzz66KMAZGRk0LhxY0aPHk3JkiUB8Pb2Jjo6mpSUFAYOHHh6E+NxBoEU4G6cVZM3OfdQjrtxTk/+GGd1xhdnQKiWc04xnKFmDc6/7x04u6A+xzkYNwBYjrNisxSoB+yy1h457R4G54DbEzi7mlrhHCsTSF4/AJ45A3ErAHHAwzmDdB/DOR17AnDcWjsv55zBOe1fjHN20wVpTIuIiBRquTOHcgfiAqRlZgPOAbq5jKcnR777kOy0k2Snp4C1VHj8E7yKl2L3u/dTIrIbvjfV4K9pL1PS4UXThsFkZQUxfvx4srKyqFixIkeOHOGHH37gtttuc133119/Zfny5fTp0wdPT08yMjJYvHgx9evXP/MZRT/irJo8iTN8ZOGcITSRnGrLGebgrKhUxBk6uuOsthzEGRyO4qye7MUZPI7h7ApKAD4DHgU+tdbONMaE4ww3K3OunYGz4pOAc+Duo8AnONd6mYpzbEzxnD8BHsQ5k6idMeYdnAOCY3P2bbLWBhtjmgO5A3ux1s7EGZ4umiotIiJSqJ0+cyhXSkYWo37ckmeArmeREpR/9D0q9hqLf6MOFKl9G17FS5G6ez1gSVo5nQMzhpJ14ijNbmvEsGHDqFmzJk8++SQBAQEcOXKEcuXKUaVKFT7++GO8vb0pUaIEt99+O08//TQTJkwgICCA8ePH4+PjQ7FixejYsSP8b2xHDZzVlSycM4eycQ6mXYizivF+znF7cP79/SnOoNIG5yyek9baEji7ZFbinJ7sWivFWjvPWlvDWtvMWjsIZ5dO7r4YoBNw+lLB4621w3HOWBqKs+riwLm43a04pzZ/Z4xZjnNwb643cQ7qXZ+znsubF/WDugiqtIiISKF2ejA5c3vFAAcJ+ewvGtScg7PeYP/kgfiUq4FXqUqU7fAyAAdnDs8zFqV8+fKMGzeO5s2b89577xEeHs7rr79OsWLF+PDDD3NnCLmEhISwdetWAHbt2sU///nPtJxdfXBWL0JxjkNZC2Ct7WaM2YNzrEh5a+0txph/46y0/GCtHWSMGQD0MsZswNmV80ju/ay1/fL7/NbaHme8n4VzDRastc1P274YiMjn/AVA3Xy2pwBP5bN9Kc6K0CUzOavxXRfCw8NtTEzMtW6GiIgUIk1HLs43mAQGOBjUqg4DZ/y9ByIHBjhYMbjFhQ+8SMaYWGtteIFdsBBT95CIiBRqp88cyuXw9mRQqzpEhQXiYc5x4nmuJ9eGuodERKRQiwpzTnTJHcNSMafCkrs9+292OOSeJ1efQouIiBR6UWGB5wwbgecY13KuY+XaUffQVTY3LoGmIxdTffB3NB252PWwLhERuTby6z7y9jB4e+btN8rtUpJrR5WWq+jMtQISElMYMnsDoHKjiMi1cq7uo/y26Xf1taXZQ1fR+UawF+RIdBERcR+aPXTx1D10FZ1vrQARERE5P4WWq+h8TxkVERGR81NouYrOt1aAiIiInJ8G4l5FF1orQERERM5NoeUqO99aASIiInJu6h4SERERt6DQIiIiIm5BoUVERETcgkKLiIiIuIUrHlqMMa2NMVuMMduNMYOv9P1ERESkcLqiocUY4wl8AtwHBAFdjTFBV/KeIiIiUjhd6UpLI2C7tfYPa206MB144ArfU0RERAqhKx1aAoE9p73fm7PNxRjT2xgTY4yJOXTo0BVujoiIiLirKx1aTD7b8jxW2lo73lobbq0NL1u27BVujoiIiLirKx1a9gKVT3tfCdh3he8pIiJXgTGGF154wfX+vffeY9iwYQVy7WrVqhEcHExwcDBBQUEMHTqUtLS0Arm2uK8rHVrWALWMMdWNMT5ANDD/Ct9TRESuAl9fX2bPns3hw4evyPWXLFnChg0bWL16NX/88Qe9e/e+IvcR93FFQ4u1NhPoB/wIbAK+stb+fiXveSOZG5dA05GLqT74O5qOXMzcuIRr3SQRuYF4eXnRu3dvPvzww7P2ffPNNzRu3JiwsDDuueceDhw4AMCwYcN4/PHHad68OTVq1GDMmDEXvE+xYsUYN24cc+fO5ejRoyxdupR27dq59vfr149JkyYV2OeS69cVX6fFWvu9tba2tbamtfbtK32/G8XcuASGzN5AQmIKFkhITGHI7A0KLiJyVT3zzDNMnTqV48eP59keGRnJL7/8QlxcHNHR0fzjH/9w7du8eTM//vgjq1evZvjw4WRkZFzwPv7+/lSvXp1t27YV+GcQ96GnPLuJuXEJjPpxC/sSU6gY4OBUeiYpGVl5jknJyGLgjHhG/biFQa3q6GnSInLF+fv789hjjzFmzBgcDodr+969e3nooYfYv38/6enpVK9e3bWvbdu2+Pr64uvrS7ly5Thw4ACVKlW64L2stRc8Rgo3hRY3kFtVyQ0pCYkp5z0+ITGFQTPXASi4iMglO/MfS4Na1QFwbUvJyGJuXAIDBw6kQYMG9OzZ03Vu//79ef7552nfvj1Lly7NM0DX19fX9drT05PMzMwLtiU5OZldu3ZRu3Ztfv/9d7Kzs137UlNTC+DTijvQs4fcwKgft5xVVbmQjCzL8G80fEhELk1+XdCDZq5j0NfrXNushSGzN7BsdwpdunRhwoQJrvOPHz9OYKDzH02TJ0++rLacOHGCvn37EhUVRcmSJalatSobN24kLS2N48eP89NPP13W9cV9KLS4gX0XqKycy7FTF+4nFhHJT37/WMrIsmRk5+2iScnIYtSPW3jhhRfyzCIaNmwYnTt3plmzZpQpU+aS2nDXXXdRr149GjVqRJUqVfjss88AqFy5Ml26dCEkJISHH36YsLCwS7q+uB9zPfURhoeH25iYmGvdjOtO05GLL9gldC67RrYt4NaISGGW2yX0d37nGGCnftdcMmNMrLU2/Fq3wx2o0uIGBrWqg8Pb85LO1WwiEblYp3cJ/R0VAxwXPkikACi0uIGosEBGdAwmMMCBATxNfk9HyN/AGfEMnbvhyjVORAqNSxk/5/D2dA3QFbnSNHvITUSFBbpmAp05m+hCvvzlT8KrltJMIhE5r0sZPzeiY7B+t8hVo0qLGzqz8lLE+8I/xlE/brnyDRMRt3Yp3TwKLHI1KbS4qaiwQFYMbsHOkW0pWdT3gsdf6gwkEblx5Dd+zuHtybk6pP9OV7VIQVBoKQQuNpDoGUUicj5nVnEDAxyM6BjMueaYZl1Hs0/lxqAxLYVAxQDHBUf75/5qyX1GEaisKyJnO338XK5zTYEO1KwhucpUaSkE7qpb9m8dn7sYlIjIxThXt5FmDcnVpkpLIbBk86G/fY7GuIjIxcqtvJz5HCJVa+VqU2gpBC4lgGgxKBH5O/LrNhK52tQ9VAhcSgBRWVdERNyNQkshMKhVnXNOSRQRESksFFoKgaiwQB5uUuVvBRcNxBUREXej0FJIvBUVzIcPhbrWVwhweJ93pVwNxBUREXejgbiFSH4D5UKHLyQxJeOsYzUQV0RE3I0qLYXcsPa3an0FEREpFBRaCrlzLcutqYsihYe1Fk9PT3744QfXtq+++orWrVv/ressWrSIqKioizp26dKllChRgrCwMOrUqcMdd9zBt99+m++xY8aMITQ0lNDQUIKCgvDz88MYw7Zt2/jiiy8YOHDg32qn3LjUPXQD0PoKIoWbMQZfX1+ef/557rrrLrKysnjllVdYsGDBFb1vs2bNXEElPj6eqKgoHA4Hd999d57jnn32WZ599lkAdu3aRXh4ONHR0dSqVYv//ve/V7SNUrio0iIiUgh4eHjQqlUrgoKCqFGjBklJSfznP/8hNDSUkydP0rZtWypUqMBNN93EjBkz2Lp1K2FhYTgcDhwOB507dyY9PZ3k5GSKFClCmTJlKFWqFMHBwWzevJk1a9Zw55130rBhQ+677z6OHj0KQGRkJIMHD6Z3796kpqYyfPjw87Zz1apVJCcn8/HHH7u27d27l2bNmlG0aFHKly9Ps2bN2Lx5M7179yY0NBR/f38CAwOJiIhgxYoVVKpUiWHDhhEWFkZISAhbt24F4ODBg9x99900aNCAvn37EhgYSGJi4pX70uWqU2gRESkkhg8fjqenJ+XKlWPt2rWMGDECgAULFlCxYkUGDBhA//79ad26NdHR0ezZs4d169Zx7NgxvL29+eabb1i7di2lSpXi1VdfpWbNmrRu3Zp3332XAQMGMGvWLGJjY3nkkUeYOHGi677WWlavXs3gwYNZu3btOdt37NgxXnzxRQIDAylevLhr+7p16/Dw8OCXX37B29ubl156ib59+zJy5EiCgoKYP38+NWrUYMSIEfTq1QuAm266ibi4OHr16sUHH3wAwGuvvUbr1q1Zu3Ytbdq0Yd++fVfia5ZrSN1DIiJuam5cgut5QCkZWfxnyzECAgLYvnM3tSPu5NTB/RxKNfzlWY5FixaxdetWatWqRXZ2Nn/99RdBQUHUrl0bgCeeeILXX3+dJk2asGnTJjp16sRvv/1GiRIlWLZsGZs3b+aee+4BICsriyJFilC2rPNhrR07dgTglltuISPj7NmKuXr37k3nzp1ZuHBhnu133nknU6dO5dFHHyUxMZHnnnsOLy8vpk2bxtdff82cOXPIyMigV69eruvn3rNhw4Z8//33ACxfvpxXXnkFgHbt2uUJRlI4qNIiIuKG5sYl8MLX60hITMEC1kLfN0az68AxvOu3o+xjo/Fw+JORmcU/Y0/yxr++oXTp0vznP//hH//4xzmv6+vr6/rT09OT7OxsMjMzCQkJIT4+nvj4eDZs2MC777571jkbN27E29s73+tOmDCB/fv388wzz5y1z8fHh4CAAOLj42natCn/+te/mD9/PqNHj6Z48eIcPXqU6Oho3nrrLRISElxjeAA8PT3JzMwEnBUfKdwUWkRE3NArczaQlZ33L+nM1JMkZXiQkW1I3b2e7BNHyD6VyPF9O/nn4j/Ys2cPkZGRbNq0iQoVKrBp0ya2b99Oamoq//rXvwgJCcn3XkWLFiUhIYHVq1cDkJ6ezs6dO/Mcs379ej744ANKlChx1vnbt2/n9ddf58svv8TT0/Os/T4+PlSvXp2vv/4acIaPmJgYihcvTqtWrXjnnXf48ccfAeeA33OJjIzkq6++AuD7778nOTn5nMeKe1L3kIiIGzqZnuV6bbOzMJ7eFA1qzvFfZ5McO4/M6g3xKlWJInVu5+CMofyVfoqAYg727dvHvHnzKF68OF26dCE4OBiA+++/n3bt2jF+/Piz7uXh4cHMmTN59tlnSU5OJjMzk7Zt2/Lzzz+TlZXFAw88QJUqVXj77bd54403AJg/fz4xMTG88cYbjBgxglOnThEVFUV6ejqbNm3Cx8eHEiVKkJmZye23387UqVPp06cPK1as4NFHH6Vnz54EBQWxevVq/vvf/5Kens5LL73E/ffff87vZPjw4XTr1o2pU6fSokULbrrpJooWLVrA37xcS+Z6KqeFh4fbmJiYa90MEZHrXrXB37lepx/8gyMLPqbCYx+e8/jAAAcrBre4Gk27ZlJTU/Hy8sLLy4vly5czcOBA3OHvFGNMrLU2/Fq3wx2o0iIi4oYMYIHkuO9Jjv2Gknc/ec5jb5RVsHft2kXXrl3JysrC19eXzz777Fo3SQqYxrSIiLihh5tUAaB4WBsq9hqLo3qDfI/zNKbQrIJdrFixs7aNGzeOKVOmAFC3bl3i4uJYv349a9asoWHDhhd13fnz5zNy5Mg826y1lClThmPHjgGwf/9+jDEsX77cdUzZsmU5cuTIpX4cuQSqtIiIuKG3opxjUab9uocsazGAh4fJMzjX4e1ZaALLuTz99NOXfY327dvTvn37PNuMMTRu3JhVq1bRpk0bVq5cSVhYGCtXriQyMpItW7ZQpkwZSpcufdn3l4unSouIiJt6KyqYHSPasGtkW3aObMv7nevfcM8ZGzZsGMYYOnfu7KqsxMbGYoxxPU6gfPnyvPHGGxw6dIgHH3yQiIgI1+q6AJMmTaJfv35nXbtp06asXLkSgJUrVxIaGsqYMWNc78PDw6lZsyaff/45jRs3JiwsjHvuuYcDBw642vb444/TvHlzatSo4ToX4M0336Ru3brce++9ANWNMf/vSn1HhYkqLSIihURhes7YnDlz6NixI5s2baJu3brMjUsgJSOL6oO/o2KAg0Gt6rg+q4+Pj2vqdlJSEl988QXe3t4cPXqU3bt3U716dRYsWMDmzZt57rnniIyM5M8//6RVq1Y88sgjfPrpp6SlpbF8+XI+++wzGjduTK9evYiMjHR1Pa1evZrvv/+eChUqsGjRIlauXMlff/3F448/TqdOnejVqxfGGL744gv69+/PqVOnCA8PZ/PmzSxZsoTk5GTq1KlDnz59WLduHbNmzSIuLo7MzEz8/f01xekiKbSIiMh1Z9q0aURGRjJ9+nRCH3iSIbM3YK1z8HFCYgpDZm/Ic/x9993H6tWrWb58Od9//z3WWo4ePcrPP/9MyZIlqVGjBl999RULFizA09OTU6dOudanGTZsGPHx8aSkpPDYY4+5Vg329vYmLi6OkydPkpGRQfHixbn99tvp27cvmZmZeHl5MWjQILZs2UKNGjUoXbo0np6eFClShK1btxIeHk6TJk245557OHHiBCdPnmTBggXs2LGD4OBg2rVrl7uujRcQDbx39b9p96LQIiIi15UTJ06wYsUKlixZQotWbfBNa0SWtVhrOTD9ZbJTT2KzMhmy+wkequEcNDtt2jROnjxJz549OXLkCNnZ2ezdu5fhw4fTtm1bPvnkE0qUKEHbtm1JTU1lxowZfPzxx7z88st4e3uzY8cOPDw82LRpEwcPHqRy5crceeed3HzzzZQqVYp69epRv359EhMTqVSpEqtWrWLKlCnccccdbNy4EV9fXxISEvjhhx945plnyM7O5quvvuLQoUPcfffdTJs2jdq1a/Pqq6/SvXt3ANauXcvGjRuZM2fOYeAmY0wTa+0v1/bbv75pTIuIiFxX5s6dS+vWrdl4sihHM304tX+ba1/ZDkOp0GM0N3V9h+3fjHUt3b979278/f3JyMigbt26+Pr6Urp0adLS0qhVqxYALVu2ZNOmTURFReHh4UFERASpqakMHjyYmJgYQkJC8PDwoHz58gQEBADOcS3p6enceeedrFu3jmbNmvHbb79RtGhRpk+fzoABA6hZsyZ+fn4ATJ48GYC0tDRat27NM888w6JFi6hZsyZ79+5l+/btREZGsmrVKho1apT7fKQAIAGodpW+Yrel0CIiIteVadOmER0dzagft+BXpxmnNi1z7shMY+8nj7J71APs/eQxMpMO8uEP68nMspStUInHHnuM48eP8+CDDwJQqlQpAgICXKvijhkzhiNHjvDyyy8TFBTElClTcDgc9OjRA09PT8aOHcukSZPytKVp06YA9OnTB4DWrVuTnJxMkSJFWLVqFZ07d2bYsGEcOnSItLQ0ypQpg7UWPz8//P39Wb58OZUrV2b48OFUr16d9PR0IiIiuP3221mx4v+3d+fhVVX3/sff3wxCQCAoaDGAIKFawpCEiBCKTBasA3BBCtZLA1rxKt7SQaxIHZ9LxaIg0uqDtYLTz2ABwWpF1KAIiExJmKdKFKICUhJCSCEk6/fH2TkGPBkY5GSHz+t5zsPZa09rrxxyPll7rXOWlX3xYyFwBN39qJJCi4iIhN38zFy6T8qg5djXWLjofW75xSg+fexmDq6cR+Hmj3HOceF1vyamTRda/nYul45bQETd8ylYNR8iIsgrjuCSLj9lypQpPPLIIwDEx8ezbt264DmaNGlCz549efLJJ3nmmWfYvXs3AJMmTeLPf/4z8fHxzJkzhz179pCXlwfA0KFDqV+/frC3pm7dugwePDj4DdcAAwcOZMiQIURHRzN58mR69uyJmXHPPfewZ88eNm/ezIQJEygsLKSkpCR43GuuuYb58+cD1AX2VaedzOzhMzHTyMzeMLNB5Za3mtkfyi3PNbPBZpZiZk97ZSPN7M+ne+7TodAiIiJhNT8zl/Hz1pObV0Th1mXUS+hD/bQZNL/zBZrfNYuo2Is5snsjpUcKiazXiF3Thge+EPJwPuf9IB5XWoJzjplZBYwdOxYIfPtzVV9Tc+jQoeA2Q4YMwTnH8uXLueOOO2jQoEHww+xKSkpo1KgRSUlJjB07lk2bNgHQtWtX5s6dC0Dbtm0pLi4mNTWVr7/+mmPHjvHLX/6S1NRU6tevT3R0NEOGDCEqKtCZMnXqVBYvXkxycjLAAeCbE+tnZt/9dskzZzmQ6p3nQuAQ0K3c+m7Acufcaufcr77HepyU0wotZjbZzLaY2TovtcWWWzfezHZ46a3/6VdVRERqo8nvbqWoONADUbjpI+r9sBvl40a9H6ZSuOkj6rfrxZGvt+OOHeHQhvfBIojtNYrIBoFejy/zivjwww/p1asXcXFxvP/++7Rq1Yq0tDTq1KnDwoULWbFiBU899RTz5s2jpKSETp060bRpU5o2bcquXbvo3bs3zz33HAcPHtE2TKcAABiHSURBVGTatGl07NiRkpISevToQbdu3Rg2bBi7d++madOm1K1blylTptC6dWsyMjJo1qwZy5cvp2fPnjRo0ICVK1fy7LPPcvPNN/PAAw8wZcoUjhw5AsAHH3zA6NGjy0LMBcCHzrlXzKyXmS02s/8HrAcwswnee+n7QPD7GMws0cxWlHsPbuyVf2hmj5vZSjPbZmY9QjT7MrzQ4v37FtDUAloDRc65r736vHXizmY21Mw2mFm2mS3xyuqa2UwzW29mmWbW2ysfaWbzzGyhmW03sz+d0guF0+9peQ9o75zrCGwDxnsVbEdg+lYCcC3wzPecGEVExKe+zCsKPv/BzycRc9nxH7/fMGUAF/YfQ2S9RjQb8SQWVYc6lyYSfWELDrw/g9LCA9Rr14tLYmPIyspi6dKlxMfH07p1aw4dOsTSpUv55ptvGDZsGNHR0eTl5fHWW2/RsGHD4IfEHT58mMOHD5ORkUFiYiIDBgxg27ZtrFq1itatW3P48GGuvvpqIiMjue6669i1axeff/45PXr0oKCggM2bN9OkSRMA0tPTKSoqYv/+/UybNo1p06axceNGrrzySjp27MiMGTOYN28eGRkZZfscAV42s8uAx4Crgc7AI2bWmcD7aRIwGLiyXNO8BPzeew9eDzxUbl2Uc64L8OsTysusAdqb2XkEQssnwFbgR97ysip+bA8C/Z1znYCyjxMeA+Cc6wDcDLxoZnW9dYnAMKADMMzMWlRx/JBOK7Q45xY55455iyuA5t7zgUC6c+6Ic24nsAPocjrnEhGR2umS2JiT3ufQqgUQGUWzUdNp2HUoBSv+zm3Jwc5+ZsyYwaZNm4iKimLRokVs2bKFdu3asX79ejZs2MCll17K3r17AVi6dCn33HMPhYWF7Ny5k9TUVDZs2EBiYiJXXXUV+fn5FBYW0qNHDzIyMvj4449JSEggLy+Pl156iYKCAuLj4ykpKWHnzp1MmjSJdu3a0adPH37zm9/wt7/9jczMTIqLi9m3bx9//etfefvtt+nbty+rVq0C2AWkA7cD+4ElzrnLgYVAD+AN59xh59xB4E0AM2sExDrnPvIu+UUCYafMPO/fNYSYleScOwJsBJKBrsCnBIJLqvdYXsWPYBkwy8xuB8o6JX4MvOwdfwvwOfBDb90Hzrl859x/gE3ApVUcP6QzOablVuAd73kcgR9Cmd1emYiIyHHG9b+cmOiT6Yx3HN23k2P5e8idcTuHshcSHQEXFgXedho3bkzz5s2JiIigSZMmwY/Vz8/P56qrrqJDhw6sW7eOgoICAC6++GIWLFjAK6+8QlRUFM45pk+fTlZWFllZWaSnp7NlyxZuuOEGNm7cSLdu3Rg4cCD16tUDAuNnioqKKCwsZPv2wPTs888/n+zsbEpLS1m0aBFffPEFAHv37mX//v3BL2Ls0qULwFHvwj4n0MPSwsx6OOfygxd88o54/5ZQ8ayk5QSCTgPn3AECnQ9loaXSnhbn3P8AfwBaAFneuBirRn2qqlOlqgwtZva+d9/qxMfActtMAI4Br5YVhThUyEY3s9FmttrMVu/bV63B0yIiUosMSorjscEdiPN6XE58Azlx2ZWWEH1hCy7ofSut757JnI+yaNSwQXCAbETEt29tERERlJaW0qpVK7Zu3coTTzzB+vXradasGaWlpQD8/Oc/JzU1lTVr1tC5c2euueYann32WYqLiwHYtWsXqampZGZmMnz4cFauXMnVV1/NhRdeiHOOO+64g6ysLHbu3Em/fv0AqF+/PikpKfzhD3+gtLSU6dOns2LFCurWrcvOnTsZMWIEixcvLgs+UQTCw3xgNFAAPGZmDwJLgP8ysxgzawDcCOAFmgPlxquMAMp6XaprGXAHkO0tryPQ69KSQC9MhcysjXPuU+fcgwQGEbfw6nqLt/6H3nG2nmSdKlVlaHHOXeOcax/iscCrWBpwA3CL+3ao9m7vAso0B76s4PjPOedSnHMp5aeQiYjIuWNQUhzL7utDzqTrmTos8bgvfoy/6ISv5iktJaZtVwo3f0y9KKN78/MoLi5my5YtlZ6jYcOG3HbbbXTr1i3Y+1JaWsrBgweJj4/nT3/6E3l5eQwbNox27dqRnJxM+/btefLJJ4OzjHr06MGxY8eIj4/nZz/7GQcOHKBbt8Ckm23btlFYWEiDBg0oKCjg+eefZ//+/SxZsoRhw4bRp08fHn/8cbZt20a/fv247LLLWLJkCQRuodxL4D35CIEPmnsCSHbOrQVmA1nAXODjcpeUBkw2s3UExow8epLNvhy4jMBtIbzhHnuB1c650ir2newNuN1AIKxkA88AkWa23qvzSO821JnjvI9GPpUHgUG2m4CmJ5QneBdQB2gNfAZEVnW8zp07OxERkTJvrN3tWv3+LXep92g5boGLqNvAtbz3H65hl8EuuklL1759e5eenu6cc27x4sXu+uuvD+4/ZswYN3PmTOeccxMmTHBt2rRxffv2dSNHjnQPPfSQO3r0qOvevbtr3769S0hIcI899th36nDiMcuUlJS48ePHB/ft1auXy8vLc0ePHnV9+vRxHTt2dFOmTKlwu7LjeiEBoD+B3o4sYBWQ4k7jPbo2PsxVMY+9Mma2wwsm+72iFS5wn6vsltGtBG4b/do5907oo3wrJSXFrV69+pTrIyIitUv3SRnklptddHTvZ+xfOJ1mv5gKBHpilt3XJ1zVOyPMbI1zLiXc9fCD0/rIYOdcfCXrJgITT+f4IiJybis/Hbog858UrPkHjfveDgTGuozrf3kFe0ptpO85EBGRGuuS2JhgT0uDpOtokHRdcN0tXVsyKEkTU88l+hh/ERGpsUJNhzbgv7u25P8GdQhPpSRs1NMiIiI1VllPyuR3t/JlXhGXxMYwrv/l6mE5Rym0iIhIjTYoKU4hRQDdHhIRERGfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfUGgRERERX1BoEREREV9QaBERERFfOCOhxczuMTNnZk28ZTOzp81sh5mtM7PkM3EeEREROXeddmgxsxbAT4AvyhX/FGjrPUYDz57ueUREROTcdiZ6WqYC9wKuXNlA4CUXsAKINbNmZ+BcIiIico46rdBiZgOAXOdc9gmr4oBd5ZZ3e2UiIiIipySqqg3M7H3gByFWTQDuB/qF2i1EmQtRhpmNJnALiZYtW1ZVHRERETlHVRlanHPXhCo3sw5AayDbzACaA2vNrAuBnpUW5TZvDnxZwfGfA54DSElJCRlsRERERE759pBzbr1z7iLnXCvnXCsCQSXZOfc18CbwC28WUVcg3zn31ZmpsoiIiJyLquxpOUX/BK4DdgCHgVHf03lERETkHHHGQovX21L23AFjztSxRURERPSJuCIiIuILCi0iIiLiCwotIiIi4gsKLSIiIuILCi0iIiLiCwotIiIi4gsKLSIiIuILCi0iIiLiCwotIiIi4gsKLSIiIuILCi0iIiLiCwotIiIi4gsKLSIiIuILCi0iIiLiCwotIrXY+eeff9zyrFmzuPvuuyvdJycnh5iYGBITE+nUqROpqals3br1e6lfTk4O7du3PyPHGjlyJPXq1aOgoCBYNnbsWMyMb775psL9Hn74YcyMHTt2BMumTp2KmbF69epKz9mqVatKjy0iZ5ZCi9Rq8zNz6T4pg9b3vU33SRnMz8wNd5V8oU2bNmRlZZGdnU1aWhp//OMfv7PNsWPHwlCzysXHx7NgwQIASktLWbx4MXFxcVXu16FDB9LT04PLc+bMoV27dt9bPUXk1Ci0SK01PzOX8fPWk5tXhANy84oYP2+9gstJOnjwII0bNwYCPTVDhw7lxhtvpF+/fgBMnjyZK6+8ko4dO/LQQw8BgR6UH/3oR9x+++0kJCTQr18/ioqKAFizZg2dOnWiW7du/OUvfwmeJycnhx49epCcnExycjLLly8H4MMPP6RXr17cdNNNXHHFFdxyyy0450LW9eabb2b27NnB/bp3705UVFRw/UsvvUTHjh3p1KkTI0aMCJYPGjQoGHY+++wzGjVqRNOmTYPr77zzTlJSUkhISAheY5np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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.scatter(tsne_embed[influential[:100], 0], tsne_embed[influential[:100],1])\n",
    "for i in influential[:20]:\n",
    "    plt.annotate(author_name_map[id_to_author_map[i]], (tsne_embed[i, 0], tsne_embed[i, 1]))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_random_subset(items, array, z, w):\n",
    "    users = np.arange(array.shape[0])\n",
    "    expected = z.dot(w.T)[users,items]\n",
    "    truth = array[users,items]\n",
    "    return roc_auc_score(truth, expected)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_influence_model(items, y, y_p, a, z, w, inf):\n",
    "    users = np.arange(y.shape[0])\n",
    "    inf_rate = (inf*a).dot(y_p)\n",
    "    expected = (z.dot(w.T) + inf_rate)[users,items]\n",
    "    truth = y[users,items]\n",
    "    return roc_auc_score(truth, expected)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC predicting ties: 0.9939010132501948\n",
      "AUC predicting past items: 0.9959769218774366\n",
      "AUC predicting current items: 0.9113593829751034\n"
     ]
    }
   ],
   "source": [
    "print(\"AUC predicting ties:\", evaluate_random_subset(a_heldout, A, fitted_z, fitted_z))\n",
    "print(\"AUC predicting past items:\", evaluate_random_subset(yp_heldout, Y_past, fitted_z, fitted_gamma))\n",
    "print(\"AUC predicting current items:\", evaluate_influence_model(y_heldout, Y, Y_past, A, fitted_z, fitted_gamma, fitted_influence))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
