{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2276be0b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pickle\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cdef60a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "ctm_A = np.load('../src_CTM/TopicMatrices.npy')\n",
    "pam_A = np.load('../src_PAM/TopicMatrices.npy')\n",
    "\n",
    "with open('../src_LDA/TopicsMatrix.pkl', 'rb') as f:\n",
    "    lda_A = pickle.load(f)\n",
    "\n",
    "with open('../src_pure/TopicsMatrix.pkl', 'rb') as f:\n",
    "    pure_A = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f174d9b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = pure_A\n",
    "\n",
    "max_sum = 0\n",
    "for alpha in range(1,10,2):\n",
    "    A_pinv = np.linalg.pinv(A[alpha-1])\n",
    "    max_sum = 0\n",
    "    for i in range(5000):\n",
    "        max_sum = max(np.sum(np.abs(A_pinv[i,:])), max_sum)\n",
    "    print(alpha, ':', max_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8ca1096",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = lda_A\n",
    "\n",
    "max_sum = 0\n",
    "for alpha in range(1,10,2):\n",
    "    A_pinv = np.linalg.pinv(A[alpha-1])\n",
    "    max_sum = 0\n",
    "    for i in range(5000):\n",
    "        max_sum = max(np.sum(np.abs(A_pinv[i,:])), max_sum)\n",
    "    print(alpha, ':', max_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef676edb",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = ctm_A\n",
    "list1 = []\n",
    "\n",
    "for alpha in range(1,10,2):\n",
    "    A_pinv = np.linalg.pinv(A[alpha-1])\n",
    "    max_sum = 0\n",
    "    for i in range(5000):\n",
    "        max_sum = max(np.sum(np.abs(A_pinv[i,:])), max_sum)\n",
    "    print(alpha, ':', max_sum)\n",
    "    list1.append(max_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14a0c870",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = pam_A\n",
    "list2 = []\n",
    "\n",
    "for alpha in range(1,10,2):\n",
    "    A_pinv = np.linalg.pinv(A[alpha-1])\n",
    "    max_sum = 0\n",
    "    for i in range(5000):\n",
    "        max_sum = max(np.sum(np.abs(A_pinv[i,:])), max_sum)\n",
    "    print(alpha, ':', max_sum)\n",
    "    list2.append(max_sum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9c8887b",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(range(1,10,2), list1, '-o', label='Pure-topic, LDA')\n",
    "#plt.plot(range(1,10,2), list2, '-o', label='CTM, PAM')\n",
    "plt.xticks([1,3,5,7,9])\n",
    "plt.ylim(0,60)\n",
    "plt.xlabel('Alpha')\n",
    "#plt.legend()\n",
    "plt.title('$\\kappa(A^\\dagger)$ for Pure-topic and LDA Model')\n",
    "plt.savefig('Condition_number_pure&lda.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36f434e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "#plt.plot(range(1,10,2), list1, '-o', label='Pure-topic, LDA')\n",
    "plt.plot(range(1,10,2), list2, '-o', label='CTM')\n",
    "plt.xticks([1,3,5,7,9])\n",
    "plt.ylim(0,60)\n",
    "plt.xlabel('Alpha')\n",
    "#plt.legend()\n",
    "plt.title('$\\kappa(A^\\dagger)$ for CTM and PAM')\n",
    "plt.savefig('Condition_number_ctm&pam.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f02687c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
