{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# [Double-Hard Debias: Tailoring Word Embeddings for Gender Bias Mitigation](https://arxiv.org/abs/2005.00965)\n",
    "\n",
    "For more detailed explanations, please refer to the paper."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import codecs, os, json, operator, pickle\n",
    "from random import shuffle\n",
    "import numpy as np\n",
    "from numpy import linalg as LA\n",
    "import scipy\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_glove(path):\n",
    "    with open(path) as f:\n",
    "        lines = f.readlines()\n",
    "    \n",
    "    wv = []\n",
    "    vocab = []\n",
    "    for line in lines:\n",
    "        tokens = line.strip().split(\" \")\n",
    "        try:\n",
    "            assert len(tokens) == 301\n",
    "            vocab.append(tokens[0])\n",
    "            wv.append([float(elem) for elem in tokens[1:]])\n",
    "        except:\n",
    "            print(line)\n",
    "        \n",
    "    w2i = {w: i for i, w in enumerate(vocab)}\n",
    "    wv = np.array(wv).astype(float)\n",
    "    print(len(vocab), wv.shape, len(w2i))\n",
    "    \n",
    "    return wv, w2i, vocab\n",
    "\n",
    "def normalize(wv):\n",
    "    \n",
    "    # normalize vectors\n",
    "    norms = np.apply_along_axis(LA.norm, 1, wv)\n",
    "    wv = wv / norms[:, np.newaxis]\n",
    "    return wv\n",
    "\n",
    "def debias_gn(wv):\n",
    "    for v in wv:\n",
    "        assert(len(v) == 300)\n",
    "    \n",
    "    wv = wv[:,:-1]\n",
    "\n",
    "    for v in wv:\n",
    "        assert(len(v) == 299)\n",
    "    return wv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "322636 (322636, 300) 322636\n"
     ]
    }
   ],
   "source": [
    "# Baseline GloVe embeddings\n",
    "glove, glove_w2i, vocab = load_glove(\"./data/vectors.txt\")\n",
    "\n",
    "# Below embeddings from from Zhao paper (GN-GloVe and GN-GloVe(W_a))\n",
    "#gn_glove, gn_glove_w2i, gn_vocab = load_glove(\"./data/vectors300.txt\")\n",
    "#gn_glove_a = debias_gn(gn_glove)\n",
    "\n",
    "# Hard GloVe and Strong Hard GloVe\n",
    "# hd_glove, hd_glove_w2i, hd_vocab = load_glove(\n",
    "#     \"./data/vectors_hd.txt\")\n",
    "# hd_glove_a, hd_glove_a_w2i, hd_vocab_a = load_glove(\n",
    "#     \"./data/vectors_hd_a.txt\")\n",
    "\n",
    "# GP-GloVe and GP-GN-GloVe\n",
    "# gp_glove, gp_glove_w2i, gp_vocab = load_glove(\n",
    "#     \"./data/gp_glove.txt\")\n",
    "# gp_gn_glove, gp_gn_glove_w2i, gp_gn_vocab = load_glove(\n",
    "#     \"./data/gp_gn_glove.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(322636, 300)\n"
     ]
    }
   ],
   "source": [
    "def load_glove_p(path):\n",
    "    # Modified from original because we did not pickle a map but rather wv_f directly\n",
    "    wv = pickle.load(open(path, 'rb'))\n",
    "    print(wv.shape)\n",
    "        \n",
    "    return wv\n",
    "    \n",
    "dhd_glove = load_glove_p(\"./data/dhd_glove_reproduce.p\")\n",
    "dhd_glove_w2i = glove_w2i\n",
    "dhd_vocab = vocab"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "314863 (314863, 300) 314863\n"
     ]
    }
   ],
   "source": [
    "null_glove, null_glove_w2i, null_vocab = load_glove(\"./data/INLP_embeddings/vecs.150k.cleaned.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def simi(a, b):\n",
    "    return 1-scipy.spatial.distance.cosine(a, b)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Word Embedding Utility: Analogy & Concept Categorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/sklearn/utils/deprecation.py:143: FutureWarning: The sklearn.datasets.base module is  deprecated in version 0.22 and will be removed in version 0.24. The corresponding classes / functions should instead be imported from sklearn.datasets. Anything that cannot be imported from sklearn.datasets is now part of the private API.\n",
      "  warnings.warn(message, FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "from eval import evaluate_cate, evaluate_ana, evaluate_analogy_google, evaluate_analogy_msr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating categorization benchmarks\n",
      "Sample data from AP, num of samples: 402 : \"['acne']\" is assigned class illness\n",
      "exist 401 in 402\n",
      "Cluster purity on AP 0.5885286783042394\n",
      "Sample data from ESSLI_2c, num of samples: 45 : \"['acquire']\" is assigned class exchange-exchange\n",
      "exist 45 in 45\n",
      "Cluster purity on ESSLI_2c 0.6\n",
      "Sample data from ESSLI_2b, num of samples: 40 : \"['chicken']\" is assigned class HI\n",
      "exist 40 in 40\n",
      "Cluster purity on ESSLI_2b 0.775\n",
      "Sample data from ESSLI_1a, num of samples: 44 : \"['bottle']\" is assigned class tool-artifact\n",
      "exist 44 in 44\n",
      "Cluster purity on ESSLI_1a 0.7272727272727273\n",
      "Sample data from Battig, num of samples: 5231 : \"doll\" is assigned class toy\n",
      "exist 4125 in 5231\n",
      "Cluster purity on Battig 0.4955151515151515\n",
      "Sample data from BLESS, num of samples: 200 : \"['carp']\" is assigned class water_animal\n",
      "exist 200 in 200\n",
      "Cluster purity on BLESS 0.81\n"
     ]
    }
   ],
   "source": [
    "evaluate_cate(glove, glove_w2i, vocab)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6750\n",
      "ACCURACY TOP1-MSR: 54.24% (3661/6750)\n",
      "capital-common-countries.txt:\n",
      "ACCURACY TOP1: 96.44% (488/506)\n",
      "capital-world.txt:\n",
      "ACCURACY TOP1: 96.35% (4359/4524)\n",
      "currency.txt:\n",
      "ACCURACY TOP1: 6.58% (57/866)\n",
      "city-in-state.txt:\n",
      "ACCURACY TOP1: 72.64% (1792/2467)\n",
      "family.txt:\n",
      "ACCURACY TOP1: 87.35% (442/506)\n",
      "gram1-adjective-to-adverb.txt:\n",
      "ACCURACY TOP1: 20.97% (208/992)\n",
      "gram2-opposite.txt:\n",
      "ACCURACY TOP1: 28.94% (235/812)\n",
      "gram3-comparative.txt:\n",
      "ACCURACY TOP1: 85.29% (1136/1332)\n",
      "gram4-superlative.txt:\n",
      "ACCURACY TOP1: 49.02% (550/1122)\n",
      "gram5-present-participle.txt:\n",
      "ACCURACY TOP1: 63.16% (667/1056)\n",
      "gram6-nationality-adjective.txt:\n",
      "ACCURACY TOP1: 91.99% (1471/1599)\n",
      "gram7-past-tense.txt:\n",
      "ACCURACY TOP1: 56.35% (879/1560)\n",
      "gram8-plural.txt:\n",
      "ACCURACY TOP1: 78.68% (1048/1332)\n",
      "gram9-plural-verbs.txt:\n",
      "ACCURACY TOP1: 58.16% (506/870)\n",
      "Questions seen/total: 100.00% (19544/19544)\n",
      "Semantic accuracy: 80.48%  (7138/8869)\n",
      "Syntactic accuracy: 62.76%  (6700/10675)\n",
      "Total accuracy: 70.80%  (13838/19544)\n",
      "\n",
      "Dataset created in /Users/david/web_data/analogy\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:143: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_left = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 0]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:144: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_right = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 1]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:147: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  question_left, question_right = np.vstack(w.get(word, mean_vector) for word in questions[:, 0]), \\\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:148: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  np.vstack(w.get(word, mean_vector) for word in questions[:, 1])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Analogy prediction accuracy on SemEval2012 0.1756625482532434\n"
     ]
    }
   ],
   "source": [
    "evaluate_ana(glove, glove_w2i, vocab)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating categorization benchmarks\n",
      "Sample data from AP, num of samples: 402 : \"['acne']\" is assigned class illness\n",
      "exist 401 in 402\n",
      "Cluster purity on AP 0.5960099750623441\n",
      "Sample data from ESSLI_2c, num of samples: 45 : \"['acquire']\" is assigned class exchange-exchange\n",
      "exist 45 in 45\n",
      "Cluster purity on ESSLI_2c 0.5777777777777778\n",
      "Sample data from ESSLI_2b, num of samples: 40 : \"['chicken']\" is assigned class HI\n",
      "exist 40 in 40\n",
      "Cluster purity on ESSLI_2b 0.8250000000000001\n",
      "Sample data from ESSLI_1a, num of samples: 44 : \"['bottle']\" is assigned class tool-artifact\n",
      "exist 44 in 44\n",
      "Cluster purity on ESSLI_1a 0.7272727272727273\n",
      "Sample data from Battig, num of samples: 5231 : \"doll\" is assigned class toy\n",
      "exist 4125 in 5231\n",
      "Cluster purity on Battig 0.4661818181818182\n",
      "Sample data from BLESS, num of samples: 200 : \"['carp']\" is assigned class water_animal\n",
      "exist 200 in 200\n",
      "Cluster purity on BLESS 0.795\n"
     ]
    }
   ],
   "source": [
    "evaluate_cate(dhd_glove, dhd_glove_w2i, dhd_vocab)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6750\n",
      "ACCURACY TOP1-MSR: 53.81% (3632/6750)\n",
      "capital-common-countries.txt:\n",
      "ACCURACY TOP1: 96.44% (488/506)\n",
      "capital-world.txt:\n",
      "ACCURACY TOP1: 96.68% (4374/4524)\n",
      "currency.txt:\n",
      "ACCURACY TOP1: 6.00% (52/866)\n",
      "city-in-state.txt:\n",
      "ACCURACY TOP1: 74.67% (1842/2467)\n",
      "family.txt:\n",
      "ACCURACY TOP1: 83.60% (423/506)\n",
      "gram1-adjective-to-adverb.txt:\n",
      "ACCURACY TOP1: 21.07% (209/992)\n",
      "gram2-opposite.txt:\n",
      "ACCURACY TOP1: 28.33% (230/812)\n",
      "gram3-comparative.txt:\n",
      "ACCURACY TOP1: 84.46% (1125/1332)\n",
      "gram4-superlative.txt:\n",
      "ACCURACY TOP1: 47.42% (532/1122)\n",
      "gram5-present-participle.txt:\n",
      "ACCURACY TOP1: 62.88% (664/1056)\n",
      "gram6-nationality-adjective.txt:\n",
      "ACCURACY TOP1: 91.99% (1471/1599)\n",
      "gram7-past-tense.txt:\n",
      "ACCURACY TOP1: 54.62% (852/1560)\n",
      "gram8-plural.txt:\n",
      "ACCURACY TOP1: 76.43% (1018/1332)\n",
      "gram9-plural-verbs.txt:\n",
      "ACCURACY TOP1: 55.06% (479/870)\n",
      "Questions seen/total: 100.00% (19544/19544)\n",
      "Semantic accuracy: 80.94%  (7179/8869)\n",
      "Syntactic accuracy: 61.64%  (6580/10675)\n",
      "Total accuracy: 70.40%  (13759/19544)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:143: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_left = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 0]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:144: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_right = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 1]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:147: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  question_left, question_right = np.vstack(w.get(word, mean_vector) for word in questions[:, 0]), \\\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:148: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  np.vstack(w.get(word, mean_vector) for word in questions[:, 1])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Analogy prediction accuracy on SemEval2012 0.17303299182822926\n"
     ]
    }
   ],
   "source": [
    "evaluate_ana(dhd_glove, dhd_glove_w2i, dhd_vocab)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating categorization benchmarks\n",
      "Sample data from AP, num of samples: 402 : \"['acne']\" is assigned class illness\n",
      "exist 401 in 402\n",
      "Cluster purity on AP 0.600997506234414\n",
      "Sample data from ESSLI_2c, num of samples: 45 : \"['acquire']\" is assigned class exchange-exchange\n",
      "exist 45 in 45\n",
      "Cluster purity on ESSLI_2c 0.5777777777777778\n",
      "Sample data from ESSLI_2b, num of samples: 40 : \"['chicken']\" is assigned class HI\n",
      "exist 40 in 40\n",
      "Cluster purity on ESSLI_2b 0.7250000000000001\n",
      "Sample data from ESSLI_1a, num of samples: 44 : \"['bottle']\" is assigned class tool-artifact\n",
      "exist 44 in 44\n",
      "Cluster purity on ESSLI_1a 0.75\n",
      "Sample data from Battig, num of samples: 5231 : \"doll\" is assigned class toy\n",
      "exist 4124 in 5231\n",
      "Cluster purity on Battig 0.4917555771096023\n",
      "Sample data from BLESS, num of samples: 200 : \"['carp']\" is assigned class water_animal\n",
      "exist 200 in 200\n",
      "Cluster purity on BLESS 0.81\n"
     ]
    }
   ],
   "source": [
    "evaluate_cate(null_glove, null_glove_w2i, null_vocab)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6750\n",
      "ACCURACY TOP1-MSR: 52.09% (3516/6750)\n",
      "capital-common-countries.txt:\n",
      "ACCURACY TOP1: 95.26% (482/506)\n",
      "capital-world.txt:\n",
      "ACCURACY TOP1: 96.33% (4358/4524)\n",
      "currency.txt:\n",
      "ACCURACY TOP1: 4.73% (41/866)\n",
      "city-in-state.txt:\n",
      "ACCURACY TOP1: 75.23% (1856/2467)\n",
      "family.txt:\n",
      "ACCURACY TOP1: 81.23% (411/506)\n",
      "gram1-adjective-to-adverb.txt:\n",
      "ACCURACY TOP1: 20.36% (202/992)\n",
      "gram2-opposite.txt:\n",
      "ACCURACY TOP1: 27.09% (220/812)\n",
      "gram3-comparative.txt:\n",
      "ACCURACY TOP1: 85.51% (1139/1332)\n",
      "gram4-superlative.txt:\n",
      "ACCURACY TOP1: 42.34% (475/1122)\n",
      "gram5-present-participle.txt:\n",
      "ACCURACY TOP1: 59.94% (633/1056)\n",
      "gram6-nationality-adjective.txt:\n",
      "ACCURACY TOP1: 91.12% (1457/1599)\n",
      "gram7-past-tense.txt:\n",
      "ACCURACY TOP1: 53.85% (840/1560)\n",
      "gram8-plural.txt:\n",
      "ACCURACY TOP1: 74.02% (986/1332)\n",
      "gram9-plural-verbs.txt:\n",
      "ACCURACY TOP1: 58.85% (512/870)\n",
      "Questions seen/total: 100.00% (19544/19544)\n",
      "Semantic accuracy: 80.60%  (7148/8869)\n",
      "Syntactic accuracy: 60.55%  (6464/10675)\n",
      "Total accuracy: 69.65%  (13612/19544)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:143: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_left = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 0]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:144: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  prot_right = np.mean(np.vstack(w.get(word, mean_vector) for word in prototypes[:, 1]), axis=0)\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:147: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  question_left, question_right = np.vstack(w.get(word, mean_vector) for word in questions[:, 0]), \\\n",
      "/Users/david/opt/anaconda3/envs/double_hard/lib/python3.7/site-packages/web-0.0.1-py3.7.egg/web/evaluate.py:148: FutureWarning: arrays to stack must be passed as a \"sequence\" type such as list or tuple. Support for non-sequence iterables such as generators is deprecated as of NumPy 1.16 and will raise an error in the future.\n",
      "  np.vstack(w.get(word, mean_vector) for word in questions[:, 1])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Analogy prediction accuracy on SemEval2012 0.17765165972024588\n"
     ]
    }
   ],
   "source": [
    "evaluate_ana(null_glove, null_glove_w2i, null_vocab)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Gender Bias Evaluation:\n",
    "### Restrict vocabulary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|███▉      | 19787/50000 [00:00<00:00, 176813.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "442\n",
      "1883\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50000/50000 [00:00<00:00, 142497.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "size of vocabulary: 47628\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "from utils import limit_vocab\n",
    "\n",
    "gender_specific = []\n",
    "\n",
    "with open('./data/male_word_file.txt') as f:\n",
    "    for l in f:\n",
    "        gender_specific.append(l.strip())\n",
    "with open('./data/female_word_file.txt') as f:\n",
    "    for l in f:\n",
    "        gender_specific.append(l.strip())\n",
    "print(len(gender_specific))\n",
    "\n",
    "with codecs.open('./data/gender_specific_full.json') as f:\n",
    "    gender_specific.extend(json.load(f))\n",
    "\n",
    "\n",
    "exclude_words = gender_specific\n",
    "print(len(exclude_words))\n",
    "\n",
    "glove_vocab_limit, glove_limit, glove_w2i_limit = limit_vocab(glove, glove_w2i, vocab, exclude = exclude_words)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50000/50000 [00:00<00:00, 228047.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "size of vocabulary: 47628\n"
     ]
    }
   ],
   "source": [
    "dhd_vocab_limit, dhd_limit, dhd_w2i_limit = limit_vocab(\n",
    "    dhd_glove, dhd_glove_w2i, dhd_vocab, exclude = exclude_words)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50000/50000 [00:00<00:00, 254371.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "size of vocabulary: 49646\n"
     ]
    }
   ],
   "source": [
    "null_vocab_limit, null_limit, null_w2i_limit = limit_vocab(\n",
    "    null_glove, null_glove_w2i, null_vocab, exclude = exclude_words)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Select originally top biased words"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "he_embed = glove[glove_w2i['he'], :]\n",
    "she_embed = glove[glove_w2i['she'], :]\n",
    "\n",
    "def simi(a, b):\n",
    "    return 1-scipy.spatial.distance.cosine(a, b)\n",
    "\n",
    "def compute_bias_by_projection(wv, w2i, vocab):\n",
    "    d = {}\n",
    "    for w in vocab:\n",
    "        u = wv[w2i[w], :]\n",
    "        d[w] = simi(u, he_embed) - simi(u, she_embed)\n",
    "    return d\n",
    "\n",
    "gender_bias_bef = compute_bias_by_projection(glove_limit, glove_w2i_limit, glove_vocab_limit)\n",
    "sorted_g = sorted(gender_bias_bef.items(), key=operator.itemgetter(1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### TSNE visualization of originally top biased words"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def visualize(vectors, y_true, y_pred, ax, title, random_state):\n",
    "    \n",
    "    # perform TSNE\n",
    "    vectors = normalize(vectors)\n",
    "    X_embedded = TSNE(n_components=2, random_state=random_state).fit_transform(vectors)\n",
    "    for x,p,y in zip(X_embedded, y_pred, y_true):\n",
    "        if y:\n",
    "            ax.scatter(x[0], x[1], marker = '.', c = 'c')\n",
    "        else:\n",
    "            ax.scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "    \n",
    "    return ax\n",
    "\n",
    "def cluster_and_visualize(words, X1, title, random_state, tsne_random_state, y_true, num=2):\n",
    "    \n",
    "    kmeans_1 = KMeans(n_clusters=num, random_state=random_state).fit(X1)\n",
    "    y_pred_1 = kmeans_1.predict(X1)\n",
    "    correct = [1 if item1 == item2 else 0 for (item1,item2) in zip(y_true, y_pred_1) ]\n",
    "    print('precision', max(sum(correct)/float(len(correct)), 1 - sum(correct)/float(len(correct))))\n",
    "    \n",
    "    fig, axs = plt.subplots(1, 1, figsize=(6, 3))\n",
    "    ax1 = visualize(X1, y_true, y_pred_1, axs, title, tsne_random_state)\n",
    "    \n",
    "#     fig.savefig(\"a_{}_{}_{}.pdf\".format(title, size, random_state))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.cluster import KMeans\n",
    "from sklearn.manifold import TSNE\n",
    "from utils import extract_vectors\n",
    "import operator\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "from cycler import cycler\n",
    "%matplotlib inline\n",
    "\n",
    "size=500\n",
    "female = [item[0] for item in sorted_g[:size]]\n",
    "male = [item[0] for item in sorted_g[-size:]]\n",
    "y_true = [1]*size + [0]*size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# You may change the random states to get more visualization result\n",
    "random_state = 0\n",
    "tsne_random_state = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 1.0\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXkAAADCCAYAAACsebI/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAABoEElEQVR4nO29aXhb13ku+q4NEgBJUSAJkASpeXQsm4OtybIkWz3pOU7b2Ekj281pT20naZR4EDWkTY/b20pKznPTZtBA2Untxk7se3tOYltOYvdmaOpatiRLpKSYg2XXmiVbJEASIEGKJAASe90fe6/FtTf2BkASlERyvc+jR8QGsAeAfNe33+/73o9QSiEhISEhMTWhXO8TkJCQkJCYOEiSl5CQkJjCkCQvISEhMYUhSV5CQkJiCkOSvISEhMQUhiR5CQkJiSmMnOt9AiJ8Ph+dP3/+9T4NCQkJiUmFkydPdlFKS62eu6FIfv78+Thx4sT1Pg0JCQmJSQVCyCW756RcIyEhITGFIUleQkIiCeZOeNkZP3khSV5CQsKAxp1BHN4W4MSuqioObwugcWcQlFID4Uvyv/FxQ2nyEhIS1waUUhBCkh5TShHrUdGyLwQAcHoILr52FV1NUZSvzsNgeBgKIXAVO7ByRxkObwvA6SFYvctvuW+740hcO0iSl5CYZmjcGUSsR8W6PX5O7Ie3BeAqUrBqZznW7i4HAE70AOCrdaF0lRvv7e8GAFTXleDQ1na01ofhq3Vj5Q4ViqIY9gUg5XEkrg2kXCMhMY0gRuqHt7ZrxLu1HS37Qoh1J9CwI4gj2wKc6Bm6mmKc4AGgpT6M1vowvLUudDVFcWR7MGlf0e6Edhxd+jm8LaA916NKmecagtxIH/aKFSuoLKGUkJhYUEpxYM15BBsG+baquhJQStHROIiOhijy/Q4MBBJp91W60gU6pC0CDPl+B5ZtKgYALvUw+GrdmH/fDIO8IzF+EEJOUkpXWD0nI3kJiWmIstV5hsdtb/Xjvf3dGB5UAcBA8G6fw3Y/ncdjBoJn7412JxDvUQ0EDwBdTVHEI1RG8tcQkuQlJKYRGLmKUTwAhJo1og63xJEzw/ieaFcCxMTzvlqX7TG8+nO5HsJ/5s/VuLB2d7khMSsxsZCJVwmJaYLGnUFEu7UIvcNE8iIcLgXDV9WRx24gEQVy8gmGBzRS7mqKoWpzMa681Y9wS9zw/lBTDKGmGNxlCqIdqvG55hgO3HkBnzsyH4qi8ETsyh1lsupmgiAjeQmJaQCWcG2tDyPYMIjSVW4oNsF4LKTC5RuhhkQUcOQTVG0rNrxu7R4/BoPWun3pSpctaYffi+Kl28/ilTXneZL20NZ2NO4Mju3iJFIiayRPCHEQQt4lhPyr/ngBIaSBEHKWEPJTQogzW8eSkJAYHQghWLfHj+otXnQ0DKKzMQo1ZvE6XZYhJmYoudWFy//ab9j2Y/9pTvJ55UY95+rlYdsFYLifItwyhI6GQS3hC6C1PiyrbiYI2YzktwD4QHj8jwD2UEoXA+gG8KUsHktCQmKUYERvB0ceQUltLgAkySy95+IINccMSdhoVwLQg3UzyTOCL67OTXlOrXopZvUWb8pzkxg7skLyhJDZAP4IwA/1xwTAfwHwiv6SFwB8NhvHkpCQyAzmqFhVVRza2m77+sQgRejkEHKNqgzc5QpiIRVunwMPtS02HUT7L9wSR9Vm4xtdZQTdLUMZnSury2f2CRLZQ7YSr3sBfB1Aof7YC6CHUjqsP/4YwCyrNxJCNgHYBABz587N0ulISExvmLtaVVXFy8vPo6spiqq6EgQbBtDRELV+8zABZ28ABf5cRIMxDA0mcOwvO5NerhQAaj/QKjRLAUCsK3Pp5ae3nUVOnoKOhiiv2ZeJ2Oxg3JE8IeTTADoopSfH8n5K6bOU0hWU0hWlpZae9xISEqOAoatV7zY9sj2IrqYofLVurN1djvLV+bbvH+rTyPnWzcWorivh5ZWJfq3TNQnDxofeGj39pia/1ACBfcItcXQ0RHHr5mIQAMd3dUh9PkvIRiS/FsB9hJA/BOAGMBPAPgBFhJAcPZqfDeBKFo4lISGRBqL23rIvxD1oqrd4sea7pVAUJamE0lvrQuX6fJw70IuBNk1Pf88UmYuorivB2j1+vLT8HEKmZqhQcxwurybx+Fa60HXcIsMLWC4ChBC01Ie5N4672CF9bsaJcUfylNInKaWzKaXzAXwewH9QSv8MwJsA7tdf9jCAX4z3WBISEpmBEILOdwcM29Z8txSvrLiAF+Z8iKBe2eJf74bb59CImhD8+aUlKKl2In+WMf4zNzUFjg1AVVX0XdZq5EtXuQ3Pz1yYi1s3F6Pc1FmbDq31YVlxk2Vk1buGELIBwF9SSj9NCFkI4CcASgC8C+B/UEptlnQN0rtGQiI7OPb37Wj6ThiJ6Mjft8NNkIhS5JU7UDgvF5RSqENa85Kv1gXFSRA+FcNwP4W3xsVlGga3z6FV1Jgeu7wKCmY5EBaSrI58YOkjM/HB93vHfA2s4kZq8+mRyrtGGpRJSEwxiElWRuwMDjfBl3qX4ujXOnii1FvrSpJcMoW31gWqqgi3DCUtAiJcPgWxLqM+48gHEgPJiwfDY+otkuAzhDQok5CYRlAUBfPvmwFfrdtA8ABQfGsucnJysH5fJS95NBO8u8xICyU19n2MD55cBFdRDny1bjwSWIrqupKk13hrXIh1qShfnYeqzcXcHG3ZXxSjpMaJaFcC3loXykySzyHdCllifJDeNRISUwDmksNVO8ux/O98eCb3Pw2v6zoRx6EtbVi3tyLjKLnnw7jtcy/dfg6VdxfAVaTA4XBg7R5/UgXOYOcwvDVOfO6dBXx4yEu3n0WoOYaFn/Fg9t0JUErRur8bVXUlIAACDYNorQ/zJLKM6McOSfISEpMcYk08w1t1V/Dh8xHD65gs0rq/O6mmncHpJUndrqpeTs+Myhgcbs1wLNQcQ1VdCRKJBF5ZcT5pnwNtCQy0JXB4azvW76vE4W0BhJrjKFvtwKqdZQC0kklz1yszL5MEPz5IkpeQmMQQa+KDxwY0KYRSnHqqB4CmwRffmouuE3FEuxKW+rcjD6AqoMaAeMheHklErR/nVzqwbo8fR7YFuLf8rZuLoejlkAzmxcWvyzaEEKzaWZ50NyIj+OxAkryExCQGr4mnFC26wySgEa8a1/xlFEVBcVUuuluHkgjeKiFqRrrE7CMffwJEH+5dtsqNstV5uGtfJX/+7CsRUBUYFAaR+GpdcBY5DCRuJnRJ8NmBTLxKSExyEEKwbm+FYdtAW4KXN1JQdLdae8ikI3ggOTFrxttb2kApxcodZfDfkQ+XTt6EEKzd48ei+z0Gggc0P/p4T0ImVq8BZCQvITHJQSnF21vaLJ+LhVR0hpJJ2mqgRzrY1cmzzlgmz/hq3SAkiNW7ynmi1QqqJPhrAknyEhKTGJRSvLLmPDoaBnHrE0VoPzyYUc37aAje6QMSAwTRrgTy/A64SxVEO1UMBhJJRO+rdaOrKYrKuws4uXc2Whuh2W2XyC4kyUtITHIw5TpTgk+Fkmpn0ji/eBcAUPhq3Xjg5EK+/cj2IJweghPf6OLbupqiSZ2qc+4pQCKmGgZ++2pdmHNPgdTdrwGkJi8hMYlBCMHGows1t8gMCN67IvWANkbwjjyC2/8vY2PT/ScWQFEU/m/t7nLEI8mSi3lQdzxC0dUUQ/UWLx5Tb0H1Fq+myUeo1OSvASTJS0hMcrAEZzq4vAr6Lw+nfR0A/EXvTRjuM0bZ73xtxP6X2Re37AvBV2vsVH15+XmoqsrPzVWkGKJ7NoZQ1sBfG0i5RkJikoMRrghz45JYKmklyZhxYOUFLfquK4FKKTobo9yymJG100O4Bl+9xYu1u8u5Z86R7UH+OnMNvOxivbaQkbyExCQGpRSHtwXQsi+E6i1efHX4ZnhrXEmNS0v+uwdlq/NQusqNB3+3yPCcaBPMZrV2NcXgrXFBpRTv7e9G2eo8VNeVwFWk8Gh+9S4/5t9XyKN0RVHwwMmFllG6rIG/fpCRvITEJIZZDgGAyrsLDDbB1XUlaKkPo2yVG/478pKi/oErw8ivdCARo1i2qQjxCEVrfZhbFrh9DqzdXQ5F0Qj+5eXn4fQo+OODC7F6lzFKVxRFRuk3GGQkLyExybFqZ7mBWIOmqU8U0BwnCUFrfTcfzFGlO0b2XxlGIkYRC6m49Ho/H6rNEO1K4JUVFzjBdzVFEY+oBt1dTKCmqo2XuPaQfvISElMEonRTtbkYrmIHLr52VRvevbkYa/f48cLs04buU6a5u4ocuPS69lozzE1QrJRSUbQY0Tw0nJ2Hq0iRo/uuEaSfvITENACTbtjIvWh3Al1NUXhrXQg2DOLAnReS7AXu3F0OhRAoCsH9JxYYnvvq8M2o3uJN8rsRCd5qaDhbaOTovhsDMpKXkJhCoJTi0NZ2tNaH4at1wb8+3zCQmzgAKnA2i9Kr6krQ9la/Qcv31brxucZ5eLHybMpIXiR2Bjm679pCRvISEtMErDxRK22MGQge0Aje7XPwx8x++OODfQg1x+CrdeOrwzfz0sjnZp5GtCsBX60bjyaW8e3mWvh1pjp9SfA3DiTJS0hMMbBSRiu4fUqS/HLrY8XIK87lEbrD4cADJxfCV+uG4jJG7my706MkRfIimHQjcf0hSyglJKYYKKU4YiJdhqiFtXC8R8Vn31wASiknbkboiqJAVVXL7exYYp3+uj1+g3QjI/rrD0nyUxxHIxEc7OnBhqIirPF40m6XmNzgpFsfRr7fgQEh0WruggW0Idst9WHAQnIRid1qO2BvWwBA2hbcIJAkP4VxNBLBJ5ubEVdVOBUFexcvRmhoCN7cXGw9e5Zvf6OmRhL9FEGS3UBdCe7cXY4f+08nyTRVm4vRur+byy9jJeTx2haYx/6ZH0uMD5LkpyiORiLYefEiYqoKFUBMVfH4mTP8DyhBKai+/WBPT1qSl5H/5MHqXX4AQVTeXcDJ9uH2JXgm9z+NLyQE1XUlcBYpWL1rfPXsY7UtkDX2Ew9J8lMQLIJnBE/0fyql2mOd4AFABfDrUCgleYv7UwjB00uWYFNlpeVrJW4MiHYDqqriwMqLhud9tW7e+Xq9yFSssQdg0POrt3hlRJ8lyOqaKYiDPT2c4AGtrV3R/xEkf+lv9/birnffxdFIJO3+hinFE2fO2L5W4sYBi4yPbA+iqynKyyA1P3ft8fXUzUXb4ZZ9IXxfOWVI4EqCzw4kyU9BeHNzYa6hSAA8elcISfrihwG8GLCuyNhQVARF+IMbptT2tRI3FsTEKKuKYcQ6/75CXdq5vucna+wnFpLkpyBCQ0NJX6yq/6PQSHo0FcxrPB48vWQJ3ycF8FwgIKP5SQJmYMaqYhixjleHzwZYh66IQ1vbZY19FiFJforgaCSCb126hKORCDYUFcGlKBBjIVGmoUASybsIwUN++6iuqqDA8HhIRvOTCjeinzulFC/M+ZDnBh5Tb0FVXQla68N4Yc6HkuizBJl4nQIQSyUdhOCLfj/2Ll6Md/v68KNAAEOUwkEI1syciUORCCd4AsBJCL7g9+Mhvz9l1czBnp6khSEQj+Nbly7JihuJMYFSCnVY+61qe6sflFK0vdUPAFCHqUy8ZgmS5KcADvb0IK6qSABIUIpn2tvhDgbxRk0NbissxONnziBBKY719sJJCIYpRU6G5A5oi0hjXx8IRu4AHAB+GQ7j9VBI1tpLjAmKouCRtpvw0u3nEGqO4QeO9wFoDVoP/m5RUhOWGWwRsPtfQsO4SZ4QMgfAiwDKoXHAs5TSfYSQEgA/BTAfwEUAD1JKu+32IzF2bCgqglNREFVVLsXE9fp3QI+YoC0AX66owFy3O+Po+2gkgt9rakJMv3VWANzn9cLvdOKf29uREI4lSX76IFsNTIqi4MHfLeIEDyAjgmf19U4PQTxCcef3yvDO1zrg9CiIR1Q4PeOv/Z8qyIYmPwzga5TSZQDuAPA4IWQZgP8J4A1K6RIAb+iPJcaIZ9vacE9zM55ta0t6bo3HgzdqavCVigq4CIEDgFNRsKGoiC8AbNtDfj+enDcvY0I+2NODuKCNUgCrZs7EQ36/Yb8biopGfd4SkxMNOwIGAzJVVXF4WwCNO4Mp38dcK8XHqqri5eXnDdtFh0sriPX1F1+7ipZ9IfzYf1p/3Mf/b9ghc0ZAFiJ5Smk7gHb95z5CyAcAZgH4DIAN+steAHAQwF+P93jTEc+2teErp08DAP6tW7sZMjcjrfF4sMbjwUN+f1Jn6hs1NWPuVt1QVAQnITySzyWE7yfdfjM5b4nJhYYdQT5tCgDW7i7nIwHtGpgopfj5711APKLigZMLuaTy0u3nEDkbx3A/5U6XLy0/x62M2Wutksas7JI1UjHLBlb/39UUReXdBVK6QZaHhhBC5gN4G8CtAC5TSov07QRAN3tses8mAJsAYO7cucsvXbqUtfOZKrinuZmTJAD8t+Ji/KamxmA1AGBMRJ6JXcHRSIRX0mSi4ac7b4nJCdFxkhEpg3mQCEPjziCi4WG0HRpAqCkGb40LlXfl4+zLvRgMJEByAedMBV8I3oST3+zCQGgI537Sh5wCgocu3JTS4oBSiu8rpyzPdbo1VKUaGpK1xCshZAaAAwC2Ukp7TXodJYRYriaU0mcBPAtok6GydT5TCRtLSw1kubG01FBRk0MIKDTNnSVBgWTSNy8KLwYCeD4QMLzPisDZXUI2zlti8sIqgmawIngmq7Tu70bV5mIMtA8j1Bzj06fyyh1Qh7UB4ke2BwFKceqpHgBA1Z+W4PDWdrTUhy3vEKw87EWs3V0+bQg+HbJC8oSQXGgE/y+U0lf1zUFCSAWltJ0QUgGgIxvHmg4wR9dM4jjQ2YmNpaXYVFmJb126xCtqVP1ujCVcv335Mv6/cBgJSuESSF8ssyQA4kJT1EQkT63OOxWebWuzfK00R7txQAjB2t3lSSR/ZHvQMnK2WxQAIN/vQKg5DrfPgdb6sOE59tjKIdPqjsI8bJzJPekSuNMB2aiuIQCeA/ABpXS38NRrAB4G8A/6/78Y77GmMhiReXNzUXfmDOKUwkkI3qyt5UQvEh9LqJojeQcheD0UAvt1jwlVNlaLAqDXy6dIno4H5vO2g51+L83Rrh/EYSHsMYCkRKmv1p00JER0l1y3x29J8qHmOLw1ToSa47bnYKWti1YNuTMJf52v1o35983gOQO7hSfTa50qC0Q2Ivm1AP4cQCshpEnf9jfQyP0lQsiXAFwC8GAWjjUlIUovAEYIWu8qNUevbEFg/vCiJt/Y24ufh0b+oBx6ohQAXxRYJD/aevmJxIHOzqTHmyorDeZoqm6OVlVQkPG52t0dSKTGzzac54lSNh3qpdvPIdqVQP+VYa7BH9ke5BG106ORqVj9kqpKJhP4at2W0ovoYU9IAJV3F2Dt7nIoioKVOzT5J1PzNatrfXn5eTg9Cv74oPUYxcmEbFTXHAZg90l+crz7nw4Qm5nMMHeVmgeBmHX0XRcv8p8dAJ5assSyyoYd90aRQOz0e2aOxu4+EpRmLCvJ6p6xQVVVxCOqocrl5eXnEWqOIa/cgaq6Eu6Fw+QYTVLRZruy6F1VVcMgcZdPQcGsHISFyD18yj6KB5AyImePV+/yGyJ9dl6ZRvBW18ruDKZCRC87Xm8AiNKLQy8vG4b25Zi7SsUFIaqqhkj/xUCA17QTAF+uqDCQmjmBeiOQO4Odfs/M0Z7Qu3Zdo5CV7O4OJFKDzXFlZMcalVj0zsoaGQEyon97Sxsn9XV7/AbnUgBY8t89eE+fRDXv3hm4+Fov1+QfCSzFq3deQEejcT4hu0NIR9hj9eZJd62TneABSfI3BMw154AWZV+ORpO6SjcUFcEhTHb6USDAjcV+FAhwnT03jeHYtUSmJZh2+v2mykpUFRSM+s5DVveMHYz8xE5UkeCZxHH/iQVwOBxQVRWBQwPIn5WDln0hSw2+o1EbR7hWvwvQ9tWHeffOgKIo8N+Rj47GKMpW5+H+owt5cjWTendWCs5q8BkysTmwu9apQPCAJPkbBlZR9rNtbSCBABS9xJER3Bf9fjzT3s5tg1lidViI4r94nTV2BrMtwvOBAA7qyeTRYCxlnKmqe8Za+z9dYNWJ+sKsD7HwgZlYt8fPJY4f+0/jlkeLcOn1fnQ1xeCrdWHgyjB/T1VdCdbvreCEXb46T5BZyrFyRylfOFzFDr4ImAeCmyESd+POIC7/+irKVufBVaQg1qPlAYINg5h7zwzEI2rKcYJ2XbdTheglyd9gEKtstp49C1WvmNm7eDEnoof8frwQDHJd3pxYZfYF6SAmJcVIGUDWCNBsizA0Ck09G7C6OzgaiWBDUxM/rx8FAryKSWKE9JgurckZ59DVFMN7+7tBKcX9Jxbw4eAnv6lF7d5aF/zr89HVFOP7YvGzSNhiVH3iG528CmfVznKoqooj2wJwFTuwckcZ1u3xo3FnEIe2tvM8APOgd+uviXUnEGwYRLBhEN4aF6/DB4BEVEWoOWbbjWt9recNGv1kJ3pJ8lnEeDtQxaQq0ZONbCZraGjIcAyxsmY09gXs/T3Dw/j2Rx8B0JKSOdBKKh16OeaQToA/bG/HX1RU8EVD3P/RSATf/ugjtMVi+JJJ/2ews0W4njjY08OvD9D6BaTB2ggURYHToxh06QdOLsLLy8+h51wcp57q4U1LIqhK8d7+blRv8ep2B+fQote7r9tbYRjWzcBnvFKKdXsr8OqdFxBsGETZajei3Qms3V2OU892YzCQwJW3rmLhZzyI9STQWh9G6Sq3thDsrQAAtNSHDQQPgBO8XSLW+loX8uqayU7wQJZtDcaLFStW0BMnTlzv08gI5gYds6c7K1EcjQ3vty5dwt9duIAENOc4h070YhfrhqYmDFGKXELSyh6pzpECSSMCARjshMVtuaZr2jxrFr770UeGfTyzdKkl0U+UNDLWJilzJO8S+hEkRmCuLEkkEjiyLYBWoWLGjNxioPoJH4Z6KVr2hZDvd2DG3Fzcf2wRJ/gDa85DpRQPHFsEALyzVQSLyH21LsOdgQhfrQvz75vJh5bbWRw8pt6SNhE7ljr5bDlxZgPXxNZgKsKORBhJiGQrVr2YO1AzjRLFKhunoiRF649++CEnprhNDb14juZSS/Eczb+KdpE8u44h4ZpiqppE8IB99cpY9PS/PncOr3Z24nOlpfjHRYtsr28sTVJrPB4crK2VmnwamEnuxDe60HZoIOl1rlKCGZVOhJpjGOoGTn6zCwBQXVcClWrRPSutPLy1HcGGQQBaNc5d+yr53wtD1eZivpCkIviuphgq71a5xGMHdux0yddUj80Qm73Y4pXKZ+d6QpK8DVLVo4ulioxsmfWuVSSfqTyRibNjprAqtRTPkUXjTVev2mrygXgcvwqHMaznBdg1KfrgETPGUr1iJXGd6u/Hv3RoLhhMUjIT/WiapKwW67H68UxXqKqKC6/1cpMxURaJdVLEOpPJmMkoiqIYKm4YQb+3v9tQR89w9qXetOfT1RTTkrS7y3FkW4DfCZjPzVvjSurGHS/EZi+2X5ZYttP+ryckydtAJMm4TpIiGZlhVwY5WrK2Ih9GUrcVFsKlLzDONCWSG4qKkCOUWj6vk3yqRcSqht6KhFlSOKZ3M96Un4+ts2ePqgadSTg/CgR45y2zZjDfIbza2ZlE8pk2SZkXa6tchkR6nPhGJxxOkkSiqSA2RokllQ+cXGQgZkAj/vtPjDRdZQJVJ1NXsQPlq/N4dU3lXfkAAYINUcy9ZwZm3Z1I8r8ZD1jlD6XUsHixJrEbieABSfK2MDcoPaeTkZMQ1C9ZYkm2E9FsZCap+iVLMiKpNR4P/qCkhFscMBJkA0PY4O9M9mN1TWOpWzdfE5tkBST76Yj4nMUdwhqPB39SWor/rUf8dk1S4mIdU1U8fuYM6ChzJdMdLHLtaIyipDo35Wu9NS48cHIh3vlaB0+omuWYI9sCSdvK12mllRV35WdM8ude6sX6vRVYtbMcK3eUAQCO7+rQE7d52PjOAhBCcGhLGy7/5ioIwZikFCvt/fiujiTJk+jHl3LNDQg77f3hcu3LCgwN4eddms4YoxTv9vXhTV2Hz4TkxuOiaL6jCA0N4cl58zK6pl+FRyIl5mHDKmJe7+oChUaOVtFtunMej9zBrslgkGayS/6cz4eG3l5bTf7ZtjYu6QDA5lmzLKP4y9Eo7yKGvv/R5kqmO1jkGjjan9SRakaoOYaXV5zHAycWApSi/dgAOsUGJ4skKwCceqoHhBB06Hq9HcpWubHx6EI+F/bVOy9g49GRQSSx7gQ6GqPoaIxq9fcA1/fLV+eNWkqx1N63tiNwbCDps2ipD6O6rkTKNTcarLR3AIZt9xQXJ70vU5IzV918cZRmYOZkbKb6vlgmyJqjWvv78djp0waPnKiq4okzZ5KqeFL544wX5rsk9pmw8063GB6NRPCdy5cN25quXk16DbsGRf9jV6HdKbA/P29u6qhUQgOlVJsTHLevxCuuykV3q1bmG2qK4Z3tQdy5uxw/W3sRAODXCXbtHj/OvhTBQCDBG5/EGnwAKKlxGvxtRCRi2jlU6hG/eEaEEEM5pWhfzJqyRkO+ttp7fRjeWpfte8yPrzfhT1uSZ5Hq5WjUECmbbXnjqgq/0wknIbyaxk4LFxuZWGQsJggTlOKZ9na8EAzaDvYwYzTJWDH69ubmcm2bAuhLJDT/F4v3DZuiW/P1ZzviTXVNmdwVMalHhDnpa1ftxP5PANg8SkfL6QgWya7dXQ7itCerzzctweFtAQSO9UMhClrqwzxiZ2TOmpyWbSpBvCeBdTrpPnDSOMibEbzLqyAWGvmeXV4FoeYYf60VcTOiN98tpCJ4u/JJ85AURvbVdSVwFimovKvAsJCUrXLzyiFgxPfe6SFYvctv2H4tiX9akrw5us4hBDBVwpi7R61mp1rtkxG6Ak0K2TxrliGRyMj0xUDA0LWaKlrO5K7BfEfycHm5oeb9/3R0WOrdEF6TY2FLPFE+82OVe0SpRwGw0O3GX82dm5T0tfLbHxKGpADW3bdyQMkIxEi27a1+dDVFbROvYpkipdRA2ozgW+rDKF+dh41HNfte9lpz+WNeuQPucgXdLUPIK3dg4QOF6Doew5x7CnDiG138dVbEzeQUMw5tbbd8fTqbYashKSqlWLmjDAfWGK0QEjEVoeY4Xllz3uC946t1Y+UOlXfrXutSy2lJ8mJ0TSnFpooKzHW703aPpvqjZ+TDCF2FRuZNV69CwUjjERvQAWQ3WjaXTAbicThMpY4KYIjkzY1P7GcWabM68rFgosjSLF+9ePPNhjwCK/30O51JJaIvBgJ4LhDgMpa5+1ZcqB2E4KlpPqDEatyfmeDLdBmGRbRM0hAhEn7Z6jy+bz7hqT5saHoaDCYwGNR+Uxf/yUyAAnPuKUA8YgxTzPXvjOBZFF9VVwICo3QjEn0mNsPHd3Xg4mtGKfC9/d344LluJISWAXH4SUfDIG/MYpOrmF3y9Si1nJYkL0oZKoDbCgv5H7NITmKCU9ze2t+fZHrFyEeM5J2Kgo2lpTgUifCI8guC/mzlPzNWmEsmfxkOY/vs2djz8cd8YtR8pxNnYkZfEXNkKzZYsfNj8tJY7BmyrenbST1mIzQGBcChSARv1NTgBzfdhIf8ftsmKHPt/eNSzuFEL0ayZavcKL8jH4A2ps+n69PBYwNaR6xOqCXVToRbRrT1WzcXG0iZEILcmYTbIBwW3gtoJA0ArfvDnCyZRQEjS2Ck/t1cTrle1+cBINAwCHexw0Cq6WyGAfApU75aN+Z+ugDv/1MPol0JA8EDsJ1uJQ5W4XLPNR4yPi1JPjQ0xKNrRX8M2HdRmj1lWHQsDqIQyUfU5Nd4PLblhtlqfAI08vuC4E6ZoBRFOTl4askSPH7mDIYpNRC8FcR6enNVD7vTyCRCN5ct7rx4ETvnz88q0Zv3ZTZCY1Bh9N1PJRMxG2em4avS08ZyYLb/jnzuFEkIgdOjoPKuBFrqw7zi5NbNxSCEINwyQtodjVEc3hbg0XTDjiAuvX4V8+4tSPK0AUbmvFZv8cLpIai8u4CTo53hmVhOybazZKydd00qm+H59xWCgqKrKYquJu3a3D4F0S7riVfF1bnobhnijw9vC+DO75UZFslrXUs/LUl+Q1ERXBaas10XpWFyk+kXUWzltyOQ0W4fK8zulN7cXBzo7IRq0qIZrLaxenpvbi4IIQab40wjdPNdzW+7u/FmT8+Eyh9mIzQRFCO+++l6AtiiqFL7ASXTRbcXB2bzCJrJITrRijq8mOwkhCQN5+5oGOQlkuv2+HHxtT6dOCmi3VcsTc8A8LF+5jmvdmQ5mgEi6WyGCQEq1ucjJNgr2BE8AAPBswHl7z9r7OrNxGYhm5j8FmtjAIu6v7lggYGoWBclAyM8RlpWX4m5qoM1GR2NRLJyrqPZn3hdexcvxtazZ/Hv3d2WRmQKrL98ByG2NsdW0X2q8/j94mIuCQ3p8ke2PherY9YvWQIHuw4Ad3k8/DsTffdTYVNlJd6urcX/Mv1uMLCF7u8uXMAnm5sn7HpuBIgDs3kEvbcC1Vu8PIIWtXURZ3+qfS5VdSV4TL2FSy955Rrx/cDxPrqaonD7HOhqinGCd/sc8K00lice3haw1K/HS5Jmm+FHE8u4LPTy8vNIJBKIdScsrRfSoaTGiWiXlldIRCncPge+Onwzqrd40bIvxK/pWmBaRvKAdRS9xmM9ao6RFmsiUqHp2X85Z07SIIpsatFWRmiZ7u/dvj6eCFYArCgsxPG+PkP0vtbjwdsmkiIAfhUO825Uqjd/AaOr2V/j8WDn/Pl4U6jXn2j5g8luDMvy83Fc/xxG6yGUiRQ1HRqqxIHZQHIEbRnt64+9NS7+WqaPu4oUQ4UMI0LxcbQrweWeYMMgWuvDKSP3sSITm+FMaDjHC9BBgsSA/asfCSyFw+GwlZkmEtOW5M0Qb8GfWrKEJ1bFP+DfhMPcqdHK9fDFQICTYzoCSOU9z55r7O3N2HWS7dOuNPRLFRX4XV8f2MyeXEKwLD8fhyMRQ6Q/RCnvhgWMOv1oDdQylT/SQfTAZ9Uytt71NqWv3txcvBgIcKO2sRLzWJvTJjNSRdCW0b4w3Jtp22z7ke3BtMcrqXHyASEAeMnheEnRyp7gjw8uNNTJM6Jnj93F2uBys/QEACQHoMMA7Sc8Ws+fp6Dn/aGkZq5XVlzg+5Wa/HWASI6iUdahSIRXV4glkuIQD3Ef4oxVZiNghWfb2jjx5RCjYyWTWeKqve5nB3Pu4MtCaejBnh6DjQCr8nkhGDRUBImmXwyi+ddo8whjnc/KYOVzIya8RaRahET/+OcCAXxplJ3HmRxjuiJdtA9ohMqqTMShIlZWwpV3FeCd7UG4ih1YtbM8K6Q4GmtgsTFq5Y4yHLKouwc0gnf7HIh2Jfj/4p1JXrkDj7TddN0nTUmSh313pBiNp4vgDvb0pJ2xyuq42XBuwOjTHldVHOjs5OeiQNOWVSCt6yRgHcmK52D1HCMsFiXXzpiB/VeuJJWCZhKx2iUks+lzw/Cdy5ctyxvtKm9Ef/whU+fxWIhekrsR6fRyq4h//n2F6PtoyNDVWlLj1LxnGgazVks+VmtgthC01odRttqNRJQa+gTyyhXkz1aw5E89SZF+SY0Tf/K7xXpH70K8tPycwQnzWna9SpKHdXckI+xfh0K4HI3itsJCblhmFQGKFSUOQnBbYSGA5JmtURNhKdA6TVkkL9bVj9YaN12UKZ4/AO5CuaGoiN/JHIpE+DHNpaCpMFG18exzNX9u56JRfLK5OaPjbCgqQi4hhhLLTCS16QaWCBSJSHw8XrCIn+071qMaCB4YsTSoHoVtb7oJTbb2BGnq1fnCVFcCCq2k01vjQuXdBQjqBmWDQRWK0p/03sq7CnB8VwfiEaqVmK7Pxzp9oLnTQxCP0GvW9SpJHskdnjNzcvC9jz5CAsDbvb14u7cXaG/nVgV2EfU9xcV4PRRCglJsPXsW5wYHDc1IrFEJ0KL9HL2r0ixnjEfesIoyzQR8W2Ehl4SYBUKmTpfi8G9RLvn25csY1CWmbJKn+W7j1c5OnItGDfYQmfj/sElQgaEh/FL/jqaLpp4JGncGcfnXVw1NRIe3tiPQMIh5n5qRERllMkLv+K4O7oXDyim9tS7Mv3cGHwgOgNfhW0Ek8cadQUS7E7z2nnW9OosUg18MgKSmLiuCNy8QrOa+cWeQV95U3l2AjUdHhpt3HjdKTt5aF97b3y2MMNTe13ZoAKGmmKGx61pE9JLkBbAac0KIZdkhsyqw8jv5ZHMzJznAYkQe1SYqEV2H/4JJE86WvGEFc0WIKAkx7T+TZOKzbW34yunTAIy6+LNtbdy3HtDuTry5uRn51WcC8fP4rM9nyJ88Hwhwws7U/2e61LlnCmbRG2wY5AZbzA4AyMyiN50HDD+OIJvMuWcGhmMqQk0xEFOB8pHtQV4fL54nWyRYZH7p133oaIgi2DBosDLO9zuwckfZiF+MvmCJMNerN+4MItY9YpzG3ucqdmD1Lj9W7lB5XoHJM95al6GGniVp88odcLiIIWnLXid27kpbg2sIkQgVSpN8XoAR3xmz38nOixcNBM8gbnEQgm2zZ6esDpkomLV6syTEpKXA0BD8uv2uFREe6Ow07Jc1gj3XbkxMLcnPN9wpTJStweVolOc3RnP3IDV1IzK16LUj+kw8YKxcHRnEyHbt7nJOpG1v9fNFQyRqdgewdnc5ElHt3lj0iwGAgUACh7e2Y/2+Shza0sY95dn1mG0RAODyr6/yRW7d3gq+YJSvzuMLhvluwGFy5iTQun3Pv9qLjsYot38w41pW2JBrVZCfCVasWEFPnDhxXY79bFuboT5+7+LFeK69HY16jbgC4PeLiw3t+VaVHwxmX5g/KyvDq11dYyI+O4lkNDCTtpgr2HzmDHdoJNCSvczcTDxXMZIHgGeWLgUAPHr6tGFB+6zXq8lW+r6+uWBBRoNOxnJNE+l7P91AKTUQJQA8mliWkXui2FjE4Kt14/4TC+BwOAyvNR9nxd+XIh4ZqXwR92WuvRf1cQarua4OFzEM9cirdCC/LAcL7puJ1bvKteHf24P8eiilOLS13bJUki0MAAyLA39+czHW76vkz1VtLgYFUjZRZTuSJ4ScpJSusHpuWna8mnE0EsHWs2d5snXzrFmoKijA7TNmwEUIHNC0+I2lpTjY08O7HO0qPwAkJVc7h4Ysu0XTdbQyYv237m585fRpPNvWNqZrXOPx8NF/4uNfhUKIC7kCCmAYWl2++Vw3VVbimaVL8d+Ki/HM0qWoKijQSkGF43zW68XX586FU1HgQOaVOWO9JqvO5Wx3HU8H2Fn0vnT7Oaiqygks1qNadmoqioJ59xYYtt1/YgHe+VoHGneO1MZbdcfGI7pfvU54rFaddYd+Xzk10my1t4JH3gwVdxmj5VBzDAnTgBMa1+SSeETlBO/0EL5gsYYt1pnLYEXw1Vu8eEy9BeUmR811e/yo3uJFqCUGSim8NU7Dvhz6afpq3de061XKNRjxrKHQSO57H32EvULC9MsVFZiZk2No6nmjpsbg/GgHgpEFQpRIMvWCsZNIxgtWzvlaKGT5PFv9zSS9qbKSH/9bly4ZaupzCcHX5869prXkZullNNG91OY1WFn0Alq0LA7pSBV9JhIJnPpBj2Hbj/2nEe1K8AQjANvuWMAoYSiKkuTjfuf3ytC4swMXXus1HMcqYg6Z6u+jXQm4fApyZxJDvX5SJY5pP+yxVQnoRj0H0ClYCa/dXY5DW9vx3v5u5BQY9zZzUS5mb5gBZ5EDlXcXwOkhUpO/VjC7D7J6eQpwQ7I9H3/MI/2YHt0+OW+ewfmRAKjJz0fLwAAotNr2L/j9uK2wEKGhoaRyyG9dupS2RX5jaSlPcrLH40UqmQkAXITwgeHe3FweyVuVjbr0slFFrxQS7xSYxLPz4sVrlodIZTtg7jKWUo+GVBa9onxhR/CqquKVFRcMTUEA+OM7v1fG32cmyrW7y/l2Ufdv2BHERROZ/9j/IeAAokHt3vGWJzx4/wcR0ASguIAvRpbgxcqziIetg65Yl4qT39QsFcwLlnmhY2CP1+kDw81NX7kegqHekWTy2t3laH9b8yEe7jeeR3frEGZtoIhHVF5G2bgzOOFllBNO8oSQTwHYB02e/SGl9B8m+pijhbn9PpcYh0oDMA7fELpZH/L78bw+iMIB4INBLXGToxNlVUGBLZlk0iLPiHGsmrxVtGolM+UQgu2zZ6MoJ8eg26ciwnQRu101zkTC7jO1mpw1nTxo0sFs0WslI9i5J4oeMPefWIB/yvmAP1e8zGXQ5EWiFEcLirp/7kzgg3/uwUAgAV+tC/efWMjvCkScekqT4xQXoMaAH7rPZHy9VtfBqm+YRMM0erEqx1yPP9QLnmAWa/CZ5QGDy6cg1qXi1A96QIdxTcsoJ5TkCSEOAE8D+K8APgZwnBDyGqX0/dTvnHiYyc/cfg+M+Mm09veDChUk22fPNhAC+3ootG5K0foglZ+NuT7fDkwiYVpzKnkhk2jVbpC2VadoOiJMVakyHqkpVbI5lcxit/CYPe6ZMdtoOnqnOsymY6314bSyCsMfH1yIRCKBd77WYdheelty+SVbROy6UKvqSlAwJwcDgQS6mmKGRcMKX4wsGRXBA1oPwDphShQhBDluYjBVW7fHj7a3+pHjtpZV7KqFAMDldSAaHFmUYro9MSP+a1lGOdGR/CoAZyml5wGAEPITAJ8BcF1J3i5CZf/MJHKwp8cwZKQoZ+RjezEQ4IlL5k7JiMObm4udFy9azlAVkckEpky0ZnOFkF20akWEVgvIeM247KSmdNVCqe4AzINdzHcfgPXCY/a4f39Au6V2QEu020lS0xGpTMfsjMIopXjnax0Z6e2M9FN1oQLA21vaMrL5tSN4h5vwEktA85m59bFixHtUtNSHEWwYxMajC/mi46vNQ8u+kGFUX6g5ZsgpWNk1mHMHABANJnj0boepUic/C8BHwuOPAawWX0AI2QRgEwDMnTt3gk9HQzrd1kymdkNGjkYieE7X4wHwxG0uIVx/Z0lZZgpmThLuvHiRE08q2SBdVH00EuEToAAtWg0MDUHRf4HNJG1uDhLdK8XIfjwJVCupKRMJJ9UdgHmwy7c/+oh3IqdrhnqjpgY7L140LDwJaPkWNYOGqumETEzHRGS6MJglGjNBimWUSbKQLssw5JYAQ4KEXvs3xWj6v4XvViB4QMsRiNVBZkHKatFhIwsB6JYEClbvGtHQrYaO5PkdGAwkUhI829+1IPrrXkJJKX2WUrqCUrqiNAtJxUzAojqrEj87MrUq1TvY04Nhi/2rulQjHsdtskNgxMqGeqSTDVhymCDZ4ZItFmKVDwF4+75CRgZ/WMFwzbp5FxuIYS69HC02VVbiNzU1BsIXIT5mdxO1M2YYXiMmm82DXQBjJ7K4H3MJ5RqP5nHvEt6vQMu9pBuEMh0x2iEdZsdIRvQssShKNC8vP4/h4eEkgjy8LYBEIoGXl59LqllXTYaVQ6aS9o9+aRq8Co2kH00sQ0m1Vs7YWh/WLQec2PjOAoMj5fFdHUnlmYFDAwbP/Iuv9aFhR4Bfz5HtQXQ1ReGtceHRxDJUb/FiMJBAcXUu8sodSedTopdV5vkd16yMcqJJ/gqAOcLj2fq26wo70gbsFwBGdgA4gbCRcyLMZP1weTm+XFGRdBzRupg1WqWLIonpf8C4WIjNTDfl52NYzw9QC2tkEebJV2L+YCxIVadurg7KVxQcjUQME5f2X7mCr8+ZY6jHZ/tb49EGu+QSwn952Xk39vXh2ba2lJOb1niME6QUaHde7Ptmdgyyxl6DmYDSEVI67/m1u8t50vGZ3P9EV1MUDrf2GoebaAvAivPcgpiRcyqw17CyyVs3F/PpUoQQHN/VaVFLH8erd14wEHi0O5HUK9DVpJWQtuwL8fOORyi/y3EVKShbnYfKuwv4onbr5mJEO1QMBo2JYmDkd7Vwbi6q60quyfCQiZZrjgNYQghZAI3cPw/gTyf4mBlB1N9FLdpOrxadJEUp503d+AoAL5W0SnqaTc3MejfrpLVKKrJInXWlslF2LF9gngDVfPUq/nNgIGOrYDEB/KNAgHe6jnXAR6rcAYvon2tvx7t9fXg9FMJvuruT8ge9w8O2yWMxSd4zPMzN5H7e1cUHnqSSv8QFj0KT0ea63Zbf73SWbkbjwZ4pFEVJqsBhAzdY9UyoKYby1XkoXeXGuj1+vLz8vKGj1Qz/OjfCLSNDOlxFDlSuKYD/jny4ihREu4ct58cGBSuEqroS7tfDJCdzTkBMljKs3FGGWLc2xJyRvEIIBgPGclKGUHNcc9hMMVw825hQkqeUDhNCngDwG2gB5vOU0lNp3nbNkC4BCxgHfLCBGiKB2EkZmdTAm62LzUnFp5csAQA8ridTKYykfTQSweVo1DAB6vYZM3Cyr89whyBaMdiBXTObpDTWBiE7uUtcvKoKtM5IRrVmkzTReEzR7RUoRvoT2HHYMBRR+WRWCszl02qhsvPdz+Q7my4Yqwd7OidKSil+tvZi0vvMZLjx6EJNDtGTn3Zw+wne/76xnv7UD7q1Jqy6EqzcUYYfV36Y9nrX763A8V0dqNItjgEkyYKAVgcvmqQRQrB2jx9tbw8YtHyzHw9rKANSO2xOBCa8Tp5S+ksAv5zo44wFmSQznxCSmVQ3LhMJxK6cL1VlinlxYVH+i4EANzpTKcVjeoKS/foTjJA2AL4gEAD3+nz4+hxNGWPVOuwOobW/P+OGpFQlkZl0iFpdt3i9zPjNbN7GTNIYmPEYFSwXVAA9w8OGz27v4sXIwciCIcJOWLBLKE/H0X52GIsHezonStZwFDS5QVqBJSVzPQryyhUMBq2TmNGA9i3n5BP8Re8n8MqKC3xAeEt9OKm5KdXxOt8dRDySgKqqWqVQfTipQufl5efgX5/PI3w20lD07AGA+ffNQOXdBdxwTQSr3pFDQ7IIO3Ly5ubaVp8A2iIgJjMV/Z8KTTL5eVcX9l+5Ynl7n6oyxWpxae3vxz+b3BzNv9YKwKPyb126xKtMAOD/C4Xw9Tlzko7b2t+flYYkcai4AuD7S5da7kc8PuuWvRyN8utNVimBP/R6DTLJ3sWL4dQXKnEcIQHQdPVqkvf9H3m9BqtjdgxxbKHVeWZaYz9dwYg+nQc7kLkTpbPIkWTPy+D2OXDLo0W49Ho/WvaFEDjWj+FBFYNBFWWr3ADATcdufaII7wkSzPAA5RKQr9aN+ffNMAwML6lxJs1drdpcjHV7K7jNAZNXXllxAfPuncEJ3u1z4OH2JTiw8qLmJ39XAarqSiwjd4Z4hOLO75UljTxkj8XPMt3Qk/FiypO8SE65hOBgbS2XD5j7ogOwrD4R2/YBYK3Hg8ORiNYNC+A7H30EAnv91y4qNkeM3txcTZIRXkOg2SKolPIolZj2IRKg3RzWnRcvGo49Fu8bZuDGJisloDlPvtvXZ9lExR6bh4qrQlTO4CQE/txcA3G/29fHpayZOTn49kdaFS4FEE0kDPLUhqIiXI4aoyiWVDWXu2ZC3qnuZKYbrMzEUnW9isTO5Alfrdsw13T1rnJQqgIUBhmGEeyl1/v1hcEFSsG19vI78nDmJ1oy3FlCEGy0vxtgxmgizAQPaL9PR7YF4CxyoHqLF7kzwY/PCNvtc+CRwFI4HA48cHIhd65cuaPMUP1j5ZgJAE4PSVlWOhF5DzOmPMmzZiVAKw98MRDAGo/HsD0BLRFonhm6xuPB3sWLuSZ/rLfXQFLs59F2TZojxoM9PQajLwLgM7r88mIgwL1xEvr1MCJ6eskSQ/OT1fHH630j+tyIUIGUc1KthooDwA/b2zEM7TO7T3esBEYkJgchhuTvPSUlBtvmQ729cABYXliIL1VUYI3Hg9b+fjja26FCk9H+qKQEfqczKdeRrsNXvGaWTB/LsO+pALHqJNOuVzbPVNSfrQZXr97lx0f/ZiydLFyYg4JZOZh3bwEq7y5Iai5qrdd+h0uqnQi3xNHZqC0QtzxRhMChAYQEEmeSDYvoL//mKjoajIGANkt2EB0NI7q5oihYtVM1nD8jeADcTx5A0uLnq3VzJ02RyO36DQDt7ofnPSjFWl36SZf3GC2mPMlniuN9fZYzQ0NDQ6B6sjVBKXy5ueg0VWc40tShW8EcMbpMc0x/Ew7j63Pm4CG/H8/p3jgUwPOBACcesxWD1fHH632Tzk7ZLkFpldwEgB/pCVXRsRKA5SCQmKryahnxmMPQvq/Wfm225tazZ3lSmlKK10MhwzHFBSeh9wH8KBBIms4FjNz5sQDgR4EA3tTv/qYTzM1NAAzkZUbjziCi4WG0HTLWqv941od45MpNnOjZ4tHRMMirTERjsMq7C5IkIhEP/m6RoTJHIcRA8N4aF9fkNWklH2Wr8tDREEXpKjcq7shHS33YcpasVWPTy8vP48HfLeLnz/V6CwlG1NrFqVZmoj6+q4OPWly3xw9QasgfZNvu4Lo3Q00UWGnkbYWFcOlNRC5C+B++OdFnVxturpv/gsV8V5VSHOjsNNRWH41E8OiHH+LRDz9MW3PNIvv/WlysERU0gtt58SJa+/sNUT4rnxTfm65ZydyQNBoYrp8QfNbnw2e9Xu6zb3cHY9WLcLCnhy9WQzbXcVthIRS9Bt5BkscwirX8MXVklKEK7e6C6f7id2nVBxCjFP/U3o4NTU2G74edI0PcdJ7TCay56fiuDh65rtvjx8odZTi8LcB94imliIaH0bq/G6GmGLw1LlRtLgYADAYS3JMeMC0euneMs8gBX60LpavcaK0PGyJpM15ZccHweGTiUzGq6kq4BMQsjtftrYC72IGquhI8cGwRL11kYOcgDirx1brxaGIZ8sodCDXH+Pk37AjglRUX0PnuIKq3eLnm3vnuAHy1buTOJFxyObI9aPDRZxBHLbbWhy2boURv/WxgSkby5uqV+iVL8K4+4YkhNDRkkAGsRvsxmEsdARjmt6oA/r27G4ciEbxRUwMAo44GWTfmoUiEJ1T/vbsbb5pKBEUHTLtrzzRxmMlr7ZKRmb7XnOgWPzOvPmpQPB82vIUAeLC0FD/t7OTVTQq0Jq8PdN8ZFUDtjBncpz+HGN1DxUY2sQ9AHJIiSnjsHMXRj840n/d0QCallOv3VeL8q33ovzKMUHMMoeYYqjYXo+3tAQx2JXDiG51cYxYlDEqpnrCNoaquBJ3CNCdx4pO31gWqUt5dWnFXvqGGfd0ejbzN1sjHd3UgHqEjMoup2YnlGBRFwWBoCG6fA/ef0DphF//JTLTWd6P3vBb1X3ztKl8Ecgopl4WMieR2DEUor7e3MmezG7XIkO3qmylJ8uLteVRV8Su94UY0AfPm5hpkgPUzZ2JZgXGyzdFIBL+nk7VTuAsoyskxJEHNyVcAltFgOoIU/VWY3QEo5V73DmL0bDdjtAMzzDX5dpG+XSXKaCWM0NAQr04CkLTwmoe3vNTZie2zZ2OPPsDFpSi42+PBh0KjV1FOjmERYvux+mxZH8DWs2f5WEfzZ7L17FluNLfe48E/LFw47aQaEZmWUhJC8NDlpYYofJ1u1/ve/m7uGSO+3rB/XbIQ4XAR3PJEEYKHB9HVFEP+rBy4vAoUZ/KgkMPbAmh7q9+w7dDWdt7gRPXAgR0jv9IBNT7iHrnmu6VIDGp3AO98jdkbaOc41EcNiWQxMevII6hYr02IEreX61KMHVGv21uRdL2PJpZZVt+MF1OK5MXOVAchvIHo9VAoqQsSMM5hPdLbi0O9vYao+8VAADFm+CVEfKLebBc95hLCI3kxGszEo51F9GJJoThsxA6ieVfMRiu3eq1KKZ44cyYp8ZxtbCgqQi4h/DN9tr0dtxUW8sXFqmKoKCcHb9XW8u5W5ggq3nmZF5x0d0x7Fy+2XLzFRQYA3unttd3PdEImpZRMohDBiLFK0L2tygWB5J6GqroStNaH4b8jH/efWIh3tgc5KXaGjOWX3hoXj4i9NS48+LtFnCyr6kpQXVdiINRbNxej/e0BhJpjcPsccHoIDqy8yIeciIsZOw8Gc2I5MUjx3v6epM+MlXya0bgziGi3VSHxyF0FYO/2ORZMCZJn1RCsS9KpKPhDrxe/0JN2LDlKBCJu7e83/GKxjz1mun23glnCAJKjx4OC3YEo85hr5F8MBCxtEcZSr51ODhGRqgRTRDZH5K3xePAHJSW8pl0F8Njp03xxsasYYhU0f3NhRI9ls2THck5rPB68qS8c5mYocUKYmqLOfjohXSmlWIlTtjoP5avzkmSI47u0ksZodwLrdR2cDc92FSnoMDVIEWgE6yxS4HA4LCNfBibpOPKBBZ8p5FUwlFK4ix1YuaPM8N679lWCUso1eFZPbzX0xEyz5sSsHezsmKPdCdsh5Gw7k4+yhUlP8laj7OKqCn9uLtx6xQqg6bu3FBRwUj7Q2WmI5K0gTn3KFSI+IFmuyFTOMA/sYJUzAID2dl4f/2ZtLTdES3XtIlGJcogCTQ6xGzKSSQnmaCSdTOF3Gg2nVMBApFYVQ0cjEXzn8mXD+wZUdVzkaydBiRPC7MpSpxMyLaV0FSmG2bAiWuvDqKorQeDYANfcxclLzJqXLRBMVqmqK0GsR0XDjiDiPdbRr4jEAHD5N/1YtVP7eyKwX6DW7i5Pisqt6uvZeTAPHVbDf/+JhVyTN4PfORCSJGmt31uBYMMgX9RCzTH+uQUbBuEudmSV4IEpQPLmEj92G/+Q388baSiAf+no4HXnPxJKEpkLYYJSDOvvn6kPBVnj8eCgHvGx7s3W/v6MpBMrMFJm8svlaBTPmLpcWeVHuruJdL735npzK30+XQmmWdJ5LEUDVKYQS0IB7bM3E6lIwHZ1+tmYdWuFTMpSpxMy9YlftbMcqqomESoDpRT+O/LQ2RhFqynhWDg3F4sf1D5ntiBU15UgoJNhvt+BgUDCdhERMRxNcOmopT7MNXQWpbPyxysHr6K/3WiGwUYMsgauA2vOo6Mxira3+nF8Vwfm3TsDA4EhKE7CrQxcXgWxkPF3M6GqBodJcy7i/qMLuTEaAMNM3YmwOpj0JG/Wx8Xa561nzxpe+12d8MUmJuYF8/OuLr4gfPujj7AoLw+bKisN3ZuM8FINqbCTN6xIGdAqb5hGbQW7/VlZIzw5b55lvXmmZlvmYyVJOtAaoJ4PBPBFYUD5aMhwjceDt2ykrHTzaAmARW43/mru3AmdFSu7Xo3IdIAIIYSXK4pEXFVXAleRA9HuYZStdhsak1itPLM9IIQYtP/quhK0HxvAQCCBtrf6EWqO8YYoK4Sb4zw6r97ihdOjnWNXUxSvrLiA+08swMdv9nGJJK/cgYevLOVRucNN0NUUxYE7L6D8jnwMR1WEmmOovLsAoBQFc3K4tYJolVBS7QSIdvxTT/Xg1ieKsHJHRVIH62i6iLOFSU/yqUr83r161fBakeAJNKJmXjCp2v9FO1/A2sbg2bY2bp+rAknRs5mUv/3RRxhIJLBl9mz0Dg/j/YEBPncU0PT5VElaK2sEJs08OW8en1qVgLYoWckO4v7NCWR2LCbpMCdIipHBIrS9PaOpTFbfmdXimG4erVNR8OLNN3MJR0bb1w7pBoiIE5+So3mKy7/uQ0djFM4S0/DsYwP42YYLGOrVjM2SErx6lMukHUCzOihd6YIaN1ojiPo2MCIlrfj7BCdxprc78jV5Z9EDhXhnexDz79MG1eTOJPDVajmFDmGwNwHQsr8bpavc8NW6ONEDmvXBgs8UYuWOMry84jxCTTF0HtfOQ5S6VFU1dLRm0kWcDUx6kgesScNsFXCXx4PjfX1cyvhDrxd+ITFpbv8XpxOZ54OKM1y/dekSeoaHub8Kg3kREMlKIQQ/79KSPf/W3Y1nli7FXLcbhyMRvv/Q0FBKl0xxcbPyQW/t7+eeN0MAWvv7U1oPiEZs4rGYfMES20MC2QOpfdtHA7trtVrER1MqKjHxEG2J297qT6odZ5YEABAPG+9aOxpHJI+Xbj+nRcwCDm1tw/q9lVi3x2+4O/CvKUiSbcyWxEx7Z74zhqqYAc3kjBDCa9rvP7EAiqKAUmrYN/tZ9JwXEe1KYKhXsz148OQiHNkWQEt9mEsyotQ12tm52cCUIHkrmCPAf1i4EACSSJHVzW+qrMS5wUEu6ey/cgWf9fmSiMabm4vQ0JBhH1Zii9VMVbaPn3d1Geq0D3R2amPpLGxuU1nfMmKzmhNr7tI80NmZpDWbFy8GFvmL0fIPbroJtxUW8rsV0S7Yzrd9NEhl82texMUFgXUGi575Msq/tjDX0gPa4A+zbGOHwgU5mDEbvIkKACd+bYEgSTXwZ3/aA0Aj6vZDg+g5E0NiQKtb/3LfJ7j23vZWP+bdOwNDkWSrYuZiKXrIv7LmPPouWktB6/dq8kvb2wOGhKvoWwMk18CLEfpoZ+dmA1OW5O1knDUe++EQrMkpVXTKyv1Eq1/z12NX3sfIypubayD5jaWltuebqpRSrH4x32HkmzL0tTNmWEa/b9TU4KEPPsBZwcmRWT6IUs4flJTgV+EwhinlJmD/Ggppnu9pvgu7aVfiNrvrt9qHeXH6bXc3/qOnB08vWYKqggIZ5U8gWF07IyXxcSrPGSsw6wNXcQ5W7ig1RNpfCN6EI9uDhiStt8YJgCDUHMNgUEVJdS7aDw1q9e7lDiiuBIa6Kd75WgfW7i7Hxwf70NUUxUBgCAOBhK3FMfv7PbS1nUs0JTVOzLqrgNsmAMBbmz+Gw+FIqqjpaorqbpYKYj1qEh8cWHMeG48u5J8T++zEPAT7LKVcM0pkUsYoRo12263kAbEmnQL4s7IydA4NZWQCZmcaNtrOUvPov98vLsbG0lJ+h5ED4HbdrTE0NGQrh/zV3Lnccx4AKp1OzaVTkHJEv3ZQigGhM9Wqxj7VyEQgeaQfOxera7Vykdy7eDEOdHbit/ps22G9oetLfr+c7jRBaNwZ5MZarCLk8NZ2BBoGMfeeAsQjxuW+tT6M4qpcdLdazxcmhOBOXcN/YZZxetMrKy5g4/H5hjuBB3+3GADw0vJzCDXFEG7R9st8Y+KRBCr/R4GhmSl/lgMzZuViIJBAqClmaIRiEM3Byla7MRxVEW6O86Sqt8aFwc5hnHo6gtKVLrjLFUSFISa+WhcCxwZAAV4iWl1XAqp/BsGGQbyy5jzK9c+NEIKGHUFcfK0P8++bgdW7/BNiMcwwpUneDqmifKvtVnoxAENN+i0FBWnr2kVsqqy0XQwylRus5sSK5+oA8FmfD5sqK3E0EjE0+oiNUlZzV+084FmJ6sbSUkNXrt3kK0UvTzV3G4+GiK1cJN3BIPYuXoz/6Onh3jYsryCnO2UforEWm+wk6tOJmIpQU4yXLLLad0bw5qQo9Pd+/NZVTqbMU97lVdDVFMUPC43Ef2R7UKtvP7HQ0LD0ucZ5eHXVJc2N0hQJ55Xm4HPvLMCLc09joC3B7RC8NS6tOakrgYG2kRr8+48uAqXUcFdRcVc+CDQztL7LQ0kEz4aOV20uBoGWZ2gRdHwA3JCMOVRefK2P3xGs3KFOiMUww7QkecA+QrbabhfhW2no48Vokop2i5LYbHU5GsWzbW286odCK4XcfOYMgBH/mIf8fnzW58NJXW8XPeBZJ7HZi92unlwkZUq1Oa1it7F4jnafnZU8w0YjUoxMhXp6yRI8dvo0VIA3rI13Tq2EBrN2vJbp7qY6d1YiOetuNWn6EaARqsM1Qlo5BQTD/dqCHG6OI69CQTxCMWO+AzMX5vLKlUSUwpEHLPtyMYINUbTsC+H0/+nG0FXjHcOLlWdx81c8oKBJckzFujwQQrDofo/hnJnBmbfWZSD5Q1vbYBZg39vfjarNxajaXGyQbwBwgi9bnYf1eietwb9H19sbd3ZAjVHDXQazQxZLPidCnydmm8vriRUrVtATJ05c79OwRCa6cjbwrUuX8HcXLvBI/JsLFozqDgEQyjmvXuVRtLm7lwAGt0UXIahfsiRJWhHLFXuGh9F09WpaScq8UFl576T67MRcAzNlAzQLBNEd8mBtLQBYTv4yfx5j9dOfrrCbWOT0EMNYPQB4TL2F2/Wy6hSx2UdEVV0x1ISKU0+PlAvf8riHP7aK+LX3leDjN3vR3ToMYGRiE2tgcvscWPT5GTj11Mh+S1e60Hk8xrV/M0Ezjb50lQu954YMTU2KC1BjI3cX6fCYegsadgRx6fWrSUnZefcWYKgXafMV7HMcCwghJymlK6yem7aRPMN4xsKNtmlGPBYAy4ag8Q6TZk6Kos0DkJwcFQke0GrfQ0NDtjKW6B3DSk1TdYaunDED56NR/Gl5ue0s2FS5BrHT9vEzZ/AXgqUEAfBF/TP71qVL3IjOKjfwbFtbVmbcTieIJZGA0V7YV+tKer3mP+NAPKJaDq4W0fnuIHo+MGr0p56OIL/SgUUbZyYRMQOLwpl7ZLQrwSUbt88Bzydy8OGPjIZyvee143zwfA+G+6lBWgEAh5Ogqq4YVw72IxZSDd2rjOAfbl+Co/pQ71R45Y5ziJyLIxZSeXftj/2nOeFvPD6fl5cymBeQiWqKmtYkfy3rrc3JQ4oRO+LnAwEegaarMmH7SmVFYFfWyeAA8LU5c7D344+TnDLtyPdAZ6fh8XPt7Wjt77eM+u96910M668Tu4czhZVRGGCUeJiPULpF0XzeY5lxO91gZy9s0J+FmvHW+jCPitveuoouQZs3E1nn8Zgmw+hDshkScWroa7HDIx9/Ag07gjj5zZG7if/x8UL8P7POcQmoqq4YbW+NJFfZ9i6LyhqqUoRb4sgrd2AwaIzYHwks5XcxIsRrKlvlRiKmcolJccHQdKW4gJxC4OhfdiZV5YgWChNhMcwwrUk+VbORHcYq0YjHMiczh3SvGnNJod3xRZtc8zASkfSYRCPKNey4RTk5tk6ZVtdobhardDq5fi9+dgd7ejjBMzBiHc1dEzMKS+ia/m2FhZZae7pFcbwzbqcrrEoi5983Ew6XsboGAK+uyXEpPCkrNkQ58gkSAyORNHHAQPAAUDg/B+dfTvb4N+PtLW0ImEYM/r+zz/NIfMmfegzNV/mzHBi4MkLeohzU0Rjl5LzowZlJHvUvzDqNfL8DoeY4TyQ73Bo5O9xAIgr0XRrCYFArz+xvG0K0wzQLOQaU3pavd9Ia7yTcPgfm3VtgmB07EU1R05rkRyuNjCfyN7tPipF8DmCwSU61XzuPewaR9Jh/DYVG8g49KrHzYbe7RkBL0OYQgmFd+/4Drxe/6e5GTFVBCOHVOhuKipADGIh+Y2npqD87Fm0zl8wnTp/GbcLwbhGpFsXxzridrrDyWIlHVHzunQUAwCPcdXqDECEE0e42TvIAMNCu/Rbc/EUPCCFciqEWEnfXCa3Cxk4Ld/sULPr8CBGLzzNN/s+vLMKxvzLmCxZ9zigBKa5kj/jSVW68/6yR4B1ugsFgQiPwGiceOLkILy8/zxeIhB6UDwYTfGD48r/z4Znc/7T8LIf06VeA8S5oqHckwS1tDSYAmUgjIsYS+dsdCxjR5AGM2kws3bGYdPJCMDiq4SMvBgJcz2d+92YTNVXX7/cuXsxJeOvZs7xR7O3bbsO3L19GWzyOL1VUYFNlpW0DWiqEhoag6oljFUBjXx9vIhPJOt0dQqpyVYlkpLIXDhwbgH91HpxFWkUM0+BzZ5KkCHswmEBJtRPr91XaulOa4fY6QFVtNiyDIx+IdmnluGWr3Dx6FhHtSuCfXafNu0OrXhkTaBhEZ2MUnY0xqDHjXUTvuTjUmEbsf9F3Ew6svMjNylwlCkLNcUPJphldTVEoLqD1aWvdXrxDqKorGbkL0m0OzNOyso1pTfLA6JKn402Kmo8lyiMiGafabyqPe6vjZbqIscErz+mRP6BF/oF4PMklU9Ejd5GEzQ1WP6uqMrxnLJ+duXSSQdTVpY9N9mHnsUIpRUfDoMHClyUTWWRtliTCLXHLwdxM7jBjoC2BW54owindcgAAbvqCB+8/HbFNyppRVVcMp0dB0/fCSAxQYySfB62eXoCYdGWRuK/Wjbmfzscd36iwrRRi8Na4MBxVEQupSbkGdmfCwJqhAG1gd7a9460gSyhHiYnyRcn2AO7RHJN1pYoVOQTAV/Q6+X8SPO8JRhw89y5ebFlyOdbztip1PBqJ4NuXLxs6bp9ZupQ/n42SUwlr2I3qE50TRfhqXfCvz0/SthmqNhfj3Ku9iIVVJAappRc7gKTtvloXkEO5pMNgV27prXGi4q4C2/MwHMunINalcldKhq8O34x3tge5pz2DXUll6So3+s4PGZ6zuj4WyTPP+2x1uMoSyiwiVev9eIh3NHcUoy3dtIIYARNTZyubTgVoPjZO/c5BwUgilzUj2d0pWH0eqc7bXOp4bnAQ/7hoEb8rsKt1H+/dlYQ97OyF7TxqGMH7at3YeHw+fuw/bSC5tkMDGLiSgLfGhYq78hFqjqH9baPEw4jRW+tC5fp8nH25F11NMTjcxnNx5BMg1xig5lVo3jGh5nhStC7um0H0skkYTwOvrDjP70i8NS7Mv28GLr3ez2UcMVr31box71MzQCnFyW+OfC5L/0xLAudXOpBfloOuphha9aHigUMD6GqKTUiHqxkyks8CJqNkIEbACsBLFnMIwerCQhzp7QXFSMRudt40X6dI6q39/YYRepl8Hvc0NxuqYBQAh2+7LaPPUbpOXjuIer0ZZavcSMSpwd7ATIgsEq6qK4GqqgZZBtCGeOT5HdzqALCXdrINs9SU53cgr8yBcEsc1Vu8WPPdUrxQcYaXPt5/YgEfMC561TDkz8qB26dg1t0zDGWmI8fTyiezIdnISH6CMZ6E7PWCOQIWiVzsLI3pETuTQKwaoMzDR4Z0nZ69P5PPw1zqSIGMP8ds3NlIpIdI8CwqZmTu8iroaIyianMxZt1VMOJpYyqVXPZVD4Z6jWTorXXBvy4Pp57q4RUtInKLCBKBiQ9Gy9a6DSR/y6ZizZZD6U+yI5h3bwFOfrMLlFJtfq0u62iVNoWI9WgDuweuALPuoiNzXwVki+DTYeKPMA3ACNOBZB/5GxUsKfvNBQvwRk0Nqgq0YQ2/CocNnbAEI97y37p0CQDw5Lx5tl41MYHgxfenw6bKSnx9zhwo+nvck+RznE4ghMDpIcgrd2iSSo0L959YAG+NC7GQirxyB1zFDj7NyQr/+cMIVFMi3b8uD3klubhVtx8wY6jXcjPyyh1jvhYRZavd8K5w4n3BagEALrzWh8u/6bdsYopHKKLdCbTu70bw2ADm3lPAF7x4RLODqKorQfnqPLTu77bsmD2yPZjUaDURGJdcQwj5DoB7AcQBnAPwBUppj/7ckwC+BK17vo5S+pt0+5uscg0wuSUDMRIHjHYHzBs/lRyV8v0+H352662jOpdrnYCWyByUUsMoPhFs+IbZoIxp9AdWXrDsOgW0pGxCVQ1Ea7b0FeH2OZA/jyB80tx6Z4Sd1FO+zo3gO1HAtHuSA3wlejPX5K3kI+abw/zuRYgVSYxbrapz2IKQLVOyiZRrfgvgSUrpMCHkHwE8CeCvCSHLAHwewC0AKgH8OyFkKaVWbRBTA5NZMhAjcQValQpzdfz63LlJtfNmGUUs1fTm5qLuzBnekfv1OXNGdS7pun1Zb8FthYWjquyRyA4IIVoZIIxj8KrrSrBWIHjNmGsGN+w6sPIi5n66wJbkr7zdz4mUdcjaETygRdPRLtunOey0/ODhERsCscSRDiOpJj5sSuKKvjnmxiozYR/a2m54762bi6HoIwd9tW44PRM39o9hXCRPKf034eExAPfrP38GwE8opTEAFwghZwGsAnB0PMebrphoF0WzPr951izuNgkAPwoEeOWN3VBwkZxTGZeNNfo+Golgg27nAAAOvZ4/WzNmJVLDrpySPwaTcxQepVbeXYC5n87H1Y+HkiQPM0Qi9SzO4QNBsgIHgARAHMndtqr1mgNAI+RQcxQ0Ec/IiRIwToE6vC2A1vowylbnwb86Dyqlmm1xXQmq60rgLFKweld2B4RYIZuJ1y8C+Kn+8yxopM/wsb4tCYSQTQA2AcDcuXOzeDpTA9fCRdEcibMI+VAkgofLy7n9ApB0d2u7P7syUyvLBLELOJXxmvk8HBY+9RLZh2g7DACHtrQlNSaxaHb93gqs3FGaJNkw73S7EXwMJdVOhFusZ6xmgpwiYLjHtFHn53Q6glkeOvdKBPnluYZqGmZtzNBaH+aDQdgUqMNb27FubwW6mrRE7MZ3FnD5JnBoEKHmKD775oIJj+AZ0pI8IeTfAVi1Vf4tpfQX+mv+Fppdyb+M9gQopc8CeBbQNPnRvn8q42gkgu9cvmzYNlEuioyYzfYDAIyOkECSmVqmMFchvRgI8E7fHN3Px86/Z0NREXIJ4ZF8DoCnlixJa9MgMT6YbYfX7i7H2Ze1TKi31oUHTy7CkW0BtNSHedMQM9wSSZ4RIyP4W58oAiGE2wAzmImvpMaZJJekQhLBp4JpyIJZHhpsV1Ewi6KkxmlwlnT5FNzy1SJ88M8RDAYTfIFjnjSuYi0h7KvNQ8u+EI5sD/JcBdPhGZgHv93jbCAtyVNKfz/V84SQRwB8GsAn6cg93BUAohg7W98mkSFY1Bs1VSJMtIuiWbp5yO/HzJwcfPujjwBofxM/1KWS8Zi0OfVfZNGZk+3fquxyjceD/cIUKIUQ7pUjMXGwsx1mBC9OjGLkpqpqSk95tl8KGAgeQFIHa7g5Dm+NC4oTCL8XQ2IQydDlmEzBO2XFQ5sIn9Xz93w4hJkLcw3vL6jMQeBQFI+03WSwbGCeNGLTGGD83MRE6882nEc8ovJSSlVV8fLy83B6FPzxwYWZX1AajGvJIIR8CsDXAdxHKRV7xl4D8HlCiIsQsgDAEgCN4znWdIPoC08ALHa7De38EwVzaeUajwdFOTmGX5SE/k+c2TqWfT/k9/PSU+bMCWh3C+IMWobQkKbTUmiDu0dzbImxQyR6hgdPLsKJb3TilTXncWRbAGv3+LFyRxne3tKGF2Z9yM3NHk0sg6/WbXivt9aF1v3d3HbA5bWmoXy/tmhQqmo+9FYED4yK4AFtIcmvNJZf1j5pLN98JLAUyx73IDefJN1JhFviiPUMJyVVzSZsVp8bI3hVVRGPqOhqiuLl5ec5wbMSTHOZ6XgwXk3+KQAuAL/VV69jlNKvUkpPEUJeAvA+NBnn8alcWTMRMEe9L9588zWLWs2a+oaiIj7P1iyrjNek7Y2aGrwYCOCfTf44jNBFSAuD6wMr2+HD2wKAbljGZBqKEcdFX60Ld36vjEsUbp8DtzxajKFemtQt+0hgaZJFr+hLE24ZgiOPIDFor+Z6VzgROpG5rJNXmmOY7dr8j8Ycw8vLz6PirjwUznNiMGiVNCZ4b383j8wPbW03DP1gsPrc1u3xQ1EUPHByISd2dkeQzS5YfqbS1uDGxY1UB24eXZjN8/rWpUv42wsXeCSfSwjespjVaj6P6/2ZTAeksh2uqisBKE1KwrJySkVR8Ord59D9vladwqwBflj4oaET1kzgdsZjqWC2Txgrbt1chLa3B3j0XrrKjfLVeUl2waHmKHy1eVi3x4/juzoQ606AAnAXO7ByRxkObW1HR8Mggg2DSZ+bKNmoqmqQfB5NLBsTwUtbg0mKG6n23s4mORvw5uYa5NFts2fb7v9G+kymA+xshwFtitHKHWVJJL9Ot9OllKL0tny0v61VmYjatMNN8KXepTiw8iIn9LJVbpTfkW/ZaJWTTzA8YCRxZwlBPKxty4TgzQ6S5qRu6UoX3tvfwx/nFhKUr3bjzP82dsKe+WkPvtD2Ca69x3pU7l+zckeZoXSyWm8QM39ujOBfXn7esO+Xl5/PeiQvbQ0krjtCQ0P8F5EA6B1O3cUocW2xame5ocmHERaLWM04vLXdMO2oeos3qU4+EaU49pedmH/fDLh9mj7e0Rg1EHxJjZP/bCZ4AFj6Z0WW53vL48lBQJ5fG8otIsdtpD//mgLD45se8eC9/T2IhVS4fQ5uuxANqnhp+bmka2ypD+P7yikerd9/dCFf8ICRz23VznKDBu+rdfPchajRZwtSrpG47mBza9lwEichfLC5xI0Js72B2YWxuq6EE5xZkgC0pOqAMP3J3DlapsskdoNCWFdsJkhVhsmcJ9PV7/Pz3FyMtkMDcHkcvAKGUgpK6ahll2xW10i5RuKGxhqPB1/w+/GMXpqZ0CtnJMnfuCCEwF3s4N2coilZR8MgXMUOEEKQSCTwyooLhvdaae5tb/UbHidiyVo/oEXpgcNR/n4lD1AHrYd5lK1yo6MxmkTweeUO7nTZ1RRD1eZiUGg1/GWr87DxnQWW06wAYP2+St2ZUiPwxp1BXPpVHxJx44Lz41kf4pZNJSk7Wv/44EJDXTxLxma7Tl7KNRI3BB7y++GeZE6e0x2rdpYbJAnma7Px6EKs2lmOY38fwCsrLnBJ4itDn0Ce34FQcwxun5F6Qs0xlFQ78WhiGarrSmwTr6eejiDUrBmHMYIHRoZ5izATL0O+3xjbuoodOP9qH7w1TnzuyPyU82gPbwtw+YVSimh4GB2NUYT0u4EqXdIZDCRw4bXetLKLmdAnwnpYRvISNwRGO1Rd4saA3fSohh0Bbk7GXChfWXGBD+iOdqmo2lxsjNb1Xa3bW4HAsQHLgd0MD19ZiiPbAob3s0j+1s3FIISgtT6cFOFb3UVc+EUfBq4MY+AK8MLs04Yh4gxlq9zw35FvKJMkhGD9vkoEGwY50TPJx1vrwoL7Cq+JX3w6SJKXuGEgK2emBiiliEcoJ/iupiivg2fdq53HY0lyTLg5jiPbAli3twLld+SjozG5yobBrqO2anMxl1QAzX/GdHYAgPLVedh4dCEva2TkLxJ82So3EjGqLQqss1evNhKTqfcfW5RkJ/zgyUU3BMEDMvEqISExAbAbE/hoYhkAJCUpD21ttxy8XbrSBXVoxPOmanMxzr7UyyN8892A5u7oQKwnAaq7PprhrXHiwd8thqIo/DydHgUnvtFpeS1s+DYrCzW7cVr564uJ52uBVInXG2OpkZCQmFIghGDt7uSk4+FtARwxad5Htgexfm8Fd3NkqNpcDP+aAoPeHWwY5ARvNRmq/Wg/4vrovXOCkZr4v8M98j52nrFu+7Ld9aYySAarCiN2DS31YV5Ker0h5RoJCYmsw6rRx1vjMhCiOGQElGr/BBBCkCv407No3lfrAnIouk7EeRQvdt/61xQYZqqGmmIjx9sWQGfTIJeFAM06+T19oHhVXQna3uo36PaHtrYbiF48v0wqjK43JMlLSEhkFZRS7lnDvFgYmeeVO1A438mljHV7/AClfBC22QKAEbyILp20u06MSCTr91agcWcHfLVuuIoUrNpZbphcxYaa5HoUDPVqHarBhkF87p0FOPdKHwBtEaJU0+C9NS449Gap1vowP1czaa/aWY6VO8oAjET5ZjfK6w1J8hISElmFaIWwdnc595cHAKeHYNXOcmMX6N4KHN/VAf8d+UkWAE6P9jqR6H21Lm5NzXBoazuI/rqKu/Jx2NSJ21of1urbCeEjCIMNgzw34K114YETC3Hym138vNk5Ht4WMCRbra431ePrDZl4lZCQmBBYJSlTEaD5eeZLb07eMrCEaCrDNHFqUyqIHaqjPe8bATLxKiEhcc0x2gjX/LyiKHB6SJIffb7fgdJVbq6TM+8Yd7ED6/cZ5y2s31uB9XsrUG1K6ppxZHuQJ0lv9Mh8tJAkLyEhcUNCrLev3uLFY+otqN7ixUAggYo78vnrRMM0K/92SilS6RXMIZO9dqpBavISEhI3JNLZHJsjbDvf+7a3+tHVFOUzWFlC9tbNxVAIQUt9GL5aN5weMumjditIkpeQkLhhsWpnuUETt6tySbUgdDWNVO0c39WB6roSqJQiryRHq4whBE6PktJMbDJDJl4lJCSmDOySpuJ2s/Y+GRKr6SCthiUkJKYF7JKm4vapllhNB5l4lZCQkJjCkCQvISEhMYVxQ2nyhJBOAJfGsQsfgK4snc6Nhql8bcDUvj55bZMTk+na5lFKS62euKFIfrwghJywSz5MdkzlawOm9vXJa5ucmCrXJuUaCQkJiSkMSfISEhISUxhTjeSfvd4nMIGYytcGTO3rk9c2OTElrm1KafISEhISEkZMtUheQkJCQkLAlCF5QshmQsh/EkJOEUK+LWx/khBylhDyISHknut5juMBIeRrhBBKCPHpjwkhpF6/thZCyO3X+xxHC0LId/TvrIUQ8jNCSJHw3KT/3gghn9LP/ywh5H9e7/MZDwghcwghbxJC3tf/xrbo20sIIb8lhJzR/y++3uc6VhBCHISQdwkh/6o/XkAIadC/v58SQpzX+xzHgilB8oSQ3wPwGQA1lNJbAHxX374MwOcB3ALgUwC+TwhJnv57g4MQMgfAfwNwWdj8BwCW6P82AfjBdTi18eK3AG6llFYDOA3gSWBqfG/6+T4N7XtaBuC/69c1WTEM4GuU0mUA7gDwuH49/xPAG5TSJQDe0B9PVmwB8IHw+B8B7KGULgbQDeBL1+WsxokpQfIAHgXwD5TSGABQSjv07Z8B8BNKaYxSegHAWQCrrtM5jgd7AHwdMNhifwbAi1TDMQBFhJAKy3ffoKCU/huldFh/eAzAbP3nqfC9rQJwllJ6nlIaB/ATaNc1KUEpbaeU/k7/uQ8aGc6Cdk0v6C97AcBnr8sJjhOEkNkA/gjAD/XHBMB/AfCK/pJJe21TheSXAliv31q9RQhZqW+fBeAj4XUf69smDQghnwFwhVLabHpq0l+bCV8E8Cv956lwbVPhGixBCJkP4DYADQDKKaVsoGoAwGT1690LLZBS9cdeAD1CEDJpv79J40JJCPl3AH6Lp/4W2nWUQLuNXAngJULIwmt4euNCmmv7G2hSzaREqmujlP5Cf83fQpMD/uVanpvE6EEImQHgAICtlNJek60vJYRMunI9QsinAXRQSk8SQjZc59PJOiYNyVNKf9/uOULIowBepVo9aCMhRIXmO3EFwBzhpbP1bTcU7K6NEFIFYAGAZv2PaTaA3xFCVmGSXxsDIeQRAJ8G8Ek6Us87Ka4tDabCNRhACMmFRvD/Qil9Vd8cJIRUUErbdbmww34PNyzWAriPEPKHANwAZgLYB00CzdGj+Un7/U0VuebnAH4PAAghSwE4oRkLvQbg84QQFyFkAbQkZeP1OsnRglLaSikto5TOp5TOh3bLeDulNADt2h7Sq2zuABARbpsnBQghn4J2i3wfpXRAeGpSf286jgNYoldoOKElkl+7zuc0Zuga9XMAPqCU7haeeg3Aw/rPDwP4xbU+t/GCUvokpXS2/jf2eQD/QSn9MwBvArhff9mkvDZgEkXyafA8gOcJIe8BiAN4WI8KTxFCXgLwPjQ54HFKaeI6nmc28UsAfwgtKTkA4AvX93TGhKcAuAD8Vr9TOUYp/SqldNJ/b5TSYULIEwB+A8AB4HlK6anrfFrjwVoAfw6glRDSpG/7GwD/AE0e/RI0B9kHr8/pTQj+GsBPCCH/C8C70Ba5SQfZ8SohISExhTFV5BoJCQkJCQtIkpeQkJCYwpAkLyEhITGFIUleQkJCYgpDkryEhITEFIYkeQkJCYkpDEnyEhISElMYkuQlJCQkpjD+fzqpsgq7yAj9AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cluster_and_visualize(male + female, extract_vectors(male + female, glove_limit, glove_w2i_limit), \n",
    "                          'GloVe', random_state, tsne_random_state, y_true)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 0.741\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cluster_and_visualize(male + female, extract_vectors(male + female, dhd_limit, dhd_w2i_limit), \n",
    "                          'Double-Hard-GloVe', random_state, tsne_random_state, y_true)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 0.722\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cluster_and_visualize(male + female, extract_vectors(male + female, null_limit, null_w2i_limit), \n",
    "                          'Double-Hard-Null It Out GloVe', random_state, tsne_random_state, y_true)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Cluster originally top biased words\n",
    "Following results may be slightly different from the numbers reported in the paper. This is due to:\n",
    "\n",
    "1. how we select top biased words. Here, we select ones with largest similarities with **he** and **she** without normalizing embeddings, however, this may not be the perfect way. Other options can be:\n",
    "    - normalize word embeddings first and then pick top biased words.\n",
    "    - select according to projections on the difference vector of **he** and **she**.\n",
    "2. different random state used in the clustering algorithm.\n",
    "\n",
    "We care more about the relative clustering acc change and we see significant decrease with Double-Hard Debiased embeddings."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def cluster(words, X1, random_state, y_true, num=2):\n",
    "    \n",
    "    kmeans_1 = KMeans(n_clusters=num, random_state=random_state).fit(X1)\n",
    "    y_pred_1 = kmeans_1.predict(X1)\n",
    "    correct = [1 if item1 == item2 else 0 for (item1,item2) in zip(y_true, y_pred_1) ]\n",
    "    print('precision', max(sum(correct)/float(len(correct)), 1 - sum(correct)/float(len(correct))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Cluster most biased words before and after debiasing\n",
    "\n",
    "def my_cluster(wv, w2i, start=0, size=500, random_state = 1):\n",
    "    \n",
    "    if start == 0:\n",
    "        female = [item[0] for item in sorted_g[:size]]\n",
    "        male = [item[0] for item in sorted_g[-size:]]\n",
    "    else:\n",
    "        female = [item[0] for item in sorted_g[start:size+start]]\n",
    "        male = [item[0] for item in sorted_g[-(start+size):-start]]\n",
    "\n",
    "    y_true = [1]*size + [0]*size\n",
    "    \n",
    "    cluster(male + female, extract_vectors(male + female, wv, w2i), random_state, y_true)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 1.0\n",
      "precision 0.665\n",
      "precision 0.5900000000000001\n"
     ]
    }
   ],
   "source": [
    "random_state_=0\n",
    "start=0\n",
    "end=100\n",
    "my_cluster(glove_limit, glove_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(dhd_limit, dhd_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(null_limit, null_w2i_limit, start, end, random_state=random_state_)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 1.0\n",
      "precision 0.741\n",
      "precision 0.722\n"
     ]
    }
   ],
   "source": [
    "random_state_=0\n",
    "start=0\n",
    "end=500\n",
    "my_cluster(glove_limit, glove_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(dhd_limit, dhd_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(null_limit, null_w2i_limit, start, end, random_state=random_state_)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "precision 1.0\n",
      "precision 0.704\n",
      "precision 0.701\n"
     ]
    }
   ],
   "source": [
    "random_state_= 0\n",
    "start=0\n",
    "end=1000\n",
    "my_cluster(glove_limit, glove_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(dhd_limit, dhd_w2i_limit, start, end, random_state=random_state_)\n",
    "my_cluster(null_limit, null_w2i_limit, start, end, random_state=random_state_)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Classification experiment\n",
    "\n",
    "We also test classification experiment as described in [Lipstick on a Pig](https://arxiv.org/abs/1903.03862). However, we don't see any significant improvement on any debiasing approaches. We suspect that classification may not reflect gender bia correctly as it can always find a decision boundary with supervisions which may not be gender. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn import svm\n",
    "from random import shuffle\n",
    "import random\n",
    "from utils import train_and_predict\n",
    "\n",
    "def cls(wv, w2i, vocab, size_train, size_test):\n",
    "    size = size_train + size_test\n",
    "    females = [item[0] for item in sorted_g[:size]]\n",
    "    males = [item[0] for item in sorted_g[-size:]]\n",
    "    males.reverse()\n",
    "\n",
    "    shuffle(females)\n",
    "    shuffle(males)\n",
    "\n",
    "    train_and_predict(wv, w2i, vocab, size_train, size_test, males, females)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "accuracy: 1.0\n",
      "accuracy: 0.929\n",
      "accuracy: 0.701\n"
     ]
    }
   ],
   "source": [
    "size_train=100\n",
    "size_test=1000\n",
    "cls(glove_limit, glove_w2i_limit, glove_vocab_limit, size_train, size_test)\n",
    "cls(dhd_limit, dhd_w2i_limit, dhd_vocab_limit, size_train, size_test)\n",
    "cls(null_limit, null_w2i_limit, null_vocab_limit, size_train, size_test)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Association Experiments (Calisken et al.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['john', 'paul', 'mike', 'kevin', 'steve', 'greg', 'jeff', 'tom']\n",
      "['amy', 'joan', 'lisa', 'sarah', 'diana', 'kate', 'ann', 'donna']\n",
      "['science', 'technology', 'physics', 'chemistry', 'einstein', 'nasa', 'experiment', 'astronomy']\n",
      "['poetry', 'art', 'shakespeare', 'dance', 'literature', 'novel', 'symphony', 'drama']\n"
     ]
    }
   ],
   "source": [
    "from utils import p_value_exhust, effect_size\n",
    "from utils import WEAT_words\n",
    "\n",
    "A = WEAT_words['A']\n",
    "B = WEAT_words['B']\n",
    "C = WEAT_words['C']\n",
    "D = WEAT_words['D']\n",
    "C = WEAT_words['E']\n",
    "D = WEAT_words['F']\n",
    "C = WEAT_words['G']\n",
    "D = WEAT_words['H']\n",
    "\n",
    "A = [elem.lower() for elem in A]\n",
    "A = ['john', 'paul', 'mike', 'kevin', 'steve', 'greg', 'jeff', 'tom']\n",
    "B = [elem.lower() for elem in B]\n",
    "B = ['amy', 'joan', 'lisa', 'sarah', 'diana', 'kate', 'ann', 'donna']\n",
    "C = [elem.lower() for elem in C]\n",
    "D = [elem.lower() for elem in D]\n",
    "print(A)\n",
    "print(B)\n",
    "print(C)\n",
    "print(D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8793966839691493\n",
      "-0.1496392289350194\n",
      "0.13909625403038622\n"
     ]
    }
   ],
   "source": [
    "print(effect_size(A, B, C, D, glove, glove_w2i, vocab))\n",
    "print(effect_size(A, B, C, D, dhd_glove, dhd_glove_w2i, dhd_vocab))\n",
    "print(effect_size(A, B, C, D, null_glove, null_glove_w2i, null_vocab))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num of samples 12870\n",
      "0.03605283605283605\n",
      "num of samples 12870\n",
      "0.6142191142191142\n",
      "num of samples 12870\n",
      "0.39487179487179486\n"
     ]
    }
   ],
   "source": [
    "print(p_value_exhust(A, B, C, D, glove, glove_w2i, vocab))\n",
    "print(p_value_exhust(A, B, C, D, dhd_glove, dhd_glove_w2i, dhd_vocab))\n",
    "print(p_value_exhust(A, B, C, D, null_glove, null_glove_w2i, null_vocab))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
