{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f7317e3a-ca3c-42a6-b680-7ce33ff99673",
   "metadata": {},
   "source": [
    "# Notebook to reproduce the graphs associated with Gaussian variables with varying dimensions"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8e0a03b6-3cf8-492c-81ff-caf097302c12",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "41d6ead1-1bc3-4581-b5cb-0f7231574315",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Utilisation du CPU\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x11673a990>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# import packages\n",
    "import scipy\n",
    "import torch\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "from torch.optim import Adam, lr_scheduler\n",
    "\n",
    "from IPython.display import display, Math, Latex\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import cm\n",
    "import matplotlib as mpl\n",
    "from tqdm import tqdm, trange\n",
    "import pandas as pd\n",
    "import ot\n",
    "import os\n",
    "\n",
    "import functions as func\n",
    "import diffusion as diff\n",
    "import synthetic_data as synt\n",
    "\n",
    "import seaborn as sns\n",
    "sns.set_theme()\n",
    "import pickle\n",
    "import time\n",
    "\n",
    "import sampler as sp\n",
    "import decoder\n",
    "from functions import gaussian, empirical, kl_divergence, kl, wasserstein_w2, w2\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "device_cuda = torch.device(\"cuda:0\")\n",
    "device_cpu = torch.device(\"cpu\")\n",
    "\n",
    "if torch.cuda.is_available() and torch.backends.cuda.is_built():\n",
    "    print(\"Utilisation du GPU\")\n",
    "    device = device_cuda\n",
    "else:\n",
    "    print(\"Utilisation du CPU\")\n",
    "    device = device_cpu\n",
    "device = torch.device(\"cpu\")\n",
    "\n",
    "#seed = torch.random.seed()\n",
    "#print(\"seed:\", seed)\n",
    "seed = 20\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc0355e1-79e7-4df5-916b-e74c1c74aebc",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# ISOTROPIC KL & W2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5e592d00-5280-46eb-8524-9df58f8acc97",
   "metadata": {},
   "outputs": [],
   "source": [
    "#### ISOTROPIC\n",
    "########### SET Training data PARAMETERS #################\n",
    "a = 0.\n",
    "a_values = np.linspace(0.,4.5,19) #set the parameter values for the beta_parametric function\n",
    "sigma_inv = 1\n",
    "beta_min = 0.1\n",
    "beta_max = 20\n",
    "T = 1\n",
    "\n",
    "dimensions = [5,10,25,50]\n",
    "n = 10000\n",
    "\n",
    "sample_by_d = []\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    sample_by_d.append(training_distribution.generate_sample(n))\n",
    "\n",
    "    if d==5: \n",
    "    # optimisation parameters\n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "    # optimisation parameters\n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "    # optimisation parameters\n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-3\n",
    "        \n",
    "    elif d==50: \n",
    "    # optimisation parameters\n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(sample_by_d[idx], batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ffad1be7-dddc-440e-86a8-7862425a8d82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\n    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\\n    for k, a in enumerate(a_values):\\n        print(f\"optimization for a = {a}\")\\n        sde.beta.change_a(a)\\n        score_theta_trained[k] = [ ]\\n        for j in range(rep_size):\\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            optimizer = Adam(network.parameters(), lr=learning_rate)\\n            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\\n            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n            score_theta_trained[k].append(network)\\n            torch.save(network.state_dict(), f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{k}_{j}_d\\'+str(d)+\\'.pt\\')\\n\\n\\nnum_steps = 500\\ndimensions = [5,10,25, 50] \\n\\nsimulation_results = []\\na = 0.\\nfor d in dimensions:\\n    print(f\"Running simulations for dimension {d}\")\\n    mu = torch.ones(d, device=device)\\n    scale_var = 0.5\\n    SIGMA = torch.eye(d, device=device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        exp_score = diff.explicit_score(sde, training_distribution)\\n\\n        for j in range(rep_size):  \\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            model_path = f\\'models/gaussian_iso/d{d}_explicit_search/model_{k}_{j}_d{d}.pt\\'\\n            network.load_state_dict(torch.load(model_path))\\n\\n            error_approx_E2, error_approx_sup_L2 = func.compute_E2(training_distribution, sde, network, exp_score, num_steps, num_mc)\\n            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n\\n                simulation_results.append({\\n                    \"dimension\": d,\\n                    \"a\": a,\\n                    \"replication\": j,\\n                    \"scheme\": scheme_name,\\n                    \"error_approx_E2\": error_approx_E2,\\n                    \"error_approx_sup_L2\": error_approx_sup_L2,\\n                })\\n\\nsimulation_df = pd.DataFrame(simulation_results)\\n\\nerror_results = []\\n\\nfor idx, d in enumerate(dimensions):\\n    print(f\"Running error calculations for dimension {d}\")\\n    \\n    dim_df = simulation_df[simulation_df[\\'dimension\\'] == d]\\n    epsilon = dim_df.groupby(\\'a\\')[\\'error_approx_sup_L2\\'].mean()\\n\\n    mu = torch.ones(d, device=device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d, device=device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = sample_by_d[idx]\\n    \\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    \\n    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        error_mixing_E1 = func.compute_E1(training_distribution, sde)\\n        error_discr_E3 = func.compute_E3(training_distribution, sde, num_steps)\\n        w2_error = func.compute_w2_bound(training_distribution, training_sample, sde, num_steps, epsilon[a]) \\n        error_results.append({\\n            \"dimension\": d,\\n            \"a\": a,\\n            \"error_mixing_E1\": error_mixing_E1,\\n            \"error_discr_E3\": error_discr_E3,\\n            \"w2_error\": w2_error\\n        })\\n\\nerrors_df = pd.DataFrame(error_results)\\n\\n#### ISOTROPIC TRAIN COSINE\\n\\ns = 0.021122\\n\\nfor idx, d in enumerate(dimensions):\\n    mu = torch.ones(d, device = device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d,device = device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = sample_by_d[idx]\\n\\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-3\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-3\\n\\n    # network_parameters\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    # Monte Carlo estimate samples (for E2 computation in the KL bound)\\n    num_mc = 500\\n\\n    # number of runs (for replication)\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(training_sample, batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n\\n    beta_cosine = func.beta_cosine(T, s)\\n    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\\n\\n    score_theta_trained_cosine = [ ]   # a_values, replicates\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n        optimizer = Adam(network.parameters(), lr=learning_rate)\\n        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\\n        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n        score_theta_trained_cosine.append(network)\\n        #torch.save(network.state_dict(), f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\')\\n\\n\\n\\n##linear \\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nsimulation_results_lin = []\\n#### LINEAR\\n\\nfor d in dimensions:\\n    \\n    mu = torch.ones(d, device = device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d,device = device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\\n    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\\n    init = sde_lin.final.generate_sample(sample_batch_size)\\n\\n    score_theta_trained_lin = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{np.where(a_values == 0)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_lin.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_lin):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_lin.append({\\n                \"dimension\": d,\\n                \"model\": \"lin\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_lin_df = pd.DataFrame(simulation_results_lin)\\n\\n#### Cosine\\nsimulation_results_cos = []\\n\\nfor d in dimensions:   \\n    mu = torch.ones(d, device = device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d,device = device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n\\n    beta_cos = func.beta_cosine(T, s)\\n    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \\n    init = sde_cos.final.generate_sample(sample_batch_size)\\n\\n    score_theta_trained_cos = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_cos.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_cos):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_cos.append({\\n                \"dimension\": d,\\n                \"model\": \\'cos\\',\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_cos_df = pd.DataFrame(simulation_results_cos)\\n\\n#### a* KL\\n\\nsimulation_results_a_star_KL = []\\nmin_a_KL_dict = pd.Series(min_kl_bounds_df.min_a.values, index=min_kl_bounds_df.dimension).to_dict()\\n\\nfor d in dimensions:\\n    a_star = min_a_KL_dict[d]\\n    mu = torch.ones(d, device = device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d,device = device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\\n    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\\n    init = sde_a_star.final.generate_sample(sample_batch_size)\\n\\n    score_theta_trained_a_star = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{np.where(a_values == a_star)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_a_star.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_a_star):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_a_star_KL.append({\\n                \"dimension\": d,\\n                \"model\": \"a_star_KL\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                })\\n\\nsimulation_a_star_KL_df = pd.DataFrame(simulation_results_a_star_KL)\\n\\nall_simulations_KL_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_KL_df])\\n\\n\\n#### a* W2\\n\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nsimulation_results_a_star_W2 = []\\nmin_a_w2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\\n\\n\\nfor d in dimensions:\\n    a_star = min_a_w2_dict[d]\\n    mu = torch.ones(d, device = device)\\n    scale_var = .5\\n    SIGMA = torch.eye(d,device = device) * scale_var\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\\n    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\\n    init = sde_a_star.final.generate_sample(sample_batch_size)\\n\\n    score_theta_trained_a_star = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_iso/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{np.where(a_values == a_star)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_a_star.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_a_star):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_a_star_W2.append({\\n                \"dimension\": d,\\n                \"model\": \"a_star_W2\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\\n'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\n",
    "    for k, a in enumerate(a_values):\n",
    "        print(f\"optimization for a = {a}\")\n",
    "        sde.beta.change_a(a)\n",
    "        score_theta_trained[k] = [ ]\n",
    "        for j in range(rep_size):\n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\n",
    "            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "            score_theta_trained[k].append(network)\n",
    "            torch.save(network.state_dict(), f'models/gaussian_iso/d'+str(d)+ '_explicit_search' + f'/model_{k}_{j}_d'+str(d)+'.pt')\n",
    "\n",
    "\n",
    "num_steps = 500\n",
    "dimensions = [5,10,25, 50] \n",
    "\n",
    "simulation_results = []\n",
    "a = 0.\n",
    "for d in dimensions:\n",
    "    print(f\"Running simulations for dimension {d}\")\n",
    "    mu = torch.ones(d, device=device)\n",
    "    scale_var = 0.5\n",
    "    SIGMA = torch.eye(d, device=device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        exp_score = diff.explicit_score(sde, training_distribution)\n",
    "\n",
    "        for j in range(rep_size):  \n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            model_path = f'models/gaussian_iso/d{d}_explicit_search/model_{k}_{j}_d{d}.pt'\n",
    "            network.load_state_dict(torch.load(model_path))\n",
    "\n",
    "            error_approx_E2, error_approx_sup_L2 = func.compute_E2(training_distribution, sde, network, exp_score, num_steps, num_mc)\n",
    "            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "\n",
    "                simulation_results.append({\n",
    "                    \"dimension\": d,\n",
    "                    \"a\": a,\n",
    "                    \"replication\": j,\n",
    "                    \"scheme\": scheme_name,\n",
    "                    \"error_approx_E2\": error_approx_E2,\n",
    "                    \"error_approx_sup_L2\": error_approx_sup_L2,\n",
    "                })\n",
    "\n",
    "simulation_df = pd.DataFrame(simulation_results)\n",
    "\n",
    "error_results = []\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    print(f\"Running error calculations for dimension {d}\")\n",
    "    \n",
    "    dim_df = simulation_df[simulation_df['dimension'] == d]\n",
    "    epsilon = dim_df.groupby('a')['error_approx_sup_L2'].mean()\n",
    "\n",
    "    mu = torch.ones(d, device=device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d, device=device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = sample_by_d[idx]\n",
    "    \n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    \n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        error_mixing_E1 = func.compute_E1(training_distribution, sde)\n",
    "        error_discr_E3 = func.compute_E3(training_distribution, sde, num_steps)\n",
    "        w2_error = func.compute_w2_bound(training_distribution, training_sample, sde, num_steps, epsilon[a]) \n",
    "        error_results.append({\n",
    "            \"dimension\": d,\n",
    "            \"a\": a,\n",
    "            \"error_mixing_E1\": error_mixing_E1,\n",
    "            \"error_discr_E3\": error_discr_E3,\n",
    "            \"w2_error\": w2_error\n",
    "        })\n",
    "\n",
    "errors_df = pd.DataFrame(error_results)\n",
    "\n",
    "#### ISOTROPIC TRAIN COSINE\n",
    "\n",
    "s = 0.021122\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = sample_by_d[idx]\n",
    "\n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-3\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(training_sample, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "\n",
    "    beta_cosine = func.beta_cosine(T, s)\n",
    "    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\n",
    "\n",
    "    score_theta_trained_cosine = [ ]   # a_values, replicates\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "        optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\n",
    "        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "        score_theta_trained_cosine.append(network)\n",
    "        #torch.save(network.state_dict(), f'models/gaussian_iso/d'+str(d)+ '_explicit' + f'/model_cosine_d'+str(d)+'.pt')\n",
    "\n",
    "\n",
    "\n",
    "##linear \n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "simulation_results_lin = []\n",
    "#### LINEAR\n",
    "\n",
    "for d in dimensions:\n",
    "    \n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\n",
    "    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\n",
    "    init = sde_lin.final.generate_sample(sample_batch_size)\n",
    "\n",
    "    score_theta_trained_lin = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_iso/d'+str(d)+ '_explicit_search' + f'/model_{np.where(a_values == 0)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_lin.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_lin):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_lin.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"lin\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_lin_df = pd.DataFrame(simulation_results_lin)\n",
    "\n",
    "#### Cosine\n",
    "simulation_results_cos = []\n",
    "\n",
    "for d in dimensions:   \n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "\n",
    "    beta_cos = func.beta_cosine(T, s)\n",
    "    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \n",
    "    init = sde_cos.final.generate_sample(sample_batch_size)\n",
    "\n",
    "    score_theta_trained_cos = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_iso/d'+str(d)+ '_explicit' + f'/model_cosine_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_cos.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_cos):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_cos.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": 'cos',\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_cos_df = pd.DataFrame(simulation_results_cos)\n",
    "\n",
    "#### a* KL\n",
    "\n",
    "simulation_results_a_star_KL = []\n",
    "min_a_KL_dict = pd.Series(min_kl_bounds_df.min_a.values, index=min_kl_bounds_df.dimension).to_dict()\n",
    "\n",
    "for d in dimensions:\n",
    "    a_star = min_a_KL_dict[d]\n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\n",
    "    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\n",
    "    init = sde_a_star.final.generate_sample(sample_batch_size)\n",
    "\n",
    "    score_theta_trained_a_star = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_iso/d'+str(d)+ '_explicit_search' + f'/model_{np.where(a_values == a_star)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_a_star.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_a_star):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_a_star_KL.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"a_star_KL\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                })\n",
    "\n",
    "simulation_a_star_KL_df = pd.DataFrame(simulation_results_a_star_KL)\n",
    "\n",
    "all_simulations_KL_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_KL_df])\n",
    "\n",
    "\n",
    "#### a* W2\n",
    "\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "simulation_results_a_star_W2 = []\n",
    "min_a_w2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\n",
    "\n",
    "\n",
    "for d in dimensions:\n",
    "    a_star = min_a_w2_dict[d]\n",
    "    mu = torch.ones(d, device = device)\n",
    "    scale_var = .5\n",
    "    SIGMA = torch.eye(d,device = device) * scale_var\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\n",
    "    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\n",
    "    init = sde_a_star.final.generate_sample(sample_batch_size)\n",
    "\n",
    "    score_theta_trained_a_star = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_iso/d'+str(d)+ '_explicit_search' + f'/model_{np.where(a_values == a_star)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_a_star.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_a_star):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_a_star_W2.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"a_star_W2\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7ff7e8f6-91a1-4653-bbbf-76e807673b5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_iso/dimension_search_pkl', 'simulation_df.pkl')\n",
    "#simulation_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_iso/dimension_search_pkl/simulation_df.pkl'\n",
    "simulation_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b0422023-14ce-49c1-a54c-20058c8b2f3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_iso/dimension_search_pkl', 'errors_df.pkl')\n",
    "#errors_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_iso/dimension_search_pkl/errors_df.pkl'\n",
    "errors_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "17d5cab3-da77-4075-91cd-769430c3a5b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_df = pd.merge(simulation_df, errors_df, on=[\"dimension\", \"a\"], how=\"left\")\n",
    "dimensions = [5,10,25, 50]\n",
    "\n",
    "dimensional_bounds = []\n",
    "\n",
    "for d in dimensions:\n",
    "    dim_df = results_df[results_df['dimension'] == d]\n",
    "    error_mixing_E1 = dim_df.groupby('a')['error_mixing_E1'].first()\n",
    "    error_approx_E2 = dim_df.groupby('a')['error_approx_E2'].mean()\n",
    "    error_discr_E3 = dim_df.groupby('a')['error_discr_E3'].first()\n",
    "    KL_upperbound = error_mixing_E1 + error_approx_E2 + error_discr_E3\n",
    "    W2_upperbound = dim_df.groupby('a')['w2_error'].mean()\n",
    "    bound_df = pd.DataFrame({\n",
    "        'dimension': d,\n",
    "        'a': error_mixing_E1.index,  \n",
    "        'KL_upperbound': KL_upperbound,\n",
    "        'W2_upperbound': W2_upperbound\n",
    "    })\n",
    "    \n",
    "    dimensional_bounds.append(bound_df)\n",
    "all_bounds_df = pd.concat(dimensional_bounds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "196c676f-011c-4bbb-bcfd-77d7384245f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   dimension  min_a min_KL_upperbound\n",
      "0          5   1.75    tensor(0.6152)\n",
      "1         10   1.00    tensor(1.2379)\n",
      "2         25   1.50    tensor(3.1450)\n",
      "3         50   2.00    tensor(6.4079)\n"
     ]
    }
   ],
   "source": [
    "min_kl_bounds = []\n",
    "\n",
    "for bound_df in dimensional_bounds:\n",
    "    d = bound_df['dimension'].iloc[0]\n",
    "    min_kl = bound_df['KL_upperbound'].min()\n",
    "    min_a = bound_df.loc[bound_df['KL_upperbound'] == min_kl, 'a'].values[0]\n",
    "    min_kl_bounds.append({'dimension': d, 'min_a': min_a, 'min_KL_upperbound': min_kl})\n",
    "min_kl_bounds_df = pd.DataFrame(min_kl_bounds)\n",
    "print(min_kl_bounds_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6e3bd78b-5f20-4252-aca7-73b4d4d2e574",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   dimension  min_a  min_W2_upperbound\n",
      "0          5   4.50           5.192498\n",
      "1         10   4.25           8.592521\n",
      "2         25   3.75          17.750468\n",
      "3         50   4.25          32.730716\n"
     ]
    }
   ],
   "source": [
    "min_w2_bounds = []\n",
    "for bound_df in dimensional_bounds:\n",
    "    d = bound_df['dimension'].iloc[0]\n",
    "    min_w2 = bound_df['W2_upperbound'].min()\n",
    "    min_a = bound_df.loc[bound_df['W2_upperbound'] == min_w2, 'a'].values[0]\n",
    "    min_w2_bounds.append({'dimension': d, 'min_a': min_a, 'min_W2_upperbound': min_w2})\n",
    "min_w2_bounds_df = pd.DataFrame(min_w2_bounds)\n",
    "print(min_w2_bounds_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "fff0c3e5-da5a-415f-9fd6-a17319f54a40",
   "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",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dimension</th>\n",
       "      <th>model</th>\n",
       "      <th colspan=\"2\" halign=\"left\">kl</th>\n",
       "      <th colspan=\"2\" halign=\"left\">w2</th>\n",
       "    </tr>\n",
       "    <tr>\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",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>5</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.001607</td>\n",
       "      <td>0.000462</td>\n",
       "      <td>0.034041</td>\n",
       "      <td>0.004758</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.001390</td>\n",
       "      <td>0.000296</td>\n",
       "      <td>0.030996</td>\n",
       "      <td>0.003254</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>5</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.001935</td>\n",
       "      <td>0.000405</td>\n",
       "      <td>0.036995</td>\n",
       "      <td>0.004663</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.005343</td>\n",
       "      <td>0.001155</td>\n",
       "      <td>0.061838</td>\n",
       "      <td>0.008745</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.005097</td>\n",
       "      <td>0.001064</td>\n",
       "      <td>0.060649</td>\n",
       "      <td>0.007117</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>10</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.005594</td>\n",
       "      <td>0.001377</td>\n",
       "      <td>0.063939</td>\n",
       "      <td>0.010876</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>25</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.026724</td>\n",
       "      <td>0.004046</td>\n",
       "      <td>0.128614</td>\n",
       "      <td>0.014132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>25</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.026900</td>\n",
       "      <td>0.001859</td>\n",
       "      <td>0.131234</td>\n",
       "      <td>0.004794</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>25</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.031748</td>\n",
       "      <td>0.006158</td>\n",
       "      <td>0.141601</td>\n",
       "      <td>0.020447</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>50</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.095981</td>\n",
       "      <td>0.005485</td>\n",
       "      <td>0.239866</td>\n",
       "      <td>0.010904</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>50</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.099917</td>\n",
       "      <td>0.004375</td>\n",
       "      <td>0.251959</td>\n",
       "      <td>0.005588</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>50</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.105592</td>\n",
       "      <td>0.019529</td>\n",
       "      <td>0.256384</td>\n",
       "      <td>0.032709</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dimension      model        kl                  w2          \n",
       "                             mean       std      mean       std\n",
       "0          5  a_star_KL  0.001607  0.000462  0.034041  0.004758\n",
       "1          5        cos  0.001390  0.000296  0.030996  0.003254\n",
       "2          5        lin  0.001935  0.000405  0.036995  0.004663\n",
       "3         10  a_star_KL  0.005343  0.001155  0.061838  0.008745\n",
       "4         10        cos  0.005097  0.001064  0.060649  0.007117\n",
       "5         10        lin  0.005594  0.001377  0.063939  0.010876\n",
       "6         25  a_star_KL  0.026724  0.004046  0.128614  0.014132\n",
       "7         25        cos  0.026900  0.001859  0.131234  0.004794\n",
       "8         25        lin  0.031748  0.006158  0.141601  0.020447\n",
       "9         50  a_star_KL  0.095981  0.005485  0.239866  0.010904\n",
       "10        50        cos  0.099917  0.004375  0.251959  0.005588\n",
       "11        50        lin  0.105592  0.019529  0.256384  0.032709"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_iso/dimension_search_pkl', 'all_simulations_KL_df.pkl')\n",
    "#all_simulations_KL_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_iso/dimension_search_pkl/all_simulations_KL_df.pkl'\n",
    "all_simulations_KL_df = pd.read_pickle(file_path_load)\n",
    "\n",
    "summary_stats = all_simulations_KL_df.groupby(['dimension', 'model']).agg({\n",
    "    'kl': ['mean', 'std'],\n",
    "    'w2': ['mean', 'std']\n",
    "}).reset_index()\n",
    "\n",
    "summary_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "849c5590-5e66-472c-a870-846d47d80120",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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12vVqlXAeXr06MG0adN44YUXUBSlTteeOHFiwChjt27d6NOnDwD79u3zb3/vvfcAmD59esBITEhICNOnT0en0/HZZ5/hdDprvV59+r5161Z27txJ586defjhh/1hDGDEiBH069ePkJCQKrfs7rzzTn+4AmjXrh0XX3wxAHv27PFvnzdvHqqq8r///S+gvV6v56mnniI6Opply5b5g9Z3332H3W7nlltu8YcxgMjISKZNm1br6z4WH330EU6nkwkTJvjDGIAsyzz44IMkJSWxefNmtm3bdsL6IAhNnQhjdSMC2WlAtZaiFGajFGaD64haW4rHv0+xFFc59obOIfx4cTAtgmUe2+piT4lCW1Pgt01bk8zuEoXHtrpo07EzGzdtZvQtN1ect5rApZQV+verqno8X24A39OLHo+n3sfm5OSQlZVFZGRkwIetj9lsZsCAAQBs2LABgLPOOguA559/nilTprBy5Ur//Khhw4Zx1VVX1fkJzl69elXZFhsbC+C/BZeXl0dKSgpms5lu3bpV275Lly6UlZWxc+fOWq9Xn777Xu+FF15Y7Zy7Tz75hAULFhAZGRmw3RcoK2vZsiUApaWlgPdrtWnTJoCAcOUTFBRE3759A9pt3LgRwP/1qKxbt27+axxv69evr7GfkiRx/vnnAxXvlyCcbkQYqztxy/I0IBlDkSMPj3roDIE7ZY1/nxwSXuVYOTSaLu3b8GO8wv/K+/DAl18yIE5DXHBFKDtkU3hwo52bb7qJee+/j9FoRLGVVZzXXHV0SjZH+vdX94F+vMTExLB79+4GTa721SQ7csSoMt+IlG906aqrruKff/5h/vz5LFy4kIULF6LVaunduzdXXHEF11577VFvV/qEhoZW2eYLmL4Qm5OTA0BZWRlJSUm1ni8nJ6fakOdTn777Xm99g47ZbK6yzTdvzDf6Vlxc7H9wobogfORrgoqvVVxcXLXtWrdu7W97PPnOOXz48Dq1E4TTiQhj9SMC2WkgZMh4QoaMr3afNrY9ce/srvHYyMe+9P//AXPm8M3XXxGm9wYoi0slRCcRppfQyhIDBg70j6DIweZazxt+75yGvJR669atG2vXrmX79u1ce+21tba1WCzMmTOHfv36ce6559Zp5M438lZ5wvxjjz3GyJEjWblyJWvXrmXLli1s3LjRP4F9wYIFVUpvVKcuQdV3/fDwcC644IJa28bExBz1fHXte0NXFqh8a7Mmld/TwYMH19q2Xbt2wNHfq8oPC9RFXUdUfe2uuuqqWl9b5duugnA6EGGs/kQgE+ps8+bNdInQo6jw4EY7X6W5uLG9jud7G0iK0LF58+bG7mIVl156Ke+88w5r1qzB4XBgMBhqbLtixQrmzZvHN998w++//+6/PXjgwIEaj8nMzAQgOjo6YHt8fDxjxoxhzJgxuFwu/vzzT5577jlSU1NZsGBBrSU46sMXsgwGg3+C+7GqS999701Nk+X//PNP8vPz6devX42jVjUJDw9Hp9Phdrt54YUXjvp0KHhHxvbt28eBAwfo1KlTlf3VrcDgC3HVha+ysrI69TU2NpYDBw7wwAMP+MOhIJzuRBhrGDGHTKizzRv+wiS5uXKNkyWHNEycOJEfDmm46hcHJsnDpvV/NXYXq0hOTqZfv37k5uYyZ07No3LFxcX+/TfccANarZZWrVoRHx9PUVFRtXOAysrK+P3334GK+VcPPvggZ599dkCI0+l0DBgwgJEjRwLelQGOl9atW9OqVSsOHTrE7t1VRyRtNhvXXHMNI0aMOOo6jvXpu28u2G+//VbtuV5//XUefvjhBt0q1uv19OrVC0VRWLt2bZX9qqoyatQobrrpJnbs2AFA//79AVi5cmWV9unp6aSmplbZ7hvNra6PdZ2E7/u6//pr9U8UT5o0iWuvvZbVq1fX6XyC0NyJMNZwIpAJdWK32/ln527W53vQtejAxk2bee2119i4aTOauA5syPfwz85d2O32xu5qFU8//TTBwcHMmTOHF198kZKSkoD9mZmZ3H333WRkZNC2bVvuuusu/75bb70VgKlTp/pHwwDKy8t55JFHsFgsDBo0yP80ZExMDMXFxbz88ssBTzXa7XZ/WDiyNtex8vXx0UcfJSMjw7/d6XTy9NNPs2fPHqxW61FrYdWn7+eccw4JCQns2rWLWbNmBdze/fzzz9m+fTuJiYmcccYZDXpNY8aMAeC5554LeBhBURTeeOMNNmzYQFZWlv9W4PDhwwkLC2PhwoUsX77c395isfD4449Xe/vZd+zHH38csH/+/Pn8888/dernqFGj0Gg0vPnmm/z5558B+xYsWMCSJUvYt29fg8uuCEJzIsLYsRG3LIU6sdls9O6RTHKvPsyaNcs/utC1a1c2bNrC+PHj2bljG3a7vc6T1k+WhIQEPvroI+666y4+/PBDFixYQPfu3YmOjubgwYPs2LEDj8dDp06dePfddwkJCfEfO2rUKLZu3cqPP/7IlVdeSb9+/QgODmbTpk0UFRWRlJTE888/729/7733smbNGn766Sc2b95McnIy4K3lVVBQQN++fRk6dOhxfX2jR49m+/btLFu2jCFDhtC9e3fCw8PZsWMHubm5REVF8dprrx31PPXpuyzLvPbaa4wZM4aZM2eyZMkSEhMTycjIYNeuXZhMpjpXua/OJZdcwtixY/nggw+4/vrr6datG7GxsezevZvMzEyCg4N56623/Lczo6KimD59Og8++CD3338/vXv3JjY2lg0bNqCqKu3btyctLa3K+/bTTz+xfPlyLr/8cpKSkti3bx+pqakMHTqURYsWHbWfycnJTJkyhWnTpjFmzBi6du1K69atSU1NZd++fWg0Gl555ZUqt7QF4VQjwtixE4FMqJOIiAj+2rSl2onLJpOJDz/8EEVR6jRpuzH07NmTZcuW8fnnn/Pbb7+xZ88etmzZgslkok+fPlxxxRVcf/31VeYrybLM66+/zoABA/j666/ZsmUL4J1MfvvttzNq1KiAeWkRERF8/vnnzJkzh7Vr17Ju3Tp0Oh3t27dn7NixjB49uk5zourDF44GDhzI119/ze7du3G73cTHx3PVVVcxduxY/5yv2tS37126dOG7777jnXfe4bfffuPnn3/GbDYzZMgQxo8fT4cOHY7pdT322GOcddZZfPbZZ/z999/s2rWLli1bct1113HnnXdWmbN18cUX+/u/efNm9uzZQ9++fZk8eTJPP/10lUDWvXt3Pv30U2bOnMnWrVvJzc0lOTmZJ598EpfLVadABjBy5EjOOOMMPvzwQzZv3sy+ffuIjY3lyiuv5I477qBr167H9D4IQlMnwtjxIaknsgiUUG9vvvkm4F1i5mjsdjupqal06NChyY1KCYJQP+LnWWiOVHc5iv1Asw9jiqsQjTEBSRty9Mb1UJ/P9KY5nCEIgiAIQpN2qoSxVT+v5cxzr2XV6jWN2g8RyARBEARBqJdTJYypqsqTz7zMjn/38+STz5zQlWOORgQyQRAEQRDq7FQJYwArVv3G+o3bGX9TG/7asJkVK1Y0Wl9EIBMEQRAEoU5OpTCmqirPTJtBv+RwXry/E/2SI3j6qScabZRMBDJB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3ytTRAxXPDaT1r3O4/rrb2iSH1q//vor4B3hPNIXX3wBwIABA05qn47sQ2lpKdddd91R2/rC2NatW+nWrRsff/wxkZG1Fzo8npYvX87w4cPp3r07F1xwAU899RSHDh2qtu0PP/zAiBEj6NOnDz169ODqq69mzpw52Gy2gHaTJ08mKSmJr7/+uso51q9fT1JSkn9E3Mc3r23VqlX8+uuvjBw5kt69e9OnTx/GjRvH5s2bq5zL6XQyd+5crrzySnr27Mkll1zC3Llz8Xg8tb7m66+/HovFwoIFC4729ghCk3SqhTFP0R84978EHm8JC8nQEn3nJ5FDklDKS3DnpKHarchh0UiyhgMH89j6zx7/vz+37+Xdz77nyngtnUM1XBGv4d23Z7Nly5aAfwcOHDgpr6fJB7KCggKAWj9swsPDAeo1mb5///4kJSXVux+19UWj0fhHWk6Vif0fffQR5VYrF97zLLKm9odyZY2WC+9+lnKrtVH/yqiOoij8/fffAJx11ln+7WVlZbz00kssWbKE+Pj4OoWh6vjmIPpuNTbkQYdvv/0WnU531FBYOYz16tWLjz76yP8zcDIsX76c+++/H7vdzqBBgzAYDHzxxRdce+21/ocJwPsePPLIIzz88MPs2LGDXr16MWDAAHJzc3njjTe46aabjtvPyffff8+dd95JXl4e5513HjExMaxbt45bb73VP8oO4HK5uOOOO3j11VcpKChgwIABxMXF8dprr/Hiiy/Weo0LLrgAnU7HwoULj0ufBeFkOpXCmKoquHIW4sqYC6obADmkK/rOU5H0MSilBbhz0kBxI4dG+O+GjJv4DOdcc4f/34XDbycrK4cxCd7PtjEJWv5LSeHMM88M+HfryFtOyutq8mUvfKNSR87Zqsz3OKqv7YnsR+Xr1daXI//6b45UVWX222+T0P/SGkfGjmSKjKHjOZcwa/ZsJkyYcMIL6dXVvn37sFqttG/fnrCwMJ555hn27dvHP//8g81m44wzzuDNN98kODi4QedfuHChfxT1119/5aeffuL5559Hluv2N09WVhZpaWn06NGDkJCQGtuVl5dzxx13sHXrVgwGA3PmzPH/EXCypKamMm7cOB555BEkScLtdvPUU0/xzTff8PTTT/P+++8D8Omnn7J48WLatWvH+++/73/QwGKxMGnSJH755ReefPLJBj2Qc6SVK1cyefJkxowZgyRJKIrCxIkT+emnn/jggw/8cwQ/+eQT/vrrL3r27Mm8efMIDQ0FvKOn9913X63XMJlMdOvWjW3btpGenl5rrUJBaEpOqTCmOHFlzEMpqZiipIm6EG38SFBlPEWHUPKzQWdADjYFHDvy+iGs37YbreLi+d4GOofKhOsl2pq8v6fPjtbyxxUmip0q+0oV/rfNiVujZ/Rt407Ka2vygUyj0aAoSp3ansgP/7p+sPo0lSCy5UApS3fm4XDX7T2szFpSyL69exl8zd31Oq7jOZey4tVJTPpqI8bQiHpf16CVGdI1ht7xofU+tia++X/du3enpKSEBQsWBIxixcbG1vn7rDrXXXcdv/76K2+//TY6nY6XX365Xt8D69evB6BLly41tvGFsS1btiBJEg6Hg7fffpupU6c2uN8N0a5dOx566CH/69NqtTz55JOsWbOGdevWkZGRQdu2bf1PG0+bNi3gqc+QkBBmzJjBoEGDWLFixXEJN127duW2227z/7csy4wcOZKffvqJffv2+bf7bk0/++yz/jAGMHDgQG666SY++eSTWq+TlJTEtm3bWL9+vQhkQrNwSoUxVzHOtLdQrSmHt0hoW92EJvoyUDx4Cg6gFB7yPkmpD6py/E3DLic2oRvjH3ycR7dk8WJvPde3D5xX1tYk81eeiynbXHRI6MxXC7+t05ze46HJ37I0Gr2Pp9ZWH8rhcAD4y1CcyH5Uvl5j9aU+Vu8r4JDFSbHdXe9/+SXe+/IGU/2CUZDJ+0OfX1zaoOsesjhZta/gKFepH9/typ49exIWFsaOHTtYs2YNb7zxBj169ODXX39l1KhRlJSUNOj83377LX///TeXXnopQ4YMYerUqfUKeL6HQHzzIavz77//snnzZi644ALef/99ZFnmk08+YfXq1Q3qc0NdccUVaLWBf8sZDAbOPfdcwPtwTU5ODllZWURGRtKvX78q5zCbzf5bs/V5GKcmPXv2rLLN94CDb7T60KFDpKenExsbW23wvfjii496HV89olPpoR3h1HUqhTHFlolj33MVYUw2oOvwANqYweB24cnN9IaxkLBqw5jdI7G3TIe2RWc++PRjBlx8EQ9stHPIFvh7+pBN4cGNdoZeez0bNm85aWEMmsEIWUREBCUlJbXONfHtO5FPyEVEVIz0FBcXB/x17eN2uykrKzvhfamPSzpHsaSBI2T6MO+tMEd5ab2Os5d7Q010eCjGoPp/ixm0Mpd0Pr7vn2+ErEePHoD3FnirVq1o1aoVF198MVdddRUZGRn89ttvXH311fU+//Dhw5EkicmTJzNw4EAGDBhQrxEy3xzFo91+HDRoEG+99RZ6vZ477riDd999lylTprBo0aKTVu6iptDoqxF46NAhcnNzAWjVqlWN5/GFm7y8vGPuU1hY1Q8b3wM2vmDse+ggLi6u1v7Uxvf1qTynVBCaolMpjHlKt+FKf8e/DBK6SPQdHkQObovqsOHOy0KxFCObI5EO/9xXVuKS2W/RUuyUidIraIOC6NOnN6tXriZM7/09bXGphOgkwvQSWlliwMCBAQMxJ0OTD2QdO3YkLS2t1qccfPvat29/wvoRFxeH2WymrKyMAwcOVPukZU5Ojv9JrRPZl/roHR/a4Ft/qqqy5KlEUv5aSadzL6/zcSl/raRzYiKv3nBWk7h1a7fb2bdvHzqdjjPOOKPKfr1eT3JyMhkZGVUKf65cuZLPP/+cPXv2YLFYaNWqFePGjeP6668PaOd7nb6J4fV93W63d2JqbU/6derUiZkzZ6LTeYfYJ0yYwLp16/j333+ZNGkSH3/8sT+EnEi1zecE0Ol0dXqowfdaj3Y+4JhuJ/sc7Wty5Khfbf3wfb0EoSk6VcKYdxmklbizF1B5GSR9hweQdOEo1jLcuZmoDhtyaBTSEVOLVBVyHRpSLFqcCrS0pGH8ZyWWgWPZtWs3SeFaFBUe3GjnqzQXN7bX8XxvA0kRumqf0D7RmvwtS9+tiMpPSlV28OBBf0HY3r17n9C++EZXtm7dWu1+3/b4+Pga/wpvTiRJ4r5772X/nyspL6rbKEZ5YR4pf61i/H33NYkwBrBz507cbjdnnHFGjR/+u3btAiAxMTFg+549e7jkkkt4+eWXeffdd7nwwgt54oknavx+bCjfCE9tI8GRkZH+MAbe4PPKK68QFBTEpk2bmDVr1nHtU018o19H8v1h1LJlS//twtr+kPI9kRkdHQ1UBKbqQmlpaf1Gaavj+5msqYB0Ta+rMt/Xp7oROUFoCk6dMObGfeDjgDUp5bCz0Hd63BvGyopw56SCy+GtMXZEGPOokG7VsqfU+zuz1YGNRH90PyF/fIHpzy/Z9e+/hMgKV/xsZ3E2XHr5ZSzKkbhyjR2T5GHT+pNfJLzJB7LLL/eOzGzYsIGUlJQq+301gfr163fC15u64oorAO98oermtPkmDA8fPvyE9uNkuvXWWzEZjfwy50kUT+2jAorHza/vPInJaGT06NEnqYdH57td2bFjx2r3b968mdTUVNq2bUu3bt0C9o0fP54RI0Zw/vnn069fPx5++GHCw8OPeyDzjajWVMurJgkJCTzyyCMAvPPOO/6HA06kdevWVdlWXl7OunXrkGWZvn370qpVK+Lj4ykqKqp2jlhZWRm///47UFGGxGTyPhFV3e3A4/F+x8bG0qlTJwoKCqr96/eXX3456jl8oa2m7yVBaEynTBjzL4O0xr/NuwzSPSDpcBfl4j6YBpKEbI6o8se/wwP7ynSkWrQYtSqhOhXJaUN2lHsb/L2G//ansj7fQ7pdg93pYuVPK7A7nKTbtWzI9/D3vztPaOWG6jT5QNa+fXuGDBmCx+NhwoQJ/kKx4F1Wad68eQDcc889VY7NyMhg//79dfrLty6uueYa2rZtS2ZmJg8//DAWiwXwPnAwbdo0Nm/ejNlsZuTIkcflek1BeHg4X3/9FVnbfufHlyZQXlj9SFl5YR4/vjSBzG2/8803X5/UulhH45vQ/9NPP1UJB/v27fMHmvvvvz/gB9vpdPLZZ5/xf//3f/Tt25euXbvSrVs3ioqKjvvcAt/obkOChy8wKorCww8/TGFh4XHt25HWr18fUGfO6XQydepUSkpKuOKKK/xzyW699VYApk6dGlCfrLy8nEceeQSLxcKgQYP8c9J8dQG///77gBGxTZs2+f/YOVZjxowB4IknnggIv5s2beLDDz886vG+UXDfqhyC0FScKmGsYhmkf70bJG3FMkiqiic/ByU3E0lvQDZWnXNb5pLYVaon264hQq8QrPGOrjm6XEDZwDHYE89lcdvhIGmQZA3t+l4UsBRg276DkGUNyPJJXwaxyc8hA+8v9L1797J3716uuOIKEhMTKS0t9d8OmThxov8Jr8rGjBnDgQMHGD58+FGLPtaFwWDg1VdfZezYsSxfvpy1a9fSsWNHsrKyKC4uRqfTMWvWrIAHAE4FgwcPZsmSJVx//Q18fNfFdDznEjqecylBpjDs5SWk/LWSlL9WYTIaWbp0KZdddlljdzmAb4TMbrczevRoevXqRatWrcjOzmbHjh14PB7uvvvuKpP5J0yYwLZt27j11ltJTk4mPDycv//+m2effZbOnTsf1z4mJCTQvn179u/fT2FhYb2q7kuSxPTp07n66qvJzc3l8ccf55133gkIl1u3buW8886r8Rw33HADDzzwQJ2u17t3b55//nm+++472rRpw/bt2zl48CCJiYk88cQT/najRo1i69at/Pjjj1x55ZX069eP4OBgNm3aRFFREUlJSTz//PP+9ldeeSVz5swhIyODyy67jL59+5Kfn8+2bdsYNmyYfy3ZY3Hdddfx119/sWTJEi6//HL69++P1Wplw4YN9OjRo8bpCOB9mGffvn20a9eOhISEY+6LIBwvqtuCYj/Q/MOYZS/OtLfA4x3sQBOCvv39yCGJqG4nnvxslOJ8JFMokq7q9JM8h0yKRYfNIxGjdXmDVSXl597CH3/8yeQHHqFNr/O58N5nq9TY7HTu5ZTflscvc57kpptuYsmSJQwePPiEvebKmvwIGXifcPzyyy8ZP368/0OrqKiIfv36MXPmTO6+u351so5Fjx49WLRoEddddx2hoaHs2bMHSZIYPHgwX3/9Neecc85J68vJNHjwYDIy0nn9tVeR8lJY8eokFj97OytenYSUl8Lrr71KZmZGkwtjxcXFZGRkEBoayhNPPEHnzp35999/WbFiBQcPHuTyyy/ns88+Y+LEiQHH7dixg19++YVXXnmFe++9lwEDBtCjRw+ysrKQZbleqzzUlW+VgIasBRobG8tzzz0HeG+9+WqA+bhcLvLz82v85xvtrYubb76Z559/HofDwc8//4wsy4wbN44FCxYE/DEiyzKvv/4606dPJzk5mS1btvD777/TokULHnnkEb7++uuAp5FNJhMLFizg//7v/9BoNPz666+Ul5fz5JNP8vTTT9f7PamOJEnMmDGDZ555hnbt2vH777+TkpLC2LFjeeGFF2o9duXKlaiqWuWBDkFoTKdKGPMU/o4z5WV/GKtYBikR1WnHfSgTT3Eekjm8ShhTVMgo17C7VI9bkYgryyDmg7vRpW8PaFdmsfDoY0/Qptf5XDG56S0FKKkNWeNFOGHefPNNgDqNVtjtdlJTU+nQocNJrXumqiqFhYWUlZVhNpuJjIxsMhP4j/Tbb79xxx13cN555/HBBx/U+Tjf8kCrVq3yFzXNzMzkmmuuIS4ujp9++um497W8vJyLL76YFi1a8P333x/38wvH5v/+7//Izs5m9erV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cQStra1cddVVNDQ0AIWlz9/85jf8+c9/xuv1djqJPdA01b6QKg4oS5cu5Rvf+Ab5fB6v18vYsWOxbbs0kzRt2jTuvffeUuHUwerEE0+krq6OW265hfPOO6/L883NzVx00UWlZahJkyaRSqVKe8euu+46rrjiir1922IQMU2TY445hpaWFjweT68V+wGOO+640n8zB8rnSIiDza58djds2MCXvvQltmzZgs/nY+LEiWzbto36+no0TeMnP/lJpxOZA00C2QFszZo13Hfffbz88sts27aNQCDAhAkTOOOMM/jiF7+4X2xE7iuQAWQyGe69916eeuopNmzYgMfjYdq0aVx44YUycyF47733eu1huaO5c+dy6623lv75QPgcCXEw2pXPblNTE7/61a944YUX2LJlC8FgkEMPPZRLL72Uo48+eo/erwQyIYQQQoh9TPaQCSGEEELsYxLIhBBCCCH2MQlkQgghhBD7mAQyIYQQQoh9TAKZEEIIIcQ+JoFMCCGEEGIfk0AmhBBCCLGPSSATQgghhNjHJJAJIYQQQuxjEsiEEEIIIfYxCWRCCCGEEPuYBDIhhBBCiH1MApkQQgghxD4mgUwIIYQQYh/7/6IA6+XwiE+4AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dimensions = np.array([5, 10, 25, 50])\n",
    "\n",
    "lin_means = summary_stats[summary_stats['model'] == 'lin']['kl']['mean'].values\n",
    "lin_stds = summary_stats[summary_stats['model'] == 'lin']['kl']['std'].values\n",
    "\n",
    "cos_means = summary_stats[summary_stats['model'] == 'cos']['kl']['mean'].values\n",
    "cos_stds = summary_stats[summary_stats['model'] == 'cos']['kl']['std'].values\n",
    "\n",
    "a_star_KL_means = summary_stats[summary_stats['model'] == 'a_star_KL']['kl']['mean'].values\n",
    "a_star_KL_stds = summary_stats[summary_stats['model'] == 'a_star_KL']['kl']['std'].values\n",
    "\n",
    "font = {'family' : 'sans-serif', 'size' : 16}\n",
    "plt.rc('font', **font)\n",
    "cmap = cm.get_cmap('tab20c')\n",
    "mpl.rcParams['axes.facecolor'] = 'white'\n",
    "mpl.rcParams['axes.grid'] = False\n",
    "mpl.rcParams['axes.edgecolor'] = 'gray'\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "#linear\n",
    "y1_color = (0.96, 0.78, 0.26)\n",
    "ax.plot(dimensions, lin_means, label='Linear schedule', color=y1_color, linewidth=2, marker='^', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, lin_means - lin_stds, lin_means + lin_stds, color=y1_color, alpha=0.15)\n",
    "\n",
    "# cosine schedule\n",
    "y2_color = cmap(4/20)\n",
    "ax.plot(dimensions, cos_means, label='Cosine schedule', color=y2_color, linewidth=2, linestyle = 'dotted', marker='*', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, cos_means - cos_stds, cos_means + cos_stds, color=y2_color, alpha=0.15)\n",
    "\n",
    "# a optimal\n",
    "y3_color = cmap(1/20)\n",
    "ax.plot(dimensions, a_star_KL_means, label='$\\\\beta_{a^*}$ (KL bound)', color=y3_color, linewidth=2, marker='o', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, a_star_KL_means - a_star_KL_stds, a_star_KL_means + a_star_KL_stds, color=y3_color, alpha=0.3)\n",
    "\n",
    "#ax.set_xlabel('Dimension', fontsize = 18)\n",
    "ax.set_ylabel('KL divergence', fontsize = 18)\n",
    "ax.legend(loc='upper left', fontsize = 16)\n",
    "ax.tick_params(axis='x', labelsize = 18)\n",
    "ax.tick_params(axis='y', labelsize = 18)\n",
    "ax.set_xticks(dimensions)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3e85c864-c12e-4af5-9b14-bf99e1206a54",
   "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",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dimension</th>\n",
       "      <th>model</th>\n",
       "      <th colspan=\"2\" halign=\"left\">kl</th>\n",
       "      <th colspan=\"2\" halign=\"left\">w2</th>\n",
       "    </tr>\n",
       "    <tr>\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",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>5</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.002066</td>\n",
       "      <td>0.001072</td>\n",
       "      <td>0.039241</td>\n",
       "      <td>0.012572</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>10</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.005175</td>\n",
       "      <td>0.001332</td>\n",
       "      <td>0.059274</td>\n",
       "      <td>0.009438</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>25</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.027388</td>\n",
       "      <td>0.004080</td>\n",
       "      <td>0.130829</td>\n",
       "      <td>0.014245</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>50</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.092688</td>\n",
       "      <td>0.005094</td>\n",
       "      <td>0.233812</td>\n",
       "      <td>0.010584</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  dimension      model        kl                  w2          \n",
       "                            mean       std      mean       std\n",
       "0         5  a_star_W2  0.002066  0.001072  0.039241  0.012572\n",
       "1        10  a_star_W2  0.005175  0.001332  0.059274  0.009438\n",
       "2        25  a_star_W2  0.027388  0.004080  0.130829  0.014245\n",
       "3        50  a_star_W2  0.092688  0.005094  0.233812  0.010584"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_iso/dimension_search_pkl', 'simulation_a_star_W2_df.pkl')\n",
    "#simulation_a_star_W2_df.to_pickle(file_path)\n",
    "\n",
    "file_path_load = 'models/gaussian_iso/dimension_search_pkl/simulation_a_star_W2_df.pkl'\n",
    "simulation_a_star_W2_df = pd.read_pickle(file_path_load)\n",
    "\n",
    "summary_stats_a_star_W2 = simulation_a_star_W2_df.groupby(['dimension', 'model']).agg({\n",
    "    'kl': ['mean', 'std'],\n",
    "    'w2': ['mean', 'std']\n",
    "}).reset_index()\n",
    "\n",
    "summary_stats_a_star_W2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1a2c90ca-475a-4361-b53a-43227639abcf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8d5Np/HD1P+x7ffv2LP2D7b9/h0/PP8/3rvpNPK2rOHbb7/ljDPOqN/DawJazztJ8p9w5pln8s0333DRRRfz3k2n0em44XQ67nRsoRG4yorY8deP7PjrJ0Lt9v/8zVwfKiJkLpeLq666iv79+5OYmMjevXtZv349uq5z8803c+655wZdd/vtt7N27VquvvpqevfuTWRkJBs2bOCJJ54IWE80FZ07dyY5OZnt27eTn59fbTJply5diI+PJy0tDVVVa9w5OWTIEDRNIyMjg169elXpq6CggNmzZwP+UlHPPfdcjfO6//77g5YOa2PAgAE8+eSTfPHFF7Rv355169aRmZlJt27dePjhhwPtxo4dy5o1a/juu+84++yzGTx4MCEhIaxcuZKCggJSUlJ48skng/o+++yzmTFjBqmpqZxxxhkMGjSI3Nxc1q5dy6hRo/jiiy/qNceaGDNmDH/99RfffPMNI0aM4Pjjj6e8vJzly5fTt2/fgOCqjsLCQrZt20bHjh0bvDNVcvgihABfMYYnB/RyFC0MRa05v6mlIYTAKF6NN/1D8Fby21KjQBuKFt671nwuRVEIvfB2it96EPtZ12DpUzUSHxjL5/VbWZhtaG2TUR3RNXqK+Y1d/cuT+S6BzQTxdrVKCowQgu0FBiv2ein17D+uKdAnQaNfgimw2xJgyLChfP/7Ur75/HM+fu8DFj7/feBc127dePGF57n66qv/87QDKcgkDebMM88kNXU37733HtNffZWFz98dONecb+a6KCwsJDU1lfDwcCZMmMDcuXP5+++/2bhxI7GxsYwYMYLLL7+cQYMGBV23fv16fv31V956660g5/zvvvsOVVWr5G41BWPGjGHq1Kn88MMPQWWAKnP88cczf/78oLqUBxIREUGfPn1Yu3ZttVG0FStWBCwfNm/ezObNm2uc0+23315vQXbZZZcxZswYZs6cyS+//EJcXBzXXXcd48ePDzK7VVWVF198kaFDh/Lpp58Gdo527NiR66+/nrFjx1YxpA0NDWXOnDm89NJL/PbbbyxevJjk5GQeeeQRLrjggkYLMkVRmDp1Kscccwwff/wxv//+OxEREVx77bVccMEFnHXWWTVe++OPPyKEqLLRQ9JyEYYXw5MLnlxQNDDV7YXVkqjRU8w0CGzHodqD71foOq7f52PpeRxa7P4d0lp0GyInvlnz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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dimensions = np.array([5, 10, 25, 50])\n",
    "\n",
    "lin_means = summary_stats[summary_stats['model'] == 'lin']['w2']['mean'].values\n",
    "lin_stds = summary_stats[summary_stats['model'] == 'lin']['w2']['std'].values\n",
    "\n",
    "cos_means = summary_stats[summary_stats['model'] == 'cos']['w2']['mean'].values\n",
    "cos_stds = summary_stats[summary_stats['model'] == 'cos']['w2']['std'].values\n",
    "\n",
    "a_star_W2_means = summary_stats_a_star_W2[summary_stats_a_star_W2['model'] == 'a_star_W2']['w2']['mean'].values\n",
    "a_star_W2_stds = summary_stats_a_star_W2[summary_stats_a_star_W2['model'] == 'a_star_W2']['w2']['std'].values\n",
    "\n",
    "font = {'family' : 'sans-serif', 'size' : 16}\n",
    "plt.rc('font', **font)\n",
    "cmap = cm.get_cmap('tab20c')\n",
    "mpl.rcParams['axes.facecolor'] = 'white'\n",
    "mpl.rcParams['axes.grid'] = False\n",
    "mpl.rcParams['axes.edgecolor'] = 'gray'\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "#linear\n",
    "y1_color = (0.96, 0.78, 0.26)\n",
    "ax.plot(dimensions, lin_means, label='Linear schedule', color=y1_color, linewidth=2, marker='^', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, lin_means - lin_stds, lin_means + lin_stds, color=y1_color, alpha=0.15)\n",
    "\n",
    "# cosine schedule\n",
    "y2_color = cmap(4/20)\n",
    "ax.plot(dimensions, cos_means, label='Cosine schedule', color=y2_color, linewidth=2, linestyle = 'dotted', marker='*', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, cos_means - cos_stds, cos_means + cos_stds, color=y2_color, alpha=0.15)\n",
    "\n",
    "# a_star w2\n",
    "y3_color = cmap(1/20)\n",
    "ax.plot(dimensions, a_star_W2_means, label='$\\\\beta_{a^*}$ (W2 bound)', color=y3_color, linewidth=2, marker='o', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, a_star_W2_means - a_star_W2_stds, a_star_W2_means + a_star_KL_stds, color=y3_color, alpha=0.3)\n",
    "\n",
    "ax.set_ylabel(r'$\\mathcal{W}_2$ distance', fontsize = 18)\n",
    "ax.legend(loc='upper left', fontsize = 16)\n",
    "ax.tick_params(axis='x', labelsize = 18)\n",
    "ax.tick_params(axis='y', labelsize = 18)\n",
    "ax.set_xticks(dimensions)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "95bac4eb-b9ce-4e98-8b67-46cbc01a73e9",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# ANISOTROPIC W2 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9035ee1e-a002-4b07-830b-e2ca8fe5d49a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nsigma_inv = 1\\nbeta_min = 0.1\\nbeta_max = 20\\nT = 1\\n\\na_values = np.linspace(2., 4.25, 10)\\na_values = np.insert(a_values, 0, 0) \\na_values\\n\\ndimensions = [5, 10, 25, 50]\\nn = 10000\\n\\nsample_by_d = []\\n\\nfor idx, d in enumerate(dimensions):\\n    mu = torch.ones(d, device = device)\\n    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\\n    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\\n    SIGMA = torch.diag(diag_values)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = training_distribution.generate_sample(n)\\n    rescale = np.sqrt(2) #set diag to 1/rescale**2\\n    training_sample_rescale, mean ,std  = func.normalize(training_sample, rescale)\\n    sample_by_d.append(training_sample_rescale)\\n    \\n    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n    \\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-3\\n\\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-3\\n\\n    # network_parameters\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    # Monte Carlo estimate samples (for E2 computation in the KL bound)\\n    num_mc = 500\\n\\n    # number of runs (for replication)\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(training_sample_rescale, batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n    a = 0.\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\\n\\n    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\\n    for k, a in enumerate(a_values):\\n        print(f\"optimization for a = {a}\")\\n        sde.beta.change_a(a)\\n        score_theta_trained[k] = [ ]\\n        for j in range(rep_size):\\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            optimizer = Adam(network.parameters(), lr=learning_rate)\\n            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\\n            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n            score_theta_trained[k].append(network)\\n            #torch.save(network.state_dict(), f\\'models/gaussian_aniso/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{k}_{j}_d\\'+str(d)+\\'.pt\\')\\n\\n\\nrep_size = 10\\nnum_steps = 500\\ndimensions = [5,10,25,50]  \\nsimulation_results = []\\na = 0\\nfor d in dimensions:\\n    print(f\"Running simulations for dimension {d}\")\\n\\n    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n    \\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        exp_score = diff.explicit_score(sde, dist)\\n\\n        for j in range(rep_size):  \\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            model_path = f\\'models/gaussian_aniso/d{d}_explicit_rescale_search/model_{k}_{j}_d{d}.pt\\'\\n            network.load_state_dict(torch.load(model_path))\\n\\n            _, error_approx_sup_L2 = func.compute_E2(dist, sde, network, exp_score, num_steps, num_mc)\\n\\n            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n\\n                simulation_results.append({\\n                    \"dimension\": d,\\n                    \"a\": a,\\n                    \"replication\": j,\\n                    \"scheme\": scheme_name,\\n                    \"error_approx_sup_L2\": error_approx_sup_L2,\\n                })\\n\\nsimulation_df = pd.DataFrame(simulation_results)\\n\\n\\ndimensions = [5,10,25,50]  \\n\\nerror_results = []\\n\\nfor idx, d in enumerate(dimensions):\\n    print(f\"Running error calculations for dimension {d}\")\\n    \\n    dim_df = simulation_df[simulation_df[\\'dimension\\'] == d]\\n    epsilon = dim_df.groupby(\\'a\\')[\\'error_approx_sup_L2\\'].mean()\\n\\n    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n    training_sample_rescale = sample_by_d[idx]\\n    \\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    \\n    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        w2_error = func.compute_w2_bound(dist, training_sample_rescale, sde, num_steps, epsilon[a]) \\n        error_results.append({\\n            \"dimension\": d,\\n            \"a\": a,\\n            \"w2_error\": w2_error\\n        })\\n\\nerrors_df = pd.DataFrame(error_results)\\n\\nsigma_inv = 1\\ns = 0.0211\\nT = 1\\n\\ndimensions = [5, 10, 25, 50]\\nn = 10000\\n\\nfor idx, d in enumerate(dimensions):\\n    mu = torch.ones(d, device = device)\\n    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\\n    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\\n    SIGMA = torch.diag(diag_values)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = training_distribution.generate_sample(n)\\n    rescale = np.sqrt(2) #set diag to 1/rescale**2\\n    training_sample_rescale = sample_by_d[idx]\\n    \\n    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n    \\n\\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 50\\n        learning_rate = 1.0e-3\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-3\\n\\n    # network_parameters\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    # Monte Carlo estimate samples (for E2 computation in the KL bound)\\n    num_mc = 500\\n\\n    # number of runs (for replication)\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(sample_by_d[idx] , batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n\\n    beta_cosine = func.beta_cosine(T, s)\\n    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\\n\\n    score_theta_trained_cosine = [ ]   # a_values, replicates\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n        optimizer = Adam(network.parameters(), lr=learning_rate)\\n        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\\n        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n        score_theta_trained_cosine.append(network)\\n        #torch.save(network.state_dict(), f\\'models/gaussian_aniso/d\\'+str(d)+\\'_explicit_rescale_search\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\')\\n\\n\\n##linear simulation\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nnum_steps_vec = np.array([num_steps]) #to adjust as desired\\nsimulation_results_lin = []\\n\\n#### LINEAR\\n\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\\n    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\\n    SIGMA = torch.diag(diag_values)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    mean = torch.ones(d)\\n    std = diag_values\\n    \\n    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\\n    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\\n    \\n    init = sde_lin.final.generate_sample(sample_batch_size)\\n    score_theta_trained_lin = []\\n\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_aniso/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{np.where(a_values == 0)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_lin.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_lin):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_lin.append({\\n                \"dimension\": d,\\n                \"model\": \"lin\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_lin_df = pd.DataFrame(simulation_results_lin)\\n\\n#### Cosine\\n\\nsimulation_results_cos = []\\nfor d in dimensions:   \\n    \\n    mu = torch.ones(d, device = device)\\n    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\\n    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\\n    SIGMA = torch.diag(diag_values)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    mean = torch.ones(d)\\n    std = diag_values\\n    \\n    beta_cos = func.beta_cosine(T, s)\\n    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \\n    init = sde_cos.final.generate_sample(sample_batch_size)\\n    score_theta_trained_cos = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_aniso/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_cos.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_cos):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_cos.append({\\n                \"dimension\": d,\\n                \"model\": \\'cos\\',\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_cos_df = pd.DataFrame(simulation_results_cos)\\n\\n#### a* W2\\n\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nsimulation_results_a_star_W2 = []\\nmin_a_W2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\\n\\n\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\\n    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\\n    SIGMA = torch.diag(diag_values)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    mean = torch.ones(d)\\n    std = diag_values\\n    \\n    a_star = min_a_W2_dict[d]\\n    \\n    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\\n    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\\n    init = sde_a_star.final.generate_sample(sample_batch_size)\\n    score_theta_trained_a_star = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_aniso/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{np.where(a_values == a_star)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_a_star.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_a_star):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_a_star_W2.append({\\n                \"dimension\": d,\\n                \"model\": \"a_star_W2\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\\n\\nall_simulations_W2_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_W2_df])\\n\\n'"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#### HETEROSCEDASTIC\n",
    "########### SET Training data PARAMETERS #################\n",
    "'''\n",
    "sigma_inv = 1\n",
    "beta_min = 0.1\n",
    "beta_max = 20\n",
    "T = 1\n",
    "\n",
    "a_values = np.linspace(2., 4.25, 10)\n",
    "a_values = np.insert(a_values, 0, 0) \n",
    "a_values\n",
    "\n",
    "dimensions = [5, 10, 25, 50]\n",
    "n = 10000\n",
    "\n",
    "sample_by_d = []\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\n",
    "    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\n",
    "    SIGMA = torch.diag(diag_values)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = training_distribution.generate_sample(n)\n",
    "    rescale = np.sqrt(2) #set diag to 1/rescale**2\n",
    "    training_sample_rescale, mean ,std  = func.normalize(training_sample, rescale)\n",
    "    sample_by_d.append(training_sample_rescale)\n",
    "    \n",
    "    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "    \n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(training_sample_rescale, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "    a = 0.\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\n",
    "\n",
    "    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\n",
    "    for k, a in enumerate(a_values):\n",
    "        print(f\"optimization for a = {a}\")\n",
    "        sde.beta.change_a(a)\n",
    "        score_theta_trained[k] = [ ]\n",
    "        for j in range(rep_size):\n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\n",
    "            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "            score_theta_trained[k].append(network)\n",
    "            #torch.save(network.state_dict(), f'models/gaussian_aniso/d'+str(d)+ '_explicit_rescale_search' + f'/model_{k}_{j}_d'+str(d)+'.pt')\n",
    "\n",
    "\n",
    "rep_size = 10\n",
    "num_steps = 500\n",
    "dimensions = [5,10,25,50]  \n",
    "simulation_results = []\n",
    "a = 0\n",
    "for d in dimensions:\n",
    "    print(f\"Running simulations for dimension {d}\")\n",
    "\n",
    "    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "    \n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        exp_score = diff.explicit_score(sde, dist)\n",
    "\n",
    "        for j in range(rep_size):  \n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            model_path = f'models/gaussian_aniso/d{d}_explicit_rescale_search/model_{k}_{j}_d{d}.pt'\n",
    "            network.load_state_dict(torch.load(model_path))\n",
    "\n",
    "            _, error_approx_sup_L2 = func.compute_E2(dist, sde, network, exp_score, num_steps, num_mc)\n",
    "\n",
    "            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "\n",
    "                simulation_results.append({\n",
    "                    \"dimension\": d,\n",
    "                    \"a\": a,\n",
    "                    \"replication\": j,\n",
    "                    \"scheme\": scheme_name,\n",
    "                    \"error_approx_sup_L2\": error_approx_sup_L2,\n",
    "                })\n",
    "\n",
    "simulation_df = pd.DataFrame(simulation_results)\n",
    "\n",
    "\n",
    "dimensions = [5,10,25,50]  \n",
    "\n",
    "error_results = []\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    print(f\"Running error calculations for dimension {d}\")\n",
    "    \n",
    "    dim_df = simulation_df[simulation_df['dimension'] == d]\n",
    "    epsilon = dim_df.groupby('a')['error_approx_sup_L2'].mean()\n",
    "\n",
    "    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "    training_sample_rescale = sample_by_d[idx]\n",
    "    \n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    \n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        w2_error = func.compute_w2_bound(dist, training_sample_rescale, sde, num_steps, epsilon[a]) \n",
    "        error_results.append({\n",
    "            \"dimension\": d,\n",
    "            \"a\": a,\n",
    "            \"w2_error\": w2_error\n",
    "        })\n",
    "\n",
    "errors_df = pd.DataFrame(error_results)\n",
    "\n",
    "sigma_inv = 1\n",
    "s = 0.0211\n",
    "T = 1\n",
    "\n",
    "dimensions = [5, 10, 25, 50]\n",
    "n = 10000\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\n",
    "    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\n",
    "    SIGMA = torch.diag(diag_values)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = training_distribution.generate_sample(n)\n",
    "    rescale = np.sqrt(2) #set diag to 1/rescale**2\n",
    "    training_sample_rescale = sample_by_d[idx]\n",
    "    \n",
    "    cov_scale = torch.eye(d)/(rescale)**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "    \n",
    "\n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 50\n",
    "        learning_rate = 1.0e-3\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(sample_by_d[idx] , batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "\n",
    "    beta_cosine = func.beta_cosine(T, s)\n",
    "    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\n",
    "\n",
    "    score_theta_trained_cosine = [ ]   # a_values, replicates\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "        optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\n",
    "        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "        score_theta_trained_cosine.append(network)\n",
    "        #torch.save(network.state_dict(), f'models/gaussian_aniso/d'+str(d)+'_explicit_rescale_search' + f'/model_cosine_d'+str(d)+'.pt')\n",
    "\n",
    "\n",
    "##linear simulation\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "num_steps_vec = np.array([num_steps]) #to adjust as desired\n",
    "simulation_results_lin = []\n",
    "\n",
    "#### LINEAR\n",
    "\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\n",
    "    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\n",
    "    SIGMA = torch.diag(diag_values)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    mean = torch.ones(d)\n",
    "    std = diag_values\n",
    "    \n",
    "    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\n",
    "    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\n",
    "    \n",
    "    init = sde_lin.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_lin = []\n",
    "\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_aniso/d'+str(d)+ '_explicit_rescale_search' + f'/model_{np.where(a_values == 0)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_lin.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_lin):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_lin.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"lin\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_lin_df = pd.DataFrame(simulation_results_lin)\n",
    "\n",
    "#### Cosine\n",
    "\n",
    "simulation_results_cos = []\n",
    "for d in dimensions:   \n",
    "    \n",
    "    mu = torch.ones(d, device = device)\n",
    "    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\n",
    "    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\n",
    "    SIGMA = torch.diag(diag_values)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    mean = torch.ones(d)\n",
    "    std = diag_values\n",
    "    \n",
    "    beta_cos = func.beta_cosine(T, s)\n",
    "    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \n",
    "    init = sde_cos.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_cos = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_aniso/d'+str(d)+ '_explicit_rescale_search' + f'/model_cosine_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_cos.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_cos):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_cos.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": 'cos',\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_cos_df = pd.DataFrame(simulation_results_cos)\n",
    "\n",
    "#### a* W2\n",
    "\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "simulation_results_a_star_W2 = []\n",
    "min_a_W2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\n",
    "\n",
    "\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    blocks = torch.tensor([1, .01, 1., 1., 1.], device=device)\n",
    "    diag_values = torch.repeat_interleave(blocks, d // len(blocks))\n",
    "    SIGMA = torch.diag(diag_values)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    mean = torch.ones(d)\n",
    "    std = diag_values\n",
    "    \n",
    "    a_star = min_a_W2_dict[d]\n",
    "    \n",
    "    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\n",
    "    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\n",
    "    init = sde_a_star.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_a_star = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_aniso/d'+str(d)+ '_explicit_rescale_search' + f'/model_{np.where(a_values == a_star)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_a_star.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_a_star):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_a_star_W2.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"a_star_W2\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\n",
    "\n",
    "all_simulations_W2_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_W2_df])\n",
    "\n",
    "'''\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "2b923ee4-bbad-4a68-97f5-3fab653b7a4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_aniso/dimension_search_rescale_pkl', 'simulation_df.pkl')\n",
    "#simulation_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_aniso/dimension_search_rescale_pkl/simulation_df.pkl'\n",
    "simulation_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e7cc1a76-09fe-49a8-b0a0-4e0c46131107",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_aniso/dimension_search_rescale_pkl', 'errors_df.pkl')\n",
    "#errors_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_aniso/dimension_search_rescale_pkl/errors_df.pkl'\n",
    "errors_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1ef9e340-8ca1-4574-8a42-f0e6ce1502cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_df = pd.merge(simulation_df, errors_df, on=[\"dimension\", \"a\"], how=\"left\")\n",
    "dimensions = [5,10,25, 50]\n",
    "\n",
    "dimensional_bounds = []\n",
    "\n",
    "\n",
    "for d in dimensions:\n",
    "    dim_df = results_df[results_df['dimension'] == d]\n",
    "    W2_upperbound = dim_df.groupby('a')['w2_error'].mean()\n",
    "    bound_df = pd.DataFrame({\n",
    "        'dimension': d,\n",
    "        'a': W2_upperbound.index,  \n",
    "        'W2_upperbound': W2_upperbound\n",
    "    })\n",
    "    \n",
    "    dimensional_bounds.append(bound_df)\n",
    "all_bounds_df = pd.concat(dimensional_bounds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "b1f8bb44-4460-4820-adcd-2b5a28c6535e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   dimension  min_a  min_W2_upperbound\n",
      "0          5   4.00           2.851929\n",
      "1         10   3.25           4.212562\n",
      "2         25   2.00           6.870854\n",
      "3         50   2.75          10.594205\n"
     ]
    }
   ],
   "source": [
    "min_w2_bounds = []\n",
    "for bound_df in dimensional_bounds:\n",
    "    d = bound_df['dimension'].iloc[0]\n",
    "    min_w2 = bound_df['W2_upperbound'].min()\n",
    "    min_a = bound_df.loc[bound_df['W2_upperbound'] == min_w2, 'a'].values[0]\n",
    "    min_w2_bounds.append({'dimension': d, 'min_a': min_a, 'min_W2_upperbound': min_w2})\n",
    "min_w2_bounds_df = pd.DataFrame(min_w2_bounds)\n",
    "print(min_w2_bounds_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "d2426da0-3950-4eb0-8890-0388c5b5d3d0",
   "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",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dimension</th>\n",
       "      <th>model</th>\n",
       "      <th colspan=\"2\" halign=\"left\">w2</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>5</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.096592</td>\n",
       "      <td>0.003062</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.096437</td>\n",
       "      <td>0.002380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>5</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.098889</td>\n",
       "      <td>0.003604</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.143224</td>\n",
       "      <td>0.004899</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.143701</td>\n",
       "      <td>0.002460</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>10</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.147478</td>\n",
       "      <td>0.009638</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>25</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.242493</td>\n",
       "      <td>0.004769</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>25</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.250520</td>\n",
       "      <td>0.004448</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>25</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.249144</td>\n",
       "      <td>0.011394</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>50</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.372292</td>\n",
       "      <td>0.004694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>50</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.374868</td>\n",
       "      <td>0.003243</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>50</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.385612</td>\n",
       "      <td>0.009333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dimension      model        w2          \n",
       "                             mean       std\n",
       "0          5  a_star_W2  0.096592  0.003062\n",
       "1          5        cos  0.096437  0.002380\n",
       "2          5        lin  0.098889  0.003604\n",
       "3         10  a_star_W2  0.143224  0.004899\n",
       "4         10        cos  0.143701  0.002460\n",
       "5         10        lin  0.147478  0.009638\n",
       "6         25  a_star_W2  0.242493  0.004769\n",
       "7         25        cos  0.250520  0.004448\n",
       "8         25        lin  0.249144  0.011394\n",
       "9         50  a_star_W2  0.372292  0.004694\n",
       "10        50        cos  0.374868  0.003243\n",
       "11        50        lin  0.385612  0.009333"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_aniso/dimension_search_rescale_pkl', 'all_simulations_W2_df.pkl')\n",
    "#all_simulations_W2_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_aniso/dimension_search_rescale_pkl/all_simulations_W2_df.pkl'\n",
    "all_simulations_W2_df = pd.read_pickle(file_path_load)\n",
    "\n",
    "summary_stats = all_simulations_W2_df.groupby(['dimension', 'model']).agg({\n",
    "    'w2': ['mean', 'std']\n",
    "}).reset_index()\n",
    "\n",
    "summary_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "681fbc1d-ddc2-4680-a424-e2ad6f42afec",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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SkQsaWok2/SmuKMDwztMpbmYM3ewxx3PvAx7SDEWb9EZ2SGS8zomhxRjmh54PFnsVkiOstA92U7LGFujL8agERZkLpeLW2+9lRkzZpCRkUH79u0JCwtj5cqV3HnnncyYMaPe15wxYwZjx45l2bJlALRv356SkhLmzp3LyJEj+fHHH6s8r+xDLyEhgV69elX5X1V/oTd2Ho+Hbdt3sDZPxdSkNes3bOSVV15h/YaNGJJasy5PZdv2v/B4PLVf7AT797//jc1mY+bMmfz3v/+luLg4ZH96ejp33303aWlptGzZkrvuuiu479ZbbwXgqaeeCvaGATidTiZMmIDD4eD8888PzoZMSEigqKiIF198MWRWo8fjCRYLR2dzNVRZGx999FHS0tKC230+H//+97/ZuXNnMFS1JvVpe79+/Wjbti1//fUXM2bMCHm8++mnn/L777/ToUMHzjrrrGN6TWUrJTz//PMhkxE0TeO1115j3bp1ZGRkBB8Fjho1iqioKObNmxfys+twOHjiiSeqfPxcdu6HH34Ysn/27Nls27atTu0cM2YMBoOBadOmsXr16pB9c+bM4bvvvmP37t3HHLsiCMdC1zV0f2Fg0L4vD8kQjmS01/mxnubNwb/vRZSM98vXoDRGYkq5F1Orf1Zag1L3+1DyDqNk7EEtyUcz2ygwxrCt1Mo+hwmjBO6LbsfTtg87b/uIr60XsCLXGAx4NUk6A5ItjOyeTFJs6FqSLp9KjtOPzWSgS1M7HRPDT8mA12PV6F7Jc889x++//85ZZ53FzJkzgwOJv/76a5588kmmT59Or1696rym4urVq4O5UY8++ihjx47FYDDg8/mYOnUqH3zwARMmTKB79+40adIk5NyyguyWW27hzjvvPI6v8tTmdrvp2a0LXXr0YsaMGcHehU6dOrFuwybuv/9+tm/dgsfjqfOg9ROlbdu2fPDBB9x11128//77zJkzh65duxIfH09WVhZbt25FVVXatWvH//73v5DE+DFjxrB582a+//57hg8fTt++fbHZbGzYsIHCwkJSU1OZPHly8Ph7772XZcuW8cMPP7Bx40a6dOkCBLK88vPz6d27N1deeeVxfX233HILv//+O4sWLWLEiBF07dqV6Ohotm7dSk5ODnFxcbzyyiu1Xqc+bZdlmVdeeYWxY8cyffp0vvvuOzp06EBaWhp//fUX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UkpKSnC5XIwdO5aLLrqIqVOn7uUei5+qiooKnn76aVauXElZWRkAOTk5HHPMMVx22WUkJyfvcsxgf36E2F/tybNbX1/PE088wXvvvUdlZSVut5tDDjmEK664gvHjx/dbXyUg2w80NTVRWlqK2Wxm3LhxnbYzm817sVfdt379eu6///4u23i9Xi655BLWrVuH1WplxIgRNDQ0sGrVKlatWsW8efO49tpr91KPxU/V//73P+bOnUtTUxNms5m8vDwMw2Dbtm388MMPLF68mIULFzJ69OjoMYP9+RFif7Unz25NTQ3nnXceRUVFxMTEMHLkSCorK1m+fDkrVqzgrrvu4swzz+yX/kpAth/YuHEjAEOGDGHRokUD3JueWb16NfPmzcPj8XTZ7q677mLdunWMGTOGJ554gszMTABef/11br31VubPn88hhxzClClT9ka3xU9QU1MT8+bNo6mpiaOOOoo///nPpKWlAVBcXMxvf/tbvvzyS6655hrefPNN7HY7MLifHyH2Z3vy7N5www0UFRVxxBFH8MgjjxAfH49hGCxcuJCHHnqIO+64gwkTJjBs2LA+76/MIdsPfP/99wCMHDlygHvSfYFAgPnz53PppZfS2NjYZduioiKWLFmCyWTiwQcfjAZjALNmzeLKK68EYP78+f3aZ/HT9uqrr1JXV0daWhp/+ctfosEYQG5uLgsWLCA+Pp6SkhLefvvt6L7B+PwIIXr+7K5evZo1a9bgdDp58MEHiY+PB8BkMjFnzhxmzpxJKBTiiSee6Jf+SkC2H2j9pRwxYsQA96R7tm/fzkknncTjjz8OwPXXX092dnan7RcvXoyu64wfP57hw4fvsv+8884D4Msvv4zOGRL7n9WrVwNw7LHHEhsbu8v+pKQkJkyYAMDXX38d3T7Ynh8hRERPn93XXnsNgOOPP56kpKRd9p977rkAvPfee/j9/j7qZRsJyPYDrb+Uo0aNGuCedE9FRQXl5eWMHz+el156iblz53bZfu3atQAceuihHe5PT0+PBnRr1qzp076KwWPu3Lncd999nHHGGZ22UUoBYBhGdNtge36EEBE9fXa/+uoroPPvkoMPPhiLxYLX6+Wbb77pm07uROaQ7eN0XWfz5s0ApKWl8cwzz/C///2P5uZm0tPTOeaYY5g+fTom008nNs/IyODvf/97t1dGbt++HYC8vLxO22RnZ1NaWkphYWFfdFEMQgcffDAHH3xwp/vr6uqiAXvrSOtgfH6EED1/dg3DoKSkBOj8u8RqtZKenk5paSnbtm1j4sSJfdpnCcj2cYWFhQQCAQAuvfTSXSbHL168mH/+858sWLCg3ZyagTRkyBCGDBnS7fa1tbUAHQ4xt0pISAAiy5mF6Mif/vQnfD4fMTExnHTSScDgfH6EED1/dhsbGwmHw8Duv0tKS0v75btE/qzbx7UO2QIcdNBBPP/886xdu5bVq1fzwAMPkJqayvr165kzZw7BYHAAe7rnWt/l22y2Ttu0rpjrj/f+YvD761//yhtvvAHA1VdfHc1Ftj88P0Lsi3r67O783TBQ3yUyQraPy8rK4sILL8RkMnHzzTdHh2djYmKYOXMmBx10ELNnz+a7777j5Zdf5vzzzx/gHvec2WxuN+enK5qm9XNvxGDz+OOPR1fgHn/88dFVubB/PD9C7It6+uwef/zxPTp/f3yXSEC2j5swYUJ05VhHhg4dymmnncZLL73Eu+++Oyi/UJxOJ42NjV2OULQOXTscjr3VLfETFw6Hueuuu3jxxRcBOPLII3nkkUfafdDuD8+PEPuinj67M2fOjO4bqO8SeWUpGDNmDEB0QuNgk5iYCHQ9P6x1X0dlccT+p6WlhTlz5kSDsVNOOYUnnngi+jqiJwb78yPE/mrnZ9fpdEZfVTY0NHR6TH9+l0hAth8wDKPLiL91qb/FMjgHTAsKCgC6rFfWui8/P39vdEn8hFVUVHDeeefx8ccfA3D55Zfz8MMPdzpvZF9/foTYV/Xk2TWZTAwdOhTo/I+rUChEVVUV0D/fJRKQ7eN+8YtfMHbs2C5rQW7YsAGgw6Sqg0FrjbLWfGQ/VlFREU0I29UQttj3VVZWcuGFF7Jp0ybMZjN33HEHv/3tbzudD7I/PD9C7Iv25Nnd3XfJ+vXrCYfD2O12DjjggL7tMBKQ7fNGjBiBruu88847tLS07LK/tLSUt956C4i8thmMpk+fDkSSvm7dunWX/a01zCZNmkROTs5e7Zv46QgGg8ydO5eioiKsViuPPvpotIpDZ/aH50eIfdGePLsnn3wyAMuWLevwtWXrd8kpp5wic8hEz11yySXYbDYqKyu54YYbqK6uju77/vvvufzyy/F6vfzsZz/jxBNPHMCe7rn8/HxmzJiBruvMmzcvmigWIrlmFi5cCLDbjP9i3/aPf/wj+hfxH/7wB6ZNm7bbY/aH50eIfdGePLuTJ0/mkEMOobm5mWuuuYaamhog8urzH//4B//973+xWq3tVmL3JU21vkQV+6xly5Zx0003EQgEsFqtDB06lHA4HB1NGjt2LE899VQ0eepP0XHHHUdpaSl33303Z5111i776+vrueiii6KvokaOHElTU1N07tgNN9zAVVddtbe7LX4igsEgRx55JI2NjVgsli4z9gNMnTo1+vuyLzw/QuyP9uTZLS4u5oILLqCiogKbzcaIESOoqqqiuroaTdO4//77263I7EsSkO0ntm7dyj//+U8+/vhjqqqqcDgcDB8+nBkzZnDuuef+5Cck7y4gA/B6vTz11FO89dZbFBcXY7FYGDt2LBdeeKGMXuznvvnmmy5rWP7Y7Nmzuffee6M/D/bnR4j91Z48u3V1dTz55JOsWLGCiooKYmJiGDduHFdccQWHH354v/VVAjIhhBBCiAEmc8iEEEIIIQaYBGRCCCGEEANMAjIhhBBCiAEmAZkQQgghxACTgEwIIYQQYoBJQCaEEEIIMcAkIBNCCCGEGGASkAkhhBBCDDAJyIQQQgghBpgEZEIIIYQQA0wCMiGEEEKIASYBmRBCCCHEAJOATAghhBBigElAJoQQQggxwP4/YAC87rEttxEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dimensions = np.array([5, 10, 25, 50])\n",
    "\n",
    "lin_means = summary_stats[summary_stats['model'] == 'lin']['w2']['mean'].values\n",
    "lin_stds = summary_stats[summary_stats['model'] == 'lin']['w2']['std'].values\n",
    "\n",
    "cos_means = summary_stats[summary_stats['model'] == 'cos']['w2']['mean'].values\n",
    "cos_stds = summary_stats[summary_stats['model'] == 'cos']['w2']['std'].values\n",
    "\n",
    "a_star_W2_means = summary_stats[summary_stats['model'] == 'a_star_W2']['w2']['mean'].values\n",
    "a_star_W2_stds = summary_stats[summary_stats['model'] == 'a_star_W2']['w2']['std'].values\n",
    "\n",
    "font = {'family' : 'sans-serif', 'size' : 16}\n",
    "plt.rc('font', **font)\n",
    "cmap = cm.get_cmap('tab20c')\n",
    "mpl.rcParams['axes.facecolor'] = 'white'\n",
    "mpl.rcParams['axes.grid'] = False\n",
    "mpl.rcParams['axes.edgecolor'] = 'gray'\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "#linear\n",
    "y1_color = (0.96, 0.78, 0.26)\n",
    "ax.plot(dimensions, lin_means, label='Linear schedule', color=y1_color, linewidth=2, marker='^', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, lin_means - lin_stds, lin_means + lin_stds, color=y1_color, alpha=0.15)\n",
    "\n",
    "# Plot for Cosine schedule\n",
    "y2_color = cmap(4/20)\n",
    "ax.plot(dimensions, cos_means, label='Cosine schedule', color=y2_color, linewidth=2, linestyle = 'dotted', marker='*', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, cos_means - cos_stds, cos_means + cos_stds, color=y2_color, alpha=0.15)\n",
    "\n",
    "y3_color = cmap(1/20)\n",
    "ax.plot(dimensions, a_star_W2_means, label='$\\\\beta_{a^*}$ (W2 bound)', color=y3_color, linewidth=2, marker='o', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, a_star_W2_means - a_star_W2_stds, a_star_W2_means + a_star_W2_stds, color=y3_color, alpha=0.3)\n",
    "\n",
    "#ax.set_xlabel('Dimension', fontsize = 18)\n",
    "ax.set_ylabel(r'$\\mathcal{W}_2$ distance', fontsize = 18)\n",
    "ax.legend(loc='upper left', fontsize = 16)\n",
    "ax.tick_params(axis='x', labelsize = 18)\n",
    "ax.tick_params(axis='y', labelsize = 18)\n",
    "ax.set_xticks(dimensions)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d7ce92c1-6eb3-447d-85e9-4b943e952120",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# CORRELATED KL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "03c92703-f5c5-4808-9165-40ca0025c067",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nsample_by_d = [] \\n\\nfor idx, d in enumerate(dimensions):\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    sample_by_d.append(training_distribution.generate_sample(n))\\n\\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-3\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-3\\n\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    num_mc = 500\\n\\n    rep_size = 10\\n\\n    dataloader = DataLoader(sample_by_d[idx], batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n    a = 0.\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\\n  \\n    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\\n    for k, a in enumerate(a_values):\\n        print(f\"optimization for a = {a}\")\\n        sde.beta.change_a(a)\\n        score_theta_trained[k] = [ ]\\n        for j in range(rep_size):\\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            optimizer = Adam(network.parameters(), lr=learning_rate)\\n            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\\n            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n            score_theta_trained[k].append(network)\\n            #torch.save(network.state_dict(), f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{k}_{j}_d\\'+str(d)+\\'.pt\\')\\n'"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#### CORRELATED\n",
    "########### SET Training data PARAMETERS #################\n",
    "a_values = np.linspace(1.25, 2.25, 5)\n",
    "a_values = np.append(a_values, 0)\n",
    "sigma_inv = 1\n",
    "beta_min = 0.1\n",
    "beta_max = 20\n",
    "T = 1\n",
    "\n",
    "dimensions = [5, 10, 25, 50]\n",
    "n = 10000\n",
    "'''\n",
    "sample_by_d = [] \n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    sample_by_d.append(training_distribution.generate_sample(n))\n",
    "\n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-3\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    num_mc = 500\n",
    "\n",
    "    rep_size = 10\n",
    "\n",
    "    dataloader = DataLoader(sample_by_d[idx], batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "    a = 0.\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\n",
    "  \n",
    "    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\n",
    "    for k, a in enumerate(a_values):\n",
    "        print(f\"optimization for a = {a}\")\n",
    "        sde.beta.change_a(a)\n",
    "        score_theta_trained[k] = [ ]\n",
    "        for j in range(rep_size):\n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\n",
    "            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "            score_theta_trained[k].append(network)\n",
    "            #torch.save(network.state_dict(), f'models/gaussian_covar/d'+str(d)+ '_explicit_search' + f'/model_{k}_{j}_d'+str(d)+'.pt')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "cec92f52-ed62-4b88-995c-ea06df1136fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nnum_steps = 500\\nsimulation_results = []\\nfor d in dimensions:\\n    print(f\"Running simulations for dimension {d}\")\\n    mu = torch.ones(d, device=device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\\n        sde.beta.change_a(a)\\n        exp_score = diff.explicit_score(sde, training_distribution)\\n        for j in range(rep_size):  \\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            model_path = f\\'models/gaussian_covar/d{d}_explicit_search/model_{k}_{j}_d{d}.pt\\'\\n            network.load_state_dict(torch.load(model_path))\\n            error_approx_E2, _ = func.compute_E2(training_distribution, sde, network, exp_score, num_steps, num_mc)\\n            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n                simulation_results.append({\\n                    \"dimension\": d,\\n                    \"a\": a,\\n                    \"replication\": j,\\n                    \"scheme\": scheme_name,\\n                    \"error_approx_E2\": error_approx_E2,\\n                })\\nsimulation_df = pd.DataFrame(simulation_results)\\n\\n\\nerror_results = []\\n\\nfor d in dimensions:\\n    print(f\"Running error calculations for dimension {d}\")\\n    dim_df = simulation_df[simulation_df[\\'dimension\\'] == d]\\n    mu = torch.ones(d, device=device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    \\n    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        error_mixing_E1 = func.compute_E1(training_distribution, sde)\\n        error_discr_E3 = func.compute_E3(training_distribution, sde, num_steps)\\n        \\n        error_results.append({\\n            \"dimension\": d,\\n            \"a\": a,\\n            \"error_mixing_E1\": error_mixing_E1,\\n            \"error_discr_E3\": error_discr_E3,\\n        })\\n\\nerrors_df = pd.DataFrame(error_results)\\n\\n\\n#### COVAR TRAIN COSINE\\n########### SET Training data PARAMETERS #################\\n\\nsigma_inv = 1\\ns = 0.021122\\nT = 1\\nn = 10000\\n\\nfor idx, d in enumerate(dimensions):\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = sample_by_d[idx]\\n\\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-3\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-3\\n\\n    # network_parameters\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    # Monte Carlo estimate samples (for E2 computation in the KL bound)\\n    num_mc = 500\\n\\n    # number of runs (for replication)\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(training_sample, batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n\\n    beta_cosine = func.beta_cosine(T, s)\\n    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\\n  \\n    score_theta_trained_cosine = [ ]   # a_values, replicates\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n        optimizer = Adam(network.parameters(), lr=learning_rate)\\n        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\\n        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n        score_theta_trained_cosine.append(network)\\n        #torch.save(network.state_dict(), f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\')\\n\\n##linear simulation\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nnum_steps_vec = np.array([num_steps]) #to adjust as desired\\nsimulation_results_lin = []\\n\\n#### LINEAR\\n\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\\n    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\\n    init = sde_lin.final.generate_sample(sample_batch_size)\\n    score_theta_trained_lin = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{np.where(a_values == 0)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_lin.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_lin):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            simulation_results_lin.append({\\n                \"dimension\": d,\\n                \"model\": \"lin\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                })\\n\\nsimulation_lin_df = pd.DataFrame(simulation_results_lin)\\n\\n#### Cosine\\n\\nsimulation_results_cos = []\\nfor d in dimensions:   \\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    beta_cos = func.beta_cosine(T, s)\\n    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \\n    init = sde_cos.final.generate_sample(sample_batch_size)\\n    score_theta_trained_cos = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_cos.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_cos):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            simulation_results_cos.append({\\n                \"dimension\": d,\\n                \"model\": \\'cos\\',\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                })\\n\\nsimulation_cos_df = pd.DataFrame(simulation_results_cos)\\n\\n#### a* KL\\n\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nnum_steps_vec = np.array([num_steps]) #to adjust as desired\\nsimulation_results_a_star_KL = []\\nmin_a_KL_dict = pd.Series(min_kl_bounds_df.min_a.values, index=min_kl_bounds_df.dimension).to_dict()\\n\\n\\nfor d in dimensions:\\n    a_star = min_a_KL_dict[d]\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    \\n    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\\n    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\\n    init = sde_a_star.final.generate_sample(sample_batch_size)\\n\\n    score_theta_trained_a_star = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_search\\' + f\\'/model_{np.where(a_values == a_star)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_a_star.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_a_star):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\\n            kl_value = kl(training_distribution, empirical(sample))\\n            simulation_results_a_star_KL.append({\\n                \"dimension\": d,\\n                \"model\": \"a_star_KL\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"kl\": kl_value,\\n                })\\n\\nsimulation_a_star_KL_df = pd.DataFrame(simulation_results_a_star_KL)\\n\\nall_simulations_KL_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_KL_df])\\n'"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "num_steps = 500\n",
    "simulation_results = []\n",
    "for d in dimensions:\n",
    "    print(f\"Running simulations for dimension {d}\")\n",
    "    mu = torch.ones(d, device=device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\n",
    "        sde.beta.change_a(a)\n",
    "        exp_score = diff.explicit_score(sde, training_distribution)\n",
    "        for j in range(rep_size):  \n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            model_path = f'models/gaussian_covar/d{d}_explicit_search/model_{k}_{j}_d{d}.pt'\n",
    "            network.load_state_dict(torch.load(model_path))\n",
    "            error_approx_E2, _ = func.compute_E2(training_distribution, sde, network, exp_score, num_steps, num_mc)\n",
    "            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "                simulation_results.append({\n",
    "                    \"dimension\": d,\n",
    "                    \"a\": a,\n",
    "                    \"replication\": j,\n",
    "                    \"scheme\": scheme_name,\n",
    "                    \"error_approx_E2\": error_approx_E2,\n",
    "                })\n",
    "simulation_df = pd.DataFrame(simulation_results)\n",
    "\n",
    "\n",
    "error_results = []\n",
    "\n",
    "for d in dimensions:\n",
    "    print(f\"Running error calculations for dimension {d}\")\n",
    "    dim_df = simulation_df[simulation_df['dimension'] == d]\n",
    "    mu = torch.ones(d, device=device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    \n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        error_mixing_E1 = func.compute_E1(training_distribution, sde)\n",
    "        error_discr_E3 = func.compute_E3(training_distribution, sde, num_steps)\n",
    "        \n",
    "        error_results.append({\n",
    "            \"dimension\": d,\n",
    "            \"a\": a,\n",
    "            \"error_mixing_E1\": error_mixing_E1,\n",
    "            \"error_discr_E3\": error_discr_E3,\n",
    "        })\n",
    "\n",
    "errors_df = pd.DataFrame(error_results)\n",
    "\n",
    "\n",
    "#### COVAR TRAIN COSINE\n",
    "########### SET Training data PARAMETERS #################\n",
    "\n",
    "sigma_inv = 1\n",
    "s = 0.021122\n",
    "T = 1\n",
    "n = 10000\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = sample_by_d[idx]\n",
    "\n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-3\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-3\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(training_sample, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "\n",
    "    beta_cosine = func.beta_cosine(T, s)\n",
    "    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\n",
    "  \n",
    "    score_theta_trained_cosine = [ ]   # a_values, replicates\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "        optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, training_distribution)) # to choose in the Gaussian case for training with the analytical score function\n",
    "        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "        score_theta_trained_cosine.append(network)\n",
    "        #torch.save(network.state_dict(), f'models/gaussian_covar/d'+str(d)+ '_explicit' + f'/model_cosine_d'+str(d)+'.pt')\n",
    "\n",
    "##linear simulation\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "num_steps_vec = np.array([num_steps]) #to adjust as desired\n",
    "simulation_results_lin = []\n",
    "\n",
    "#### LINEAR\n",
    "\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\n",
    "    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\n",
    "    init = sde_lin.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_lin = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit_search' + f'/model_{np.where(a_values == 0)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_lin.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_lin):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            simulation_results_lin.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"lin\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                })\n",
    "\n",
    "simulation_lin_df = pd.DataFrame(simulation_results_lin)\n",
    "\n",
    "#### Cosine\n",
    "\n",
    "simulation_results_cos = []\n",
    "for d in dimensions:   \n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    beta_cos = func.beta_cosine(T, s)\n",
    "    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \n",
    "    init = sde_cos.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_cos = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit' + f'/model_cosine_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_cos.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_cos):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            simulation_results_cos.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": 'cos',\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                })\n",
    "\n",
    "simulation_cos_df = pd.DataFrame(simulation_results_cos)\n",
    "\n",
    "#### a* KL\n",
    "\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "num_steps_vec = np.array([num_steps]) #to adjust as desired\n",
    "simulation_results_a_star_KL = []\n",
    "min_a_KL_dict = pd.Series(min_kl_bounds_df.min_a.values, index=min_kl_bounds_df.dimension).to_dict()\n",
    "\n",
    "\n",
    "for d in dimensions:\n",
    "    a_star = min_a_KL_dict[d]\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    \n",
    "    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\n",
    "    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\n",
    "    init = sde_a_star.final.generate_sample(sample_batch_size)\n",
    "\n",
    "    score_theta_trained_a_star = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit_search' + f'/model_{np.where(a_values == a_star)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_a_star.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_a_star):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\n",
    "            kl_value = kl(training_distribution, empirical(sample))\n",
    "            simulation_results_a_star_KL.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"a_star_KL\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"kl\": kl_value,\n",
    "                })\n",
    "\n",
    "simulation_a_star_KL_df = pd.DataFrame(simulation_results_a_star_KL)\n",
    "\n",
    "all_simulations_KL_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_KL_df])\n",
    "'''\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "74b8ab4b-adb1-44ec-88a0-c240de7f3f07",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_pkl', 'simulation_df.pkl')\n",
    "#simulation_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_pkl/simulation_df.pkl'\n",
    "simulation_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "49037b18-acaa-41b0-ba4b-ac37f7e9e9d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_pkl', 'errors_df.pkl')\n",
    "#errors_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_pkl/errors_df.pkl'\n",
    "errors_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "03e07a0a-ec70-41e1-8753-2cc0e4fbe0e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_df = pd.merge(simulation_df, errors_df, on=[\"dimension\", \"a\"], how=\"left\")\n",
    "\n",
    "dimensional_bounds = []\n",
    "\n",
    "for d in dimensions:\n",
    "    dim_df = results_df[results_df['dimension'] == d]   \n",
    "    error_mixing_E1 = dim_df.groupby('a')['error_mixing_E1'].first()\n",
    "    error_approx_E2 = dim_df.groupby('a')['error_approx_E2'].mean()\n",
    "    error_discr_E3 = dim_df.groupby('a')['error_discr_E3'].first()\n",
    "    KL_upperbound = error_mixing_E1 + error_approx_E2 + error_discr_E3  \n",
    "    error_approx_E2_std = dim_df.groupby('a')['error_approx_E2'].std() \n",
    "    bound_df = pd.DataFrame({\n",
    "        'dimension': d,\n",
    "        'a': error_mixing_E1.index,  \n",
    "        'KL_upperbound': KL_upperbound,\n",
    "        'error_approx_E2_std': error_approx_E2_std\n",
    "    })   \n",
    "    dimensional_bounds.append(bound_df)\n",
    "\n",
    "all_bounds_df = pd.concat(dimensional_bounds)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "953a707f-a3da-4d6d-8c36-9bd93befd31f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   dimension  min_a min_KL_upperbound\n",
      "0          5   2.25    tensor(1.0166)\n",
      "1         10   1.75    tensor(2.1687)\n",
      "2         25   1.75    tensor(5.7183)\n",
      "3         50   2.25   tensor(11.8163)\n"
     ]
    }
   ],
   "source": [
    "min_kl_bounds = []\n",
    "\n",
    "for bound_df in dimensional_bounds:\n",
    "    d = bound_df['dimension'].iloc[0]\n",
    "    min_kl = bound_df['KL_upperbound'].min()\n",
    "    min_a = bound_df.loc[bound_df['KL_upperbound'] == min_kl, 'a'].values[0]\n",
    "    min_kl_bounds.append({'dimension': d, 'min_a': min_a, 'min_KL_upperbound': min_kl})\n",
    "min_kl_bounds_df = pd.DataFrame(min_kl_bounds)\n",
    "print(min_kl_bounds_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "189db74c-744e-40a0-9645-4aaf2f5ede49",
   "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",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dimension</th>\n",
       "      <th>model</th>\n",
       "      <th colspan=\"2\" halign=\"left\">kl</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>5</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.001861</td>\n",
       "      <td>0.000880</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.001197</td>\n",
       "      <td>0.000332</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>5</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.002568</td>\n",
       "      <td>0.002708</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.005871</td>\n",
       "      <td>0.001165</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.005515</td>\n",
       "      <td>0.000775</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>10</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.006210</td>\n",
       "      <td>0.001816</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>25</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.033156</td>\n",
       "      <td>0.003785</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>25</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.040430</td>\n",
       "      <td>0.003475</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>25</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.038434</td>\n",
       "      <td>0.010313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>50</td>\n",
       "      <td>a_star_KL</td>\n",
       "      <td>0.109649</td>\n",
       "      <td>0.008056</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>50</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.110515</td>\n",
       "      <td>0.004646</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>50</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.134716</td>\n",
       "      <td>0.016541</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dimension      model        kl          \n",
       "                             mean       std\n",
       "0          5  a_star_KL  0.001861  0.000880\n",
       "1          5        cos  0.001197  0.000332\n",
       "2          5        lin  0.002568  0.002708\n",
       "3         10  a_star_KL  0.005871  0.001165\n",
       "4         10        cos  0.005515  0.000775\n",
       "5         10        lin  0.006210  0.001816\n",
       "6         25  a_star_KL  0.033156  0.003785\n",
       "7         25        cos  0.040430  0.003475\n",
       "8         25        lin  0.038434  0.010313\n",
       "9         50  a_star_KL  0.109649  0.008056\n",
       "10        50        cos  0.110515  0.004646\n",
       "11        50        lin  0.134716  0.016541"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_pkl', 'all_simulations_KL_df.pkl')\n",
    "#all_simulations_KL_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_pkl/all_simulations_KL_df.pkl'\n",
    "all_simulations_KL_df = pd.read_pickle(file_path_load)\n",
    "\n",
    "summary_stats = all_simulations_KL_df.groupby(['dimension', 'model']).agg({\n",
    "    'kl': ['mean', 'std']\n",
    "}).reset_index()\n",
    "\n",
    "summary_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "789b295d-70c1-45b9-b9c3-defaf01ac382",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmQAAAHECAYAAACX5TbPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOydd3hU1daH3zMtyaR3IAFCSyihiigWECsKKtgbyLWLoiiigsqnXhALVkQsiCgi6BUQFKSIqIBKb4oUSUIKCellJpNpZ39/TGaSkEIamaD7fZ48yj67rHMmmfnN2muvpQghBBKJRCKRSCQSr6HxtgESiUQikUgk/3akIJNIJBKJRCLxMlKQSSQSiUQikXgZKcgkEolEIpFIvIwUZBKJRCKRSCReRgoyiUQikUgkEi8jBZlEIpFIJBKJl5GCTCKRSCQSicTL6LxtgKTpvPzyyzidTgICArxtikQikUgkknJMJhNarZann376lH2lIPsH4HA4kAUXJBKJRCJpXaiqWu/PZynI/gEEBgYC8Oijj3rZEolEIpFIJG7efvvteveVMWQSiUQikUgkXkYKMolEIpFIJBIvIwWZRCKRSCQSiZeRgkwikUgkEonEy0hBJpFIJBKJROJlpCCTSCQSiUQi8TJSkEkkEolEIpF4GSnIJBKJRCKRSLyMTAz7L0cIgd1uR1VVb5sikUgagE6nQ6eTb+ESyT8F+df8L8XpdJKbm0tJSQl2u93b5kgkkkbg7+9PREQERqPR26ZIJJImcsYIMovFwrx581i1ahXp6en4+/uTmJjI2LFjGTp0aLOs8fjjj7Nq1SrWrVtHx44da+yTnp7OJZdcUuc83bt3Z8WKFdXaDx8+zNy5c9m6dSvFxcVERUUxZMgQHnzwQaKjo5vlHuqD0+kkLS0Nq9VKcHAwAQEBaLVaFEVpMRskEknjEUJgtVrJz88nLS2NTp06YTAYvG2WRCJpAmeEICstLWXcuHHs3bsXvV5Pt27dKCwsZPPmzWzevJkJEybw8MMPN2mNxYsXs2rVqlP2O3jwIAAhISF07ty5xj5xcXHV2nbs2MFdd92F1WolNDSU+Ph4kpOTWbx4MatXr+bTTz+lR48eTbqH+pKbm4vVaqVDhw74+fm1yJoSiaR58fPzIzAwkOTkZLKzs4mNjfW2SRKJpAmcEYLsxRdfZO/evfTo0YO5c+fStm1bAL755hueeeYZZs+ezYABAzjvvPMaNf+CBQt4+eWX69XXLciGDx/OCy+8UK8xhYWFjB8/HqvVyr333svEiRPR6XSYTCamTp3K2rVrmTBhAqtXrz7t33KFEJSUlBAcHCzFmERyhqPVagkODqagoAAhhPRySyRnMK3+lGVqaiorV65Eo9Ewa9YsjxgDGDVqFPfeey8As2fPbvDc2dnZPPLII8ycORMhRL3GHDp0CID4+Ph6r7Nw4UKKioro168fTzzxhCcQNyAggFmzZtG+fXvS0tJq3OZsbux2O3a7nYCAgNO+lkQiOf34+fnhdDplLKhEcobT6gXZihUrcDqd9OvXj65du1a7fuuttwKwa9cujh8/Xu95169fzxVXXMHatWsJDg5m2rRp9Rrn9pA1RJAtX74cgBtuuKHaNYPBwPXXXw/Ad999V+85G4v7NKVWqz3ta0kkktOP+29ZnpSWSM5sWr0g27NnDwBnnXVWjdejo6OJiYkBYNu2bfWe9+DBg1gsFq6++mpWrVpVr4MBZrOZtLQ0oP6CLDs7m4yMDAAGDBhQYx93+65du1rsW67c2pBI/hnIv2WJpHkQwunV9Vt9DNmxY8cA6NChQ619YmJiyMjIICUlpd7zDhw4kBUrVpCQkAC4Tk+eikOHDiGEICoqivz8fObPn8+BAwdwOp3ExcUxYsSIasIxNTUVcL1ptm/fvlb7AWw2G5mZmXXeq0QikUgkkuZDCIGw5SHUUjS+7b32JafVC7K8vDwAwsLCau0TEhICQEFBQb3nHTx4cINtcW9XFhcXM2LECJzOCjW9ZcsWFi1axPXXX88LL7yAXq8HKuwPCAioNWDfbT+47kEKMolEIpFITj8eMWbNBK2vV21p9VuWZWVlAHWePvTx8anS93ThFmRWq5Ubb7yRVatWsX//fjZu3MjEiRPR6/UsXbqUGTNmeMZYLJYqNtaEr2/FL4G7v8S7LFu2jISEBMaMGVOv/unp6SQkJDBkyJDTbNk/C28/t2PHjpGQkMDFF1/cpHnGjBlDQkICv/76azNZJpFITjcuMZaLas30tinAGeAh02q19Q5WPd1uxoEDByKEoEePHtx2222e9nbt2vHggw8SExPD5MmTWbJkCbfffjvdunVrcPC8jAeRSCQSieT0UiHGslA0vkD9Mi2cTlq9IDMajRQVFWGz2WrtY7VagaqeptPBNddcwzXXXFPn9Tlz5pCSksKGDRvo1q2bp6SJ28aaqOzZk7nBzkyio6NZvXq1Z6taIpFIJK2TqmLMD0Xrg3B6f3eq1W9ZhoaGAnXHh7mvhYeHt4hNdeHOtu8+JOC232w213qCsvK91RUr90/ghx9+oF/fRH744Qdvm9Ks6PV6unTpIuP/JBKJpBVTeZvSLcZaC61ekLnLE7lTR9SE+1pNJYuaG7vdXiWY/2Tc26vu5K9dunTxtGdm1rxP7bbfx8enSuLbfxpCCJ57dip79/3Jc89OrXcy3jOBmmKh3G3jx48nOzubKVOmcMEFF9C7d29GjBjB/Pnza/xdcjqdfPnll9x4443079+f/v37c/PNN7Ns2bIan1lZWRmffPIJt9xyC4MGDaJXr16ce+653HvvvWzevLla/4SEBK699lq2bdvG8OHD6d27N5dffvkpTynv2bOHhx56iIsvvpjExEQuuOACHnnkEU9qmpP5888/eeKJJxg6dCh9+/Zl+PDhvPLKK7V+uTpx4gRTp07l/PPPp0+fPowYMYJPP/20xntu6DMSQrBkyRJGjx5Nv379GDJkCLNmzaox7vRUcW0NjRdbvXo1Y8aM4ayzzqJv375ce+21LFiwQCZylUhamKpizNiqxBicAYKsb9++ALW+6WdlZXkSwvbv3/+02VFUVMSgQYNITExkw4YNtfb766+/ADxJbIODgz1Ccffu3TWOcbf37dv3H52wdd26dfy+dTsP39Ke37duZ926dd42qUXIycnhhhtu4IcffqBHjx7079+fpKQkXnnlFV566aUqfR0OBw899BDTpk0jOTmZAQMGMGjQIA4fPsyUKVOYMmVKlf5Wq5U77riDl19+mfT0dAYMGMCQIUMwGo388ssv3HPPPTV6I/Py8njwwQfR6/VccMEF+Pj40LFjx1rv4ffff+eOO+7gxx9/pG3btlx88cVERkaydu1abr/9drZs2VKl/3fffcfNN9/Mt99+S0REBEOHDsVmszF//nxuueUWioqKqvQ3mUzccMMNrF27lt69e9OnTx+OHj3KSy+9xKuvvtqkZwTw1FNP8X//93+kpKQwePBgunTpwieffMLjjz9e6z03B9OmTeOxxx5j37599OzZk/PPP5+srCxmzpzJ/fffX2cohkQiaT6qiDFt6xNjcAYIsuHDhwOupK9JSUnVri9evBiAQYMGndbiusHBwURERACuE3g1sWbNGlJTU9Hr9Vx22WWedvc9fPXVV9XG2Gw2li5dCsDo0aOb2+xWgxCC5//vOQYlhvLyI10ZlBjK8//33D/KS1Yb+/bto2PHjqxdu5aPPvqIzz77jDlz5gCwZMkSiouLPX3nzp3Lxo0bOffcc1m3bh0ff/wxH3zwAevXr6dnz54sX76c//3vf57+X3zxBfv37+eSSy5h48aNvP/++8ydO5f169dz2223IYRg0aJF1WzKycnh7LPPZuXKlcydO5cVK1bUeaBk7ty52O12PvroIxYtWsQ777zD8uXLmTJlCg6Hg/fff9/TNzMzk+eec7227777LkuXLuWdd95h3bp1jBw5kpSUlGqlzsxmMzExMWzYsIH333+fzz//nFmzZnnusXIMZkOf0dq1a1mxYgUdOnTg+++/Z+7cuXzyySd8+eWXZGdn1/dlbDDLli3jyy+/JCEhgVWrVrFw4ULee+89NmzYwAUXXMCWLVs8vwcSieT0IYRAWHNQy8rFmKb1iTE4A4L64+LiGDlyJN999x0TJkzgvffe83yTX7FiBfPmzQPgwQcfrDY2NTUVu91OYGAgUVFRTbblvvvu46mnnmLjxo28/vrrTJgwwZOOY82aNZ5v5vfccw/R0dGecWPHjuWLL75gx44dTJ8+nSeffBKDweApLp6Wlkb79u25+uqrm2xjc+DI+xl72gJQS5ttzvW/ZvH71u1882ZfFEVh6t0dGPXYdr6dcxGXndemeRbRGNG3H4cu/NRVF1qaZ555pkp84MUXX0xsbCzp6ekkJyfTt29fbDYbn376KXq9ntdee61K/4iICKZPn851113Hxx9/zI033gi4YteGDh3KpEmTqhwo0Gq13HzzzXzxxRe1Jj2+/fbbPSJMo6n7u1lOTg7gOlFcGfdp406dOnnavvnmG0pLS7n11lurfDHR6XRMmTKFvXv3UlhYWG2N//u//6uSk2/kyJG88sorZGdnk5KSQkJCQqOekftL29NPP02bNhW/a4mJiYwfP56XX365zntvLB999BEAM2fOrPJlMSAggJkzZ3LxxRezaNEiHnrooTrT+kgkksbjEWPWLBRd6xVjcAYIMoBnn32Ww4cPc/jwYa688kri4+MpLi72xF499thjnHfeedXGjRs3joyMDEaPHt0sb7qjRo3i0KFDzJ8/nw8//JBFixYRFxdHbm4uJ06cAODGG2/kkUceqTIuPDycV199lQkTJrBw4UK+/fZbYmNjSU5Oxmw2ExQUxNy5c1vNCT3H8S8RZanNNp8Qghkf7GFQYhCXnuP6AL30nDAGJQYx44M9XHLWWc2W7sNx/KtWJ8j8/Pw8FSEqExUVRXp6OqWlLuF74MABSkpKSEhIqPELRK9evQgPDyc5OZmcnBwiIyO54447uOOOO6r0M5lMHD16lJ9//hmg1m2x7t271/seBg4cyNGjRxkzZgyjR49myJAh9O/fH4PBwLhx46r0dZcwqym3V0RERI1bqH5+fp4DMZVp27Yt2dnZlJSUAA1/RuHh4ezYsQOtVsv5559frf+ll156WgRZTk4OSUlJBAYG0qtXr2rXo6Ki6N69O/v37+fAgQP069ev2W2QSP7tnEliDM4QQRYaGsqXX37Jxx9/zPfff8/Ro0fR6XQMGjSIMWPGcPnll7eYLU899RQXXnghn3/+OXv27OHQoUMEBwczbNgwbrnlFi666KIaxw0bNoylS5fy/vvvs23bNg4ePEhoaCiXX345Dz30UK1llbyBrt3Nzeoh++HXLLb9UezxjgHlXrJOjHpsLxt2OpvHS6Yxomt3U9PnaWYCAwNrFJzugx/ubVt3LOShQ4dqFHCVyczMJDIyEoDc3FwWL17M77//TlJSEvn5+UBFTrvatoWDg4PrfQ+TJ08mPT2dLVu28NFHH/HRRx9hNBq54IILuPbaa7n00ks9fWvzptVFQEBAje3umEr34YeGPiOtVovdbicsLKzGtDjusmXNjfsAj1s8nqqvFGQSSfMihOoSY7YTKDp/FE3r90KfEYIMXPnIJkyYwIQJE+o95scff6x339jYWA4dOlSvvuedd16NHrlTkZCQwJtvvtngcS2NLnxos3mZhBDMHH8OgxJDPd4xNy4vWSgzP7dw9UNL/rFJcet7X+4Tuu3atatWE/Vk/P39Adi6dSsPPPAApaWlREdH079/f7p06UKPHj2IjY31bNvVxKm2KSsTGBjI/Pnz2b9/Pz/88AO//fYbf/zxB+vWrWPdunVcccUVvPPOO4Ar6L6h1NeWxjyjU63b0IM0dZ2yPrlPSEgIF154YZ193cJaIpE0D0KoqNZshC0bRXtmiDE4gwSZ5MzEfbKysnfMTeVYMveH+r8Z9wdzmzZtPAHtdSGE4JlnnqG0tJRp06Zx++23V7l+4MCBZrexd+/e9O7dm8cee4ySkhK+//57ZsyYwdq1a9mxYwcDBw4kMjKS5ORksrKyPKeNK7NixQr8/PwYOrThor8xz8jHx4fCwkLMZnM1kZabm1tNYLnFYW0VQtzbp/Wx08fHp152SiSS5uFMFWNwBpyylJy5uE9Wdo41EhGiZ/ehkmo/ESF6Osca/zUnLuuid+/e+Pr6cvDgwRpP/504cYIrrriCcePGYTabyc3NJS0tjaCgoGpiDPDkIKtv6bHaKCgo4Lrrrqt26CQwMJCbbrqJCy64AHCloAEYMGAAgCeGrTImk4lnnnmG5557zrNl2xAa+owUReHcc89FVdUa09X89NNP1drc1TWKioqq5QorLi6u8bT3ycTGxtKuXTtOnDjhqYFbGYvFwjXXXMPtt99e66ELiUTSMM5kMQZSkElOIzabjfT0NJLSS7ngPzu4YNz26j//2UFSeikZGen/+pxMRqORm266idLSUiZPnkxeXp7nmtls5umnnyYlJQV/f3/8/f0JDAxEr9dTXFzMjh07qsy1bt063nvvPaD2oP76EhoaitPp5PDhwyxYsKDKtfT0dHbt2oVGoyExMRFwHWzx8fFh8eLFVRLT2mw2XnjhBex2OyNGjGhUzr2GPiOAO++8E4BXX32Vo0ePevofPXq0xhCCkJAQ2rRpg81mY8mSJZ52q9XKtGnT6r0l6173ySefJDW14pCMzWbj+eef59ChQ5SWlp7WdD0Syb+FCjF24owUYyC3LCWnER8fH379bZsnyLsuoqKi8PFpfSdgdu/eXePpPDc33XQTjz76aLOtN2nSJP766y9+//13LrvsMnr37o2fnx+7d++msLCQuLg4XnzxRcBVu/WWW25h4cKFjB07lrPPPpugoCCOHDlCcnIyMTExFBQUUFJSQllZWZNqvb7wwguMGTOGmTNn8tVXX9GlSxdMJhM7d+7EarVy7733ehIgx8bG8uKLLzJ16lTuuece+vXrR2RkJH/88QfHjx8nPj6eyZMnt8gzAjj//PO57777+PDDDxk1ahTnnnsu4Ep226tXL3Jzc6utcc899zB9+nSmT5/OqlWriIiIYNeuXdjtdi6++OJ6xaeOHTuWvXv3snr1akaOHEnv3r0JCQlh3759ZGdnEx4ezhtvvNHo5yCRSFxUFWMBZ6QYAynIJKeZ9u3bt6oTpA3FbrfX+IHtxmQyNet6vr6+zJ8/nyVLlrBy5Ur27dsHuETOmDFjGDt2LEFBQZ7+U6ZMoVOnTnz55Zfs27cPVVWJjY3lgQce4O677+bJJ59k48aN/Pzzz02K0evXrx9ffPEFH330Ebt27eLHH3/E39+fAQMGcMstt3iSH7sZNWoUcXFxfPTRR+zYsYP9+/cTHR3NXXfdxfjx4/Hz82u0LQ19RuAScT179uTTTz9lx44d+Pr6Mnr0aCZPnszAgQOrrTFmzBgCAwNZuHAhBw4cwM/Pj8GDBzNp0iS+/PLLegkyjUbDG2+8wdChQ/nf//7HwYMHcTgcxMTEMGLECO66665myY8okfybqbpNeeaKMQBF/NsDd/4BvP322wD18tSUlZWRnJxMp06dmuQxkUgkrQP5Ny35tyKEs1yM5ZSLscbn8hROCygKGmPXZj3x35DPZ+khk0gkEolEckbhEmMnELbcJoux1oIM6pdIJBKJRHLG8E8UYyAFmUQikUgkkjOEf6oYA7llKZFIJBKJ5AygqhgLRNH8sySM9JBJJBKJRCJp1bjEWBbCmvOPFGMgBZlEIpFIJJJWTIUYy0PRBf0jxRhIQSaRSCQSiaSVUlWM/TM9Y26kIJNIJBKJRNLq+DeJMZCCTCKRSCQSSSujQozlouj/+WIM5ClLiUQikUgkrQghnKhlmQhbHoo+CEX5d0gV6SGTSCQSiUTSKvi3ijGQHjKJRCKRSCStAKE6XNuU/0IxBlKQSSQSiUQi8TJVxVgwiqL1tkktjhRkEolEIpFIvIZQHa5tSnseij7kXynGQMaQSSSnxGazsXr1au6//34uueQSevfuzcCBA7n11lv59NNPsVqtLW5TQkICCQkJOByOFl+7Jbn44otJSEjg2LFjXll/yJAhJCQkkJ6e3ug5Zs+eTUJCAm+++WYzWiaR/DOoEGP5/2oxBlKQSSR18vfff3Pdddfx2GOPsXXrViIiIhg2bBhdu3bljz/+4KWXXmL06NFkZ2d721SJRCI5oxCqHbXseLkY8+425Q8bf2XAuSP44YcfvGaD3LKUSGrh2LFj3HTTTZjNZsaMGcNDDz1EaGio53pWVhZTpkzh119/5c4772Tp0qUYjcYWsW316tUA6HTyT1gikZx5uMRYJsJe4HUxJoTg//77Bvv+OMK0557h0ksvRVGUFrdDesgkLcqOHTu44tKL2bFjh7dNqRMhBJMmTcJsNnP//ffz7LPPVhFjAG3atGHOnDnExcWRlJTEV1991WL2denShS5durTYehKJRNJctCYxBrDuh1/Yun0/D9/Snt+3bmfdunVesUMKMkmL8tlnn7Fuw0YWLlzobVPqZOfOnezfv5/IyEjGjx9faz+j0ciDDz7IWWedVeM3qm+//Zbbb7+dAQMG0KdPH66++mrmzp2LxWKp1vfEiRNMmzaNK6+8kj59+jBo0CDGjh3LypUrq/WtKYYsISGBa6+9lpKSEl566SUuuugiEhMTufTSS3nrrbdqXBNc3rYxY8Zw1lln0bdvX6699loWLFiA3W6vz6NqsO0AOTk5vPLKK1xxxRX06dOHYcOG8fjjj3P06NEa+1utVt59910uu+wyEhMTueiii5g+fTomk6nG/r/++iv33nsv55xzDr179+bKK69k9uzZlJaW1tj/t99+4z//+Q9nn302AwcO5LHHHuP48eM19q0rrq2h8WJ//PEHjzzyCIMHDyYxMZFLLrmEmTNnkp+fX6/xEsmZRsU2ZUGriBkTQvDC9FkMSgzh5Ue6MigxlOf/7zmEEC1ui9zvkJxW0tPTq8RXLf3qSwwa+PrLJdx5552e9ujoaGJiYrxhYo24twQvvfRSfH196+w7atQoRo0aVaVNCMGTTz7JypUrMRgMnH322RiNRrZv385bb73FmjVrWLBggcfrlpeXxw033EB2djbx8fFcdNFFFBUVsX37drZu3cqxY8eYMGHCKe22WCzcfvvtpKam0q9fP7p168Zvv/3G3LlzOXjwIO+//36V/tOmTePLL7/E19eXPn36EBgYyM6dO5k5cya//PIL77//PgaDoc41G2r74cOHueuuu8jJySE2NpaLLrqI9PR0Vq1axY8//sjChQvp3bt3lTUeffRRjh07xtlnn02nTp3Yvn07CxcuZN++fSxevBittuJN/cMPP+T1119Hr9eTmJhIZGQke/bs4d1332XDhg18+umnBAcHe/r/73//47nnnkNRFAYOHEhQUBCbNm1i586dtQq45mDFihVMnToVp9NJr169iImJ4a+//mLBggWsX7+ezz77jNjY2NO2vkTS0gjVhlp2HBzF5WLM+z4hl3dsL9+82RdFUZh6dwdGPebykl1xxRUta4yQnPG89dZb4q233qpXX4vFIg4c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ip9G0aLv8ADakLO9apc3OSMEGbjykU2YMIEJEybUe8yPP/5Y776xsbEcOnSo1ut33XUXd911V73nq4nzzjuvRk/eP5m9e/cyduxYulwwgmHjX0SrqygNNeC6e9j43jTGjh1Lz549W6WnTFVV9u/fD8DZZ1e8UZSUlPDee+/x3XffERMTUy8xVBNCCBRF4emnn+bll1/2/LshLFu2DL1ef0pRWFmM9evXj3nz5nk8fC2BW4x17tyZYcOGceDAAZYsWcKGDRtYvHixJ35NCMGTTz7JypUrMRgMnH322RiNRrZv385bb73FmjVrWLBggSclTlP45ptvWL9+PXFxcZx//vkcOXKEzZs3s3XrVj7//HP69esHuE5J33vvvfz++++EhIQwZMgQ8vPzeeONN6qUSauJCy+80FONQwoyibcQjpJyz1grEGMOE7ak108qEj4BbWCiV+3yNmeMIJOcmbz11lv4h0dXE2MAWp2eYeNfJOuA64P2k08+8ZKVtXPkyBFKS0uJi4sjODiYF154gSNHjvDHH39gsVjo0aMHb7/9dhWPTUNYunQpJ06coKysjJ9//pk1a9YwY8YMNJr6hXemp6eTkpJCnz59CAgIqLWf2Wzm3nvvZffu3fj4+DB37twWFWPgOqV69913M3nyZBRFweFw8H//9398/fXXPP/883z88ccAfP7556xcuZKOHTvy8ccfe4SayWRi0qRJ/PTTT0ybNo3Zs2c32ab169fz9NNPM27cOBRFQVVVHnvsMdasWcP8+fM9MYILFy7k999/p2/fvsybN4+gINcH2s8//8xDDz1U5xr+/v706tWLPXv2cOzYMTp27NhkuyWShlAhxlTvizF7AbajryGsruwIriLhj6HxlxkGpCCTVGNXRjGrDuRgdTQt8F6oKp8vXsKA0fdWE2NutDo9CRdfz+eLP6LdjVOaFMTpo9Mwsmck/WOa7w1n3759APTu3ZuioiIWL16MEMJzPSoqqkkHFG644QZ+/vln3nvvPfR6Pa+++mqDnsHWrVsB6N69e6193GJs165dKIqC1Wrlvffe49lnn2203Y2hY8eOPP7445770+l0TJs2jY0bN7J582ZSU1Pp0KEDCxYsAGD69OlVTn0GBAQwa9Yshg0bxrp165pF3PTs2bNKdQ2NRsMdd9zBmjVrOHLkiKfdvTX94osvesQYwNChQ7nl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f/0XX/3qV4f6q1EURdlquoKxOoQWHNQi+i16PTeDveYWvMQnuQNCxxx7Ub9Nwru1Psokc4v29Z5fZa6EmpTOulRuHVZwj6/ivD0Go2k9brQcYWW6TU92PVMahEZClvByrY/GTZb/jg0LjpxSRnAQO/r7k7RcElmXiqiPCSVBon61dljZwkr9++23HwsXLuSuu+7ihRdeKKzlAigrK+PII4/kwgsv7Lft0WAUFxfz0EMPcdddd/H000+zcuVKDMPggAMO4JxzzuHYY48d8pgzZ85kwYIF3Hbbbbz++ussX76cSCTCcccdx8UXX8z06dP7vLdzLdhA05WdQqEQ99xzD//4xz9YsGABy5YtY/ny5ZSXl3PMMcdw3nnnDSrbpiiKsq10z4yFtn0w5iSwVt+ITOWXomi+fJPwGX3fs3nro3jvxWGzLqxOGNRmDCKGJGRIwEfrKT/GaK4ms8dRsNm0YG4nZRo0H2syRbzeYGDl965pSA4cGWDG6NIh17LclOtJmtM2piaYWh5iVFEAXe2gVPKElFIOfNngpFIpOjo6CIVCW1wKQhm8m266Ccg1N1cURRmq7R6M2S1Yq25AZvI73fVQvkl435uaBmp91KndFtR8tITwP/+PljN/hREa+Lso1yA8g0OARW1FLGvrCrqiJhw9uZiKooHrn/Unbbu0ZRzKQj4mlAaJB9UOyi+DoXw/DztDdvPNNzN37txudchCoVC3wquKoijKzm17B2NetgF71fVIa2PugFGUbxLee01L6di4LY14LXWg67nWR70sepcS6rM6za89ReULNwOgvXg7badc3e/z5MpapGlzo7yyMUKz1TX2pCKDwyaX49+CtV25chYOEphYGmJMPIBPVzsolZ6G/a/itttu49hjj+Wcc87hscce67fno6IoirLzKQRjmVqEvh2CsfR6rM9/VQjGhK8c3+Sf9hmMeakOnNrVfbY+6uR0lrRoN0lOOggvv9NS69gITt9dXqS08dw0n6eLWVgbLQRjuoDDx0WZvVvlFgVjluPRkLAI+XRmjIgwsSSogjGlT8POkB188MG8/fbbvPPOOyxevJhrr72W448/ntNOO63PFkGKoijKzkFKicw25hbwGyGEto2DseQKrNW/BzcF5JuET7wi1xNy82dzHdy2jXjNdSBlrvVRH2u3ko5gdcKgIWsQN138peW0H/cDRDZJ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t7/NjBkz+u0H+cknnwD0Wlh1Z9fZy6yzHtnm6urqCgVh+0t1K1889fX1nHPOOXz22Wfous4vf/lLrr766j7XiXzR3yuKsqsbznt0oO+IJUuW4DgOfr+f3Xfffes+MCogUzYxZcoUXNflueeeI5FI9DhfU1PD008/DeSmcnY1xx9/PJAr+rpq1aoe5zt7nR1wwAGMHj16uz6bsuNYlsXFF1/MunXrME2Tm266qdC1oS9f9PeKouzqhvMePeGEEwB49tlne5227PyOOPHEE9UaMmXbOvfcc/H5fNTX13P55ZfT2NhYOLds2TK++93vkkql+MpXvsKxxx67A590eMaPH8/JJ5+M67pcdtllhUKxkKtJM3/+fIABK/4rXyx33nln4S/lX/ziFxxzzDED3vNFf68oyq5uOO/Rgw8+mH333ZeOjg4uueQSNm7cCOSmPu+8804ef/xxTNPstuN6axKycxJVUcj9ZXDVVVeRzWYxTZMJEybgOE4hozRjxgzuuuuuQgHVnc1RRx1FTU0N1113HV//+td7nG9paWHevHmFqampU6fS3t5eWDt2+eWXc9FFF23vx1Z2EMuyOPTQQ2lra8MwjH4r9gMcccQRhX8fu/p7RVG+6IbzHl2/fj1nn302dXV1+Hw+pkyZQkNDA42NjQghuP7667vtyNyaVECm9LBq1Sruvvtu3njjDRoaGggEAkyePJmTTz6Zb37zmzv1IuWBAjKAVCrFXXfdxdNPP8369esxDIMZM2ZwzjnnqGzGl8zHH3/cbw/Lzc2dO5df//rXhf/eld8rivJlMJz3aHNzM3/605946aWXqKurIxgMstdee3H++edz0EEHbbNnVQGZoiiKoijKDqbWkCmKoij/v906FgAAAAAY5G89jD1FETATMgCAmZABAMyEDABgJmQAADMhAwCYCRkAwEzIAABmQgYAMBMyAICZkAEAzIQMAGAmZAAAMyEDAJgFWwhomloOHFkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "summary_stats = all_simulations_KL_df.groupby(['dimension', 'model']).agg({\n",
    "    'kl': ['mean', 'std']\n",
    "}).reset_index()\n",
    "dimensions = np.array([5, 10, 25, 50])\n",
    "\n",
    "lin_means = summary_stats[summary_stats['model'] == 'lin']['kl']['mean'].values\n",
    "lin_stds = summary_stats[summary_stats['model'] == 'lin']['kl']['std'].values\n",
    "\n",
    "cos_means = summary_stats[summary_stats['model'] == 'cos']['kl']['mean'].values\n",
    "cos_stds = summary_stats[summary_stats['model'] == 'cos']['kl']['std'].values\n",
    "\n",
    "a_star_KL_means = summary_stats[summary_stats['model'] == 'a_star_KL']['kl']['mean'].values\n",
    "a_star_KL_stds = summary_stats[summary_stats['model'] == 'a_star_KL']['kl']['std'].values\n",
    "\n",
    "font = {'family' : 'sans-serif', 'size' : 16}\n",
    "plt.rc('font', **font)\n",
    "cmap = cm.get_cmap('tab20c')\n",
    "mpl.rcParams['axes.facecolor'] = 'white'\n",
    "mpl.rcParams['axes.grid'] = False\n",
    "mpl.rcParams['axes.edgecolor'] = 'gray'\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "#linear\n",
    "y1_color = (0.96, 0.78, 0.26)\n",
    "ax.plot(dimensions, lin_means, label='Linear schedule', color=y1_color, linewidth=2, marker='^', markeredgecolor='black', markersize=7)\n",
    "ax.fill_between(dimensions, lin_means - lin_stds, lin_means + lin_stds, color=y1_color, alpha=0.15)\n",
    "\n",
    "# cosine schedule\n",
    "y2_color = cmap(4/20)\n",
    "ax.plot(dimensions, cos_means, label='Cosine schedule', color=y2_color, linewidth=2, linestyle = 'dotted', marker='*', markeredgecolor='black', markersize=7)\n",
    "ax.fill_between(dimensions, cos_means - cos_stds, cos_means + cos_stds, color=y2_color, alpha=0.15)\n",
    "\n",
    "# a optimal\n",
    "y3_color = cmap(1/20)\n",
    "ax.plot(dimensions, a_star_KL_means, label='$\\\\beta_{a^*}$ (KL bound)', color=y3_color, linewidth=2, marker='o', markeredgecolor='black', markersize=7)\n",
    "ax.fill_between(dimensions, a_star_KL_means - a_star_KL_stds, a_star_KL_means + a_star_KL_stds, color=y3_color, alpha=0.3)\n",
    "\n",
    "#ax.set_xlabel('Dimension', fontsize = 18)\n",
    "ax.set_ylabel('KL divergence', fontsize = 18)\n",
    "ax.legend(loc='upper left', fontsize = 16)\n",
    "ax.tick_params(axis='x', labelsize = 18)\n",
    "ax.tick_params(axis='y', labelsize = 18)\n",
    "ax.set_xticks(dimensions)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "#plt.savefig(\"GRAPH_3_6.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9f02f4f8-65e9-42b1-a312-63dabe19c32b",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# CORRELATED W2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "a0b23f33-86dc-4cb3-ab9b-60da95bb2736",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    training_sample = training_distribution.generate_sample(n)\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    training_sample_rescale, mean ,std  = func.normalize(training_sample, rescale)\\n    sample_by_d.append(training_sample_rescale)\\n\\n    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n\\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-4\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-4\\n\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    num_mc = 500\\n\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(training_sample_rescale, batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n    a = 0.\\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\\n\\n    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\\n    for k, a in enumerate(a_values):\\n        print(f\"optimization for a = {a}\")\\n        sde.beta.change_a(a)\\n        score_theta_trained[k] = [ ]\\n        for j in range(rep_size):\\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            optimizer = Adam(network.parameters(), lr=learning_rate)\\n            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\\n            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n            score_theta_trained[k].append(network)\\n            #torch.save(network.state_dict(), f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{k}_{j}_d\\'+str(d)+\\'.pt\\')\\n'"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#### CORRELATED rescale\n",
    "########### SET Training data PARAMETERS #################\n",
    "\n",
    "a_values = np.linspace(8,11,13)\n",
    "a_values = np.insert(a_values, 0, 0) \n",
    "a_values\n",
    "sigma_inv = 1\n",
    "beta_min = 0.1\n",
    "beta_max = 20\n",
    "T = 1\n",
    "\n",
    "dimensions = [5, 10, 25, 50]\n",
    "n = 10000\n",
    "sample_by_d = []\n",
    "'''\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    training_sample = training_distribution.generate_sample(n)\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    training_sample_rescale, mean ,std  = func.normalize(training_sample, rescale)\n",
    "    sample_by_d.append(training_sample_rescale)\n",
    "\n",
    "    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "\n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-4\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-4\n",
    "\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    num_mc = 500\n",
    "\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(training_sample_rescale, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "    a = 0.\n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device = device)\n",
    "\n",
    "    score_theta_trained = [ [] for _ in a_values ]   # a_values, replicates\n",
    "    for k, a in enumerate(a_values):\n",
    "        print(f\"optimization for a = {a}\")\n",
    "        sde.beta.change_a(a)\n",
    "        score_theta_trained[k] = [ ]\n",
    "        for j in range(rep_size):\n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "            loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\n",
    "            diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "            score_theta_trained[k].append(network)\n",
    "            #torch.save(network.state_dict(), f'models/gaussian_covar/d'+str(d)+ '_explicit_rescale_search' + f'/model_{k}_{j}_d'+str(d)+'.pt')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "0506c9a0-13c2-4d2f-9f79-10371b4a6e9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nrep_size = 10\\nnum_steps = 500\\ndimensions = [5,10,25,50]  \\nsimulation_results = []\\na = 0\\n\\nfor d in dimensions:\\n    print(f\"Running simulations for dimension {d}\")\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n    \\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        exp_score = diff.explicit_score(sde, dist)\\n\\n        for j in range(rep_size):  \\n            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n            model_path = f\\'models/gaussian_covar/d{d}_explicit_rescale_search/model_{k}_{j}_d{d}.pt\\'\\n            network.load_state_dict(torch.load(model_path))\\n\\n            _, error_approx_sup_L2 = func.compute_E2(dist, sde, network, exp_score, num_steps, num_mc)\\n\\n            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n\\n                simulation_results.append({\\n                    \"dimension\": d,\\n                    \"a\": a,\\n                    \"replication\": j,\\n                    \"scheme\": scheme_name,\\n                    \"error_approx_sup_L2\": error_approx_sup_L2,\\n                })\\n\\nsimulation_df = pd.DataFrame(simulation_results)\\n\\n\\ndimensions = [5,10,25,50]  \\n\\n\\nerror_results = []\\n\\nfor idx, d in enumerate(dimensions):\\n    print(f\"Running error calculations for dimension {d}\")\\n    \\n    dim_df = simulation_df[simulation_df[\\'dimension\\'] == d]\\n    epsilon = dim_df.groupby(\\'a\\')[\\'error_approx_sup_L2\\'].mean()\\n\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    \\n    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n\\n    training_sample_rescale = sample_by_d[idx]\\n    \\n    beta = func.beta_parametric(a, T, beta_min, beta_max)\\n    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\\n    \\n    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\\n\\n        sde.beta.change_a(a)\\n        w2_error = func.compute_w2_bound(dist, training_sample_rescale, sde, num_steps, epsilon[a]) \\n        error_results.append({\\n            \"dimension\": d,\\n            \"a\": a,\\n            \"w2_error\": w2_error\\n        })\\n\\nerrors_df = pd.DataFrame(error_results)\\n\\n\\n\\nsigma_inv = 1\\ns = 0.021122\\nT = 1\\n\\nn = 10000\\n\\nfor idx, d in enumerate(dimensions):\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    \\n    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\\n    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\\n    dist =  gaussian(d,mean_scale, cov_scale)\\n\\n    training_sample_rescale = sample_by_d[idx]\\n    \\n    if d==5: \\n        n_epochs = 20 \\n        learning_rate = 1.0e-4\\n    \\n    elif d==10: \\n        n_epochs = 30\\n        learning_rate = 1.0e-4  \\n    \\n    elif d==25: \\n        n_epochs = 75\\n        learning_rate = 1.0e-4\\n        \\n    elif d==50: \\n        n_epochs = 150\\n        learning_rate = 1.0e-4\\n\\n    # network_parameters\\n    mid_features = 256\\n    num_layers = 3\\n    batch_size = 64\\n\\n    # Monte Carlo estimate samples (for E2 computation in the KL bound)\\n    num_mc = 500\\n\\n    # number of runs (for replication)\\n    rep_size = 10\\n\\n    # load data\\n    dataloader = DataLoader(sample_by_d[idx] , batch_size=batch_size, shuffle=True)\\n\\n    # number of discretisation steps\\n    num_step = 500\\n\\n    beta_cosine = func.beta_cosine(T, s)\\n    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\\n\\n    score_theta_trained_cosine = [ ]   # a_values, replicates\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\\n        optimizer = Adam(network.parameters(), lr=learning_rate)\\n        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\\n        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\\n        score_theta_trained_cosine.append(network)\\n        torch.save(network.state_dict(), f\\'models/gaussian_covar/d\\'+str(d)+\\'_explicit_rescale_search\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\')\\n\\n\\n\\n##linear simulation\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nsimulation_results_lin = []\\n\\n#### LINEAR\\n\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n    \\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    \\n    mean = torch.ones(d)\\n    std = torch.ones(d)\\n    \\n    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\\n    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\\n    \\n    init = sde_lin.final.generate_sample(sample_batch_size)\\n    score_theta_trained_lin = []\\n\\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{np.where(a_values == 0)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_lin.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_lin):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_lin.append({\\n                \"dimension\": d,\\n                \"model\": \"lin\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_lin_df = pd.DataFrame(simulation_results_lin)\\n\\n#### Cosine\\n\\ndimensions = [5,10,25,50]\\n\\nsimulation_results_cos = []\\nfor d in dimensions:   \\n    \\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    \\n    mean = torch.ones(d)\\n    std = torch.ones(d)\\n    \\n    beta_cos = func.beta_cosine(T, s)\\n    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \\n    init = sde_cos.final.generate_sample(sample_batch_size)\\n    score_theta_trained_cos = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_cosine_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_cos.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_cos):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_cos.append({\\n                \"dimension\": d,\\n                \"model\": \\'cos\\',\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_cos_df = pd.DataFrame(simulation_results_cos)\\n\\n#### a* W2\\n\\nsample_batch_size = 10000 # size of the sample generated\\nnum_steps = 500\\nsimulation_results_a_star_W2 = []\\nmin_a_W2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\\n\\n\\nfor d in dimensions:\\n    mu = torch.ones(d, device = device)\\n    SIGMA = torch.eye(d, device=device)\\n    for i in range(d):\\n        for j in range(d):\\n            if i != j:\\n                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\\n\\n    training_distribution = func.gaussian(d, mu, SIGMA)\\n    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\\n    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\\n    rescale = np.sqrt(2*lambda_max) \\n    \\n    mean = torch.ones(d)\\n    std = torch.ones(d)\\n    \\n    a_star = min_a_W2_dict[d]\\n    \\n    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\\n    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\\n    init = sde_a_star.final.generate_sample(sample_batch_size)\\n    score_theta_trained_a_star = []\\n    \\n    for j in range(rep_size):\\n        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \\n        network.load_state_dict(torch.load(f\\'models/gaussian_covar/d\\'+str(d)+ \\'_explicit_rescale_search\\' + f\\'/model_{np.where(a_values == a_star)[0][0]}_{j}_d\\'+str(d)+\\'.pt\\'))\\n        score_theta_trained_a_star.append(network)\\n\\n    for j, score_theta in enumerate(score_theta_trained_a_star):\\n        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\\n            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\\n            sample = func.unnormalize(sample, mean, std,rescale)\\n            w2_value = w2(training_distribution, empirical(sample))\\n            simulation_results_a_star_W2.append({\\n                \"dimension\": d,\\n                \"model\": \"a_star_W2\" ,\\n                \"replication\": j,\\n                \"scheme\": scheme_name,\\n                \"w2\": w2_value,\\n                })\\n\\nsimulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\\n\\nall_simulations_W2_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_W2_df])\\n\\n'"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "rep_size = 10\n",
    "num_steps = 500\n",
    "dimensions = [5,10,25,50]  \n",
    "simulation_results = []\n",
    "a = 0\n",
    "\n",
    "for d in dimensions:\n",
    "    print(f\"Running simulations for dimension {d}\")\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "    \n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        exp_score = diff.explicit_score(sde, dist)\n",
    "\n",
    "        for j in range(rep_size):  \n",
    "            network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "            model_path = f'models/gaussian_covar/d{d}_explicit_rescale_search/model_{k}_{j}_d{d}.pt'\n",
    "            network.load_state_dict(torch.load(model_path))\n",
    "\n",
    "            _, error_approx_sup_L2 = func.compute_E2(dist, sde, network, exp_score, num_steps, num_mc)\n",
    "\n",
    "            for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "\n",
    "                simulation_results.append({\n",
    "                    \"dimension\": d,\n",
    "                    \"a\": a,\n",
    "                    \"replication\": j,\n",
    "                    \"scheme\": scheme_name,\n",
    "                    \"error_approx_sup_L2\": error_approx_sup_L2,\n",
    "                })\n",
    "\n",
    "simulation_df = pd.DataFrame(simulation_results)\n",
    "\n",
    "\n",
    "dimensions = [5,10,25,50]  \n",
    "\n",
    "\n",
    "error_results = []\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    print(f\"Running error calculations for dimension {d}\")\n",
    "    \n",
    "    dim_df = simulation_df[simulation_df['dimension'] == d]\n",
    "    epsilon = dim_df.groupby('a')['error_approx_sup_L2'].mean()\n",
    "\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    \n",
    "    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "\n",
    "    training_sample_rescale = sample_by_d[idx]\n",
    "    \n",
    "    beta = func.beta_parametric(a, T, beta_min, beta_max)\n",
    "    sde = diff.forward_VPSDE(d, beta, sigma_inv, T, device=device)\n",
    "    \n",
    "    for k, a in tqdm(enumerate(a_values), desc=f\"Errors for dimension {d}\"):\n",
    "\n",
    "        sde.beta.change_a(a)\n",
    "        w2_error = func.compute_w2_bound(dist, training_sample_rescale, sde, num_steps, epsilon[a]) \n",
    "        error_results.append({\n",
    "            \"dimension\": d,\n",
    "            \"a\": a,\n",
    "            \"w2_error\": w2_error\n",
    "        })\n",
    "\n",
    "errors_df = pd.DataFrame(error_results)\n",
    "\n",
    "\n",
    "\n",
    "sigma_inv = 1\n",
    "s = 0.021122\n",
    "T = 1\n",
    "\n",
    "n = 10000\n",
    "\n",
    "for idx, d in enumerate(dimensions):\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    \n",
    "    cov_scale = SIGMA/rescale**2 #func.compute_cov_matrix(training_sample_rescale)\n",
    "    mean_scale = torch.zeros(d) #torch.mean(training_sample_rescale, dim=0)\n",
    "    dist =  gaussian(d,mean_scale, cov_scale)\n",
    "\n",
    "    training_sample_rescale = sample_by_d[idx]\n",
    "    \n",
    "    if d==5: \n",
    "        n_epochs = 20 \n",
    "        learning_rate = 1.0e-4\n",
    "    \n",
    "    elif d==10: \n",
    "        n_epochs = 30\n",
    "        learning_rate = 1.0e-4  \n",
    "    \n",
    "    elif d==25: \n",
    "        n_epochs = 75\n",
    "        learning_rate = 1.0e-4\n",
    "        \n",
    "    elif d==50: \n",
    "        n_epochs = 150\n",
    "        learning_rate = 1.0e-4\n",
    "\n",
    "    # network_parameters\n",
    "    mid_features = 256\n",
    "    num_layers = 3\n",
    "    batch_size = 64\n",
    "\n",
    "    # Monte Carlo estimate samples (for E2 computation in the KL bound)\n",
    "    num_mc = 500\n",
    "\n",
    "    # number of runs (for replication)\n",
    "    rep_size = 10\n",
    "\n",
    "    # load data\n",
    "    dataloader = DataLoader(sample_by_d[idx] , batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # number of discretisation steps\n",
    "    num_step = 500\n",
    "\n",
    "    beta_cosine = func.beta_cosine(T, s)\n",
    "    sde = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)\n",
    "\n",
    "    score_theta_trained_cosine = [ ]   # a_values, replicates\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde.d, mid_features, num_layers).to(device)\n",
    "        optimizer = Adam(network.parameters(), lr=learning_rate)\n",
    "        loss = diff.loss_explicit(network, sde, diff.explicit_score(sde, dist)) # to choose in the Gaussian case for training with the analytical score function\n",
    "        diff.train(loss, dataloader, n_epochs=n_epochs, optimizer=optimizer)\n",
    "        score_theta_trained_cosine.append(network)\n",
    "        torch.save(network.state_dict(), f'models/gaussian_covar/d'+str(d)+'_explicit_rescale_search' + f'/model_cosine_d'+str(d)+'.pt')\n",
    "\n",
    "\n",
    "\n",
    "##linear simulation\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "simulation_results_lin = []\n",
    "\n",
    "#### LINEAR\n",
    "\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "    \n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    \n",
    "    mean = torch.ones(d)\n",
    "    std = torch.ones(d)\n",
    "    \n",
    "    beta_lin = func.beta_parametric(0., T, beta_min, beta_max)\n",
    "    sde_lin = diff.forward_VPSDE(d, beta_lin, sigma_inv, T, device = device)\n",
    "    \n",
    "    init = sde_lin.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_lin = []\n",
    "\n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_lin.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit_rescale_search' + f'/model_{np.where(a_values == 0)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_lin.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_lin):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_lin, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_lin.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"lin\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_lin_df = pd.DataFrame(simulation_results_lin)\n",
    "\n",
    "#### Cosine\n",
    "\n",
    "dimensions = [5,10,25,50]\n",
    "\n",
    "simulation_results_cos = []\n",
    "for d in dimensions:   \n",
    "    \n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    \n",
    "    mean = torch.ones(d)\n",
    "    std = torch.ones(d)\n",
    "    \n",
    "    beta_cos = func.beta_cosine(T, s)\n",
    "    sde_cos = diff.forward_VPSDE(d, beta_cosine, sigma_inv, T, device = device)    \n",
    "    init = sde_cos.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_cos = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_cos.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit_rescale_search' + f'/model_cosine_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_cos.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_cos):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_cos, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_cos.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": 'cos',\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_cos_df = pd.DataFrame(simulation_results_cos)\n",
    "\n",
    "#### a* W2\n",
    "\n",
    "sample_batch_size = 10000 # size of the sample generated\n",
    "num_steps = 500\n",
    "simulation_results_a_star_W2 = []\n",
    "min_a_W2_dict = pd.Series(min_w2_bounds_df.min_a.values, index=min_w2_bounds_df.dimension).to_dict()\n",
    "\n",
    "\n",
    "for d in dimensions:\n",
    "    mu = torch.ones(d, device = device)\n",
    "    SIGMA = torch.eye(d, device=device)\n",
    "    for i in range(d):\n",
    "        for j in range(d):\n",
    "            if i != j:\n",
    "                SIGMA[i, j] = 1 / np.sqrt(np.abs(j-i)+1)\n",
    "\n",
    "    training_distribution = func.gaussian(d, mu, SIGMA)\n",
    "    eigenvalues_SIGMA = torch.linalg.eigvals(SIGMA)\n",
    "    lambda_max = torch.max(torch.abs(eigenvalues_SIGMA))\n",
    "    rescale = np.sqrt(2*lambda_max) \n",
    "    \n",
    "    mean = torch.ones(d)\n",
    "    std = torch.ones(d)\n",
    "    \n",
    "    a_star = min_a_W2_dict[d]\n",
    "    \n",
    "    beta_a_star = func.beta_parametric(a_star, T, beta_min, beta_max)\n",
    "    sde_a_star = diff.forward_VPSDE(d, beta_a_star, sigma_inv, T, device = device)\n",
    "    init = sde_a_star.final.generate_sample(sample_batch_size)\n",
    "    score_theta_trained_a_star = []\n",
    "    \n",
    "    for j in range(rep_size):\n",
    "        network = decoder.Decoder(sde_a_star.d, mid_features, num_layers) \n",
    "        network.load_state_dict(torch.load(f'models/gaussian_covar/d'+str(d)+ '_explicit_rescale_search' + f'/model_{np.where(a_values == a_star)[0][0]}_{j}_d'+str(d)+'.pt'))\n",
    "        score_theta_trained_a_star.append(network)\n",
    "\n",
    "    for j, score_theta in enumerate(score_theta_trained_a_star):\n",
    "        for scheme_name, scheme_sampler in [(\"euler\", sp.Euler_Maruyama_discr_sampler)]:#, (\"semii\", sp.EI_discr_sampler)]:\n",
    "            sample = scheme_sampler(init, sde_a_star, score_theta, num_steps)\n",
    "            sample = func.unnormalize(sample, mean, std,rescale)\n",
    "            w2_value = w2(training_distribution, empirical(sample))\n",
    "            simulation_results_a_star_W2.append({\n",
    "                \"dimension\": d,\n",
    "                \"model\": \"a_star_W2\" ,\n",
    "                \"replication\": j,\n",
    "                \"scheme\": scheme_name,\n",
    "                \"w2\": w2_value,\n",
    "                })\n",
    "\n",
    "simulation_a_star_W2_df = pd.DataFrame(simulation_results_a_star_W2)\n",
    "\n",
    "all_simulations_W2_df = pd.concat([simulation_lin_df, simulation_cos_df, simulation_a_star_W2_df])\n",
    "\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "adf65282-0e23-4775-8ea1-bc767fe4e672",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_rescale_pkl', 'simulation_df.pkl')\n",
    "#simulation_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_rescale_pkl/simulation_df.pkl'\n",
    "simulation_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "eef33dc8-ddd1-4fe2-8e48-0325c2f777df",
   "metadata": {},
   "outputs": [],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_rescale_pkl', 'errors_df.pkl')\n",
    "#errors_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_rescale_pkl/errors_df.pkl'\n",
    "errors_df = pd.read_pickle(file_path_load)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "63d1b33f-85db-4081-be3b-694db255aea3",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_df = pd.merge(simulation_df, errors_df, on=[\"dimension\", \"a\"], how=\"left\")\n",
    "dimensions = [5,10,25, 50]\n",
    "\n",
    "dimensional_bounds = []\n",
    "\n",
    "for d in dimensions:\n",
    "    dim_df = results_df[results_df['dimension'] == d]\n",
    "    W2_upperbound = dim_df.groupby('a')['w2_error'].mean()\n",
    "    bound_df = pd.DataFrame({\n",
    "        'dimension': d,\n",
    "        'a': W2_upperbound.index,  \n",
    "        'W2_upperbound': W2_upperbound\n",
    "    })\n",
    "    \n",
    "    dimensional_bounds.append(bound_df)\n",
    "all_bounds_df = pd.concat(dimensional_bounds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "1fbb4cd9-b7ac-4ee9-be30-c50a21922be9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   dimension  min_a  min_W2_upperbound\n",
      "0          5   8.00          28.112476\n",
      "1         10   8.75         105.966260\n",
      "2         25  10.50         535.688037\n",
      "3         50  11.00        1734.125195\n"
     ]
    }
   ],
   "source": [
    "min_w2_bounds = []\n",
    "for bound_df in dimensional_bounds:\n",
    "    d = bound_df['dimension'].iloc[0]\n",
    "    min_w2 = bound_df['W2_upperbound'].min()\n",
    "    min_a = bound_df.loc[bound_df['W2_upperbound'] == min_w2, 'a'].values[0]\n",
    "    min_w2_bounds.append({'dimension': d, 'min_a': min_a, 'min_W2_upperbound': min_w2})\n",
    "min_w2_bounds_df = pd.DataFrame(min_w2_bounds)\n",
    "print(min_w2_bounds_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "3a7984df-9afb-47e7-a7dd-37ace389b421",
   "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",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dimension</th>\n",
       "      <th>model</th>\n",
       "      <th colspan=\"2\" halign=\"left\">w2</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>5</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.066548</td>\n",
       "      <td>0.013873</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>5</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.048276</td>\n",
       "      <td>0.008605</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>5</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.072068</td>\n",
       "      <td>0.019861</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.107291</td>\n",
       "      <td>0.028454</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.112898</td>\n",
       "      <td>0.011284</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>10</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.138240</td>\n",
       "      <td>0.031119</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>25</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.261075</td>\n",
       "      <td>0.029533</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>25</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.391753</td>\n",
       "      <td>0.030112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>25</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.302986</td>\n",
       "      <td>0.045539</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>50</td>\n",
       "      <td>a_star_W2</td>\n",
       "      <td>0.676151</td>\n",
       "      <td>0.123277</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>50</td>\n",
       "      <td>cos</td>\n",
       "      <td>0.765524</td>\n",
       "      <td>0.022376</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>50</td>\n",
       "      <td>lin</td>\n",
       "      <td>0.897584</td>\n",
       "      <td>0.079860</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dimension      model        w2          \n",
       "                             mean       std\n",
       "0          5  a_star_W2  0.066548  0.013873\n",
       "1          5        cos  0.048276  0.008605\n",
       "2          5        lin  0.072068  0.019861\n",
       "3         10  a_star_W2  0.107291  0.028454\n",
       "4         10        cos  0.112898  0.011284\n",
       "5         10        lin  0.138240  0.031119\n",
       "6         25  a_star_W2  0.261075  0.029533\n",
       "7         25        cos  0.391753  0.030112\n",
       "8         25        lin  0.302986  0.045539\n",
       "9         50  a_star_W2  0.676151  0.123277\n",
       "10        50        cos  0.765524  0.022376\n",
       "11        50        lin  0.897584  0.079860"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#save\n",
    "#file_path = os.path.join('models/gaussian_covar/dimension_search_rescale_pkl', 'all_simulations_W2_df.pkl')\n",
    "#all_simulations_W2_df.to_pickle(file_path)\n",
    "\n",
    "#load \n",
    "file_path_load = 'models/gaussian_covar/dimension_search_rescale_pkl/all_simulations_W2_df.pkl'\n",
    "all_simulations_W2_df = pd.read_pickle(file_path_load)\n",
    "\n",
    "summary_stats = all_simulations_W2_df.groupby(['dimension', 'model']).agg({\n",
    "    'w2': ['mean', 'std']\n",
    "}).reset_index()\n",
    "summary_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "0017ceb3-5f77-46d7-b346-2c5bc76d840c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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46KLLmLevHnoul7pXrqus3DhQq688koGDRrEoEGDuPrqq/n888+rfL/cbjfvvPMO11xzDUOHDqVPnz6ccsopTJ48mdWrV1e6PjExkUsvvZT169dz/vnn069fP84991z27dtX4zNu2bKF2267jbPOOou+ffty2mmnceedd1ZbEuzPP//kvvvuY+TIkQwYMIDzzz+f5557jvz8/Cqvz8zMZNq0aQwfPpz+/ftz0UUX8e6771b5zHV9j4QQfPzxx1x22WUMHDiQESNGMH36dNxud6Vrj7aura7rxZYsWcK4ceM48cQTGTBgAJdeeinz58+XmfUl6R9EGD5/MObNRbE4UNSWOVsipyylwOjYlzMGoCgK0yZ1Ysw9/lGy8847r7m716iys7MZO3YsLpeLgQMH4vF42LBhA8899xxpaWk8+uijgWs1TeP2229nxYoVOBwOBg8ejNlsZv369fznP/9h/fr1PPvss4HrPR4P119/PX/88QexsbEMHjwYRVHYtWsXv/zyC6tWrWL27NmMGjWqQp9yc3O55ZZbaN++Paeddhqpqal07ty52mdYu3YtN954I7quM3jwYPr27cuBAwdYunQpP/30E2+++SbDhw8PXP/NN9/w0EMP4fP56Nu3LwMGDGD79u3MmzeP5cuX88knnxAeHh64vqSkhLFjx+J0OjnppJMoKSlh48aN/O9//yMjI4MHH3zwmN8j8CdtXrx4MXa7nVNPPTUQxK5YsaLuX9A6eOyxx1i4cCFBQUH0798fh8PBpk2beOaZZ/jll194/fXXsVpb3l/RkiTVnjC8GO6DoBWhWMJRlBawnbIaMiA7zh0+Ojbq5CgARp0cFRglO/fcc/8xa8mqsm3bNoYOHcrMmTOJivI///Lly7nlllv4+OOPueuuuwgLCwNgzpw5rFixglNOOYUZM2YErs/JyWHy5Ml88cUXnHjiiVx55ZUAfPTRR/zxxx+cffbZzJw5M7CGTdd1nnrqKT766CM+/PDDSgFZdnY2Z555JnPmzEFRFAzDqPFrMGfOHHw+H2+//TannXZa4Pj8+fN55plneP311wMBWXp6Oo8+6h/9nD17Nueccw7gD6QefPBBvvnmG2bNmsUjjzwSuE9paSk9e/bk9ddfJyIiAvAHdVOnTuWjjz7i7rvvxmazHdN7tHTpUhYvXkynTp14//33adu2LQDbt2/n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668H/JUBGkqHDh1o3749mZmZ7NxZeUTS5XJxySWXcN111x21jmNd+l6+FuyXX36p8l4zZszgvvvuO6apYqvVysCBAzEMg1WrVlU6L4Rg3LhxXHPNNWzbtg2AU089FYBly5ZVun7//v0kJydXOl4+mltVH2u7CL/8675yZdU7iqdOncoVV1zBTz/9VKv7SdI/1aEi4Zko5pCmC8acSXj/fupQMGaOwNr9P606GAMZkB3X3G4323fsZF2OjqVtFzZs3MRLL73Eho2bMLXpwvocne07/sLtdjd3Vyt54oknCA4OZs6cOTz77LMUFhZWOH/gwAFuvvlmUlJS6NSpEzfddFPg3IQJEwB45JFHAqNhAKWlpdx///2UlJRw5plnBnZDxsbGUlBQwPPPP19hV6Pb7Q4EC0fm5qqv8j4+8MADpKSkBI57vV6eeOIJdu3aFUiqWpO69P2UU06hW7du/PXXX8yePbvC9O5HH33E1q1b6dmzJyeccMIxPVN5pYT/+7//q7AZwTAMXn75ZdavX09qampgKvCyyy4jPDycRYsWsXTp0sD1JSUl/Oc//6ly+rn8te+9916F8/Pnz2f79u216ue4ceMwmUzMnDmT3377rcK5BQsW8M0337Bnz55jTrsiSf8EgWDMk11WJPzoo94NQS/agnfvs6D5NwwptvbYejyCGtz6R7PllOVxzOVyMah/X/oOHMzs2bMDowu9e/dm/cbfuf3229mxbQtut7vWi9abSrdu3Xj33Xe56aabeOedd1iwYAH9+vUjJiaGjIwMtm3bhq7rdO/enTfeeKNCxvhx48axefNmvvvuOy688EKGDh1KcHAwGzduJD8/n8TERJ5++unA9bfeeisrVqzg+++/Z9OmTfTt6/8rbNu2beTm5jJkyBAuvfTSBn2+8ePHs3XrVpYsWcLo0aPp168fERERbNu2jaysLKKjo3nppZeOep+69F1VVV566SUmTpzIrFmz+Oabb+jZsycpKSn89ddfhISEMGPGjGN+plGjRnHDDTcwb948rrzySvr06UNcXBw7d+7kwIEDBAcH88orrwSmM6Ojo3nmmWe4++67ufPOOxk0aBBxcXGsX78eIQQJCQns27ev0vv2/fffs3TpUs4//3wSExPZs2cPycnJXHrppSxevPio/ezbty/Tpk3jqaeeYuLEifTu3ZsOHTqQnJzMnj17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N9006HsuXryYk08+mX/+859ks1l23HFHisUid999NyeffDJPP/30MPwkQgghhBCeEReQXX311SxYsICdd96ZRx55hP/85z888cQT/PjHP8bn8zF37lyeffbZAd/PcRy++MUv0trayic+8QnmzZvHv/71L55++mk+97nPUSgU+OpXv0oymRzGn0oIIYQQ27MRFZA1NDRwzz33YFkW1113HWPGjCkfO+mkkzj//PMBmDt37oDvec8997Bs2TLGjh3LNddcU24VEQgEuPLKK9lnn31oa2vjD3/4w5D+LEIIIYQQnUZUQHb33Xfjui577LEH06ZN63b8jDPOAOCVV15h1apVA7rnf/7zHwBOPPFEAoFAl2NKKT796U8DcP/992/OqwshhBBC9GpEBWSvvfYaAHvvvXePx+vr6xk3bhwA8+fP7/d+Wmtef/31Pu+51157AbB8+XJWr1492FcWQgghhOjXiArIli1bBsDEiRN7PaczIFu6dGm/91u7dm15xFBv9xwzZgy2bQ/4nkIIIYQQgzWiArLm5mYAqqurez0nHo8DDKgIv/N+fd3Ttm0qKioGfE8hhBBCiMEaUQFZ52rWxrVeGwoGg13OHcj9Nryur3vmcrkBvacQQgghxGCMqICsM3U4EEqpfs8Z7IihgdxTCCGEEGKwRlSn/kgkQiqVolgs9npOoVAAKLev6O9+G17X2yrZYO7Zk/b2dowx3HjjjZt0vRBCCCFGnra2tgEv5oyoFbJEIgH0XcvVeaympmbA9wNobW3t8RzHcWhvbx/wPXvi8/lk4LcQQgixnbEsC59vYGtfI2qFbOrUqSxdupSVK1f2ek7nscmTJ/d7v/r6eioqKmhvb2flypU97rRcvXo1rusO+J49ufzyyzfpOiGEEEJsH0bUss3uu+8OrO9HtrE1a9aUG8LuueeeA7rnbrvtBsCrr77a4/HOz8eNG0d9ff1gXlcIIYQQYkBGVEB2zDHHAF7T18WLF3c7fvvttwMwa9Ysxo8fP6B7HnvssQD8+9//7rE27e9//zsAJ5988ia9sxBCCCFEf0ZUQDZ58mROOOEEXNdlzpw55Uax4I1VuvXWWwG48MILu13b0NDAokWLWLduXZfPTzzxRCZOnMjy5cv5+te/TjqdBqBYLHLNNdfw8ssvU1FRwec+97lh/MmEEEIIsT1TxhizpV9iMJLJJGeddRYLFy7Etm1mzJhBW1tbuXbs0ksv5Ytf/GK36z72sY+xcuVKTj75ZK699toux15//XW+8IUv0N7eTiQSYerUqaxYsYLW1lb8fj+33nor+++//4fy8wkhhBBi+zOiVsjA2xl5xx13cMkllzB58mQWLVpEMplk1qxZzJ07t8dgrD+77bYbd999N5/61KeorKzkvffeQynF0UcfzT/+8Q8JxoQQQggxrEbcCpkQQgghxLZmxK2QCSGEEEJsayQgE0IIIYTYwiQgE0IIIYTYwiQgE0IIIYTYwiQgE0IIIYTYwiQgE0IIIYTYwkbUcHHh6Wxy25cXX3yRysrKD+mNNs3f//53vvvd73LNNddw6qmn9nhOLpfj1ltv5f7772fFihVEo1FmzpzJWWedxezZsz/kNxYjxZo1a/jd737H008/XZ5vO378eA499FC+8IUvUFNT0+2abeV7JYTwbMp3OplMcsstt/DYY4+xdu1aKisr2WuvvTjvvPPYY489hvV9JSAbYTqnEti2XR623hPbtj/Etxq8119/nZ/85Cd9npPNZjn77LNZsGABfr+f6dOn09rayrx585g3bx5z5szhkksu+ZDeWIwUL730EhdeeCFtbW3Yts3EiRPRWrNkyRI++OCD8pi1nXbaqXzNtvK9EkJ4NuU73dTUxBlnnEFDQwPhcJgZM2awdu1aHnnkER5//HGuvvpqPvWpTw3bO0tANsK89957AEyaNKk8TH2keeGFF5gzZw6ZTKbP866++moWLFjAzjvvzC233MKYMWMAuOuuu/j2t7/N3Llz2WuvvTjwwAM/jNcWI0BbWxtz5syhra2NQw45hB/+8IeMGjUKgOXLl/ONb3yDV155hYsvvpj//ve/BINBYNv4Xgkh1tuU7/Sll15KQ0MDBx10EDfccANVVVVorbn11lv52c9+xve+9z323HNPdthhh2F5Z6khG2HeffddAGbMmLGF32TwCoUCc+fO5ZxzziGVSvV5bkNDA/fccw+WZXHdddeVgzGAk046ifPPPx+AuXPnDus7i5Hl3//+Ny0tLYwaNYqf//zn5WAMYMKECdx8881UVVWxYsUKHnzwwfKxkfy9EkJ0N9jv9AsvvMD8+fOJRCJcd911VFVVAWBZFhdccAEnnngipVKJW265ZdjeWQKyEabzL9n06dO38JsMzrJlyzj66KO56aabAPjKV77CuHHjej3/7rvvxnVd9thjD6ZNm9bt+BlnnAHAK6+8Uq4REuKFF14A4LDDDiMWi3U7Xl1dzZ577gnAG2+8Uf58pH6vhBA9G+x3+j//+Q8Ahx9+ONXV1d2On3766QA89thj5PP5IXrLriQgG2E6/5LtuOOOW/hNBmfNmjWsXr2aPfbYgzvvvJMLL7ywz/Nfe+01APbee+8ej9fX15cDuvnz5w/pu4qR68ILL+THP/4xp5xySq/ndI7v1VqXPxup3yshRM8G+51+9dVXgd5/5+y22274fD6y2Sxvvvnm0LzkRqSGbARxXZf3338fgFGjRvGHP/yBl156ifb2durr6zn00EM55phjsKytL84ePXo0v/nNbwa8M3LZsmUATJw4sddzxo0bx8qVK1m6dOlQvKLYBuy2227stttuvR5vaWkpB/CdK68j+XslhOhusN9prTUrVqwAev+d4/f7qa+vZ+XKlSxZsoR99tlnyN9bArIRZOnSpRQKBQDOOeecbkXxd999N7///e+5+eabu9TObA0mTZrEpEmTBnx+c3MzQI9Lx53i8TjgbVMWYiB+8IMfkMvlCIfDHH300cDI/l4JIbob7Hc6lUrhOA7Q/++clStXDtvvHPlPvhGkcwkW4CMf+Qh//etfee2113jhhRf46U9/Sl1dHa+//joXXHABxWJxC77p5uvM0QcCgV7P6dwhN1z5fLFt+eUvf8l9990HwEUXXVTuRbY9fa+E2B4M9ju94e+QLfk7R1bIRpCxY8dy5plnYlkWl19+eXm5NRwOc+KJJ/KRj3yEk08+mXfeeYd//vOffOYzn9nCb7zpbNvuUuPTF6XUML+NGOluuumm8o7cww8/vLxLF7av75UQ24PBfqcPP/zwQd1/uH7nSEA2guy5557lHWI9mTJlCh//+Me58847efTRR0f0L45IJEIqlepzRaJzSToUCn1YryVGGMdxuPrqq7njjjsAOPjgg7nhhhu6/IO6PX2vhNgeDPY7feKJJ5aPbcnfOZKy3MbsvPPOAOUCxZEqkUgAfdeHdR7raQyOEOl0mgsuuKAcjB133HHccsst5bTDYGwr3yshhGfD73QkEimnKltbW3u9Zrh/50hANsJorfuM4Du39Pt8I3vxc+rUqQB9ziHrPDZ58uQP45XECLJmzRrOOOMMnnnmGQDOPfdcrr/++l7rQ7aX75UQ24vBfKcty2LKlClA7//RVSqVWLduHTB8v3MkIBtBPvvZzzJz5sw+Z0C+9dZbAD02Ux1JOmePdfYj29iaNWvKDWH7WpoW25+1a9dy5plnsnDhQmzb5nvf+x7f+MY3eq372J6+V0JsDzblO93f75zXX38dx3EIBoPssssuQ/vCHSQgG0GmT5+O67o8/PDDpNPpbsdXrlzJAw88AHjpmZHsmGOOAbymr4sXL+52vHM22axZsxg/fvyH+m5i61UsFrnwwgtpaGjA7/dz4403lqc69GZ7+l4JsT3YlO/0scceC8BDDz3UY9qy83fOcccdJzVkAs4++2wCgQBr167l0ksvpbGxsXzs3Xff5dxzzyWbzbLvvvty1FFHbcE33XyTJ0/mhBNOwHVd5syZU24UC14PmVtvvRWg347/Yvvy29/+tvxfvt/97nc58sgj+71me/peCbE92JTv9AEHHMBee+1Fe3s7F198MU1NTYCX+vztb3/Lvffei9/v77JDe6gp05lIFSPCQw89xGWXXUahUMDv9zNlyhQcxymvIs2cOZPbbrut3DR1a/axj32MlStXcs0113Dqqad2O55MJjnrrLPKqacZM2bQ1tZWrh279NJL+eIXv/hhv7bYShWLRQ4++GBSqRQ+n6/Pjv0As2fPLv/92Za+V0KITftOL1++nM997nOsWbOGQCDA9OnTWbduHY2NjSil+MlPftJlR+ZQk4BsBFq8eDG///3veeaZZ1i3bh2hUIhp06ZxwgkncPrpp4+YwuP+AjKAbDbLbbfdxgMPPMDy5cvx+XzMnDmTM888U1YrRBdvvvlmnzMsN3byySdz7bXXlv/3tvK9EkJ4NuU73dLSwq9+9Ssef/xx1qxZQzgcZvfdd+e8885j//33H9b3lYBMCCGEEGILkxoyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogtTAIyIYQQQogt7P8DPjs4fFXngLwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dimensions = np.array([5, 10, 25, 50])\n",
    "\n",
    "lin_means = summary_stats[summary_stats['model'] == 'lin']['w2']['mean'].values\n",
    "lin_stds = summary_stats[summary_stats['model'] == 'lin']['w2']['std'].values\n",
    "\n",
    "# Accessing multi-level columns for Cosine\n",
    "cos_means = summary_stats[summary_stats['model'] == 'cos']['w2']['mean'].values\n",
    "cos_stds = summary_stats[summary_stats['model'] == 'cos']['w2']['std'].values\n",
    "\n",
    "# Accessing multi-level columns for a_star_W2\n",
    "a_star_W2_means = summary_stats[summary_stats['model'] == 'a_star_W2']['w2']['mean'].values\n",
    "a_star_W2_stds = summary_stats[summary_stats['model'] == 'a_star_W2']['w2']['std'].values\n",
    "\n",
    "# Plot configuration\n",
    "font = {'family' : 'sans-serif', 'size' : 16}\n",
    "plt.rc('font', **font)\n",
    "cmap = cm.get_cmap('tab20c')\n",
    "mpl.rcParams['axes.facecolor'] = 'white'\n",
    "mpl.rcParams['axes.grid'] = False\n",
    "mpl.rcParams['axes.edgecolor'] = 'gray'\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "#linear\n",
    "y1_color = (0.96, 0.78, 0.26)\n",
    "ax.plot(dimensions, lin_means, label='Linear schedule', color=y1_color, linewidth=2, marker='^', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, lin_means - lin_stds, lin_means + lin_stds, color=y1_color, alpha=0.15)\n",
    "\n",
    "# Plot for Cosine schedule\n",
    "y2_color = cmap(4/20)\n",
    "ax.plot(dimensions, cos_means, label='Cosine schedule', color=y2_color, linewidth=2, linestyle = 'dotted', marker='*', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, cos_means - cos_stds, cos_means + cos_stds, color=y2_color, alpha=0.15)\n",
    "\n",
    "y3_color = cmap(1/20)\n",
    "ax.plot(dimensions, a_star_W2_means, label='$\\\\beta_{a^*}$ (W2 bound)', color=y3_color, linewidth=2, marker='o', markeredgecolor='black', markersize=10)\n",
    "ax.fill_between(dimensions, a_star_W2_means - a_star_W2_stds, a_star_W2_means + a_star_W2_stds, color=y3_color, alpha=0.3)\n",
    "\n",
    "#ax.set_xlabel('Dimension', fontsize = 18)\n",
    "ax.set_ylabel(r'$\\mathcal{W}_2$ distance', fontsize = 18)\n",
    "ax.legend(loc='upper left', fontsize = 16)\n",
    "ax.tick_params(axis='x', labelsize = 18)\n",
    "ax.tick_params(axis='y', labelsize = 18)\n",
    "ax.set_xticks(dimensions)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
