{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compare MMD kernels that do not have parameters in scaling experiments\n",
    "\n",
    "RBF kernel (standard with bandwidth parameter) compared to linear kernel and an energy based kernel"
   ]
  },
  {
   "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: ['ScaleSampleSizeMMD', 'ScaleSampleSizeMMDlinear', 'ScaleSampleSizeMMDenergy']\n",
      "Data: ['toy_2d', 'random', 'random']\n"
     ]
    }
   ],
   "source": [
    "import os\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",
    "print(\"Running experiments...\")\n",
    "# load the config file\n",
    "cfg = get_cfg_from_file(\"conf_mmd_main_scaling_experiment_different_kernels\")\n",
    "cfg.running_user = 'MMD_main_scaling_kernel_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",
    "color_dict = {\"wasserstein\": \"#cc241d\",\n",
    "              \"mmd\": \"#eebd35\",\n",
    "              \"c2st\": \"#458588\",\n",
    "              \"fid\": \"#8ec07c\", \n",
    "              \"kl\": \"#8ec07c\"}\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','ScaleDimMMDlinear':'mmd',  'ScaleDimMMDenergy':'mmd',\n",
    "           'ScaleSampleSizeMMDlinear':'mmd',  'ScaleSampleSizeMMDenergy':'mmd',}\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",
    "            'ScaleSampleSizeMMDlinear':'MMDlin',  'ScaleSampleSizeMMDenergy':'MMDen',\n",
    "            'ScaleDimMMDlinear':'MMDlin',  'ScaleDimMMDenergy':'MMDen'}\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'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Loop over the three datasets for respective MMD kernel implementations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "toy_2d 50000 2\n",
      "ScaleSampleSizeMMD MMD toy_2d 0 1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_24636/216142709.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 ScaleSampleSizeMMD finished in 1.4273862838745117\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_toy_2d_ds_0_bw_1_0_.pkl\n",
      "ScaleSampleSizeMMD MMD toy_2d 0 1\n",
      "Experiment ScaleSampleSizeMMD finished in 1.3973114490509033\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_toy_2d_ds_0_bw_1_1_.pkl\n",
      "ScaleSampleSizeMMDlinear MMD toy_2d 0 no params\n",
      "Experiment ScaleSampleSizeMMDlinear finished in 0.021864891052246094\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_toy_2d_ds_0_bw_1_0_.pkl\n",
      "ScaleSampleSizeMMDlinear MMD toy_2d 0 no params\n",
      "Experiment ScaleSampleSizeMMDlinear finished in 0.0218961238861084\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_toy_2d_ds_0_bw_1_1_.pkl\n",
      "ScaleSampleSizeMMDenergy MMD toy_2d 0 no params\n",
      "Experiment ScaleSampleSizeMMDenergy finished in 0.9617993831634521\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_toy_2d_ds_0_bw_1_0_.pkl\n",
      "ScaleSampleSizeMMDenergy MMD toy_2d 0 no params\n",
      "Experiment ScaleSampleSizeMMDenergy finished in 0.924964427947998\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_toy_2d_ds_0_bw_1_1_.pkl\n",
      "random 50000 10\n",
      "ScaleSampleSizeMMD MMD random 1 5\n",
      "Experiment ScaleSampleSizeMMD finished in 1.420243740081787\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_random_ds_1_bw_5_0_.pkl\n",
      "ScaleSampleSizeMMD MMD random 1 5\n",
      "Experiment ScaleSampleSizeMMD finished in 1.3829517364501953\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_random_ds_1_bw_5_1_.pkl\n",
      "ScaleSampleSizeMMDlinear MMD random 1 no params\n",
      "Experiment ScaleSampleSizeMMDlinear finished in 0.02272176742553711\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_random_ds_1_bw_5_0_.pkl\n",
      "ScaleSampleSizeMMDlinear MMD random 1 no params\n",
      "Experiment ScaleSampleSizeMMDlinear finished in 0.02247762680053711\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_random_ds_1_bw_5_1_.pkl\n",
      "ScaleSampleSizeMMDenergy MMD random 1 no params\n",
      "Experiment ScaleSampleSizeMMDenergy finished in 1.0050208568572998\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_random_ds_1_bw_5_0_.pkl\n",
      "ScaleSampleSizeMMDenergy MMD random 1 no params\n",
      "Experiment ScaleSampleSizeMMDenergy finished in 0.9576895236968994\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_random_ds_1_bw_5_1_.pkl\n",
      "random 50000 1000\n",
      "ScaleDimMMD MMD random 2 10\n",
      "Experiment ScaleDimMMD finished in 37.54896664619446\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_random_ds_2_bw_10_0_.pkl\n",
      "ScaleDimMMD MMD random 2 10\n",
      "Experiment ScaleDimMMD finished in 38.63400721549988\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMD_random_ds_2_bw_10_1_.pkl\n",
      "ScaleDimMMDlinear MMD random 2 no params\n",
      "Experiment ScaleDimMMDlinear finished in 0.16700053215026855\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_random_ds_2_bw_10_0_.pkl\n",
      "ScaleDimMMDlinear MMD random 2 no params\n",
      "Experiment ScaleDimMMDlinear finished in 0.1669614315032959\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDlin_random_ds_2_bw_10_1_.pkl\n",
      "ScaleDimMMDenergy MMD random 2 no params\n",
      "Experiment ScaleDimMMDenergy finished in 29.14513874053955\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_random_ds_2_bw_10_0_.pkl\n",
      "ScaleDimMMDenergy MMD random 2 no params\n",
      "Experiment ScaleDimMMDenergy finished in 29.86012363433838\n",
      "Numerical results saved to results/MMD_main_scaling_kernel_experiment/MMD_main_scaling_kernel_experiment_MMDen_random_ds_2_bw_10_1_.pkl\n",
      "Finished running experiments.\n"
     ]
    },
    {
     "data": {
      "image/png": "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YdM//kj+8T0N7jdh6vVMyFpwynN/+umnaJrG1q1bEUIwffp03nnnHfbu3ctjjz3GjBkzuOuuu1iyZAnLlwcLnfHx8Xz11Ve89dZbLFiwgG+//Ta8fO/evfh8PgYPHswrr7zCpEmTWL9+PVdffTVffPEFq1at4uabb+bXv/41hYWF/OY3v2np5ZLaoKTgKFB/hOvRk37MqLPnogd8+P1uvO4KLLYYOeShdNr57L0VHP9hByMmzA4/MHOVF7DzP69w4vAuLrjszk5OodRWqqoR7UjCHpNISvpgxp1/DXt3vM2+r97FWZYPBIer3vzPBygrOcHErAVEO5LRTF1voIimygfQeBlh3853KMr/odH9mlNGWLt2LWPGjOGhhx5i7969PPPMMwDY7XZ27NjB119/zYwZM2rNKL1kyRI++OADli5dSlZWFq+//jpLly5l3LhxnHfeeTzyyCNMmDCB77//nuzsbA4ePMjtt9/Oddddx09/+lPWrFnDU0891ZzL0yqylNsaDRQGLBY7la4SvB4XUdFxnZCons3rceEsO9mifYQwKCk8RqWzuNF9vR5Xk8e54IILSEpKYvny5ezbt48DBw7gdDoZOHAgM2bMAGDBggVcc8014X1uuukmAH70ox+xYMECCgsLAZgyZQoABw4cICEhIfz0YN68edx8882UlZUxbdo0Zs6cyR133MGePXtQ5SgYHSohpS+KoiKEEV6mKCqDRk1H00woioKztIwTh3dhtccRE5uMLSoWs9UuAwnptLBnx7+44X/eqNd5duj4i3n+gStk8HAaURQFW1Qstt6xJKb0Y+zkeezbuYG9O96m+OQhzFY7fc6YSN6xb7HZY4lL7E10bAomU9dpztSa8gGEBsAoO3nKfZtTRsjKymLmzJkcOnSIWbNmsXTpUmbPns2Pf/xjAEaPHh0uAzTF6XSybds2Fi9eHF7m9/s5evQomzdv5qWXXgLg2muvrRWMtDcZPLSCYfgpLzmBsywfR3waMXG9UDUThq7j9VTI4KETWG3RxMT1anR93acKECzwJST3wR6T2Oi+VlvTkwX985//5Pe//z133nknN9xwA4WFhfTr1w+Tqfr2MgwDTav+om1snd1uDy+rSwhBIBBACMH+/fuJjY3l22+/pX///k2mMdJyj35Det9RABz97gt+2LMFVdUYPHoG6f3GdHLq2pcjPo2L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sIsuukhNmDBBTZs2TW3atEkppZRpmur2229XJ554oho7dqxauXJlb36sPiX6pkGua8+RONBxEgfiT+JA//f++++riRMnKrvdHrnZk5HdWpPr1DE9dZ00pZSKT4WIEEIIIYRozzXXXMO1117LlVdeydq1a8nLy+Opp57irbfe4oknngDgr3/9K2vXruXxxx/v5dL2HrlOHdNT10n6PAghhBBC9IKmG7poMhJWa3KdOqanrpMMrSCEEEII0UfISFgdI9epY+JxneQqCyGEEEL0EW2NhCUju7Um16lj4nGdJHkQQgghhOgj5s2bx5tvvklRURGBQICnnnqq80NpHgfkOnVMPK6T9HkQQgghhOgjcnJyuP/++5k3bx4+n48lS5Zw4YUX9nax+hy5Th0Tj+skoy0JIYQQQgghOkSaLYletW/fPvLy8rp8nHPPPZfDhw93vUBCiB4ncUAIIfoPabYkBoT//Oc/vV0EIUQvkzgghBDxJzUPopXS0lLOOeccTj75ZKZPn87LL78MwLp16zj99NOZNm0aI0aM4JlnngHg6quv5jvf+Q4nnXQSw4YN4+mnn+biiy/mhBNO4OabbwbgySef5LzzzmP27NmMGjWKm266iZYt5kpKSrjooos4+eSTOfnkk/nXv/7Vqmy7du3i9NNPZ/r06Zx22mm8//77AOTl5bFv3z5uv/12pk6dytSpUznhhBNwOp3U1dWxe/du5s+fz7Rp05g5c2ZkPyFE2yQOCCGEaFOX5qcWA9IDDzygvv/97yullNqyZYu65ZZblFJKXXzxxeqLL75QSin11ltvqYkTJyqllFq2bJlavHixUkqpJ598UiUnJ6uioiJVXV2tvF6vqqioUE888YTKzMxUBQUFyufzqZkzZ6rnnntO7d27Vw0fPlwppdTXv/519cILLyillCopKVEnnHCCKioqiinbzTffrH73u98ppZR6++231a9+9SullFLDhw+PTMWulFJ+v1+deeaZ6tFHH1VKKXX66aerjz/+WCml1K5du1ReXp4KBALdet2EGEgkDgghhGiLNFsSrcyZM4cFCxawd+9eFi5cyIoVKwB4+umneeWVV3jxxRdZv349tbW1kX2ahv0aPnw4EydOZNCgQQCkpaVRWVkJwPnnn092djYAl19+OevWreOUU06JHOP111/nyy+/5J577gEgEAiwdevWyLEA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",
      "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 exp_name == \"ScaleSampleSizeMMD\":\n",
    "                    print(f\"{exp_name} MMD {cfg.data[dd]} {dd} {cfg.mmd_bandwidth[dd]}\")\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],\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",
    "                    print(f\"{exp_name} MMD {cfg.data[dd]} {dd} no params\")\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]}_{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('MMD' + str(cfg.mmd_bandwidth[dd]) 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",
    "                    print(f\"{exp_name} MMD {cfg.data[dd]} {dd} {cfg.mmd_bandwidth[dd]}\")\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],\n",
    "                    )\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",
    "                    print(f\"{exp_name} MMD {cfg.data[dd]} {dd} no params\")\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]}_{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('MMD' + str(cfg.mmd_bandwidth[dd]) 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(\n",
    "    f\"./results/plots/MMD_kernels_scaling_{cfg.mmd_bandwidth}_{cfg.n[0]}.png\", dpi=300\n",
    ")\n",
    "fig.savefig(\n",
    "    f\"./results/plots/MMD_kernels_scaling_{cfg.mmd_bandwidth}_{cfg.n[0]}.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
}
