{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Imagenet comparison"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Note that here we overwrite the config samples sizes to reduced the run time "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load configs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running experiments...\n",
      "Seed: 0\n",
      "Experiments: ['ScaleSampleSizeSW', 'ScaleSampleSizeC2ST', 'ScaleSampleSizeMMD', 'ScaleSampleSizeFID']\n",
      "Data: ['imagenet_real_embeddings']\n"
     ]
    }
   ],
   "source": [
    "import datetime\n",
    "import os\n",
    "import pickle\n",
    "import sys\n",
    "import time\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from omegaconf import OmegaConf\n",
    "from torch.distributions import MultivariateNormal\n",
    "\n",
    "from labproject.data import DATASETS, DISTRIBUTIONS, get_dataset\n",
    "from labproject.experiments import *\n",
    "from labproject.plotting import cm2inch, generate_palette\n",
    "from labproject.utils import get_cfg, get_cfg_from_file, get_log_path, set_seed\n",
    "\n",
    "# inline plotting\n",
    "%matplotlib inline\n",
    "\n",
    "\n",
    "\n",
    "print(\"Running experiments...\")\n",
    "# load the config file\n",
    "cfg = get_cfg_from_file(\"conf_embedding_samplesize\")\n",
    "cfg.running_user = 'embedding_samplesize'\n",
    "seed = cfg.seed\n",
    "\n",
    "set_seed(seed)\n",
    "print(f\"Seed: {seed}\")\n",
    "print(f\"Experiments: {cfg.experiments}\") \n",
    "print(f\"Data: {cfg.data}\")\n",
    "\n",
    "# assert cfg.data is list\n",
    "assert len(cfg.data) == len(cfg.n) == len(cfg.d), \"Data, n and d must be lists of the same length\"\n",
    "    \n",
    "# setup colors and labels for plotting\n",
    "\n",
    "color_dict = {\"wasserstein\": \"#cc241d\",\n",
    "              \"mmd\": \"#eebd35\",\n",
    "              \"c2st\": \"#458588\",\n",
    "              \"fid\": \"#8ec07c\", \n",
    "              \"kl\": \"#8ec07c\"}\n",
    "\n",
    "\n",
    "col_map = {'ScaleSampleSizeKL':'kl', 'ScaleSampleSizeSW':'wasserstein',\n",
    "           'ScaleSampleSizeMMD':'mmd', 'ScaleSampleSizeC2ST':'c2st',\n",
    "           'ScaleSampleSizeFID':'fid', 'ScaleDimKL':'kl', 'ScaleDimSW':'wasserstein',\n",
    "           'ScaleDimMMD':'mmd', 'ScaleDimC2ST':'c2st', 'ScaleGammaMMD':'mmd',\n",
    "           'ScaleDimFID':'fid',}\n",
    "\n",
    "mapping = {'ScaleSampleSizeKL':'KL', 'ScaleSampleSizeSW':'SW',\n",
    "           'ScaleSampleSizeMMD':'MMD', 'ScaleSampleSizeC2ST':'C2ST',\n",
    "           'ScaleSampleSizeFID':'FD', 'ScaleDimKL':'KL', 'ScaleDimSW':'SW',\n",
    "           'ScaleDimMMD':'MMD', 'ScaleDimC2ST':'C2ST',\n",
    "           'ScaleDimFID':'FD', 'ScaleGammaMMD':'MMD'}\n",
    "\n",
    "# dark and light colors for inter vs. intra comparisons \n",
    "col_dark = {}\n",
    "col_light = {}\n",
    "for e, exp_name in enumerate(cfg.experiments):\n",
    "    col_dark[exp_name] = generate_palette(color_dict[col_map[exp_name]], saturation='dark')[2]\n",
    "    col_light[exp_name] = generate_palette(color_dict[col_map[exp_name]], saturation='light')[-1]\n",
    "    \n",
    "color_list = [col_light, col_dark] # make this a list to account for true and shifted\n",
    "\n",
    "label_true = {}\n",
    "label_shift = {}\n",
    "for e, data_name in enumerate(cfg.data):\n",
    "    label_true[data_name] = \"true\"\n",
    "    label_shift[data_name] = \"generated\"\n",
    "    \n",
    "label_list = [label_true, label_shift]\n",
    "label_list[1]['toy_2d'] = 'approx.'\n",
    "label_list[1]['random'] = 'shifted'\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Run over the embedding nets and compute all metrics for uncoditional samples and the imagenet image embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "imagenet_real_embeddings 20000 2048\n",
      "Experiment ScaleSampleSizeSW finished in 1.1709089279174805\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_SW_imagenet_real_embeddings_0_.pkl\n",
      "Experiment ScaleSampleSizeSW finished in 1.2682056427001953\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_SW_imagenet_real_embeddings_1_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 1247.8897092342377\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_C2ST_imagenet_real_embeddings_0_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 1583.934558391571\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_C2ST_imagenet_real_embeddings_1_.pkl\n",
      "MMD\n",
      "Experiment ScaleSampleSizeMMD finished in 33.50712823867798\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_MMD_imagenet_real_embeddings_0_.pkl\n",
      "MMD\n",
      "Experiment ScaleSampleSizeMMD finished in 33.10595393180847\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_MMD_imagenet_real_embeddings_1_.pkl\n",
      "Experiment ScaleSampleSizeFID finished in 387.8903315067291\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_FD_imagenet_real_embeddings_0_.pkl\n",
      "Experiment ScaleSampleSizeFID finished in 420.0091345310211\n",
      "Numerical results saved to results/embedding_samplesize/embeddings_samplesize_FD_imagenet_real_embeddings_1_.pkl\n",
      "Finished running experiments.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 393.701x314.961 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# make comparison plots\n",
    "fig, axes = plt.subplots(2, 2, figsize=cm2inch((10, 8)), sharex=\"col\")\n",
    "for ax in axes.flatten():\n",
    "    # move spines outward\n",
    "    ax.spines[\"bottom\"].set_position((\"outward\", 4))\n",
    "    ax.spines[\"left\"].set_position((\"outward\", 4))\n",
    "    ax.locator_params(nbins=4)\n",
    "\n",
    "sample_sizes = cfg.sample_sizes\n",
    "\n",
    "# COMMENT OUT THE FOLLOWING LINES TO RUN THE ACTUAL EXPERIMENTS\n",
    "#sample_sizes = [50,100,200,] # reduced experiment\n",
    "\n",
    "for dd, ds in enumerate(cfg.data):\n",
    "    dataset_fn = get_dataset(cfg.data[dd])\n",
    "    n_samples = cfg.n[dd]\n",
    "\n",
    "    dataset_gt = dataset_fn(2*n_samples, cfg.d[dd])[:n_samples]\n",
    "    # ensure it is different embeddings from the ground truth\n",
    "    dataset_intra = dataset_fn(2*n_samples, cfg.d[dd])[n_samples:]\n",
    "\n",
    "    print(cfg.data[dd], n_samples, cfg.d[dd])\n",
    "\n",
    "    assert (\n",
    "        cfg.data[dd] == \"imagenet_real_embeddings\"\n",
    "    ), \"Only embeddings are supported for this experiment\"\n",
    "    dataset_fn = get_dataset(cfg.augmentation[dd])\n",
    "    dataset_inter = dataset_fn(n_samples, cfg.d[dd])\n",
    "\n",
    "    for e, exp_name in enumerate(cfg.experiments):\n",
    "        experiment = globals()[exp_name]()\n",
    "        ax = axes.flatten()[e]\n",
    "        for dc, data_comp in enumerate([dataset_intra, dataset_inter]):\n",
    "            assert (\n",
    "                dataset_gt.shape == data_comp.shape\n",
    "            ), f\"Dataset shapes do not match: {dataset_gt.shape} vs. {data_comp.shape}\"\n",
    "\n",
    "            time_start = time.time()\n",
    "            if mapping[exp_name] == \"MMD\":\n",
    "                print(\"MMD\")\n",
    "                output = experiment.run_experiment(\n",
    "                    dataset1=dataset_gt,\n",
    "                    dataset2=data_comp,\n",
    "                    sample_sizes=sample_sizes,\n",
    "                    nb_runs=cfg.runs,\n",
    "                    bandwidth=cfg.bandwidth,\n",
    "                )\n",
    "            else:\n",
    "                output = experiment.run_experiment(\n",
    "                    dataset1=dataset_gt,\n",
    "                    dataset2=data_comp,\n",
    "                    sample_sizes=sample_sizes,\n",
    "                    nb_runs=cfg.runs,\n",
    "                )\n",
    "            time_end = time.time()\n",
    "            print(f\"Experiment {exp_name} finished in {time_end - time_start}\")\n",
    "\n",
    "            # log results\n",
    "            log_path = get_log_path(\n",
    "                cfg, tag=f\"_{mapping[exp_name]}_{cfg.data[dd]}_{dc}\", timestamp=False\n",
    "            )\n",
    "            os.makedirs(os.path.dirname(log_path), exist_ok=True)\n",
    "            experiment.log_results(output, log_path)\n",
    "            print(f\"Numerical results saved to {log_path}\")\n",
    "\n",
    "            # plot results\n",
    "            experiment.plot_experiment(\n",
    "                *output,\n",
    "                cfg.data[dd],\n",
    "                ax=ax,\n",
    "                color=color_list[dc][exp_name],\n",
    "                label=label_list[dc][cfg.data[dd]],\n",
    "                linestyle=\"-\" if dc == 0 else \"--\",\n",
    "                lw=2,\n",
    "                marker=\"o\",\n",
    "            )\n",
    "\n",
    "            ax.set_ylabel(\n",
    "                mapping[exp_name] + str(cfg.bandwidth)\n",
    "                if mapping[exp_name] == \"MMD\"\n",
    "                else mapping[exp_name]\n",
    "            )\n",
    "            ax.set_xlabel(\"\")\n",
    "\n",
    "            if mapping[exp_name] == \"C2ST\":\n",
    "                ax.set_ylim([0.30, 1])\n",
    "                ax.set_yticks([0.5, 1])\n",
    "\n",
    "        ax.legend()\n",
    "\n",
    "axes[-1, 0].set_xlabel(\"sample size\")\n",
    "axes[-1, 1].set_xlabel(\"sample size\")\n",
    "os.makedirs(\"./results/plots\", exist_ok=True)\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(\n",
    "    f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_{cfg.data}_only_embed_MMD_{cfg.bandwidth}.png\",\n",
    "    dpi=300,\n",
    ")\n",
    "fig.savefig(\n",
    "    f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_{cfg.data}_only_embed_MMD_{cfg.bandwidth}.pdf\",\n",
    "    dpi=300,\n",
    ")\n",
    "\n",
    "print(\"Finished running experiments.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished running experiments.\n"
     ]
    }
   ],
   "source": [
    "axes[-1, -1].set_yscale(\"log\")\n",
    "fig.tight_layout()\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(\n",
    "    f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_{cfg.data}_only_embed_MMD_{cfg.bandwidth}log.png\",\n",
    "    dpi=300,\n",
    ")\n",
    "fig.savefig(\n",
    "    f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_{cfg.data}_only_embed_MMD_{cfg.bandwidth}log.pdf\",\n",
    "    dpi=300,\n",
    ")\n",
    "\n",
    "print(\"Finished running experiments.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "labproject",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
