{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Perform main sample size and dimensionality scaling experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load the configs and set up the plotting "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running experiments...\n",
      "Seed: 0\n",
      "Experiments: ['ScaleSampleSizeSW', 'ScaleSampleSizeC2ST', 'ScaleSampleSizeMMD']\n",
      "Data: ['toy_2d', 'random', 'random']\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_main_scaling_experiment\")\n",
    "cfg.running_user = 'main_scaling_experiment'\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",
    "for e, exp_name in enumerate(cfg.experiments_dim):\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": [
    "## Loop over the three dataset conditions for the sample size experiments and the dimensionality scaling "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "toy_2d 50000 2\n",
      "Experiment ScaleSampleSizeSW finished in 0.14130663871765137\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_toy_2d_ds_0_bw_1_0_.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1249013/75318551.py:28: UserWarning: The use of `x.T` on tensors of dimension other than 2 to reverse their shape is deprecated and it will throw an error in a future release. Consider `x.mT` to transpose batches of matrices or `x.permute(*torch.arange(x.ndim - 1, -1, -1))` to reverse the dimensions of a tensor. (Triggered internally at ../aten/src/ATen/native/TensorShape.cpp:3637.)\n",
      "  torch.mean(dataset_gt, axis=0).T, torch.cov(dataset_gt.T)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment ScaleSampleSizeSW finished in 0.13274812698364258\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_toy_2d_ds_0_bw_1_1_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 59.161877155303955\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_toy_2d_ds_0_bw_1_0_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 91.61674976348877\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_toy_2d_ds_0_bw_1_1_.pkl\n",
      "MMD toy_2d 0 1\n",
      "Experiment ScaleSampleSizeMMD finished in 1.7586042881011963\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_toy_2d_ds_0_bw_1_0_.pkl\n",
      "MMD toy_2d 0 1\n",
      "Experiment ScaleSampleSizeMMD finished in 1.7076401710510254\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_toy_2d_ds_0_bw_1_1_.pkl\n",
      "random 50000 10\n",
      "Experiment ScaleSampleSizeSW finished in 0.14093399047851562\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_random_ds_1_bw_5_0_.pkl\n",
      "Experiment ScaleSampleSizeSW finished in 0.14368605613708496\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_random_ds_1_bw_5_1_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 173.15071654319763\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_random_ds_1_bw_5_0_.pkl\n",
      "Experiment ScaleSampleSizeC2ST finished in 140.77306056022644\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_random_ds_1_bw_5_1_.pkl\n",
      "MMD random 1 5\n",
      "Experiment ScaleSampleSizeMMD finished in 1.723785161972046\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_random_ds_1_bw_5_0_.pkl\n",
      "MMD random 1 5\n",
      "Experiment ScaleSampleSizeMMD finished in 1.6481142044067383\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_random_ds_1_bw_5_1_.pkl\n",
      "random 50000 1000\n",
      "Experiment ScaleDimSW finished in 0.7471611499786377\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_random_ds_2_bw_10_0_.pkl\n",
      "Experiment ScaleDimSW finished in 0.7502999305725098\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_SW_random_ds_2_bw_10_1_.pkl\n",
      "Experiment ScaleDimC2ST finished in 943.5828912258148\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_random_ds_2_bw_10_0_.pkl\n",
      "Experiment ScaleDimC2ST finished in 704.4154124259949\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_C2ST_random_ds_2_bw_10_1_.pkl\n",
      "MMD random 2 10\n",
      "Experiment ScaleDimMMD finished in 39.61072611808777\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_random_ds_2_bw_10_0_.pkl\n",
      "MMD random 2 10\n",
      "Experiment ScaleDimMMD finished in 39.43699407577515\n",
      "Numerical results saved to results/main_scaling_experiment/main_scaling_experiment_MMD_random_ds_2_bw_10_1_.pkl\n",
      "Finished running experiments.\n"
     ]
    },
    {
     "data": {
      "image/png": "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v2+Px/n888+xWCx8+eWXGIbB8ccfzzvvvMPatWt59NFHOeGEE7jlllu4++67eeyxxwBIT0/nm2++4Y033uDSSy9l9erVseVr164lFAoxbNgwFi9ezNSpU3n55Zc5//zzWbZsGU8//TRXX301t956K9XV1dx222179b6FONT0ZHx4/vnnGTduHA899BBr167lr3/9KwBut5sVK1bw3XffccIJJ3DllVfG9rn77rv56KOPWLBgATNnzuS1115jwYIFTJgwgaOPPpo//OEPTJ48mc2bNzNr1iw2btzIDTfcwMUXX8yPfvQjnn32WR5//PG9er9CHAr2JRaAGQ+qamt3u++hGg8keRAHrSSXm9zMzA7Xt76SAGY2X5SfT3pqaof7Jrnce3ztGTNmkJWVxWOPPca6devYsGEDHo+HwYMHc8IJJwBw6aWXcsEFF8T2ueqqqwA47bTTuPTSS6murgZg+vTpAGzYsIGMjIzYFYN58+Zx9dVX09DQwHHHHcfs2bO58cYbWbNmDaoq3ZWE2J2ejA8zZ85k9uzZbN26lVNOOYUFCxYwd+5czjrrLADGjh0b+/7vicfjYenSpcyfPz+2LBwOs337dpYsWcILL7wAwIUXXphQ+BBCmPYUC6DjeJCTmYnX79/tsfekL8YDSR7EQevCH+y5uvD1jz7iV399El3XUVWV26+aT15WFr+/9Wf79dr/+c9/uPPOO7n55pu5/PLLqa6uZuDAgVitLV8pXdexWCyx5x2tc7vdsWWtGYZBJBLBMAzWr19Pamoqq1evpri4eL/OX4i+rifjw/jx49mwYQPvvPMOb775Jg899BB5eXmxGLA3HRk1TcPpdLJy5crYsl27dlFQUICiKBiGETtmfLwRQpg6Ewug/XjQFX0e+mI86LbkobK2do+ZnhDd7fTjj2fq+PHsLC+nKD+fvKysLjnuBx98wHnnncfll19OaWkpn3zyCbNmzWLTpk2sWLGCSZMm8fTTT3PSSSfF9nnxxRe5+eabee211xg2bBgZGRkJxxwxYgS1tbV8+eWXTJ06lZdeeomioiKysrL4y1/+gsVi4b///S9z587l22+/bbN/bybxQPRG3RUfHnjgAbxeL/fddx9z5sxhwIABOJ3OvTqG1WolEomQlpbGsGHDeO6557jooov47LPPOPvss9m+fTuzZs3imWee4cYbb+T1118n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dDrVWWedpV5//XV18OBB1adPH6WUUtdcc4168803lVJK5ebmqgEDBqjs7OyQtP3qV79Sf//735VSSn355Zfq//7v/5RSSvXp0yewDLtSSrlcLjV58mS1ZMkSpZRSkyZNUps2bVJKKbVv3z7Vt29f5Xa7W/S+CXGqkbxACCFEXaTbkggxZcoUZsyYwcGDB5k5cyaLFy8G4KWXXuKDDz7grbfeYv369ZSVlQXOqZ7yq0+fPqSnp9OtWzcAEhISKCoqAuCSSy6he/fuAFx99dWsWbOGM844I3CNTz/9lJ9++okHHngAALfbzc6dOwPXArjwwgu5/vrrWb9+PRdddBG//OUv63wPt912G+np6SxYsICysjI2btzIwoULA/vdbjdHjhyhf//+zbxbQpy6JC8QQghRFwkeRIhRo0axZ88ePvroIz744AMee+wxdu7cyTnnnMPkyZOZOnUq06ZN49prrw2cY7VaA4/N5rr/pIK3G4aByWQK2e/1evnyyy9JSEgAfIuYJCcnhxwzY8YMduzYwYcffshrr73GsmXLWLVqVcgxTzzxBHv37uWzzz4LXNdut7N169bAMRkZGaSmpjbhrgjR9UheIIQQoi4y5kGEePjhh3nkkUe46qqreOaZZ8jJyaGwsJA9e/bwP//zP1x00UV8+umneL3eJl33448/pqioiKqqKl555RUuuOCCkP1Tp07lH//4BwB79+5l+PDhFBQUhBxz66238u677zJ//nyeeuopvvvuu5D9n3zyCU899RQrV64MFFBiY2MZNGgQL730EgBr167l9NNPx+PxNCn9QnQ1khcIIYSoi7Q8iBALFy7k2muvZeTIkZjNZu6//34SEhJYuHAhw4cPJyYmhgkTJlBRURHSXaExqampXHzxxeTk5HDttdcya9YsDh06FNj/5JNPcssttzBy5EgMw+D5558P6aYA8Jvf/IZ58+bx9NNPYzKZePbZZ0P233nnnXi9XmbMmIFhGIBvgOaKFSu49dZb+ctf/oLJZOKNN94IqSEVQtQmeYEQQoi6yCJxotUtW7aM1atXs2zZsvZOihCiHUleIMSpY/78+Zx22mmsXbu2zadJrq4wuOWWW9r0dYWPtDwIIYQQQogm69GjR7usryJBQ/uSMQ+i1c2fP19qGoUQkhcI0Ykppfj1r3/NoEGDmDJlCvv37wcIrA4fzlovXq+Xu+++m7FjxzJy5EgefPBBAFavXs306dO5/PLLGTZsGBdccAEFBQUYhsGtt97KqFGjGDt2bGDWt8WLFwcef/DBB4wePZqRI0cyd+5csrOzA+m69957mTBhAoMGDeKTTz4B4L333mPs2LGMGzeOCy64gJycnLa5gacQCR6EEEIIIUSD3nzzTbZs2cKOHTtYuXIl+/btq3VMRkYG33//PQ8++CB33HEHzzzzDFu3buWFF16gqKiI559/HpfLxZYtW9iyZQvffvstH3zwAQDr16/n8ccfZ8eOHURERLBixQq2b9/Oxo0b2bZtG+vWrWPv3r1UVFQEXi8nJ4ebb76Zt956ix9++IFJkyZxxx13BPbHxsayfv16/vKXv/DHP/4RgPvuu48XX3yRzZs3c/HFF7Nly5ZWvnOnHum2JIQQQgghGrR69Wouv/xyLBYLycnJXHTRRbWOaWytl08//ZTvv/+eNWvWAFBeXs727ds566yzSE9Pp3fv3gCMHj2agoICBg4ciNPp5Nxzz+Wiiy7ioYceIjIyMvB6Gzdu5Mwzzwys1XLzzTfz5z//uVZ6qq8HMHfuXGbNmsWcOXOYPXs2559/fkvfqlOetDwIIYQQQogGaZpG8Bw7Foul1jGNrfXi9Xp55JFH2Lp1K1u3bmX9+vUsWrQIALvdXuu1HA4HW7du5Z577iEvL4+zzjqLPXv2BI6rnk2tmlIKt9sdeF59zeC033fffaxatYp+/frxu9/9joceeqhJ90FI8CCEEEIIIRoxffp0Xn31VZxOJ0VFRXz88cdNvsbUqVP517/+hdvtpqKigmnTptVa4DHY2rVrmTlzJlOnTuXRRx9l2LBh7N69O7B//PjxbNiwgQMHDgDw3HPPMXny5AbTkJ6eDsCvf/1r7rrrrlrrxIjGSbclIYQQQgjRoDlz5rBp0ybS09Pp3r07Q4cObfI1brnlFvbt28eYMWNwu91cffXVzJkzh9WrV9d5/KRJkxgyZAjp6elEREQwduxYZs6cGRinkJKSwnPPPcdll12G2+2mV69ePP/88w2m4eGHH+bKK6/EYrEQGRnJM8880+T30dXJOg9CCCGEEEKIsEi3JSGEEEIIIURYJHgQQgghhBBChEWCByGEEEIIIURYJHgQQgghhBBChEWCByGEEEIIIURYJHgQQgghhBBChEWCByGEEEIIIURYJHgQQgghhBBChEWCByGEEEIIIURYJHgQQgghhBBChOX/A/VkkYxCmZ/QAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 787.402x393.701 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# make comparison plots\n",
    "fig, axes = plt.subplots(3, 3, figsize=cm2inch((20, 10)), 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=3)\n",
    "\n",
    "# Loop over all three datasets\n",
    "for dd, ds in enumerate(cfg.data):\n",
    "\n",
    "    # specify the bandwidth parameters to vary for each dataset\n",
    "    # custom_values = np.linspace(cfg.val_min[dd], cfg.val_max[dd], cfg.val_step[dd]) # switch for linspacing\n",
    "\n",
    "    dataset_fn = get_dataset(cfg.data[dd])\n",
    "    # sample double the number of samples to ensure variability at the highest samples set size\n",
    "    n_samples = cfg.n[dd] * cfg.runs\n",
    "\n",
    "    # generate the ground truth and the two approximations inter and intra\n",
    "    dataset_gt = dataset_fn(n_samples, cfg.d[dd])\n",
    "    dataset_intra = dataset_fn(n_samples, cfg.d[dd])\n",
    "\n",
    "    print(cfg.data[dd], n_samples, cfg.d[dd])\n",
    "\n",
    "    # generate the inter dataset\n",
    "    if cfg.data[dd] == \"toy_2d\":\n",
    "        dataset_inter = MultivariateNormal(\n",
    "            torch.mean(dataset_gt, axis=0).T, torch.cov(dataset_gt.T)\n",
    "        ).sample((n_samples,))\n",
    "    elif cfg.data[dd] == \"random\" and cfg.augmentation[dd] == \"mean_shift\":\n",
    "        # shift the mean by 1 for all dimensions\n",
    "        dataset_inter = dataset_fn(n_samples, cfg.d[dd]) + 1\n",
    "    elif cfg.data[dd] == \"random\" and cfg.augmentation[dd] == \"one_dim_shift\":\n",
    "        # just shift the first dimension by 1\n",
    "        dataset_inter = dataset_fn(n_samples, cfg.d[dd])\n",
    "        dataset_inter[:, 0] += 1  # just shift the mean of first dim by 1\n",
    "\n",
    "    if dd < 2:  # for the first two datasets, we compare sample sizes\n",
    "        for e, exp_name in enumerate(cfg.experiments):\n",
    "            experiment = globals()[exp_name]()\n",
    "            ax = axes[e, dd]\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",
    "                time_start = time.time()\n",
    "                if mapping[exp_name] == \"MMD\":\n",
    "                    print(f\"MMD {cfg.data[dd]} {dd} {cfg.mmd_bandwidth[dd][e]}\")\n",
    "                    output = experiment.run_experiment(\n",
    "                        dataset1=dataset_gt,\n",
    "                        dataset2=data_comp,\n",
    "                        sample_sizes=cfg.sample_size,\n",
    "                        nb_runs=cfg.runs,\n",
    "                        bandwidth=cfg.mmd_bandwidth[dd][e],\n",
    "                    )\n",
    "                else:\n",
    "                    output = experiment.run_experiment(\n",
    "                        dataset1=dataset_gt,\n",
    "                        dataset2=data_comp,\n",
    "                        sample_sizes=cfg.sample_size,\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_path = get_log_path(\n",
    "                    cfg, tag=f\"_{mapping[exp_name]}_{cfg.data[dd]}_ds_{dd}_bw_{cfg.mmd_bandwidth[dd][e]}_{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",
    "                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",
    "                ax.set_ylabel(mapping[exp_name] + str(cfg.mmd_bandwidth[dd][e]) if mapping[exp_name]  == 'MMD' else mapping[exp_name])\n",
    "                ax.set_xlabel(\"\")\n",
    "                if mapping[exp_name] == \"C2ST\":\n",
    "                    ax.set_ylim([0.45, 1])\n",
    "                    ax.set_yticks([0.5, 1])\n",
    "            ax.legend()\n",
    "    else:  # for the last dataset, we compare dimensions\n",
    "        for e, exp_name in enumerate(cfg.experiments_dim):\n",
    "            experiment = globals()[exp_name]()\n",
    "            ax = axes[e, 2]\n",
    "            ax.set_xscale(\"log\")\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",
    "                time_start = time.time()\n",
    "                if exp_name == \"ScaleDimMMD\":\n",
    "                    output = experiment.run_experiment(\n",
    "                        dataset1=dataset_gt,\n",
    "                        dataset2=data_comp,\n",
    "                        dataset_size=cfg.n[dd],\n",
    "                        dim_sizes=cfg.dim_sizes,\n",
    "                        nb_runs=cfg.runs_dim,  # deterministic\n",
    "                        bandwidth=cfg.mmd_bandwidth[dd][e],\n",
    "                    )\n",
    "                    print(f\"MMD {cfg.data[dd]} {dd} {cfg.mmd_bandwidth[dd][e]}\")\n",
    "                else:\n",
    "                    output = experiment.run_experiment(\n",
    "                        dataset1=dataset_gt,\n",
    "                        dataset2=data_comp,\n",
    "                        dataset_size=cfg.n[dd],\n",
    "                        dim_sizes=cfg.dim_sizes,\n",
    "                        nb_runs=cfg.runs_dim,\n",
    "                    )\n",
    "                time_end = time.time()\n",
    "                print(f\"Experiment {exp_name} finished in {time_end - time_start}\")\n",
    "\n",
    "                log_path = get_log_path(\n",
    "                    cfg, tag=f\"_{mapping[exp_name]}_{cfg.data[dd]}_ds_{dd}_bw_{cfg.mmd_bandwidth[dd][e]}_{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",
    "                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",
    "                ax.set_ylabel(mapping[exp_name] + str(cfg.mmd_bandwidth[dd][e]) if mapping[exp_name]  == 'MMD' else mapping[exp_name])\n",
    "                ax.set_xlabel(\"\")\n",
    "                if mapping[exp_name] == \"C2ST\":\n",
    "                    ax.set_ylim([0.45, 1])\n",
    "                    ax.set_yticks([0.5, 1])\n",
    "\n",
    "            ax.legend()\n",
    "\n",
    "axes[-1, -1].set_xlabel(\"dimensions\")\n",
    "axes[-1, 0].set_xlabel(\"sample size\")\n",
    "axes[-1, 1].set_xlabel(\"sample size\")\n",
    "\n",
    "\n",
    "os.makedirs(\"./results/plots\", exist_ok=True)\n",
    "fig.tight_layout()\n",
    "fig.savefig(f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_and_dimensionality.png\", dpi=300)\n",
    "fig.savefig(f\"./results/plots/{cfg.exp_log_name}_metric_comparison_sample_size_and_dimensionality.pdf\", dpi=300)\n",
    "\n",
    "\n",
    "print(\"Finished running experiments.\")"
   ]
  }
 ],
 "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
}
