{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "8b2aa06b-b661-4f2b-8a88-3ba65a0cfa53",
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.colors import LogNorm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "f1911837-5085-48e6-949b-4f6ef857739b",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "\n",
    "for index in [str(i) for i in range(60)]:\n",
    "    with open('./early_stopping_diag_cpu/optimization_' + index + '.txt', 'r') as f:\n",
    "        reader = csv.reader(f,  delimiter='\\t')\n",
    "        for row in reader:\n",
    "            new_row = []\n",
    "            new_row.append(int(row[0]) ** 2)\n",
    "            new_row.append(int(row[1]))\n",
    "            new_row.append(np.log10(float(row[2])))\n",
    "            data.append(new_row)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "433c642f-3dab-4e47-8d71-8ffca204d4cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "for elem in data:\n",
    "    elem[1] = elem[1] - elem[1] % 100\n",
    "    elem[0] = elem[0] - elem[0] % 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "0a09881c-d8e6-4d66-ab74-f13752c20eb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(data=data, columns=(['d2', 'N', 'loss']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "9c25a66b-75b7-4034-a35c-c4a9a60e73a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df.groupby(['d2', 'N']).mean().reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "0865d6fb-44cd-4a54-b3f3-f6efa60c5549",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataframe = df.pivot('N', 'd2', 'loss')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "3ffa7dc2-2985-4650-a080-b534cf987a04",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 259.2x216 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(3.6, 3))\n",
    "ax = sns.heatmap(dataframe, cbar_kws={'label': r'$\\log_{10}L(\\theta_f)$'}, xticklabels=10, yticklabels=10)\n",
    "ax.axes.invert_yaxis()\n",
    "ax.set_xlabel(r'$d^2$')\n",
    "ax.set_ylabel(r'$N$')\n",
    "\n",
    "plt.show()\n",
    "fig.savefig('optimization.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "ed028006-7b44-4e8d-a42e-09f607b3b824",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8248802042343476"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.rand()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bbcd379-67b8-4204-adb2-4aae36623ecd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18a563ab-42de-4740-8bef-f88d32e0d8de",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c7b20f22-40e6-4685-9fc6-a19500c38843",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "94b9df45-0534-4993-a946-db9cf7bd0383",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_eig = []\n",
    "\n",
    "for index in [str(i) for i in range(10)]:\n",
    "    with open('./min_eig_good/min_eig_good_' + index + '.txt', 'r') as f:\n",
    "        reader = csv.reader(f,  delimiter='\\t')\n",
    "        for row in reader:\n",
    "            new_row = []\n",
    "            new_row.append(int(row[0]))\n",
    "            new_row.append(int(row[1]))\n",
    "            new_row.append(float(row[2]))\n",
    "            data_eig.append(new_row)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "72d5cceb-5740-4b5a-a263-0c14caf099f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "for elem in data_eig:\n",
    "    elem[0] = elem[0] ** 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "77e751e4-3669-41c8-9515-dcb7ba453808",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_eig = pd.DataFrame(data=data_eig, columns=(['d', 'N', 'eig']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "id": "34e6fb97-622f-40ae-8881-18462c008833",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 324x216 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_theme(style=\"darkgrid\")\n",
    "\n",
    "fig_eig, ax_eig = plt.subplots(1, 1, figsize=(4.5, 3))\n",
    "ax_eig = sns.lineplot(x='d', y='eig', hue='N', data=df_eig)\n",
    "ax_eig.set_xlabel(r'$d^2$')\n",
    "ax_eig.set_ylabel(r'$\\lambda_{min}(K)$')\n",
    "fig_eig.show()\n",
    "\n",
    "fig_eig.savefig('scaling.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "661ea90c-671e-42b4-9bf5-40e27f7ffc2e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf259ba2-59be-43ba-8e34-201d03e15c62",
   "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.9.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
