{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "fa20c8f9",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "c826edbc",
   "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 dataset_multi_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": 2,
   "id": "c6da0c50",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2022-08-27 14:46:23.114933: 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:46:23.114979: 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": 3,
   "id": "8335cd00",
   "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": "8a39c0b7",
   "metadata": {},
   "source": [
    "## Loading results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b8228e88",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/multi_mixture_fim.pickle\", \"rb\") as handle:\n",
    "    output_fim_mixture = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4b2a7b5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/multi_single_fim.pickle\", \"rb\") as handle:\n",
    "    output_fim_single = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d90d58f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"logs_final/maml_mixed.pickle\", \"rb\") as handle:\n",
    "    output_maml_mixed = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d6f6a948",
   "metadata": {},
   "source": [
    "## Loading network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a3e946e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = models.small_network(40, \"relu\", 1)\n",
    "apply_fn = utils.apply_fn_wrapper(model.apply, False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c010565f",
   "metadata": {},
   "source": [
    "## Computing kernels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bf935c2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel1_fim_mixture, kernel1_self_fim_mixture, jac_fim_mixture = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_fim_mixture[\"trained_params\"], output_fim_mixture[\"trained_scale1\"], output_fim_mixture[\"trained_batch_stats\"], output_fim_mixture[\"proj1\"])\n",
    "kernel2_fim_mixture, kernel2_self_fim_mixture, jac_fim_mixture = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_fim_mixture[\"trained_params\"], output_fim_mixture[\"trained_scale2\"], output_fim_mixture[\"trained_batch_stats\"], output_fim_mixture[\"proj2\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "950cf959",
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel_fim_single, kernel_self_fim_single, jac_fim_single = ntk.get_kernel_and_jac_lowdim_cov(apply_fn, output_fim_single[\"trained_params\"], output_fim_single[\"trained_scale\"], output_fim_single[\"trained_batch_stats\"], output_fim_single[\"proj\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "37ad58e6",
   "metadata": {},
   "source": [
    "## AUC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7fdb324a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def true_score_mixed(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",
    "    y_true = y_true.at[nll_sines.shape[0]:nll_sines.shape[0]+nll_lines.shape[0]].set(np.array([0]*nll_lines.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_mixed(nll_sines, nll_lines, nll_quad)\n",
    "    return roc_auc_score(y_true, y_score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "5065e227",
   "metadata": {},
   "outputs": [],
   "source": [
    "def auc_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    aucs_fim_mixture = []\n",
    "    aucs_fim_single = []\n",
    "\n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey, subkey_1 = random.split(key, 3)\n",
    "        nll_sine_fim_mixture = test.test_nll_two_kernels(subkey, kernel1_self_fim_mixture, kernel2_self_fim_mixture, jac_fim_mixture, jac_fim_mixture, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean1=output_fim_mixture[\"trained_mean1\"], current_mean2=output_fim_mixture[\"trained_mean2\"])\n",
    "        nll_sine_fim_single = test.test_nll_one_kernel(subkey_1, kernel_self_fim_single, jac_fim_single, dataset_sines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_single[\"trained_mean\"])\n",
    "        \n",
    "        nll_line_fim_mixture = test.test_nll_two_kernels(subkey, kernel1_self_fim_mixture, kernel2_self_fim_mixture, jac_fim_mixture, jac_fim_mixture, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean1=output_fim_mixture[\"trained_mean1\"], current_mean2=output_fim_mixture[\"trained_mean2\"])\n",
    "        nll_line_fim_single = test.test_nll_one_kernel(subkey_1, kernel_self_fim_single, jac_fim_single, dataset_lines_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_single[\"trained_mean\"])\n",
    "        \n",
    "        nll_quad_fim_mixture = test.test_nll_two_kernels(subkey, kernel1_self_fim_mixture, kernel2_self_fim_mixture, jac_fim_mixture, jac_fim_mixture, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean1=output_fim_mixture[\"trained_mean1\"], current_mean2=output_fim_mixture[\"trained_mean2\"])\n",
    "        nll_quad_fim_single = test.test_nll_one_kernel(subkey_1, kernel_self_fim_single, jac_fim_single, dataset_quads_infinite.get_test_batch, K=K, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_single[\"trained_mean\"])\n",
    "\n",
    "        aucs_fim_mixture.append(compute_auc(nll_sine_fim_mixture, nll_line_fim_mixture, nll_quad_fim_mixture))\n",
    "        aucs_fim_single.append(compute_auc(nll_sine_fim_single, nll_line_fim_single, nll_quad_fim_single))\n",
    "        \n",
    "    return Ks, np.array(aucs_fim_mixture), np.array(aucs_fim_single)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "4f6829e8",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "key = random.PRNGKey(0)\n",
    "Ks, aucs_fim_mixture, aucs_fim_single = auc_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "3ebc3755",
   "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_mixture, \"royalblue\", label=\"UNLIMTD-F (mixture)\")\n",
    "plt.plot(Ks, aucs_fim_single, \"--\", color=\"tab:blue\", label=\"UNLIMTD-F (single GP)\")\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/multi_auc.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06b964b2",
   "metadata": {},
   "source": [
    "## MSE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b978681f",
   "metadata": {},
   "source": [
    "### Executing our algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "6dac0610",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mse_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    mses_fim_mixture = []\n",
    "    mses_fim_single = []\n",
    "    \n",
    "    ci95s_fim_mixture = []\n",
    "    ci95s_fim_single = []\n",
    "    \n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey_1 = random.split(key)\n",
    "        \n",
    "        mse_fim_mixture = test.test_error_two_kernels(subkey_1, kernel1_fim_mixture, kernel1_self_fim_mixture, kernel2_fim_mixture, kernel2_self_fim_mixture, jac_fim_mixture, jac_fim_mixture, dataset_quads_infinite.get_test_batch, dataset_quads_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean1=output_fim_mixture[\"trained_mean1\"], current_mean2=output_fim_mixture[\"trained_mean2\"])\n",
    "        mse_fim_single = test.test_error_one_kernel(subkey_1, kernel_fim_single, kernel_self_fim_single, jac_fim_single, dataset_quads_infinite.get_test_batch, dataset_quads_infinite.error_fn, K=K, L=100, n_tasks=1000, data_noise=0.05, maddox_noise=0.05, current_mean=output_fim_single[\"trained_mean\"])\n",
    "        \n",
    "        mses_fim_mixture.append(np.mean(mse_fim_mixture))\n",
    "        ci95s_fim_mixture.append(ci95(mse_fim_mixture))\n",
    "        \n",
    "        mses_fim_single.append(np.mean(mse_fim_single))\n",
    "        ci95s_fim_single.append(ci95(mse_fim_single))\n",
    "\n",
    "    return Ks, np.array(mses_fim_mixture), np.array(ci95s_fim_mixture), np.array(mses_fim_single), np.array(ci95s_fim_single)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "a36d544e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "Ks, mses_fim_mixture, ci95s_fim_mixture, mses_fim_single, ci95s_fim_single = mse_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65536712",
   "metadata": {},
   "source": [
    "### Executing MAML"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "f4b65a49",
   "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": 27,
   "id": "74b7ad91",
   "metadata": {},
   "outputs": [],
   "source": [
    "# copied from maml_toy.ipynb\n",
    "\n",
    "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": 28,
   "id": "4716fecd",
   "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_multi_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": 29,
   "id": "8c5c5fcc",
   "metadata": {},
   "outputs": [],
   "source": [
    "config = output_maml_mixed[\"config\"]\n",
    "\n",
    "def mse_maml_f_K(key, min_K, max_K):\n",
    "    Ks = range(min_K, max_K)\n",
    "    mses_maml_mixed = []\n",
    "    ci95s_maml_mixed = []\n",
    "    \n",
    "    for K in Ks:\n",
    "        print(f\"Computation for K={K}\")\n",
    "        key, subkey_1 = random.split(key)\n",
    "        errors_mixed = test_maml(subkey_1, apply_fn, output_maml_mixed[\"trained_params\"], config[\"n_updates_test\"], config[\"inner_lr\"], 1000, K, 100, 0.05, error_fn)\n",
    "\n",
    "        mses_maml_mixed.append(np.mean(errors_mixed))\n",
    "        ci95s_maml_mixed.append(ci95(errors_mixed))\n",
    "\n",
    "    return Ks, np.array(mses_maml_mixed), np.array(ci95s_maml_mixed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "762e8415",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation for K=1\n"
     ]
    }
   ],
   "source": [
    "key, subkey = random.split(key)\n",
    "Ks, mses_maml_mixed, ci95s_maml_mixed = mse_maml_f_K(key, 1, 11)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1dcda544",
   "metadata": {},
   "source": [
    "### MMAML"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "9910766f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Yes, the results are hard-coded\n",
    "# To obtain these results, train MMAML as explained in readme.md\n",
    "# Then, test MMAML using the command specified in readme.md\n",
    "mses_mmaml = np.array( [3.730254, 2.929165, 1.855181, 0.889051, 0.285268, 0.083995, 0.019562, 0.009378, 0.003262, 0.002573])\n",
    "ci95s_mmaml = np.array( [8.848934e-02, 7.866433e-02, 7.536615e-02, 6.057159e-02, 3.437318e-02, 2.199177e-02, 7.254124e-03, 5.865512e-03, 3.095880e-04, 2.571919e-04])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "79c2426a",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "824539fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9Ol89NFHVFdXA8lVSlpcXMyoUaNixu69914eeOABAGbPnk1BQYERXquoqKBfv377fG70OW+88QYA06ZNo0+fPjF7ac4880ycTierVq1i3LhxjBs3jqysLPr378+4ceM4+eSTKS4uxm63c8QRRzB8+HAmTpzICy+8sM+fY9q0aQwdOtR4vej7t0RKyYknnhgj5Afivffe4/7779/vOXPmzDHyUR3BBx98wD333NNhr3cgTCGIMxY9cncaCCSPEEBkY1m1p4k53xSzuawhqRLG6enp+P1+SkpKePfddxFC4PV6O2xTX1paGj169IgJN1100UX4/X7efPNNY8zhcFBcXNwh79nVqKrKc889d8jPz8jI4OuvvwagpqaG3bt3AzB69GiWL1/O8uXLmTlzJn/7299Yvnw5//nPfwAYOHAg33//PevWrWPevHk8/PDDPP/88/t8n5dfftl4vWhJb0s+/PBDxo4di8vlOui5z5w5k9tua+OiH8OhCEG06KA9zjjjDN57770OW8keCLN8NM5Ym4XA50+uEEGGXaeszsc7y3ciBAzIS0NKmRRJTafTSXV1Nd9++y1//vOfmTRpEqqq4vf7O8wHqH///nzzzTfGBaVfv34cffTRvP766/zsZz/DYrEYpaQNDQ04nc6Det3HXq9mc8nhVzi1ZGChhWvPOzy/qBtuuIGHH36YK6+88pCef+GFFzJv3jyOPfZY3nrrLc4++2zWrGnjL7lfBgwYwEMPPcRvfvMbLrvsskOax8svv8xVV10FRFYzp556KsceeyyLFi1i7NixXHbZZdxzzz2UlZXx8ssvM3HiRObMmcOSJUt47LHHmDVrFueccw4/+9nPePLJJ5k/fz5nnXUWS5Ys4Sc/+Ql2u52FCxcyfPhwlixZQk5ODkuWLOHmm2/miy++4N5772XXrl0UFxeTk5PDP/7xD66++mq2b98OwN///neOOeYYhBBMmzaNDz74gPPPP/+QftYfgrkiiDMWrVkImpJrRZBm1VAVQWGGneKKxqSymkhLSyMYDMalhDRKRkYGGRkZMbuNL774YiorK/n000+NMV3XKSkp6bD37Sr69OnDsccey0svvXRIzz/ppJOYP38+oVCIefPmccEFFxzS64wfP57169fv8/hPfvITIzRUWdnWrebrr7/myCOPNB4XFRVx/fXXs3LlStavX88rr7zC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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_mixture, \"royalblue\", label=\"UNLIMTD-F (mixture)\")\n",
    "plt.fill_between(Ks, mses_fim_mixture - ci95s_fim_mixture, mses_fim_mixture + ci95s_fim_mixture, color='royalblue', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks, mses_fim_single, \"--\", color=\"tab:blue\", label=\"UNLIMTD-F (single GP)\")\n",
    "plt.fill_between(Ks, mses_fim_single - ci95s_fim_single, mses_fim_single + ci95s_fim_single, color='tab:blue', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks, mses_mmaml, \"k--\", label=\"MMAML\")\n",
    "plt.fill_between(Ks, mses_mmaml - ci95s_mmaml, mses_mmaml + ci95s_mmaml, color='k', alpha=0.2)\n",
    "\n",
    "plt.plot(Ks, mses_maml_mixed, \"k\", label=\"MAML\")\n",
    "plt.fill_between(Ks, mses_maml_mixed - ci95s_maml_mixed, mses_maml_mixed + ci95s_maml_mixed, 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/multi_mse.pdf\", bbox_inches='tight')"
   ]
  }
 ],
 "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
}
