{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7cac932d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "import re\n",
    "\n",
    "import sys\n",
    "sys.path.append('..')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e2d4e935",
   "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>Unnamed: 0</th>\n",
       "      <th>step</th>\n",
       "      <th>Best/Test/avg_ll</th>\n",
       "      <th>Best/Test/bpd</th>\n",
       "      <th>Best/Test/ppl</th>\n",
       "      <th>Best/Test/std_ll</th>\n",
       "      <th>Best/Train/avg_ll</th>\n",
       "      <th>Best/Train/bpd</th>\n",
       "      <th>Best/Train/epoch</th>\n",
       "      <th>Best/Train/ppl</th>\n",
       "      <th>...</th>\n",
       "      <th>Loss</th>\n",
       "      <th>Test/avg_ll</th>\n",
       "      <th>Test/bpd</th>\n",
       "      <th>Valid/bpd</th>\n",
       "      <th>Valid/ll</th>\n",
       "      <th>diverged</th>\n",
       "      <th>log Z</th>\n",
       "      <th>num_params</th>\n",
       "      <th>num_sum_params</th>\n",
       "      <th>dir_name</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>285</td>\n",
       "      <td>0</td>\n",
       "      <td>-1924.495117</td>\n",
       "      <td>3.541402</td>\n",
       "      <td>inf</td>\n",
       "      <td>530.495178</td>\n",
       "      <td>-1859.240601</td>\n",
       "      <td>3.421323</td>\n",
       "      <td>282.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>33465684.0</td>\n",
       "      <td>9381204.0</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>588</td>\n",
       "      <td>0</td>\n",
       "      <td>-1940.020752</td>\n",
       "      <td>3.569972</td>\n",
       "      <td>inf</td>\n",
       "      <td>537.625061</td>\n",
       "      <td>-1878.580322</td>\n",
       "      <td>3.456911</td>\n",
       "      <td>269.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>33465684.0</td>\n",
       "      <td>9381204.0</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>880</td>\n",
       "      <td>0</td>\n",
       "      <td>-1917.598755</td>\n",
       "      <td>3.528712</td>\n",
       "      <td>inf</td>\n",
       "      <td>529.408203</td>\n",
       "      <td>-1859.192627</td>\n",
       "      <td>3.421235</td>\n",
       "      <td>255.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>33465684.0</td>\n",
       "      <td>9381204.0</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1183</td>\n",
       "      <td>0</td>\n",
       "      <td>-1896.919556</td>\n",
       "      <td>3.490659</td>\n",
       "      <td>inf</td>\n",
       "      <td>524.003174</td>\n",
       "      <td>-1826.462158</td>\n",
       "      <td>3.361005</td>\n",
       "      <td>299.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>45110596.0</td>\n",
       "      <td>16209220.0</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1477</td>\n",
       "      <td>0</td>\n",
       "      <td>-1903.659424</td>\n",
       "      <td>3.503061</td>\n",
       "      <td>inf</td>\n",
       "      <td>523.447876</td>\n",
       "      <td>-1829.276611</td>\n",
       "      <td>3.366184</td>\n",
       "      <td>291.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>45110596.0</td>\n",
       "      <td>16209220.0</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 25 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0  step  Best/Test/avg_ll  Best/Test/bpd  Best/Test/ppl  \\\n",
       "0         285     0      -1924.495117       3.541402            inf   \n",
       "1         588     0      -1940.020752       3.569972            inf   \n",
       "2         880     0      -1917.598755       3.528712            inf   \n",
       "3        1183     0      -1896.919556       3.490659            inf   \n",
       "4        1477     0      -1903.659424       3.503061            inf   \n",
       "\n",
       "   Best/Test/std_ll  Best/Train/avg_ll  Best/Train/bpd  Best/Train/epoch  \\\n",
       "0        530.495178       -1859.240601        3.421323             282.0   \n",
       "1        537.625061       -1878.580322        3.456911             269.0   \n",
       "2        529.408203       -1859.192627        3.421235             255.0   \n",
       "3        524.003174       -1826.462158        3.361005             299.0   \n",
       "4        523.447876       -1829.276611        3.366184             291.0   \n",
       "\n",
       "   Best/Train/ppl  ...  Loss  Test/avg_ll  Test/bpd  Valid/bpd  Valid/ll  \\\n",
       "0             inf  ...   NaN          NaN       NaN        NaN       NaN   \n",
       "1             inf  ...   NaN          NaN       NaN        NaN       NaN   \n",
       "2             inf  ...   NaN          NaN       NaN        NaN       NaN   \n",
       "3             inf  ...   NaN          NaN       NaN        NaN       NaN   \n",
       "4             inf  ...   NaN          NaN       NaN        NaN       NaN   \n",
       "\n",
       "   diverged  log Z  num_params  num_sum_params  \\\n",
       "0       0.0    NaN  33465684.0       9381204.0   \n",
       "1       0.0    NaN  33465684.0       9381204.0   \n",
       "2       0.0    NaN  33465684.0       9381204.0   \n",
       "3       0.0    NaN  45110596.0      16209220.0   \n",
       "4       0.0    NaN  45110596.0      16209220.0   \n",
       "\n",
       "                                            dir_name  \n",
       "0  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...  \n",
       "1  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...  \n",
       "2  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...  \n",
       "3  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...  \n",
       "4  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...  \n",
       "\n",
       "[5 rows x 25 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv('image-results.csv')\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8fdc5a1a",
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">Best/Valid/bpd</th>\n",
       "      <th colspan=\"2\" halign=\"left\">num_params</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>prod</th>\n",
       "      <th>circuit</th>\n",
       "      <th>rg</th>\n",
       "      <th>nunits</th>\n",
       "      <th>optim</th>\n",
       "      <th>config</th>\n",
       "      <th>id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">FashionMNIST</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">cp</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">OSOS</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">qt</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">128</th>\n",
       "      <th>LandingAdam</th>\n",
       "      <th>LandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <td>3.874807</td>\n",
       "      <td>0.000408</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>3.951786</td>\n",
       "      <td>0.009000</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>3.943281</td>\n",
       "      <td>0.006509</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">16</th>\n",
       "      <th>LandingAdam</th>\n",
       "      <th>LandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K16_KI16_OLandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <td>3.836804</td>\n",
       "      <td>0.001649</td>\n",
       "      <td>6557728.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K16_KI16_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>3.889869</td>\n",
       "      <td>0.003115</td>\n",
       "      <td>6557728.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">MNIST</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">tucker</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">OSOS</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">qt</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>1.302889</td>\n",
       "      <td>0.002232</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs-experimental/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.759107</td>\n",
       "      <td>0.005913</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.244175</td>\n",
       "      <td>0.002570</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGDog</th>\n",
       "      <th>LandingSGDog_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGDog_LR0.001_BS512_LA0.1</th>\n",
       "      <td>1.621085</td>\n",
       "      <td>0.003158</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGDog_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGDog_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.759107</td>\n",
       "      <td>0.005913</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>195 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                       Best/Valid/bpd  \\\n",
       "                                                                                                                                                 mean   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                                  \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.874807   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.951786   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.943281   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.836804   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.889869   \n",
       "...                                                                                                                                               ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.302889   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...       1.759107   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.244175   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.621085   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.759107   \n",
       "\n",
       "                                                                                                                                                  \\\n",
       "                                                                                                                                             std   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                             \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.000408   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.009000   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.006509   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.001649   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.003115   \n",
       "...                                                                                                                                          ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.002232   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  0.005913   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.002570   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.003158   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.005913   \n",
       "\n",
       "                                                                                                                                        num_params  \\\n",
       "                                                                                                                                              mean   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                               \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...   6557728.0   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...   6557728.0   \n",
       "...                                                                                                                                            ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  20133888.0   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "\n",
       "                                                                                                                                             \n",
       "                                                                                                                                        std  \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                       \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "...                                                                                                                                     ...  \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  0.0  \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "\n",
       "[195 rows x 4 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "colname = 'Best/Valid/bpd'\n",
    "\n",
    "agg_cols = [colname, 'num_params']\n",
    "\n",
    "ndf = df[['dir_name'] + agg_cols].copy()\n",
    "ndf['id'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('_')])\n",
    "\n",
    "ndf['dir_name'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('/')])\n",
    "\n",
    "ndf['nunits'] = ndf['dir_name'].apply(lambda s: re.search(r'_K(\\d+)_', s).group(1))\n",
    "ndf['circuit'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(O?SOS)\\/', s).group(1))\n",
    "ndf['dataset'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/((Fashion)?MNIST)\\/', s).group(1))\n",
    "ndf['optim'] = ndf['dir_name'].apply(lambda s: re.search(r'_O([^_]*)', s).group(1))\n",
    "ndf['config'] = ndf['dir_name'].apply(lambda s: re.search(r'_O(.*)_SEED', s).group(1))\n",
    "ndf['prod'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(cp|tucker)\\/', s).group(1))\n",
    "ndf['seed'] = ndf['dir_name'].apply(lambda s: re.search(r'SEED(.*)', s).group(1))\n",
    "ndf['rg'] = ndf['dir_name'].apply(lambda s: re.search(r'RG([^_]*)_', s).group(1))\n",
    "\n",
    "ndf = ndf.groupby(['dataset', 'prod', 'circuit', 'rg', 'nunits', 'optim', 'config', 'id']).agg({k: ['mean', 'std'] for k in agg_cols})\n",
    "ndf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e4640c32",
   "metadata": {},
   "outputs": [],
   "source": [
    "ndf = ndf.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fc408040",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "55"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_configs = []\n",
    "best_ids = []\n",
    "\n",
    "for c in ndf['circuit'].unique():\n",
    "    for p in ndf['prod'].unique():\n",
    "        for n in ndf['nunits'].unique():\n",
    "            for d in ndf['dataset'].unique():\n",
    "                for r in ndf['rg'].unique():\n",
    "                    mask = (ndf['prod'] == p) & (ndf['circuit'] == c) & (ndf['dataset'] == d) & (ndf['nunits'] == n) & (ndf['rg'] == r)\n",
    "                    if mask.sum() > 0:\n",
    "                        best_configs.append(ndf[mask][ndf[mask][(colname, 'mean')] == ndf[mask][(colname, 'mean')].min()].index[0])\n",
    "                        best_ids.append(ndf[mask][ndf[mask][(colname, 'mean')] == ndf[mask][(colname, 'mean')].min()]['id'].iloc[0])\n",
    "\n",
    "len(best_configs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "5ba96f40",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "165\n"
     ]
    },
    {
     "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>Unnamed: 0</th>\n",
       "      <th>step</th>\n",
       "      <th>Best/Test/avg_ll</th>\n",
       "      <th>Best/Test/bpd</th>\n",
       "      <th>Best/Test/ppl</th>\n",
       "      <th>Best/Test/std_ll</th>\n",
       "      <th>Best/Train/avg_ll</th>\n",
       "      <th>Best/Train/bpd</th>\n",
       "      <th>Best/Train/epoch</th>\n",
       "      <th>Best/Train/ppl</th>\n",
       "      <th>...</th>\n",
       "      <th>dir_name</th>\n",
       "      <th>id</th>\n",
       "      <th>nunits</th>\n",
       "      <th>circuit</th>\n",
       "      <th>dataset</th>\n",
       "      <th>optim</th>\n",
       "      <th>config</th>\n",
       "      <th>prod</th>\n",
       "      <th>seed</th>\n",
       "      <th>rg</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>285</td>\n",
       "      <td>0</td>\n",
       "      <td>-1924.495117</td>\n",
       "      <td>3.541402</td>\n",
       "      <td>inf</td>\n",
       "      <td>530.495178</td>\n",
       "      <td>-1859.240601</td>\n",
       "      <td>3.421323</td>\n",
       "      <td>282.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>12041</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>588</td>\n",
       "      <td>0</td>\n",
       "      <td>-1940.020752</td>\n",
       "      <td>3.569972</td>\n",
       "      <td>inf</td>\n",
       "      <td>537.625061</td>\n",
       "      <td>-1878.580322</td>\n",
       "      <td>3.456911</td>\n",
       "      <td>269.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>42</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>880</td>\n",
       "      <td>0</td>\n",
       "      <td>-1917.598755</td>\n",
       "      <td>3.528712</td>\n",
       "      <td>inf</td>\n",
       "      <td>529.408203</td>\n",
       "      <td>-1859.192627</td>\n",
       "      <td>3.421235</td>\n",
       "      <td>255.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>84686</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1183</td>\n",
       "      <td>0</td>\n",
       "      <td>-1896.919556</td>\n",
       "      <td>3.490659</td>\n",
       "      <td>inf</td>\n",
       "      <td>524.003174</td>\n",
       "      <td>-1826.462158</td>\n",
       "      <td>3.361005</td>\n",
       "      <td>299.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>12</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>12041</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1477</td>\n",
       "      <td>0</td>\n",
       "      <td>-1903.659424</td>\n",
       "      <td>3.503061</td>\n",
       "      <td>inf</td>\n",
       "      <td>523.447876</td>\n",
       "      <td>-1829.276611</td>\n",
       "      <td>3.366184</td>\n",
       "      <td>291.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>12</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>42</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 34 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0  step  Best/Test/avg_ll  Best/Test/bpd  Best/Test/ppl  \\\n",
       "0         285     0      -1924.495117       3.541402            inf   \n",
       "1         588     0      -1940.020752       3.569972            inf   \n",
       "2         880     0      -1917.598755       3.528712            inf   \n",
       "3        1183     0      -1896.919556       3.490659            inf   \n",
       "4        1477     0      -1903.659424       3.503061            inf   \n",
       "\n",
       "   Best/Test/std_ll  Best/Train/avg_ll  Best/Train/bpd  Best/Train/epoch  \\\n",
       "0        530.495178       -1859.240601        3.421323             282.0   \n",
       "1        537.625061       -1878.580322        3.456911             269.0   \n",
       "2        529.408203       -1859.192627        3.421235             255.0   \n",
       "3        524.003174       -1826.462158        3.361005             299.0   \n",
       "4        523.447876       -1829.276611        3.366184             291.0   \n",
       "\n",
       "   Best/Train/ppl  ...                                           dir_name  \\\n",
       "0             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "1             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "2             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "3             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "4             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "\n",
       "                                                  id  nunits  circuit  \\\n",
       "0  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "1  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "2  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "3  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      12     OSOS   \n",
       "4  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      12     OSOS   \n",
       "\n",
       "        dataset        optim                          config    prod   seed  \\\n",
       "0  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  12041   \n",
       "1  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker     42   \n",
       "2  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  84686   \n",
       "3  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  12041   \n",
       "4  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker     42   \n",
       "\n",
       "      rg  \n",
       "0  dl-qg  \n",
       "1  dl-qg  \n",
       "2  dl-qg  \n",
       "3  dl-qg  \n",
       "4  dl-qg  \n",
       "\n",
       "[5 rows x 34 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "colname = 'Best/Valid/bpd'\n",
    "\n",
    "ndf = df.copy()\n",
    "ndf['id'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('_')])\n",
    "\n",
    "ndf['dir_name'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('/')])\n",
    "\n",
    "ndf['nunits'] = ndf['dir_name'].apply(lambda s: re.search(r'_K(\\d+)_', s).group(1))\n",
    "ndf['circuit'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(O?SOS)\\/', s).group(1))\n",
    "ndf['dataset'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/((Fashion)?MNIST)\\/', s).group(1))\n",
    "ndf['optim'] = ndf['dir_name'].apply(lambda s: re.search(r'_O([^_]*)', s).group(1))\n",
    "ndf['config'] = ndf['dir_name'].apply(lambda s: re.search(r'_O(.*)_SEED', s).group(1))\n",
    "ndf['prod'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(cp|tucker)\\/', s).group(1))\n",
    "ndf['seed'] = ndf['dir_name'].apply(lambda s: re.search(r'SEED(.*)', s).group(1))\n",
    "ndf['rg'] = ndf['dir_name'].apply(lambda s: re.search(r'RG([^_]*)_', s).group(1))\n",
    "\n",
    "ndf = ndf[ndf['id'].isin(best_ids)]\n",
    "\n",
    "print(len(ndf))\n",
    "\n",
    "ndf.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1631d919",
   "metadata": {},
   "outputs": [],
   "source": [
    "type_to_label = {\n",
    "    'OSOS tucker LandingRAdam qt': r'$\\perp_\\mathbb{C}^2$',\n",
    "    'SOS cp Adam qt': r'$\\pm_\\mathbb{C}^2$',\n",
    "    'OSOS tucker LandingAdam dl-qg': r'$\\perp_\\mathbb{C}^2 \\cdot$',\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "90c8c1b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#1f77b4;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ff7f0e;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#2ca02c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#d62728;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#9467bd;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c564b;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#e377c2;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#7f7f7f;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#bcbd22;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#17becf;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.12156862745098039, 0.4666666666666667, 0.7058823529411765),\n",
       " (1.0, 0.4980392156862745, 0.054901960784313725),\n",
       " (0.17254901960784313, 0.6274509803921569, 0.17254901960784313),\n",
       " (0.8392156862745098, 0.15294117647058825, 0.1568627450980392),\n",
       " (0.5803921568627451, 0.403921568627451, 0.7411764705882353),\n",
       " (0.5490196078431373, 0.33725490196078434, 0.29411764705882354),\n",
       " (0.8901960784313725, 0.4666666666666667, 0.7607843137254902),\n",
       " (0.4980392156862745, 0.4980392156862745, 0.4980392156862745),\n",
       " (0.7372549019607844, 0.7411764705882353, 0.13333333333333333),\n",
       " (0.09019607843137255, 0.7450980392156863, 0.8117647058823529)]"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def_palette = sns.color_palette()\n",
    "\n",
    "palette_dict = {\n",
    "    type_to_label['SOS cp Adam qt']: def_palette[1],\n",
    "    type_to_label['OSOS tucker LandingAdam dl-qg']: def_palette[7],\n",
    "    type_to_label['OSOS tucker LandingRAdam qt']: def_palette[2],\n",
    "}\n",
    "\n",
    "def_palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47921ddf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x137.5 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import bundles, figsizes\n",
    "import matplotlib.ticker as tck\n",
    "\n",
    "plt.rcParams.update(bundles.iclr2024(usetex=True))\n",
    "plt.rcParams.update(figsizes.iclr2024(nrows=1, ncols=2, rel_width=.5, height_to_width_ratio=1.))\n",
    "\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{amssymb,amsmath}')\n",
    "\n",
    "datasets = ['MNIST', 'FashionMNIST']\n",
    "\n",
    "fig, axes = plt.subplots(1, 2)\n",
    "\n",
    "for i, (dataset, ax) in enumerate(zip(datasets, axes.flat)):\n",
    "\n",
    "    colx = 'num_params'\n",
    "    \n",
    "    coly = colname\n",
    "    coly = 'Best/Test/bpd'\n",
    "\n",
    "    # colh = 'id' # TODO \n",
    "    colh = 'circuit' # TODO \n",
    "\n",
    "    plot_df = ndf[ndf['dataset'] == dataset].copy()\n",
    "    plot_df['id'] = plot_df['circuit'] + ' ' + plot_df['prod'] + ' ' + plot_df['optim'] + ' ' + plot_df['rg']\n",
    "\n",
    "    plot_df = plot_df[~((plot_df['circuit'] == 'OSOS') & (plot_df['prod'] == 'cp'))]\n",
    "\n",
    "    plot_df['id'] = plot_df['id'].apply(lambda k: type_to_label[k])\n",
    "    from pandas.api.types import CategoricalDtype\n",
    "    cat_type = CategoricalDtype(categories=list([x for x in type_to_label.values() if x in plot_df['id'].unique()]), ordered=True)\n",
    "\n",
    "    plot_df['id'] = plot_df['id'].astype(cat_type)\n",
    "\n",
    "    colh = 'id'\n",
    "\n",
    "    sns.lineplot(\n",
    "        plot_df,\n",
    "        x=colx,\n",
    "        y=coly,\n",
    "        hue=colh,\n",
    "        style=colh,\n",
    "        legend='brief' if i == 1 else False,\n",
    "        errorbar=('ci', 100),\n",
    "        alpha=0.7,\n",
    "        ax=ax,\n",
    "        markers=True,\n",
    "        palette=palette_dict,   \n",
    "        style_order=[\n",
    "            type_to_label['OSOS tucker LandingRAdam qt'],\n",
    "            type_to_label['SOS cp Adam qt'],\n",
    "            type_to_label['OSOS tucker LandingAdam dl-qg']\n",
    "        ]\n",
    "    )\n",
    "\n",
    "    ax.grid(linestyle=\"--\", which=\"major\", alpha=0.3, linewidth=0.5)\n",
    "    ax.grid(linestyle=\"--\", which=\"minor\", alpha=0.3, linewidth=0.3)\n",
    "    ax.yaxis.set_minor_locator(tck.AutoMinorLocator())\n",
    "\n",
    "    ax.set_xscale(\"log\")\n",
    "    if i == 1:\n",
    "        handles, labels = ax.get_legend_handles_labels()\n",
    "        axes[0].legend(\n",
    "            loc=\"best\",\n",
    "            handles=handles[:-1],\n",
    "            labels=labels[:-1],\n",
    "            ncols=1,\n",
    "            alignment=\"left\",\n",
    "            handletextpad=0.25,\n",
    "        )\n",
    "\n",
    "        axes[1].legend(\n",
    "            loc=\"best\",\n",
    "            handles=handles[-1:],\n",
    "            labels=labels[:1],\n",
    "            title_fontsize=5,\n",
    "            title=r\"non-str-dec\",\n",
    "            ncols=1,\n",
    "            alignment=\"left\",\n",
    "            handletextpad=0.25,\n",
    "        )\n",
    "\n",
    "    ax.set_title(dataset)\n",
    "    ax.set_ylabel(\"test bpd\" if i == 0 else None)\n",
    "    ax.set_xlabel(None)\n",
    "\n",
    "fig.text(0.0, 0.05, r'\\#\\,parameters', fontsize='x-small', fontweight=plt.rcParams['figure.labelweight'], usetex=True)\n",
    "\n",
    "fig.savefig(f'bpd-curves-both.pdf', dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d2a4835",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "c7f524f3",
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">Best/Valid/bpd</th>\n",
       "      <th colspan=\"2\" halign=\"left\">num_params</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>prod</th>\n",
       "      <th>circuit</th>\n",
       "      <th>rg</th>\n",
       "      <th>nunits</th>\n",
       "      <th>optim</th>\n",
       "      <th>config</th>\n",
       "      <th>id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">FashionMNIST</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">cp</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">OSOS</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">qt</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">128</th>\n",
       "      <th>LandingAdam</th>\n",
       "      <th>LandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <td>3.874807</td>\n",
       "      <td>0.000408</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>3.951786</td>\n",
       "      <td>0.009000</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K128_KI128_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>3.943281</td>\n",
       "      <td>0.006509</td>\n",
       "      <td>60031232.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">16</th>\n",
       "      <th>LandingAdam</th>\n",
       "      <th>LandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K16_KI16_OLandingAdam_LR0.05_BS512_LA0.1</th>\n",
       "      <td>3.836804</td>\n",
       "      <td>0.001649</td>\n",
       "      <td>6557728.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGqt_R1_K16_KI16_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>3.889869</td>\n",
       "      <td>0.003115</td>\n",
       "      <td>6557728.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">MNIST</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">tucker</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">OSOS</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">qt</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">LandingSGD</th>\n",
       "      <th>LandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.001_BS512_LA0.1</th>\n",
       "      <td>1.302889</td>\n",
       "      <td>0.002232</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs-experimental/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.759107</td>\n",
       "      <td>0.005913</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGD_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.244175</td>\n",
       "      <td>0.002570</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">LandingSGDog</th>\n",
       "      <th>LandingSGDog_LR0.001_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGDog_LR0.001_BS512_LA0.1</th>\n",
       "      <td>1.621085</td>\n",
       "      <td>0.003158</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LandingSGDog_LR0.01_BS512_LA0.1</th>\n",
       "      <th>image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R1_K8_KI8_OLandingSGDog_LR0.01_BS512_LA0.1</th>\n",
       "      <td>1.759107</td>\n",
       "      <td>0.005913</td>\n",
       "      <td>20133888.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>195 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                       Best/Valid/bpd  \\\n",
       "                                                                                                                                                 mean   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                                  \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.874807   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.951786   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.943281   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.836804   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...       3.889869   \n",
       "...                                                                                                                                               ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.302889   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...       1.759107   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.244175   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.621085   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...       1.759107   \n",
       "\n",
       "                                                                                                                                                  \\\n",
       "                                                                                                                                             std   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                             \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.000408   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.009000   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.006509   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.001649   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.003115   \n",
       "...                                                                                                                                          ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.002232   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  0.005913   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.002570   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.003158   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.005913   \n",
       "\n",
       "                                                                                                                                        num_params  \\\n",
       "                                                                                                                                              mean   \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                               \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  60031232.0   \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...   6557728.0   \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...   6557728.0   \n",
       "...                                                                                                                                            ...   \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  20133888.0   \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  20133888.0   \n",
       "\n",
       "                                                                                                                                             \n",
       "                                                                                                                                        std  \n",
       "dataset      prod   circuit rg nunits optim        config                           id                                                       \n",
       "FashionMNIST cp     OSOS    qt 128    LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                               16     LandingAdam  LandingAdam_LR0.05_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "                                      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/FashionMNIST/OSOS/cp/OSOS-C_RGq...  0.0  \n",
       "...                                                                                                                                     ...  \n",
       "MNIST        tucker OSOS    qt 8      LandingSGD   LandingSGD_LR0.001_BS512_LA0.1   image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                                   LandingSGD_LR0.01_BS512_LA0.1    image-osos-npcs-experimental/MNIST/OSOS/tucker/...  0.0  \n",
       "                                                                                    image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                      LandingSGDog LandingSGDog_LR0.001_BS512_LA0.1 image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "                                                   LandingSGDog_LR0.01_BS512_LA0.1  image-osos-npcs/MNIST/OSOS/tucker/OSOS-C_RGqt_R...  0.0  \n",
       "\n",
       "[195 rows x 4 columns]"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "colname = 'Best/Valid/bpd'\n",
    "\n",
    "agg_cols = [colname, 'num_params']\n",
    "\n",
    "ndf = df[['dir_name'] + agg_cols].copy()\n",
    "ndf['id'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('_')])\n",
    "\n",
    "ndf['dir_name'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('/')])\n",
    "\n",
    "ndf['nunits'] = ndf['dir_name'].apply(lambda s: re.search(r'_K(\\d+)_', s).group(1))\n",
    "ndf['circuit'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(O?SOS)\\/', s).group(1))\n",
    "ndf['dataset'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/((Fashion)?MNIST)\\/', s).group(1))\n",
    "ndf['optim'] = ndf['dir_name'].apply(lambda s: re.search(r'_O([^_]*)', s).group(1))\n",
    "ndf['config'] = ndf['dir_name'].apply(lambda s: re.search(r'_O(.*)_SEED', s).group(1))\n",
    "ndf['prod'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(cp|tucker)\\/', s).group(1))\n",
    "ndf['seed'] = ndf['dir_name'].apply(lambda s: re.search(r'SEED(.*)', s).group(1))\n",
    "ndf['rg'] = ndf['dir_name'].apply(lambda s: re.search(r'RG([^_]*)_', s).group(1))\n",
    "\n",
    "ndf = ndf.groupby(['dataset', 'prod', 'circuit', 'rg', 'nunits', 'optim', 'config', 'id']).agg({k: ['mean', 'std'] for k in agg_cols})\n",
    "ndf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "18783289",
   "metadata": {},
   "outputs": [],
   "source": [
    "ndf = ndf.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "fdf238b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "119"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_configs = []\n",
    "best_ids = []\n",
    "\n",
    "for c in ndf['circuit'].unique():\n",
    "    for p in ndf['prod'].unique():\n",
    "        for n in ndf['nunits'].unique():\n",
    "            for d in ndf['dataset'].unique():\n",
    "                for r in ndf['rg'].unique():\n",
    "                    for o in ndf['optim'].unique():\n",
    "                        mask = (ndf['prod'] == p) & (ndf['circuit'] == c) & (ndf['dataset'] == d) & (ndf['nunits'] == n) & (ndf['rg'] == r) & (ndf['optim'] == o)\n",
    "                        if mask.sum() > 0:\n",
    "                            best_configs.append(ndf[mask][ndf[mask][(colname, 'mean')] == ndf[mask][(colname, 'mean')].min()].index[0])\n",
    "                            best_ids.append(ndf[mask][ndf[mask][(colname, 'mean')] == ndf[mask][(colname, 'mean')].min()]['id'].iloc[0])\n",
    "\n",
    "len(best_configs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "1e4a5b13",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "356\n"
     ]
    },
    {
     "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>Unnamed: 0</th>\n",
       "      <th>step</th>\n",
       "      <th>Best/Test/avg_ll</th>\n",
       "      <th>Best/Test/bpd</th>\n",
       "      <th>Best/Test/ppl</th>\n",
       "      <th>Best/Test/std_ll</th>\n",
       "      <th>Best/Train/avg_ll</th>\n",
       "      <th>Best/Train/bpd</th>\n",
       "      <th>Best/Train/epoch</th>\n",
       "      <th>Best/Train/ppl</th>\n",
       "      <th>...</th>\n",
       "      <th>dir_name</th>\n",
       "      <th>id</th>\n",
       "      <th>nunits</th>\n",
       "      <th>circuit</th>\n",
       "      <th>dataset</th>\n",
       "      <th>optim</th>\n",
       "      <th>config</th>\n",
       "      <th>prod</th>\n",
       "      <th>seed</th>\n",
       "      <th>rg</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>285</td>\n",
       "      <td>0</td>\n",
       "      <td>-1924.495117</td>\n",
       "      <td>3.541402</td>\n",
       "      <td>inf</td>\n",
       "      <td>530.495178</td>\n",
       "      <td>-1859.240601</td>\n",
       "      <td>3.421323</td>\n",
       "      <td>282.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>12041</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>588</td>\n",
       "      <td>0</td>\n",
       "      <td>-1940.020752</td>\n",
       "      <td>3.569972</td>\n",
       "      <td>inf</td>\n",
       "      <td>537.625061</td>\n",
       "      <td>-1878.580322</td>\n",
       "      <td>3.456911</td>\n",
       "      <td>269.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>42</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>880</td>\n",
       "      <td>0</td>\n",
       "      <td>-1917.598755</td>\n",
       "      <td>3.528712</td>\n",
       "      <td>inf</td>\n",
       "      <td>529.408203</td>\n",
       "      <td>-1859.192627</td>\n",
       "      <td>3.421235</td>\n",
       "      <td>255.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>10</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>84686</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1183</td>\n",
       "      <td>0</td>\n",
       "      <td>-1896.919556</td>\n",
       "      <td>3.490659</td>\n",
       "      <td>inf</td>\n",
       "      <td>524.003174</td>\n",
       "      <td>-1826.462158</td>\n",
       "      <td>3.361005</td>\n",
       "      <td>299.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>12</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>12041</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1477</td>\n",
       "      <td>0</td>\n",
       "      <td>-1903.659424</td>\n",
       "      <td>3.503061</td>\n",
       "      <td>inf</td>\n",
       "      <td>523.447876</td>\n",
       "      <td>-1829.276611</td>\n",
       "      <td>3.366184</td>\n",
       "      <td>291.0</td>\n",
       "      <td>inf</td>\n",
       "      <td>...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...</td>\n",
       "      <td>12</td>\n",
       "      <td>OSOS</td>\n",
       "      <td>FashionMNIST</td>\n",
       "      <td>LandingAdam</td>\n",
       "      <td>LandingAdam_LR0.05_BS512_LA0.1</td>\n",
       "      <td>tucker</td>\n",
       "      <td>42</td>\n",
       "      <td>dl-qg</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 34 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0  step  Best/Test/avg_ll  Best/Test/bpd  Best/Test/ppl  \\\n",
       "0         285     0      -1924.495117       3.541402            inf   \n",
       "1         588     0      -1940.020752       3.569972            inf   \n",
       "2         880     0      -1917.598755       3.528712            inf   \n",
       "3        1183     0      -1896.919556       3.490659            inf   \n",
       "4        1477     0      -1903.659424       3.503061            inf   \n",
       "\n",
       "   Best/Test/std_ll  Best/Train/avg_ll  Best/Train/bpd  Best/Train/epoch  \\\n",
       "0        530.495178       -1859.240601        3.421323             282.0   \n",
       "1        537.625061       -1878.580322        3.456911             269.0   \n",
       "2        529.408203       -1859.192627        3.421235             255.0   \n",
       "3        524.003174       -1826.462158        3.361005             299.0   \n",
       "4        523.447876       -1829.276611        3.366184             291.0   \n",
       "\n",
       "   Best/Train/ppl  ...                                           dir_name  \\\n",
       "0             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "1             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "2             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "3             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "4             inf  ...  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...   \n",
       "\n",
       "                                                  id  nunits  circuit  \\\n",
       "0  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "1  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "2  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      10     OSOS   \n",
       "3  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      12     OSOS   \n",
       "4  image-data-osos-nstrdec/FashionMNIST/OSOS/tuck...      12     OSOS   \n",
       "\n",
       "        dataset        optim                          config    prod   seed  \\\n",
       "0  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  12041   \n",
       "1  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker     42   \n",
       "2  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  84686   \n",
       "3  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker  12041   \n",
       "4  FashionMNIST  LandingAdam  LandingAdam_LR0.05_BS512_LA0.1  tucker     42   \n",
       "\n",
       "      rg  \n",
       "0  dl-qg  \n",
       "1  dl-qg  \n",
       "2  dl-qg  \n",
       "3  dl-qg  \n",
       "4  dl-qg  \n",
       "\n",
       "[5 rows x 34 columns]"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "colname = 'Best/Valid/bpd'\n",
    "\n",
    "ndf = df.copy()\n",
    "ndf['id'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('_')])\n",
    "\n",
    "ndf['dir_name'] = ndf['dir_name'].apply(lambda row: row[:row.rindex('/')])\n",
    "\n",
    "ndf['nunits'] = ndf['dir_name'].apply(lambda s: re.search(r'_K(\\d+)_', s).group(1))\n",
    "ndf['circuit'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(O?SOS)\\/', s).group(1))\n",
    "ndf['dataset'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/((Fashion)?MNIST)\\/', s).group(1))\n",
    "ndf['optim'] = ndf['dir_name'].apply(lambda s: re.search(r'_O([^_]*)', s).group(1))\n",
    "ndf['config'] = ndf['dir_name'].apply(lambda s: re.search(r'_O(.*)_SEED', s).group(1))\n",
    "ndf['prod'] = ndf['dir_name'].apply(lambda s: re.search(r'\\/(cp|tucker)\\/', s).group(1))\n",
    "ndf['seed'] = ndf['dir_name'].apply(lambda s: re.search(r'SEED(.*)', s).group(1))\n",
    "ndf['rg'] = ndf['dir_name'].apply(lambda s: re.search(r'RG([^_]*)_', s).group(1))\n",
    "\n",
    "ndf = ndf[ndf['id'].isin(best_ids)]\n",
    "\n",
    "print(len(ndf))\n",
    "\n",
    "ndf.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "1be5e04f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#1f77b4;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ff7f0e;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#2ca02c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#d62728;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#9467bd;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c564b;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#e377c2;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#7f7f7f;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#bcbd22;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#17becf;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.12156862745098039, 0.4666666666666667, 0.7058823529411765),\n",
       " (1.0, 0.4980392156862745, 0.054901960784313725),\n",
       " (0.17254901960784313, 0.6274509803921569, 0.17254901960784313),\n",
       " (0.8392156862745098, 0.15294117647058825, 0.1568627450980392),\n",
       " (0.5803921568627451, 0.403921568627451, 0.7411764705882353),\n",
       " (0.5490196078431373, 0.33725490196078434, 0.29411764705882354),\n",
       " (0.8901960784313725, 0.4666666666666667, 0.7607843137254902),\n",
       " (0.4980392156862745, 0.4980392156862745, 0.4980392156862745),\n",
       " (0.7372549019607844, 0.7411764705882353, 0.13333333333333333),\n",
       " (0.09019607843137255, 0.7450980392156863, 0.8117647058823529)]"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def_palette = sns.color_palette()\n",
    "\n",
    "palette_dict = {\n",
    "    'OSOS tucker LandingRAdam': def_palette[2], \n",
    "    'OSOS cp LandingAdam': def_palette[3],\n",
    "    'OSOS cp LandingSGD': def_palette[6], \n",
    "    'OSOS tucker LandingSGD': def_palette[4], \n",
    "    'OSOS tucker LandingSGDog': def_palette[5],\n",
    "    'SOS cp Adam': def_palette[1], \n",
    "    'SOS cp SGD': def_palette[0], \n",
    "}\n",
    "\n",
    "def_palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "907245a3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 550x169.959 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import bundles, figsizes\n",
    "import matplotlib.ticker as tck\n",
    "\n",
    "plt.rcParams.update(bundles.iclr2024(usetex=True))\n",
    "plt.rcParams.update(figsizes.iclr2024(nrows=1, ncols=2))\n",
    "\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{amssymb,amsmath}')\n",
    "\n",
    "datasets = ['MNIST', 'FashionMNIST']\n",
    "\n",
    "fig, axes = plt.subplots(1, 2)\n",
    "\n",
    "for i, (dataset, ax) in enumerate(zip(datasets, axes.flat)):\n",
    "\n",
    "    colx = 'num_params'\n",
    "    coly = 'Best/Test/bpd'\n",
    "    colh = 'id' \n",
    "\n",
    "    plot_df = ndf[ndf['dataset'] == dataset].copy()\n",
    "    plot_df['id'] = plot_df['circuit'] + ' ' + plot_df['prod'] + ' ' + plot_df['optim']\n",
    "\n",
    "    plot_df = plot_df[~((plot_df['circuit'] == 'OSOS') & (plot_df['prod'] == 'tucker') & (plot_df['optim'] == 'LandingAdam'))]\n",
    "    plot_df = plot_df[plot_df['rg'] == 'qt']\n",
    "\n",
    "    label_dict = {\n",
    "        'OSOS tucker LandingRAdam': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingPC$^*$', \n",
    "        'OSOS cp LandingAdam': r'$\\perp_\\mathbb{C}^2$ - Hadamard - LandingPC$^*$',\n",
    "        'OSOS cp LandingSGD': r'$\\perp_\\mathbb{C}^2$ - Hadamard - LandingSGD$^*$', \n",
    "        'OSOS tucker LandingSGD': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingSGD$^*$', \n",
    "        'OSOS tucker LandingSGDog': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingSGD',\n",
    "        'SOS cp Adam': r'$\\pm_\\mathbb{C}^2$ - Hadamard - Adam', \n",
    "        'SOS cp SGD': r'$\\pm_\\mathbb{C}^2$ - Hadamard - SGD', \n",
    "       }\n",
    "\n",
    "    sns.lineplot(\n",
    "        plot_df,\n",
    "        x=colx,\n",
    "        y=coly,\n",
    "        hue=colh,\n",
    "        style=colh,\n",
    "        legend='brief' if i == 1 else False,\n",
    "        alpha=0.7,\n",
    "        ax=ax,\n",
    "        markers=True,\n",
    "        palette=palette_dict,   \n",
    "    )\n",
    "\n",
    "    ax.grid(linestyle=\"--\", which=\"major\", alpha=0.3, linewidth=0.5)\n",
    "    ax.grid(linestyle=\"--\", which=\"minor\", alpha=0.3, linewidth=0.3)\n",
    "    ax.yaxis.set_minor_locator(tck.AutoMinorLocator())\n",
    "\n",
    "    ax.set_xscale(\"log\")\n",
    "\n",
    "    if i == 1:\n",
    "        handles, labels = ax.get_legend_handles_labels()\n",
    "\n",
    "        ax.legend(\n",
    "            loc=\"best\",\n",
    "            handles=handles,\n",
    "            labels=[label_dict[k] for k in labels],\n",
    "            bbox_to_anchor=(1.05, 1.),\n",
    "            ncols=1,\n",
    "            alignment=\"left\",\n",
    "        )\n",
    "\n",
    "\n",
    "    ax.set_title(dataset)\n",
    "    ax.set_ylabel(\"test bpd\" if i == 0 else None)\n",
    "    ax.set_xlabel(None)\n",
    "\n",
    "fig.text(0.62, 0.05, '\\# parameters', fontsize='medium', fontweight=plt.rcParams['figure.labelweight'])\n",
    "\n",
    "fig.savefig(f'bpd-curves-both-all.pdf', dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af73a23d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "175c27bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#1f77b4;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ff7f0e;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#2ca02c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#d62728;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#9467bd;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c564b;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#e377c2;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#7f7f7f;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#bcbd22;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#17becf;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.12156862745098039, 0.4666666666666667, 0.7058823529411765),\n",
       " (1.0, 0.4980392156862745, 0.054901960784313725),\n",
       " (0.17254901960784313, 0.6274509803921569, 0.17254901960784313),\n",
       " (0.8392156862745098, 0.15294117647058825, 0.1568627450980392),\n",
       " (0.5803921568627451, 0.403921568627451, 0.7411764705882353),\n",
       " (0.5490196078431373, 0.33725490196078434, 0.29411764705882354),\n",
       " (0.8901960784313725, 0.4666666666666667, 0.7607843137254902),\n",
       " (0.4980392156862745, 0.4980392156862745, 0.4980392156862745),\n",
       " (0.7372549019607844, 0.7411764705882353, 0.13333333333333333),\n",
       " (0.09019607843137255, 0.7450980392156863, 0.8117647058823529)]"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def_palette = sns.color_palette()\n",
    "\n",
    "palette_dict = {\n",
    "    'OSOS tucker LandingRAdam qt': def_palette[2], \n",
    "    'OSOS cp LandingAdam qt': def_palette[3],\n",
    "    'OSOS cp LandingSGD qt': def_palette[6], \n",
    "    'OSOS tucker LandingSGD qt': def_palette[4], \n",
    "    'OSOS tucker LandingSGDog qt': def_palette[5],\n",
    "    'SOS cp Adam qt': def_palette[1], \n",
    "    'SOS cp SGD qt': def_palette[0], \n",
    "    'OSOS tucker LandingAdam dl-qg': def_palette[7], \n",
    "}\n",
    "\n",
    "def_palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "3cdc43a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 550x169.959 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import bundles, figsizes\n",
    "import matplotlib.ticker as tck\n",
    "\n",
    "plt.rcParams.update(bundles.iclr2024(usetex=True))\n",
    "# plt.rcParams.update(bundles.iclr2024(usetex=False, family='sans-serif'))\n",
    "plt.rcParams.update(figsizes.iclr2024(nrows=1, ncols=2))\n",
    "\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{amssymb,amsmath}')\n",
    "\n",
    "datasets = ['MNIST', 'FashionMNIST']\n",
    "\n",
    "fig, axes = plt.subplots(1, 2)\n",
    "\n",
    "for i, (dataset, ax) in enumerate(zip(datasets, axes.flat)):\n",
    "\n",
    "    colx = 'num_params'\n",
    "    \n",
    "    coly = colname\n",
    "    coly = 'Best/Test/bpd'\n",
    "\n",
    "    colh = 'id' # TODO \n",
    "    # colh = 'circuit' # TODO \n",
    "\n",
    "    plot_df = ndf[ndf['dataset'] == dataset].copy()\n",
    "    plot_df['id'] = plot_df['circuit'] + ' ' + plot_df['prod'] + ' ' + plot_df['optim'] + ' ' + plot_df['rg']\n",
    "\n",
    "    # plot_df = plot_df[~((plot_df['circuit'] == 'OSOS') & (plot_df['prod'] == 'cp'))]\n",
    "    plot_df = plot_df[~((plot_df['circuit'] == 'OSOS') & (plot_df['prod'] == 'tucker') & (plot_df['optim'] == 'LandingAdam') & (plot_df['rg'] == 'qt'))]\n",
    "    # plot_df = plot_df[plot_df['rg'] == 'qt']\n",
    "\n",
    "    label_dict = {\n",
    "        'OSOS tucker LandingRAdam qt': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingPC$^*$', \n",
    "        'OSOS cp LandingAdam qt': r'$\\perp_\\mathbb{C}^2$ - Hadamard - LandingPC$^*$',\n",
    "        'OSOS cp LandingSGD qt': r'$\\perp_\\mathbb{C}^2$ - Hadamard - LandingSGD$^*$', \n",
    "        'OSOS tucker LandingAdam dl-qg': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingPC$^*$ (non-str-dec)',\n",
    "        'OSOS tucker LandingSGD qt': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingSGD$^*$', \n",
    "        'OSOS tucker LandingSGDog qt': r'$\\perp_\\mathbb{C}^2$ - Kronecker - LandingSGD',\n",
    "        'SOS cp Adam qt': r'$\\pm_\\mathbb{C}^2$ - Hadamard - Adam', \n",
    "        'SOS cp SGD qt': r'$\\pm_\\mathbb{C}^2$ - Hadamard - SGD', \n",
    "       }\n",
    "\n",
    "    sns.lineplot(\n",
    "        plot_df,\n",
    "        x=colx,\n",
    "        y=coly,\n",
    "        hue=colh,\n",
    "        style=colh,\n",
    "        legend='brief' if i == 1 else False,\n",
    "        # legend=False,\n",
    "        alpha=0.7,\n",
    "        ax=ax,\n",
    "        markers=True,\n",
    "        palette=palette_dict,   \n",
    "    )\n",
    "\n",
    "    ax.grid(linestyle=\"--\", which=\"major\", alpha=0.3, linewidth=0.5)\n",
    "    ax.grid(linestyle=\"--\", which=\"minor\", alpha=0.3, linewidth=0.3)\n",
    "    ax.yaxis.set_minor_locator(tck.AutoMinorLocator())\n",
    "\n",
    "    ax.set_xscale(\"log\")\n",
    "    # ax.set_yscale('log')\n",
    "\n",
    "    # ax.set_xlim(1e6, None)\n",
    "\n",
    "    # ax.margins(x=0.05, y=0.18)\n",
    "\n",
    "    if i == 1:\n",
    "        handles, labels = ax.get_legend_handles_labels()\n",
    "        # del handles[0]\n",
    "        # del labels[0]\n",
    "\n",
    "        # labels[4] = ''\n",
    "\n",
    "        ax.legend(\n",
    "            loc=\"best\",\n",
    "            handles=handles,\n",
    "            labels=[label_dict[k] for k in labels],\n",
    "            bbox_to_anchor=(1.05, 1.1),\n",
    "            # fontsize=8,\n",
    "            # title=r\"Class \\qquad Memory (GiB)\",\n",
    "            ncols=1,\n",
    "            # handleheight=3.2,\n",
    "            alignment=\"left\",\n",
    "        )\n",
    "\n",
    "    # handles = handles[5:]\n",
    "    # labels = labels[5:]\n",
    "\n",
    "    # ax.legend(\n",
    "    #     loc=\"upper left\",\n",
    "    #     handles=handles,\n",
    "    #     labels=labels,\n",
    "    #     # bbox_to_anchor=(1, 1),\n",
    "    #     # fontsize=8,\n",
    "    #     # title=r\"Memory (GiB)\",\n",
    "    #     title=r'Time per iteration (ms)',\n",
    "    #     ncols=5,\n",
    "    #     columnspacing=0.2,\n",
    "    #     borderpad=0.75,\n",
    "    #     handletextpad=0.25,\n",
    "    #     # alignment=\"left\",\n",
    "    # )\n",
    "\n",
    "    ax.set_title(dataset)\n",
    "    ax.set_ylabel(\"test bpd\" if i == 0 else None)\n",
    "    ax.set_xlabel(None)\n",
    "\n",
    "fig.text(0.62, 0.05, '\\# parameters', fontsize='medium', fontweight=plt.rcParams['figure.labelweight'])\n",
    "# fig.text(0.0, 0.05, r'\\#\\,parameters', fontsize='x-small', fontweight=plt.rcParams['figure.labelweight'], usetex=True)\n",
    "\n",
    "fig.savefig(f'bpd-curves-both-all.pdf', dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "428a4d87",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
