{
	"cells": [
		{
			"cell_type": "code",
			"execution_count": 11,
			"metadata": {
				"colab": {
					"base_uri": "https://localhost:8080/"
				},
				"executionInfo": {
					"elapsed": 124939,
					"status": "ok",
					"timestamp": 1673856780101,
					"user": {
						"displayName": "M Petersen",
						"userId": "13637530209006951077"
					},
					"user_tz": -60
				},
				"id": "azin34LbflEi",
				"outputId": "8c88e0bf-67cd-4a23-c02d-4c4387ced40c"
			},
			"outputs": [],
			"source": [
				"import numpy as np\n",
				"import torch\n",
				"import torch.nn as nn\n",
				"import torch.nn.functional as F\n",
				"\n",
				"import time\n",
				"import io\n",
				"import copy\n",
				"import os\n",
				"import math\n",
				"from scipy import integrate\n",
				"from functools import partial\n",
				"import pandas as pd\n",
				"\n",
				"import pickle\n",
				"from pylab import *\n",
				"\n",
				"from torchvision import transforms\n",
				"\n",
				"from diffusers import DDPMScheduler, EulerDiscreteScheduler\n",
				"from statsmodels.tsa.stattools import acf\n",
				"\n",
				"import sys\n",
				"\n",
				"current_path = os.getcwd()\n",
				"two_folders_up = os.path.join(current_path, '..', '..')\n",
				"desired_folder = os.path.join(two_folders_up, 'SeqDiff')\n",
				"absolute_desired_folder = os.path.abspath(desired_folder)\n",
				"sys.path.insert(0, absolute_desired_folder)\n",
				"\n",
				"from dynamicsdiffusion import TemporalUnet, TemporalUnetEnergy, GaussianDiffusion, Trainer, count_parameters\n",
				"\n",
				"device = 'cuda'"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {
				"executionInfo": {
					"elapsed": 218,
					"status": "ok",
					"timestamp": 1673866836981,
					"user": {
						"displayName": "M Petersen",
						"userId": "13637530209006951077"
					},
					"user_tz": -60
				},
				"id": "HbfSo-pe1xj6"
			},
			"outputs": [],
			"source": [
				"#@title Sampling and Logging\n",
				"def batch_sampler(traj, batch_size, horizon, transition_dim):\n",
				"    #hflipper = transforms.RandomHorizontalFlip(p=0.5)\n",
				"    if isinstance(horizon, list):\n",
				"        horizon = np.random.choice(horizon)\n",
				"    \n",
				"    batch = torch.zeros(size = (batch_size, horizon, transition_dim))\n",
				"\n",
				"    for i in range(batch_size):\n",
				"        start_replica = np.random.randint(0, traj.shape[1])\n",
				"\n",
				"        if traj.shape[0] <= horizon:\n",
				"            #batch[i] = hflipper(torch.tensor(traj[:, start_replica, :]))\n",
				"            batch[i] = torch.tensor(traj[:, start_replica, :])\n",
				"        else:\n",
				"            start_step = np.random.randint(0, traj.shape[0] - horizon)\n",
				"            #batch[i] = hflipper(torch.tensor(traj[start_step:start_step + horizon, start_replica, :]))\n",
				"            batch[i] = torch.tensor(traj[start_step:start_step + horizon, start_replica, :])\n",
				"    return batch\n",
				"\n",
				"def potential(shape):\n",
				"    #caclulate the potential at each point\n",
				"    x = np.linspace(-2, 2, shape[0])\n",
				"    y = np.linspace(-2, 2, shape[1])\n",
				"    X, Y = np.meshgrid(x, y)\n",
				"    return X, Y, -9*X**2 + X**3 + 4.5*x**4 + 3*Y**2\n",
				"\n",
				"def plotting_fn(samples, data, step, dim, training = True, title_addition = ''):\n",
				"    #make a subplot of the data and the samples side by side\n",
				"    samples = samples.cpu().detach().numpy()\n",
				"    samples = samples.reshape(-1, dim)\n",
				"\n",
				"    data = data[::10].reshape(-1, dim)\n",
				"\n",
				"    samples = (samples + 1)/2*(max_min_array[0] - max_min_array[1]) + max_min_array[1]\n",
				"    data = (data + 1)/2*(max_min_array[0] - max_min_array[1]) + max_min_array[1]\n",
				"\n",
				"\n",
				"    fig, ax = plt.subplots(1, 2, figsize = (14, 5))\n",
				"\n",
				"    density_samples = np.histogram2d(samples[::, 0], samples[::, 1], bins=100, range=[[-2, 2], [-2, 2]])[0]\n",
				"    density_samples = density_samples/np.sum(density_samples)\n",
				"    ax[0].imshow(-np.log(density_samples.T), origin='lower', extent=[-2, 2, -2, 2])\n",
				"    ax[0].set_title('Free Energy of DDPM Samples')\n",
				"    ax[0].set_xlabel('x')\n",
				"    ax[0].set_ylabel('y')\n",
				"\n",
				"    X, Y, Z = potential((100, 100))\n",
				"    min_level = np.min(Z)\n",
				"    Z = Z - min_level\n",
				"    levels = np.logspace(0, 1, 10)\n",
				"    levels = levels + min_level\n",
				"    Z = Z + min_level\n",
				"\n",
				"    ax[0].contour(X, Y, Z, levels=levels, alpha=1)\n",
				"    cbar = fig.colorbar(ax[0].contour(X, Y, Z, levels=levels, alpha=1), ax=ax[0])\n",
				"    cbar.ax.set_ylabel('Potential Energy')\n",
				"    \n",
				"    density_data = np.histogram2d(data[::, 0], data[::, 1], bins=100, range=[[-2, 2], [-2, 2]])[0]\n",
				"    density_data = density_data/np.sum(density_data)\n",
				"    ax[1].imshow(-np.log(density_data.T), origin='lower', extent=[-2, 2, -2, 2])\n",
				"    ax[1].set_title('Free Energy of Data')\n",
				"    ax[1].set_xlabel('x')\n",
				"    ax[1].set_ylabel('y')\n",
				"\n",
				"    cbar = fig.colorbar(ax[1].imshow(-np.log(density_data.T), origin='lower', extent=[-2, 2, -2, 2]), ax=ax[1])\n",
				"    cbar.ax.set_ylabel('Free Energy')\n",
				"\n",
				"    #add a title to the figure\n",
				"    if training:\n",
				"        fig.suptitle('DDPM Samples and Data at Trainingstep: ' + str(step), fontsize=16)\n",
				"    else:\n",
				"        fig.suptitle('DDPM Samples and Data at ' + title_addition + str(step), fontsize=16)\n",
				"\n",
				"    plt.show()\n",
				"\n",
				"def plotting_fn_cross(samples, data, step):\n",
				"    plt.hist(samples[:, :, 0].cpu().numpy().flatten(), bins=100, density=True)\n",
				"    plt.hist(data[::10, :, 0].flatten(), bins=100, density=True, alpha=0.3)\n",
				"    plt.title('Histogram of the samples')\n",
				"    plt.xlabel('x')\n",
				"    plt.ylabel('Density')\n",
				"    plt.show()"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {
				"id": "yl50mOsMi3A0"
			},
			"source": [
				"Instantiate Models"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {
				"colab": {
					"base_uri": "https://localhost:8080/"
				},
				"executionInfo": {
					"elapsed": 2787,
					"status": "ok",
					"timestamp": 1673866843043,
					"user": {
						"displayName": "M Petersen",
						"userId": "13637530209006951077"
					},
					"user_tz": -60
				},
				"id": "z4Gp-UxCgvKY",
				"outputId": "37cd9f80-1f1f-4510-cef1-3607a150cfc7"
			},
			"outputs": [],
			"source": [
				"data_dir = \"../Data Generation/Data/traj_dw.pkl\"\n",
				"file = open(data_dir,'rb')\n",
				"data = pickle.load(file)\n",
				"\n",
				"scaler_dir = \"../Data Generation/Data/dw_scaler.pkl\"\n",
				"file = open(scaler_dir,'rb')\n",
				"max_min_array = pickle.load(file)\n",
				"\n",
				"use_forces = True\n",
				"transition_dim = 4\n",
				"\n",
				"if use_forces == False:\n",
				"    data = data[::, ::, 0:2]\n",
				"    max_min_array = max_min_array[::, 0:2]\n",
				"    transition_dim = 2\n",
				"    \n",
				"horizon = [128]\n",
				"batch_size = 256"
			]
		},
		{
			"attachments": {},
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"## Ablations"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"def free_energy_eval(trainer, data, sample_count, h, transition_dim, bins):\n",
				"    samples = trainer.ema_model.p_sample_loop((sample_count, h, transition_dim), None).trajectories\n",
				"\n",
				"    samples = samples.cpu().detach().numpy()\n",
				"    samples = samples.reshape(-1, transition_dim)\n",
				"\n",
				"    data = data[::, ::10].reshape(-1, transition_dim)\n",
				"\n",
				"    samples = (samples + 1)/2*(max_min_array[0] - max_min_array[1]) + max_min_array[1]\n",
				"    data = (data + 1)/2*(max_min_array[0] - max_min_array[1]) + max_min_array[1]\n",
				"\n",
				"    #calculate the free energy of the samples and the data\n",
				"    samples_x = samples[::, 0]\n",
				"    data_x = data[::, 0]\n",
				"\n",
				"    #calculate the free energy of the samples and the data\n",
				"    log_density_samples, bin_edges = np.histogram(samples_x, bins=bins, density=True, range=(-1.6, 1.5))\n",
				"    log_density_data, bin_edges = np.histogram(data_x, bins=bins, density=True, range=(-1.6, 1.5))\n",
				"    #take the negative log of the free energy\n",
				"    log_density_samples = -np.log(log_density_samples)\n",
				"    log_density_data = -np.log(log_density_data)\n",
				"    \n",
				"    #calculate the difference between the samples and the data\n",
				"    diff_free = log_density_samples - log_density_data\n",
				"    diff_free_mean_nonnan_noninf = np.nanmean(diff_free[np.isfinite(diff_free)])\n",
				"    diff_free_median_nonnan_noninf = np.nanmedian(diff_free[np.isfinite(diff_free)])\n",
				"\n",
				"    #calculate the difference between the samples and the data as a percentage\n",
				"    diff_per = np.abs((log_density_samples - log_density_data)/log_density_data)*100\n",
				"    diff_per_mean_nonnan_noninf = np.nanmean(diff_per[np.isfinite(diff_per)])\n",
				"    diff_per_median_nonnan_noninf = np.nanmedian(diff_per[np.isfinite(diff_per)])\n",
				"\n",
				"    #calculate the difference between the samples and the data of the central 25% of the bins\n",
				"    diff_free_central = log_density_samples[int(len(log_density_samples)/4):int(len(log_density_samples)*3/4)] - log_density_data[int(len(log_density_data)/4):int(len(log_density_data)*3/4)]\n",
				"    diff_free_central_mean_nonnan_noninf = np.nanmean(diff_free_central[np.isfinite(diff_free_central)])\n",
				"    diff_free_central_median_nonnan_noninf = np.nanmedian(diff_free_central[np.isfinite(diff_free_central)])\n",
				"\n",
				"    #calculate the difference between the samples and the data as a percentage of the central 25% of the bins\n",
				"    diff_per_central = np.abs((log_density_samples[int(len(log_density_samples)/4):int(len(log_density_samples)*3/4)] - log_density_data[int(len(log_density_data)/4):int(len(log_density_data)*3/4)])/log_density_data[int(len(log_density_data)/4):int(len(log_density_data)*3/4)])*100\n",
				"    diff_per_central_mean_nonnan_noninf = np.nanmean(diff_per_central[np.isfinite(diff_per_central)])\n",
				"    diff_per_central_median_nonnan_noninf = np.nanmedian(diff_per_central[np.isfinite(diff_per_central)])\n",
				"\n",
				"    result_dict = {'diff_free_mean_nonnan_noninf': diff_free_mean_nonnan_noninf, 'diff_free_median_nonnan_noninf': diff_free_median_nonnan_noninf, 'diff_per_mean_nonnan_noninf': diff_per_mean_nonnan_noninf, 'diff_per_median_nonnan_noninf': diff_per_median_nonnan_noninf, 'diff_free_central_mean_nonnan_noninf': diff_free_central_mean_nonnan_noninf, 'diff_free_central_median_nonnan_noninf': diff_free_central_median_nonnan_noninf, 'diff_per_central_mean_nonnan_noninf': diff_per_central_mean_nonnan_noninf, 'diff_per_central_median_nonnan_noninf': diff_per_central_median_nonnan_noninf}\n",
				"\n",
				"    return result_dict"
			]
		},
		{
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Energy Model Ablation"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results = {}\n",
				"model_types = [\"Energy\", \"No Energy\"]\n",
				"training_repeats = 5\n",
				"\n",
				"for model_type in model_types:\n",
				"    for i in range(training_repeats):\n",
				"        if model_type == \"Energy\":\n",
				"            model = TemporalUnetEnergy(horizon = horizon[0], transition_dim = transition_dim, cond_dim = None, dim=64, dim_mults=(1, 2)).to(device)\n",
				"        elif model_type == \"No Energy\":\n",
				"            model = TemporalUnet(horizon = horizon[0], transition_dim = transition_dim, cond_dim = None, dim=64, dim_mults=(1, 2)).to(device)\n",
				"        diffuser = GaussianDiffusion(model = model, horizon = horizon[0], action_dim=transition_dim, observation_dim=0).to(device)\n",
				"        trainer = Trainer(diffuser, training_data = data, training_horizons = horizon, batch_sampler = batch_sampler, plotting_fn = None, train_lr=1e-4, train_batch_size=batch_size, run_name = \"ablation_\" + model_type + \"_\" + str(i))\n",
				"        trainer.train(3001)\n",
				"        #change the training rate to 1e-6 after 5000 iterations\n",
				"        trainer = Trainer(diffuser, training_data = data, training_horizons = horizon, batch_sampler = batch_sampler, plotting_fn = None, train_lr=1e-6, train_batch_size=batch_size, run_name = \"ablation_\" + model_type + \"_\" + str(i))        \n",
				"        trainer.load(0)\n",
				"        trainer.train(1501)\n",
				"        ablation_results[model_type + \"_\" + str(i)] = free_energy_eval(trainer, data, sample_count = 2000, h = horizon[0], transition_dim = transition_dim, bins = 100)\n",
				"    "
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"#save the results in the Data folder\n",
				"with open(\"../Data Generation/Data/ablation_results_energy.pkl\", \"wb\") as f:\n",
				"    pickle.dump(ablation_results, f)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"#compute the mean and standard deviation of the results over the training repeats for each model type\n",
				"ablation_results_mean = {}\n",
				"ablation_results_std = {}\n",
				"for model_type in model_types:\n",
				"    ablation_results_mean[model_type] = {}\n",
				"    ablation_results_std[model_type] = {}\n",
				"    for key in ablation_results[model_type + \"_0\"]:\n",
				"        ablation_results_mean[model_type][key] = np.mean(np.abs([ablation_results[model_type + \"_\" + str(i)][key] for i in range(training_repeats)]))\n",
				"        ablation_results_std[model_type][key] = np.std(np.abs([ablation_results[model_type + \"_\" + str(i)][key] for i in range(training_repeats)]))\n",
				"\n",
				"#turn the results into a dataframe\n",
				"ablation_results_mean_df = pd.DataFrame(columns = [\"Model\", \"Difference Free Mean\", \"Difference Free Median\", \"Difference Percentage Mean\", \"Difference Percentage Median\", \"Difference Free Central Mean\", \"Difference Free Central Median\", \"Difference Percentage Central Mean\", \"Difference Percentage Central Median\"])\n",
				"for model_type in model_types:\n",
				"    ablation_results_mean_df = ablation_results_mean_df.append({\"Model\": model_type, \"Difference Free Mean\": ablation_results_mean[model_type][\"diff_free_mean_nonnan_noninf\"], \"Difference Free Median\": ablation_results_mean[model_type][\"diff_free_median_nonnan_noninf\"], \"Difference Percentage Mean\": ablation_results_mean[model_type][\"diff_per_mean_nonnan_noninf\"], \"Difference Percentage Median\": ablation_results_mean[model_type][\"diff_per_median_nonnan_noninf\"], \"Difference Free Central Mean\": ablation_results_mean[model_type][\"diff_free_central_mean_nonnan_noninf\"], \"Difference Free Central Median\": ablation_results_mean[model_type][\"diff_free_central_median_nonnan_noninf\"], \"Difference Percentage Central Mean\": ablation_results_mean[model_type][\"diff_per_central_mean_nonnan_noninf\"], \"Difference Percentage Central Median\": ablation_results_mean[model_type][\"diff_per_central_median_nonnan_noninf\"]}, ignore_index=True)\n",
				"#save the results in the Data folder\n",
				"ablation_results_mean_df.to_csv(\"../Data Generation/Data/ablation_results_mean_energy.csv\")\n",
				"\n",
				"ablation_results_std_df = pd.DataFrame(columns = [\"Model\", \"Difference Free Mean\", \"Difference Free Median\", \"Difference Percentage Mean\", \"Difference Percentage Median\", \"Difference Free Central Mean\", \"Difference Free Central Median\", \"Difference Percentage Central Mean\", \"Difference Percentage Central Median\"])\n",
				"for model_type in model_types:\n",
				"    ablation_results_std_df = ablation_results_std_df.append({\"Model\": model_type, \"Difference Free Mean\": ablation_results_std[model_type][\"diff_free_mean_nonnan_noninf\"], \"Difference Free Median\": ablation_results_std[model_type][\"diff_free_median_nonnan_noninf\"], \"Difference Percentage Mean\": ablation_results_std[model_type][\"diff_per_mean_nonnan_noninf\"], \"Difference Percentage Median\": ablation_results_std[model_type][\"diff_per_median_nonnan_noninf\"], \"Difference Free Central Mean\": ablation_results_std[model_type][\"diff_free_central_mean_nonnan_noninf\"], \"Difference Free Central Median\": ablation_results_std[model_type][\"diff_free_central_median_nonnan_noninf\"], \"Difference Percentage Central Mean\": ablation_results_std[model_type][\"diff_per_central_mean_nonnan_noninf\"], \"Difference Percentage Central Median\": ablation_results_std[model_type][\"diff_per_central_median_nonnan_noninf\"]}, ignore_index=True)\n",
				"#save the results in the Data folder\n",
				"ablation_results_std_df.to_csv(\"../Data Generation/Data/ablation_results_std_energy.csv\")"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results_mean_df"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results_std_df"
			]
		},
		{
			"attachments": {},
			"cell_type": "markdown",
			"metadata": {},
			"source": [
				"### Attention Ablation"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results = {}\n",
				"model_types = [\"Attention\", \"No Attention\"]\n",
				"training_repeats = 5\n",
				"\n",
				"for model_type in model_types:\n",
				"    for i in range(training_repeats):\n",
				"        if model_type == \"Attention\":\n",
				"            model = TemporalUnet(horizon = horizon[0], transition_dim = transition_dim, cond_dim = None, dim=64, dim_mults=(1, 2), attention = True).to(device)\n",
				"        elif model_type == \"No Attention\":\n",
				"            model = TemporalUnet(horizon = horizon[0], transition_dim = transition_dim, cond_dim = None, dim=64, dim_mults=(1, 2), attention = False).to(device)\n",
				"        diffuser = GaussianDiffusion(model = model, horizon = horizon[0], action_dim=transition_dim, observation_dim=0).to(device)\n",
				"        trainer = Trainer(diffuser, training_data = data, training_horizons = horizon, batch_sampler = batch_sampler, plotting_fn = None, train_lr=1e-4, train_batch_size=batch_size, run_name = \"ablation_\" + model_type + \"_\" + str(i))\n",
				"        trainer.train(5001)\n",
				"        #change the training rate to 1e-6 after 5000 iterations\n",
				"        trainer = Trainer(diffuser, training_data = data, training_horizons = horizon, batch_sampler = batch_sampler, plotting_fn = None, train_lr=1e-6, train_batch_size=batch_size, run_name = \"ablation_\" + model_type + \"_\" + str(i))        \n",
				"        trainer.load(0)\n",
				"        trainer.train(2501)\n",
				"        ablation_results[model_type + \"_\" + str(i)] = free_energy_eval(trainer, data, sample_count = 2000, h = horizon[0], transition_dim = transition_dim, bins = 100)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"#save the results in the Data folder\n",
				"with open(\"../Data Generation/Data/ablation_results_attention.pkl\", \"wb\") as f:\n",
				"    pickle.dump(ablation_results, f)"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"#load the abaition results\n",
				"with open(\"../Data Generation/Data/ablation_results_attention.pkl\", \"rb\") as f:\n",
				"    ablation_results = pickle.load(f)\n",
				"\n",
				"model_types = [\"Attention\", \"No Attention\"]\n",
				"training_repeats = 5\n",
				"\n",
				"#compute the mean and standard deviation of the results over the training repeats for each model type\n",
				"ablation_results_mean = {}\n",
				"ablation_results_std = {}\n",
				"for model_type in model_types:\n",
				"    ablation_results_mean[model_type] = {}\n",
				"    ablation_results_std[model_type] = {}\n",
				"    for key in ablation_results[model_type + \"_0\"]:\n",
				"        ablation_results_mean[model_type][key] = np.mean(np.abs([ablation_results[model_type + \"_\" + str(i)][key] for i in range(training_repeats)]))\n",
				"        ablation_results_std[model_type][key] = np.std(np.abs([ablation_results[model_type + \"_\" + str(i)][key] for i in range(training_repeats)]))\n",
				"\n",
				"#turn the results into a dataframe\n",
				"ablation_results_mean_df = pd.DataFrame(columns = [\"Model\", \"Difference Free Mean\", \"Difference Free Median\", \"Difference Percentage Mean\", \"Difference Percentage Median\", \"Difference Free Central Mean\", \"Difference Free Central Median\", \"Difference Percentage Central Mean\", \"Difference Percentage Central Median\"])\n",
				"for model_type in model_types:\n",
				"    ablation_results_mean_df = ablation_results_mean_df.append({\"Model\": model_type, \"Difference Free Mean\": ablation_results_mean[model_type][\"diff_free_mean_nonnan_noninf\"], \"Difference Free Median\": ablation_results_mean[model_type][\"diff_free_median_nonnan_noninf\"], \"Difference Percentage Mean\": ablation_results_mean[model_type][\"diff_per_mean_nonnan_noninf\"], \"Difference Percentage Median\": ablation_results_mean[model_type][\"diff_per_median_nonnan_noninf\"], \"Difference Free Central Mean\": ablation_results_mean[model_type][\"diff_free_central_mean_nonnan_noninf\"], \"Difference Free Central Median\": ablation_results_mean[model_type][\"diff_free_central_median_nonnan_noninf\"], \"Difference Percentage Central Mean\": ablation_results_mean[model_type][\"diff_per_central_mean_nonnan_noninf\"], \"Difference Percentage Central Median\": ablation_results_mean[model_type][\"diff_per_central_median_nonnan_noninf\"]}, ignore_index=True)\n",
				"#save the results in the Data folder\n",
				"ablation_results_mean_df.to_csv(\"../Data Generation/Data/ablation_results_mean_attention.csv\")\n",
				"\n",
				"ablation_results_std_df = pd.DataFrame(columns = [\"Model\", \"Difference Free Mean\", \"Difference Free Median\", \"Difference Percentage Mean\", \"Difference Percentage Median\", \"Difference Free Central Mean\", \"Difference Free Central Median\", \"Difference Percentage Central Mean\", \"Difference Percentage Central Median\"])\n",
				"for model_type in model_types:\n",
				"    ablation_results_std_df = ablation_results_std_df.append({\"Model\": model_type, \"Difference Free Mean\": ablation_results_std[model_type][\"diff_free_mean_nonnan_noninf\"], \"Difference Free Median\": ablation_results_std[model_type][\"diff_free_median_nonnan_noninf\"], \"Difference Percentage Mean\": ablation_results_std[model_type][\"diff_per_mean_nonnan_noninf\"], \"Difference Percentage Median\": ablation_results_std[model_type][\"diff_per_median_nonnan_noninf\"], \"Difference Free Central Mean\": ablation_results_std[model_type][\"diff_free_central_mean_nonnan_noninf\"], \"Difference Free Central Median\": ablation_results_std[model_type][\"diff_free_central_median_nonnan_noninf\"], \"Difference Percentage Central Mean\": ablation_results_std[model_type][\"diff_per_central_mean_nonnan_noninf\"], \"Difference Percentage Central Median\": ablation_results_std[model_type][\"diff_per_central_median_nonnan_noninf\"]}, ignore_index=True)\n",
				"\n",
				"#save the results in the Data folder\n",
				"ablation_results_std_df.to_csv(\"../Data Generation/Data/ablation_results_std_attention.csv\")\n"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results_mean_df"
			]
		},
		{
			"cell_type": "code",
			"execution_count": null,
			"metadata": {},
			"outputs": [],
			"source": [
				"ablation_results_std_df"
			]
		}
	],
	"metadata": {
		"accelerator": "GPU",
		"colab": {
			"authorship_tag": "ABX9TyMjwkK+LQFuanFegidX+2Vc",
			"machine_shape": "hm",
			"mount_file_id": "1T4CnIKZ8_7dslj0HpkrHuqBJXlIo1a4C",
			"name": "",
			"version": ""
		},
		"gpuClass": "premium",
		"kernelspec": {
			"display_name": "base",
			"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.13"
		},
		"vscode": {
			"interpreter": {
				"hash": "639d8a7c3e620b1d142eea4deabde5aac9ed3b21a6e651e4622d69fbdac2ed0a"
			}
		}
	},
	"nbformat": 4,
	"nbformat_minor": 2
}
