{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cfe0414b-0f8a-4f9c-82ef-c2a222c47f61",
   "metadata": {},
   "source": [
    "## Reference:\n",
    "* Gonen, H.; and Goldberg, Y. 2019. Lipstick on a Pig: Debiasing Methods Cover up Systematic Gender Biases in Word Embeddings But do not Remove Them. NAACL-HLT.\n",
    "* Yang, Z.; and Feng, J. 2020. A causal inference method for reducing gender bias in word embedding relations. In Proceedings of the AAAI Conference on Artificial Intelligence, volume 34, 9434–9441.\n",
    "* Ding, L., Yu, D., Xie, J., Guo, W., Hu, S., Liu, M., Kong, L., Dai, H., Bao, Y. and Jiang, B., 2022, June. Word embeddings via causal inference: Gender bias reducing and semantic information preserving. In Proceedings of the AAAI Conference on Artificial Intelligence (Vol. 36, No. 11, pp. 11864-11872)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "49a3eef2-b9fe-4589-ad86-d431010e2a19",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy, requests, codecs, os, re, nltk, itertools, csv\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "import tensorflow as tf\n",
    "from scipy.stats import spearmanr\n",
    "import functools as ft\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.preprocessing import normalize\n",
    "import gdown"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "659378d0-246a-463b-a077-d66b7abb5065",
   "metadata": {},
   "source": [
    "## Read File"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ac7ce3dd-1efe-426e-bc56-3ee4c48288b2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "322636\n"
     ]
    }
   ],
   "source": [
    "VEC_LEN = 300\n",
    "glove_file = open(\"./Data/WordEmbedding/glove_wiki_vectors.txt\", 'r')\n",
    "glove_word = {}\n",
    "for line in glove_file:\n",
    "    line = line.strip()\n",
    "    _word = line.split(' ')\n",
    "    vector = np.array([float(num) for num in _word[1:]])\n",
    "    if len(vector) != VEC_LEN: \n",
    "        raise Exception(\"Word dimension is wrong\")\n",
    "    glove_word[_word[0]] = vector\n",
    "glove_file.close()\n",
    "print(len(glove_word))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "686f7111-d1c4-4be3-a01e-17b5ed5b1a5f",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv('Iter_1_q_75_9000_Glove.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "30bb46f4-3b67-4ce7-97f6-fec948d06784",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.drop(columns=['Unnamed: 0'],inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2c765b62-8a35-4932-9bdc-fd3c9bb14944",
   "metadata": {},
   "outputs": [],
   "source": [
    "proj = np.identity(len(df)) - df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2656c09f-5d8d-4897-8a19-d16f6ff3e53c",
   "metadata": {},
   "outputs": [],
   "source": [
    "VEC_LEN = 300\n",
    "debias_file = open(\"./Data/WordEmbedding/glove_wiki_vectors.txt\", 'r')\n",
    "debias_word = {}\n",
    "for line in debias_file:\n",
    "    line = line.strip()\n",
    "    _word = line.split(' ')\n",
    "    vector = np.array([float(num) for num in _word[1:]])\n",
    "    if len(vector) != VEC_LEN: \n",
    "        raise Exception(\"Word dimension is wrong\")\n",
    "    debias_word[_word[0]] = np.array(proj @ vector) #load vector and do projection\n",
    "debias_file.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae92f19d-0812-47bf-8a26-b6ec4d906efe",
   "metadata": {},
   "source": [
    "## Word Similarity Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5a81b083-2b7e-4364-a87a-8e9825fc2bb3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "446\n"
     ]
    }
   ],
   "source": [
    "'''\n",
    "Read the male words and female words\n",
    "'''\n",
    "gender_specific = []\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",
    "\n",
    "exclude_words = gender_specific\n",
    "print(len(exclude_words))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e95c1563-c4c8-4258-96da-efee09e78a2e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████| 50000/50000 [00:00<00:00, 231748.71it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "size of vocabulary: 47698\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "'''\n",
    "Generate word list for evaluation\n",
    "'''\n",
    "import string \n",
    "from tqdm import tqdm\n",
    "\n",
    "def has_punct(w):\n",
    "    '''\n",
    "    Examine if the word includes punctuations\n",
    "    Arg:\n",
    "        w - str, word for examining\n",
    "    Returns:\n",
    "        bool\n",
    "    '''\n",
    "    if any([c in string.punctuation for c in w]):\n",
    "        return True\n",
    "    return False\n",
    "\n",
    "def has_digit(w):\n",
    "    '''\n",
    "    Examine if the word includes numbers\n",
    "    Arg:\n",
    "        w - str, word for examining\n",
    "    Returns:\n",
    "        bool\n",
    "    '''\n",
    "    if any([c in '0123456789' for c in w]):\n",
    "        return True\n",
    "    return False\n",
    "\n",
    "def limit_vocab(word_embedding, exclude = None, vec_len = 300):\n",
    "    '''\n",
    "    Generate the word list for evaluation\n",
    "    Arg:\n",
    "        word_embedding - dict{str:np.array}, the word vector dictionary\n",
    "        exclude - list[str], the list of gender words\n",
    "        vec_len - int, the number of dimentions of word vector\n",
    "    Returns:\n",
    "        vocab_limited - list[str], the evaluation word list\n",
    "    '''\n",
    "    vocab_limited = []\n",
    "    for w in tqdm(list(word_embedding.keys())[:50000]): \n",
    "        if w.lower() != w:\n",
    "            continue\n",
    "        if len(w) >= 20:\n",
    "            continue\n",
    "        if has_digit(w):\n",
    "            continue\n",
    "        if '_' in w:\n",
    "            p = [has_punct(subw) for subw in w.split('_')]\n",
    "            if not any(p):\n",
    "                vocab_limited.append(w)\n",
    "            continue\n",
    "        if has_punct(w):\n",
    "            continue\n",
    "        vocab_limited.append(w)\n",
    "    \n",
    "    if exclude:\n",
    "        vocab_limited = list(set(vocab_limited) - set(exclude))\n",
    "    \n",
    "    print(\"size of vocabulary:\", len(vocab_limited))\n",
    "    \n",
    "    return vocab_limited\n",
    "\n",
    "word_limited = limit_vocab(glove_word, exclude_words)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0248a925-2d66-4f5c-b35b-2ad004a02e20",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "Calculate Pearson correlation coeficient\n",
    "'''\n",
    "import scipy.stats\n",
    "\n",
    "def pearson(a,b):\n",
    "   \n",
    "    return scipy.stats.pearsonr(a,b)\n",
    "\n",
    "def compute_corr(tuples, i1, i2):\n",
    "    '''\n",
    "    Calculate Pearson correlation coeficient between two lists\n",
    "    Args:\n",
    "        tuples - list[list[int]], the elements are result of each test\n",
    "        i1 - int, for each test, the index of number to form first list in Pearson\n",
    "        i2 - int, for each test, the index of number to form second list in Pearson\n",
    "                e.g. i1==2; i2==4 means we select second and forth numbers in the tests results to do Pearson test\n",
    "    Returns:\n",
    "        (float, float) - a tuple of (coeficient, p-value)\n",
    "    '''\n",
    "    \n",
    "    a = []\n",
    "    b = []\n",
    "    for t in tuples:\n",
    "        a.append(t[i1])\n",
    "        b.append(t[i2])\n",
    "    assert(len(a)==len(b))    \n",
    "    return pearson(a,b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "43dff0c1-83e5-4e0b-b540-10e737928e3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataSets = ['EN-RG-65.txt', 'EN-WS-353-ALL.txt', 'EN-RW-STANFORD.txt', 'EN-MEN-TR-3k.txt', 'EN-MTurk-287.txt', 'EN-MTurk-771.txt', 'EN-SIMLEX-999.txt', 'EN-SimVerb-3500.txt']\n",
    "\n",
    "\n",
    "def similarity_eval(dataSetAddress, wordVecModel_str):\n",
    "    \n",
    "    wordVecModel = eval(wordVecModel_str)\n",
    "    vocab = set(list(wordVecModel.keys()))\n",
    "    \n",
    "    fread_simlex = open(dataSetAddress, \"r\")\n",
    "    \n",
    "    pair_list = []\n",
    "\n",
    "    line_number = 0\n",
    "    for line in fread_simlex:\n",
    "\n",
    "        tokens = line.split()\n",
    "        word_i = tokens[0]\n",
    "        word_j = tokens[1]\n",
    "        score = float(tokens[2])\n",
    "        if word_i in vocab and word_j in vocab:\n",
    "            pair_list.append( ((word_i, word_j), score) )\n",
    "\n",
    "    pair_list.sort(key=lambda x: - x[1]) # order the pairs from highest score (most similar) to lowest score (least similar)\n",
    "\n",
    "\n",
    "    extracted_scores = {}\n",
    "\n",
    "    extracted_list = []\n",
    "    \n",
    "               \n",
    "    for (x,y) in pair_list:\n",
    "        (word_i, word_j) = x\n",
    "        \n",
    "        current_distance = 1- cosine_similarity( wordVecModel[word_i].reshape(1,-1)  , wordVecModel[word_j].reshape(1,-1) )        \n",
    "\n",
    "        extracted_scores[(word_i, word_j)] = current_distance\n",
    "        extracted_list.append(((word_i, word_j), current_distance))\n",
    "\n",
    "    extracted_list.sort(key=lambda x: x[1])\n",
    "\n",
    "    spearman_original_list = []\n",
    "    spearman_target_list = []\n",
    "\n",
    "    for position_1, (word_pair, score_1) in enumerate(pair_list):\n",
    "        score_2 = extracted_scores[word_pair]\n",
    "        position_2 = extracted_list.index((word_pair, score_2))\n",
    "        spearman_original_list.append(position_1)\n",
    "        spearman_target_list.append(position_2)\n",
    "\n",
    "    spearman_rho = spearmanr(spearman_original_list, spearman_target_list)\n",
    "    \n",
    "    return spearman_rho[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d6d7400c-b345-4e74-9f32-4851628d9ea0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Word Similarity task\n",
      "Good result is higher\n",
      "\n",
      "EN-RG-65.txt\n",
      "0.7913\n",
      "EN-WS-353-ALL.txt\n",
      "0.6617\n",
      "EN-RW-STANFORD.txt\n",
      "0.3986\n",
      "EN-MEN-TR-3k.txt\n",
      "0.7423\n",
      "EN-MTurk-287.txt\n",
      "0.6349\n",
      "EN-MTurk-771.txt\n",
      "0.6792\n",
      "EN-SIMLEX-999.txt\n",
      "0.3949\n",
      "EN-SimVerb-3500.txt\n",
      "0.2493\n"
     ]
    }
   ],
   "source": [
    "print('Word Similarity task\\nGood result is higher\\n')\n",
    "resourceFile = './Data/' \n",
    "\n",
    "for dataset in dataSets:\n",
    "    dataSetAddress = resourceFile + 'WordSim/' +  dataset\n",
    "    print(dataset)\n",
    "    print('%.4f' %  similarity_eval(dataSetAddress, 'debias_word'))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6efd077-e2ca-46cb-9524-9284151a6683",
   "metadata": {},
   "source": [
    "# GBWR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "50ae5057-aec4-4d2b-b9ef-a078ec2a8231",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done\n",
      "Done\n"
     ]
    }
   ],
   "source": [
    "'''\n",
    "Normalize the word embedding\n",
    "'''\n",
    "def normalize(word_embedding):\n",
    "    for word in word_embedding.keys():\n",
    "        vec = word_embedding[word]\n",
    "        norm = np.linalg.norm(vec)\n",
    "        word_embedding[word] = vec / norm\n",
    "\n",
    "def check_normalize(word_embedding):\n",
    "    count = 0\n",
    "    for word in word_embedding.keys():\n",
    "        vec = word_embedding[word]\n",
    "        if np.linalg.norm(vec) > 1.0001 or np.linalg.norm(vec) < 0.9999:\n",
    "            print(word)\n",
    "            print(count)\n",
    "            raise Exception(\"Normalize error\")\n",
    "            \n",
    "def dim299(word_embedding):\n",
    "    for w in word_embedding:\n",
    "        try:\n",
    "            word_embedding[w] = word_embedding[w][:-1]\n",
    "            assert(len(word_embedding[w]) == 299)\n",
    "        except Exception:\n",
    "            print(w)\n",
    "\n",
    "normalize(glove_word)\n",
    "check_normalize(glove_word)\n",
    "print(\"Done\")\n",
    "debias_copy = debias_word.copy()\n",
    "normalize(debias_word)\n",
    "check_normalize(debias_word)\n",
    "print(\"Done\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f5808914-c498-4095-b36f-83be7b73ff83",
   "metadata": {},
   "source": [
    "## WEAT Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "5edbdb09-2355-40bf-b416-919e5b19107d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy\n",
    "import scipy.misc as misc\n",
    "import itertools\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "\n",
    "def similarity(w1, w2):\n",
    "    \n",
    "    return w1.dot(w2)\n",
    "\n",
    "def s_word(w, A, B, word_embedding, all_s_words):\n",
    "    '''\n",
    "    Calculate association s(w, A, B) in WEAT test\n",
    "    Args:\n",
    "        w - str, the word for calculate\n",
    "        A - list[str], attribute set 1\n",
    "        B - list[str], attribute set 2\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        all_s_words - dict{str:float}, {word:value of s(w, A, B)} record the result of the word\n",
    "    Returns:\n",
    "        float - value of s(w, A, B)\n",
    "    '''\n",
    "    if w in all_s_words:\n",
    "        return all_s_words[w]\n",
    "    \n",
    "    mean_a = []\n",
    "    mean_b = []\n",
    "    \n",
    "    for a in A:\n",
    "        mean_a.append(similarity(word_embedding[w], word_embedding[a]))\n",
    "    for b in B:\n",
    "        mean_b.append(similarity(word_embedding[w], word_embedding[b]))\n",
    "        \n",
    "    mean_a = sum(mean_a)/float(len(mean_a))\n",
    "    mean_b = sum(mean_b)/float(len(mean_b))\n",
    "    \n",
    "    all_s_words[w] = mean_a - mean_b\n",
    "\n",
    "    return all_s_words[w]\n",
    "\n",
    "\n",
    "def s_group(X, Y, A, B, word_embedding, all_s_words):\n",
    "    '''\n",
    "    Calculate test statistic s(X, Y, A, B) in WEAT test\n",
    "    Args:\n",
    "        X - list[str], target set 1\n",
    "        Y - list[str], target set 2\n",
    "        A - list[str], attribute set 1\n",
    "        B - list[str], attribute set 2\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        all_s_words - dict{str:float}, {word:value of s(w, A, B)} record the result of each word\n",
    "    Returns:\n",
    "        float - value of s(X, Y, A, B)\n",
    "    '''\n",
    "    total = 0\n",
    "    for x in X:\n",
    "        total += s_word(x, A, B, word_embedding, all_s_words)\n",
    "    for y in Y:\n",
    "        total -= s_word(y, A, B, word_embedding, all_s_words)\n",
    "        \n",
    "    return total\n",
    "\n",
    "def effect_size(X, Y, A, B, word_embedding, all_s_words):\n",
    "    '''\n",
    "    Calculate effect size d in WEAT test\n",
    "    Args:\n",
    "        X - list[str], target set 1\n",
    "        Y - list[str], target set 2\n",
    "        A - list[str], attribute set 1\n",
    "        B - list[str], attribute set 2\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        all_s_words - dict{str:float}, {word:value of s(w, A, B)} record the result of each word\n",
    "    Returns:\n",
    "        float - effect size d\n",
    "    '''\n",
    "    total_x = []\n",
    "    total_y = []\n",
    "    \n",
    "    for x in X:\n",
    "        total_x.append(s_word(x, A, B, word_embedding, all_s_words))\n",
    "    for y in Y:\n",
    "        total_y.append(s_word(y, A, B, word_embedding, all_s_words))\n",
    "        \n",
    "    \n",
    "    mean = sum(total_x)/float(len(total_x)) - sum(total_y)/float(len(total_y))\n",
    "    std_dev = np.std(total_x + total_y)\n",
    "    \n",
    "    if std_dev == 0:\n",
    "        print(\"Error! \")\n",
    "    \n",
    "    return mean / std_dev\n",
    "\n",
    "\n",
    "def p_value_exhust(X, Y, A, B, word_embedding):\n",
    "    '''\n",
    "    WEAT test\n",
    "    Args:\n",
    "        X - list[str], target set 1\n",
    "        Y - list[str], target set 2\n",
    "        A - list[str], attribute set 1\n",
    "        B - list[str], attribute set 2\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "    Returns:\n",
    "        tuple(float, float) - (test statistic, effect size)\n",
    "    '''\n",
    "    \n",
    "\n",
    "    if len(X) > 10:\n",
    "        print('might take too long, use sampled version: p_value')\n",
    "        return\n",
    "    \n",
    "    assert(len(X) == len(Y))\n",
    "    \n",
    "    all_s_words = {}\n",
    "    s_orig = s_group(X, Y, A, B, word_embedding, all_s_words) \n",
    "    \n",
    "    union = set(X+Y)\n",
    "    subset_size = int(len(union)/2)\n",
    "    \n",
    "    larger = 0\n",
    "    total = 0\n",
    "\n",
    "    for subset in set(itertools.combinations(union, subset_size)):\n",
    "        total += 1\n",
    "        Xi = list(set(subset))\n",
    "        Yi = list(union - set(subset))\n",
    "        if s_group(Xi, Yi, A, B, word_embedding, all_s_words) > s_orig:\n",
    "            larger += 1\n",
    "    \n",
    "    d = effect_size(X, Y, A, B, word_embedding, all_s_words)\n",
    "    \n",
    "    return larger/float(total), d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "97e671a0-ad6d-474b-9801-8cae54f57bb6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def weat_test(word_embedding):\n",
    "    final = \"Experiment 1 : \"\n",
    "\n",
    "    A = ['john', 'paul', 'mike', 'kevin', 'steve', 'greg', 'jeff', 'bill']\n",
    "    B = ['amy', 'joan', 'lisa', 'sarah', 'diana', 'kate', 'ann', 'donna']\n",
    "    C = ['caress', 'freedom', 'health', 'love', 'peace', 'cheer', 'friend', 'heaven', 'loyal', 'pleasure', 'diamond', 'gentle', 'honest', 'lucky', 'rainbow', 'diploma', 'gift', 'honor', 'miracle', 'sunrise', 'family', 'happy', 'laughter', 'paradise', 'vacation']\n",
    "    D = ['abuse', 'crash', 'filth', 'murder', 'sickness', 'accident', 'death', 'grief', 'poison', 'stink', 'assault', 'disaster', 'hatred', 'pollute', 'tragedy', 'divorce', 'jail', 'poverty', 'ugly', 'cancer', 'kill', 'rotten', 'vomit', 'agony', 'prison']\n",
    "    \n",
    "    result = p_value_exhust(A, B, C, D, word_embedding)\n",
    "    final += \"p-value: \" + str(result[0]) + \"\\t effect size: \" + str(result[1]) + '\\n'\n",
    "\n",
    "    final += \"Experiment 2 : \"\n",
    "\n",
    "    E = ['executive', 'management', 'professional', 'corporation', 'salary', 'office', 'business', 'career']\n",
    "    F = ['home', 'parents', 'children', 'family', 'cousins', 'marriage', 'wedding', 'relatives']\n",
    "\n",
    "    result = p_value_exhust(A, B, E, F, word_embedding)\n",
    "    final += \"p-value: \" + str(result[0]) + \"\\t effect size: \" + str(result[1]) + '\\n'\n",
    "\n",
    "\n",
    "    final +=  \"Experiment 3 : \"\n",
    "\n",
    "    G = ['science', 'technology', 'physics', 'chemistry', 'einstein', 'nasa', 'experiment', 'astronomy']\n",
    "    H = ['poetry', 'art', 'dance', 'literature', 'novel', 'symphony', 'drama', 'sculpture']\n",
    "\n",
    "    \n",
    "    result = p_value_exhust(A, B, G, H, word_embedding)\n",
    "    final += \"p-value: \" + str(result[0]) + \"\\t effect size: \" + str(result[1]) + '\\n'\n",
    "    \n",
    "\n",
    "    return final"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c54baade-78ba-4aa5-9230-39dd026d1390",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment 1 : p-value: 0.41126651126651126\t effect size: 0.11905717812383561\n",
      "Experiment 2 : p-value: 0.14172494172494174\t effect size: 0.5645880559728366\n",
      "Experiment 3 : p-value: 0.9123543123543123\t effect size: -0.7106859549232489\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(weat_test(debias_word))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8497d595-fc58-4bb0-81d6-f16e013371e6",
   "metadata": {},
   "source": [
    "## Gender-projection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "efa9147d-dfe6-4d43-96fd-4c73b91e3166",
   "metadata": {},
   "outputs": [],
   "source": [
    "# create a dictionary of the bias, before and after\n",
    "\n",
    "def compute_bias_by_projection(word_embedding, word_list):\n",
    "    '''\n",
    "    Calculate gender projection on gender direction for each word\n",
    "    Args:\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        word_list - list[str], the evaluation word list\n",
    "    Returns:\n",
    "        dict{str:float} - {word:projection}, record the projection of each word in the evaluation word list\n",
    "    '''\n",
    "    direction = word_embedding['he'] - word_embedding['she']\n",
    "    d = {}\n",
    "    for w in word_list:\n",
    "        try:\n",
    "            d[w] = word_embedding[w].dot(direction)\n",
    "        except Exception:\n",
    "            print(w)\n",
    "            continue\n",
    "    return d\n",
    "word_project = compute_bias_by_projection(glove_word, word_limited)\n",
    "debias_project = compute_bias_by_projection(debias_word, word_limited)\n",
    "\n",
    "dim299(debias_copy)\n",
    "normalize(debias_copy)\n",
    "check_normalize(debias_copy)\n",
    "del debias_word\n",
    "debias_word = debias_copy\n",
    "\n",
    "\n",
    "\n",
    "# calculate the avg bias of the vocabulary (abs) before and after debiasing\n",
    "\n",
    "def report_bias(gender_bias):\n",
    "    '''\n",
    "    Calculate average word projection in the evaluation word list\n",
    "    Args:\n",
    "        gender_bias - dict{str:float}, {word:projection} dictionary records projection of word\n",
    "    Returns:\n",
    "        float - average gender projection\n",
    "    '''\n",
    "    bias = 0.0\n",
    "    for k in gender_bias:\n",
    "        bias += np.abs(gender_bias[k])\n",
    "    return bias/len(gender_bias)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "90da48a0-a0cd-4ed9-be18-4684652edb7f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "debias word : 0.01163070007161296\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"debias word : {}\\n\".format(report_bias(debias_project)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a1c533a9-d34a-4bf2-a4dc-84a1b0f36dcc",
   "metadata": {},
   "source": [
    "## Correlation between bias-by-projection and bias-by-neighbors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "38570e4d-7d6f-40cf-b157-8d1afb1cfe00",
   "metadata": {},
   "outputs": [],
   "source": [
    "def word_vec(word_embedding, word_list):\n",
    "    '''\n",
    "    Integrete the word vectors in the evaluation word list in a matrix.\n",
    "    Args:\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        word_list - list[str], the evaluation word list\n",
    "    Returns:\n",
    "        np.array(number of words, number of dimentions) - each row is a word vector, the order is same as the word list\n",
    "    '''\n",
    "    word_limited_vec = []\n",
    "    for w in word_list:\n",
    "        try:\n",
    "            word_limited_vec.append(word_embedding[w])\n",
    "        except:\n",
    "            print(w)\n",
    "            continue\n",
    "    word_limited_vec = np.array(word_limited_vec)\n",
    "    return word_limited_vec\n",
    "\n",
    "word_limited_vec = word_vec(glove_word, word_limited)\n",
    "debias_limited_vec = word_vec(debias_word, word_limited)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "967c7e18-3725-46f7-910e-f0af4fd096e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████| 47698/47698 [11:28<00:00, 69.27it/s]\n"
     ]
    }
   ],
   "source": [
    "# get tuples of biases and counts of masculine/feminine NN for each word (for bias-by-neighbors)\n",
    "\n",
    "def bias_by_neighbors(word_embedding, word_list, word_limited_vec, gender_bias_project, neighbours_num = 105):\n",
    "    '''\n",
    "    Calculate the gender-biased words in the k nearest neighbors of each word in the word list\n",
    "    Args:\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        word_list - list[str], the evaluation word list\n",
    "        word_limited_vec - np.array(number of words, number of dimentions),\n",
    "                            each row is a word vector, the order is same as the word list\n",
    "        gender_bias_project - dict{str:float}, {word:projection} record the projection of each word in the evaluation word list\n",
    "        neighbours_num - int, select top k similar neighbors\n",
    "    Returns:\n",
    "        tuple(str, np.array, int) - (word, word vector, the number of male words in top k similar neighbors)\n",
    "    '''\n",
    "    tuples = []\n",
    "    count = 0\n",
    "    for w in tqdm(word_list):\n",
    "        \n",
    "        vec = word_embedding[w]\n",
    "        sim = word_limited_vec.dot(vec)\n",
    "        sort_sim = (sim.argsort())[::-1]\n",
    "        best = sort_sim[:(neighbours_num+1)]\n",
    "        \n",
    "        top = []\n",
    "        for i in best:\n",
    "            if i != count:\n",
    "                top.append(word_list[i])\n",
    "            elif word_list[i] != word_list[count]:\n",
    "                raise Exception(\"Same Word Error\")\n",
    "        \n",
    "\n",
    "        m = 0\n",
    "        f = 0    \n",
    "        for t in top[:100]:\n",
    "            if gender_bias_project[t] > 0:\n",
    "                m+=1\n",
    "            else:\n",
    "                f+=1\n",
    "            \n",
    "        tuples.append((w, word_project[w], m))\n",
    "        count = count + 1\n",
    "\n",
    "    return tuples\n",
    "\n",
    "tuples_debias = bias_by_neighbors(debias_word, word_limited, debias_limited_vec, word_project) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "353e4bed-1957-4a01-b08b-d3b63e9bce93",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GBWR correlation task :\n",
      "k-nearest neighbor of 50000 words, percent of male in k = 100\n",
      "Good result is lower\n",
      "debias word : \n",
      "(0.5198836982434382, 0.0)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"GBWR correlation task :\\nk-nearest neighbor of 50000 words, percent of male in k = 100\\nGood result is lower\")\n",
    "\n",
    "print(\"debias word : \\n{}\\n\".format(compute_corr(tuples_debias, 1, 2)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8921f183-2341-4e28-8b07-fc91aebcd2cb",
   "metadata": {},
   "source": [
    "## Clustering Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e977569d-a3be-4211-9dd2-c74efb127ca0",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_bef, X_aft = extract_vectors(male + female, glove_word, debias_word)\n",
    "y_pred_bef = KMeans(n_clusters=2, random_state=1).fit_predict(X_bef)\n",
    "X_embedded_bef = TSNE(n_components=2).fit_transform(X_bef)\n",
    "y_pred_aft = KMeans(n_clusters=2, random_state=1).fit_predict(X_aft)\n",
    "X_embedded_aft = TSNE(n_components=2).fit_transform(X_aft)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "feb12228-d228-46fa-b699-19059d505f38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(ncols=2,figsize=(10, 5))\n",
    "\n",
    "for x,l in zip(X_embedded_bef, y_pred_bef):\n",
    "    if l:\n",
    "        axes[0].scatter(x[0], x[1], marker = '.', c = 'c')\n",
    "        #plt.scatter(x[0], x[1], marker = '.', c = 'c',)\n",
    "    else:\n",
    "        axes[0].scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "        #plt.scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "\n",
    "axes[0].set(xlabel='Original GloVe')\n",
    "#axes[0].set_title('Original GloVe',y=-0.05)\n",
    "\n",
    "for x,l in zip(X_embedded_aft, y_pred_aft):\n",
    "    if l:\n",
    "        axes[1].scatter(x[0], x[1], marker = '.', c = 'c')\n",
    "        #plt.scatter(x[0], x[1], marker = '.', c = 'c',)\n",
    "    else:\n",
    "        axes[1].scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "        #plt.scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "\n",
    "axes[1].set(xlabel='SDR Debiased GloVe')\n",
    "fig.legend()\n",
    "fig.suptitle('t-SNE visualization of the embedding')\n",
    "fig.savefig('tsne.jpg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "cf24dd53-a0f4-46bc-9fdb-9c23a7b0b382",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Auxiliary finctions\n",
    "\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "from cycler import cycler\n",
    "import operator\n",
    "import random\n",
    "\n",
    "from sklearn.cluster import KMeans\n",
    "\n",
    "from sklearn.manifold import TSNE\n",
    "\n",
    "\n",
    "def visualize(vectors, words, labels, title, ax, num_clusters = 2):\n",
    "    \n",
    "    # perform TSNE\n",
    "    \n",
    "    \n",
    "    #plt.figure()\n",
    "    X_embedded = TSNE(n_components=2).fit_transform(vectors)\n",
    "    if num_clusters == 2:\n",
    "        for x,l,i in zip(X_embedded, labels, [0,1]):\n",
    "            if l:\n",
    "                ax.scatter(x[0], x[1], marker = '.', c = 'c',)\n",
    "                #plt.scatter(x[0], x[1], marker = '.', c = 'c',)\n",
    "            else:\n",
    "                ax.scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "                #plt.scatter(x[0], x[1], marker = 'x', c = 'darkviolet')\n",
    "    else:\n",
    "        pass\n",
    "        #plt.scatter(X_embedded[:,0], X_embedded[:,1], c = labels)                \n",
    "\n",
    "    # ax.text(.01, .9, title ,transform=ax.transAxes, fontsize=18)\n",
    "    #plt.show()\n",
    "\n",
    "\n",
    "def extract_vectors(words, before, after):\n",
    "    '''\n",
    "    Generate the word vector set\n",
    "    '''\n",
    "    size = len(words)/2\n",
    "    \n",
    "    X_bef = []\n",
    "    X_aft = []\n",
    "    for x in words:\n",
    "        if x in after:\n",
    "            X_bef.append(before[x])\n",
    "            X_aft.append(after[x])\n",
    "        else:\n",
    "            print(x)\n",
    "#     X_bef = [before[x] for x in words]\n",
    "#     X_aft = [after[x] for x in words]\n",
    "        \n",
    "    X_bef = pd.DataFrame(X_bef)\n",
    "    X_aft = pd.DataFrame(X_aft)\n",
    "    \n",
    "    return X_bef, X_aft\n",
    "\n",
    "    \n",
    "\n",
    "def cluster(words, X_bef, X_aft, random_state, y_true, num=2):\n",
    "    '''\n",
    "    Use K-Means to cluster the word vector set and calcualte the accuracy\n",
    "    Args:\n",
    "        words - list[str], the word list for clustering\n",
    "        X_bef - list[np.array], the list of the original word vectors\n",
    "        X_aft - list[np.array], the list of the debiased word vectors\n",
    "        random_state - int\n",
    "        y_true - list[int], the label (female/male) of the words\n",
    "        num - int, the number of clusters\n",
    "    Return:\n",
    "        str - the accuracy of clustering test\n",
    "    '''\n",
    "    final = ''\n",
    "    \n",
    "    import pdb\n",
    "#    pdb.set_trace()\n",
    "    y_pred_bef = KMeans(n_clusters=num, random_state=random_state).fit_predict(X_bef)\n",
    "    #visualize(X_bef, words, y_pred_bef, 'Original',axes[0])\n",
    "    correct = [1 if item1 == item2 else 0 for (item1,item2) in zip(y_true, y_pred_bef) ]\n",
    "    final += \"original glove: {} \".format(sum(correct)/float(len(correct)))\n",
    "    \n",
    "    y_pred_aft = KMeans(n_clusters=num, random_state=random_state).fit_predict(X_aft)\n",
    "    for i in range(0, len(y_pred_aft)):\n",
    "        if y_pred_aft[i] == 0:\n",
    "            y_pred_aft[i] = 1\n",
    "        else:\n",
    "            y_pred_aft[i] = 0\n",
    "        \n",
    "    #visualize(X_aft, words, y_pred_aft, 'Debiased',axes[1])\n",
    "    correct = [1 if item1 == item2 else 0 for (item1,item2) in zip(y_true, y_pred_aft) ]\n",
    "    accuracy = sum(correct)/float(len(correct))\n",
    "    # print(accuracy)\n",
    "    if accuracy < 0.5:\n",
    "        accuracy = 1 - accuracy\n",
    "    final += \"compare with {} \".format(accuracy)\n",
    "    \n",
    "    return final, accuracy\n",
    "\n",
    "\n",
    "# Cluster most biased words before and after debiasing\n",
    "def test(before, after):\n",
    "    '''\n",
    "    Generate word vector set and label set\n",
    "    Args:\n",
    "        before - dict{word:np.array}, the original word embedding\n",
    "        after - dict{word:np.array}, the debiased word embedding\n",
    "    Returns:\n",
    "        float - the accuracy of clustering test\n",
    "    '''\n",
    "    X_bef, X_aft = extract_vectors(male + female, before, after)\n",
    "    \n",
    "    \n",
    "    y_true = [0]*size + [1]*size\n",
    "    return cluster(male + female, X_bef, X_aft, random_state, y_true) \n",
    "    \n",
    "random.seed(1)\n",
    "random_state = 1\n",
    "\n",
    "size = 500\n",
    "sorted_g = sorted(word_project.items(), key=operator.itemgetter(1))\n",
    "female = [item[0] for item in sorted_g[:size]]\n",
    "male = [item[0] for item in sorted_g[-size:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "6caea991-515d-4cdb-97ca-9f6d1a30e431",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GBWR clustering task : \n",
      "clustering top 500, show which word is clustered wrongly\n",
      "Good result is lower\n",
      "original glove: 1.0 compare with 0.536 debias word\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(\"GBWR clustering task : \")\n",
    "print(\"clustering top 500, show which word is clustered wrongly\")\n",
    "print(\"Good result is lower\")\n",
    "print(\"{}debias word\\n\".format(test(glove_word, debias_word)[0]))\n",
    "#Xembed1, Xembed2 = test(glove_word, debias_word)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "93701ad4-5f80-46c5-8db5-7f67ed850448",
   "metadata": {},
   "source": [
    "## Professional test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "32e082c7-4e06-4096-8b43-724cb8e4a14f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json \n",
    "\n",
    "def extract_professions():\n",
    "    '''\n",
    "    Read the professions list\n",
    "    Returns:\n",
    "        list[str] - the list of professions\n",
    "    '''\n",
    "    professions = []\n",
    "    with codecs.open('./Data/professions.json', 'r', 'utf-8') as f:\n",
    "        professions_data = json.load(f)\n",
    "    for item in professions_data:\n",
    "        professions.append(item[0].strip())\n",
    "    return professions\n",
    "\n",
    "\n",
    "professions = extract_professions()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "305fa1cf-f7b5-4628-b32e-7cdadf1f3b05",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_tuples_prof(word_embedding, words, word_list, word_limited_vec, gender_bias_dict):\n",
    "    '''\n",
    "    Calculate the gender-biased words in the k nearest neighbors for each profession\n",
    "    Args:\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "        words - list[str], the profession list\n",
    "        word_list - list[str], the evaluation word list\n",
    "        word_limited_vec - np.array(number of words, number of dimentions),\n",
    "                            each row is a word vector, the order is same as the word list\n",
    "        gender_bias_dict - dict{str:float}, {word:projection} record the projection of each word in the evaluation word list\n",
    "    Returns:\n",
    "        tuple(str, np.array, int) - (word, word vector, the number of male words in top k similar neighbors)\n",
    "    '''\n",
    "    \n",
    "    \n",
    "    tuples = []\n",
    "    \n",
    "    for w in words:\n",
    "        if w not in gender_bias_dict:\n",
    "            continue\n",
    "            \n",
    "        # top = topK(w, space, k=105)[:100]\n",
    "        vec = word_embedding[w]\n",
    "        sim = word_limited_vec.dot(vec)\n",
    "        sort_sim = (sim.argsort())[::-1]\n",
    "        best = sort_sim[:(105+1)]\n",
    "        \n",
    "        # if w in words:\n",
    "        #     print(w)\n",
    "        # idx = word_list.index(w)\n",
    "        top = []\n",
    "        for i in best:\n",
    "            if word_list[i] != w:\n",
    "                top.append(word_list[i])\n",
    "            # else:\n",
    "                # print(\"___________________\")\n",
    "                # print(w)\n",
    "                # raise Exception(\"Same Word Error\")\n",
    "            \n",
    "        m = 0\n",
    "        f = 0  \n",
    "        for t in top[:100]:          \n",
    "            if gender_bias_dict[t] > 0:\n",
    "                m+=1\n",
    "            else:\n",
    "                f+=1\n",
    "                \n",
    "        tuples.append((w, gender_bias_dict[w], m))\n",
    "        \n",
    "        \n",
    "    return tuples\n",
    "\n",
    "prof_glove = get_tuples_prof(glove_word, professions, word_limited, word_limited_vec, word_project)\n",
    "prof_debias = get_tuples_prof(debias_word, professions, word_limited, debias_limited_vec, word_project)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "c75fa634-7c11-4601-b7e2-a035c30cdb4e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GBWR professional task : \n",
      "k-nearest neighbor of professional words, percent of male in k = 100\n",
      "Good result is lower\n",
      "\n",
      "debias word : \n",
      "0.6515575823395002\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"GBWR professional task : \\nk-nearest neighbor of professional words, percent of male in k = 100\\nGood result is lower\\n\")\n",
    "print(\"debias word : \\n{}\\n\".format(compute_corr(prof_debias, 1, 2)[0]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b66521f3-c185-4c11-9f5a-35308fc86fa8",
   "metadata": {},
   "source": [
    "## Classification test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "231a20e0-57e1-497a-bed6-accea8a29af6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn import svm\n",
    "from random import shuffle\n",
    "import random\n",
    "random.seed(100)\n",
    "\n",
    "\n",
    "\n",
    "def train_and_predict(word_embedding):\n",
    "    '''\n",
    "    Train an SVM classifier and calculate the accuracy of prediction\n",
    "    Args:\n",
    "        word_embedding - dict{str:np.array}, {word:vector} word vectors dictionary\n",
    "    Returns:\n",
    "        float - the accuracy of prediction\n",
    "    '''\n",
    "    X_train = [word_embedding[w] for w in males[:size_train]+females[:size_train]]\n",
    "    Y_train = [1]*size_train + [0]*size_train\n",
    "    X_test = [word_embedding[w] for w in males[size_train:]+females[size_train:]]\n",
    "    Y_test = [1]*size_test + [0]*size_test\n",
    "\n",
    "    clf = svm.SVC()\n",
    "    clf.fit(X_train, Y_train)\n",
    "\n",
    "    preds = clf.predict(X_test)\n",
    "\n",
    "    accuracy = [1 if y==z else 0 for y,z in zip(preds, Y_test)]\n",
    "    return float(sum(accuracy))/len(accuracy)\n",
    "\n",
    "    \n",
    "# extract most biased words\n",
    "size_train = 500\n",
    "size_test = 2000\n",
    "size = size_train + size_test\n",
    "sorted_g = sorted(word_project.items(), key=operator.itemgetter(1))\n",
    "females = [item[0] for item in sorted_g[:size]]\n",
    "females = [w for w in females if w in word_limited]\n",
    "males = [item[0] for item in sorted_g[-size:]]\n",
    "males = [w for w in males if w in word_limited]\n",
    "for f in females:\n",
    "    assert(word_project[f] < 0)\n",
    "for m in males:\n",
    "    assert(word_project[m] > 0)\n",
    "shuffle(females)\n",
    "shuffle(males)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "951f1b31-f917-453c-97ce-367be806e2f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GBWR classification task : \n",
      "top 25000 female and male, SVM is trained by 10000 words and predict other 40000\n",
      "Good result is lower\n",
      "\n",
      "debias word : 0.72475\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"GBWR classification task : \\ntop 25000 female and male, SVM is trained by 10000 words and predict other 40000\\nGood result is lower\\n\")\n",
    "\n",
    "print('debias word : {}\\n'.format(train_and_predict(debias_word)))"
   ]
  }
 ],
 "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
}
