{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "random_feature_test_train_split.ipynb",
      "provenance": [],
      "machine_shape": "hm"
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU",
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "2789711bbeb742e68b4b76ef39a6f089": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "HBoxView",
            "_dom_classes": [],
            "_model_name": "HBoxModel",
            "_view_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_view_count": null,
            "_view_module_version": "1.5.0",
            "box_style": "",
            "layout": "IPY_MODEL_fd325ba805bc495eb7ab9dd90b40ec59",
            "_model_module": "@jupyter-widgets/controls",
            "children": [
              "IPY_MODEL_edba72dec89c48a89ca2c48abf9c281a",
              "IPY_MODEL_4025d866aa354e66b80686bb22e1412a",
              "IPY_MODEL_c6251e0e1ab9476b90753a8fe34082ac"
            ]
          }
        },
        "fd325ba805bc495eb7ab9dd90b40ec59": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_view_name": "LayoutView",
            "grid_template_rows": null,
            "right": null,
            "justify_content": null,
            "_view_module": "@jupyter-widgets/base",
            "overflow": null,
            "_model_module_version": "1.2.0",
            "_view_count": null,
            "flex_flow": null,
            "width": null,
            "min_width": null,
            "border": null,
            "align_items": null,
            "bottom": null,
            "_model_module": "@jupyter-widgets/base",
            "top": null,
            "grid_column": null,
            "overflow_y": null,
            "overflow_x": null,
            "grid_auto_flow": null,
            "grid_area": null,
            "grid_template_columns": null,
            "flex": null,
            "_model_name": "LayoutModel",
            "justify_items": null,
            "grid_row": null,
            "max_height": null,
            "align_content": null,
            "visibility": null,
            "align_self": null,
            "height": null,
            "min_height": null,
            "padding": null,
            "grid_auto_rows": null,
            "grid_gap": null,
            "max_width": null,
            "order": null,
            "_view_module_version": "1.2.0",
            "grid_template_areas": null,
            "object_position": null,
            "object_fit": null,
            "grid_auto_columns": null,
            "margin": null,
            "display": null,
            "left": null
          }
        },
        "edba72dec89c48a89ca2c48abf9c281a": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "HTMLView",
            "style": "IPY_MODEL_8d7c0c96a4ee4469aafb43a546ebf3a1",
            "_dom_classes": [],
            "description": "",
            "_model_name": "HTMLModel",
            "placeholder": "​",
            "_view_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "value": "Dl Completed...: 100%",
            "_view_count": null,
            "_view_module_version": "1.5.0",
            "description_tooltip": null,
            "_model_module": "@jupyter-widgets/controls",
            "layout": "IPY_MODEL_8b5f906742b84f418c9435e35426a3b1"
          }
        },
        "4025d866aa354e66b80686bb22e1412a": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "ProgressView",
            "style": "IPY_MODEL_2d91316fcd5248e5a447a647ff17ada4",
            "_dom_classes": [],
            "description": "",
            "_model_name": "FloatProgressModel",
            "bar_style": "success",
            "max": 4,
            "_view_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "value": 4,
            "_view_count": null,
            "_view_module_version": "1.5.0",
            "orientation": "horizontal",
            "min": 0,
            "description_tooltip": null,
            "_model_module": "@jupyter-widgets/controls",
            "layout": "IPY_MODEL_69713426f6784d2ca71745b0ab19b1f6"
          }
        },
        "c6251e0e1ab9476b90753a8fe34082ac": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "HTMLView",
            "style": "IPY_MODEL_cf8c93803c3042b6aea0db6143dc1ff9",
            "_dom_classes": [],
            "description": "",
            "_model_name": "HTMLModel",
            "placeholder": "​",
            "_view_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "value": " 4/4 [00:00&lt;00:00,  4.87 file/s]",
            "_view_count": null,
            "_view_module_version": "1.5.0",
            "description_tooltip": null,
            "_model_module": "@jupyter-widgets/controls",
            "layout": "IPY_MODEL_f8c76dd88cb04dd79c197e1a2383b942"
          }
        },
        "8d7c0c96a4ee4469aafb43a546ebf3a1": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "StyleView",
            "_model_name": "DescriptionStyleModel",
            "description_width": "",
            "_view_module": "@jupyter-widgets/base",
            "_model_module_version": "1.5.0",
            "_view_count": null,
            "_view_module_version": "1.2.0",
            "_model_module": "@jupyter-widgets/controls"
          }
        },
        "8b5f906742b84f418c9435e35426a3b1": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_view_name": "LayoutView",
            "grid_template_rows": null,
            "right": null,
            "justify_content": null,
            "_view_module": "@jupyter-widgets/base",
            "overflow": null,
            "_model_module_version": "1.2.0",
            "_view_count": null,
            "flex_flow": null,
            "width": null,
            "min_width": null,
            "border": null,
            "align_items": null,
            "bottom": null,
            "_model_module": "@jupyter-widgets/base",
            "top": null,
            "grid_column": null,
            "overflow_y": null,
            "overflow_x": null,
            "grid_auto_flow": null,
            "grid_area": null,
            "grid_template_columns": null,
            "flex": null,
            "_model_name": "LayoutModel",
            "justify_items": null,
            "grid_row": null,
            "max_height": null,
            "align_content": null,
            "visibility": null,
            "align_self": null,
            "height": null,
            "min_height": null,
            "padding": null,
            "grid_auto_rows": null,
            "grid_gap": null,
            "max_width": null,
            "order": null,
            "_view_module_version": "1.2.0",
            "grid_template_areas": null,
            "object_position": null,
            "object_fit": null,
            "grid_auto_columns": null,
            "margin": null,
            "display": null,
            "left": null
          }
        },
        "2d91316fcd5248e5a447a647ff17ada4": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "StyleView",
            "_model_name": "ProgressStyleModel",
            "description_width": "",
            "_view_module": "@jupyter-widgets/base",
            "_model_module_version": "1.5.0",
            "_view_count": null,
            "_view_module_version": "1.2.0",
            "bar_color": null,
            "_model_module": "@jupyter-widgets/controls"
          }
        },
        "69713426f6784d2ca71745b0ab19b1f6": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_view_name": "LayoutView",
            "grid_template_rows": null,
            "right": null,
            "justify_content": null,
            "_view_module": "@jupyter-widgets/base",
            "overflow": null,
            "_model_module_version": "1.2.0",
            "_view_count": null,
            "flex_flow": null,
            "width": null,
            "min_width": null,
            "border": null,
            "align_items": null,
            "bottom": null,
            "_model_module": "@jupyter-widgets/base",
            "top": null,
            "grid_column": null,
            "overflow_y": null,
            "overflow_x": null,
            "grid_auto_flow": null,
            "grid_area": null,
            "grid_template_columns": null,
            "flex": null,
            "_model_name": "LayoutModel",
            "justify_items": null,
            "grid_row": null,
            "max_height": null,
            "align_content": null,
            "visibility": null,
            "align_self": null,
            "height": null,
            "min_height": null,
            "padding": null,
            "grid_auto_rows": null,
            "grid_gap": null,
            "max_width": null,
            "order": null,
            "_view_module_version": "1.2.0",
            "grid_template_areas": null,
            "object_position": null,
            "object_fit": null,
            "grid_auto_columns": null,
            "margin": null,
            "display": null,
            "left": null
          }
        },
        "cf8c93803c3042b6aea0db6143dc1ff9": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_view_name": "StyleView",
            "_model_name": "DescriptionStyleModel",
            "description_width": "",
            "_view_module": "@jupyter-widgets/base",
            "_model_module_version": "1.5.0",
            "_view_count": null,
            "_view_module_version": "1.2.0",
            "_model_module": "@jupyter-widgets/controls"
          }
        },
        "f8c76dd88cb04dd79c197e1a2383b942": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_view_name": "LayoutView",
            "grid_template_rows": null,
            "right": null,
            "justify_content": null,
            "_view_module": "@jupyter-widgets/base",
            "overflow": null,
            "_model_module_version": "1.2.0",
            "_view_count": null,
            "flex_flow": null,
            "width": null,
            "min_width": null,
            "border": null,
            "align_items": null,
            "bottom": null,
            "_model_module": "@jupyter-widgets/base",
            "top": null,
            "grid_column": null,
            "overflow_y": null,
            "overflow_x": null,
            "grid_auto_flow": null,
            "grid_area": null,
            "grid_template_columns": null,
            "flex": null,
            "_model_name": "LayoutModel",
            "justify_items": null,
            "grid_row": null,
            "max_height": null,
            "align_content": null,
            "visibility": null,
            "align_self": null,
            "height": null,
            "min_height": null,
            "padding": null,
            "grid_auto_rows": null,
            "grid_gap": null,
            "max_width": null,
            "order": null,
            "_view_module_version": "1.2.0",
            "grid_template_areas": null,
            "object_position": null,
            "object_fit": null,
            "grid_auto_columns": null,
            "margin": null,
            "display": null,
            "left": null
          }
        }
      }
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "SQOn9-eqvulU"
      },
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import jax.numpy as jnp\n",
        "from jax import grad, vmap, jit\n",
        "from jax.experimental import optimizers \n",
        "from jax import random\n",
        "from google.colab import drive"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "jxz8kczuvw8V"
      },
      "source": [
        "def feature_map(X, N, nonlin):\n",
        "  P,D = X.shape\n",
        "  G = 10/np.sqrt(D) * np.random.standard_normal((N,D))\n",
        "  G = jnp.array(G)\n",
        "  F = nonlin( X @ G.T )\n",
        "  F = F - jnp.mean(F)\n",
        "  return F\n",
        "\n",
        "tanh = lambda x: jnp.tanh(x)\n",
        "linear = lambda x: x\n",
        "relu = lambda x: x * jnp.heaviside(x,0)\n",
        "\n",
        "P = 3000\n",
        "D = 25\n",
        "N = 3200\n",
        "\n",
        "X = np.random.standard_normal((P,D))\n",
        "F_tanh = feature_map(X, N, tanh)\n",
        "F_relu = feature_map(X, N, relu)\n",
        "\n",
        "def spectra(F):\n",
        "  s = jnp.linalg.svd(F, compute_uv=False)\n",
        "  sorted = s.sort()[::-1]\n",
        "  return sorted\n",
        "\n",
        "def sorted_decomp(F, y, square = True):\n",
        "  u, s, _ = jnp.linalg.svd(F)\n",
        "  inds = jnp.argsort(s)[::-1]\n",
        "  s = s[inds]\n",
        "  u = u[:,inds]\n",
        "  vk = (u.T @ y)**2 / np.sum(y**2)\n",
        "  if square == False:\n",
        "    v_non = u.T @ y / np.sqrt(np.sum(y**2))\n",
        "    return s, v_non\n",
        "  return s, vk\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "YeEb4R_qvzru"
      },
      "source": [
        "def theory(s, teach, eta, T, m = 1, noise = 0):\n",
        "    A = jnp.eye(len(s)) - 2*eta*jnp.diag(s) + 1.0*(m+1)/m *eta**2 * jnp.diag(s**2) + 1.0/m * eta**2 * jnp.outer(s, s)\n",
        "    Inv_mat = jnp.linalg.inv(jnp.eye(A.shape[0]) - A)\n",
        "    x = s.copy()\n",
        "    theory_loss = []\n",
        "    for t in range(T):\n",
        "        losst = 0.5 * jnp.dot(x, teach) + 0.5/m * eta**2 * noise**2 * jnp.dot(s, Inv_mat @ (s-x))\n",
        "        theory_loss += [losst]\n",
        "        x = A @ x\n",
        "    return theory_loss\n",
        "\n",
        "\n",
        "def theory_eig(s, teach, eta, t, m=1, noise = 0):\n",
        "  A = jnp.eye(len(s)) - 2*eta*jnp.diag(s) + 1.0*(m+1)/m *eta**2 * jnp.diag(s**2) + 1.0/m * eta**2 * jnp.outer(s, s)\n",
        "  eigA, VA = jnp.linalg.eigh(A)\n",
        "  Inv_mat = jnp.linalg.inv(jnp.eye(A.shape[0]) - A)\n",
        "  left = VA.T @ s\n",
        "  right = VA.T @ teach\n",
        "\n",
        "  Inv_mat = jnp.linalg.inv(jnp.eye(A.shape[0]) - A)\n",
        "  theory_loss = []\n",
        "  \n",
        "  losst = 0.5 * jnp.dot(left, eigA**t * right) + 0.5/m * eta**2 * noise**2 * jnp.dot(s, Inv_mat @ (s - eigA**t * left))\n",
        "  return losst\n",
        "\n",
        "def theory_white(t, eta, N, m=1):\n",
        "  return (1 - 2*eta + (m+1)/m * eta**2 + 1/m *N*eta**2)**t\n",
        "def theory_pop_white(t, eta):\n",
        "  return (1-eta)**(2*t)\n",
        "\n",
        "def theory_var(s, teach, eta, T, m = 1):\n",
        "  A = jnp.eye(len(s)) - 2*eta*jnp.diag(s) + 1.0*(m+1)/m *eta**2 * jnp.diag(s**2) + 1.0/m * eta**2 * jnp.outer(s, s)\n",
        "  B = jnp.eye(len(s))-eta*jnp.outer(s, jnp.ones(len(s)))-eta*jnp.outer(jnp.ones(len(s)),s)+ eta**2 * 1.0*(m+1)/m * jnp.outer(s,s)\n",
        "  B = B - jnp.diag( jnp.diag(B) )\n",
        "  x = teach.copy()\n",
        "  theory_loss = []\n",
        "  for t in range(T): \n",
        "      losst = jnp.dot(s**2, x**2) + jnp.dot(teach*s, jnp.dot(B**(2*t), s*teach) )\n",
        "      #losst = jnp.dot(s**2, x**2)\n",
        "      theory_loss += [losst]\n",
        "      x = A @ x\n",
        "  return theory_loss\n",
        "\n",
        "def batch_theory_split(Sigma_tr):\n",
        "  return"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "UlLK5liTv8qy"
      },
      "source": [
        "def train_fn_split(F, y, F_te, y_te, T, eta, m = 1, noise = 0):\n",
        "  loss = jit( lambda w, X, y: 0.5*jnp.mean( (jnp.dot(X, w)-y)**2 ) )\n",
        "  loss_te = jit( lambda w: 0.5* jnp.mean( (jnp.dot(F_te, w) - y_te)**2  ))\n",
        "  gloss = jit( grad(loss, 0) )\n",
        "  g_test_loss = jit(grad(loss_te))\n",
        "  w = jnp.zeros(F.shape[1])\n",
        "\n",
        "  eta_expt = eta*F.shape[0]\n",
        "  opt_init, opt_update, get_params = optimizers.sgd(eta_expt)\n",
        "  opt_state = opt_init(w)\n",
        "\n",
        "  losses_tr = []\n",
        "  losses_te = []\n",
        "  for t in range(T):\n",
        "    start = (t * m) % F.shape[0]\n",
        "    inds = np.random.choice(F.shape[0], size = m)\n",
        "    opt_state = opt_update(t, gloss(get_params(opt_state),F[inds,:],y[inds]), opt_state)\n",
        "    losses_tr += [loss(get_params(opt_state), F, y)]\n",
        "    losses_te += [loss_te(get_params(opt_state))]\n",
        "    #opt_state = opt_update(t, g_test_loss(get_params(opt_state)), opt_state)\n",
        "  return losses_tr, losses_te"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 185,
          "referenced_widgets": [
            "2789711bbeb742e68b4b76ef39a6f089",
            "fd325ba805bc495eb7ab9dd90b40ec59",
            "edba72dec89c48a89ca2c48abf9c281a",
            "4025d866aa354e66b80686bb22e1412a",
            "c6251e0e1ab9476b90753a8fe34082ac",
            "8d7c0c96a4ee4469aafb43a546ebf3a1",
            "8b5f906742b84f418c9435e35426a3b1",
            "2d91316fcd5248e5a447a647ff17ada4",
            "69713426f6784d2ca71745b0ab19b1f6",
            "cf8c93803c3042b6aea0db6143dc1ff9",
            "f8c76dd88cb04dd79c197e1a2383b942"
          ]
        },
        "id": "Z7ivttbAwFIK",
        "outputId": "c6ba3409-16f7-42ad-d842-c91b3d393725"
      },
      "source": [
        "\n",
        "import tensorflow as tf\n",
        "import tensorflow_datasets as tfds\n",
        "\n",
        "num_tot = 50000\n",
        "num_classes = 10\n",
        "size = 32\n",
        "name = 'mnist'\n",
        "ds = tfds.load(name, split=tfds.Split.TRAIN).shuffle(1024).batch(num_tot)\n",
        "\n",
        "plt.rcParams.update({'font.size': 12})\n",
        "\n",
        "for i,ex in enumerate(ds):\n",
        "  Xtf = ex['image']\n",
        "  image = Xtf.numpy() / 255.0\n",
        "  X = np.reshape(image, (image.shape[0], image.shape[1]*image.shape[2]*image.shape[3]))\n",
        "  X = X / np.outer(np.linalg.norm(X, axis = 1), np.ones(X.shape[1]))\n",
        "  y = ex['label'].numpy()\n",
        "  #y_mat = np.eye(num_classes)[y] \n",
        "  break\n",
        "\n",
        "inds_89 = [i for i in range(y.shape[0]) if y[i]==8 or y[i]==9]\n",
        "X89 = X[inds_89,:]\n",
        "y89 = y[inds_89]\n",
        "y89 = 1.0*(y89==8) -1.0*(y89==9)\n",
        "\n",
        "\"\"\"\n",
        "X89 = X\n",
        "y89 = np.zeros(y.shape)\n",
        "for c in range(10):\n",
        "  if c % 2 ==0:\n",
        "    y89 += 1.0 * (y == c)\n",
        "  else:\n",
        "    y89 += -1.0 * (y == c)\n",
        "\"\"\"\n",
        "\n",
        "ds_test = tfds.load(name, split=tfds.Split.TEST).shuffle(1024).batch(num_tot)\n",
        "\n",
        "for i,ex in enumerate(ds_test):\n",
        "  Xtf = ex['image']\n",
        "  image = Xtf.numpy() / 255.0\n",
        "  X = np.reshape(image, (image.shape[0], image.shape[1]*image.shape[2]*image.shape[3]))\n",
        "  X = X / np.outer(np.linalg.norm(X, axis = 1), np.ones(X.shape[1]))\n",
        "  y = ex['label'].numpy()\n",
        "  #y_mat = np.eye(num_classes)[y] \n",
        "  break\n",
        "\n",
        "inds_89_te = [i for i in range(y.shape[0]) if y[i]==8 or y[i]==9]\n",
        "X89_te = X[inds_89_te,:]\n",
        "y89_te = y[inds_89_te]\n",
        "y89_te = 1.0*(y89_te==8) -1.0*(y89_te==9)\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\u001b[1mDownloading and preparing dataset mnist/3.0.1 (download: 11.06 MiB, generated: 21.00 MiB, total: 32.06 MiB) to /root/tensorflow_datasets/mnist/3.0.1...\u001b[0m\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "WARNING:absl:Dataset mnist is hosted on GCS. It will automatically be downloaded to your\n",
            "local data directory. If you'd instead prefer to read directly from our public\n",
            "GCS bucket (recommended if you're running on GCP), you can instead pass\n",
            "`try_gcs=True` to `tfds.load` or set `data_dir=gs://tfds-data/datasets`.\n",
            "\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "2789711bbeb742e68b4b76ef39a6f089",
              "version_minor": 0,
              "version_major": 2
            },
            "text/plain": [
              "Dl Completed...:   0%|          | 0/4 [00:00<?, ? file/s]"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "\u001b[1mDataset mnist downloaded and prepared to /root/tensorflow_datasets/mnist/3.0.1. Subsequent calls will reuse this data.\u001b[0m\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "CjAlR70d_Hx7",
        "outputId": "8e7c7d6a-1d4a-42be-82dc-ab3b3a3aff61"
      },
      "source": [
        "for i in range(5):\n",
        "  plt.imshow(X89[i,:].reshape((28,28)))\n",
        "  plt.show()\n",
        "  print(y89[i])\n",
        "\n",
        "plt.hist(y89[0:100])\n",
        "plt.show()\n",
        "print(y89.shape)"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAP0AAAD8CAYAAAC8aaJZAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAARyElEQVR4nO3df5BdZX3H8fcnu5vduElMAhgqlCTEYDJRQLOYWsaCjUrNTKo101FErW1trJoZRh1H6RAaNQ4qLeM4tdQgQoyUghisQNWRltQBlLKoQXaMARqDNCGwNYTd/Nhkk2//uDedm0vusz/uuXtveD6vmZ1Jzveec75zks+ee89zz3kUEZhZPiY1uwEzm1gOvVlmHHqzzDj0Zplx6M0y49CbZaa9GTudrM7oorsZuzbLxgB7+iPitOrlhYRe0izgBuAtQD9wRUT8c63Xd9HNUi0rYtdmVsM9cfuOEy0v6kz/FeAQMBs4H7hb0paI6Cto+2ZWkLo/00vqBlYCayJiMCLuA74LvLfebZtZ8Yq4kHcOMBwR2yqWbQEWV75I0ipJvZJ6DzNUwG7NbDyKCP1U4PmqZXuBaZULImJ9RPRERE8HnQXs1szGo4jQDwLTq5ZNBwYK2LaZFayI0G8D2iUtqFh2HuCLeGYtqO7QR8Q+YBPwGUndki4E3gZsrHfbZla8or6R92FgCvAMcAvwIQ/XmbWmQsbpI+K3wNuL2JaZNZa/e2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzBQygaWdBCa1JcttC+cn61v/emZdu3/pnL01az+74F/q2nY91vUvTNa/e+0bk/VZNz+crMfhQ2PuqdEKOdNL2izpoKTB8s+vitiumRWvyLf3qyNiavnnlQVu18wK5M/0ZpkpMvRXS+qXdL+ki6uLklZJ6pXUe5ihAndrZmNRVOg/CZwNnAGsB+6UdNyVoYhYHxE9EdHTQWdBuzWzsSok9BHxYEQMRMRQRGwA7geWF7FtMytWoz7TB6AGbdvM6qCIqG8D0gxgKfCfwDDwTkpv8V8TEdtOtM50zYqlWlbXfrM0wlj77o8srVk7+IaB5Lp9F24YV0uj9fzRg+Ned/qkrmR915H9yfpk1T7/nDJpyrh6OmbNM+cn6z+7cGqyfnR/uvd63BO3PxwRPdXLi/hyTgewDlgIHAG2Am+vFXgza666Qx8RzwIXFNCLmU0Aj9ObZcahN8uMQ2+WGYfeLDO+tbaFtM+bk6w/8YXpyXrfhf9QZDtjcu2eBcn63Z/4w3Fve/frOpL1s7/262R9+IxTatauue365LqLOyYn65992c+T9RWdIwxNN3DIrhaf6c0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzHicfgKNNA6/7M5fJOvfnfl4ke0c5+796VtAr/j6+5P1Od/enax3bntorC39v7O+l64Pj7SB/9lZs/S+az+WXPW2j1+TrHdphFvT42i63gQ+05tlxqE3y4xDb5YZh94sMw69WWYcerPMOPRmmfE4fYEmdXcn6yONw1/ewHH4wUhPJfaVJ/84WT/z6geS9SNj7mjibL/69TVrr9jYn1z3uY+m76e/b196rtan/nJxsn7mN2v/mx/Z/Uxy3fHymd4sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4zH6Qukrs5kvd5x+ANxKFm/dWBuzdoXvvMnyXXnXfHj8bR0Umgbqj1V9UW3/iy57pLJ6enBl0xO/5te/rH0XASvmra6Zu2stU0cp5e0WlKvpCFJN1XVlknaKmm/pHslpZ8UYWZNNdq39zspzUH/9cqFkk4FNgFrgFlAL3BrkQ2aWbFG9fY+IjYBSOoBzqwovQPoi4hvletrgX5JCyNia8G9mlkB6r2QtxjYcuwvEbEPeKK8/DiSVpU/IvQeJv09cDNrnHpDPxXYW7VsLzCt+oURsT4ieiKip4P0BS8za5x6Qz8IVE+lOh0YqHO7ZtYg9Ya+Dzjv2F8kdQPzy8vNrAWN6kKepPbya9uANkldlB43fgdwjaSVwN3AVcAjuV7EizNe1tDtP3DwBZ+ajvPti8+tWZu3Oz0O37YoPb/8c+fVnuMdYNfF6ee7L/hG467j9J/7kmT93/78izVrZ7Wn1/3FocPJ+jv/66+S9an/kX7GwlnXP5isN8Joz/RXAgeATwHvKf/5yoh4FlgJfA7YAywF3tWAPs2sIKMdslsLrK1RuwdYWFxLZtZI/u69WWYcerPMOPRmmXHozTLjW2sLtPXD1d9TKtayKelhrx/9YFfN2n3PzE+uu2b+pmT94q700NWIVtS3en1qD8tduyc9VHn9XW9J1ud96uS7JdlnerPMOPRmmXHozTLj0JtlxqE3y4xDb5YZh94sMx6nL1DXzuYezk+ftqV2MVXL2L1/+tpkfd4vT75x+JH4TG+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y49CbZcbj9AWa96VHk/Ufvm9Ksv7mKQeKbOekMdJjpl86KV0f6THWKfteMTNZ7/rluDfdsnymN8uMQ2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y43H6Ah15/vlk/UM/em+y/vgl64tsZ0x+Pbw/Wf/kk29P1h+7/ZxkfcZ/D9esdf5v+nn+RzvbkvWXrduerG+c++81a5/+0teS617Tm37u/fCup5P1VjSqM72k1ZJ6JQ1Juqli+VxJIWmw4mdNw7o1s7qN9ky/E1gHXAKc6GtlMyKi9q9yM2sZo52ffhOApB7gzIZ2ZGYNVdSFvB2SnpJ0o6RTT/QCSavKHxF6D5P+DGdmjVNv6PuBC4A5wBJgGnDziV4YEesjoiciejrorHO3ZjZedV29j4hBoLf8192SVgO7JE2LiIG6uzOzwhU9Th8N2q6ZFWRUZ3pJ7eXXtgFtkrqAYUpv6Z8DHgNmAl8GNkfE3sa029rapqfnp7/xoq/Xtf1njqTH0t/c+8GatdO+mr6Xv2Mgfc+6Hkg/N/90+pP1eqRH6WHrN1+ffsGVtcfp39CVHnT6+Ip5yfqp61+k4/TAlcAB4FPAe8p/vhI4G/g+MAA8CgwBlxbfppkVZbRDdmuBtTXKtxTVjJk1nj97m2XGoTfLjENvlhmH3iwzvrW2QAdftyBZf0PX5rq2/8DBlyfrZ7yjr67t2wud/sOdyfrJeJeZz/RmmXHozTLj0JtlxqE3y4xDb5YZh94sMw69WWY8Tj9GRy96Tc3aNddfN8LaPtwnm71LTk/Wu7fvmKBOiuMzvVlmHHqzzDj0Zplx6M0y49CbZcahN8uMQ2+WGQ8cj9ETKyfXrJ0/ubGHc25H+jHTk85dXrN29JGtRbczYdoWpZ9TsPf3DzZs391PHWjYtpvFZ3qzzDj0Zplx6M0y49CbZcahN8uMQ2+WGYfeLDMepx+jH77t7xPVlyTX/eiupcn6ginPJOsfnrE9WV/3r9+ove5VlyfXnbHxx8l6I400Dv/Gb/00Wb9z5mPj3veiDR9J1s/ufShZj3HvuXlGPNNL6pR0g6QdkgYk/VzSWyvqyyRtlbRf0r2S5jS2ZTOrx2je3rcDvwEuAl5KaV762yTNlXQqsAlYA8wCeoFbG9SrmRVgxLf3EbGP4+emv0vSdmAJcArQFxHfApC0FuiXtDAiTt7vfZq9iI35Qp6k2cA5QB+wGNhyrFb+BfFEeXn1eqsk9UrqPczQ+Ds2s7qMKfSSOoCbgQ3lM/lUYG/Vy/YC06rXjYj1EdETET0ddI63XzOr06hDL2kSsBE4BKwuLx4Eple9dDowUEh3Zla4UQ3ZSRJwAzAbWB4Rh8ulPuDPKl7XDcwvL39Rmt8xtWbtSBxNrrv5qVck649/4nfTO/9Oupwa0lv1N3ck1719y8XJer235v72L15fs3bpx36QXPfymY8n6xsH0o+pvuX9f1SzNuKQ3PDJOBl12mjP9NcBi4AVEVF5g/EdwKskrZTUBVwFPOKLeGatazTj9HOADwLnA09LGiz/XBYRzwIrgc8Be4ClwLsa2bCZ1Wc0Q3Y7ACXq9wALi2zKzBrH3703y4xDb5YZh94sMw69WWYUMfE3B07XrFiqZRO+3yKc+9Oa1zT5/OyHk+seHeFGzJ6H3pOsP//0C77oeJzHV/xTsp7y5PD+ZH0g6rsL++zE6nft+53kuutuvDRZP+urv0zWj+zZk6y/WN0Ttz8cET3Vy32mN8uMQ2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y40dgj9F9f5d4jPU16XH6SbXvWwLgpxfcPJ6WCnFWe/rx3fV67UOX1ay9/G/T656x5YFk/ch4GsqYz/RmmXHozTLj0JtlxqE3y4xDb5YZh94sMw69WWY8Tj9G0295sGZtxffSzwhYdE/1ZEDH++LpvePqaTQeGkrfy//uO9NTNr9kZ/r8cOaX0t9ROP3wtpq1o0c90j6RfKY3y4xDb5YZh94sMw69WWYcerPMOPRmmXHozTIz4ji9pE7gH4E3AbOAJ4ArIuJ7kuYC24F9Fat8ISI+W3yrLSIxT8BIz1d/dEl608t57Xg6KsQCflLX+hM/e4KN12i+nNMO/Aa4CHgSWA7cJunVFa+ZERHDDejPzAo24tv7iNgXEWsj4tcRcTQi7qJ0dh/hvGVmrWjMn+klzQbOAfoqFu+Q9JSkGyWdWmO9VZJ6JfUeZmic7ZpZvcYUekkdwM3AhojYCvQDFwBzKJ35p5XrLxAR6yOiJyJ6Ouisr2szG7dR33AjaRKwETgErAaIiEHg2F0iuyWtBnZJmhYRA0U3a2b1G1XoJQm4AZgNLI+IwzVeeuwirocCzVrUaM/01wGLgDdFxIFjCyUtBZ4DHgNmAl8GNkdE+h5SM2uaEc/IkuYAHwTOB56WNFj+uQw4G/g+MAA8CgwB6cnEzaypRjzTR8QOSM7ScEtx7ZhZo/mzt1lmHHqzzDj0Zplx6M0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzDj0Zplx6M0y49CbZUaReKRzw3YqPQvsqFh0KqVHb7Ui9zY+7m3siu5rTkScVr2wKaF/QRNSb0T0NLuPE3Fv4+Pexm6i+vLbe7PMOPRmmWmV0K9vdgMJ7m183NvYTUhfLfGZ3swmTquc6c1sgjj0Zplx6M0y09TQS5ol6Q5J+yTtkPTuZvZTSdJmSQcrnvP/qyb2sro8+eeQpJuqasskbZW0X9K95XkKmtqXpLmSouLYDUpaM1F9lXvolHRD+f/VgKSfS3prRb2Zx61mbxNx7EY9l12DfIXS3HizKU2mcbekLRHRl15twqyOiK81uwlgJ7AOuASYcmxheYbgTcAHgDuBzwK3Ar/XzL4qzIiI4QnqpVo78BvgIuBJYDlwm6RXA4M097ilejumcccuIpryA3RTCvw5Fcs2Ap9vVk9V/W0GPtDsPqp6WgfcVPH3VcADVcf0ALCwyX3NpTSvYXuzj1lVn48AK1vluNXoreHHrplv788BhiNiW8WyLcDiJvVzIldL6pd0v6SLm93MCSymdMwAiIh9wBO0zjHcIekpSTeW35U0jaTZlP7P9dFix62qt2MaduyaGfqpwPNVy/ZSmuO+FXyS0lx9Z1D60sSdkuY3t6UXmErpmFVqhWPYD1wAzAGWUOrn5mY1I6mjvP8NEbGVFjpuJ+it4ceumaEfBKZXLZtOaTLMpouIByNiICKGImIDcD+lz16tpCWPYUQMRkRvRAxHxG5gNfAWSc0I1SRKHxsPlfuAFjluJ+ptIo5dM0O/DWiXtKBi2Xkc/xanlQTpiTyboY/SMQNAUjcwn9Y7hse+9jmh/98kCbiB0oXilRFxuFxq+nFL9Fat8GPXtNCXP0dtAj4jqVvShcDbKP3maypJMyRdIqlLUnt5Wu4/oDQtdzP6aZfUBbQBbcf6Au4AXiVpZbl+FfBI+W1i0/qStFTSKyVNknQK8GVgc0RUv6VutOuARcCKiDhQsbypxy3V24QcuyZfTZ0FfAfYR2no4t3N7Keir9OAhyi93XsO+Anw5ib2s5bSb/zKn7Xl2puArZSuPm8G5ja7L+BSYHv533UX8A3g9Ak+ZnPK/Ryk9Hb+2M9lLXDcavY2EcfON9yYZcZfwzXLjENvlhmH3iwzDr1ZZhx6s8w49GaZcejNMuPQm2Xm/wDm9Yl7zV5eOAAAAABJRU5ErkJggg==\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "1.0\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "1.0\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAP0AAAD8CAYAAAC8aaJZAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAP5UlEQVR4nO3de4xc5X3G8e9j78YmaxtjTI0KxcYuxlwSaL3gJCQBBRIUS2koblMIkKCKmIZsFSWCmKRALAKlubSopIHUiosBUcolJirQIAUV0xYS0jXFKBs5dizHQCCAudi7xqzX9q9/zBgNg+fd8c6Zi3mfjzSS9/zmnPPT8T57zsw7c15FBGaWj3HtbsDMWsuhN8uMQ2+WGYfeLDMOvVlmHHqzzHS1Y6fv0oSYSE87dm2WjUFe3RwRh1QvLyT0kqYBy4GPAZuBr0bEv9Z6/kR6WKDTi9i1mdXwUNyzaW/LizrTfw/YAcwATgQekLQmIgYK2r6ZFaTh1/SSeoBFwJURMRQR/wP8O3BBo9s2s+IV8UbeXGBnRKyrWLYGOK7ySZIWS+qX1D/CcAG7NbOxKCL0k4CtVcu2AJMrF0TEsojojYjebiYUsFszG4siQj8ETKlaNgUYLGDbZlawIkK/DuiSdFTFshMAv4ln1oEaDn1EbANWAldL6pF0CvBJ4LZGt21mxSvqE3mXAAcALwJ3AJ/3cJ1ZZypknD4iXgHOKmJbZtZc/uy9WWYcerPMOPRmmXHozTLj0JtlxqE3y4xDb5YZh94sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4xDb5YZh94sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4xDb5YZh94sMw69WWYcerPMOPRmmXHozTJTyASWZo1QV/rXcOTUE5L1A7/+dLJ++R/8R83al77Sl1x30t2PJ+v7o0LO9JJWSXpD0lD58asitmtmxSvy8r4vIiaVH0cXuF0zK5Bf05tlpsjQXydps6RHJZ1WXZS0WFK/pP4RhgvcrZnti6JCvwSYDRwGLAPukzSn8gkRsSwieiOit5sJBe3WzPZVIaGPiMcjYjAihiPiFuBRYGER2zazYjXrNX0AatK2zawBDY/TS5oKLAAeAXYCfwF8GPhio9u2d45dp/1xzdpHv/vfyXWXHLy8wb1316wMHjE+ueakBvfciYr4cE43cA0wD9gFrAXOioh1BWzbzArWcOgj4iXgpAJ6MbMW8Di9WWYcerPMOPRmmXHozTLjr9ZaIZ7/8geS9SUX31mzdt7kl5Pr9v12QbL+4nB6YG3rjok1a7//T6uT60ayun/ymd4sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4zH6Q0Y/TbU67/Tm6w/cva3kvWJqn17hbm3Xppc96h/3Jisn/aT9cn6h95d+wufVx/wkeS6u4bfebd285neLDMOvVlmHHqzzDj0Zplx6M0y49CbZcahN8uMx+kNgKeXnJysb/jUjcn6khc+mKz/3xdqTzc9e/UTyXV3/Xh6sn7ZtA3J+txH/rJm7cjX1iTXfSfymd4sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4zH6TPx4iXp+9I/eHH6+/DnbPyTZH3r59Jj6fpl7fHw9de/L7nuhnnfT9dHhpL13/th7fve56iuM72kPkn9koYlraiqnS5praTXJT0saWZTOjWzQtR7ef8cpTno/6VyoaTpwErgSmAa0A/UnsrEzNqursv7iFgJIKkXOLyidDYwEBF3l+tLgc2S5kXE2oJ7NbMCNPpG3nHAmy/WImIbsKG8/C0kLS6/ROgf4Z133zGz/UWjoZ8EbKlatgWYXP3EiFgWEb0R0dvNhAZ3a2Zj1Wjoh4ApVcumAIMNbtfMmqTR0A8Ab35nUlIPMKe83Mw6UF1v5EnqKj93PDBe0kRgJ3Av8G1Ji4AHgKuAp/wmXufZOnd3sr5+5MBk/ZWvHJGs65dPJuuvfeb9NWv9f/b3yXW37K59z3yAz1yWvm/+pHt+lqznpt4z/RXAduBy4Pzyv6+IiJeARcC1wKvAAuCcJvRpZgWpd8huKbC0Ru0hYF5xLZlZM/mz92aZcejNMuPQm2XGoTfLjL9am4k4aEeyftF/XZisz310dbI+eE7667Gf/9oPk/WUk1d8OVmfdddPx7ztHPlMb5YZh94sMw69WWYcerPMOPRmmXHozTLj0JtlxuP0uRjqTpbvXXhDsv7ZH12YrK+a/w/72tGbPnJd+quxs258bMzbtrfzmd4sMw69WWYcerPMOPRmmXHozTLj0JtlxqE3y4zH6TPRtSX99/3ECelZh9acfMcoe3h3snrCty6pWTvU4/At5TO9WWYcerPMOPRmmXHozTLj0JtlxqE3y4xDb5YZj9NbIWbfc3GyfvT3n6hZS0+ibUWr60wvqU9Sv6RhSSsqls+SFJKGKh5XNq1bM2tYvWf654BrgDOBA/ZSnxoROwvrysyapt756VcCSOoFDm9qR2bWVEW9kbdJ0rOSbpY0fW9PkLS4/BKhf4ThgnZrZvuq0dBvBk4CZgLzgcnA7Xt7YkQsi4jeiOjtJv3lDjNrnobevY+IIaC//OMLkvqA5yVNjojBhrszs8IVPU4fTdqumRWkrjO9pK7yc8cD4yVNBHZSuqR/DVgPHATcAKyKiC3NaddSxh0/r2bta2ePfX74ehw0kP47v/uNN5q6f6tfvWfkK4DtwOXA+eV/XwHMBh4EBoFfAMPAucW3aWZFqXfIbimwtEZ5tFuqmFkH8Wtvs8w49GaZcejNMuPQm2XGX63dj4ybODFZ3/qdHTVrF055MbnuWevPTNaXzV6ZrL9y8kiyPv2fk2VrIZ/pzTLj0JtlxqE3y4xDb5YZh94sMw69WWYcerPMeJx+P7Lh63+UrK977001a8c+dn5y3Znn/zpZX3D9l5L1v/rgw8n6f9KTrFvr+ExvlhmH3iwzDr1ZZhx6s8w49GaZcejNMuPQm2XG4/QdZOjPFyTrT1xwfbK+YusRNWtHXro1ue7OUW5RPf51nx/eKfw/aZYZh94sMw69WWYcerPMOPRmmXHozTLj0JtlxuP0LZSaShrgi9f+W7K+i0jWb/rbRTVrU3/z0+S6ccqJyfoPzlqWrH/hyfRkxYczkKxb64x6ppc0QdJySZskDUp6UtLHK+qnS1or6XVJD0ua2dyWzawR9VzedwHPAKcCB1Kal/4uSbMkTQdWAlcC04B+4M4m9WpmBRj18j4itvHWuenvl7QRmA8cDAxExN0AkpYCmyXNi4i1xbdrZo3a5zfyJM0A5gIDwHHAmj218h+IDeXl1estltQvqX+E4bF3bGYN2afQS+oGbgduKZ/JJwFbqp62BZhcvW5ELIuI3ojo7WbCWPs1swbVHXpJ44DbgB1AX3nxEDCl6qlTgMFCujOzwtU1ZCdJwHJgBrAwIvbMSzwAfLbieT3AnPJyq7L+wqnJ+qcmVV80vdWcu9K3of7DW9PDcim//tz4ZP20A3Yn6/r5gWPet7VWvWf6m4BjgE9ExPaK5fcCx0taJGkicBXwlN/EM+tc9YzTzwQuBk4EfidpqPw4LyJeAhYB1wKvAguAc5rZsJk1pp4hu02AEvWHgPRHzcysY/iz92aZcejNMuPQm2XGoTfLjL9a20ITjkx/Zmn18I5k/ahL+5P13R84oWbt2O+mPzpx/6Hpr86+9+fpqa4P+/bjybp1Dp/pzTLj0JtlxqE3y4xDb5YZh94sMw69WWYcerPMeJy+hcY9nv7O+fz3vytZv2BgY7L+pz2P1axt2Z3+DMCxt1+WrM/5m9XJeuzelaxb5/CZ3iwzDr1ZZhx6s8w49GaZcejNMuPQm2XGoTfLjMfpW6jnt+l7x4/mvMkvJ+vffPlts4m96Sd//aHkurNXjTKVdbJq+xOf6c0y49CbZcahN8uMQ2+WGYfeLDMOvVlmHHqzzCgiPQIraQJwI3AGMA3YAHw1In4saRawEdhWsco3I+IbqW1O0bRYoNMbaNvMRvNQ3LM6Inqrl9fz4Zwu4BngVOBpYCFwl6T3VDxnakTsLKRTM2uqUS/vI2JbRCyNiN9ExO6IuJ/S2X1+89szs6Lt82t6STOAuUDlPEmbJD0r6WZJ02ust1hSv6T+EYbH2K6ZNWqfQi+pG7gduCUi1gKbgZOAmZTO/JPL9beJiGUR0RsRvd1MaKxrMxuzur9wI2kccBuwA+gDiIghYM+sii9I6gOelzQ5ItKzNZpZW9QVekkClgMzgIURMVLjqXuGAjwUaNah6j3T3wQcA5wREdv3LJS0AHgNWA8cBNwArIqILUU3ambFGPWMLGkmcDFwIvA7SUPlx3nAbOBBYBD4BTAMnNvEfs2sQaOe6SNiE6DEU+4orh0zaza/9jbLjENvlhmH3iwzDr1ZZhx6s8w49GaZcejNMuPQm2XGoTfLjENvlhmH3iwzDr1ZZhx6s8yMegvspuxUegnYVLFoOqVbb3Ui9zY27m3fFd3XzIg4pHphW0L/tiak/r3dn7sTuLexcW/7rlV9+fLeLDMOvVlmOiX0y9rdQIJ7Gxv3tu9a0ldHvKY3s9bplDO9mbWIQ2+WGYfeLDNtDb2kaZLulbRN0iZJn25nP5UkrZL0RsV9/n/Vxl76ypN/DktaUVU7XdJaSa9Lerg8T0Fb+5I0S1JUHLshSVe2qq9yDxMkLS//Xg1KelLSxyvq7TxuNXtrxbGrey67JvkepbnxZlCaTOMBSWsiYiC9Wsv0RcQP2t0E8BxwDXAmcMCeheUZglcCFwH3Ad8A7gTe186+KkyNiJ0t6qVaF/AMcCrwNLAQuEvSe4Ah2nvcUr3t0bxjFxFteQA9lAI/t2LZbcDftaunqv5WARe1u4+qnq4BVlT8vBh4rOqYbgfmtbmvWZTmNexq9zGr6vMpYFGnHLcavTX92LXz8n4usDMi1lUsWwMc16Z+9uY6SZslPSrptHY3sxfHUTpmAETENmADnXMMN0l6VtLN5auStpE0g9Lv3AAddtyqetujaceunaGfBGytWraF0hz3nWAJpbn6DqP0oYn7JM1pb0tvM4nSMavUCcdwM3ASMBOYT6mf29vVjKTu8v5viYi1dNBx20tvTT927Qz9EDClatkUSpNhtl1EPB4RgxExHBG3AI9Seu3VSTryGEbEUET0R8TOiHgB6AM+JqkdoRpH6WXjjnIf0CHHbW+9teLYtTP064AuSUdVLDuBt17idJIgPZFnOwxQOmYASOoB5tB5x3DPxz5b+vsmScBySm8UL4qIkXKp7cct0Vu1wo9d20Jffh21ErhaUo+kU4BPUvrL11aSpko6U9JESV3labk/TGla7nb00yVpIjAeGL+nL+Be4HhJi8r1q4CnypeJbetL0gJJR0saJ+lg4AZgVURUX1I3203AMcAnImJ7xfK2HrdUby05dm1+N3Ua8CNgG6Whi0+3s5+Kvg4B/pfS5d5rwM+Aj7axn6WU/uJXPpaWa2cAaym9+7wKmNXuvoBzgY3l/9fngVuBQ1t8zGaW+3mD0uX8nsd5HXDcavbWimPnL9yYZcYfwzXLjENvlhmH3iwzDr1ZZhx6s8w49GaZcejNMuPQm2Xm/wE29P0zMb56UwAAAABJRU5ErkJggg==\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "1.0\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "-1.0\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "1.0\n"
          ],
          "name": "stdout"
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "text": [
            "(9857,)\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 272
        },
        "id": "5pskaGAawfqg",
        "outputId": "2d1606e9-acb6-49c0-96c5-1541964609aa"
      },
      "source": [
        "P_sub = 250\n",
        "M = P_sub\n",
        "\n",
        "N = 800\n",
        "\n",
        "# MNIST RELU\n",
        "#F_MNIST = feature_map(X89[0:P_sub,:], N, relu)\n",
        "#F_MNIST_te = feature_map(X89[P_sub:P_sub+1000], N, relu)\n",
        "\n",
        "s = jnp.amax( jnp.linalg.svd( X89 , compute_uv=False)  )\n",
        "X89 = X89 / s\n",
        "\n",
        "P_test = 200\n",
        "F_MNIST = X89[0:P_sub,:]\n",
        "F_MNIST_te = X89[P_sub:P_sub+P_test,:]\n",
        "\n",
        "\n",
        "\n",
        "y_tr = y89[0:P_sub]\n",
        "y_te = y89[P_sub:P_sub + P_test]\n",
        "#y_te = y89_te\n",
        "\n",
        "T = 2500\n",
        "eta = 10\n",
        "m = 5\n",
        "\n",
        "Mvals = [25,50,100,250]\n",
        "all_train_expt = []\n",
        "all_test_expt = []\n",
        "\n",
        "for i, M in enumerate(Mvals):\n",
        "  losses_tr, losses_te = train_fn_split(X89[0:M,:], y89[0:M], X89[0:780,:], y89[0:780], T, eta, m = m)\n",
        "  all_train_expt += [losses_tr]\n",
        "  all_test_expt += [losses_te]\n",
        "\n",
        "plt.loglog(2*jnp.array(losses_tr))\n",
        "plt.loglog(2*jnp.array(losses_te))\n",
        "plt.show()\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "-0iWpy3kHYY0"
      },
      "source": [
        "\n",
        "\n",
        "def theory_split(X,y,X_tr, y_tr, eta, T, m=10):\n",
        "  # perform decomposition on whole dataset\n",
        "  phi, s, u = jnp.linalg.svd(X)\n",
        "  phi = phi[:,0:s.shape[0]]\n",
        "  vk = phi.T @ y\n",
        "  print(vk.shape)\n",
        "  print(s.shape)\n",
        "\n",
        "  plt.loglog(vk**2)\n",
        "  plt.show()\n",
        "\n",
        "  vk = vk / (s+1e-4)\n",
        "  print(u.shape)\n",
        "  print(vk.shape)\n",
        "  # u is modes x N\n",
        "  w_star = u[0:vk.shape[0],:].T @ vk\n",
        "\n",
        "  Sigma = X.T @ X\n",
        "  Sigma_tr = X_tr.T @ X_tr\n",
        "  Sigma_te = X_te.T @ X_te\n",
        "\n",
        "  \n",
        "\n",
        "  print(\"dot product\")\n",
        "  print(jnp.dot(w_star, Sigma @ w_star))\n",
        "  e = jnp.dot(w_star, Sigma @ w_star)\n",
        "  #w_star = w_star / jnp.sqrt(e)\n",
        "\n",
        "  phi, s, u = jnp.linalg.svd(X_tr)\n",
        "  phi = phi[:,0:s.shape[0]]\n",
        "  vk = phi.T @ y_tr\n",
        "  var_remaining = jnp.sum(y**2) - jnp.sum( vk**2 )\n",
        "\n",
        "  #loss_irr = jnp.sqrt(X_tr.shape[0])/m * eta**2 * var_remaining * jnp.trace(Sigma_tr @(jnp.eye(Sigma_tr.shape[0])-eta*Sigma_tr) @ (jnp.eye(Sigma_tr.shape[0]) - eta*Sigma_tr) @ Sigma_tr )\n",
        "  #loss_irr = jnp.sqrt(X.shape[0])/m * eta**2 * var_remaining * jnp.trace(Sigma_tr @(jnp.eye(Sigma_tr.shape[0])-eta*Sigma_tr) @ (jnp.eye(Sigma_tr.shape[0]) - eta*Sigma_tr) @ Sigma_tr )\n",
        "  \n",
        "  V = jnp.eye(Sigma_tr.shape[0])\n",
        "  all_loss_theory = []\n",
        "  loss_train = []\n",
        "\n",
        "  lambda_k , u = jnp.linalg.eigh(Sigma_tr) \n",
        "  proj_teach = u.T @ w_star\n",
        "  proj_sigma = u.T @ Sigma @ u\n",
        "\n",
        "  # definition of irreducible loss lambda (I-A)^{-1} lambda\n",
        "  \n",
        "\n",
        "  # V = (I - eta Sigma)**t w_star\n",
        "  #   = u (1-eta Lambda)**t u.T @ w_star\n",
        "  #   V^T @ Sigma @ V = w_star (1-etaLambda)**t u^T Sigma u\n",
        "  alpha_star_train = jnp.linalg.inv(X_tr @ X_tr.T) @ y_tr\n",
        "  w_star_train = X_tr.T @ alpha_star_train\n",
        "  loss_irr = jnp.dot(w_star_train, Sigma @ w_star_train)\n",
        "\n",
        "  tvals = np.logspace(0,np.log10(2500), 100)\n",
        "  for t in tvals:\n",
        "    #loss_irr = eta**2/(2*m) * var_remaining * jnp.dot( jnp.ones(len(lambda_k)), lambda_k *( 1- (1-eta*lambda_k)**(2*t)) ) \n",
        "    #print(loss_irr)\n",
        "    #z = jnp.dot( V, w_star )\n",
        "    z = (1-eta*lambda_k)**(t) * proj_teach \n",
        "    loss_theory = jnp.dot(z, proj_sigma @ z)\n",
        "    #V = (jnp.eye(Sigma_tr.shape[0]) - eta*Sigma_tr) @ V\n",
        "    all_loss_theory += [loss_theory + loss_irr]\n",
        "    #all_loss_theory += [loss_theory]\n",
        "    loss_train += [  jnp.dot(vk**2, (1-eta*s**2)**(2*t)) ]\n",
        "\n",
        "  return all_loss_theory, loss_train, tvals, loss_irr\n",
        "\n",
        "def theory_split_2(X,y,X_tr, y_tr, eta, T, m=10):\n",
        "  \n",
        "\n",
        "  # Compute training statistics\n",
        "  phi, s, uh = jnp.linalg.svd(X_tr, full_matrices=False)\n",
        "  vk = phi.T @ y_tr\n",
        "  \n",
        "  w_star_train = uh.T @ (vk/s)\n",
        "\n",
        "  # compute irreducible test statistics\n",
        "  total_y_var = jnp.sum( y**2 )\n",
        "  Sigma_test = X.T @ X\n",
        "  final_proj = jnp.dot(w_star_train, Sigma_test @ w_star_train)\n",
        "  d_test = X.T @ y\n",
        "  #loss_irr = total_y_var + final_proj - 2 * jnp.dot( w_star_train, d_test)\n",
        "\n",
        "  tvals = np.logspace(0, np.log10(2500), 100)\n",
        "  all_loss_theory = []\n",
        "  loss_train = []\n",
        "  for t in tvals:\n",
        "    z =  (1-(1 - eta * s**2 )**t) * (uh @ w_star_train)\n",
        "    z = uh.T @ z\n",
        "    # z = (I-eta Sigma)^t w_star\n",
        "    all_loss_theory += [jnp.dot(z, Sigma_test @ z) - 2*jnp.dot(z, d_test) + total_y_var]\n",
        "    loss_train += [  jnp.dot(vk**2, (1-eta*s**2)**(2*t))] # this is now working correctly!   \n",
        "  return all_loss_theory, loss_train, tvals, loss_irr\n",
        "#Mvals = [50,100,250,500]\n",
        "\n",
        "all_test = []\n",
        "all_train = []\n",
        "all_loss_irr = []\n",
        "\n",
        "for i, M in enumerate(Mvals):\n",
        "  loss, all_loss_train, tvals, loss_irr = theory_split_2(X89[0:780,:], y89[0:780], X89[0:M,:], y89[0:M], eta, T, m = m)\n",
        "  all_test += [loss]\n",
        "  all_train += [all_loss_train]\n",
        "#plt.loglog(loss_train_theory)\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "behuS3KNya3l",
        "outputId": "cf25bab1-0dc4-4004-b077-d7b65c8c745a"
      },
      "source": [
        "drive.mount('/content/gdrive', force_remount=True)\n",
        "root_dir = \"/content/gdrive/My Drive/\""
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/gdrive\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 569
        },
        "id": "zFLYok0UyGm4",
        "outputId": "5c158e0b-c42e-4d4e-c8da-abe9627343d9"
      },
      "source": [
        "#plt.title(r'Train')\n",
        "for i,M in enumerate(Mvals):\n",
        "  plt.loglog(np.linspace(1,len(all_train_expt[i]),len(all_train_expt[i])),2*jnp.array(all_train_expt[i]), label = r'$M = %d$' % M)\n",
        "  #plt.loglog( 2*jnp.array(losses_tr) , label = r'Train Error')\n",
        "  #plt.loglog(tvals, jnp.array(loss) / loss[0], '--', color = 'black')\n",
        "  plt.loglog(tvals, jnp.array(all_train[i]) / all_train[i][0], '--', color = 'black')\n",
        "plt.legend()\n",
        "plt.xlim([0.9,2500])\n",
        "plt.ylim([5e-2,1.1])\n",
        "plt.xlabel(r'$t$', fontsize = 20)\n",
        "plt.ylabel(r'$L_{train}$', fontsize=20)\n",
        "plt.tight_layout()\n",
        "plt.savefig(root_dir + 'train_split_vary_M.pdf')\n",
        "plt.show()\n",
        "for i,M in enumerate(Mvals):\n",
        "  plt.loglog(np.linspace(1,len(all_test_expt[i]),len(all_test_expt[i])), 2*jnp.array(all_test_expt[i]), label = r'$M = %d$' % M)\n",
        "  #plt.loglog( 2*jnp.array(losses_tr) , label = r'Train Error')\n",
        "  #plt.loglog(tvals, jnp.array(loss) / loss[0], '--', color = 'black')\n",
        "  plt.loglog(tvals, jnp.array(all_test[i]) / all_test[i][0], '--', color = 'black')\n",
        "plt.legend()\n",
        "plt.xlabel(r'$t$', fontsize = 20)\n",
        "plt.ylabel(r'$L_{test}$', fontsize=20)\n",
        "plt.xlim([0.9,2500])\n",
        "plt.ylim([5e-2,1.1])\n",
        "plt.tight_layout()\n",
        "plt.savefig(root_dir + 'test_split_vary_M.pdf')\n",
        "plt.show()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "f8V4jgEgMyNu"
      },
      "source": [
        "def theory_split_full(X, y, X_tr, y_tr, X_te, y_te, eta, T, m = 5):\n",
        "  # perform decomposition on whole dataset\n",
        "  phi, s, u = jnp.linalg.svd(X)\n",
        "  phi = phi[:,0:s.shape[0]]\n",
        "  vk = phi.T @ y\n",
        "  print(vk.shape)\n",
        "  print(s.shape)\n",
        "\n",
        "  plt.loglog(vk**2)\n",
        "  plt.show()\n",
        "\n",
        "  vk = vk / (s+1e-4)\n",
        "  print(u.shape)\n",
        "  print(vk.shape)\n",
        "  # u is modes x N\n",
        "  w_star = u[0:vk.shape[0],:].T @ vk\n",
        "\n",
        "  Sigma = X.T @ X\n",
        "  Sigma_tr = X_tr.T @ X_tr\n",
        "  Sigma_te = X_te.T @ X_te\n",
        "\n",
        "  print(\"dot product\")\n",
        "  print(jnp.dot(w_star, Sigma @ w_star))\n",
        "  e = jnp.dot(w_star, Sigma @ w_star)\n",
        "  #w_star = w_star / jnp.sqrt(e)\n",
        "\n",
        "  phi, s, u = jnp.linalg.svd(X_tr)\n",
        "  phi = phi[:,0:s.shape[0]]\n",
        "  vk = phi.T @ y_tr\n",
        "  var_remaining = jnp.sum(y**2) - jnp.sum( vk**2 )\n",
        "\n",
        "  loss_irr = 2*jnp.sqrt(X_tr.shape[0])/m*eta**2 * var_remaining * jnp.trace(Sigma_tr @(jnp.eye(Sigma_tr.shape[0])-eta*Sigma_tr) @ (jnp.eye(Sigma_tr.shape[0]) - eta*Sigma_tr) @ Sigma_tr )\n",
        "  print(loss_irr)\n",
        "  V = jnp.eye(Sigma_tr.shape[0])\n",
        "  all_loss_theory = []\n",
        "  loss_train = []\n",
        "  for t in range(T):\n",
        "    z = jnp.dot( V, w_star ) \n",
        "    loss_theory = jnp.dot(z, Sigma_te @ z)\n",
        "    V = (jnp.eye(Sigma_tr.shape[0]) - eta*Sigma_tr) @ V\n",
        "    all_loss_theory += [loss_theory + loss_irr]\n",
        "    loss_train += [  jnp.dot(vk**2,  (1-eta*s**2)**(2*t)) ]\n",
        "\n",
        "  return all_loss_theory, loss_train\n",
        "\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "BmpkMoB-ySyk"
      },
      "source": [
        ""
      ],
      "execution_count": null,
      "outputs": []
    }
  ]
}