{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "abfa11d9-db57-49fa-8c5f-2fe584d13066",
   "metadata": {},
   "source": [
    "# Generate bound curves for all methods on dSprites"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bd59d9c6-9d24-48b3-b3ae-c28140765530",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "653d9f5a-22e9-45dd-a301-717e375a2fd8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "import pickle\n",
    "import yaml\n",
    "\n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.autograd import Variable\n",
    "import torch.nn.functional as F\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from tqdm import tqdm\n",
    "\n",
    "from geometry.datasets import custom_dsprites\n",
    "from geometry.datasets.generic_dataset_loader import DatasetName, load_dataset\n",
    "from geometry.computations_grid.data_analysis.data_analysis import (\n",
    "    compute_measures_multiclass,\n",
    "    plot_pairs_multiclass,\n",
    "    plot_3d_pca_projections_multiclass,\n",
    "    clip_results_multiclass,\n",
    "    MeasureAggregates\n",
    ")\n",
    "from representation_learning.beta_vae.solver import Solver\n",
    "from representation_learning.beta_vae.dataset import CustomTensorDataset\n",
    "from experiment_scripts.model_configs import BetaVAEConfig\n",
    "from representation_learning.beta_vae.utils import cuda\n",
    "from geometry.datasets.generic_dataset_loader import load_dataset_fixed_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3a1604b7-f055-461d-b711-9385b8296731",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option('display.max_columns', None)\n",
    "pd.set_option('display.max_rows', None)\n",
    "pd.set_option('display.max_colwidth', None)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "815d5417-b08f-4348-a44e-2c8c492594a6",
   "metadata": {},
   "source": [
    "## Load the measures for all datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "96bf6d26-e5e9-48f6-9975-830cf2ecbcc1",
   "metadata": {},
   "outputs": [],
   "source": [
    "normalize_for_volume = True\n",
    "number_of_dims = 4\n",
    "output_dir = Path(f\"~/experiments/manifold_microscope/manifold_fitting/measures_all_datasets/dsprites_measures_vol_norm_{normalize_for_volume}\").expanduser() \n",
    "\n",
    "output_path = output_dir / f\"dsprites_{number_of_dims}.pkl\"\n",
    "with open(output_path, \"rb\") as f:\n",
    "    measures_dsprites = clip_results_multiclass(pickle.load(f))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b830149-5c5d-4dc4-872a-83abce93ea01",
   "metadata": {},
   "source": [
    "## Load the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2e75affb-ca32-4e78-bb9b-fd266eb72096",
   "metadata": {},
   "outputs": [],
   "source": [
    "def parse_path(path):\n",
    "    dataset_name, _, perc_data, dim, _, iteration = path.name.split(\"__\")\n",
    "    \n",
    "    checkpoints = list(path.glob(\"checkpoints/*rec_loss*\"))\n",
    "\n",
    "    if not (path / \"checkpoints\" / \"last.pth\").exists():\n",
    "        return None\n",
    "        \n",
    "    checkpoint_infos = [\n",
    "        (\n",
    "            int(ckpt.stem.split(\"_\")[1]), \n",
    "            float(ckpt.stem.split(\"_\")[4]),\n",
    "            float(ckpt.stem.split(\"_\")[7]),\n",
    "            float(ckpt.stem.split(\"_\")[10])\n",
    "        ) \n",
    "        for ckpt in checkpoints\n",
    "    ]\n",
    "\n",
    "    model_stop_iteration, rec_loss, haus_dist, avg_dist = max(checkpoint_infos, key=lambda x: x[0])\n",
    "\n",
    "    return dict(\n",
    "        dataset_name=dataset_name,\n",
    "        perc_data=perc_data,\n",
    "        dim=int(dim),\n",
    "        iteration=iteration,\n",
    "        model_stop_iteration=model_stop_iteration,\n",
    "        train_rec_loss=rec_loss, \n",
    "        train_haus_dist=haus_dist, \n",
    "        train_avg_dist=avg_dist,\n",
    "        model_path=path / \"checkpoints\" / \"last.pth\",\n",
    "        dataset_path=path.parent / \"datasets\" / f\"{dataset_name}__{dim}.npz\",\n",
    "        config_path=path / \"config.yml\"\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9e2af05b-085d-4345-8393-0f363e777dbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "paths = list(Path(\"~/experiments/manifold_microscope/manifold_fitting/training_absolute_ratio_dl_models_fixed_test_set_dsprites_FINAL\").expanduser().glob(\"*\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "67c9e4b5-a8bf-466f-9d2b-fcb9c6505190",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_infos = [parse_path(p) for p in paths if p.name != \"datasets\" if parse_path(p) is not None]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8ecda69a-e6d6-42c0-9597-d21d2bddce3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_the_test_data(config: BetaVAEConfig):\n",
    "    datasets_dir = config.exported_datasets_dir\n",
    "    dataset_name = config.dataset\n",
    "    number_of_dims = config.number_of_dims\n",
    "    training_ratio = config.training_ratio\n",
    "    noise_sigma = 0.0\n",
    "    \n",
    "    data_train, data_test, _, _ = load_dataset_fixed_test_split(\n",
    "        datasets_dir=datasets_dir,\n",
    "        dataset_name=dataset_name,\n",
    "        number_of_dims=number_of_dims,\n",
    "        ratio_per_dim=False,\n",
    "        training_ratio=training_ratio,\n",
    "        noise_sigma=noise_sigma,\n",
    "        weight_subsampling_by_manifold_volume=True\n",
    "    )\n",
    "    \n",
    "    print(f\"Number test: {len(data_test)}\")\n",
    "\n",
    "    data_test = (data_test - data_test.min()) / (data_test.max() - data_test.min())\n",
    "    data_test = torch.from_numpy(data_test).unsqueeze(1).float()\n",
    "\n",
    "    test_kwargs = {'data_tensor': data_test}\n",
    "\n",
    "    test_data = CustomTensorDataset(**test_kwargs)\n",
    "    test_loader = DataLoader(\n",
    "        test_data,\n",
    "        batch_size=config.batch_size,\n",
    "        shuffle=False,\n",
    "        num_workers=config.num_workers,\n",
    "        pin_memory=True,\n",
    "        drop_last=False\n",
    "    )\n",
    "\n",
    "    return test_loader, len(data_train), len(data_test)\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def compute_distance_metrics(solver, data_loader):\n",
    "    all_distances = []\n",
    "    for x in tqdm(data_loader, total=len(data_loader)):\n",
    "        x = Variable(cuda(x, solver.use_cuda))\n",
    "        x_recon, _, _ = solver.net(x)\n",
    "        x_recon = F.sigmoid(x_recon)\n",
    "        \n",
    "        distances = torch.linalg.norm((x_recon - x).flatten(start_dim=1), axis=-1)\n",
    "        all_distances.append(distances.detach().cpu().numpy())\n",
    "\n",
    "    all_distances = np.concatenate(all_distances, axis=0)\n",
    "\n",
    "    return all_distances.max(), all_distances.mean()\n",
    "\n",
    "\n",
    "def compute_distances(row):\n",
    "    model_path = row[\"model_path\"]\n",
    "    config_path = row[\"config_path\"]\n",
    "\n",
    "    if not model_path.exists():\n",
    "        return dict(\n",
    "        test_hausdorff_distance=None,\n",
    "        test_average_distance=None,\n",
    "        n_train=None,\n",
    "        n_test=None\n",
    "    )\n",
    "\n",
    "    with open(str(config_path), 'r') as f:\n",
    "        config_dict = yaml.load(f, Loader=yaml.UnsafeLoader)\n",
    "\n",
    "    config = BetaVAEConfig(**config_dict[\"model_config\"])\n",
    "    \n",
    "    solver = Solver(config, load_data=False)\n",
    "    solver.load_checkpoint(\"last.pth\")\n",
    "\n",
    "    data_loader, n_train, n_test = load_the_test_data(config)\n",
    "\n",
    "    hausdorff_distance, average_distance = compute_distance_metrics(solver, data_loader)\n",
    "\n",
    "    return dict(\n",
    "        test_hausdorff_distance=hausdorff_distance,\n",
    "        test_average_distance=average_distance,\n",
    "        n_train=n_train,\n",
    "        n_test=n_test\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fdfc9e4-7b69-4423-930c-90dd9f050332",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_infos = [\n",
    "    info | compute_distances(info)\n",
    "    for info in tqdm(path_infos)\n",
    "    if info[\"dim\"] == 4\n",
    "]\n",
    "\n",
    "df = pd.DataFrame(all_infos)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "345808d8-abf9-4c3b-8feb-9f9ed1fe6255",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.head(3)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c2481a66-10e7-4c76-af78-907de6b255aa",
   "metadata": {},
   "source": [
    "## Generate the curves"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "653045d3-2b78-4ca5-88ae-466db671862e",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_df = []\n",
    "\n",
    "for path in Path(\"~/experiments/manifold_microscope/manifold_fitting/training_absolute_ratio_dl_models_fixed_test_set_mmls_FINAL\").expanduser().glob(\"**/*.pkl\"):\n",
    "    dataset, method, data_perc, dims, noise, n_iter = path.parent.name.split(\"__\")\n",
    "    \n",
    "    with open(path, \"rb\") as f:\n",
    "        results = pickle.load(f)\n",
    "\n",
    "    results_df.append(dict(\n",
    "        dataset=dataset,\n",
    "        method=method,\n",
    "        data_perc=float(data_perc), \n",
    "        dims=int(dims), \n",
    "        noise=float(noise), \n",
    "        n_iter=int(n_iter),\n",
    "        number_of_train_points=results[\"number_of_train_points\"],\n",
    "        number_of_test_points=results[\"number_of_test_points\"],\n",
    "        hausdorff_distance=results[\"hausdorff_distance\"],\n",
    "        avg_distance=results[\"pointwise_distances\"].mean()\n",
    "    ))\n",
    "\n",
    "results_df = pd.DataFrame(results_df)\n",
    "results_df = results_df[(results_df[\"dims\"] == 4) & (results_df[\"dataset\"] == \"custom_dsprites_balanced\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "811605b0-66fb-479b-8048-4031976ae092",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(39, 10)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "05cbddfd-073b-4697-a2ea-42a128e207ba",
   "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>dataset</th>\n",
       "      <th>method</th>\n",
       "      <th>data_perc</th>\n",
       "      <th>dims</th>\n",
       "      <th>noise</th>\n",
       "      <th>n_iter</th>\n",
       "      <th>number_of_train_points</th>\n",
       "      <th>number_of_test_points</th>\n",
       "      <th>hausdorff_distance</th>\n",
       "      <th>avg_distance</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>custom_dsprites_balanced</td>\n",
       "      <td>MMLS</td>\n",
       "      <td>0.70</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "      <td>137275</td>\n",
       "      <td>500</td>\n",
       "      <td>2.815711</td>\n",
       "      <td>0.694557</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>custom_dsprites_balanced</td>\n",
       "      <td>MMLS</td>\n",
       "      <td>0.80</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "      <td>156886</td>\n",
       "      <td>500</td>\n",
       "      <td>2.626897</td>\n",
       "      <td>0.663727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>custom_dsprites_balanced</td>\n",
       "      <td>MMLS</td>\n",
       "      <td>0.30</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "      <td>58832</td>\n",
       "      <td>500</td>\n",
       "      <td>3.746525</td>\n",
       "      <td>1.137041</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>custom_dsprites_balanced</td>\n",
       "      <td>MMLS</td>\n",
       "      <td>0.05</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0</td>\n",
       "      <td>9805</td>\n",
       "      <td>500</td>\n",
       "      <td>5.004093</td>\n",
       "      <td>2.463012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>custom_dsprites_balanced</td>\n",
       "      <td>MMLS</td>\n",
       "      <td>0.90</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1</td>\n",
       "      <td>176497</td>\n",
       "      <td>500</td>\n",
       "      <td>2.600549</td>\n",
       "      <td>0.658447</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     dataset method  data_perc  dims  noise  n_iter  \\\n",
       "4   custom_dsprites_balanced   MMLS       0.70     4    0.0       1   \n",
       "11  custom_dsprites_balanced   MMLS       0.80     4    0.0       1   \n",
       "12  custom_dsprites_balanced   MMLS       0.30     4    0.0       1   \n",
       "17  custom_dsprites_balanced   MMLS       0.05     4    0.0       0   \n",
       "18  custom_dsprites_balanced   MMLS       0.90     4    0.0       1   \n",
       "\n",
       "    number_of_train_points  number_of_test_points  hausdorff_distance  \\\n",
       "4                   137275                    500            2.815711   \n",
       "11                  156886                    500            2.626897   \n",
       "12                   58832                    500            3.746525   \n",
       "17                    9805                    500            5.004093   \n",
       "18                  176497                    500            2.600549   \n",
       "\n",
       "    avg_distance  \n",
       "4       0.694557  \n",
       "11      0.663727  \n",
       "12      1.137041  \n",
       "17      2.463012  \n",
       "18      0.658447  "
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "397bac84-ddce-471d-838c-152901d9803c",
   "metadata": {},
   "outputs": [],
   "source": [
    "dim = 4\n",
    "dataset = \"custom_dsprites_balanced\"\n",
    "\n",
    "df_dsprites_1 = (\n",
    "    df\n",
    "    [(df[\"dim\"] == dim) & (df[\"dataset_name\"] == dataset) & (~df[\"test_hausdorff_distance\"].isna())]\n",
    "    .sort_values(\"perc_data\")\n",
    "    .reset_index(drop=True)\n",
    ")\n",
    "df_dsprites_1.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9c8bc867-c1ed-4681-bec6-231e493491c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_dsprites_1 = (\n",
    "    df_dsprites_1\n",
    "    .assign(\n",
    "        data_perc=lambda df: df[\"perc_data\"].astype(np.float64),\n",
    "        hausdorff_distance=lambda df: df[\"test_hausdorff_distance\"]\n",
    "    )\n",
    "    .merge(results_df[[\"data_perc\", \"number_of_train_points\"]].drop_duplicates(), on=\"data_perc\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aacee360-99cf-4693-8441-956b37079c2d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df_dsprites_1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc116200-9763-4177-af62-d2cb92614165",
   "metadata": {},
   "source": [
    "## Polish and export bounds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "156001f1-3889-4ed7-b2a1-f103aebcaed7",
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "4bfb1c71-8b82-4f5f-833a-94d824acaabf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def robust_lower_bound(f_values, g, x, q=0.01):\n",
    "    lower_bound = g(x)\n",
    "    return np.quantile(f_values / lower_bound, q=q)\n",
    "\n",
    "def robust_upper_bound(f_values, g, x, q=0.99):\n",
    "    upper_bound = g(x)\n",
    "    return np.quantile(f_values / upper_bound, q=q)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "9b422806-8d7d-4017-a9a8-48bc7d63084d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAADhjklEQVR4nOzdd3iT9drA8e+T2b03dDDbgjIKggjKVIaiuEU8FlT0qIgKehQ9iODAcUTcW3CAWxEXKggqiOwyhEJbSsvo3jNtk+f9o28jsS00pW3S9v5cVy7Is3InlN65n99SVFVVEUIIIYQQQgghRIvTODoAIYQQQgghhBCio5KiWwghhBBCCCGEaCVSdAshhBBCCCGEEK1Eim4hhBBCCCGEEKKVSNEthBBCCCGEEEK0Eim6hRBCCCGEEEKIViJFtxBCCCGEEEII0Uqk6BZCCCGEEEIIIVqJFN1CCCGEEEIIIUQrkaJbiA5MURQeffRRu887cuQIiqKwfPnyFo+prTT3vQshhBAtzVH5ePr06Xh4eDTrXCFEy5GiW4hWtnz5chRFQVEUNm7cWG+/qqqEh4ejKAqXXHKJAyIUQgghOj7Jxy3j1Vdfbdc35YVwBCm6hWgjLi4urFy5st72X3/9lWPHjmE0Gh0QlRBCCNG5SD4+M1J0C2E/KbqFaCOTJk3is88+o6amxmb7ypUrGTRoECEhIQ6KTAghhOg8JB8LIdqaFN1CtJGpU6eSl5fHzz//bN1WVVXF559/zvXXX9/gOWVlZcydO5fw8HCMRiPR0dH873//Q1VVm+NMJhP33nsvgYGBeHp6cumll3Ls2LEGr3n8+HFuuukmgoODMRqN9O3bl3ffffe08VdXV5OYmEhGRsZpj60bQ5aens4ll1yCh4cHXbp04ZVXXgFg7969jBkzBnd3dyIjI+u1ONR1Ady4cSOzZ88mMDAQHx8fbrvtNqqqqigsLOTGG2/E19cXX19f/vOf/9T7TP6ppKSEe+65h6ioKIxGI0FBQVx44YXs3LnztO9HCCFEx9GZ8nGdw4cPM378eNzd3QkLC2PRokX1YrdYLCxdupS+ffvi4uJCcHAwt912GwUFBdZjoqKi+Ouvv/j111+tXfVHjRoFQH5+Pvfddx9nn302Hh4eeHl5MXHiRHbv3t3kOAEuueQSunfv3uC+YcOGMXjwYOvzZcuWMWbMGIKCgjAajfTp04fXXnutwXN/+OEHzj//fNzd3fH09OTiiy/mr7/+sis2IZpLim4h2khUVBTDhg3jo48+sm774YcfKCoq4rrrrqt3vKqqXHrppTz//PNMmDCBJUuWEB0dzf3338+cOXNsjr3llltYunQpF110EU899RR6vZ6LL7643jWzsrI499xzWbt2LbNmzeKFF16gZ8+e3HzzzSxduvSU8R8/fpzY2FjmzZvXpPdrNpuZOHEi4eHhPPPMM0RFRTFr1iyWL1/OhAkTGDx4ME8//TSenp7ceOONpKam1rvGXXfdRVJSEgsXLuTSSy/lzTffZP78+UyePBmz2cyTTz7JiBEjePbZZ/nggw9OGc+///1vXnvtNa688kpeffVV7rvvPlxdXTlw4ECT3o8QQoiOoTPm4wkTJhAcHMwzzzzDoEGDWLBgAQsWLLA57rbbbuP+++9n+PDhvPDCC8yYMYMVK1Ywfvx4qqurAVi6dCldu3YlJiaGDz74gA8++ICHH34YqC3sV61axSWXXMKSJUu4//772bt3LyNHjuTEiRNNihXg2muvJTU1lW3bttlsT0tL488//7T5N3rttdeIjIzkoYce4rnnniM8PJw77rjDepO/zgcffMDFF1+Mh4cHTz/9NPPnz2f//v2MGDGCI0eONDk2IZpNFUK0qmXLlqmAum3bNvXll19WPT091fLyclVVVfXqq69WR48eraqqqkZGRqoXX3yx9bxVq1apgPr444/bXO+qq65SFUVRk5OTVVVV1YSEBBVQ77jjDpvjrr/+ehVQFyxYYN128803q6GhoWpubq7Nsdddd53q7e1tjSs1NVUF1GXLllmPqdsWHx9/2vccHx+vAuqTTz5p3VZQUKC6urqqiqKoH3/8sXV7YmJivTjrPrPx48erFovFun3YsGGqoijqv//9b+u2mpoatWvXrurIkSNtYvjnNb29vdU777zztLELIYTomDpzPr7rrrus2ywWi3rxxRerBoNBzcnJUVVVVX///XcVUFesWGFz/po1a+pt79u3b72cq6qqWllZqZrNZpttqampqtFoVBctWnTaWOsUFRWpRqNRnTt3rs32Z555RlUURU1LS7Nuq/ucTjZ+/Hi1e/fu1uclJSWqj4+POnPmTJvjMjMzVW9v73rbhWgN0tItRBu65pprqKio4Ntvv6WkpIRvv/220a5s33//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WRn9+/fnlVdeaXD/M888w4svvsjrr7/Oli1bcHd3Z/z48VRWVrZxpKK1aZXamQAtqsXBkXRuEyZMICMjg4yMDNatW4dOp+OSSy5xdFitQlVVrr/+embPns2kSZP46aef2L9/P++88w4uLi48/vjjjg5RCCHaFa2mNpebVbODIxGSzyWfCyejOglA/eqrr6zPLRaLGhISoj777LPWbYWFharRaFQ/+uijJl+3qKhIBdSioqKWDFe0sAM5B9TViavVvVl7HR3KGauoqFD379+vVlRUODoUu8THx6uXXXaZzbbff/9dBdTs7Gzrtj179qijR49WXVxcVD8/P3XmzJlqSUmJdf/IkSPVu+++2+Y6l112mRofH299HhkZqT7xxBPqjBkzVA8PDzU8PFx94403bM7ZsmWLOmDAANVoNKqDBg1Sv/zySxVQd+3apaqqqubn56vXX3+9GhAQoLq4uKg9e/ZU33333Sa/348++kgF1K+//rrB/RaLxeb5W2+9pcbExKhGo1GNjo5WX3nlFeu+1NRUFVC/+OILddSoUaqrq6var18/9Y8//rC5xueff6726dNHNRgMamRkpPq///3Pum/evHnqkCFD6sXRr18/deHChU2Kw2QyqXfeeacaEhKiGo1GNSIiQn3yySet+wsKCtSbb75ZDQgIUD09PdXRo0erCQkJp/yc0tPT1auvvlr19vZWfX191UsvvVRNTU1VVVVVFyxYoAI2j/Xr1zd4nR9++EEdPny46u3trfr5+akXX3yxmpycXO8zrPv37ShO9ftA8lPTyWfVPiTnJaurE1erO0/sdHQoZ6y95nJVlXz+T5LPa0k+b76WyOVOW3SnpKQ0+A92wQUXqLNnz270OpWVlWpRUZH1cfToUUnU7cCh3EPq6sTVakLGqX9htAeN/cesMde0+cMe/0zSJSUl6m233ab27NlTNZvNqqqqamlpqRoaGqpeccUV6t69e9V169ap3bp1s0nATU3Sfn5+6iuvvKImJSWpixcvVjUajZqYmGh97cDAQPX6669X9+3bp37zzTdq9+7dbX4n3HnnneqAAQPUbdu2qampqerPP/+srl69usnv99JLL1Wjo6ObdOyHH36ohoaGql988YV6+PBh9YsvvlD9/PzU5cuXq6r6d4KJiYlRv/32W/XgwYPqVVddpUZGRqrV1dWqqqrq9u3bVY1G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oEENnn/yv01wcDBubm50797dZtvWrVutz5OSknjkkUfYsmULubm51jvi6enpnHXWWQ1eNzQ0FIDs7GxiYmIafA+lpaU2PzcAFRUVNl3dmiIrK4v//ve/bNiwgezsbMxmM+Xl5afsBimEsCW5vH2RfC75HCSftwUpuoXT6MjjwDRaDb0m9XLI6zaVl5cXRUVF9bYXFhbi7e3dkmFRWlqKVqtlx44d9SYTOTlhuLq62iT6UwkPD6dnz54AxMbGkpKSwvz583n00UebdH7dhC4nJ9Pq6up6x+n1epvniqK02qyqAQEB1vdU5+DBgwB89913dOnSxWaf0Wi06/qlpaVMnjyZp59+ut6+uuQI4O7u3uD5J38WiqI0+Nmc3NVs8uTJREZG8tZbbxEWFobFYuGss86yGT/Y0HWBel3WTn4PoaGhNuMH69g7S298fDx5eXm88MILREZGYjQaGTZsWL34hBCNk1zeOq9rD8nnks9PJvncOfK5FN3CaXT0dbrtTZptLTo6mp9++qne9p07d9a7g717924qKipwdXUF4M8//8TDw4Pw8HDrMVu2bLE5p25MjVarZeDAgZjNZrKzszn//PNb4d3UzgxaU1NDVVUVXl5ehIWFsWnTJkaOHGk9ZtOmTQwZMgTAOqlJRkYGvr6+QO3EK/bw9vYmNDSULVu2cMEFFwBQU1NjHZfUEk6ehObk99IccXFxfPHFF0RFRaHTtW46yMvL4+DBg7z11lvWf/ONGzee8XXj4uLIzMxEp9MRFRXV4DEGgwGz+fS/VzZt2sSrr77KpEmTADh69KjNJDRCiNPr6C3dzp7LQfK55HPJ586Yz53/N4foNGSdbse6/fbbOXToELNnz2bPnj0cPHiQJUuW8NFHHzF37lybY6uqqrj55pvZv38/33//PQsWLGDWrFk2y3+kp6czZ84cDh48yEcffcRLL73E3XffDUDv3r2ZNm0aN954I19++SWpqals3bqVxYsX89133zUr/ry8PDIzMzl27Bg//PADL7zwAqNHj8bLywuo7dr19NNP88knn3Dw4EEefPBBEhISrDH17NmT8PBwHn30UZKSkvjuu+947rnn7I7j7rvv5qmnnmLVqlUkJiZyxx132MygeqY8PT257777uPfee3nvvfdISUlh586dvPTSS7z33nt2XevOO+8kPz+fqVOnsm3bNlJSUvjx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LlE6nU5deOGF6q9//WtkmRG9Xq/OO+88pWmaGjNmTGSZkQ8//FDp9XqVkJCgAHXKKadEjo2JiVEFBQXqnnvuUTNnzlS33Xab+uSTT9TYsWNVTk6O+vrrr9X69etVWlqauueee9T69evVzp07O6zza6+9prZt26ZuueUWFRsbG1k6Y+7cuer++++PHP/EE08ok8mk3nrrrTbLWDQ3N3e5zMcff1x9/PHHqqioSG3btk099dRTymAwqD/+8Y9dLvNgh5q9/GjL/eUvf6n++9//qqKiIrV27Vp19dVXK4vForZu3drlMktKSpTD4VC33367KiwsVP/5z39UcnKy+tWvfnXM73/y5MnqqquuOuR1OdpyH374YeVwONSbb76pdu/erT7++GM1ZMgQdeWVV3a5zK+++kr961//UkVFRWr58uXqnHPOUYMGDVL19fWRY5qbm9X69evV+vXrFaB++9vfqvXr16vi4mKllFL333+/mjt3buT41mVG7r33XlVQUKCef/55WWZECNEpPRnLBwwY0GbJsGeeeUbNmTNHxcTEqNtuu02tWrVKXXrpperqq69WY8eOVUOHDlVNTU2R/3+HiucnSizvSrkH6yieSyyXWC76Jkm6RY957rnn1IABA5Rer1cmk0kZjUZ1xhlnqK+++kpNnTpVzZs3T+Xk5Ci73a5MJpPKyclRWVlZymAwKJPJpAAVGxur3n//faVUeFkL4JCPjz76SJ1//vnKaDQqTdNUdna2uvnmm9Xq1as7PH7q1KmHrLPJZIrUtVVrnVtlZ2d3WO7DDz/c5TIffPBBlZOToywWi4qLi1MTJkxQixYtOqZ6Huxwy6odTbl33nln5NiUlBQ1a9asNmtQdrWuX375pRo/frwym81q8ODB6te//rUKBALHVOb27dsVoD7++ONDXpejLdfv96tHHnlEDRkyRFksFpWVlaV+9KMftQmqR1vmsmXLVF5enjKbzSohIUHNnTtX7d+/v015n332WYe/d63lzJs3r93v9meffaZGjx6tTCaTGjx4cLt1TYUQ4lCOdyx/5pln1Pnnn6+SkpKUpmnKbrerm2++WVVUVESWGTtSPD9RYvnRlnuwQ8VzieUSy0XfoymlVPe2nQshhBBCCCGEEAJkTLcQQgghhBBCCNFjJOkWQgghhBBCCCF6iCTdQgghhBBCCCFED5GkWwghhBBCCCGE6CGSdAshhBBCCCGEED1Ekm4hhBBCCCGEEKKHSNIthBBCCCGEEEL0EEm6hRBCCCGEEEKIHiJJtxCiW+zduxdN09iwYUNvVyVi+/btnHnmmVgsFkaPHt3b1TkqN9xwA7Nnz+7tagghhDiJSCzvXhLLRStJukWfcMMNN6BpGpqmYTKZyMnJ4dFHHyUQCPR21Y5I0zTeeeed3q6G6MDDDz+M3W6nsLCQpUuX9nZ1hBCiX5NYLnqCxHLRHxh6uwJCtJo5cyYLFy7E6/XywQcfMH/+fIxGIw888MBRlxUMBtE0DZ1O7iud6Hw+HyaTqUvnFhUVceGFF5Kdnd3NtRJCCNERieWiIxLLxclO/ouJPsNsNpOamkp2dja33XYb5557Lu+99x4AXq+Xe+65h4yMDOx2O+PHj2fZsmWRc1977TViY2N57733OOWUUzCbzZSUlOD1ernvvvvIysrCbDaTk5PDK6+8Ejlvy5YtXHDBBURFRZGSksLcuXOpqamJ7J82bRp33HEHP/3pT4mPjyc1NZVHHnkksn/gwIEAXHrppWiaFnleVFTEJZdcQkpKClFRUZx++ul88sknbd5veXk5F154IVarlUGDBvG3v/2NgQMH8swzz0SOaWho4KabbiIpKYno6GjOOeccNm7ceMhr2NotbPHixZx99tnYbDZGjRrFqlWrIsc88sgj7bpnPfPMM5G6w3fdoR5//HFSUlKIjY2NtFbce++9xMfHk5mZycKFC9vVYfv27UycOBGLxcKpp57K559/3mZ/Z6757bffzp133kliYiIzZszo8L2GQiEeffRRMjMzMZvNjB49mo8++iiyX9M01q5dy6OPPoqmaW1+bgd66623yM/Px2q1kpCQwLnnnktLSwsAa9as4bzzziMxMZGYmBimTp3KunXr2pyvaRovv/wy3/ve97DZbOTl5bFq1Sp27drFtGnTsNvtTJw4kaKionY/g5dffpmsrCxsNhtXXnkljY2NHdax9f0uWLCAQYMGYbVaGTVqFG+99VZkf319Pddddx1JSUlYrVaGDh3a4c9HCCF6ksRyieWt11xiecfvV2L5yUmSbtFnWa1WfD4fALfffjurVq1i0aJFbNq0iSuuuIKZM2eyc+fOyPEul4snn3ySP/3pT2zdupXk5GSuv/563nzzTf7v//6PgoICXn75ZaKiooBwEDznnHMYM2YM33zzDR999BGVlZVceeWVberx+uuvY7fb+frrr/nNb37Do48+ypIlS4DwP3KAhQsXUl5eHnnudDqZNWsWS5cuZf369cycOZOLLrqIkpKSSLnXX389ZWVlLFu2jH/961/84Q9/oKqqqs1rX3HFFVRVVfHhhx+ydu1axo4dy/Tp06mrqzvstXvwwQe555572LBhA8OGDeOaa6456u59n376KWVlZSxfvpzf/va3PPzww3zve98jLi6Or7/+mv/3//4ft956K6WlpW3Ou/fee7n77rtZv349EyZM4KKLLqK2tvaor7nJZGLlypW89NJLHdbv2Wef5emnn+app55i06ZNzJgxg4svvjjyO1FeXs6IESO4++67KS8v55577mlXRnl5Oddccw0/+MEPKCgoYNmyZVx22WUopQBobm5m3rx5rFixgq+++oqhQ4cya9Ysmpub25Tz2GOPcf3117NhwwZyc3O59tprufXWW3nggQf45ptvUEpx++23tzln165d/OMf/+Df//43H330EevXr+dHP/rRIX8eCxYs4M9//jMvvfQSW7du5Sc/+Qlz5syJfBB66KGH2LZtGx9++CEFBQW8+OKLJCYmHrI8IYQ4HiSWSyyXWP4dieUnMSVEHzBv3jx1ySWXKKWUCoVCasmSJcpsNqt77rlHFRcXK71er/bv39/mnOnTp6sHHnhAKaXUwoULFaA2bNgQ2V9YWKgAtWTJkg5f87HHHlPnn39+m2379u1TgCosLFRKKTV16lQ1efLkNsecfvrp6r777os8B9Tbb799xPc4YsQI9dxzzymllCooKFCAWrNmTWT/zp07FaB+97vfKaWU+uKLL1R0dLTyeDxtyhkyZIh6+eWXO3yNPXv2KED96U9/imzbunWrAlRBQYFSSqmHH35YjRo1qs15v/vd71R2dnbk+bx581R2drYKBoORbcOHD1dnnXVW5HkgEFB2u129+eabbV77iSeeiBzj9/tVZmamevLJJ5VSnb/mY8aM6fD9HSg9PV39+te/brPt9NNPVz/60Y8iz0eNGqUefvjhQ5axdu1aBai9e/ce8fWUUioYDCqHw6H+/e9/R7YB6uc//3nk+apVqxSgXnnllci2N998U1kslsjzhx9+WOn1elVaWhrZ9uGHHyqdTqfKy8uVUm3/Jjwej7LZbOrLL79sU58f/vCH6pprrlFK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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def g_lower_genovese(x): \n",
    "    return (1/x)**(2/(2 + d))\n",
    "def g_upper_genovese(x): \n",
    "    return (np.log(x)/x)**(2/(2 + d))\n",
    "\n",
    "def g_upper_fefferman(x): \n",
    "    return (np.log(x) / x)**(1/d)\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(10, 4))\n",
    "\n",
    "curves_to_export = {}\n",
    "\n",
    "for i, model_name in enumerate([\"mmls\", \"beta_vae\"]):\n",
    "    d = 4\n",
    "    tau = np.min(list(measures_dsprites.measure_aggregates.normalized_min_reaches.values()))\n",
    "    \n",
    "    match model_name:\n",
    "        case \"mmls\":\n",
    "            dataset_results = (\n",
    "                results_df\n",
    "                .groupby(\"number_of_train_points\")\n",
    "                .agg(list)\n",
    "            )\n",
    "            \n",
    "        case \"beta_vae\":\n",
    "            dataset_results = (\n",
    "                df_dsprites_1\n",
    "                .groupby(\"number_of_train_points\")\n",
    "                .agg(list)\n",
    "            )\n",
    "    \n",
    "    haus_all = dataset_results[\"hausdorff_distance\"]\n",
    "    \n",
    "    f_values_haus = np.array(haus_all.map(np.mean))\n",
    "    x = np.array(dataset_results.index)\n",
    "\n",
    "    x_perc = np.array(dataset_results[\"data_perc\"].str[0])\n",
    "\n",
    "    x_log = np.log(x).reshape(-1, 1)\n",
    "    y_log = np.log(f_values_haus)\n",
    "    \n",
    "    # linear regression\n",
    "    reg = LinearRegression().fit(x_log, y_log)\n",
    "    alpha_fit = -reg.coef_[0]\n",
    "    C_fit = np.exp(reg.intercept_)\n",
    "    f_vals_fitted = C_fit * x**(-alpha_fit)\n",
    "    \n",
    "    C1 = robust_lower_bound(f_vals_fitted, g_lower_genovese, x)\n",
    "    C2 = robust_upper_bound(f_vals_fitted, g_upper_genovese, x)\n",
    "    C = robust_upper_bound(f_vals_fitted, g_upper_fefferman, x)\n",
    "    \n",
    "    yl = C1 * g_lower_genovese(x)\n",
    "    yu = C2 * g_upper_genovese(x)\n",
    "    yu_f = C * g_upper_fefferman(x)\n",
    "\n",
    "    curves_to_export[model_name] = {\n",
    "        \"x\": x, \n",
    "        \"empirical\": f_values_haus, \n",
    "        \"empirical_all_repetitions\": haus_all, \n",
    "        \"lower_genovese\": yl, \n",
    "        \"upper_genovese\": yu, \n",
    "        \"upper_fefferman\": yu_f\n",
    "    }\n",
    "    \n",
    "    ax = axes[i]\n",
    "    # ax.set_title(f\"C1: {C1:.2f}, C2: {C2:.2f}, C: {C:.2f}\")\n",
    "    ax.set_title(f\"Model: {model_name}\")\n",
    "    ax.boxplot(haus_all, positions=x_perc, widths=0.02)\n",
    "    ax.plot(x_perc, f_values_haus, color=\"steelblue\")\n",
    "    # ax[1].plot(x, f_vals_fitted, color=\"steelblue\")\n",
    "    ax.plot(x_perc, yl, color=\"green\", alpha=0.3, label=\"Bounds, Genovese et al.\")\n",
    "    ax.plot(x_perc, yu, color=\"green\", alpha=0.3)\n",
    "    ax.plot(x_perc, yu_f, color=\"purple\", alpha=0.3, label=\"Upper Bound, Fefferman et al.\")\n",
    "    # ax[1].set_ylim((0, 1.05*f_values_haus.max()))\n",
    "    ax.set_xlabel(\"Percentage number of samples\")\n",
    "    ax.set_ylabel(\"Hausdorff distance\")\n",
    "    ax.legend()\n",
    "\n",
    "np.savez(\"all_models_bounds.npz\", **curves_to_export)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"all_models_bounds.png\", dpi=200)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "curvatures",
   "language": "python",
   "name": "curvatures"
  },
  "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.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
