{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "97f9ed1b-49be-4964-9b3d-b2dceccc39ac",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import gensim.downloader as api\n",
    "from sklearn.decomposition import PCA\n",
    "from matplotlib import pyplot\n",
    "from sklearn.cluster import KMeans\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2d470990-401f-4e08-9da9-3781359b7235",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# load in vectors\n",
    "wv = api.load('glove-wiki-gigaword-50')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 437,
   "id": "18ada073-6429-47a2-8f52-c5cf65289a14",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# load in top-attended words extracted from a certain level of a circuit\n",
    "with open('cdt15/cdt15_h2.json', 'r') as fp:\n",
    "    f = json.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 438,
   "id": "330f0736-3121-492b-94ff-d35c22109360",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# define helpful functions\n",
    "def vectorize(list_of_words, wv, N):\n",
    "    features = {}\n",
    "    dot_sizes = []\n",
    "    cnt = 0\n",
    "    \n",
    "    for item in list_of_words:\n",
    "        if cnt >= N:\n",
    "            break\n",
    "        else:\n",
    "            w, p = item[0], item[1]\n",
    "            if w in wv:\n",
    "                try:\n",
    "                    features[w] = wv[w]\n",
    "                    dot_sizes.append(p*100)\n",
    "                    cnt += 1\n",
    "                except KeyError:\n",
    "                    continue\n",
    "    return features, dot_sizes\n",
    "\n",
    "def plot2D(result, wordgroups, words, dot_sizes):\n",
    "    pyplot.scatter(result[:, axes[0]], result[:, axes[1]], s=dot_sizes, color=defaultcolor, alpha=0.3)\n",
    "    for g, group in enumerate(wordgroups):\n",
    "        for word in group:\n",
    "            if not word in words:\n",
    "                continue\n",
    "            i = words.index(word)\n",
    "            # Create plot point\n",
    "            coord = (result[i, axes[0]], result[i, axes[1]])\n",
    "            color = colors[g] if g < len(colors) else defaultcolor\n",
    "            size = sizes[g] if g < len(sizes) else defaultsize\n",
    "            pyplot.annotate(word, xy=coord, color=color, fontsize=size)\n",
    "            \n",
    "            \n",
    "def get_groups(vecs, clusterK=2):\n",
    "    groups = []\n",
    "\n",
    "    # Assign groups if using clustering\n",
    "    if clusterK > 0:\n",
    "        estimator = KMeans(init='k-means++', n_clusters=clusterK, n_init=10)\n",
    "        estimator.fit_predict(list(vecs.values()))\n",
    "        groups = [[] for n in range(clusterK)]\n",
    "        for i, w in enumerate(vecs.keys()):\n",
    "            group = estimator.labels_[i]\n",
    "            groups[group].append(w)\n",
    "\n",
    "    return groups"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "id": "3835e34b-48d7-4588-af05-5f009a6f73a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# show top-20 words in the plot\n",
    "all_fs, dot_sizes = vectorize(f, wv, N=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "id": "a09850da-c75a-4b43-9ce1-1e0a6cd1cc0b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# PCA axes to plot on, the most relevant are [0,1] or [1,2] for 2D and [0,1,2] or [1,2,3] for 3D\n",
    "axes = [0, 1]\n",
    "\n",
    "# To differentiate groups in the graph, you can give the labels a corresponding color or font size\n",
    "# e.g. words in the first group will be red, words in the second group will be blue, etc.\n",
    "\n",
    "# Color of words in each group, uses default if too many groups\n",
    "# Dark colors are good for matplotlib's white background, use hex or https://matplotlib.org/gallery/color/named_colors.html\n",
    "colors = [\"tab:red\", \"tab:blue\", \"tab:green\", \"tab:orange\",\n",
    "          \"tab:purple\", \"tab:olive\", \"tab:pink\", \"tab:cyan\", \"tab:gray\"]\n",
    "defaultcolor = \"gray\"\n",
    "\n",
    "# Font sizes of words in each group\n",
    "sizes = []\n",
    "defaultsize = 15"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 474,
   "id": "035f9db6-cc5f-4a8b-8912-1baff6b5125a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Get groups from file or by clustering\n",
    "features = all_fs\n",
    "groups = get_groups(features, clusterK=3)\n",
    "\n",
    "coords = list(features.values())\n",
    "\n",
    "# Create axes to plot on\n",
    "pca = PCA(n_components=2)\n",
    "result = pca.fit_transform(coords)\n",
    "\n",
    "words = list(features.keys())\n",
    "# Plot vectors on axes\n",
    "plot2D(result, groups, words, dot_sizes)\n",
    "\n",
    "pyplot.title(\"Word clusters (backtrack 2): CD-T\")\n",
    "pyplot.xlabel(\"PC1\")\n",
    "pyplot.ylabel(\"PC2\")\n",
    "pyplot.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 443,
   "id": "b7ccf03f-61c0-4174-8f61-d5f0326044be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[7.99635281 2.90531288]\n",
      "[0.34240256 0.12440504]\n",
      "[0.34240256 0.4668076 ]\n"
     ]
    }
   ],
   "source": [
    "print(pca.explained_variance_)\n",
    "print(pca.explained_variance_ratio_)\n",
    "print(pca.explained_variance_ratio_.cumsum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "3dc64c8b-fca9-4be7-ac5e-c9bcbcb67d34",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.47\n",
      "0.040311288741492764\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "exp_ratio = [0.48, 0.55, 0.46, 0.48, 0.48, 0.42, 0.41, 0.48]\n",
    "print(np.mean(exp_ratio))\n",
    "print(np.std(exp_ratio))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8cd94bec-54e5-4d1c-a8d9-68b228025e4f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "downgrade",
   "language": "python",
   "name": "downgrade"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
