{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3892bf3d-f575-49da-87f0-ff268b80f891",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c416f8a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "if os.path.isdir(\"../notebooks/\"):\n",
    "    os.chdir(\"../badseeds/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5db09a6a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import random\n",
    "import itertools\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import gensim.models as gm\n",
    "from tqdm import tqdm\n",
    "from gensim.models import KeyedVectors\n",
    "import seaborn as sns\n",
    "\n",
    "import replicate_bolukbasi, utils, seedbank, metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "203c5210",
   "metadata": {},
   "outputs": [],
   "source": [
    "# path to config json file containing paths to datasets. change if necessary\n",
    "CONFIG_PATH = \"../config.json\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "554e6eeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(CONFIG_PATH, \"r\") as f:\n",
    "    config = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "80c17f8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for replicability\n",
    "np.random.seed(42)\n",
    "random.seed(42)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e62bd0dd",
   "metadata": {},
   "source": [
    "## Models and Data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ebccc814",
   "metadata": {},
   "source": [
    "### Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0ef28ca0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "b'vectors_sample1.kv'\n",
      "b'vectors_sample13.kv'\n",
      "b'vectors_sample5.kv'\n",
      "b'vectors_sample17.kv'\n",
      "b'vectors_sample4.kv'\n",
      "b'vectors_sample16.kv'\n",
      "b'vectors_sample12.kv'\n",
      "b'vectors_sample19.kv'\n",
      "b'vectors_sample18.kv'\n",
      "b'vectors_sample9.kv'\n",
      "b'vectors_sample8.kv'\n",
      "b'vectors_sample7.kv'\n",
      "b'vectors_sample15.kv'\n",
      "b'vectors_sample3.kv'\n",
      "b'vectors_sample11.kv'\n",
      "b'vectors_sample2.kv'\n",
      "b'vectors_sample10.kv'\n",
      "b'vectors_sample6.kv'\n",
      "b'vectors_sample20.kv'\n",
      "b'vectors_sample14.kv'\n"
     ]
    }
   ],
   "source": [
    "models = []\n",
    "\n",
    "# load google news word2vec\n",
    "# Load vectors directly from the file\n",
    "# models.append(\n",
    "#     KeyedVectors.load_word2vec_format(\n",
    "#         os.path.join(\n",
    "#             config[\"models\"][\"dir_path\"], config[\"models\"][\"google_news_subpath\"]\n",
    "#         )\n",
    "#         + \".bin\",\n",
    "#         binary=True,\n",
    "#     )\n",
    "# )\n",
    "\n",
    "direct = os.fsencode(\n",
    "    os.path.join(config[\"models\"][\"dir_path\"], config[\"models\"][\"nyt_subpath\"][\"0\"])\n",
    ")\n",
    "\n",
    "for filename in os.listdir(direct):\n",
    "    print(filename)\n",
    "    f = os.path.join(direct, filename)\n",
    "\n",
    "    # checking if it is a file\n",
    "    if os.path.isfile(f):\n",
    "        f = os.fsdecode(f)\n",
    "        models.append(KeyedVectors.load(f))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8bdc6a09",
   "metadata": {},
   "source": [
    "### Seeds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6fec88df",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = seedbank.seedbanking(config[\"seeds\"][\"dir_path\"] + \"seeds.json\", index=\"ID\")\n",
    "\n",
    "seed_genres = [\"gender pairs\", \"social class pairs\", \"chinese-hispanic name pairs\"]\n",
    "\n",
    "seed_list = [\n",
    "    [\n",
    "        \"definitional_female-Bolukbasi_et_al_2016\",\n",
    "        \"definitional_male-Bolukbasi_et_al_2016\",\n",
    "    ],\n",
    "    [\n",
    "        \"upperclass-Kozlowski_et_al_2019\",\n",
    "        \"lowerclass-Kozlowski_et_al_2019\",\n",
    "    ],\n",
    "    [\n",
    "        \"names_chinese-Garg_et_al_2018\",\n",
    "        \"names_hispanic-Garg_et_al_2018\",\n",
    "    ],\n",
    "]\n",
    "\n",
    "# hard coded shuffled seeds from appendix of the oirginal paper\n",
    "\n",
    "shuffled_seeds = [\n",
    "    [\n",
    "        [\n",
    "            \"herself\",\n",
    "            \"woman\",\n",
    "            \"daughter\",\n",
    "            \"mary\",\n",
    "            \"her\",\n",
    "            \"girl\",\n",
    "            \"mother\",\n",
    "            \"she\",\n",
    "            \"female\",\n",
    "            \"gal\",\n",
    "        ],\n",
    "        [\n",
    "            \"man\",\n",
    "            \"his\",\n",
    "            \"he\",\n",
    "            \"son\",\n",
    "            \"guy\",\n",
    "            \"himself\",\n",
    "            \"father\",\n",
    "            \"boy\",\n",
    "            \"male\",\n",
    "            \"john\",\n",
    "        ],\n",
    "    ],\n",
    "    [\n",
    "        [\n",
    "            \"richer\",\n",
    "            \"opulent\",\n",
    "            \"luxury\",\n",
    "            \"affluent\",\n",
    "            \"rich\",\n",
    "            \"affluence\",\n",
    "            \"richest\",\n",
    "            \"expensive\",\n",
    "        ],\n",
    "        [\n",
    "            \"poorer\",\n",
    "            \"impoverished\",\n",
    "            \"poorest\",\n",
    "            \"cheap\",\n",
    "            \"needy\",\n",
    "            \"poverty\",\n",
    "            \"inexpensive\",\n",
    "            \"poor\",\n",
    "        ],\n",
    "    ],\n",
    "    [\n",
    "        [\n",
    "            \"tang\",\n",
    "            \"chang\",\n",
    "            \"chu\",\n",
    "            \"yang\",\n",
    "            \"wu\",\n",
    "            \"hong\",\n",
    "            \"huang\",\n",
    "            \"wong\",\n",
    "            \"hu\",\n",
    "            \"liu\",\n",
    "            \"lin\",\n",
    "            \"chen\",\n",
    "            \"liang\",\n",
    "            \"chung\",\n",
    "            \"li\",\n",
    "            \"ng\",\n",
    "            \"wang\",\n",
    "        ],\n",
    "        [\n",
    "            \"ruiz\",\n",
    "            \"rodriguez\",\n",
    "            \"diaz\",\n",
    "            \"perez\",\n",
    "            \"lopez\",\n",
    "            \"vargas\",\n",
    "            \"alvarez\",\n",
    "            \"garcia\",\n",
    "            \"cruz\",\n",
    "            \"torres\",\n",
    "            \"gonzalez\",\n",
    "            \"soto\",\n",
    "            \"martinez\",\n",
    "            \"medina\",\n",
    "            \"rivera\",\n",
    "            \"castillo\",\n",
    "            \"castro\",\n",
    "            \"mendoza\",\n",
    "            \"sanchez\",\n",
    "            \"gomez\",\n",
    "        ],\n",
    "    ],\n",
    "]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5683ae68",
   "metadata": {},
   "source": [
    "### Visualization and Function call"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9abbabb3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "random words: ['sleep' '4' 'even' 'print' 'served' 'huge' 'words' 'front' 'selection'\n",
      " 'important'] ['chosen' 'traded' 'camps' 'option' 'nearly' 'winter' 'profit' 'get'\n",
      " 'world' 'vote']\n",
      "random words: ['mark' 'blue' 'n.y' 'usual' 'city' 'panel' 'site' 'correction' 'neck'\n",
      " 'conversations'] ['finish' 'writer' 'estate' 'guard' 'auction' 'choice' 'pacific' 'rifle'\n",
      " 'by' 'protesters']\n",
      "random words: ['rousseff' 'services' 'ads' 'october' 'hear' 'particular' 'issues'\n",
      " 'google' 'trucks' 'merger'] ['27' 'close' 'side' 'changing' 'college' 'hits' 'zero' 'assault' 'worker'\n",
      " 'region']\n",
      "\"Key 'chu' not present\"\n",
      "\"Key 'chu' not present\"\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtAAAADFCAYAAAB908WdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA240lEQVR4nO3debxVdb3/8ddbNEk0R8oUEXJWIEEcyNRTamEY3hyuQ5bYwM0mm0zrFprZ/WmZV285xDXDbjmkWReVzExPmfeiIM7ggHgUNG+AioKiop/fH2ud4zqHc/Y8rXPez8djP85ew17rs/fZ772+a1ZEYGZmZmZmpVmn2QWYmZmZmeWJG9BmZmZmZmVwA9rMzMzMrAxuQJuZmZmZlcENaDMzMzOzMrgBbWZmZmZWBjegrRtJIWn7FqhjP0mPNLsOs1qT9AdJJ5Q4boekg8qc/og0x+tWVmHjSPq2pEubXYfVh6Qpkv5WYHjJWWgESW2SlhQYfomk7zayph7zHy5ppaRBzaqhVbTCZ9HyP7A2MEXE7cBOza7DrNYi4pBm19AqIuLfml2DNU/eshARn2vy/J8CNmxmDa2iFT4Lb4G2mmjk1q48bFkzs+o452ZWCSXq3r51AzoHJI2TdI+klyRdI+lqSWdlhh8q6V5JL0j6H0ljMsM6JH1D0v2SVqSvHZwZfoqkv0t6RtKnesx3fUnnSnpK0v+lu6/eng5rk7RE0qmSngV+0UvdUyTdIemn6bwflnRgZviJkhak72uRpH/JDOu2Ky19H6dKuh9YJWndtPvp9PWPZKdtVit9fc/SfJyfZueZ9Pn6mdcdlubyRUmPS5qY9m+X9Jn0+XaSbpW0XNIySb+WtEmJdb1d0o8lPZnm62+d+ewxXqGcbSHphvS34zlJt3cueErNl6QZ6W/Dn9Jx/yJp28zwCyQtTj+HuyXtlxl2hqRfpc87Dz35tKSngFslDZb0q/TzeUHSHEnvKuXzscaRtI2k6yQtTf9XP+0x/FxJz0t6QtIhmf7ZLExJv8N9jbuxpJ8rWV49LekspbvvJW2ffu9WpDm6OvO6ndPv5nPp9/ifS3g/X5f0j3ReJ2b6z1C67C2SnQ5J35I0P30vv1C63JW0afq6pemwGyQN6/GZfF/JsvMlSTdL2iId1u3wLEmbpdN+Jp3W7/t4P8U+20K/EZ3L+m9mPpN/kvQRSY+m7/3bmfHXkXSakt+85ZJ+I2mzPurqnPa30/9bh6SPZ4ZPUtL2eTH9DTkjM6znZ9Eu6QeS7gBeBt6Tvu9F6ft6IjvtmogIP1r4AbwNeBI4GVgPOBx4DTgrHT4W+AewNzAIOAHoANZPh3cAdwFbAZsBC4DPpcMmAv8HjAKGAFcAAWyfDv93YGb6uo2A64H/lw5rA9YA5wDrA2/vpfYp6ThfTWs/GlgBbJYOnwRsBwg4gORLPy4z/SWZaXUA9wLbAG8nObxjMbBVOnwEsF2z/19+9K9Hoe8ZcCYwG3gnMBT4H+D76bC90u/6wSQbKrYGdk6HtQOfSZ9vn46zfjqNvwLnZ+bfARzUR20XptPaOs3++9LpjEhzvG46XqGc/T/gkjSf6wH7peOVnC9gBvASsH86/wuAv2WGHw9sTnLI4NeBZ4HB6bAzgF9l5hHAL0l+j94O/AvJ784G6XvcA3hHs78XfnT7/w8C7iNZXgwBBgPvT4dNAV4HPpuOdxLwDKBeslBs3N8BP0vn8U6S5dq/pMOuBP41zVp2/kPS7/GJ6fdvLLAM2LWP99JGssw6M83DR9K8bJr5rncue3vNTjqsA3iQZHm1GXBH5nWbA0ek3+mNgGuA32dqaAceB3ZMM9AOnN0jI53ZvhG4Gtg0reGAPt5Xsc+22LJ4DTAtncdngaUk7YWNgN2AV4CR6fgnk/wuDiP5PfgZcGWRz/u8dNwDgFXATpnho9P/6xiS9so/9fFZtANPpfWsC2wMvJiZ1ruB3Wr63W92+Pwo8g9KFkpPd37R035/y4TxYtKFdmb4I51BSoN8fGbYD4FL0ueXdQYz7d4x/UJunwZpFZmFJjABeCJ93kbSkB9coPYp2ZCm/e4CPtHH+L8HTs5Mv2cD+lOZ7u1JVhwOAtZr9v/Jj/75KPQ9I1nIfSTT/WGgI33+M+Df+5hmO2mjoZdh/wTck+nuoJcGdLpAeQV4by/Dui1YehmezdmZwH+TrjSX8r57md4M4KpM94bAG8A2fYz/fGfd9N6Afk9m3E+RrJiMafZ3wY8+//8TSBpUa33f0mXAwkz3Bun/eMu0uysLhcYF3gW8SmZDDXAscFv6/JfAdGBYj/kfDdzeo9/PgNP7eC9taa7WzfT7B7BP+nwGby17e81OOqyDdENV2v0R4PE+5rk78Hymux34Tqb788BN6fOubJM0CN8kbdwX+R8V/D/0Mn72N6LzMxmUdm+UvnbvzPh381bDdgFwYGbYu0ka7719P9pIGtBDMv1+A3y3j7rOJ/1dpfcG9JmZcYcAL5CsrKy1ga8WDx/C0fq2Ap6O9BuRWpx5vi3w9XQ30guSXiBZ690qM86zmecv89aB91v1mNaTmedDSUJ2d2a6N6X9Oy2NiNVF6u9Z+5OdtUk6RNLsdBfQCyQ/MlsUmFZXrRGxEPgKyQL4H5KukrRVH68zq0iR79lWdM9M13ebJIOPF5u+pHel03xa0ovAryicgU5bkGxpK2UehXL2I2AhcHO6q/M0qChf2WyuBJ7jrZx/I909vCKd/8ZF3mP2N+m/gD8CV6W7qX8oab1i79kaahvgyYhY08fwruVPRLycPu3r5K++xt2WZOvn3zPLo5+RbIkG+CbJRp+7JD2ktw5H3BbYu8fy8ePAlnrrKg4rJa3M1LC8x3vJLjOzes1ORs9la2ceNpD0MyWHXr1IstdpE3W/mkRfy+ysbYDnIuL5Xob1ps//QwnL4uUR8Ub6/JX07/9lhr+SqXFb4HeZz3sByQp1X4dePR8RqzLd2c9qb0m3pYe7rAA+R+lthFUkK1CfI/ne3Chp5wKvLZsb0K3v78DWkpTpt03m+WLgBxGxSeaxQURcWeK0s9Mannm+jCQUu2Wmu3FEZIOcbRj3pWftw4FnlBwr+lvgXOBdEbEJMIvkR7Av3eYXEVdExPtJAhskh5OY1VSB79kzab9Ow9N+kORyuxIm/2/pNEdHxDtIDncolIFOy4DVxeZRLGcR8VJEfD0i3gNMBr6m9FjnMvPV9TsiaUOS3dbPKDne+ZvAP5NsKduE5NCWknIeEa9HxPciYleSQ1QOBT5Z6D1bwy0Ghqu+J30uJtkCvUVmefSOiNgNICKejYjPRsRWJIf9XKTkcqyLgb/0WD5uGBEnRcRT6fMNeyzXSlIoO6mey9bO34avkxwitXea+f3T/qXkPmsxsJlKPGeiLxUui4vVdUiPz3xwRDzdx/ibShqS6c5+VleQHEa6TURsTHLITDlthD9GxMEkW8EfBv6zgvfTJzegW9//kqy9fVHJiXOHkRxf2ek/gc+la2qSNCQ98H6jEqb9G2CKpF0lbQCc3jkgIt5Mp/3vkt4JIGlrSR8us/53Al+WtJ6ko4BdSML5NpJjnpYCa5Sc0PChUicqaSdJH0zDv5qksf9mmbWZFVTke3Yl8B1JQ5Wc5DONZAsywM+BEyUdqOSkmq372PqxEbASWCFpa+CUUupK83kZcJ6krSQNkjRBmZMYUwVzpuQE5O3TldwVJL81b1aQr49Ier+ktwHfB2ZHxOL0/a1J57+upGnAO0p5j2l9H5A0Ot069yLJrmDnvLXcRbIx5ux0+TNY0r61nEFE/B24GfixpHekmdpO0gEAko7SWyfiPU/SkHoTuAHYUdIn0mXQepL2lLRLtTX1lZ3MKF+QNEzJCXT/SnKsMiSZeAV4IR12OhVIP5M/kKwsbJq+t/2Lva4XVS2Le3EJ8AOlJxKnv4+HFXnN9yS9LV3hPpTkuHBIPqvnImK1pL2A40otQsnevcPSxvmrJL+zNf3tcAO6xUXEayQnDn6a5Hie40l+FF5Nh88lOaj/pyQ/HAtJjncqZdp/IDmm6Nb0dbf2GOXUtP/sdFfTLZR/beY7gR1Itpj9ADgyIpZHxEvAl0ka8c+TBGNmGdNdHzg7ne6zJA31b5VZm1kxhb5nZwFzgfuBB4B5aT8i4i6SE5f+nWTh+he6b63u9D1gXDrOjcB1ZdT2jXS+c0gOmTiHHr/pJeRsB5JcryRZWb8oIm4r8r57cwVJQ+A5khP9jk/7/5Hk0K9HSXbNrqb7ru1itgSuJWk8LyD5HP+rjNdbnaW79j9Kctz8U8ASkl3ntfZJksbefJLv8rUkWxYB9gTuTA/FmEly/O6i9Pv/IeAYkq2az/LWie/V6is7na4gafQvIjnUqvPKWeeTnBy4jORku5uqqOETJCuVD5Mcq/2VcidQg2VxTxekr79Z0ksk73HvAuM/m873GeDXJMeOP5wO+zxwZjqdaWmNpVoH+Fo63edITlA8qYzXF9V5BqbliKQ7SU4E/EWzaylE0hSSE0Te3+xazKw+JM0gOeH3O82uxawVSOogWfbd0uxaWpmkNpKTiIcVGbUleQt0Dkg6QNKW6SEcJ5BczqWatVYzMzMzq5Dv9JQPO5HsuhhCsjvoyPT4JzMzMzNrMB/CYWZmZmZWBh/CYWZmZmZWBjegzczMzMzKkLtjoLfYYosYMWJEs8swaxl33333sogYWnzMxnNezbpr5byCM2vWU1+ZzV0DesSIEcydO7fZZZi1DElPFh+rOZxXs+5aOa/gzJr11FdmfQiHmZmZmVkZ3IA2MzMzMyuDG9BmZmZmZmXI3THQVn+vv/46S5YsYfXq1c0uxTIGDx7MsGHDWG+99ZpdirUQ57U1Oa/WG+e1dZWb2X7fgG5rawOgvb29qXXkyZIlS9hoo40YMWIEkppdjgERwfLly1myZAkjR45sdjlN4Sz3znltPQMlr85k+ZzX1lRJZosewiFpPUlflnRt+viSJK9S92OrV69m8803d7hbiCQ233zzkrZaOLMDi/PaepxX64vz2prKyWynUrZAXwysB1yUdn8i7feZsiu03HC4W08Z/xNndoBxXluP82p9cV5bU7n/l1JOItwzIk6IiFvTx4nAniUWM1HSI5IWSjqtj3H+WdJ8SQ9JuqKc4vsy4rQbux6zFy1n9qLlXd3Wv3zkIx/hhRdeKDjOtGnTuOWWWyqafnt7O4ceemhFr+1NW1tbI66xWnFmzerJee2V82otyXktrJQt0G9I2i4iHgeQ9B7gjWIvkjQIuBA4GFgCzJE0MyLmZ8bZAfgWsG9EPC/pnZW8CauvWq94dJw9qeppRAQRwaxZs4qOe+aZZ1Y9v0qsWbOGddet7jSDN954g0GDBpX9skoya/2D81oZ59WawXmtTBPz2qWULdCnALdJapf0F+BW4OslvG4vYGFELIqI14CrgMN6jPNZ4MKIeB4gIv5ReunWn5133nmMGjWKUaNGcf755wPQ0dHBTjvtxCc/+UlGjRrF4sWLGTFiBMuWLQPg+9//PjvttBPvf//7OfbYYzn33HMBmDJlCtdeey2Q3GXr9NNPZ9y4cYwePZqHH34YgLvuuosJEyYwduxY3ve+9/HII48UrG/16tWceOKJjB49mrFjx3LbbbcBMGPGDCZPnswHP/hBDjzwQF555RWOOeYYdtllFz72sY/xyiuvdE3j5ptvZsKECYwbN46jjjqKlStXdtV46qmnMm7cOK655ppKPr5KM2tWEefVebX8cF6rymuXos33iPhzuqV4p7TXIxHxagnT3hpYnOleAuzdY5wdASTdAQwCzoiIm0qYdsm2PO7sWk7OGuDuu+/mF7/4BXfeeScRwd57780BBxzApptuymOPPcbll1/OPvvs0+01c+bM4be//S333Xcfr7/+OuPGjWOPPfbodfpbbLEF8+bN46KLLuLcc8/l0ksvZeedd+b2229n3XXX5ZZbbuHb3/42v/3tb/us8cILL0QSDzzwAA8//DAf+tCHePTRRwGYN28e999/P5ttthnnnXceG2ywAQsWLOD+++9n3LhxACxbtoyzzjqLW265hSFDhnDOOedw3nnnMW3aNAA233xz5s2bV9HnV0VmW9MZGyd/O1Z17wY4Y0Xj67FunFfn1fLDea0ur1l9NqAlfTAibpV0eI9B20siIq6reu7J/HcA2oBhwF8ljY6IF3rUMhWYCjB8+PAazNZa2d/+9jc+9rGPMWTIEAAOP/xwbr/9diZPnsy22267VrgB7rjjDg477DAGDx7M4MGD+ehHP9rn9A8/PPlK77HHHlx3XfI1XrFiBSeccAKPPfYYknj99deL1vilL30JgJ133pltt922K+AHH3wwm222GQB//etf+fKXvwzAmDFjGDNmDACzZ89m/vz57LvvvgC89tprTJgwoWv6Rx99dJFPaW0NyqxZN86r82r54bxWltfeFNoCfQDJrqTePqkAioX7aWCbTPewtF/WEuDOiHgdeELSoyQN6jndZhYxHZgOMH78+CgyX+vHOkNfjfXXXx+AQYMGsWbNGgC++93v8oEPfIDf/e53dHR0dF3ftF41RgQHH3wwV155ZcXT6EW1mTWrKee1IOfVWorzWp4+j4GOiNPTp2dGxInZB/D9EqY9B9hB0khJbwOOAWb2GOf3JFufkbQFySEdi8p7C9bf7Lfffvz+97/n5ZdfZtWqVfzud79jv/32K/iafffdl+uvv57Vq1ezcuVKbrjhhrLmuWLFCrbeemsgOc6qlBp//etfA/Doo4/y1FNPsdNOO6013v77788VVyQXl3nwwQe5//77Adhnn3244447WLhwIQCrVq3qWsOuVA0ya1Y257Uyec5rX1e58pWuWp/zWjulnETY24Eq1xZ7UUSsAb4I/BFYAPwmIh6SdKakyelofwSWS5oP3AacEhHLSyvd+qtx48YxZcoU9tprL/bee28+85nPMHbs2IKv2XPPPZk8eTJjxozhkEMOYfTo0Wy88cYFX5P1zW9+k29961uMHTu2a625kM9//vO8+eabjB49mqOPPpoZM2Z0rXlnnXTSSaxcuZJddtmFadOmdR03NnToUGbMmMGxxx7LmDFjmDBhQtcJFzVQUWbNKuG8Vs15tYZxXmtHEb0fESFpZ2A34IckZwl3egdJQ3e3mldTgvHjx0ex6/wVWguuxSVe+rsFCxawyy67NLuMsq1cuZINN9yQ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\n",
      "text/plain": [
       "<Figure size 864x180 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.arange(10)\n",
    "width = 0.4\n",
    "\n",
    "fig, axes = plt.subplots(1, 3)\n",
    "fig.set_size_inches(w=12, h=2.5)\n",
    "# for row in axes\n",
    "for idx, ax in enumerate(axes):\n",
    "\n",
    "    # lower case seeds\n",
    "    seed_lists = [seed.loc[seed_set][\"Seeds\"] for seed_set in seed_list[idx]]\n",
    "    seed1 = seed_lists[0]\n",
    "    seed2 = seed_lists[1]\n",
    "\n",
    "    seed1_shuf = (shuffled_seeds[idx])[0]\n",
    "    seed2_shuf = (shuffled_seeds[idx])[1]\n",
    "\n",
    "    (\n",
    "        variance_ordered,\n",
    "        variance_rnd,\n",
    "        variance_inshuffle,\n",
    "    ) = replicate_bolukbasi.pca_seeds_model(\n",
    "        seed1, seed2, models, seed1_shuf, seed2_shuf\n",
    "    )\n",
    "\n",
    "    ax.bar(\n",
    "        x - 0.2,\n",
    "        np.mean(variance_ordered, axis=0),\n",
    "        width,\n",
    "        yerr=np.std(variance_ordered, axis=0),\n",
    "        label=\"original order\",\n",
    "    )\n",
    "\n",
    "    ax.bar(\n",
    "        x + 0.2,\n",
    "        np.mean(variance_inshuffle, axis=0),\n",
    "        width,\n",
    "        yerr=np.std(variance_inshuffle, axis=0),\n",
    "        label=\"shuffled\",\n",
    "    )\n",
    "    ax.legend()\n",
    "    ax.set_xlabel(\"Prinicipal Component\")\n",
    "    ax.set_ylabel(\"Explained Variance Ratio\")\n",
    "    ax.set_title(seed_genres[idx])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "5af0f333",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rc(\"pgf\", texsystem=\"pdflatex\")\n",
    "fig.savefig(\"../images/fig3.pdf\", bbox_inches=\"tight\", dpi=600)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
