{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import norm\n",
    "import copy"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Utility Function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_vector(vector, similarity):\n",
    "    \"\"\"given a vector and a desired cosine similarity, \n",
    "    returns another vector that has the desired cosine similarity\n",
    "    (keeps magnitude of target vector the same as the given one)\n",
    "    (samples uniformly from space of possible vectors)\"\"\"\n",
    "    target_norm = np.linalg.norm(vector)\n",
    "    vector = vector/target_norm\n",
    "    t = similarity\n",
    "    x = np.random.normal(size=len(vector))\n",
    "    u = np.sqrt(1-t**2)*(x-(np.dot(x,vector)*vector))/np.linalg.norm(x-(np.dot(x,vector)*vector))\n",
    "    return (t*vector + u)*target_norm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Functions to actually sample data and simulate SGd descent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_data(T, d, mean, varpos, varneg, mixing, seed=0):\n",
    "    np.random.seed(seed)\n",
    "    Npos = int(np.round(mixing*T))\n",
    "    Nneg = int(np.round((1-mixing)*T))\n",
    "    posdata = np.random.multivariate_normal(mean=mean/np.sqrt(d) , cov=varpos*np.eye(d), size=Npos) \n",
    "    negdata = np.random.multivariate_normal(mean=-mean/np.sqrt(d) , cov=varneg*np.eye(d), size=Nneg)\n",
    "    return posdata, negdata\n",
    "\n",
    "def label_data(posdata, negdata, teachpos, teachneg, biaspos, biasneg, get_cluster_labels = False):\n",
    "    d = posdata.shape[1]\n",
    "    data = np.vstack([posdata, negdata])\n",
    "    T = data.shape[0]\n",
    "    poslabels = (posdata@teachpos/(d**0.5) + biaspos) >= 0\n",
    "    neglabels = (negdata@teachneg/(d**0.5) + biasneg) >= 0\n",
    "    labels = np.hstack([poslabels, neglabels])\n",
    "    shuffle = np.random.permutation(T) \n",
    "    data = data[shuffle]\n",
    "    labels = labels[shuffle]\n",
    "    ytrue = -np.ones(len(labels))\n",
    "    ytrue[labels] = 1\n",
    "    if get_cluster_labels:\n",
    "        cluster_labels = np.hstack([np.ones(len(poslabels)), -np.ones(len(neglabels))])\n",
    "        cluster_labels = cluster_labels[shuffle]\n",
    "        return data, ytrue, cluster_labels\n",
    "    return data, ytrue\n",
    "\n",
    "def simulate_oSGD(lr, data, ytrue, classifier0, k1, k2, k3, k4, mixing, varpos, varneg, mean, teachpos, teachneg):\n",
    "    d = len(classifier0)\n",
    "    classifier = copy.deepcopy(classifier0)\n",
    "    classifiers = np.zeros(data.shape)\n",
    "    errors = np.zeros(len(data))\n",
    "    for i in range(len(data)):\n",
    "        error = (ytrue[i] - np.dot(classifier, data[i])/np.sqrt(d))**2\n",
    "        errors[i] = error\n",
    "        classifier += data[i]*lr*(ytrue[i] - np.dot(classifier, data[i])/np.sqrt(d))/np.sqrt(d)\n",
    "        classifiers[i, :] = classifier\n",
    "    \n",
    "    simQs = np.zeros(len(classifiers))\n",
    "    simMs = np.zeros(len(classifiers))\n",
    "    simRposs = np.zeros(len(classifiers))\n",
    "    simRnegs = np.zeros(len(classifiers))\n",
    "    simegs = np.zeros(len(classifiers))\n",
    "    simegposs = np.zeros(len(classifiers))\n",
    "    simegnegs = np.zeros(len(classifiers))\n",
    "    \n",
    "    varmix = mixing*varpos + (1-mixing)*varneg\n",
    "\n",
    "    for i in range(len(classifiers)):\n",
    "        simQs[i] = np.dot(classifiers[i], classifiers[i])/d\n",
    "        simMs[i] = np.dot(classifiers[i], mean)/d\n",
    "        simRposs[i] = np.dot(classifiers[i], teachpos)/d\n",
    "        simRnegs[i] = np.dot(classifiers[i], teachneg)/d\n",
    "        simegposs[i] = 1 + varpos*simQs[i] + simMs[i]**2 - 2*(simMs[i]*k2 + simRposs[i]*k1)\n",
    "        simegnegs[i] = 1 + varneg*simQs[i] + simMs[i]**2 - 2*(-simMs[i]*k4 + simRnegs[i]*k3)\n",
    "        simegs[i] = 1 + varmix*simQs[i] + simMs[i]**2 - 2*mixing*(simMs[i]*k2 + simRposs[i]*k1) - 2*(1-mixing)*(-simMs[i]*k4 + simRnegs[i]*k3)\n",
    "    \n",
    "    return simegs, simegposs, simegnegs, simQs, simMs, simRposs, simRnegs\n",
    "\n",
    "\n",
    "def complete_simulation(T, d, lr, classifier0, mean, mixing, varpos, varneg, teachpos, teachneg, biaspos, biasneg):\n",
    "    \"\"\"Samples data from data distribution defined by given parameters,\n",
    "    simulates SGD and returns values of order parameters and \n",
    "    generalization errors obtained through simulation\"\"\"\n",
    "\n",
    "    posdata, negdata = generate_data(T, d, mean, varpos, varneg, mixing)\n",
    "    data, ytrue = label_data(posdata, negdata, teachpos, teachneg, biaspos, biasneg, get_cluster_labels=False)\n",
    "    del posdata, negdata\n",
    "\n",
    "    # These order parameters don't change\n",
    "    Mpos = np.dot(teachpos, teachpos)/d # Always 1 as per assumption in paper of setting teacher norm to sqrt(d)\n",
    "    Mneg = np.dot(teachneg, teachneg)/d # Always 1 as per assumption in paper of setting teacher norm to sqrt(d)\n",
    "    Mstarpos = np.dot(teachpos, mean)/d\n",
    "    Mstarneg = np.dot(teachneg, mean)/d\n",
    "\n",
    "    # Constants that appear frequently while computing integrals of the form <yW.x>\n",
    "    k1 = np.sqrt(2*varpos/Mpos/np.pi)*np.exp(-(Mstarpos+biaspos)**2/(2*Mpos*varpos))\n",
    "    k2 = 1 - 2*norm.cdf(-(Mstarpos+biaspos)/np.sqrt(Mpos*varpos))\n",
    "    k3 = np.sqrt(2*varneg/Mneg/np.pi)*np.exp(-(-Mstarneg+biasneg)**2/(2*Mneg*varneg))\n",
    "    k4 = 1 - 2*norm.cdf(-(-Mstarneg+biasneg)/np.sqrt(Mneg*varneg))\n",
    "    \n",
    "    simegs, simegposs, simegnegs, simQs, simMs, simRposs, simRnegs = simulate_oSGD(lr, data, ytrue, classifier0, k1, k2, k3, k4, mixing, varpos, varneg, mean, teachpos, teachneg)\n",
    "    \n",
    "    return simegs, simegposs, simegnegs, simQs, simMs, simRposs, simRnegs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Function to analytically obtain values through expressions given in the paper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def TSMexact(T, d, lr, classifier0, mean, mixing, varpos, varneg, teachpos, teachneg, biaspos, biasneg):\n",
    "    \"\"\"Returns values of Order Parameters and Generalization errors obtained from analytic expressions\"\"\"\n",
    "    \n",
    "    Q0 = np.dot(classifier0, classifier0)/d\n",
    "    M0 = np.dot(classifier0, mean)/d\n",
    "    Rpos0 = np.dot(classifier0, teachpos)/d\n",
    "    Rneg0 = np.dot(classifier0, teachneg)/d\n",
    "\n",
    "    # These order parameters don't change\n",
    "    Mpos = np.dot(teachpos, teachpos)/d # Always 1 as per assumption in paper of setting teacher norm to sqrt(d)\n",
    "    Mneg = np.dot(teachneg, teachneg)/d # Always 1 as per assumption in paper of setting teacher norm to sqrt(d)\n",
    "    Tposneg = np.dot(teachpos, teachneg)/d\n",
    "    Mstarpos = np.dot(teachpos, mean)/d\n",
    "    Mstarneg = np.dot(teachneg, mean)/d\n",
    "    v = np.dot(mean, mean)/d\n",
    "    print(f'Static Order Parameters from provided data distribution parameters \\n Tposneg: {Tposneg}, Mpos: {Mpos}, Mneg: {Mneg}, Mstarpos: {Mstarpos}, Mstarneg: {Mstarneg}, v: {v}')\n",
    "\n",
    "    varmix = mixing*varpos + (1-mixing)*varneg\n",
    "    varsquaremix = mixing*varpos**2 + (1-mixing)*varneg**2\n",
    "\n",
    "    # Constants\n",
    "    betapos = np.sqrt(2*varpos/Mpos/np.pi)*np.exp(-(Mstarpos+biaspos)**2/(2*Mpos*varpos))\n",
    "    alphapos = 1 - 2*norm.cdf(-(Mstarpos+biaspos)/np.sqrt(Mpos*varpos))\n",
    "    betaneg = np.sqrt(2*varneg/Mneg/np.pi)*np.exp(-(-Mstarneg+biasneg)**2/(2*Mneg*varneg))\n",
    "    alphaneg = 1 - 2*norm.cdf(-(-Mstarneg+biasneg)/np.sqrt(Mneg*varneg))\n",
    "\n",
    "    c1 = lr*(v+varmix)/d\n",
    "    exp1 = np.exp(-c1*np.arange(T+1))\n",
    "    exp1squared = np.exp(-2*c1*np.arange(T+1))\n",
    "    \n",
    "    Minf = (mixing*(v*alphapos + Mstarpos*betapos) + (1-mixing)*(-v*alphaneg + Mstarneg*betaneg))/(v+varmix)\n",
    "    Ms = Minf*(1-exp1) + M0*exp1\n",
    "\n",
    "    c2 = lr*varmix/d\n",
    "    exp2 = np.exp(-c2*np.arange(T+1))\n",
    "    \n",
    "    Rposinf = (Mstarpos*(mixing*alphapos - (1-mixing)*alphaneg - Minf) + (mixing*betapos + Tposneg*(1-mixing)*betaneg))/(varmix)\n",
    "    Rneginf = (Mstarneg*(mixing*alphapos - (1-mixing)*alphaneg - Minf) + (Tposneg*mixing*betapos + (1-mixing)*betaneg))/(varmix)\n",
    "    if v != 0:\n",
    "        Rpostrans = Mstarpos/v*(Minf-M0)\n",
    "        Rnegtrans = Mstarneg/v*(Minf-M0)\n",
    "    else:\n",
    "        Rpostrans = 0\n",
    "        Rnegtrans = 0\n",
    "    \n",
    "    Rposs = Rpos0*exp2 + Rposinf*(1-exp2) + Rpostrans*(exp2 - exp1)\n",
    "    Rnegs = Rneg0*exp2 + Rneginf*(1-exp2) + Rnegtrans*(exp2 - exp1)\n",
    "\n",
    "    k1 = -2*varmix + lr*varsquaremix\n",
    "    k2 = lr*varmix - 2\n",
    "    k3 = 2*mixing*alphapos*(1-lr*varpos) - 2*(1-mixing)*alphaneg*(1-lr*varneg)\n",
    "    k4 = 2*mixing*betapos*(1-lr*varpos)\n",
    "    k5 = 2*(1-mixing)*betaneg*(1-lr*varneg)\n",
    "\n",
    "    c3 = lr/d*(-k1)\n",
    "    exp3 = np.exp(-c3*np.arange(T+1))\n",
    "\n",
    "    Qinf = -(Rposinf*k4 + Rneginf*k5 + lr*varmix)/k1 - Minf*(Minf*k2 + k3)/k1\n",
    "    \n",
    "    Qterm1 = Q0*exp3\n",
    "    Qterm2 = Qinf*(1-exp3)\n",
    "    Qterm3 = ((M0-Minf)*k3 + 2*Minf*k2*(M0 - Minf) - Rpostrans*k4 - Rnegtrans*k5)*(exp3-exp1)/(v+varmix+k1)\n",
    "    Qterm4 = (k2*(M0 - Minf)**2)/(2*(v+varmix) + k1)*(exp3 - exp1squared)\n",
    "    Qterm5 = ((Rpos0-Rposinf)*k4 + (Rneg0-Rneginf)*k5 + Rpostrans*k4 + Rnegtrans*k5)*(exp3-exp2)/(varmix+k1)\n",
    "    \n",
    "    Qs = Qterm1 + Qterm2 + Qterm3 + Qterm4 + Qterm5\n",
    "    \n",
    "    egposs = 1 + Qs*varpos + Ms**2 - 2*(Ms*alphapos + Rposs*betapos)\n",
    "    egnegs = 1 + Qs*varneg + Ms**2 - 2*(-Ms*alphaneg + Rnegs*betaneg)\n",
    "    egs = mixing*egposs + (1-mixing)*egnegs\n",
    "    \n",
    "    return egs, egposs, egnegs, Qs, Rposs, Rnegs, Ms"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Basic Usage"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Example below is for the most general case to reproduce Figure 1a. The fairness and robustness settings described in the paper can be obtained by appropriately setting relevant parameters as described in the paper."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set Data Distribution Parameters\n",
    "seed = 1\n",
    "np.random.seed(seed)\n",
    "\n",
    "d = 1000 # dimemsionality of data\n",
    "T = 100000 # number of timesteps under consideration\n",
    "\n",
    "mean = np.ones(d)\n",
    "biaspos = 0 # always zero in paper\n",
    "biasneg = 0 # always zero in paper\n",
    "\n",
    "mixing = 0.5 # mixing is equivalent to \\rho defined in the paper\n",
    "varpos = 0.2 # positive subpopulation variance\n",
    "varneg = 0.4 # positive subpopulation variance\n",
    "Tposneg = 0.7 # cosine similarity between teachers\n",
    "\n",
    "lr = 0.2 # equivalent to \\eta in paper\n",
    "classifier0 = 0.001*np.random.normal(size=d) # initial guess for classifier\n",
    "\n",
    "teacher_shift_cos_sim = 0.5 # desired cosine similarity between positive teacher and shift\n",
    "\n",
    "teachpos = get_vector(mean*np.sqrt(d)/np.linalg.norm(mean), teacher_shift_cos_sim)\n",
    "teachpos = teachpos*np.sqrt(d)/np.linalg.norm(teachpos) #positive teacher normalised to have norm = sqrt(d)\n",
    "teachneg = get_vector(teachpos, Tposneg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Static Order Parameters from provided data distribution parameters \n",
      " Tposneg: 0.7, Mpos: 1.0, Mneg: 0.9999999999999998, Mstarpos: 0.5, Mstarneg: 0.34769600268538964, v: 1.0\n"
     ]
    }
   ],
   "source": [
    "# Obtain values through analytic expressions\n",
    "egs, egposs, egnegs, Qs, Rposs, Rnegs, Ms = TSMexact(T, d, lr, classifier0, mean, mixing, varpos, varneg, teachpos, teachneg, biaspos, biasneg)\n",
    "\n",
    "# Obtain values through simulation (much slower)\n",
    "simegs, simegposs, simegnegs, simQs, simMs, simRposs, simRnegs= complete_simulation(T, d, lr, classifier0, mean, mixing, varpos, varneg, teachpos, teachneg, biaspos, biasneg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATIAAAEJCAYAAAAXe6urAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABIcUlEQVR4nO3deXhTVd4H8O+92fe2tHShOwLKIohQNmVTqSDgggr4yqaC4igKDIM4oywuyMjrKyPjBg6LooIyr6O+rAoFQYqAgMpSSmlLoS3QJUmzJ/ee9480oaFbcpumTXs+z9MHcu/pyS9p8+u5556FIYQQUBRFhTG2pQOgKIpqKprIKIoKezSRURQV9mgioygq7NFERlFU2KOJjKKosEcTGUVRYU/c0gGEC57nUVxcDI1GA4ZhWjocimoRhBBUVVUhISEBLNt62kGCEplIJMKkSZOwadOmYMfTahUXFyMpKamlw6CoVqGoqAiJiYktHYaXoESm1Wrb3Ydao9EAcP8AtVptC0dDUS3DaDQiKSnJ+3loLQQlsoyMDJw8eTLYsbRqnstJrVZLExnV7rW27hVBF7lLlizBnj17sHHjxmDHAwD47LPP8PTTT6Nfv36QyWRgGAbr168PuB6e5/Hee++hV69eUCgUiImJweTJk3HhwoXgB01RVIsR1CLbvXs3hg8fjhkzZuC9995D//79ERsbWytLMwyDV155JeD6//a3v6GwsBDR0dGIj49HYWGhkDDx9NNPY+3atejRowfmzJmD4uJibNmyBbt27UJ2dja6dOkiqF6KoloZIgDDMH59sSwrpHqye/duUlBQQAghZPny5QQAWbduXUB17NmzhwAgQ4cOJXa73Xt827ZtBAAZNWpUQPUZDAYCgBgMhoC+j6Laktb6ORDUItu7d28QU2ltd999d5PrWLNmDQDgtddeg1Qq9R4fPXo0hg8fjl27duHixYtITk5u8nMBQNmlK7CZLUjsloZLOfmQq5SITowNSt0URTVMUCIbNmxYsOMIuqysLKhUKgwZMqTWuczMTGRlZWHfvn2YMmVKk5+r7NIVHH/4MTisdpye/SLkn6yCUyJD7y2baDKjqBBokwNizWYzSkpK0LNnT4hEolrnPX1jubm59dZht9tht9u9j41GY71lbWYLKo0OXDxzENzsQxjfrSuuaaJhM1ua8CooivJXk4bmHjx4EDNnzkT//v3RrVs39O/fH7NmzcKBAweCFZ8gBoMBAKDT6eo87xk+4SlXl+XLl0On03m/Gho3l9gtDVHz5wMARODh4AHN0teR2C1N6EugKCoAghPZ3LlzMXToUHzyySc4duwYzp8/j2PHjmHt2rUYNmwY5s2bF8w4Q27RokUwGAzer6KionrLXsrJh/O9d7yPbRyDqsV/w6Wc/FCESlHtnqBEtmHDBqxatQpdunTBpk2bUFxcDJfLhZKSEnz++efo2rUrVq1a1WzjzBrjaYnV1+LyXCbW12IDAJlM5h382tggWLlKCVYuBQ/38JNiRSScEhnkKqXQl0BRVAAEJbIPPvgAiYmJOHz4MCZPnoy4uDgwDIPY2FhMmjQJ2dnZ6NSpE95///1gx+sXlUqF+Ph45Ofng+O4Wuc9fWPBGkcWnRiL27/eBFd1l2P0K4tpRz9FhZCgRHbq1ClMmDCh3haNTqfDhAkTcOrUqSYF1xTDhg2D2WzGwYMHa53buXMnAGDo0KFBe77oxFi44B7modFpaBKjqBBqtnU4QjUXq6ysDGfPnkVZWZnP8VmzZgEAXnnlFTgcDu/x7du3IysrC6NGjUJKSkpQY3Gy7kRmrTIHtV6KohomKJH16NEDW7duhclkqvN8VVUVtm7dih49eggKau3atZg+fTqmT5+Or776qtaxtWvXesuuXr0at9xyC1avXu1Tx4gRI/DUU09h//796Nu3LxYuXIipU6figQceQFRUFN577z1BsTWEYyQAAKuRJjKKCiVBiezpp5/GpUuXMGjQIGzdutXbGiorK8PXX3+NwYMH49KlS5g9e7agoA4cOIANGzZgw4YN+PXXXwG4h3p4jvk7vOOjjz7CqlWrAACrVq3Ctm3b8OCDD+KXX35B165dBcXWEE4kAwDYaYuMokKKIUTYTuNz5szB6tWrvZeQLMuC53kA7lUkn3/+eW8SaQuMRiN0Oh0MBkO9dzAXKG9CrDUPnV/7GA/+bWaII6So5ufP56AlCB7Z/49//AOPPPII1q9fjxMnTsBoNEKr1eK2227DtGnTcOeddwYzzrDAV7fIHCbaIqOoUBKUyPbv3w+tVos777yzXSaseomrE5nZ2sKBUFT7IqiPbMSIEfj444+DHUvYIxJPIqNzLCkqlAQlso4dO0Iulwc7lvBXncicFprIKCqUBCWye+65B1lZWRB4n6DNYiTu5O600EtLigolQYnsrbfeQnl5OWbNmoWKiopgxxS+ZO5E5rLSFhlFhZKgzv7HH38cERER+Ne//oXPPvsMaWlp9a7Z/+OPPwYl0HDASt2JjLPSFhlFhZKgRJaVleX9v91ux9mzZ3H27Nla5VrbllHNjZUrAACczdbCkVBU+yIokXkGvlK+RNU3QDgbbZFRVCgJ6iNbtmwZPv3002DHEvZE1S0y3kFbZBQVSoIS2euvv47ff/892LGEPbHCvZAisdMWGUWFkqBElpycDL1eH+RQwp9Y6W6REae9kZIURQWToEQ2adIk7Nixo8HNO9ojaXUiA720pKiQEpTIXnnlFdx6660YOXIk/u///g9Xr14NdlxhSaJ0X1oytEVGUSEl6K6lsvoDSwjB+PHj6y3HMAxcLpewyMKQVK2CCwBcNJFRVCgJSmR33nlnuxsj5g+ZSgkLAJajiYyiQqnJA2Kp62RaNQCApS0yigqpZtt8pD2SazUAADFnoxPqKSqE/E5kFy9e9G5s649z587h22+/FRRUuFJGurfHY0DgovMtKSpk/E5kaWlptdbg/+ijj9C3b986y3/xxRd48MEHmxZdmJFrVN7dxh317DBFUVTw+Z3ICCG1LpdKS0tx8uTJoAcVrhRKKRzVm/Q6aSKjqJChfWRBJJOJvInMUVXVwtFQVPtBE1kQyeUi2FG93DVtkVFUyNBEFkQymdibyGgfGUWFDk1kQSSXi2gfGUW1gIASGR3N3zCF4nqLzKqnE+opKlQCGtn/2muvYfny5d7HnnmUnrmXNbWnOZYeSqXE2yIzV/o/5o6iqKbxO5ElJyfTFlkjZDJRjRYZTWQUFSp+J7KCgoJmDKNtYBgGvFgOuGgio6hQop39QcZL3Isr2gw0kVFUqNBEFmxSd3+hzUjvWlJUqNBEFmxSd4uMjuynqNChiSzIGLkKAB1HRlGhRBNZkDHVW8I5zeYWjoSi2g+ayIJMrHS3yDgLbZFRVKjQRBZkYqV7uWvOQltkFBUqNJEFmVijBQDwFtrZT1GhImjzEY/S0lIcO3YMer0eHMfVWWbq1KlNeYqwI9G6l7sm1ioQQuhsCIoKAUGJzGazYebMmfjyyy/B83ydZTwf4vaWyKS66nX7ORdcVqt3016KopqPoET20ksvYdOmTejatSsmT56MxMREiMVNaty1GQqtBhxYiMDDrtfTREZRISAo+2zZsgXdu3fHsWPHIJPJgh1TWFMoJbBBDhUssBsMUCcktHRIFNXmCers1+v1uPfee5s1iR05cgRjxoxBREQEVCoVBg4ciC1btgRUR3FxMV544QV0794dKpUKsbGxuOOOO/Dpp5/W26fXVMrqRAYAdr2+WZ6Doihfglpk3bp1w5UrV4Idi9fevXuRmZkJuVyOSZMmQaPRYOvWrZg4cSKKioowf/78Ruu4cOECBgwYgPLycmRmZmLcuHEwGo345ptvMHXqVOzZswfr1q0LeuwKhRhXUD1xnCYyigoNIsCmTZuIRqMhubm5Qr69QU6nk3Tu3JnIZDJy/Phx73G9Xk+6du1KpFIpKSgoaLSe2bNnEwDk3Xff9TleWVlJkpOTCQC/6vEwGAwEADEYDA2W++ijE2QWbiJvA+T055/7XT9FhQN/PwehJujSMjExEZmZmcjIyMCyZcvw/fffY//+/XV+BWrPnj3Iy8vDY489hj59+niP63Q6vPzyy3A4HNiwYUOj9Vy4cAEAMGbMGJ/jERERuOOOOwAAZWVlAcfXGIVCTC8tKSrEBF1aDh8+HAzDgBCCJUuWNDhWKtC+qKysLADAqFGjap3LzMwEAOzbt6/Renr27ImdO3di27ZteOGFF7zH9Xo9Dh48iLi4OHTv3j2g2PyhVEpgrb60tBvouv0UFQqCEtmrr77abAM9c3NzAQBdunSpdS4uLg5qtdpbpiELFizAd999h7lz52LHjh249dZbvX1kSqUS//u//wuFQlHv99vtdtjtdu9jo9G/hRKVStoio6hQE5TIlixZEuQwrjNUt2J01QNLb6TVar1lGhIbG4tDhw7h8ccfx/bt27Fjxw4AgEKhwDPPPIPevXs3+P3Lly/H0qVLA4zefWnpbZHRREZRIdFm51qeP38eQ4YMwbVr1/DTTz+hqqoKRUVFePXVV/Haa6/hrrvuavCyd9GiRTAYDN6voqIiv5635vALeteSokKjScPxzWYzvvnmG5w4cQJGoxFarRZ9+vTBAw88AJVKJahOT0usvlaX0WhEZGRko/VMnz4dhYWFuHDhAuLi4gAAarUaL730Eq5cuYJ3330XX375Jf7rv/6rzu+XyWSCxsnRFhlFhZ7gRLZ161bMmjULer0ehBDvcYZhEBERgTVr1uChhx4KuF5P31hubi5uv/12n3OlpaUwmUzIyMhosI6qqiocPHgQffv29SaxmkaMGIF3330Xx48frzeRCUUHxFJU6Am6tPz5558xadIkmM1mPPXUU/j888+xd+9efPHFF5g5cyYsFgsmTZqEQ4cOBVz3sGHDAAC7du2qdW7nzp0+ZerjcDgA1D+84tq1awDQLDMTlEoxzHC3Rq3l5UGvn6KoOggZfHbfffcRlUpFTpw4Uef5kydPEpVKRcaOHRtw3U6nk6Snpzc4IDY/P997vLi4mJw5c4bo9Xqferp160YAkDVr1vgcr6ysJDfffDMBQHbv3u13XP4OBDQa7SQGC8jbAFml0/ldP0WFg9Y6IFZQIouKiiJPPPFEg2VmzJhBoqKiBAW1Z88eIpFIiEajITNnziTz5s0jKSkpBABZuXKlT9lp06YRAGTdunU+x7dt20bEYjEBQO666y7y5z//mTz55JMkJiaGACATJkwIKCZ/f4AcxxMllpC3AfI2QFwOR0DPQ1GtWWtNZIL6yCwWC2JjYxssExsbC4vFIqR6jBgxAgcOHMDixYuxefNmOJ1O9OrVCytWrMDEiRP9qmP06NH4+eef8fbbb+PAgQPYt28f5HI5brnlFrz66quYPXu2oNgaw7IMWKUWvIUBCwJrWRnU8fHN8lwURbkxhNToqffTLbfcArVajSNHjtRbJiMjA1VVVThz5kyTAmwtjEYjdDodDAYDtFptg2Xj4t7HM1f+AjXMmPbbb4jp1StEUVJU8wrkcxBKgjr7H330URw7dgzTpk1DcXGxz7mSkhJMnz4dx44d87v11Nao1dLrHf7VNxYoimo+gi4tFy5ciB07duDTTz/F5s2bcdNNNyE2NhZXrlzB+fPn4XA4kJGRgYULFwY73rCgVktgghqxuApLM0xMpyjKl6AWmVKpxP79+7FkyRIkJibi9OnT2Lt3L06fPo3ExEQsXboU+/bta3AuY1umVkthgXuJaytNZBTV7AQPiJXJZHj11Vfx6quvoqqqyjuyX6PRBDO+sKTRuFtkAL20pKhQCMqOIRqNhiawGtRqKao8fWS0RUZRza7NThpvSWq1xNvZb6EtMopqdn61yNLT08EwDH744QekpaUhPT3dr8oZhkFeXl6TAgxH9K4lRYWWX4mM53mfhRRvfFwfAUPU2gS1WoIquC+1zaWlLRwNRbV9fiWygoKCBh9TvtRqKYxwDxY03TDOjqKo4KN9ZM1ArZZ4E5ldr4dT4FQtiqL8IyiRjRw5Ehs3bmywzGeffYaRI0cKCircaTRS2CAHJ3IvE2QuKWnhiCiqbROUyLKyshq9vCwsLPRrt6O2SK2WAGBgk7pXsq26fLllA6KoNq7ZLi3NZjMkEklzVd+qqdVSAIBZ5F6220z7ySiqWfk9IPbixYs+j/V6fa1jgHsfy6KiImzduhWpqalNDjAcuVtkgJHRoSNohz9FNTe/E1lqaqp3yAXDMFi1ahVWrVpVb3lCCN5+++2mRxiGPC0yPU/vXFJUKPidyKZOnerdXXzjxo3o3bs3+vTpU6ucSCRCVFQURo4ciXvvvTeYsYYNT4uswuWeb0kTGUU1L78T2fr1673/37dvH2bMmIE5c+Y0R0xhT6Nxt8iu2d2j+6v83BOToihhBE0az8/PD3YcbYpO5x52UQH3XUsjHUBMUc2KDohtBgqFGBIJi3J0AOAefuGy21s4KopquwQv41NVVYXVq1fjhx9+QHFxMex1fFDb66RxhmGg08lQVqaCSKEEZ7Wg6uJFRFZvPkxRVHAJSmTXrl3D4MGDkZeXB61W692QwOFwwGq1AgASEhLa7TgyANWJzAppXCKs+edgyM+niYyimomgS8slS5YgLy8PGzduRGVlJQBg7ty5MJvNOHz4MDIyMpCamopTp04FNdhwEhHh7icTRXcCABhovyJFNRtBiWzbtm2466678Pjjj9dazqd///7Yvn07CgoKsHTp0qAEGY48Hf4kMgEAoL9woSXDoag2TVAiKykpwW233eZ9LBKJvJeUABAZGYnRo0djy5YtTY8wTHkSmUMTB4C2yCiqOQlKZDqdDk6n0/s4MjISly5d8imj1Wpx5cqVpkUXxjyXllalO5Hpc3NbMhyKatMEJbL09HSf1S9uu+027N69G+Xl5QAAq9WK7777DsnJyUEJMhx5WmRGhfvSsuLsWfAc15IhUVSbJSiRjRo1Cj/++CMs1QsGPv3007h69Sp69+6NRx55BD179kReXh6mT58ezFjDiqdFVkGiIJLJ4LLZYCwsbOGoKKptEpTInnnmGaxZs8abyB566CG8/fbbMJvN2Lp1K0pLSzFv3jwsWLAgqMGGE0+LzFDlQtTNNwMAyk+fbsmQKKrNEpTI4uPjMXHiRERHR3uPzZ8/H2VlZSgpKYHJZMLbb78NkUgUtEDDjU7nnm9pMNjR4ZZbAADlZ860ZEgU1WYFdYqSSCRCbGysXzsstXUREXIAgF5vR4fu3QHQFhlFNRfBnf29evXC4cOH6y2zatUqv/e/bIu8l5aG64ms7I8/WjIkimqzBCWygoICnDp1CiNGjKh3rJher0dhO+7crnlp2bF63bay338H53C0YFQU1TYJvrR89NFHERcXh8mTJ+P1118PZkxtQs1LS116OmQREeDsdpS142lbFNVcBCey7t27e+dVLl68GFOnTvUZJNveeYZfmM1OOJ084vr1AwBcOXq0JcOiqDapSZ39MTExyMrKwsMPP4zPPvsMd999t3cSeXsXESEDy7pvelRU2BBbnchKaSKjqKBr8l1LmUyGzZs3Y9GiRfjpp58wYMAA5OTkBCO2sCYSsYiMdF9elpdbvS2y0iNHWjIsimqTgjb84o033sC6detw8eJFDB48GD///HOwqg5b0dEKAEBZmRXxAwYAAK799hscVVUtGRZFtTlBHUc2bdo07Nq1CwzDYPfu3cGsOix16HC9RaZJTIQuNRWE43DpwAE4S0rgopfhFBUUglaIXbx4MYYPH17nuaFDhyI7Oxtz5szxWdqnParZInNVViKC42EAkL95M/h3/gesQoHkDeshjoxs2UApKswJTmQNuemmm7Bt2zZBAbUlHTq4E1l5uQ3EZkMHrQaFcCeyhJRUSJKSQGy2lg2SotqAVruL0pEjRzBmzBhERERApVJh4MCBghZqvHr1KubOnYsuXbpALpejQ4cOGDRoED744INmiNrX9RaZBZL4ePRY8XcAgMFmg5PjkLBiBSTx8c0eB0W1dX61yJYtWwaGYfCnP/0JUVFRWLZsmV+VMwyDV155JeCg9u7di8zMTMjlckyaNAkajQZbt27FxIkTUVRUhPnz5/tVz4kTJzBq1ChUVlbivvvuw8MPPwyTyYQzZ87gu+++w+zZswOOLRDX+8hscJaUoOrdd6GSSGF2OlBmMUO5cCFSNm6gyYyimor4gWEYwrIsycnJ8T7254tlWX+q9+F0Oknnzp2JTCYjx48f9x7X6/Wka9euRCqVkoKCgkbrMRgMJDk5mcTExJCTJ0/W+TyBMBgMBAAxGAx+f8+aNScJ8Da5776txFlRQfLGjSf/m5JC3gbIl3HxJG/ceOKsqAgoDopqSUI+B6HgV4ts7969AOBd8dXzuDns2bMHeXl5mDFjBvpUz1EE3Mtrv/zyy5g+fTo2bNiAV199tcF63n//fVy8eBGffPIJbr311lrnxWLBW3r6zXNpWV5uhTgyEskb1oPdtw/nH3wQ1+w2JH6ylnb0U1QQ+PVpHjZsWIOPgykrKwuAexXaG2VmZgIA9u3b12g9mzdvBsMwmDBhAnJycrBr1y5YrVbcfPPNuPfeeyGVSoMad11qdvYDcCezsWMhj4qCraICV86cQVJMTLPHQVFtXfM3SwKUW71JR5c6NrONi4uDWq32lqmPw+HA77//jpiYGLz33ntYvHgxeJ73nk9PT8c333yDXr161VuH3W732T3daDQG+lIQHa1AZKQEcjmBrcbdyS5TpiDvm2+Qu2MHYjIyAq63PRGJRO16o2fKPwwhhLR0EDWNGjUKu3fvRm5uLm666aZa5zt16gSTyQSDwVBvHaWlpYiPj4dIJALLsli+fDmmTJkCp9OJjz76CK+//jqSk5Nx9uxZyOXyOutYsmRJnftyGgwGaLXaRl+H0WjE5culOH++HGIxg5QUrXfBSZfVCsvVq2BYFurERLoQZSNkMhmio6P9et+p5mU0GqHT6fz+HISKXy0ylmUFfdgYhoHL5Qr4+5rK0/riOA7PPfecz13OZcuWIScnB1u2bMHXX3+Nxx9/vM46Fi1ahHnz5nkfG41GJCUl+fX87iR2GSqVCvHx8QBESEyMglTqXvqbEIIKlgXvckEbHQ1ZK/qFaE0IIXA6nTAYDLh8+TIAtKoPD9V6+JXIhg4dGrJWg06nA4B6W1xGoxGRjXSQe+oAgPHjx9c6P378eGzZsgVHjx6tN5HJZDLIZDJ/w/ZRVlYGtVqNxMREVFZeg9PJQySSQi6/fomk6dABlitXQKqqIO/YUdDztAcKhQIajQaXLl1CWVkZTWRUnfxKZJ4O+FDw9I3l5ubi9ttv9zlXWloKk8mEjEb6lVQqFTp16oTLly8jIiKi1nnPseaYQuV0OmG32xEdHQ2GYSCRsHA6ebhcvE85RXUis+n14BwOiEJw8yFcMQwDnU6Hy5cvw+l00j4zqpZWN7Lfc0d0165dtc7t3LnTp0xDRo4cCQA4XceGH55jqampQsOsF1e9Ca/nwyaRuC8nHQ7fzXklSiUkajVACKxlZUGPo63xvJ8c3eSYqkOrS2R33XUX0tPT8fnnn+PEiRPe4waDAW+++SakUimmTp3qPV5SUoKzZ8/WuhR95plnAABvvfUW9Hq993hpaSlWrVoFlmUxYcKEZnsdnktxicT9Ft/YIgMAZfUlpeXaNRC+9nnqOnpDhGpIk4ZfHDp0CD/88AOKi4t9hip4MAyDTz75JLCAxGKsXbsWmZmZGDp0qM8UpcLCQqxcudKnJbVo0SJs2LAB69at89nZfPDgwZg3bx7eeecd3HrrrRg3bhycTif+85//4OrVq3jzzTfRtWtXoS/db55E5nTWTlTyiAhUSSTgnU7YKiuh6NCh2eOhqLZIUCJzuVyYPHky/v3vf4MQAoZhUHMUh+exkEQGACNGjMCBAwewePFibN68GU6nE7169cKKFSswceJEv+v57//+b/Tq1Qv//Oc/sX79ejAMg9tuuw0ffvghHnzwwYDjEqKhRMawLJQdO8J0+TLMpaWQR0XRlgdFCSFkXtNbb71FGIYhTz75JDl27BhhGIbMnTuXZGdnk7///e8kKiqKPProoyQ/Pz9YU6lanL9zzKxWKzl9+jSxWq2EEELKy63kyJEScuZMWZ3lOaeTlP76Kyk5coRY6bzLet34vlIto7XOtRTUR7Zp0yb07NkTa9euRd++fQG47wQOGDAACxYswP79+/H99997O+fbM6m0/hYZALBisbevzFRS4tOypSjKP4IS2fnz531WiGUYxmcruB49emDcuHEhWfOrtROLryey+pKUKjYWDMvCZbHAXuPGBEVR/hGUyKRSKZRKpfexWq3G1atXfcqkpKQ0OieyPfD0kfE8AcfVnchYsRjK2FgAQNWlS23yDub06dNp/x/VbAQlsqSkJBQVFXkf33zzzdi/f79PiyM7OxtRUVFNjzDMiUQsRCJPq6z+MVCquDiwEgk4ux2W0lIAAO9wgLTAFC+KCjeCEtmwYcN8EtfEiRORk5ODsWPH4p///CcmT56MAwcO4N577w1qsOHK009mt9efyFiRCOq4OADuvjJXVRUcBQVw5BfQZEZRjRA0/OKJJ54Ax3G4fPkyEhMT8fzzzyMrKwvff/89tm/fDgDIyMjAW2+9FdRgw5VMJoLV6oLdzsFsdtRbjpeqYbMT8DwHx+85UIjFYKRSSKvsYKWhu9xUKiX0MpAKK4ISWd++fX068iUSCb799lscPXoUeXl5SElJQUZGBli21U0caBGeVS8MBjvi4lr/DRCTaQ5UKjr3kwofghLZxo0bERsb612x1aNfv37o169fUAJrSzyJ7Mb5lm1VamoqCgsL6zxXV0vvxlkZFBUoQYnsySefxHPPPVcrkVF18yQykYiByTSn3nLExcFRUAie41Bls4JwHOQyGbTduoERi0IVLpTKpq0u8eKLL/rMbwWAb775BidPnqxzT9SaezNQlBCCEll8fHyLLJgYrmQyz11L0uglG+lxEwjPQ1VVBUN+PsBwkIl5SFSKUIQaFC+++GKtYwUFBTh58iSWLFkS8niotk9QJ9b48eOxe/fuOieKU7XVvLTk+YZH7jNiMVipFPKoKMgjIwFCYMjPB0+Xr6GoeglKZG+88QZUKhUeeughnDp1KtgxtTli8fWlwhsaS1YTwzDQpqSAlUjgstlgql7qmaKo2gRdWt52222w2+04ceIEduzYAblcjo4dO9bqyGUYBnl5eUEJNJwxDAO53D0Ew2bjIJP597azYjF0qamozM2F5epVSNRqKOggY4qqRVAi43keUqnUu2Gvx41zCekE6OtkMnF1InNBp/N/LwCZTgdVXBzMpaUwFhRArFBAogif/jKKCgVBiaygoCDIYbR9crm7n6yh0f31UXfqBKfFAofRCP358+hwyy1gQ7BTejCtX78e69evb+kwqDaKjlgNEU8is9kCv9vLMAx0aWkQSaXg7Hboz58H4Xk6F5OiqjX5z/rp06dx9uxZmM1mTJkyJRgxtUmefjGbTdjdR5FEAl1aGipzcuAwmWDIy4OcJ2BYFtK0VDBh1kKjqGAS3CI7cuQI+vTpg169euGRRx7xGZm9f/9+KJVKfPvtt8GIsU3wtMjcQzCEzZsUy2RQVS+fZDMYYLVYQHi+TS77Q1GBEJTITp06hZEjRyI/Px9z587F6NGjfc7feeediI6OxldffRWUINsCsZiFSOS+qyu0VcZKpVCkpEJZvTWanXPBKZOCofs8Uu2coETmmWZy7NgxrFy5Ev379/c5zzAMBg0ahCNHjjQ9wjbCPQTDfflntbrgcPFwcYG1pHiHA87LlyARiSCvvpQ0l5XBdOkSvUNMtWuCEtm+ffswYcIE3HTTTfWWSU5ORklJieDA2hoXx8PJuJON0eTAhTITLpSZA0pmDMuCYVgwUik0XbpCIZMDAMxXrrhXlqXJjGqnBCWyqqoqdKzeMKM+VquV7gpdA08Apnr9/gqDHQ4XD54QNDJjyQcjFkOalgppaipEKiU03bpC06kTAMBy5QoMFy7Q/jKqXRK81PXvv//eYJlff/0VnTt3FhRUWyQVs4jv4B7ISlzu7JUUqYRUHNiPwDMXE3D3mani46FLSwMYBrbKSlScOweXzQbe4V7AkQ7RoNoDQYls7Nix2LVrF3744Yc6z2/ZsgXZ2dl44IEHmhJbm+Jw8SizVu80xROAB4oqLXC4mt6CUnTogMguXcCIRHCaTKg4dQqW8+fBmS10uWyqXRCUyF5++WUkJCRgzJgxmDlzJo4ePQoAeP/99zFlyhQ89thjSE1Nxbx584IabDhjGYAVMWCrW2AinoBlGLBBWlFaptWiw803QyyXgycEJosFVbnnQBwOEEKHaFBtm6BRlDExMdi3bx+mTJmCTz75xHv8ueeeAwAMGDAAX3zxBXQ6XXCibAPEIhbp0SoUmDjoK23QisWIj1ZBLAre5AqxQoGoW26BMS8PNqMRNpcLTo6HrlMn7+UoRbVFgoeDp6en4+DBgzhx4gSys7NRUVEBrVaLAQMG1BqOQbmJRSy0Gin0lTZYLc6gJjEvjoOcAIxEApvTCY7wqMjLgzouDqqEBDB0HwWqDWryvJY+ffrQpYoDoFa7B6+aTE4QQoK+WxHDsmBYFjKFAsqUVBgK8uFyuWAqLYW1shKaxETIIiLoLklUm0In6IWYQiGGSMSA4wisVleT18e/kWeIBuF5sFIporp3h81ggKm42D3hPC8PEpUKqthYSNVqsFIpeIfDnQDpfE0qTAn+zb127RrWrVuHI0eOQK/X1zlmjGEY/Pjjj00KsK1hGAYqlQRGowNVVY6gJzLAncw87S1WKoUyJgbyqCiYS0thKS2F02yG/sIFiEQi9w7nRiMYVkQnn1NhS9Bv7W+//YaRI0eisrKywdHk9PKlbhqNFEajA0ajA7GxqpA8JysSQdOpE5QdO8JcXAzrtWvgOA7Gy5fBgIFMJoXIboeYJjIqDAnq+Z0/fz4qKirw17/+Ffn5+XA6neB5vtYXHdlfN88KsVVVjkY3Iwk2kUQCbUoKorp2hay65UZAYLPbUXbmDCpycmC5dg08HXdGhRFBf34PHTqEBx54AMuWLQt2PO2CQiGGRMLC6eRhMjmg1fq/9HUw8A4HuNJSyMViyMViODkODp6Hi+PgqKqCo6oKxosXIVWrIdVoII+KAlt9E4FeelKtkaDfSqlUSqcfCUAIgdNiAQCoJC6UG20oLyGQi7ShDcTlgstqAyE8JAmdwBRfhpwVQZSYCJvRCJfVCs5m8yY1U3ExWJaFWCyGPDYWUq0WIrmcdh1QrYagRDZs2DDvaH7Kf06LBf9Qq1s6jEbNMZnA8DwshYVwOhxwVXcVOBwOOIqKALh3eBIrlZDI5RDL5ZBoNGBFItpqCzJXZSWIzQZJfDycJSVg5HKIIyNbOqxWR9Bv3MqVKzFw4ECsXLkSf/7zn4MdE9UKSDQaqNPS4ci/AEIAjudBdFq47HY4TSbwLhccRiMcRqPP94lYFmKNBmKFAiKZDCKJxP2lVII4nXUmOuJyeYeLtPRQkFAmjsaey1VZiYvTpoO3WpGwYgWKFy4Eq1AgecN6bzma6NwE/ba88cYb6NmzJxYuXIgPP/wQffr0gVZb+/KIYRifKUztnUSpxByTyfu4sMCAigoboqMVSEoO8eVlAyRKpXcRRwBgGPesBMbhgDotDYxYDKfFAqfJBPuVq+BcTvCEgABY8eGHteqbOXkydBoNWIYBw7IQq9XuJCeVgmFZ8OXlYAggiY8Hd/WKe0Bv9fN4EJcLpPrmUX0f2KZ+qP1JHMF4Hn+fi9hs4K1WOIuKUPjYYwAASVISiM0WULztgaBEVnNbrwsXLuDChQt1lqOJzBfDMJCqrg+36JgohsFaCaONhUiugKg5piwJVb2II6RSSDolwnn5kntRx+pOf6laDalaDblGC0e+++fPE4L/XrOmVlUTx46FTqMBTwjAceAMhrqfM+/89af/4w+wYjGY6stVu9UKy7VrOPD++7Bs3wGJXI6OTz4BeWwsxAoFWI5D+apVYJwuxM2di4rVqyFRKpH0z9WQx8e7y4jF4PT6epNQY4kDCF6y8+e5JPHxSFixwnseABJWrIAkPt7vOvyJpS1giIBlRQsLC/0um5KSEmj1rZLRaIROp4PBYKiz9elhs9mQn5+PtLQ0yOXyBuskhOCPP8pgt3NISdEiJkYZ7LCbpLFLPt7hgKOgAKR67TMAYKRSSFNTvZPUObOl+vKUgCcEoo4dQVgWnMMB3ukE73K5/2+zgVS36uriBFBcVoZjzzwDSwC/fzUxLFu94ggDsUYDYrGAZVlI4+PBSqVgJRIwTiecBQVgqsspb70Vkg4dwEok7r1EXS5Ysg8DFjMABgwDiNRqaO66CyKNBgzLgjgcMO3eDXAcNMOHw7xvHxiJBBH33w+RWu1+H0UiuEpKof/yS7jvmTCImjoVspRkgGHAMAw4oxGVGzeCq6iEZ4SzODIKHZ58AqLqaWb2wouoWPOx9zVGPzMbsrRUVFcK3mJB+UcfgzgdiJr8GCq/+AKsVIoOz852x8sw3ufz/Jtyzz2Q1tOX6+/nINQEJbL2qDkSGQCUlppx6VIVFAoxunfvEFZ3AonL5V7rjPA+rTbPDAF/El2tMgQgEjHECQkAw4DnOBCOg7XKhIJzOSheuBC2gkLI77wDnFQKR/VdVpfVCqdeD9vFi+B4Ap7w4CUScHZ7S7w1Ye2p8+cRUc+ohNaayILSo1pRUQGz2YykpKRgVNeuREcrUFxsgtXqgl5vR2Rk48mvtbhxXieTmurTamMauDz11lFHGZZhIVEqvfXwDgccV69CLBIhLSISbKwNEqsNKR995L3McpaUoHDqNDjF16d8SZKSkLxhPdioKG+yqzp6DJdefAGEuC+FY5ctg7RzOjinE67KSpS+tQKc3YaI/3oc5Rs3AmIxIp+YAUil4JxOOMvLUbFpk/sSlQAAAavVQfvgA2BVKvf2fBwHR3EJDN9+C08bU515L0QdorzneasVVVn7wLucUPTtC8uxYwArgiKjv3tXLELcLVS7HYTjwMrl4K1WEM/7Swh4hwPW4ydAOA6ym2+G/ewZgBVB3qsnGLHYPeuGEHBGI6x//OF9X2S3dAerVgHV5z3lAPdVgsiPP8CtDhFIr9eTOXPmkI4dOxKWZYlIJPKey87OJqNHjyZHjx4VWj355ZdfyOjRo4lOpyNKpZIMGDCAbN68WXB9FRUVJCEhgQAgmZmZAX+/wWAgAIjBYGiwnNVqJadPnyZWq9Xvui9dMpIjR0rIH39cIzzPBxxba8Y7nYSz2wkhhHB2O+GdzoDL8E4nMZw5S07u3Usqjh4juXffQ/LGjSfOigpvGWdFBckbN57k3n0PMR/7tc4yjuJiknv3PeR0t5u9X7l330McxcU+9XgeO4qLfb4/mM/jz3P5o7E6/I3FX/5+DkJNUIusoqICgwcPxrlz59C3b1/ExMTgzJkz3vO33norDh48iE2bNuH2228PuP69e/ciMzMTcrkckyZNgkajwdatWzFx4kQUFRVh/vz5Adf53HPPwVBfJ3MLi41V4epVK6xWF8rKrK2ur6wpbpzALqQMIxZDktgJYpcTiptuQsrGDbU6rMWRkUjesN7bqV1XGUYuB6tQQJKU5NNRz9RogdQs72nt1RSs5/HnufzRWB3+xhL2hGS/559/njAM420hLVmyhLAs61Nm3LhxpHfv3gHX7XQ6SefOnYlMJiPHjx/3Htfr9aRr165EKpWSgoKCgOr8+uuvCQCyevXqVtkiI4SQ0lITOXKkhPz6aykxWxyEEELsTo44XVzAsbZFQt/XGwWjFdSanifUsbTWFpmg+/3ffvstxo4di0cffbTeMqmpqbh06VLAde/Zswd5eXl47LHHfBZs1Ol0ePnll+FwOLBhwwa/67t27Rpmz56NKVOm4L777gs4nlDp2FEJpVIMjiPIydPDbHcJ2vuSapg4MtLbcpHExzfbMIRQPU+4xdJcBCWykpISdO/evcEyMpkMZrM54LqzsrIAAKNGjap1LjMzE4B7g2B/PfPMMxCJRFi1alXAsYQSwzBITNICDMDZOJzL1wva+5Ki2iNBfWQdOnRAUfWcu/qcPXsW8QKu+3NzcwEAXbp0qXUuLi4OarXaW6Yxn332Gf7973/jm2++QWRkZEB9ZHa7HfYat+6NN0zFaQ5ajRQJndQovmQCZ3KBETFISlYHvPclRbU3gj4hQ4cOxX/+8596Lx1Pnz6NHTt24O677w64bk+yqW8HJq1W61dCKi4uxpw5czB58mTcf//9AcexfPly6HQ671cohpY4XDyM4MGq3H9fXAYnLhQZg7L3JUW1ZYIS2V//+ldwHIchQ4Zg06ZNKCsrAwCcOXMGn3zyCUaOHAmZTIYFCxYENdhAPPXUU5BIJPjHP/4h6PsXLVoEg8Hg/WqsBRoMLAP3aPIIKSKj3HeV7HoHSopNIV+AkaLCiaBLy169emHz5s2YMmUKpk6dCsA9kK5nz54ghECj0WDLli11Xh42xtMSq6/VZTQaEdlIZ+WGDRuwfft2fPXVV4iOjg44BsDdxyeThXbBQ8/elzwBJCIGl6QiXCk149pVC0xVDqSmaiGTi8ETQCpm4XDxYKsndFOtS4XZAZuTQ0KEAsV6K+QSEaJULbO3aGuKpbkIHtk/fvx45OfnY8OGDTh8+LDPvpYzZswQnEA8yS83N7fWGLTS0lKYTCZkZGQ0WMfx48cBAI888kid53fu3AmGYdC7d2+cOHFCUJyNIQJnftVMSkmJGqhVEhQWGmG1unDmTAUkChEkGglSYtUoqrSAZRikB3mj32BycXxQEq+L48BVt0rr+zD684FtrEyw6nhsTTYsDg7/M7E35m4+CaVUhM9nDgx5AmlNsTSnJk1RioqKwty5c4MVCwD3oo3Lly/Hrl27MGnSJJ9zO3fu9JZpyKBBg2CqsVyOh8lkwubNm5GYmIjMzEwkJycHL/BqIpEIAOB0OqFQKJpcX2SkHGq1BJcumVBeboXTysFp5XC20gGRQgSZUlzrrqY/ySMUZVwcjwtlZvCEIClSWW/ibex5XByPi2VVKDXYYC+pwtyv/qj1YbzxA/viFyegELNYO6UfNFIxnE4OVw12PLvxGCw2F/4yqive+r+zkLEMlo7vCbVUhEqTA0u/PQWbg8PTQ9Pxwd48yFgW80d1hVIiAscRGMwOrPohF3Ynh8n9k/B59kVIWBZPDkmDXMyC5wkqTHbkHihGhcmBu7cXAYQgQiHB38sPQyOXuKceETTwr/v/PN94OauDg4vjoZSKYLK5wDIMZGLWW8Zkc+Hk6Ssw2V0Yvuk8CAHUMjGePWqEQuL+XfX8zfX88f3734eFbFOcYGl1k8ZdLhe6deuGy5cvIzs72zuWzGAwICMjAwUFBcjJyUFqaioA91AQg8GA+Pj4em8QeBQUFCAtLQ2ZmZnYsWNHQHEFMln2woULkEgkSExMDOokcKvViaJLJhgNvhOh5XIxVCoJVCoJZHIRSk12EAZIiqo7efiTYJpSJrWDEiwYOFwcCsss7psVhAAEELMsYrUysGBACIGL43HNaAdPCHRyCQwWJ0AAjVwMEIDnCVwuDiZzGfb9fBGL3sgB4QjEADqqZOA5AqeTh93BwWh2gOcICOd+LkqY8+efQufOEXWeaxOTxktKSmC1WpGamgq2euLvvn376hzX1adPH4wfPz7wgMRirF27FpmZmRg6dKjPFKXCwkKsXLnSm8QAd6f8hg0bsG7dOkyfPj3g52sO0dHRuHz5Mi5dugSdTgeJRBKUhObkeLjkHCQiFpydA3HwIE4eNpsTNpsV5eU1CjPA2VIjwDBgWQYXjFb34ogMAwICq80JDkBOpRkggIgBiqwOsNVhujgCi80JjiM4e80EEPedoXMVZm+C4XnAyXEgPHDmshHupSuA34r09b8GAAVlVXWeu1ajW7Tc26DmQIgNJSUV2PLZRThKbd56Cq8FtrKFWMxCJGbg4AkYEQOGBaJ1ciikIrAsA5GIhZPncdlgcy+bwwA3xaqhUUggErHVZRhYnBz+KDa63xAG6J8WhSi1DCKR+712cDwO5VfA4uS89ahlYoy8pSNUMjEYhoHDxePHs1fgIgR33BSNg3nlEIsYZPaIg0IqcpfheGz/owQunmDEzR2xN+caJCIG4/p0glIqgtnuwn9OFsNgc3p+5NAqpXj49k7QKty/cya7C18dveQuU/2zjVBK8diAZGgVYu/vpefXk2EYREWF3/QlvxNZWVkZunXrhkGDBnkv8QD3ANalS5fWKq/RaJCXlyeor2zEiBE4cOAAFi9ejM2bN8PpdKJXr15YsWIFJk6cGHB9oeb5S1VWVobLly8HrV6eJ7hmsoMQIEolRYXVAQaAWiyC08nBbufhcnFwuYQ1R0qCFukNmOv/MgwDici97hVT/ZgAsLuqP/RgoJKJIGJZ74fLUMVj488VuBCvRMeH1YCIQWyEHK8/1AsJUQpIJCwqrU4s+PdvKKmyASzjHoPXQYmNTw1AcowKEgmLEoMNkz7OxsUKize05Cglvpw10NvfNenjbJAa56NrnAfgLRNbEXH99UUp8X6NMvX1S62ucSnsqedihQVHAEg7RSM5SomlNzzXqeoyP4GDeFAUkqKUeKlGmemFFZjwwSFvKFtnD8LtKVHexxVmB36vI5b5M/u3zz6yjRs3wmw2Y8WKFbXOMQyDzz//3Pu4srISzz77LD799FPBfWgZGRnYvn17o+XWr1/vs2JtQ1JTUwV3wgdKq9VCq9XC6XQGdX/PDhYHHC4eHbVyXDXaIBWziFBe/4W8arThxS+O49JlE3iLC7yNg4YV4d4uHcHygMPBwWB2YN/ZazBbqv+SM4BSJsGQLtFQyUVgWRY2F4ef8sph5jh360XMIEItxZQhqYiJkEMmE8HCcfj4QAHKbQ4wIgYQMYiPUuDNh29FUowSZiePBV+fhM3JY9Hobli+PQdyCYuVj/T2xnzVaMO8LSdRYrB6X0O8ToF3Hu2Njlo5RCIRqhwE/3PKhJujVD4fxjuGdPLpI+uQrYLCIfcpExUhh1Tq7guSS0RQSkVIjlL6lJFL/Dvvb5kolRSfzxzovSHw5ayBtW4IJEQo8D8Te/skof+Z2NuboPwpU6y3Yu7mkz6/H3M3n/RJvP7E0hb43Uc2atQolJaW4rfffvM5vnTpUixbtqzWh3XgwIHQaDTYvXt38KJtQa21b+BG/tylCnWZYNzhC8bdRH/jCcbzNKZmi8wjuZ7WX31lWuKOZGv9HPidyOLj4zF+/Hh89NFHPsfrS2SzZs3C999/j+Li4uBF24Ja6w+wLqH60PtbJhjxtjWh+kMRbK31c+D3pWVFRQU6duxY6/jw4cPrLN+xY0dUVFQIDowS7sZLmJYu05hg1BFu/Lnk87eMR3t57+ridyKTy+V1rmYxbNiwOsd1WSyWkI+Mp6hwEqo/FO2B30OsExMTa/WPNeTkyZNITEwUFBRFUVQg/E5kd955J/bv34/8/PxGy+bl5WH//v0YOnRok4KjKIryh9+JbPbs2XC5XJg4cWKDfV8VFRWYPHkyeJ7HM888E5QgKYqiGuJ3H1nv3r0xb948vPPOO+jevTueeeYZDB8+HAkJCQDc63/t3bsXH3/8Ma5cuYL58+ejd+/ezRZ4qHlu7oZigUWKaq08v/+tbGZjYJuP8DxPXnrpJSIWiwnLsrW+GIYhIpGILFq0qM1ta1ZUVETgnsFHv+hXu/8qKipq6Y+kD0GTxnNzc7F+/XpkZ2ejtLQUABAbG4vBgwdj2rRpgtYha+14nkdxcTE0nm3m62A0GpGUlISioqJWNcamraDvb/Py5/0lhKCqqgoJCQne+datQatb/SKctdbBgm0FfX+bVzi/v60npVIURQlEExlFUWGPJrIgkslkWLx4MZ3R0Ezo+9u8wvn9pX1kFEWFPdoioygq7NFERlFU2KOJjKKosEcTGUVRYY8msiA4cuQIxowZg4iICKhUKgwcOBBbtmxp6bBCIjU1tXojkdpfdS26abfbsWzZMnTp0gVyuRwJCQmYNWsWrl69Wu9zbNq0CRkZGVCpVIiMjMTYsWPx66+/1ls+0J9HSUkJnnzyScTHx0Mul6Nbt25444034HQ6A3ovhPrss8/w9NNPo1+/fpDJZGAYpsF9KIxGI+bNm4eUlBTIZDKkpqZiwYIFde7lCrhnpbz33nvo1asXFAoFYmJiMHnyZFy4cKHe59i5cyeGDRsGjUYDrVaLESNG4Mcff6y3/Llz5/Doo48iOjoaCoUCvXv3xgcffFDvnMxAX0OjWm52VNuwZ88eIpFIiEajITNnziTz5s0jKSkpBABZuXJlS4fX7FJSUohOpyOLFy+u9bVu3TqfshzHkczMTAKADBw4kCxcuJA89NBDhGEYkp6eTq5evVqr/tdff50AICkpKWTevHlk5syZRKPREJlMRg4cOFCrfKA/j5KSEpKUlEQYhiEPPfQQWbhwIRk4cCABQMaPHx+SOcOe+KKjo73/v/G98zCZTKRPnz4EABk1ahRZuHAhGTVqFAFA+vfvT6xWa63veeqppwgA0qNHD/KXv/yFPP7440QqlZKoqChy7ty5WuU//fRTAoDExMSQ5557jjz33HMkJiaGMAxDvvrqq1rlT506RXQ6HZFKpeTxxx8nf/nLX0iPHj0IAPLcc88F5TU0hiayJnA6naRz585EJpOR48ePe4/r9XrStWtXIpVKSUFBQcsFGAIpKSkkJSXFr7L/+te/CAAyefJknwTxwQcfEABk1qxZPuXPnTtHxGIx6dq1K9Hr9d7jx48fJzKZjNxyyy2E4zjvcSE/j6lTpxIA5IMPPvAe43meTJo0iQAgn3/+uV+vrSl2797tjWv58uUNJrJXX32VACALFy70Ob5w4UICgLz55ps+x/fs2UMAkKFDhxK73e49vm3bNm8iqamiooJERESQ6Ohon4nhRUVFJDo6mkRHRxOj0ejzPUOHDiUAyLZt27zH7HY7ufPOOwkA8vPPPzfpNfiDJrIm2LlzJwFAZsyYUevc+vXrCQCydOnSFogsdAJJZIMGDSIAaiUTnudJeno6UalUxGKxeI8vWrSIACAbNmyoVdf06dMJALJv3z7vsUB/HkajkchkMpKenl6r5VVQUEAAkBEjRvj12oKloUTG8zxJSEggarWamEwmn3Mmk4mo1WqSnp7uc3zy5Mm13ieP4cOHEwCksLDQe+yjjz6q9/d2yZIltX4eOTk59b5PWVlZtX4eQl6DP2gfWRNkZWUBcG+Vd6PMzEwAqHMX9rbGbrdj/fr1ePPNN7F69WocPny4VhmbzYbDhw+jW7duSElJ8TnHMAzuuecemM1mHD161Hs80Pc30PKHDh2C3W7HPffcU2tFk5SUFHTr1g0HDx4M6r6kTZGbm4vi4mIMGTIEKpXK55xKpcKQIUNw4cIFFBUVeY9nZWV5z90oGO9hQ+XvuOMOqFQqn/JCXoM/aCJrgtzcXACoc9miuLg4qNVqb5m2rLS0FDNmzMBf//pXPP/88xg4cCAyMjKQl5fnLZOXlwee5+td4slzvOb7lZubC7Vajbi4OL/L1zxXU10/j4bKe447HA4UFhbW/cJDzJ94a5Yzm80oKSlBWloaRCJRo+Ube45Ay4tEIqSlpaGgoAAul0vQa/AXTWRNYDAYAAA6na7O81qt1lumrZoxYwZ+/PFHXLlyBWazGcePH8eUKVNw5MgR3HXXXaiqqgLg33tVs5zn/4GWb+w5Ai1/43O0pEDjFfqe1/c9Qt9znueb9HvgD7+XuqaouixevNjncZ8+fbBx40YAwKeffoo1a9Zg3rx5LREa1Y7QFlkTeP6q1PfXw7NQXXv09NNPAwAOHjwIwL/3qmY5z/8DLd/YcwRa/sbnaEmBxiv0Pa/ve4S+5wzDQKPRCI7JHzSRNUFD1/OlpaUwmUxtctlvf0RHRwOAd1Pn9PR0sCxbb99HXX0nXbp0gclk8i6n7k/5mudqquvn0Vh/TG5uLqRSKZKTk+t5laHlT7w1y6lUKsTHxyM/P7/OGxaBvoeBluc4Dvn5+UhLS4NYLBb0GvxFE1kTeHZY37VrV61zO3fu9CnT3njuXKampgIAFAoFMjIykJOTU6vznBCC3bt3Q6VSoV+/ft7jgb6/gZYfOHAgpFIpdu/eXWsEemFhIXJycjBkyBDvh7CldenSBQkJCTh48KD3D4SH2WzGwYMHkZaWhqSkJO/xYcOGec/dyPOe1Nx/Npjv+YEDB2A2m33KC3kNfgl4wAbl5XQ6SXp6eoMDMPPz81ssvuZ25swZYjab6zweFxdXa/xSoANic3JyAh4QG+jPo74BsZ7xV6EYEFtTaxgQq9Ppgjog9uDBg016Df6giayJ2vMUpcWLFxONRkPuu+8+8uyzz5IFCxaQ+++/n0gkEgKALFq0yKd8XVOUJkyYQBiGIWlpaS0yRam4uNg7RWnChAk+U5TGjRsXkilKa9asIdOmTSPTpk0jffv2JQDIkCFDvMfWrFnjLWsymUjv3r29Seill17ymd5Tc0Cxx41TlKZMmeKdopSTk1OrfENTlLZs2VKr/B9//OGdojRlyhS/pigF+hoaQxNZEBw+fJjce++9RKvVEoVCQTIyMsiXX37Z0mE1u6ysLPLoo4+SLl26EK1WS8RiMYmLiyP3338/2blzZ53fY7PZyJIlS0jnzp2JVColcXFx5KmnniKlpaX1Ps9nn31G+vXrRxQKBdHpdGTMmDHk2LFj9ZYP9OdRXFxMnnjiCRIbG0ukUinp0qULee2113xaMM1p2rRpDe4hOW3aNJ/yer2evPjiiyQpKYlIJBKSnJxM5s+fX6ul5MFxHFm1ahXp0aMHkclkpEOHDmTixInk/Pnz9ca0fft2cueddxKVSkXUajUZNmwY2b17d73lz549Sx5++GESFRVFZDIZ6dWrF/nnP/9Z7x+CQF9DY+hS1xRFhT3a2U9RVNijiYyiqLBHExlFUWGPJjKKosIeTWQURYU9msgoigp7NJFRFBX2aCKjKCrs0URGUVTYo4mMancKCgrAMAymT5/e0qFQQUITGUVRYY8mMoqiwh5NZBRFhT2ayKgm279/P8aNG4fo6GjIZDJ06dIFf/vb32CxWLxlsrKywDAMlixZggMHDmD48OHQaDSIiIjAhAkTcP78+Trr/uOPP/Doo4+iY8eOkMlkSEtLw4svvojy8vI6y1+9ehXz589Ht27doFAoEBUVhQEDBmDlypV1lj9//jwefPBBREZGQqVS4e6778bJkyeb/qZQIUWX8aGa5IMPPsCf/vQnREREYNy4cejYsSOOHj2KrKwsDB48GHv37oVUKkVWVhZGjBiBzMxM7N27F/feey969OiBU6dO4bvvvkN0dDSys7ORnp7urfvAgQPIzMyEw+HAww8/jNTUVBw6dAj79u1D586dkZ2d7d0bAABycnIwYsQIlJSU4I477sDgwYNhNptx6tQpnDx5EhUVFQDcnf1paWkYNmwY/vjjD/To0QP9+vVDXl4e/vOf/yAyMhJnzpxBbGxsyN9PSiBBq5hRFCHk1KlTRCwWk969e5OysjKfc54lmz2rsu7du9e7UOCHH37oU/bDDz8kAMjYsWO9xziOI507dyYAyI4dO3zKL1iwgAAgTzzxhM/xfv36EQDk448/rhVrzWWb8/PzvbG89dZbPuX+9re/EQBk+fLlAbwTVEujiYwSbM6cOQQA2b9/f61zHMeRmJgYcvvttxNCrieyrl27+qyz7ynbpUsXwjCMd7nr/fv3EwBk9OjRtequqqoiUVFRRC6Xe1dxPXz4sHdt+sZ4EllaWlqtWDznHnroIf/eBKpVaB3bw1BhKTs7G4B7d50ff/yx1nmJRIKzZ8/6HBsyZAhY1rdrlmVZDBkyBLm5uTh58iTuvvtuHD9+HAAwfPjwWvWq1Wr069cPu3btQk5ODnr16oVffvkFADBq1Ci/4+/Tp0+tWBITEwEAer3e73qolkcTGSWYp8/pjTfe8Pt76ut38hz3bNzq2ai1vvLx8fE+5Tzf16lTJ79j0Wq1tY55tn6rax9IqvWidy0pwTyJwGg0gri7Ker8qunKlSt11uU57tlh2lN3feU9m/Z6ykVERAAALl++3IRXRIUrmsgowQYMGADg+iWmPw4ePAie532O8TyPn3/+GQzDoHfv3gCA2267DYB72MaNzGYzjh49CoVCgW7dugEAMjIyANS9USzV9tFERgn27LPPQiwW4/nnn8fFixdrndfr9d6+Lo9z585hzZo1PsfWrFmDc+fO4b777kNMTAwAd19a586dsX37dvzwww8+5V9//XWUl5dj8uTJkEqlAID+/fujf//+2L9/f636AdpSa+toHxklWM+ePfH+++9j9uzZ6NatG8aMGYPOnTujqqoKFy5cwL59+zB9+nR8+OGH3u/JzMzEnDlzsG3btlrjyFatWuUtx7Is1q9fj8zMTIwZMwaPPPIIUlJScOjQIWRlZaFz58546623fOLZtGkThg8fjlmzZuHTTz/FoEGDYLPZcOrUKRw/frzeQbRUG9CCd0ypNuKXX34hkyZNIgkJCUQikZDo6GjSt29f8tJLL5EzZ84QQq4Pv1i8eDH56aefyLBhw4hKpSJarZY8+OCDJDc3t866f/vtN/Lwww+T6OhoIpFISEpKCnnhhRfItWvX6ixfWlpKXnjhBZKenu7dTXvAgAHknXfe8ZbxDLG4ceNbDwBk2LBhTXpPqNCiI/upkPCM7F+8eDGWLFnS0uFQbQztI6MoKuzRREZRVNijiYyiqLBH+8goigp7tEVGUVTYo4mMoqiwRxMZRVFhjyYyiqLCHk1kFEWFPZrIKIoKezSRURQV9mgioygq7P0/UtrQfvNZMiUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot generalization error\n",
    "\n",
    "subsample = 5000 #controls how many crosses are plotted from actual simulation\n",
    "cmap = plt.get_cmap(\"tab10\")\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "plt.figure(figsize=(2.5,2.5))\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simegposs[::subsample], color='tab:blue', marker='x', s=10, alpha=1)\n",
    "plt.plot(egposs, '-', label = '+', color='darkblue')\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simegnegs[::subsample], color='tab:red', marker='x', s=10, alpha=1)\n",
    "plt.plot(egnegs, '-', label = '-', color='darkred')\n",
    "plt.legend(loc='lower left')\n",
    "plt.ylabel('Generalization Error')\n",
    "plt.xlabel('epoch')\n",
    "plt.show()\n",
    "plt.rcParams.update({'font.size': 10})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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MwDHBji4u9slRDttlCpafguIxag1euU6EkljoarLExgYyOjRoyukRUdH8+2331JSUkJ+fj5hYWFoteq2xCyPn3LhZmIXUp4eFxenqvxyNBoNCQkJZGZmkp6eTseOHetVXl15ZsaTdKKMPMWf/7zxIfFH/g1nfkKJGcW7VywiqJV6U0paL3UyKOvXr2fNmjUkJydjNBrp0aMH99xzD506dXKfYzabqx378JTycZe9e/dWKS9P79GjR72uA7idwMrHZRqLzIJMMr7dQSegOOFSLvu/J8Diaq2YUhIxrbwLpqyVq4olLQqPDcqdd97JypUrgfPej2vXrmXBggWsXLmS6667zmtKDRkyhMDAQI4fP84vv/xCr169KshXrVoFwIQJE+p1nYMHD5KYmIjZbG70tTwvfrGIroUuJ7BrH7gTbP8CXG7y5OdAcCDYZSBqScvCozGU999/n08//RStVsvUqVN5/fXXefHFFxk0aBAWi4W7776b/Px8ryllMBh46CGXN+aDDz7oHjMBl+v9/v37GT58eAWntjfffJOuXbsye/bsCmWtX7+ezZs3V7rG/v37ueWWWxBCMH36dAyGxtsTOLc4lzWL/49g8rAreq74yzS4aJBLaNcBCkyUYR4lLRBPRm6HDRsmtFqt2LhxYyXZ1KlThUajEUuXLvXqaHFpaakYOHCgAERkZKSYNGmS+zg0NFQcP368wvnPPPOMAMSUKVOqTI+LixPXXXeduO2228SAAQOETqcTgLjyyitFSUlJnXSr78j7/G/nixFBvcUrIP550SAhck8LscAgxAKEeN5HiGcChHithxB5yarKl7QeWuUsz2+//cagQYMYNWpUJdnf//53hBD89ttv3rNygMlkYsuWLcyZMwez2cyaNWtISkpi6tSp7N271+OVxqNHj2batGkEBASwfft2Vq1axbFjxxg6dCjvvfceGzduxMen8cIpCiFYsmUpXfNzAOh20w1QmASUAQrcsd4VM1aGeZS0RDyyOhqNuPvuu6uUORwOoSiKuPfee71o55o39fnV2HpkqzCNihcvo4hXQOSeOCnErnmu1slnI10n5SULUZTtXaUlLZKW1kLxaFBWCFHtFLBGcy5OhtNZpVziojzIzkc7P6LTkVA0nKAsIJqgTh1h17kwj11udv2VYyeSFoqMKdsIlK8KLikrYffP/2Nohqu7FjRw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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot order parameters\n",
    "\n",
    "plt.figure(figsize=(2,2))\n",
    "plt.rcParams.update({'font.size': 15})\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simMs[::subsample], color='tab:green', marker='x', s=10, alpha=1)\n",
    "plt.plot(Ms, '-', label = 'M', color='darkgreen')\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simRposs[::subsample], color='tab:blue', marker='x', s=10, alpha=1)\n",
    "plt.plot(Rposs, '-', label = '$R_+$', color='darkblue')\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simRnegs[::subsample], color='tab:red', marker='x', s=10, alpha=1)\n",
    "plt.plot(Rnegs, '-', label = '$R_-$', color='darkred')\n",
    "plt.scatter(np.arange(1, T+1)[::subsample], simQs[::subsample], color='tab:orange', marker='x', s=10, alpha=1)\n",
    "plt.plot(Qs, '-', label = 'Q', color='darkorange')\n",
    "plt.ylabel('Order Parameter')\n",
    "plt.show()\n",
    "plt.rcParams.update({'font.size': 10})"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
