{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9715da67",
   "metadata": {
    "id": "1a946d4f"
   },
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3edb8da2",
   "metadata": {},
   "source": [
    "### Best TV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f5d66400",
   "metadata": {
    "id": "18f47750"
   },
   "outputs": [],
   "source": [
    "best_tv = np.array([[0.0148, 0.0308, 0.0501, 0.0391, 0.0517],\n",
    "                    [0.0709, 0.0951, 0.1045, 0.1222, 0.1377],\n",
    "                    [0.0550, 0.0799, 0.0970, 0.1071, 0.1101],\n",
    "                    [0.0436, 0.0659, 0.0787, 0.0953, 0.0971]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "eb633dfd",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_tv = pd.DataFrame({'Pure-topic': list(best_tv[0]), 'LDA': list(best_tv[1]), \n",
    "                      'CTM': list(best_tv[2]), 'PAM': list(best_tv[3])})\n",
    "df_tv['alpha'] = pd.Series([1,3,5,7,9])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "41f870ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pure</th>\n",
       "      <th>LDA</th>\n",
       "      <th>CTM</th>\n",
       "      <th>PAM</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0148</td>\n",
       "      <td>0.0709</td>\n",
       "      <td>0.0550</td>\n",
       "      <td>0.0436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0308</td>\n",
       "      <td>0.0951</td>\n",
       "      <td>0.0799</td>\n",
       "      <td>0.0659</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.0501</td>\n",
       "      <td>0.1045</td>\n",
       "      <td>0.0970</td>\n",
       "      <td>0.0787</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.0391</td>\n",
       "      <td>0.1222</td>\n",
       "      <td>0.1071</td>\n",
       "      <td>0.0953</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.0517</td>\n",
       "      <td>0.1377</td>\n",
       "      <td>0.1101</td>\n",
       "      <td>0.0971</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         Pure     LDA     CTM     PAM\n",
       "alpha                                \n",
       "1      0.0148  0.0709  0.0550  0.0436\n",
       "3      0.0308  0.0951  0.0799  0.0659\n",
       "5      0.0501  0.1045  0.0970  0.0787\n",
       "7      0.0391  0.1222  0.1071  0.0953\n",
       "9      0.0517  0.1377  0.1101  0.0971"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_tv = df_tv.set_index('alpha')\n",
    "df_tv.columns = ['Pure', 'LDA', 'CTM', 'PAM']\n",
    "df_tv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4d4f31bd",
   "metadata": {},
   "outputs": [
    {
     "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": [
    "sns.heatmap(df_tv.transpose(), cmap='coolwarm', vmin=0, vmax=0.25)\n",
    "plt.title('Topic Posterior Recovery Loss')\n",
    "plt.savefig('best_tv_all.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ca232ee",
   "metadata": {},
   "source": [
    "### Major Topic Recovery"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ade3d55f",
   "metadata": {},
   "outputs": [],
   "source": [
    "list_MAP = [\n",
    "    [1.0, 1.0, 1.0, 1.0, 1.0],\n",
    "    [0.89, 0.88, 0.895, 0.905, 0.905], \n",
    "    [0.9175, 0.89, 0.8975, 0.8675, 0.885],\n",
    "    [0.9025, 0.895, 0.8675, 0.8675, 0.8325]\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ed333862",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Pure</th>\n",
       "      <th>LDA</th>\n",
       "      <th>CTM</th>\n",
       "      <th>PAM</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.890</td>\n",
       "      <td>0.9175</td>\n",
       "      <td>0.9025</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.880</td>\n",
       "      <td>0.8900</td>\n",
       "      <td>0.8950</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.895</td>\n",
       "      <td>0.8975</td>\n",
       "      <td>0.8675</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.905</td>\n",
       "      <td>0.8675</td>\n",
       "      <td>0.8675</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.905</td>\n",
       "      <td>0.8850</td>\n",
       "      <td>0.8325</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       Pure    LDA     CTM     PAM\n",
       "Alpha                             \n",
       "1       1.0  0.890  0.9175  0.9025\n",
       "3       1.0  0.880  0.8900  0.8950\n",
       "5       1.0  0.895  0.8975  0.8675\n",
       "7       1.0  0.905  0.8675  0.8675\n",
       "9       1.0  0.905  0.8850  0.8325"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_MAP = pd.DataFrame({'Pure': list_MAP[0], 'LDA': list_MAP[1], 'CTM': list_MAP[2], 'PAM': list_MAP[3]})\n",
    "df_MAP['Alpha'] = pd.Series(range(1,10,2))\n",
    "df_MAP = df_MAP.set_index('Alpha')\n",
    "df_MAP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "11188147",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAV0AAAEWCAYAAADFF0QYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAc7ElEQVR4nO3debwcVZ338c/33gQSQthBWcIihCWyKALBgXEYEJ6ACgiPkiuPGkUij4KAjgrPC4XBQXH0GZeRkQnCsIwQMgJj1LCJOCAoBB3WMGBkS4LDHsIOgd/8UedCpbm3q/ve7uruyvedV71S2z31q759f3361KlTigjMzKwcfZ0OwMxsZeKka2ZWIiddM7MSOemamZXISdfMrEROumZmJXLSLYGkTSU9K6m/07EMRdLhkq5qcN8pkm6RpIL9jpH0zdZEaFYdTroFJD0g6WVJ69Ws/09JIWnzojIi4qGIWD0iXm1BPJenBP6spFdSbIPLZ46kzIj4cUTs1+DuXwO+HcUdvM8CDpe0wXA7pNfvuRT7Ekn/0K0fTKMl6dzc7+pJSVdL2rbBn908vVZj2h2ntZ+TbmPuBwYGFyTtAKxWxoFr/9AiYv+UwFcHfgz8/eByRBzV5lg2BP4a+PeifSPiReBy4GMFu+6UzuWvgMOAT44yzFKM8MPh79O5bgwsAc5ubVTWC5x0G3MBKyaPjwPn53eQ9L5U+10maZGkU3LbVqipSNpI0txU41ko6cjcvqdI+omkf5W0DJjRaJCSjkzlPZnK3yi3LSR9TtJ9kh6X9C1JfWnbDEm/ye379lQTe1LSI5L+X9q0L/CHlFAH9/1yqqU+I+keSfvkQvo18L5GYo+IhcANwDtyZb9f0q2Slkq6UdKOuW2TJF0q6TFJT0j6QVrfJ+kkSQ9KelTS+ZLWTNsul3R0zWt2m6RD0vy2ufO+R9KHc/udK+mHkuZJeg74fHpt+nP7HCLptgbO9QVgTs25Dvv+Aa5L/y9NNeV3p5/5pKS7JT0l6UpJmxUd27pARHiqMwEPAO8F7gG2A/qBxcBmQACbp/32AnYg+yDbEXgEODht2zztOyYtXwf8EzCO7A/vMWDvtO0U4BXg4FTW+DqxnQv8XZrfG3gc2BlYFfhH4LrcvgFcC6wDbArcC3wqbZsB/CbNTwT+DHwhxTcRmJq2fQs4I1fmNsAiYKPceW6Z274z8GSd+APYKs1vm457fFp+J/AoMDW95h9Pv4tV0/JtwHeACSnOPdPPfRJYCLwNWB24FLggbfsYcEPu+FOApanMCelcPgGMScd/HJiSe62fBvZIv5dxwAJg/1x5lwFfaOB3NYHsg/y23Pa9aPD9k9YdlM5zuxTvScCNnf578dRATul0AN0+8UbSPQn4BjANuDq90V9PukP83HeB76T51/9ogEnAq8DE3L7fAM5N86eQS5YFseX/kM8m+/o6uG11suS9eVoOYFpu+2eAa9L8DN5IugPAfw5zvLOA03PLW5ElxvcCY4fYfzLwap34A1gGPJfmLwJWTdt+CHytZv97yJoh3k32QTVmiDKvAT6TW94mvQ5jyD5AngM2S9tOA85J84cB19eU9c/AybnX+vya7V8Gfpzm1wGeBzas87t6kSzJv0bWZLVjnddmyPdPbvvlwBG55b50/M06/Tfjqf7k5oXGXQB8hCxBnV+7UdJUSdemr7tPA0cB69XuB2xEVvt7JrfuQbJ2vkGLRhDfRqkcACLiWeCJOuU+mH6m1iTgT8Mc4ymyxDV4jIXAcWQfFI9Kmp1v0kj7Pl0Q985kHxCHkdVqJ6T1mwFfSE0LSyUtTbFtlP5/MCKWD1HeCq9Dmh8DvCW95r8ApqdtA2Tt4oPHm1pzvMOBt+bKqv29/CvwAUkTgA+TJe0/1znXb0fEWmRJ9AWyDwSgqffPoM2A7+VifRIQK/6+rQs56TYoIh4kq50cQPaVtdaFwFxgUkSsCZxJ9kdQ62FgHUkTc+s2Jbuw8vrhRhDiw2R/iACkRLBuTbmTao758BDlLCL7aj6U24Gt8ysi4sKI2JM3mlvy3cS2I2sGqCsyc4DfAl/NxXFaRKyVm1aLiIvStk2HuZq/wutAdp7Lyb6uQ1abHkjtouPImlwGj/cfNcdbPSL+bz7UmriXpJgPAT5K9sFcKCIeAo4lS5rj0+p675+h3g+LgE/XxDs+Im5sJAbrHCfd5hxB1vb63BDbJpLVYF+UtBtZrfhNImIRcCPwDUnj0sWhI8hqTaNxEfAJSe+QtCrwdeCmiHggt88XJa0taRLZH/3FQ5Tzc2BDScdJWlXSRElT07argZ0ljQOQtI2kvdPxXiSrvb2WK+uvyL4GN+p04EhJbyVryjgq1QAlaUK62DQRuJms/ff0tH6cpD1yr8PxkraQtHp6HS7O1YrnkSXlU9P6wXh/Dmwt6aOSxqZpV0nbFcR8PvAlsvbYoT6MhxQRV5N9QMxMq+q9fx4je13zH4ZnAidKejuApDUlfajR41vnOOk2ISL+FBG3DLP5M8Cpkp4hq63NqVPUANlXzIfJLr6cHBG/HGVsvwS+AlxClpC25I2v0YN+CvweuJXsa/abuiylr+D7Ah8A/hv4I1k3MSLiEeBXZBdxILsAdTrZBaf/BjYATgRIifkA4LwmzuEOsouMX0yv85HAD8iaNRaSenJE1t/5A2Rtyg+RXdg8LBVzDlmN8zqybyYvAsfkjvESWXJ8L1ntMn/e+5G9Zg+n8/lmOsd6LiNL4pdFxPONnmvyLeBL6UNr2PdPKvc04IbUnLB7RFyW4putrJfLncD+TR7fOkARHsS83SS9jay3wNjo0AsuKYDJqR12NOVMIUuku9U7F0nHkH1V/tJojtcLJP2J7Kv+qD44beXgO1zKsT3ZhZ+e/4SLiAXArg3s948lhNNxkg4la3P9Vadjsd7g5oU2k/R5YBZwQqdjsdaS9Guyrm2fzbUNW4VIOifdZHPnMNsl6fvKbkq6XdLOhWVWoPJlZtYWkt4DPEvWR3v7IbYfQHbN4ACyLo/fi4iptfvluaZrZjaMiLiOrA/0cA4iS8gREb8D1lI2Rsmw2t6mO37TAVelzawhLzx0Ud0hQxvRTM55cdHsT/NGtz2AWRExq4nDbcyKN80sTuuGvUnGF9LMrFLSOE4NSQm2mSQ7ak66ZlYpKrfVdAkr3um5CSveBfombtM1s0qR+hqeWmAu8LHUi2F34OmC8Tdc0zWzamlRMk1l6SKyYTfXk7QYOBkYCxARZ5LdVn4A2R2Tz5MNDVqXk66ZVUorn/gUEQMF2wP4bDNlOumaWaW0sqbbDk66ZlYpTrpmZiUqufdC05x0zaxSXNM1MyuRk66ZWYn6Wth7oR2cdM2sUlzTNTMrkZOumVmJnHTNzErlpGtmVpq+vu5Oa90dnZlZk3xzhJlZidyma2ZWImnUT/xpq4Y+EiStJukrks5Ky5Mlvb+9oZmZNa/kQcyb1uhR/wV4CXh3Wl4C/F1bIjIzGwXR1/DUCY02L2wZEYdJGgCIiOfV7XV4M1spVaX3wsuSxgMBIGlLspqvmVlXqUrvhZOBK4BJkn4M7AHMaFdQZmYj1uu9F5S1Nq8NHALsDgg4NiIeb3NsZmZN6/kuYxHxmqQvRcQc4BclxGRmNmLdfrmp0eaFX0r6G+Bi4LnBlRHxZFuiMjMboaq06R6W/s8/ajiAtw21s6SZwEyAMWvvwpjVtxpxgGZmzVBfBQYxj4gtmik0ImYBswDGbzoQI4jLzGxkurui21jSlfSxodZHxPmtDcfMbJQq0qa7a25+HLAP8AfASdfMuksVkm5EHJNflrQWMLsdAZmZjUoVmheG8BzQVDuvmVkZoq8CNV1JPyPdAkz2OTIFmNOuoMzMRqwKSRf4dm5+OfBgRCxuQzxmZqPTy226ksYBRwFbAXcAZ0fE8jICMzMbke7OuYU13fOAV4Drgf3JmhWObXdQZmYj1uPNC1MiYgcASWcDN7c/JDOzUejl5gWyWi4AEbG82weSMDOjv7vzVFHS3UnSsjQvYHxaFhARsUZbozMza1Z359z63Ygjoj8i1kjTxIgYk5t3wjWzrhNSw1MRSdMk3SNpoaQThti+maRrJN0u6deSNikqs8vv3TAza1KfGp/qkNQPnMEbnQgGJE2p2e3bwPkRsSNwKvCNwvBGdFJmZt1KTUz17QYsjIj7IuJlsqEPDqrZZwrwqzR/7RDb38RJ18yqRWp4kjRT0i25aWaupI2BRbnlxWld3m1kjzID+CAwUdK69cLr7mcVm5k1q4neC/mxv0fob4AfSJoBXAcsAV6t9wNOumZWLa3r2roEmJRb3iSte11EPEyq6UpaHTg0IpbWK9TNC2ZWLU00LxSYD0yWtIWkVYDpwNwVD6X19Mbjh08Ezikq1EnXzKqlr4mpjjTOzNHAlcDdwJyIuEvSqZIOTLvtBdwj6V7gLcBpReG5ecHMqqWFd85GxDxgXs26r+bmfwL8pJkynXTNrFKix28DNjPrLV0+RoyTrplVS3fnXCddM6uYHh9P18yst6zszQsbT31fuw/REbFKf6dDaDk9/0rxTr3opbo3CFnVdHfOdU3XzCpmTHfffuCka2aVEq7pmpmVyBfSzMxKtLJfSDMzK5VrumZmJeru62hOumZWMf3dnXWddM2sUhp5ym8nOemaWbV0d0XXSdfMKsYX0szMSuTmBTOzEnkQczOz8oSbF8zMSuSka2ZWIrfpmpmVyF3GzMxK5JqumVmJPIi5mVl5uv024KY/EiRNkPRRSb9oR0BmZqPS18TUofAKSVpF0gcl/RvwZ2Bv4My2RmZmNhJS41MH1G1ekLQfMADsB1wLnA/sGhGfKCE2M7Pm9Xg/3SuA64E9I+J+AEnfa3tUZmYj1eNJd2dgOvBLSfcBs4H+tkdlZjZC0eVjL9Rt042IWyPihIjYEjgZeAcwVtLlkmaWEaCZWVO6vE234et3EXFjRBwDbAJ8B9i9bVGZmY1UnxqfOqCwn66kdYGPANumVXcDF0XEVXV+ZiYwE2D9nT/BGm/buwWhmpk1oLtbF+rXdCVtB9wJvAu4F/gjsCtwh6Rthvu5iJgVEbtExC5OuGZWpr6+xqdOKKrpfg04NiLm5FdKOhT4OnBouwIzMxuJViZTSdOA75F1IPhRRJxes31T4DxgrbTPCRExr258BcfcoTbhAkTEJcD2jYduZlYOSQ1PBeX0A2cA+wNTgAFJU2p2OwmYExHvJOvp9U9F8RUl3edGuM3MrCNa2HlhN2BhRNwXES+TdZk9qGafANZI82sCDxcVWtS8sIGkzw+xXsD6RYWbmZWtmZ5g+Yv+yayImJXmNwYW5bYtBqbWFHEKcJWkY4AJwHuLjlmUdM8CJg6z7UdFhZuZlU1NtOmmBDurcMfhDQDnRsT/l/Ru4AJJ20fEa8P9QN2kGxF/O9w2SceNOEwzszZp4T0PS4BJueVN0rq8I4BpABHxW0njgPWAR4crdDTX+YZqdjAz66j+vsanAvOByZK2kLQK2YWyuTX7PATsA693sR0HPFav0NEMYt7lXZDNbGXUqppuRCyXdDRwJVl3sHMi4i5JpwK3RMRc4AvAWZKOJ7uoNiMiol65o0m6dQs2M+uEoq5gzUh9bufVrPtqbn4BsEczZRaNp/sMQydXAeObOZCZWRmauZDWCUUX0obruWBm1pW6/BFpfjClmVVLp8ZUaJSTrplVSpc/OMJJ18yqxc0LZmYlctI1MyuRurx9wUnXzCrFNV0zsxK594KZWYm6vHXBSdfMqsXNC2ZmJerp24DNzHqNa7pmZiVq5Shj7eCka2aV4t4LZmYl6vKKbvuTrp54od2H6Ix1KziccEWHpX9to9U7HULL9T3zcqdD6FruMmZmViInXTOzEvWpu7+yOemaWaWMcU3XzKw8rumamZXIbbpmZiXq8m66TrpmVi2u6ZqZlUhu0zUzK497L5iZlci9F8zMSuQ2XTOzErn3gplZiVzTNTMrkdt0zcxK5N4LZmYlck3XzKxEbtM1MytRtyfdbu9dYWbWlL4mpiKSpkm6R9JCSScMsf07km5N072SlhaVWbemK+n79bZHxOcKozYzK9GYvta06UrqB84A9gUWA/MlzY2IBYP7RMTxuf2PAd5ZGF/B9qOAO4E5wMNAl1fczWxl18Kv77sBCyPiPgBJs4GDgAXD7D8AnFxUaFHS3RD4EHAYsBy4GPhJRCxtLGYzs3I106YraSYwM7dqVkTMSvMbA4ty2xYDU4cpZzNgC+BXRcesm3Qj4gngTOBMSZsA04EFkr4cERcUFW5mVrZmhnZMCXZW4Y7FppNVSF8t2rGh3guSdiarOu8LXA78flThmZm1SQt7LywBJuWWN0nrhjId+GwjhRZdSDsVeB9wNzAbODEiljdSsJlZJ7SwTXc+MFnSFmTJdjrwkdqdJG0LrA38tpFCi2q6JwH3Azul6euSILugFhGxY6PRm5mVoVW9FyJiuaSjgSuBfuCciLgrVUZviYi5adfpwOyIaOjARUl3i5EEm2+cXn+b/8OaG71nJMWYmTWtlTdHRMQ8YF7Nuq/WLJ/STJlFSfesiNivmQJTEK83Tk/e+6zuvhHazCqlv9MBFChKuuuXEoWZWYv0+oA3a0o6ZLiNEXFpi+MxMxuVbh97oTDpAu9n6DvRAnDSNbOu0utJ98GI+GQpkZiZtcDYLh/Gqyi8bSTtUbtS0h6StmxTTGZmI9anaHjqSHwF228Clg2xfhnw3ZZHY2Y2Sn1qfOqEouaFiRFxR+3KiLhD0ubtCcnMbOR6vcvY2nW2jW9lIGZmrdDtF9KKmhfmSzqydqWkT+FBb8ysC43ti4anTiiq6R4HXCbpcN5IsrsAqwAfbGNcZmYj0u013aLxdB8B/kLSXwPbp9W/iIjCgXrNzDqhp5PuoIi4Fri2zbGYmY1aJZKumVmv6O/xsRfMzHpKl9+Q5qRrZtUypsuzrpOumVWKmxfMzErkC2lmZiVy0jUzK5GTrplZiTp1e2+jnHTNrFK6vPOCk66ZVYubF8zMStTvpGtmVp5efwS7mVlPWembF2K1se0+RGcsf63TEbTca+v5YSC9YvmU9TodQtcas7InXTOzMslJ18ysPF2ec510zaxaXNM1MyuRb44wMyuR3GXMzKw8K32XMTOzMnV5zu365g8zs6b0qfGpiKRpku6RtFDSCcPs82FJCyTdJenCojJd0zWzSmlVTVdSP3AGsC+wGJgvaW5ELMjtMxk4EdgjIp6StEFRua7pmlmlSI1PBXYDFkbEfRHxMjAbOKhmnyOBMyLiKYCIeLSoUCddM6uUviYmSTMl3ZKbZuaK2hhYlFtenNblbQ1sLekGSb+TNK0oPjcvmFmlNNN7ISJmAbNGcbgxwGRgL2AT4DpJO0TE0mHjG8XBzMy6jpqYCiwBJuWWN0nr8hYDcyPilYi4H7iXLAkPy0nXzCpFioanAvOByZK2kLQKMB2YW7PPv5PVcpG0Hllzw331CnXSNbNKaVVNNyKWA0cDVwJ3A3Mi4i5Jp0o6MO12JfCEpAXAtcAXI+KJeuW6TdfMKqWVA95ExDxgXs26r+bmA/h8mhripGtmleJnpJmZlajLc66TrplVi8fTNTMrUZfn3PpJV9IzQL5fhdKyyNqQ12hjbGZmTev1oR2vAd4KXArMjoiH2h+SmdnIdXnOrZ90I+JgSWsChwBnSRoHXEyWgJ8sI0Azs2b09fqTIyLiaeBfJJ1HdkfG94FxwD+0OTYzs6b1/IU0SX8BDAB/CfwG+GBEXN/uwMzMRqLLc27hhbQHgKVk40jOBJan9TsDRMQf2huemVlzun1sg6Ka7gNkvRX+F7AfK36IBLB3e8IyMxuZnm5eiIi9htsmaWydbTPJasasv8PHWWPTYYsxM2spdXldt6nolNlH0tlk40gOKSJmRcQuEbGLE66ZlUnqa3jqhIaOKml3Sd8HHgR+ClwHbNvOwMzMRqaFw5i3Qd2kK+nrkv4InAbcDrwTeCwizht8EJuZWTdRE/86oehC2qfIHj/xQ+BnEfGSGhhu3cysc7r7SlpR0t2Q7JnvA8B3JV0LjJc0Jo2qbmbWVTrVVtuoot4LrwJXAFdIWhV4PzAeWCLpmoj4SAkxmpk1rNt7LxTdHDEOOArYiqxN95yIuETSGsDB7Q/PzKw5nWqrbVRR88J5wCvA9cABwBTguIhYBpzf5tjMzEagh2u6wJSI2AEg9c29uf0hmZmNnLr8lrSipPvK4ExELO/2kzEz6/XeCztJWpbmRdZzYRl+coSZdamebtONiP6yAjEzawXR3WnLD6Y0s0rp9mZQJ10zqxgnXTOz0vT0zRFmZr3HNV0zs9L09NgLZma9xs0LZmalcvOCmVlpevrmCDOzXuN+umZmpXKbrplZabr9Qlp3R2dm1iRJDU8NlDVN0j2SFko6YYjtMyQ9JunWNH2qqEzXdM2sYlpTl5TUD5xB9pzIxcB8SXMjYkHNrhdHxNHlRmdm1iVa+Aj23YCFEXFfRLwMzAYOGm18ba/pLvz5jNIuJUqaGRGzyjpeWap4XlU8J6jmefXeOW3dcM6RNBOYmVs1K3euGwOLctsWA1OHKOZQSe8B7gWOj4hFQ+zzuqrVdGcW79KTqnheVTwnqOZ5VfGcAIiIWRGxS25q9sPlZ8DmEbEjcDXZcyXrqlrSNTNrlSXApNzyJmnd6yLiiYh4KS3+CHhXUaFOumZmQ5sPTJa0haRVgOnA3PwOkjbMLR4I3F1UaNV6L/RQu1NTqnheVTwnqOZ5VfGcCqWH8R4NXAn0A+dExF2STgVuiYi5wOckHQgsB54EZhSVq4hoY9hmZpbn5gUzsxI56ZqZlagSSVfSOZIelXRnp2NpFUnjJN0s6TZJd0n6207H1CqSHpB0R7pt8pZOxzNakrbJ3QZ6q6Rlko7rdFytIOlYSXem9+BxnY6nCirRpps6Jj8LnB8R23c6nlZQdmP4hIh4VtJY4DfAsRHxuw6HNmqSHgB2iYjHOx1Lq6VbR5cAUyPiwU7HMxqStie7C2s34GXgCuCoiFjY0cB6XCVquhFxHdmVw8qIzLNpcWyaev8Tsvr2Af7U6wk32Q64KSKej4jlwH8Ah3Q4pp5XiaRbVZL6Jd0KPApcHRE3dTikVgngKkm/T7dhVsl04KJOB9EidwJ/KWldSasBB7DizQI2AlXrp1spEfEq8A5JawGXSdo+IqrQbr1nRCyRtAFwtaT/St9WelrqQH8gcGKnY2mFiLhb0jeBq4DngFuBVzsaVAW4ptsDImIpcC0wrcOhtERELEn/PwpcRtZmWAX7A3+IiEc6HUirRMTZEfGuiHgP8BTZoC42Ck66XUrS+qmGi6TxZGN6/ldHg2oBSRMkTRycB/Yj+xpbBQNUp2kBgPRtBEmbkrXnXtjZiHpfJZoXJF0E7AWsJ2kxcHJEnN3ZqEZtQ+C8dDW8D5gTET/vcEyt8BayphLI3n8XRsQVnQ1p9NIHyL7ApzsdS4tdImld4BXgs+lbl41CJbqMmZn1CjcvmJmVyEnXzKxETrpmZiVy0jUzK5GTrplZiZx0rSUkHSwpJG2bljcvGvWtkX3MqsZJ11plgGwktIFOB2LWzZx0bdQkrQ7sCRxBNuBL7fYZkn4q6deS/ijp5NzmfklnpfFar0p33yHpSEnz03jCl6QBV8x6npOutcJBwBURcS/whKShHkO9G3AosCPwIUm7pPWTgTMi4u3A0rQPwKURsWtE7ET2hNUj2nkCZmVx0rVWGCAb7Jr0/1BNDFdHxBMR8QJwKVnNGOD+iLg1zf8e2DzNby/pekl3AIcDb29H4GZlq8TYC9Y5ktYB9gZ2kBRkj6oO4IyaXWvvNx9cfim37lVgfJo/Fzg4Im6TNINsbA2znuearo3W/wYuiIjNImLziJgE3M+bB7veV9I6qc32YOCGgnInAn9Ojyo6vNVBm3WKk66N1gDZmLh5l/DmgbxvTutvBy6JiKIHUn4FuIksOff8kJZmgzzKmLVdah7YJSKO7nQsZp3mmq6ZWYlc0zUzK5FrumZmJXLSNTMrkZOumVmJnHTNzErkpGtmVqL/AYebhzhVTzdFAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.heatmap(df_MAP.transpose(), cmap='YlGnBu', vmin=0.5, vmax=1.0).set_title('Major Topic(s) Recovery Rate')\n",
    "plt.savefig('major_topic_recovery.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75babc0b",
   "metadata": {},
   "source": [
    "### Best top-k overlap (CTM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2cdd0f11",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>k=2</th>\n",
       "      <th>k=4</th>\n",
       "      <th>k=6</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.9175</td>\n",
       "      <td>0.8513</td>\n",
       "      <td>0.7742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.8900</td>\n",
       "      <td>0.7825</td>\n",
       "      <td>0.6825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.8975</td>\n",
       "      <td>0.7113</td>\n",
       "      <td>0.6250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.8825</td>\n",
       "      <td>0.7063</td>\n",
       "      <td>0.6242</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.8800</td>\n",
       "      <td>0.6638</td>\n",
       "      <td>0.6233</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          k=2     k=4     k=6\n",
       "Alpha                        \n",
       "1      0.9175  0.8513  0.7742\n",
       "3      0.8900  0.7825  0.6825\n",
       "5      0.8975  0.7113  0.6250\n",
       "7      0.8825  0.7063  0.6242\n",
       "9      0.8800  0.6638  0.6233"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np_top_k_ctm = np.array([[0.9175, 0.89, 0.8975, 0.8825, 0.88],\n",
    "                     [0.8513, 0.7825, 0.7113, 0.7063, 0.6638],\n",
    "                     [0.7742, 0.6825, 0.625, 0.6242, 0.6233]])\n",
    "\n",
    "df_top_k_ctm = pd.DataFrame({'k=2': list(np_top_k_ctm[0]), 'k=4': list(np_top_k_ctm[1]), 'k=6': list(np_top_k_ctm[2])})\n",
    "df_top_k_ctm['Alpha'] = pd.Series([1,3,5,7,9])\n",
    "df_top_k_ctm = df_top_k_ctm.set_index('Alpha')\n",
    "df_top_k_ctm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d5866e80",
   "metadata": {},
   "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": [
    "plt.plot(range(1,10,2), df_top_k_ctm['k=2'], '-o', label='k=2')\n",
    "plt.plot(range(1,10,2), df_top_k_ctm['k=4'], '-o', label='k=4')\n",
    "plt.plot(range(1,10,2), df_top_k_ctm['k=6'], '-o', label='k=6')\n",
    "plt.legend()\n",
    "plt.ylim([0.0, 1.0])\n",
    "plt.xticks(range(1,10,2))\n",
    "plt.xlabel('Alpha')\n",
    "plt.ylabel('Top-k Topics Overlap Rate')\n",
    "plt.title('Top-k Topic Recovery for CTM documents')\n",
    "plt.savefig('Top-k_topic_recovery_CTM.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6cc589dc",
   "metadata": {},
   "source": [
    "### Best top-k Overlap (PAM)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0b686d32",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>k=2</th>\n",
       "      <th>k=4</th>\n",
       "      <th>k=6</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Alpha</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.9025</td>\n",
       "      <td>0.8850</td>\n",
       "      <td>0.7942</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.8950</td>\n",
       "      <td>0.8200</td>\n",
       "      <td>0.7300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.8675</td>\n",
       "      <td>0.8113</td>\n",
       "      <td>0.7100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.8675</td>\n",
       "      <td>0.7338</td>\n",
       "      <td>0.6825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.8325</td>\n",
       "      <td>0.6950</td>\n",
       "      <td>0.6208</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          k=2     k=4     k=6\n",
       "Alpha                        \n",
       "1      0.9025  0.8850  0.7942\n",
       "3      0.8950  0.8200  0.7300\n",
       "5      0.8675  0.8113  0.7100\n",
       "7      0.8675  0.7338  0.6825\n",
       "9      0.8325  0.6950  0.6208"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np_top_k_pam = np.array([[0.9025, 0.895, 0.8675, 0.8675, 0.8325],\n",
    "                     [0.885, 0.82, 0.8113, 0.7338, 0.695],\n",
    "                     [0.7942, 0.73, 0.71, 0.6825, 0.6208]])\n",
    "\n",
    "df_top_k_pam = pd.DataFrame({'k=2': list(np_top_k_pam[0]), 'k=4': list(np_top_k_pam[1]), 'k=6': list(np_top_k_pam[2])})\n",
    "df_top_k_pam['Alpha'] = pd.Series([1,3,5,7,9])\n",
    "df_top_k_pam = df_top_k_pam.set_index('Alpha')\n",
    "df_top_k_pam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d5fbeadb",
   "metadata": {},
   "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": [
    "plt.plot(range(1,10,2), df_top_k_pam['k=2'], '-o', label='k=2')\n",
    "plt.plot(range(1,10,2), df_top_k_pam['k=4'], '-o', label='k=4')\n",
    "plt.plot(range(1,10,2), df_top_k_pam['k=6'], '-o', label='k=6')\n",
    "plt.legend()\n",
    "plt.ylim([0.0, 1.0])\n",
    "plt.xticks(range(1,10,2))\n",
    "plt.xlabel('Alpha')\n",
    "plt.ylabel('Top-k Topics Overlap Rate')\n",
    "plt.title('Top-k Topic Recovery for PAM documents')\n",
    "plt.savefig('Top-k_topic_recovery_PAM.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "56812f79",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "name": "Untitled.ipynb",
   "provenance": []
  },
  "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
