{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "67c87798",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c72da0f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: TF_FORCE_UNIFIED_MEMORY=1\n"
     ]
    }
   ],
   "source": [
    "%env TF_FORCE_UNIFIED_MEMORY=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b59d35e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "from jax import random\n",
    "import dataset_sines_infinite\n",
    "import dataset_sines_finite\n",
    "import dataset_lines_infinite\n",
    "import dataset_quads_infinite\n",
    "import test\n",
    "import plots\n",
    "import ntk\n",
    "import nll\n",
    "from jax import numpy as np\n",
    "\n",
    "import pickle\n",
    "import models\n",
    "import utils\n",
    "from matplotlib import pyplot as plt\n",
    "from sklearn.metrics import roc_auc_score\n",
    "\n",
    "from jax.lax import scan\n",
    "from jax import grad\n",
    "from jax.tree_util import tree_map\n",
    "from functools import partial"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "eaa18515",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2022-08-27 14:35:10.648292: W external/org_tensorflow/tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libcuda.so.1'; dlerror: libcuda.so.1: cannot open shared object file: No such file or directory; LD_LIBRARY_PATH: /state/partition1/llgrid/pkg/anaconda/anaconda3-2022a/pkgs/cudatoolkit-11.3.1-h2bc3f7f_2/lib\n",
      "2022-08-27 14:35:10.648337: W external/org_tensorflow/tensorflow/stream_executor/cuda/cuda_driver.cc:269] failed call to cuInit: UNKNOWN ERROR (303)\n",
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "key = random.PRNGKey(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "24e4f2f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ci95(array):\n",
    "    sample_std = np.std(array)\n",
    "    sample_size = array.shape[0]\n",
    "    return 0.95 * sample_std / np.sqrt(sample_size)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b4e76d6d",
   "metadata": {},
   "source": [
    "## Loading results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "f6e1296c",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/fim_infinite.pickle\", \"rb\") as handle:\n",
    "    output_fim_infinite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b915ac78",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/fim_finite.pickle\", \"rb\") as handle:\n",
    "    output_fim_finite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7e5233fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/random_infinite.pickle\", \"rb\") as handle:\n",
    "    output_random_infinite = pickle.load(handle)\n",
    "with open(\"logs_final/random_infinite2.pickle\", \"rb\") as handle:\n",
    "    output_random_infinite2 = pickle.load(handle)\n",
    "with open(\"logs_final/random_infinite3.pickle\", \"rb\") as handle:\n",
    "    output_random_infinite3 = pickle.load(handle)\n",
    "with open(\"logs_final/random_infinite4.pickle\", \"rb\") as handle:\n",
    "    output_random_infinite4 = pickle.load(handle)\n",
    "with open(\"logs_final/random_infinite5.pickle\", \"rb\") as handle:\n",
    "    output_random_infinite5 = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "5a82007c",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/random_finite.pickle\", \"rb\") as handle:\n",
    "    output_random_finite = pickle.load(handle)\n",
    "with open(\"logs_final/random_finite2.pickle\", \"rb\") as handle:\n",
    "    output_random_finite2 = pickle.load(handle)\n",
    "with open(\"logs_final/random_finite3.pickle\", \"rb\") as handle:\n",
    "    output_random_finite3 = pickle.load(handle)\n",
    "with open(\"logs_final/random_finite4.pickle\", \"rb\") as handle:\n",
    "    output_random_finite4 = pickle.load(handle)\n",
    "with open(\"logs_final/random_finite5.pickle\", \"rb\") as handle:\n",
    "    output_random_finite5 = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "f7ad9931",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/identity_infinite.pickle\", \"rb\") as handle:\n",
    "    output_identity_infinite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7b133714",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/identity_finite.pickle\", \"rb\") as handle:\n",
    "    output_identity_finite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "7ae8ffb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/maml_single_infinite.pickle\", \"rb\") as handle:\n",
    "    output_maml_infinite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "afb6ed9e",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/maml_single_finite.pickle\", \"rb\") as handle:\n",
    "    output_maml_finite = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "14c05d23",
   "metadata": {},
   "source": [
    "## Loading network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b97d942d",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = models.small_network(40, \"relu\", 1)\n",
    "apply_fn = utils.apply_fn_wrapper(model.apply, False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75d564cd",
   "metadata": {},
   "source": [
    "## Computing kernels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f433e0ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel_fim_infinite, kernel_self_fim_infinite, jac_fim_infinite = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_fim_infinite[\"trained_params\"], output_fim_infinite[\"trained_scale\"], output_fim_infinite[\"trained_batch_stats\"], output_fim_infinite[\"proj\"])\n",
    "kernel_fim_finite, kernel_self_fim_finite, jac_fim_finite = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_fim_finite[\"trained_params\"], output_fim_finite[\"trained_scale\"], output_fim_finite[\"trained_batch_stats\"], output_fim_finite[\"proj\"])\n",
    "\n",
    "kernel_random_infinite, kernel_self_random_infinite, jac_random_infinite = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_infinite[\"trained_params\"], output_random_infinite[\"trained_scale\"], output_random_infinite[\"trained_batch_stats\"], output_random_infinite[\"proj\"])\n",
    "kernel_random_finite, kernel_self_random_finite, jac_random_finite = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_finite[\"trained_params\"], output_random_finite[\"trained_scale\"], output_random_finite[\"trained_batch_stats\"], output_random_finite[\"proj\"])\n",
    "\n",
    "kernel_random_infinite2, kernel_self_random_infinite2, jac_random_infinite2 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_infinite2[\"trained_params\"], output_random_infinite2[\"trained_scale\"], output_random_infinite2[\"trained_batch_stats\"], output_random_infinite2[\"proj\"])\n",
    "kernel_random_finite2, kernel_self_random_finite2, jac_random_finite2 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_finite2[\"trained_params\"], output_random_finite2[\"trained_scale\"], output_random_finite2[\"trained_batch_stats\"], output_random_finite2[\"proj\"])\n",
    "\n",
    "kernel_random_infinite3, kernel_self_random_infinite3, jac_random_infinite3 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_infinite3[\"trained_params\"], output_random_infinite3[\"trained_scale\"], output_random_infinite3[\"trained_batch_stats\"], output_random_infinite3[\"proj\"])\n",
    "kernel_random_finite3, kernel_self_random_finite3, jac_random_finite3 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_finite3[\"trained_params\"], output_random_finite3[\"trained_scale\"], output_random_finite3[\"trained_batch_stats\"], output_random_finite3[\"proj\"])\n",
    "\n",
    "kernel_random_infinite4, kernel_self_random_infinite4, jac_random_infinite4 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_infinite4[\"trained_params\"], output_random_infinite4[\"trained_scale\"], output_random_infinite4[\"trained_batch_stats\"], output_random_infinite4[\"proj\"])\n",
    "kernel_random_finite4, kernel_self_random_finite4, jac_random_finite4 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_finite4[\"trained_params\"], output_random_finite4[\"trained_scale\"], output_random_finite4[\"trained_batch_stats\"], output_random_finite4[\"proj\"])\n",
    "\n",
    "kernel_random_infinite5, kernel_self_random_infinite5, jac_random_infinite5 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_infinite5[\"trained_params\"], output_random_infinite5[\"trained_scale\"], output_random_infinite5[\"trained_batch_stats\"], output_random_infinite5[\"proj\"])\n",
    "kernel_random_finite5, kernel_self_random_finite5, jac_random_finite5 = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_random_finite5[\"trained_params\"], output_random_finite5[\"trained_scale\"], output_random_finite5[\"trained_batch_stats\"], output_random_finite5[\"proj\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "a14ba1f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel_identity_infinite, kernel_self_identity_infinite, jac_identity_infinite = ntk.get_kernel_and_jac_identity_cov(apply_fn, output_identity_infinite[\"intermediate_params\"], output_identity_infinite[\"intermediate_batch_stats\"])\n",
    "kernel_identity_finite, kernel_self_identity_finite, jac_identity_finite = ntk.get_kernel_and_jac_identity_cov(apply_fn, output_identity_finite[\"intermediate_params\"], output_identity_finite[\"intermediate_batch_stats\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fcdc9539",
   "metadata": {},
   "source": [
    "## AUC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2dd51449",
   "metadata": {},
   "outputs": [],
   "source": [
    "def true_score_single(nll_sines, nll_lines, nll_quad):\n",
    "    y_true = np.ones( (nll_sines.shape[0] + nll_lines.shape[0] + nll_quad.shape[0]) )\n",
    "    y_true = y_true.at[:nll_sines.shape[0]].set(np.array([0]*nll_sines.shape[0]))\n",
    "\n",
    "    y_score = np.append(nll_sines, nll_lines)\n",
    "    y_score = np.append(y_score, nll_quad)\n",
    "\n",
    "    return y_true, y_score\n",
    "\n",
    "def compute_auc(nll_sines, nll_lines, nll_quad):\n",
    "    y_true, y_score = true_score_single(nll_sines, nll_lines, nll_quad)\n",
    "    return roc_auc_score(y_true, y_score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "30f1202a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def auc_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    aucs_fim_infinite = []\n",
    "    aucs_fim_finite = []\n",
    "    aucs_identity_infinite = []\n",
    "    aucs_identity_finite = []\n",
    "    \n",
    "    aucs_random_infinite = []\n",
    "    aucs_random_finite = []\n",
    "    aucs_random_infinite2 = []\n",
    "    aucs_random_finite2 = []\n",
    "    aucs_random_infinite3 = []\n",
    "    aucs_random_finite3 = []\n",
    "    aucs_random_infinite4 = []\n",
    "    aucs_random_finite4 = []\n",
    "    aucs_random_infinite5 = []\n",
    "    aucs_random_finite5 = []\n",
    "\n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey_1, subkey_2, subkey_3 = random.split(key, 4)\n",
    "        nll_sine_fim_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_infinite, jac_fim_infinite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_infinite[\"trained_mean\"])\n",
    "        nll_sine_fim_finite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_finite, jac_fim_finite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_finite[\"trained_mean\"])\n",
    "        nll_sine_identity_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_infinite, jac_identity_infinite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_infinite[\"intermediate_mean\"])\n",
    "        nll_sine_identity_finite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_finite, jac_identity_finite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_finite[\"intermediate_mean\"])\n",
    "        nll_sine_random_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite, jac_random_infinite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite[\"trained_mean\"])\n",
    "        nll_sine_random_finite = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite, jac_random_finite, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite[\"trained_mean\"])\n",
    "        nll_sine_random_infinite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite2, jac_random_infinite2, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite2[\"trained_mean\"])\n",
    "        nll_sine_random_finite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite2, jac_random_finite2, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite2[\"trained_mean\"])\n",
    "        nll_sine_random_infinite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite3, jac_random_infinite3, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite3[\"trained_mean\"])\n",
    "        nll_sine_random_finite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite3, jac_random_finite3, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite3[\"trained_mean\"])\n",
    "        nll_sine_random_infinite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite4, jac_random_infinite4, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite4[\"trained_mean\"])\n",
    "        nll_sine_random_finite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite4, jac_random_finite4, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite4[\"trained_mean\"])\n",
    "        nll_sine_random_infinite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite5, jac_random_infinite5, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite5[\"trained_mean\"])\n",
    "        nll_sine_random_finite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite5, jac_random_finite5, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite5[\"trained_mean\"])\n",
    "        \n",
    "        nll_line_fim_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_infinite, jac_fim_infinite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_infinite[\"trained_mean\"])\n",
    "        nll_line_fim_finite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_finite, jac_fim_finite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_finite[\"trained_mean\"])\n",
    "        nll_line_identity_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_infinite, jac_identity_infinite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_infinite[\"intermediate_mean\"])\n",
    "        nll_line_identity_finite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_finite, jac_identity_finite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_finite[\"intermediate_mean\"])\n",
    "        nll_line_random_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite, jac_random_infinite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite[\"trained_mean\"])\n",
    "        nll_line_random_finite = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite, jac_random_finite, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite[\"trained_mean\"])\n",
    "        nll_line_random_infinite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite2, jac_random_infinite2, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite2[\"trained_mean\"])\n",
    "        nll_line_random_finite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite2, jac_random_finite2, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite2[\"trained_mean\"])\n",
    "        nll_line_random_infinite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite3, jac_random_infinite3, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite3[\"trained_mean\"])\n",
    "        nll_line_random_finite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite3, jac_random_finite3, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite3[\"trained_mean\"])\n",
    "        nll_line_random_infinite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite4, jac_random_infinite4, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite4[\"trained_mean\"])\n",
    "        nll_line_random_finite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite4, jac_random_finite4, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite4[\"trained_mean\"])\n",
    "        nll_line_random_infinite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite5, jac_random_infinite5, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite5[\"trained_mean\"])\n",
    "        nll_line_random_finite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite5, jac_random_finite5, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite5[\"trained_mean\"])\n",
    "        \n",
    "        nll_quad_fim_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_infinite, jac_fim_infinite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_infinite[\"trained_mean\"])\n",
    "        nll_quad_fim_finite = test.test_nll_one_kernel(subkey_1, kernel_self_fim_finite, jac_fim_finite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_finite[\"trained_mean\"])\n",
    "        nll_quad_identity_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_infinite, jac_identity_infinite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_infinite[\"intermediate_mean\"])\n",
    "        nll_quad_identity_finite = test.test_nll_one_kernel(subkey_1, kernel_self_identity_finite, jac_identity_finite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_finite[\"intermediate_mean\"])\n",
    "        nll_quad_random_infinite = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite, jac_random_infinite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite[\"trained_mean\"])\n",
    "        nll_quad_random_finite = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite, jac_random_finite, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite[\"trained_mean\"])\n",
    "        nll_quad_random_infinite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite2, jac_random_infinite2, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite2[\"trained_mean\"])\n",
    "        nll_quad_random_finite2 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite2, jac_random_finite2, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite2[\"trained_mean\"])\n",
    "        nll_quad_random_infinite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite3, jac_random_infinite3, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite3[\"trained_mean\"])\n",
    "        nll_quad_random_finite3 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite3, jac_random_finite3, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite3[\"trained_mean\"])\n",
    "        nll_quad_random_infinite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite4, jac_random_infinite4, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite4[\"trained_mean\"])\n",
    "        nll_quad_random_finite4 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite4, jac_random_finite4, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite4[\"trained_mean\"])\n",
    "        nll_quad_random_infinite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_infinite5, jac_random_infinite5, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite5[\"trained_mean\"])\n",
    "        nll_quad_random_finite5 = test.test_nll_one_kernel(subkey_1, kernel_self_random_finite5, jac_random_finite5, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite5[\"trained_mean\"])\n",
    "\n",
    "        aucs_fim_infinite.append(compute_auc(nll_sine_fim_infinite, nll_line_fim_infinite, nll_quad_fim_infinite))\n",
    "        aucs_fim_finite.append(compute_auc(nll_sine_fim_finite, nll_line_fim_finite, nll_quad_fim_finite))\n",
    "        aucs_identity_infinite.append(compute_auc(nll_sine_identity_infinite, nll_line_identity_infinite, nll_quad_identity_infinite))\n",
    "        aucs_identity_finite.append(compute_auc(nll_sine_identity_finite, nll_line_identity_finite, nll_quad_identity_finite))\n",
    "        aucs_random_infinite.append(compute_auc(nll_sine_random_infinite, nll_line_random_infinite, nll_quad_random_infinite))\n",
    "        aucs_random_finite.append(compute_auc(nll_sine_random_finite, nll_line_random_finite, nll_quad_random_finite))\n",
    "        aucs_random_infinite2.append(compute_auc(nll_sine_random_infinite2, nll_line_random_infinite2, nll_quad_random_infinite2))\n",
    "        aucs_random_finite2.append(compute_auc(nll_sine_random_finite2, nll_line_random_finite2, nll_quad_random_finite2))\n",
    "        aucs_random_infinite3.append(compute_auc(nll_sine_random_infinite3, nll_line_random_infinite3, nll_quad_random_infinite3))\n",
    "        aucs_random_finite3.append(compute_auc(nll_sine_random_finite3, nll_line_random_finite3, nll_quad_random_finite3))\n",
    "        aucs_random_infinite4.append(compute_auc(nll_sine_random_infinite4, nll_line_random_infinite4, nll_quad_random_infinite4))\n",
    "        aucs_random_finite4.append(compute_auc(nll_sine_random_finite4, nll_line_random_finite4, nll_quad_random_finite4))\n",
    "        aucs_random_infinite5.append(compute_auc(nll_sine_random_infinite5, nll_line_random_infinite5, nll_quad_random_infinite5))\n",
    "        aucs_random_finite5.append(compute_auc(nll_sine_random_finite5, nll_line_random_finite5, nll_quad_random_finite5))\n",
    "\n",
    "    return Ks, np.array(aucs_fim_infinite), np.array(aucs_fim_finite), np.array(aucs_random_infinite), np.array(aucs_random_finite), np.array(aucs_identity_infinite), np.array(aucs_identity_finite), np.array(aucs_random_infinite2), np.array(aucs_random_finite2), np.array(aucs_random_infinite3), np.array(aucs_random_finite3), np.array(aucs_random_infinite4), np.array(aucs_random_finite4), np.array(aucs_random_infinite5), np.array(aucs_random_finite5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "3484e981",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "key = random.PRNGKey(0)\n",
    "Ks, aucs_fim_infinite, aucs_fim_finite, aucs_random_infinite, aucs_random_finite, aucs_identity_infinite, aucs_identity_finite, aucs_random_infinite2, aucs_random_finite2, aucs_random_infinite3, aucs_random_finite3, aucs_random_infinite4, aucs_random_finite4, aucs_random_infinite5, aucs_random_finite5 = auc_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9505d947",
   "metadata": {},
   "outputs": [],
   "source": [
    "aucs_random_infinite_all = np.concatenate( (aucs_random_infinite[:, np.newaxis],\n",
    "                 aucs_random_infinite2[:, np.newaxis],\n",
    "                 aucs_random_infinite3[:, np.newaxis],\n",
    "                 aucs_random_infinite4[:, np.newaxis],\n",
    "                 aucs_random_infinite5[:, np.newaxis]\n",
    "                ), axis=1)\n",
    "\n",
    "aucs_random_finite_all = np.concatenate( (aucs_random_finite[:, np.newaxis],\n",
    "                 aucs_random_finite2[:, np.newaxis],\n",
    "                 aucs_random_finite3[:, np.newaxis],\n",
    "                 aucs_random_finite4[:, np.newaxis],\n",
    "                 aucs_random_finite5[:, np.newaxis]\n",
    "                ), axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "0de82a76",
   "metadata": {},
   "outputs": [],
   "source": [
    "aucs_random_infinite_means = np.mean(aucs_random_infinite_all, axis=1)\n",
    "aucs_random_infinite_ci95 = []\n",
    "for k in range(10):\n",
    "    aucs_random_infinite_ci95.append(ci95(aucs_random_infinite_all[k]))\n",
    "aucs_random_infinite_ci95 = np.array(aucs_random_infinite_ci95)\n",
    "\n",
    "aucs_random_finite_means = np.mean(aucs_random_finite_all, axis=1)\n",
    "aucs_random_finite_ci95 = []\n",
    "for k in range(10):\n",
    "    aucs_random_finite_ci95.append(ci95(aucs_random_finite_all[k]))\n",
    "aucs_random_finite_ci95 = np.array(aucs_random_finite_ci95)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "b551dc89",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(Ks, aucs_fim_infinite, \"--\", color=\"tab:blue\", label=\"UNLIMTD-F (infinite)\")\n",
    "plt.plot(Ks, aucs_fim_finite, \"-\", color=\"royalblue\", label=\"UNLIMTD-F (finite)\")\n",
    "plt.plot(Ks, aucs_random_infinite_means, \"--\", color=\"tab:orange\", label=\"UNLIMTD-R (infinite)\")\n",
    "plt.fill_between(Ks, aucs_random_infinite_means - aucs_random_infinite_ci95, aucs_random_infinite_means + aucs_random_infinite_ci95, color=\"tab:orange\", alpha=0.2)\n",
    "plt.plot(Ks, aucs_random_finite_means, \"-\", color=\"chocolate\", label=\"UNLIMTD-R (finite)\")\n",
    "plt.fill_between(Ks, aucs_random_finite_means - aucs_random_finite_ci95, aucs_random_finite_means + aucs_random_finite_ci95, color=\"chocolate\", alpha=0.2)\n",
    "plt.plot(Ks, aucs_identity_infinite, \"--\", color=\"tab:purple\", label=\"UNLIMTD-I (infinite)\")\n",
    "plt.plot(Ks, aucs_identity_finite, \"-\", color=\"purple\", label=\"UNLIMTD-I (finite\")\n",
    "plt.gca().set_ylim([0.5, 1])\n",
    "plt.gca().set_xlabel(\"$K$\")\n",
    "plt.gca().set_ylabel(\"AUC-ROC score\")\n",
    "plt.legend()\n",
    "plt.savefig(\"plots/single_auc.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0d1d2118",
   "metadata": {},
   "source": [
    "## MSE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6577bca7",
   "metadata": {},
   "source": [
    "### Executing our algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "4d5bf5d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mse_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    mses_fim_infinite = []\n",
    "    mses_fim_finite = []\n",
    "    mses_random_infinite = []\n",
    "    mses_random_finite = []\n",
    "    mses_identity_infinite = []\n",
    "    mses_identity_finite = []\n",
    "    \n",
    "    ci95s_fim_infinite = []\n",
    "    ci95s_fim_finite = []\n",
    "    ci95s_random_infinite = []\n",
    "    ci95s_random_finite = []\n",
    "    ci95s_identity_infinite = []\n",
    "    ci95s_identity_finite = []\n",
    "    \n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey_1 = random.split(key)\n",
    "        \n",
    "        mse_fim_infinite = test.test_error_one_kernel(subkey_1, kernel_fim_infinite, kernel_self_fim_infinite, jac_fim_infinite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_infinite[\"trained_mean\"])\n",
    "        mse_fim_finite = test.test_error_one_kernel(subkey_1, kernel_fim_finite, kernel_self_fim_finite, jac_fim_finite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_finite[\"trained_mean\"])\n",
    "        mse_identity_infinite = test.test_error_one_kernel(subkey_1, kernel_identity_infinite, kernel_self_identity_infinite, jac_identity_infinite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_infinite[\"intermediate_mean\"])\n",
    "        mse_identity_finite = test.test_error_one_kernel(subkey_1, kernel_identity_finite, kernel_self_identity_finite, jac_identity_finite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_identity_finite[\"intermediate_mean\"])\n",
    "        mse_random_infinite = test.test_error_one_kernel(subkey_1, kernel_random_infinite, kernel_self_random_infinite, jac_random_infinite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite[\"trained_mean\"])\n",
    "        mse_random_finite = test.test_error_one_kernel(subkey_1, kernel_random_finite, kernel_self_random_finite, jac_random_finite, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite[\"trained_mean\"])\n",
    "        mse_random_infinite2 = test.test_error_one_kernel(subkey_1, kernel_random_infinite2, kernel_self_random_infinite2, jac_random_infinite2, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite2[\"trained_mean\"])\n",
    "        mse_random_finite2 = test.test_error_one_kernel(subkey_1, kernel_random_finite2, kernel_self_random_finite2, jac_random_finite2, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite2[\"trained_mean\"])\n",
    "        mse_random_infinite3 = test.test_error_one_kernel(subkey_1, kernel_random_infinite3, kernel_self_random_infinite3, jac_random_infinite3, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite3[\"trained_mean\"])\n",
    "        mse_random_finite3 = test.test_error_one_kernel(subkey_1, kernel_random_finite3, kernel_self_random_finite3, jac_random_finite3, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite3[\"trained_mean\"])\n",
    "        mse_random_infinite4 = test.test_error_one_kernel(subkey_1, kernel_random_infinite4, kernel_self_random_infinite4, jac_random_infinite4, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite4[\"trained_mean\"])\n",
    "        mse_random_finite4 = test.test_error_one_kernel(subkey_1, kernel_random_finite4, kernel_self_random_finite4, jac_random_finite4, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite4[\"trained_mean\"])\n",
    "        mse_random_infinite5 = test.test_error_one_kernel(subkey_1, kernel_random_infinite5, kernel_self_random_infinite5, jac_random_infinite5, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_infinite5[\"trained_mean\"])\n",
    "        mse_random_finite5 = test.test_error_one_kernel(subkey_1, kernel_random_finite5, kernel_self_random_finite5, jac_random_finite5, dataset_sines_infinite.get_test_batch, dataset_sines_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_random_finite5[\"trained_mean\"])\n",
    "\n",
    "        mses_fim_infinite.append(np.mean(mse_fim_infinite))\n",
    "        ci95s_fim_infinite.append(ci95(mse_fim_infinite))\n",
    "        \n",
    "        mses_fim_finite.append(np.mean(mse_fim_finite))\n",
    "        ci95s_fim_finite.append(ci95(mse_fim_finite))\n",
    "        \n",
    "        mse_random_infinite_all = np.concatenate( (mse_random_infinite, mse_random_infinite2, mse_random_infinite3, mse_random_infinite4, mse_random_infinite5) )\n",
    "        mses_random_infinite.append(np.mean(mse_random_infinite_all))\n",
    "        ci95s_random_infinite.append(ci95(mse_random_infinite_all))\n",
    "        \n",
    "        mse_random_finite_all = np.concatenate( (mse_random_finite, mse_random_finite2, mse_random_finite3, mse_random_finite4, mse_random_finite5) )\n",
    "        mses_random_finite.append(np.mean(mse_random_finite_all))\n",
    "        ci95s_random_finite.append(ci95(mse_random_finite_all))\n",
    "        \n",
    "        mses_identity_infinite.append(np.mean(mse_identity_infinite))\n",
    "        ci95s_identity_infinite.append(ci95(mse_identity_infinite))\n",
    "        \n",
    "        mses_identity_finite.append(np.mean(mse_identity_finite))\n",
    "        ci95s_identity_finite.append(ci95(mse_identity_finite))\n",
    "\n",
    "    return Ks, np.array(mses_fim_infinite), np.array(ci95s_fim_infinite), np.array(mses_fim_finite), np.array(ci95s_fim_finite), np.array(mses_random_infinite), np.array(ci95s_random_infinite), np.array(mses_random_finite), np.array(ci95s_random_finite), np.array(mses_identity_infinite), np.array(ci95s_identity_infinite), np.array(mses_identity_finite), np.array(ci95s_identity_finite),"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "8929e972",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "Ks, mses_fim_infinite, ci95s_fim_infinite, mses_fim_finite, ci95s_fim_finite, mses_random_infinite, ci95s_random_infinite, mses_random_finite, ci95s_random_finite, mses_identity_infinite, ci95s_identity_infinite, mses_identity_finite, ci95s_identity_finite = mse_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e59c912",
   "metadata": {},
   "source": [
    "### Executing MAML"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "fa7df92c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = models.small_network(40, \"relu\", 1)\n",
    "\n",
    "def apply_fn(params, inputs):\n",
    "    return model.apply({\"params\": params}, inputs)\n",
    "\n",
    "key, key_init0, key_init1 = random.split(key, 3)\n",
    "batch = dataset_sines_infinite.get_test_batch(key, 10, 10, 10, 0.05)\n",
    "init_vars = model.init(key_init1, batch[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "78bb3d04",
   "metadata": {},
   "outputs": [],
   "source": [
    "def error_fn(predictions, gt):\n",
    "    return np.mean( (predictions - gt)**2 )\n",
    "\n",
    "def inner_loss(current_params, x_a, y_a, apply_fn):\n",
    "    predictions = apply_fn(current_params, x_a)\n",
    "    \n",
    "    return error_fn(predictions, y_a)\n",
    "\n",
    "def inner_updates(current_params, x_a, y_a, n_updates, inner_lr, apply_fn):\n",
    "    def f(parameters, x):\n",
    "        inner_gradients = grad(inner_loss)(parameters, x_a, y_a, apply_fn)\n",
    "        parameters = tree_map(partial(gd_step0, inner_lr), parameters, inner_gradients)\n",
    "        \n",
    "        return parameters, None\n",
    "    \n",
    "    updated_params, _ = scan(f, current_params, None, n_updates)\n",
    "    \n",
    "    return updated_params\n",
    "\n",
    "def gd_step0(inner_lr, param_value, param_grad):\n",
    "    return param_value - inner_lr * param_grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "a7037164",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_maml(key, apply_fn, params, n_updates_test, inner_lr, n_test_tasks, K, L, noise, error_fn):\n",
    "    x_a, y_a, x_b, y_b = dataset_sines_infinite.get_test_batch(key, n_test_tasks, K, L, noise)\n",
    "    \n",
    "    def f(carry, task):\n",
    "        x_a, y_a, x_b, y_b = task\n",
    "        \n",
    "        updated_params = inner_updates(params, x_a, y_a, n_updates_test, inner_lr, apply_fn)\n",
    "        predictions = apply_fn(updated_params, x_b)\n",
    "        \n",
    "        return None, error_fn(predictions, y_b)\n",
    "    \n",
    "    _, errors = scan(f, None, (x_a, y_a, x_b, y_b))\n",
    "    return errors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "e68bcab3",
   "metadata": {},
   "outputs": [],
   "source": [
    "config = output_maml_infinite[\"config\"]\n",
    "\n",
    "def mse_maml_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    mses_maml_infinite = []\n",
    "    ci95s_maml_infinite = []\n",
    "    mses_maml_finite = []\n",
    "    ci95s_maml_finite = []\n",
    "    \n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey_1 = random.split(key)\n",
    "        errors_infinite = test_maml(subkey_1, apply_fn, output_maml_infinite[\"trained_params\"], config[\"n_updates_test\"], config[\"inner_lr\"], 1000, K, 100, 0.05, error_fn)\n",
    "        errors_finite = test_maml(subkey_1, apply_fn, output_maml_finite[\"trained_params\"], config[\"n_updates_test\"], config[\"inner_lr\"], 1000, K, 100, 0.05, error_fn)\n",
    "\n",
    "        mses_maml_infinite.append(np.mean(errors_infinite))\n",
    "        ci95s_maml_infinite.append(ci95(errors_infinite))\n",
    "        mses_maml_finite.append(np.mean(errors_finite))\n",
    "        ci95s_maml_finite.append(ci95(errors_finite))\n",
    "\n",
    "    return Ks, np.array(mses_maml_infinite), np.array(ci95s_maml_infinite), np.array(mses_maml_finite), np.array(ci95s_maml_finite)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "7e1afc04",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "key, subkey = random.split(key)\n",
    "Ks, mses_maml_infinite, ci95s_maml_infinite, mses_maml_finite, ci95s_maml_finite = mse_maml_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2c64905e",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "3891534d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(Ks, mses_fim_infinite, \"--\", color=\"tab:blue\", label=\"UNLIMTD-F (infinite)\")\n",
    "plt.fill_between(Ks, mses_fim_infinite - ci95s_fim_infinite, mses_fim_infinite + ci95s_fim_infinite, color='tab:blue', alpha=0.2)\n",
    "plt.plot(Ks, mses_fim_finite, \"royalblue\", label=\"UNLIMTD-F (finite)\")\n",
    "plt.fill_between(Ks, mses_fim_finite - ci95s_fim_finite, mses_fim_finite + ci95s_fim_finite, color='royalblue', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks, mses_random_infinite, \"--\", color=\"tab:orange\", label=\"UNLIMTD-R (infinite)\")\n",
    "plt.fill_between(Ks, mses_random_infinite - ci95s_random_infinite, mses_random_infinite + ci95s_random_infinite, color='tab:orange', alpha=0.2)\n",
    "plt.plot(Ks, mses_random_finite, \"chocolate\", label=\"UNLIMTD-R (finite)\")\n",
    "plt.fill_between(Ks, mses_random_finite - ci95s_random_finite, mses_random_finite + ci95s_random_finite, color='chocolate', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks, mses_identity_infinite, \"--\", color=\"tab:purple\", label=\"UNLIMTD-I (infinite)\")\n",
    "plt.fill_between(Ks, mses_identity_infinite - ci95s_identity_infinite, mses_identity_infinite + ci95s_identity_infinite, color='tab:purple', alpha=0.3)\n",
    "plt.plot(Ks, mses_identity_finite, \"purple\", label=\"UNLIMTD-I (finite)\")\n",
    "plt.fill_between(Ks, mses_identity_finite - ci95s_identity_finite, mses_identity_finite + ci95s_identity_finite, color='purple', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks[1:], mses_maml_infinite[1:], \"k--\", label=\"MAML (infinite)\")\n",
    "plt.fill_between(Ks[1:], mses_maml_infinite[1:] - ci95s_maml_infinite[1:], mses_maml_infinite[1:] + ci95s_maml_infinite[1:], color='k', alpha=0.2)\n",
    "plt.plot(Ks, mses_maml_finite, \"k\", label=\"MAML (finite)\")\n",
    "plt.fill_between(Ks, mses_maml_finite - ci95s_maml_finite, mses_maml_finite + ci95s_maml_finite, color='k', alpha=0.2)\n",
    "\n",
    "plt.gca().set_ylim([0, 0.5])\n",
    "plt.gca().set_xlabel(\"$K$\")\n",
    "plt.gca().set_ylabel(\"MSE\")\n",
    "plt.legend()\n",
    "plt.savefig(\"plots/single_mse.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8b1f24f7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.13"
  },
  "latex_envs": {
   "LaTeX_envs_menu_present": true,
   "autoclose": false,
   "autocomplete": true,
   "bibliofile": "biblio.bib",
   "cite_by": "apalike",
   "current_citInitial": 1,
   "eqLabelWithNumbers": true,
   "eqNumInitial": 1,
   "hotkeys": {
    "equation": "Ctrl-E",
    "itemize": "Ctrl-I"
   },
   "labels_anchors": false,
   "latex_user_defs": false,
   "report_style_numbering": false,
   "user_envs_cfg": false
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
