{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "538dfeb0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import  matplotlib.pyplot as plt \n",
    "import matplotlib as mpl\n",
    "import os\n",
    "\n",
    "from matplotlib.markers import MarkerStyle\n",
    "mpl.rcParams['lines.markersize'] = 9 \n",
    "mpl.rcParams['lines.linewidth'] = 2\n",
    "\n",
    "os.environ['KMP_DUPLICATE_LIB_OK'] = 'True'\n",
    "\n",
    "plt.rcParams.update({'font.size': 20})\n",
    "plt.rcParams['legend.fontsize'] = 20\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = [\"Times New Roman\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fa6c78aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "d = 2\n",
    "n = 20\n",
    "k = 40\n",
    "eta = 1 # learning rate / scaling\n",
    "batchsize = k # k means gd\n",
    "steps = 10000\n",
    "init = 1/n\n",
    "\n",
    "# Generate k data points x_k of dimension d\n",
    "np.random.seed(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0e95aced",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = np.random.normal(0,1, (k, d)) # should be sample from the unit sphere\n",
    "x_norm = np.linalg.norm(x, axis = 1)\n",
    "\n",
    "x = np.transpose(x)/x_norm\n",
    "x = np.transpose(x)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9eabc7a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1 -1]\n"
     ]
    }
   ],
   "source": [
    "# Teacher with l neurons\n",
    "l = 2\n",
    "\n",
    "a_t = np.random.choice([1,-1], l)\n",
    "\n",
    "w_t = np.random.normal(0,1,(l,d))\n",
    "w_norm_t = np.linalg.norm(w_t, axis = 1)\n",
    "\n",
    "w_t = np.transpose(w_t)/w_norm_t # Normalize\n",
    "w_t = np.transpose(w_t)\n",
    "#print(x)\n",
    "#print(w_t)\n",
    "z_t = np.dot(x,np.transpose(w_t)) # Inner part of the ReLu\n",
    "z_t = np.maximum(z_t,0)\n",
    "#print(z_t)\n",
    "h_t = a_t*z_t \n",
    "print(a_t)\n",
    "#print(h_t)\n",
    "y = np.sum(h_t, axis = 1)#/l # Teacher output\n",
    "#print(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f4ffea07",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Student network of n neurons\n",
    "\n",
    "# Initialisation\n",
    "#a_s = np.random.normal(0, 0.1, n) # Normal initialisation\n",
    "#w_s = np.random.normal(0, 0.1, (n,d))\n",
    "\n",
    "a_s = np.abs(np.random.normal(0, init, n)) # COB initialisation\n",
    "w_s = np.random.normal(0, init, (n,d))\n",
    "\n",
    "a_s[n//2:] = -a_s[:n//2]\n",
    "w_s[n//2:,:] = w_s[:n//2,:]\n",
    "\n",
    "a_s_I = a_s # Store initialisation\n",
    "w_s_I = w_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "308ce8cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.12730563528783612\n"
     ]
    }
   ],
   "source": [
    "# Compute the Loss\n",
    "z_s = np.dot(x, np.transpose(w_s)) # Inner part of the ReLu\n",
    "Index_s = z_s > 0\n",
    "z_s = np.maximum(z_s, 0)\n",
    "\n",
    "h_s = a_s*z_s \n",
    "\n",
    "f_s = np.sum(h_s, axis = 1)#/n\n",
    "#print(f_s)\n",
    "#print(np.sum(f_s))\n",
    "#print(np.sum(y))\n",
    "#print(np.sum(np.square(f_s-y)))\n",
    "#print(np.sum((f_s-y)**2))\n",
    "\n",
    "# Loss function and optimization\n",
    "S = len(y)\n",
    "L = np.sum((f_s-y)**2)/(2*S)\n",
    "print(L)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "461a87c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run(eta, steps, batchsize, S, x, w_s, a_s):\n",
    "\n",
    "    L = []\n",
    "    n = len(a_s)\n",
    "\n",
    "    for i in range(steps):\n",
    "        \n",
    "        # Forward Pass\n",
    "\n",
    "        z_s = np.dot(x, np.transpose(w_s)) # Inner part of the ReLu\n",
    "        Index_s = z_s > 0\n",
    "        z_s = np.maximum(z_s, 0)\n",
    "\n",
    "        h_s = a_s*z_s \n",
    "        f_s = np.sum(h_s, axis = 1)#/n\n",
    "        \n",
    "        L.append(np.sum((f_s-y)**2)/(2*S))\n",
    "        \n",
    "        \n",
    "        # Backward Pass\n",
    "\n",
    "        BatchIndex = np.random.permutation(S)[:batchsize]\n",
    "\n",
    "\n",
    "        Derivative_L = (f_s-y)/S\n",
    "\n",
    "        Derivative_a_s = np.sum(Derivative_L[BatchIndex] * np.transpose(z_s[BatchIndex]), axis = 1)\n",
    "\n",
    "        Derivative_w_s = np.zeros((d,n))\n",
    "\n",
    "        #print(BatchIndex)\n",
    "        for i in BatchIndex:\n",
    "        \n",
    "            Derivative_w_s += Derivative_L[i]*np.outer(x[i],np.transpose(a_s*Index_s[i]))\n",
    "\n",
    "        w_s = w_s - eta*np.transpose(Derivative_w_s)\n",
    "        a_s = a_s - eta*Derivative_a_s\n",
    "        \n",
    "    return w_s, a_s, L\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "ea9d55b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def circle(x, sign):\n",
    "    if sign == '+':\n",
    "        return np.sqrt(1-x**2)\n",
    "    elif sign == '-':\n",
    "        return -np.sqrt(1- x**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1f8ea3b5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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FEUv0lBVVbqQhBBNyt69e/XrkhR+IFNThRBNUU1NDbm5uQDExsYaslT2hfwiKYSGhupdSNXV1VLdHOTOnj1Lp06d6Ny5s74XrRBN0YEDB/RZl506dfKLXSj9IikoiqK3FqQLKfitXbuW/fv3s2/fPtasWWN0OEIYZufOnfr1Ll26GBjJeT7fo/liwsPDqaqqArSFoWp3KYngMnr0aCZOnKhfF6Ipqqys1KuYY2NjDa1irs1vkoKnC0lVVaqrq3G73ZhMDdSQqTwONQVXEUwiRPrHf1AwioyMZO7cuUaHIYSh9uzZo8+27N69u190HYEfJQXPLCSbzaYnhoiIiOt/4srjML8juK9iANsUBuP3S2IQQjSa2l1H3bt3NzASb34xpuBROwnYbLaGedKagqtLCKDd/2paFkIIcRWKior0grWUlBRSUlIMjug8v0oKISEhmM1mQNuNTbbpFEIEo+3bt+vX/amVAH6WFBRF8WoteAaehf87duwY9957L82aNdOr1BVFIS4urs59d+zYwRNPPEFsbCxHjx6tc7vNZuOll16iS5cuREdHEx8fz+23305OTk69r22325k5cya9e/fm97//PQCbN29m1KhRREVFkZmZyYcfftiA71aIa+d2u9m2bRsAJpOJnj17GhyRN79KCoDXFnSe8QXh3woLCxk6dChJSUkcO3aMqqoqVqxYUac6s7S0lMmTJzNs2DDefvttysrK6jxXSUkJgwcPZurUqUydOpXS0lL+85//sGvXLgYMGEBERARxcXEkJCQwb948PvjgA/r27Ut2drZ+9vXZZ58xfPhw9u7di91u5/Dhw2RnZ7N69Wpf/DqEuKSDBw9SXl4OQIcOHYiOjjY4Im9+lxQsFou+SJ7L5ZKahQDwwQcfcPLkSV555RWioqIwm82MGDGC+fPne60LHxsby6effspnn3120ed65pln2LFjBz//+c8ZO3YsJpOJvn378te//lXfoW/Lli0UFRUxYcIE7r//frZu3UpycjIAy5cv5+uvv2bfvn0cP36ckydP0qZNG1RV5e23327034UQl7N161b9ep8+fQyMpH5+lxRAm7LoUVlZaWAkgcfpdOpdN9dzmT59+hW/pqdMf+XKlV7HMzMzmTBhQp37Z2Rk1Ps8drudTz/9FID+/ft73TZhwgRiY2NxOp3MmjVLPx4eHk5ISAjp6ekA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "k=20\n",
    "w_s, a_s, L_og = run(2, steps, batchsize, S, x, w_s_I, a_s_I)\n",
    "\n",
    "result = np.transpose(w_s)*np.abs(a_s)\n",
    "initialisation =  np.transpose(w_s_I)*np.abs(a_s_I)\n",
    "\n",
    "#plt.scatter(result[0][:k//2-1], result[1][:k//2-1], color = 'purple', label = '+')\n",
    "#plt.scatter(result[0][k//2:], result[1][k//2:], color = 'orange', label = '-')\n",
    "#plt.scatter(initialisation[0], initialisation[1], color = 'red')\n",
    "\n",
    "#plt.plot([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "#plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "#plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "#plt.legend()\n",
    "#plt.savefig('dense_init.png')\n",
    "#plt.show()\n",
    "\n",
    "markers=[\"*\",\"o\"]\n",
    "colors = [\"purple\", \"orange\"]\n",
    "\n",
    "index = (a_s > 0)\n",
    "index2 = (a_s <=0)\n",
    "\n",
    "plt.scatter(result[0][index], result[1][index], color = 'purple', label = '+', facecolors='none')\n",
    "plt.scatter(result[0][index2], result[1][index2], color = 'orange', label = '-', facecolors='none')\n",
    "\n",
    "\n",
    "index = (a_s_I > 0)\n",
    "index2 = (a_s_I <=0)\n",
    "\n",
    "plt.scatter(initialisation[0][index], initialisation[1][index], color ='purple', marker = MarkerStyle(\"*\", fillstyle=\"right\"))\n",
    "plt.scatter(initialisation[0][index2], initialisation[1][index2], color = 'orange', marker = MarkerStyle(\"*\", fillstyle=\"left\"))\n",
    "\n",
    "\n",
    "plt.arrow(0, 0, \n",
    "          w_t[0][0] ,w_t[0][1], \n",
    "          head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "plt.arrow(0, 0, \n",
    "          w_t[1][0] ,w_t[1][1], \n",
    "          head_width=0.05, head_length=0.1, fc='orange', ec='orange', length_includes_head = True)\n",
    "\n",
    "#plt.arrow(0, 0, \n",
    "#          w_t[2][0] ,w_t[2][1], \n",
    "#          head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "#plt.quiver([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "#plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "#plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "#plt.scatter(white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "#plt.scatter(-white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "circ = np.linspace(-1,1, num = 500)\n",
    "plt.plot(circ, circle(circ, '+'), color = 'black', alpha = 0.5)\n",
    "plt.plot(circ, circle(circ, '-'), color = 'black', alpha = 0.5)\n",
    "#plt.xlabel(r'$w_1$')\n",
    "#plt.ylabel(r'$w_2$')\n",
    "plt.box(False)\n",
    "plt.gca().axes.xaxis.set_visible(False)\n",
    "plt.gca().axes.yaxis.set_visible(False)\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "f = lambda m,c: plt.plot([],[],marker=m, color=c, ls=\"none\")[0]\n",
    "\n",
    "handles = [f(\"s\", colors[i]) for i in range(2)]\n",
    "handles += [f(markers[i], \"k\") for i in range(2)]\n",
    "\n",
    "labels = [r'$+$ sign', r'$-$ sign', 'Init', 'Final']\n",
    "\n",
    "plt.legend(handles, labels, loc = 'lower left')\n",
    "plt.savefig('dense_final.pdf',bbox_inches='tight',dpi=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2da0ca12",
   "metadata": {},
   "outputs": [],
   "source": [
    "def is_topk(a, k=1):\n",
    "    _, rix = np.unique(-a, return_inverse=True)\n",
    "    return np.where(rix < k, 1, 0).reshape(a.shape)\n",
    "\n",
    "def is_bottomk(a, k=1):\n",
    "    _, rix = np.unique(a, return_inverse=True)\n",
    "    return np.where(rix < k, 1, 0).reshape(a.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "808b7f6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def runCD(eta, steps, batchsize, S, x, y, w_s, a_s, p1, p2, x_test, y_test, y_pre, grad_crit):\n",
    "\n",
    "    L = []\n",
    "    n = len(a_s)\n",
    "    \n",
    "    L_test = []\n",
    "\n",
    "    L_pre = []\n",
    "    \n",
    "    for i in range(steps):\n",
    "        \n",
    "        # Forward Pass\n",
    "\n",
    "        z_s = np.dot(x, np.transpose(w_s)) # Inner part of the ReLu\n",
    "        Index_s = z_s > 0\n",
    "        z_s = np.maximum(z_s, 0)\n",
    "\n",
    "        h_s = a_s*z_s \n",
    "        f_s = np.sum(h_s, axis = 1)#/n\n",
    "        \n",
    "        L.append(np.sum((f_s-y)**2)/(2*S))\n",
    "        \n",
    "        # test\n",
    "        z_test = np.dot(x_test, np.transpose(w_s)) # Inner part of the ReLu \n",
    "        Index_test = z_test > 0\n",
    "        z_test = np.maximum(z_test, 0)\n",
    "\n",
    "        h_test = a_s*z_test \n",
    "        f_test = np.sum(h_test, axis = 1)#/n\n",
    "        \n",
    "        L_test.append(np.sum((f_test-y_test)**2)/(2*len(y_test)))\n",
    "        \n",
    "        # pretrain check\n",
    "        z_pre = np.dot(x, np.transpose(w_s)) # Inner part of the ReLu \n",
    "        Index_pre = z_pre > 0\n",
    "        z_pre = np.maximum(z_pre, 0)\n",
    "\n",
    "        h_pre = a_s*z_pre \n",
    "        f_pre = np.sum(h_pre, axis = 1)#/n\n",
    "        \n",
    "        L_pre.append(np.sum((f_pre-y_pre)**2)/(2*len(y_pre)))\n",
    "        \n",
    "        \n",
    "        # Backward Pass with coord descent\n",
    "\n",
    "        BatchIndex = np.random.permutation(S)[:batchsize]\n",
    "\n",
    "\n",
    "        Derivative_L = (f_s-y)/S\n",
    "\n",
    "        Derivative_a_s = np.sum(Derivative_L[BatchIndex] * np.transpose(z_s[BatchIndex]), axis = 1)\n",
    "\n",
    "        Derivative_w_s = np.zeros((d,n))\n",
    "\n",
    "        #print(BatchIndex)\n",
    "        for j in BatchIndex:\n",
    "        \n",
    "            Derivative_w_s += Derivative_L[j]*np.outer(x[j],np.transpose(a_s*Index_s[j]))\n",
    "\n",
    "            \n",
    "        # Create mask on w and a based on magnitude, since we only have a small subset choose Top/bottom k\n",
    "        #print(i)\n",
    "        if i <  1:\n",
    "            print('mask mask')\n",
    "            size_w = np.abs(w_s)\n",
    "            size_a = np.abs(a_s)\n",
    "        \n",
    "            mask_w = np.mod(is_topk(size_w, int(d*p1)) + is_bottomk(size_w, int(d*p2)), 2)\n",
    "            mask_s = np.mod(is_topk(size_a, p1) + is_bottomk(size_a, p2), 2)\n",
    "        \n",
    "        \n",
    "            # change mask based on large grads now:\n",
    "            if grad_crit:\n",
    "            \n",
    "                size_w_grad = np.abs(Derivative_w_s)\n",
    "                size_a_grad = np.abs(Derivative_a_s)\n",
    "            \n",
    "                mask_w = np.transpose(is_topk(size_w_grad, int(d*p1)))\n",
    "                mask_s = np.transpose(is_topk(size_a_grad, p1))\n",
    "            \n",
    "        \n",
    "        w_s = w_s - eta*np.transpose(Derivative_w_s)  * mask_w\n",
    "        a_s = a_s - eta*Derivative_a_s * mask_s\n",
    "        \n",
    "    return w_s, a_s, L, L_test, L_pre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0a1e8320",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Init\n",
    "w_s_ft_in, a_s_ft_in = w_s, a_s\n",
    "\n",
    "# generate ft data set\n",
    "\n",
    "# x could still stay the same..\n",
    "\n",
    "# 4 neurons now, with 3 being rather similar to teacher, and one new one\n",
    "w_t_ft, a_t_ft = np.vstack([w_t, np.array([-1/np.sqrt(2), -1/np.sqrt(2)])]), np.append(a_t, 1)\n",
    "\n",
    "\n",
    "# generate ft labels\n",
    "z_ft_t = np.dot(x,np.transpose(w_t_ft)) # Inner part of the ReLu\n",
    "z_ft_t = np.maximum(z_ft_t,0)\n",
    "\n",
    "h_t_ft = a_t_ft*z_ft_t \n",
    "\n",
    "y_ft = np.sum(h_t_ft, axis = 1)#/l # Teacher output\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "43ff8eaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Fine tuning representation with temperature\n",
    "\n",
    "def Finetunerep(w, a, x, epsilon):\n",
    "    # generate noise perturbation  on one neuron with strength epsilon\n",
    "    \n",
    "    choose = np.random.choice(len(a), 1)[0]\n",
    "    print(choose)\n",
    "    indicator = np.eye(1,len(a),choose)[0]\n",
    "    \n",
    "    print(indicator)\n",
    "    noise_w = indicator[:, np.newaxis]  * np.random.normal(0, epsilon, w.shape)\n",
    "    \n",
    "    print(noise_w)\n",
    "    # apply to w\n",
    "    \n",
    "    w_new = w + noise_w\n",
    "    a_new = a\n",
    "    \n",
    "    # project back to unit sphere \n",
    "    \n",
    "    w_new_t = np.linalg.norm(w_new, axis = 1)\n",
    "\n",
    "    w_new = np.transpose(w_new)/w_new_t # Normalize\n",
    "    w_new = np.transpose(w_new)\n",
    "    \n",
    "\n",
    "    \n",
    "    # calculate labels\n",
    "    \n",
    "    z_new = np.dot(x,np.transpose(w_new)) # Inner part of the ReLu\n",
    "    z_new = np.maximum(z_new,0)\n",
    "\n",
    "    h_new = a_new*z_new \n",
    "\n",
    "    y_new = np.sum(h_new, axis = 1)#/l # Teacher output\n",
    "    \n",
    "    return w_new, a_new, y_new\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "da244546",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Fine tuning representation with temperature\n",
    "\n",
    "def FinetunerepAdd(w, a, x, x_test):\n",
    "    # generate noise perturbation  on one neuron with strength epsilon\n",
    "    \n",
    "    w_star = np.random.normal(0, 1, len(w.transpose()))\n",
    "    \n",
    "    #print(w_star)\n",
    "    a_star = np.random.choice([-1,1],1)\n",
    "    \n",
    "    #print(a_star)\n",
    "    \n",
    "    \n",
    "    w_new, a_new = np.vstack([w, w_star]), np.append(a, a_star[0])\n",
    "\n",
    "    \n",
    "    \n",
    "    # project back to unit sphere \n",
    "    \n",
    "    w_new_t = np.linalg.norm(w_new, axis = 1)\n",
    "\n",
    "    w_new = np.transpose(w_new)/w_new_t # Normalize\n",
    "    w_new = np.transpose(w_new)\n",
    "    \n",
    "\n",
    "    \n",
    "    # calculate labels\n",
    "    \n",
    "    z_new = np.dot(x,np.transpose(w_new)) # Inner part of the ReLu\n",
    "    z_new = np.maximum(z_new,0)\n",
    "\n",
    "    h_new = a_new*z_new \n",
    "\n",
    "    y_new = np.sum(h_new, axis = 1)#/l # Teacher output\n",
    "    \n",
    "    # calculate test labels\n",
    "    \n",
    "    z_test = np.dot(x_test,np.transpose(w_new)) # Inner part of the ReLu\n",
    "    z_test = np.maximum(z_test,0)\n",
    "\n",
    "    h_test = a_new*z_test\n",
    "\n",
    "    y_test = np.sum(h_test, axis = 1)#/l # Teacher output\n",
    "    \n",
    "    return w_new, a_new, y_new, y_test\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "2887090e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulationFT(lr, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, top, bottom, seed, x_test, y_pre, figure : bool, grad_crit : bool):\n",
    "    \n",
    "    np.random.seed(seed)\n",
    "    \n",
    "    # generate labels and new representation with noise\n",
    "    w_e, a_e, y_ft, y_test = FinetunerepAdd(w_t, a_t, x, x_test)\n",
    "    \n",
    "    \n",
    "    k=20\n",
    "    \n",
    "    # simulate gradient flow/descent initialized from w_s_ft_in, a_s_ft_in\n",
    "    w_s, a_s, L_og, L_test, L_pre = runCD(lr, steps, batchsize, S, x, y_ft, w_s_ft_in, a_s_ft_in, top, bottom, x_test, y_test, y_pre, grad_crit)\n",
    "    \n",
    "    result = np.transpose(w_s)*np.abs(a_s)\n",
    "    initialisation =  np.transpose(w_s_ft_in)*np.abs(a_s_ft_in)\n",
    "    \n",
    "    distance = np.linalg.norm(w_s - w_s_ft_in)**2 + np.linalg.norm(a_s - a_s_ft_in)**2\n",
    "    \n",
    "    print(w_s.size)\n",
    "    distance = np.sqrt(distance)/(w_s.size + a_s.size)\n",
    "    \n",
    "    \n",
    "    if figure:\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "        #plt.scatter(result[0][:k//2-1], result[1][:k//2-1], color = 'purple', label = '+')\n",
    "        #plt.scatter(result[0][k//2:], result[1][k//2:], color = 'orange', label = '-')\n",
    "        #plt.scatter(initialisation[0], initialisation[1], color = 'red')\n",
    "\n",
    "        #plt.plot([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "        #plt.legend()\n",
    "        #plt.savefig('dense_init.png')\n",
    "        #plt.show()\n",
    "\n",
    "        index = (a_s > 0)\n",
    "        index2 = (a_s <=0)\n",
    "\n",
    "        plt.scatter(result[0][index], result[1][index], color = 'purple', label = '+', facecolors='none')\n",
    "        plt.scatter(result[0][index2], result[1][index2], color = 'orange', label = '-', facecolors='none')\n",
    "\n",
    "\n",
    "        index = (a_s_ft_in > 0)\n",
    "        index2 = (a_s_ft_in <=0)\n",
    "\n",
    "        plt.scatter(initialisation[0][index], initialisation[1][index], color ='purple', marker = MarkerStyle(\"*\", fillstyle=\"right\"))\n",
    "        plt.scatter(initialisation[0][index2], initialisation[1][index2], color = 'orange', marker = MarkerStyle(\"*\", fillstyle=\"left\"))\n",
    "\n",
    "\n",
    "        colorlist = ['orange', 'purple']\n",
    "        \n",
    "        colorindex = a_e > 0\n",
    "        \n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[0][0] ,w_e[0][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[0]], ec=colorlist[colorindex[0]], length_includes_head = True, alpha = 0.5)\n",
    "\n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[1][0] ,w_e[1][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[1]], ec=colorlist[colorindex[1]], length_includes_head = True, alpha = 0.5)\n",
    "\n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[2][0] ,w_e[2][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[2]], ec=colorlist[colorindex[2]], length_includes_head = True, alpha =1)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "        #          w_e[3][0] ,w_e[3][1], \n",
    "        #          head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[0][0] ,w_t[0][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='orange', ec='orange', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[1][0] ,w_t[1][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='orange', ec='orange', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[2][0] ,w_t[2][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t_ft[3][0] ,w_t_ft[3][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "\n",
    "        markers=[\"*\",\"o\"]\n",
    "        colors = [\"purple\", \"orange\"]\n",
    "        #plt.quiver([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "        #plt.scatter(white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "        #plt.scatter(-white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "        circ = np.linspace(-1,1, num = 500)\n",
    "        plt.plot(circ, circle(circ, '+'), color = 'black', alpha = 0.5)\n",
    "        plt.plot(circ, circle(circ, '-'), color = 'black', alpha = 0.5)\n",
    "        #plt.xlabel(r'$w_1$')\n",
    "        #plt.ylabel(r'$w_2$')\n",
    "        plt.box(False)\n",
    "        plt.gca().axes.xaxis.set_visible(False)\n",
    "        plt.gca().axes.yaxis.set_visible(False)\n",
    "        plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "        f = lambda m,c: plt.plot([],[],marker=m, color=c, ls=\"none\")[0]\n",
    "\n",
    "        handles = [f(\"s\", colors[i]) for i in range(2)]\n",
    "        handles += [f(markers[i], \"k\") for i in range(2)]\n",
    "\n",
    "        labels = [r'$+$ sign', r'$-$ sign', 'Init', 'Final']\n",
    "\n",
    "        plt.legend(handles, labels, loc = 'lower left')\n",
    "       \n",
    "        plt.savefig(f'runftbottom{bottom}top{top}distseed{seed}.pdf',bbox_inches='tight',dpi=100)\n",
    "        plt.show()\n",
    "    return L_og, L_test, L_pre, distance\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "ef7bb9da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mask mask\n",
      "40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:59: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[0]], ec=colorlist[colorindex[0]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:63: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[1]], ec=colorlist[colorindex[1]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:67: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[2]], ec=colorlist[colorindex[2]], length_includes_head = True, alpha =1)\n"
     ]
    },
    {
     "data": {
      "image/png": "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9TzxxBP069ePmJgYEhISuOGGG9i8eXOLr+1wOJg/fz5Dhw7l8ccfB2DLli1ce+21REdHk52dzVtvvdWG71aIi+fxeNi+fTsAJpOJwYMHG9wiXwEVFACfLei88wsisJWVlTF+/HiSk5M5cuQIDQ0NrFy5sll2ZlVVFXfccQeXX345L730EtXV1c2eq7KykrFjxzJ37lzmzp1LVVUVX331Fbt372bUqFFERkYSHx9PYmIiixYt4rXXXmP48OHMmTNHP/p69913mTBhAnv37sXhcJCfn8+cOXP4+uuv/fHnEOKsDhw4QE1NDQC9evUiJibG4Bb5CrigYLFY9CJ5brdbchaCwGuvvcbx48d5+umniY6Oxmw2M3HiRBYvXuxTFz4uLo533nmHd999t9Xnevjhh9m5cyc//vGPmTZtGiaTieHDh/O3v/1N36Fv69atlJeXM2PGDO688062bdtGSkoKACtWrODjjz9m3759HD16lOPHj9OtWzdUVeWll15q97+FEOeybds2/fywYcMMbEnLAi4ogLZk0auurs7AlgQfl8ulD91cyunNN98879f0pumvWrXK5/rs7GxmzJjR7P5ZWVktPo/D4eCdd94BYOTIkT63zZgxg7i4OFwuF++9955+fUREBFarle7duwOQnp7O22+/ra/5TklJYfbs2YBvjRkhjFBdXa3vnRAbG2v43gktCcigEBYWpk84NzY2yoRzgPPWf7/99tt58cUXff6/XnvttWb3by0xsby8XK99deaabUVR9GBy7NixZo/19i579erV7LauXbsC6F12IYyydetWfUh82LBhbZeL1YYCJk+hKUVRiIqK0sec6+rqiIuLM7hVwcFisbTJEfGFFOa6//77ef3118nNzeWhhx5i7ty5/OIXv+C+++5rMQC0lqSTkpJCVFQUdXV1eu+jKe+XqaXle2f7cnnnqWRnP2Ekl8ulL5YwmUwBOXQEARoUQPsie4NCfX09MTExARlVA5G/y+/GxMSwYcMGHnvsMV544QUOHz7MQw89xHPPPcdrr73G5MmTz+t5TCYTDzzwAH//+9+ZN28eP/nJT/QAUlVVxcGDBzGbzdx2223t+XaEaBe7du3S86/69+9PbGyswS1qWcD+yprNZp99FmR5amCLiopi7ty5HDhwgO9973uYzWYKCgqYOnUqa9euPe/neeaZZ5g+fTo7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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mask mask\n",
      "40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:59: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[0]], ec=colorlist[colorindex[0]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:63: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[1]], ec=colorlist[colorindex[1]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_24920\\854639267.py:67: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[2]], ec=colorlist[colorindex[2]], length_includes_head = True, alpha =1)\n"
     ]
    },
    {
     "data": {
      "image/png": "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/TSJiYkkJiby2muvBeQ9CdGavF4vH3zwAVVVVQB06dKFK6+80uCoAqddJIV77rmHyMhIv9aA76i28dGtoihERkZy9913BzzGtrZjxw5uvvlmRowYwZtvvonL5eLYsWOMHj2a+fPn43Q6qaqq4rXXXuN//ud//B77m9/8htGjR/Pwww9z5MgRv9sefPBBSktL9Tnbv/nNb6isrKSyspK77rorYO9PiNayYsUKDh48CGjjCDfddFPYVS2fS7tICnfccQebN28mJyfnrHOLTSYTubm5bN68mTvuuCPAEba93Nxc3n33XX72s58BUF9fz49//GOeffZZTp48SVlZGT/5yU8AmD9/vl8V+NNPP82OHTva1RdDtE979uxh1apVgPabcNNNN/lN3GgP2kVSAOjbty9btmxh2rRpzd4+ffp0tmzZctbplqHONy01NzcX0Jb/+Ne//sXUqVP1FpQvYbjdbn3GhU98fHzIbzMoxLmUlpb61SNcddVVdO/e3biADNJukgJos5BKSkqatBZMJhNFRUVERUUZFFng+GZhJSQkNFm3pUuXLvr55gr9WqveQYhgY7fb+e9//6uPNfbr1y/sVj9tqXaVFL788ks2btyI1+slMjKSBx54gIiICLxeL1u2bGHx4sVGh9jmzlWa3zgp+mZdNBbu87NF++R2u3nnnXeoqKgAtOWwZ86c2W4/7+0mKaiqyu9//3sAevXqxebNm/n73//O6tWr6dGjBwCPPvqoXvEshAh/qqqyePFifQJFbGwst912GzabzeDIjNNukoLL5SIxMZG77rrLb+xg+PDhrFq1iptvvpn4+HhKSkpkYx4h2onVq1ezfft2ACwWC7fddpvfCgjtUbsoXgNt850vvvii2SZhRkYGL774Ig0NDSiKQnl5OSkpKTLbRogwtnPnTn1lA4Drr79eilZpRy0FOHufuKIoJCcn6yuqejweysvLQ3Ydn8a1F4GqMvaNVUj3mwgFBw8ebLLyabjOPLxQ7SopnIvJZKJDhw5668DlclFRURGSSzf4BsxAq1huzHfZN8vibJqrarbb7We9LS4uDtCa4x6PhwMHDsiKqSIoHTt2jHfeeUc/6Bs2bFjYbphzMSQpNGI2m0lOTtZbFA0NDVRWVoZMYlBVlTVr1ujFNwDPPfecngAcDoc+w6q4uNjvfoDf5jkffvih3wykZcuWcfLkSQA++uijJknFN31vzZo1ZGRkMH78eObOnduK706IS1daWsp///tffSfGPn36cM0117TbmUbNUdQ2/MVzOBzk5+eTlZUVUnPcGxoaKCsr0y9HR0eTkJAQ1B+c1atXc/XVVzd7FG+xWBg3bhzffPNNk6mmWVlZHDp0iISEhCatCqvVyq5du/jxj3/s1/fqe86vvvqKSZMmAVrr4d5772XhwoX079+fF198keHDh7fumzRIqH6OhT/fMi6VlZUAdO/ene9973tYLO1maLVFJCmchcPhoLy8XL8cExNDfHx8UCcG0TZC+XMsNDU1Nbz22mv6d7pjx47ceeed8v/ZDOk+OovIyEi/DWrq6urCejtPIcJVbW0t8+fP1xNChw4d+N73vicJ4SwkKZxDVFSU33aetbW1khiECCF1dXUsWLCA0tJSQNuJcO7cue1is5yLJUnhPHzjCT41NTVUV1eHzOCzEO2V3W5nwYIFlJSUANp6X3Pnzm13q55eKBlhaYGYmBhUVdUHYmtra1FVVcYYhAhSNTU1LFiwQJ8xFx8fz9y5c/1a/qJ5khRaKDY2FkVR9N2YfPsNSGIQIrhUVlayYMECfQwhLi6OuXPnkpycbHBkoUGSwgWIiYkB8EsMqqoG/XRVIdqLsrIyFixYoH9HExMTmTt3rt+kEXFukhQuUExMDIqi6HOd7XY7Xq+XpKQkSQxCGKi4uJg33niD2tpaQJtldMcdd7T7Be4ulAw0X4To6Gi/vkmHw0FZWVnIrpUkRKg7cuQIr7/+up4Q0tPTueuuuyQhXARpKVyk6OhoTCaTvj6S0+mkrKyM5ORkWV1ViADatWsXCxcuxO12A9C5c2e+973vtYudFNuCtBQuQWRkJB06dNC7jVwuF6WlpfqHUwjRtr799lvef/99/TvXs2dP7rjjDkkIl0CSwiWy2Wx+ey94PB5KS0vPuwqpEOLiqarK559/zhdffKHXDA0ZMoQ5c+bo+5CLiyPdR63AarWSkpJCWVkZbrcbr9dLWVkZiYmJREdHGx2eEGHF6XSycOFCdu/erV83adIkJk6cKJM9WoEkhVZiNptJSUmhoqJCbyVUVlbidruJi4uTD6sQraCiooK3336b4uJiQNsHZcaMGQwdOtTgyMKHJIVWZDKZSE5Oprq6Wi9uq62txeVykZSUpO9OJoS4cIcPH+bdd9/VN3uKjIzkxhtvJDs72+DIwoskhVamKAoJCQlYLBa9gKahoYHS0lKSkpL0LT+FEC23ceNGPvvsM33ad0pKCrfeeispKSkGRxZ+JCm0kZiYGCwWC+Xl5aiqitvtprS0lMTERJkZIUQLuVwuPv30U7Zt26Zfl52dzY033ihLX7cRSQptKCIigtTUVMrLy3G73aiqSkVFBU6nU9ZMEuI8SktLeffdd/VVTgHGjh3LFVdcIV2xbUiSQhuzWCykpKRQVVWlb5VZV1enjzNIoZsQTeXl5fHxxx/reynbbDauvfZaBgwYYHBk4U+SQgCYTCYSExOx2Wz6OIPT6aSkpES6k4RoxOVy8eWXX7Jx40b9urS0NG666SZSU1MNjKz9kDZYgCiKQkxMDCkpKXrT19edVFlZafi6SX/+85+Ji4vjL3/5i2ExOBwO5s+fz8iRI7nrrrsMi0MY48SJE/zrX//ySwiDBg3innvukYQQQJIUAsxms5GWluY3SGa32yktLcXlcl3Ucy5btoyf/exnZGZmoihKi0/r1q3Tn+M///kPtbW1LFiw4JLf48V4++23GTt2LHfeeScbNmyQne3aEVVVWbt2Lf/617/08QOLxcK1117LrFmzsNlsBkfYvrTLpHD06FFee+01nn/+eV577TWOHj0a0Nc3mUwkJSX57cPgdrs5efIkNTU1F/yDOHnyZP7+97+zadMmvRUyYcIEXC6X36myspKNGzcyc+ZM4PRGQQCPPPIIw4cP55FHHmmld3lhbr31VjZv3syIESMMeX1hjOrqat544w2+/PJLPB4PAB07duSHP/whw4YNk8kYBmhXYwobNmzgySef5NNPP0VVVUwmE16vF0VRmDFjBr///e8D9qPk606y2WxUVFToC3rV1NTgcDhITEy84JqGjh07kpaWxokTJ1AUBYvF/783ISGB4cOH8+GHHzJ27Fi9CAjgpptu4qabbrr0N3aJevbs6dd9IMKTqqps3bqVL7/8EofDoV8/ZswYJk+e3OSzKwKn3fzlP/zwQ2655RZUVdWPxH39+KqqsmTJEj777DPeeecdrr/++oDFZbVaSU1N9auCdrlcnDx5kri4OH0b0JZqyWJgJpOJBx980K+lECykqyD8VVRUsHjxYg4dOqRfFx8fz+zZs8nKyjIwMgHtJCls2LCBW265BY/Hc9auGY/Hg6Io3HLLLaxduzag3Ri+KuioqCgqKir0ZvSltBrO57rrrtNnQgUT6S4IX6qqsmHDBpYuXapPNQVtMHnq1KkyCy9ItIuk8Ic//MGvhXA2vvv84Q9/YNGiRQGK7jSbzUZqaio1NTVNWg0xMTHExcW1WtFOREQEaWlprfJcQpxPcXExn376qd/4XUJCAjNmzCAnJ8fAyMSZwn6g+ejRo3zyySf60ff5eDweFi9eHPDBZx+TyURCQgIpKSl+/ap1dXWcPHmS+vr6S5qZ84tf/KLJdXa7nVdffZVRo0Y1OxV0+fLlXHvttUyePBmA48eP84Mf/IAOHTqQlpbGQw891OyUWo/Hw4IFCxgzZgyZmZlER0eTk5PDz3/+cyoqKi76PYjQ4XA4+Pzzz3n55Zf9vlPDhw/nJz/5iSSEIBT2SWHp0qUX/COqqirLli1ro4haxtdqiIuL06/zeDxUVFToy2ZcjPXr1/tdfuONN5gwYQJ3330369ev9/tbrVixgqlTpzJ58mQ++eQTvF4veXl5DB8+nCVLluitmL/85S/86U9/8nteVVW5+eabmTt3Lj/84Q8pKCjg4MGDdOvWjb///e9MmzZNpp2GMVVV2bFjBy+88ALr1q3TDxqSk5O58847mTFjhmyGE6TCPinU1NRccJeLyWSiurq6jSJqOUVRiIuLIy0tze8L1NDQQElJCdXV1S0uenM4HPzzn/9k7dq1ftd///vfZ9OmTc2OoYwcOZLPP/+cWbNmAVoXwK9//Wvef/99Tpw4QXl5Oddeey0AL774ot9jV65cyYcffkhGRgZ33nkniqLQqVMn5s2bB2jJad++fS3+W4jQceLECV5//XU+/PBDamtrAW1CxeTJk/nJT35C9+7djQ1QnFPYjynExcVdcLWw1+slPj6+jSK6cBaLheTkZBwOB1VVVfr7qa2txW63ExcXR3R0tN8g7erVq0lMTNQv19XVnbN1kZWV1WQqqG/gLzc3F9BaKu+88w6xsbF6XPfffz+LFy/mxIkTVFZW6q/p+zE4c9yid+/e+vnS0lJ69ep1IX8KEcSqq6tZtmwZ27dv92sF9u7dm6lTp/p9HkXwCvukcMUVV6AoygV1VSiKovefBwtFUYiKiiIiIoLa2lr9R9fr9VJVVUVdXZ1fIhs3bhwrVqzQL6uqyurVq7nxxhubff5zLUPsa6VkZGToCcGnS5cu+vmamhr9iz9t2jRef/11hg0b5nf/zZs36+cvtgtMBJeGhgZWr17Nt99+6/d/mpyczLRp02TcIMSEfVLo2rUrM2bMYMmSJS0abDabzVxzzTV07do1ANFdOJPJRHx8PNHR0VRXV+uFP263m/Ly8rO2ihRFYfz48dx+++1nvf1cr3k2jacRNv77ms1m5s6dC2hHkP/+97959913/bqpZEwhtLndbjZv3syqVav8al6ioqKYMGECI0aMkCK0EBT2YwoAv//97/X1fs7Fd5+HH344QJFdPF+XUkpKil8Ng++H1uVy+c0F9/nrX/8asBg9Hg9//vOfGTx4MBERESxbtoznn38+YK8v2obb7Wbjxo08//zzfPbZZ3pCMJvNjB49mgceeIDRo0dLQghR7eJ/bcSIEbzzzjt6RXNzLQaz2YyiKE2OZoOdzWYjJSUFh8PhNziuqiqlpaVERkYSGxsb8Erh+vp6pk2bxr59+1i7dq0MLoYBj8fD1q1b+eabb5oUPvbv358rrriCpKQkg6ITraVdJAWA66+/nrVr1/Lkk0/yySefNFn76JprruHhhx8OqYTg4xtviIyMbNLV43A4cDgcRERE6MkhEFXD//u//8vKlSv505/+JAkhxDmdTrZu3cq3335LZWWl3229evVi0qRJdOrUyZjgRKtrN0kBtBbDxx9/zNGjR1m2bBnV1dXEx8czefLkoB1DuBCNB9RNJpOe9EAbDGxoaMBqtRIXF0dERESbJocvv/wS4Jw7yxm9h4Q4t7q6OjZu3MiGDRv8Fk8EbUbapEmTyMjIMCg60VbaVVLw6dq1K3feeafRYbQJ35Gc3W4nLS2N+vp6amtr9S4zl8tFeXk5FouFmJgYoqKiMJlM+pfet2VoY75uqYaGhnO+duPH+roRXnrpJW699Va6du3K7t27+d3vfqff5/jx4+zfv5+9e/cyY8YM4PRy3mf+CInAKS8vZ926dWzdurXJHh85OTlMmjSJzp07GxSdaGvtMimEI5fLxT//+U9qamoA2LVrF5999hnTp08nOjpaTw6+KYNut5uqqiqqq6upqqrim2++AbT6hqKiIv0IsKqqiq+++grQ9s3dvXs3ffr00V/3ww8/1M+///77PPzww/rCgmvWrOHIkSNkZ2eTnp6Ow+HgnXfeYfny5VRWVnLfffeRk5PD8uXLAS1JrF69GtCK344cOUK3bt3a+C8nQGu1HThwgA0bNnDgwAG/20wmE/3792fMmDF07NjRoAhFoChqG84LdDgc5Ofnk5WVdc558OLSPP300zzyyCPN7twWGRnJ888/z7333ouqqjQ0NFBbW6vPTHruued49tln/aaHKorC448/Tvfu3Zk7d26TqaOTJk3iv//9Lz179vRbCx+0moaqqiqsViuPP/44//rXv6itrWXatGk8++yzZGZm8sgjj/DXv/6VK6+8kn/+85+kpaXx/PPP8//+3//z61JSFIUf/OAHvPLKK63557pg4fw5ttvtbN26lU2bNjVZj8pmszF06FBGjRolhWftiCSFdsrpdGK325vtpjGZTERHRxMdHS3TCgm/z7HX6+XQoUNs3bqVPXv2NJmNl5iYyIgRIxg6dKgsZ90OyTe+nbLZbNhsNuLi4rDb7dTV1elH6V6vV6+attlsREdHNzuzSYSWsrIytm3bxvbt25td2ys7O5sRI0aQk5Mj/9ftmCSFds5sNus7vDU0NFBXV+c3oOx0OvWupsjISH3qq2yGExqqqqrYtWsXeXl5FBUVNbk9OjqaQYMGMXz4cDp06GBAhCLYSFIQgNZ/HxkZSWRkJB6PR+9aaty14Kt58N03KioKm80mR5VBprq6mu+++468vDwKCwub3G4ymcjJyWHw4MHk5uaec9qwaH8kKYgmGrcenE4n9fX1OBwOvz2t6+vrqa+vR1EUIiIiiIyMJCIiQn5gDKCqKidOnGDfvn3s27ePY8eONXu/Tp06MWDAAAYOHNhkYUMhfCQpiLPy/eBHREToM5d8CcI3P0FVVb0FAdpYhe8xVqtVupnaSENDA4cPH9YTgW8q8pnS09Pp168f/fr1k+4h0SKSFESLNO5e8iWChoYGvxYEnB6DqKmp8UsqvlaEJImL43K5KCgoID8/n/z8fIqKis5aEd6xY0d69+5Nv379SE1NDXCkItRJUhAXzLfWUlRUFKqq4nK59NZC4/X0z2xFmEwmfdaTzWaTlsQ51NbWcuzYMQoLCzl69CiFhYVnXfrdYrHQo0cPcnNzycnJISEhIcDRinAiSUFcEkVR9B/5+Ph43G63vs5SQ0ODX+Gb1+v1SxKgbdPoSxBWqxWLxdLuEkV9fT3FxcWcOHGCwsJCCgsLmyw8d6bU1FSysrLIzs4mKyvLb/l0IS6FJAXRqiwWi76ukq8V4XQ6aWhowOl0NqmOdrlcTSqxLRaLX5KwWCxh0fXU0NBAeXk5paWlFBcX66eW7AeenJxMVlYW3bt3JysrSwaKRZuRpCDaTONWRGxsLKqq4na79XEHp9PZbJeI2+3G7XY3WZzPbDb7JQnfyWQyGZ40fAPxNTU11NTU6GtKlZeX66fGu5Odi9VqJSMjg8zMTDIzM+ncuXNQ7RkuwltAkoJsuyhASxK+FkBMTAygbdzidrv1FoPL5Trr3s0ejwePx3PW1Vp9y4U3d/Ltqtf41DiuM6mqqp8cDgdOp5Pt27fjcDj06bi+mVh1dXXU1NQ0u9Pd+URGRpKenq6fMjIySE9Pl9oPYZg2TQq+D3ZL9kYW7ZPvaD8iIkK/zuv16q2FxiePx3POAwyv19smezQ4nU7q6upYuXLleZcPP5u4uDiSk5Pp0KEDycnJpKWlkZ6eTnx8fMh3i4nw0qZJwXdUWFtbK32gosUaz1JqTFVVPWF4vV695eA7+a5rbU6nk9ra2rMmBN8ge1xcHHFxcfr5+Ph4kpOTSUpKCvh2qEJcrDZdJRWguLiYyspKunbtKisuioDwtRh8p8ZdQWeezsbXxdTQ0MDx48dxOp1YrVZ9eQ/fGlBRUVFSxS3CSpsnBY/HQ0FBAQ0NDfoRlNGDgkKci6qqeDwefcA4IiKCLl26yI+/aBfaPCmAlhhKS0upqalpdiMYIYKRbz/rlJQUSQii3QhIUvDxzVuXDdtFsDOZTFJxLdqlgCYFIYQQwU0mQwshhNBJUhBCCKGTpCCEEEInSUEIIYROkoIQQgidJAUhhBA6SQpCCCF0khSEEELoJCkIIYTQSVIQQgihk6QghBBCJ0lBCCGETpKCEEIInSQFIYQQOkkKQgghdJIUhBBC6CQpCCGE0ElSEEIIoZOkIIQQQidJQQghhE6SghBCCN3/DzCEPAzenvkXAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k_test = 100\n",
    "\n",
    "x_test = np.random.normal(0,1, (k_test, d)) # should be sample from the unit sphere\n",
    "x_norm_test = np.linalg.norm(x_test, axis = 1)\n",
    "\n",
    "x_test = np.transpose(x_test)/x_norm_test\n",
    "x_test = np.transpose(x_test)\n",
    "\n",
    "# Init\n",
    "w_s_ft_in, a_s_ft_in = w_s, a_s\n",
    "\n",
    "\n",
    "#L_og_large, L_og_large_test, L_og_large_pre, dist_large= simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 1, 0, 3, x_test,y, True, False)\n",
    "L_og_small, L_og_small_test, L_og_small_pre, dist_small = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 0, 2, 3, x_test,y, True, False)\n",
    "#L_og_full, L_og_full_test, L_og_full_pre, dist_full = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 20, 0, 3, x_test,y, True, False)\n",
    "\n",
    "L_og_grad, L_og_grad_test, L_og_grad_pre, dist_grad = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 2, 0, 3, x_test,y, True, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 266,
   "id": "474f8be3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.025962672791346987, 0.022506431369498987)"
      ]
     },
     "execution_count": 266,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dist_small, dist_grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 276,
   "id": "a323a492",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "average test loss ft a pre train loss small weights\n",
      "0.009414974338510714 ci 0.01173315105727074 0.11871760999968566 ci 0.02403871556489048\n",
      "average test loss ft a pre train loss grad weights\n",
      "0.017481566752151307 ci 0.014714568513087877 0.11532649905627179 ci 0.020861459898282007\n"
     ]
    }
   ],
   "source": [
    "# static\n",
    "\n",
    "simlist = range(10)\n",
    "\n",
    "train_l = []\n",
    "test_l = []\n",
    "pre_l = []\n",
    "\n",
    "train_s = []\n",
    "test_s = []\n",
    "pre_s = []\n",
    "ldist_s = []\n",
    "\n",
    "train_t = []\n",
    "test_t = []\n",
    "pre_t = []\n",
    "\n",
    "train_g = []\n",
    "test_g = []\n",
    "pre_g = []\n",
    "ldist_g = []\n",
    "\n",
    "for i in simlist:\n",
    "\n",
    "\n",
    "    #L_og_large, L_og_large_test, L_og_large_pre= simulationFT(5, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 1, 0, i, x_test,y, False, False)\n",
    "    L_og_small, L_og_small_test, L_og_small_pre, dist_s = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 0, 2, i, x_test,y, False, False)\n",
    "    #L_og_full, L_og_full_test, L_og_full_pre = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 20, 0, i, x_test,y, False, False)\n",
    "    L_og_g, L_og_g_test, L_og_g_pre, dist_g = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 2, 0, i, x_test,y, False, True)\n",
    "\n",
    "    \n",
    "   # index_l = L_og_large.index(np.min(L_og_large))\n",
    "   # test_l.append(L_og_large_test[index_l])\n",
    "   # pre_l.append(L_og_large_pre[index_l])\n",
    "\n",
    "    index_s = L_og_small.index(np.min(L_og_small))\n",
    "    test_s.append(L_og_small_test[index_s])\n",
    "    pre_s.append(L_og_small_pre[index_s])\n",
    "    ldist_s.append(dist_s)\n",
    "\n",
    "   # index_t = L_og_full.index(np.min(L_og_full))\n",
    "   # test_t.append(L_og_full_test[index_t])\n",
    "   # pre_t.append(L_og_full_pre[index_t])\n",
    "    index_g = L_og_g.index(np.min(L_og_g))\n",
    "    test_g.append(L_og_g_test[index_g])\n",
    "    pre_g.append(L_og_g_pre[index_g])\n",
    "    ldist_g.append(dist_g)\n",
    "\n",
    "\n",
    "#print('average test loss ft a pre train loss large weights')\n",
    "#print(f'{np.mean(test_l)} ci {1.96*np.std(test_l)/np.sqrt(20)}' , f'{np.mean(pre_l)} ci {1.96*np.std(pre_l)/np.sqrt(20)}')\n",
    "\n",
    "print('average test loss ft a pre train loss small weights')\n",
    "print(f'{np.mean(test_s)} ci {1.96*np.std(test_s)/np.sqrt(10)}' , f'{np.mean(pre_s)} ci {1.96*np.std(pre_s)/np.sqrt(10)}')\n",
    "\n",
    "#print('average test loss ft a pre train loss all weights')\n",
    "#print(f'{np.mean(test_t)} ci {1.96*np.std(test_t)/np.sqrt(20)}' , f'{np.mean(pre_t)} ci {1.96*np.std(pre_t)/np.sqrt(20)}')\n",
    "\n",
    "print('average test loss ft a pre train loss grad weights')\n",
    "print(f'{np.mean(test_g)} ci {1.96*np.std(test_g)/np.sqrt(10)}' , f'{np.mean(pre_g)} ci {1.96*np.std(pre_g)/np.sqrt(10)}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 277,
   "id": "a8f80318",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.05695684190056749,\n",
       " 0.03233776665119079,\n",
       " 0.02747977553514392,\n",
       " 0.003959989822290061)"
      ]
     },
     "execution_count": 277,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(ldist_g), 1.96*np.std(ldist_g)/np.sqrt(10) , np.mean(ldist_s), 1.96*np.std(ldist_s)/np.sqrt(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 280,
   "id": "8a73a47b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.037747307089506583,\n",
       " 0.0423433907851403,\n",
       " 0.025293653593513942,\n",
       " 0.024176354681097734,\n",
       " 0.02413520396200724,\n",
       " 0.024442845955719526,\n",
       " 0.023528072219196002,\n",
       " 0.02422581400256442,\n",
       " 0.023671403372250495,\n",
       " 0.025233709690442897]"
      ]
     },
     "execution_count": 280,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ldist_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "b6f6225a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "mask mask\n",
      "40\n",
      "average test loss ft a pre train loss small weights\n",
      "0.00451043346600922 ci 0.008356460733791336 0.12802387686821234 ci 0.013353573499980113\n",
      "average test loss ft a pre train loss grad weights\n",
      "0.01284645742538496 ci 0.011862600430154004 0.11718662742764445 ci 0.021567447248036314\n"
     ]
    }
   ],
   "source": [
    "# small lr\n",
    "\n",
    "simlist = range(10)\n",
    "\n",
    "train_s = []\n",
    "test_s = []\n",
    "pre_s = []\n",
    "ldist_s = []\n",
    "\n",
    "\n",
    "train_g = []\n",
    "test_g = []\n",
    "pre_g = []\n",
    "ldist_g = []\n",
    "\n",
    "for i in simlist:\n",
    "\n",
    "    L_og_small, L_og_small_test, L_og_small_pre, dist_s = simulationFT(0.1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 0, 2, i, x_test,y, False, False)\n",
    "    L_og_g, L_og_g_test, L_og_g_pre, dist_g = simulationFT(0.1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 2, 0, i, x_test,y, False, True)\n",
    "\n",
    "\n",
    "    index_s = L_og_small.index(np.min(L_og_small))\n",
    "    test_s.append(L_og_small_test[index_s])\n",
    "    pre_s.append(L_og_small_pre[index_s])\n",
    "    ldist_s.append(dist_s)\n",
    "\n",
    "    index_g = L_og_g.index(np.min(L_og_g))\n",
    "    test_g.append(L_og_g_test[index_g])\n",
    "    pre_g.append(L_og_g_pre[index_g])\n",
    "    ldist_g.append(dist_g)\n",
    "\n",
    "\n",
    "print('average test loss ft a pre train loss small weights')\n",
    "print(f'{np.mean(test_s)} ci {1.96*np.std(test_s)/np.sqrt(10)}' , f'{np.mean(pre_s)} ci {1.96*np.std(pre_s)/np.sqrt(10)}')\n",
    "\n",
    "print('average test loss ft a pre train loss grad weights')\n",
    "print(f'{np.mean(test_g)} ci {1.96*np.std(test_g)/np.sqrt(10)}' , f'{np.mean(pre_g)} ci {1.96*np.std(pre_g)/np.sqrt(10)}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "40d952c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulationFT2(lr, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, top, bottom, seed, x_test, y_pre, figure : bool, grad_crit : bool):\n",
    "    \n",
    "    np.random.seed(seed)\n",
    "    \n",
    "    # generate labels and new representation with noise\n",
    "    w_b, a_b, y_ft, y_test = FinetunerepAdd(w_t, a_t, x, x_test)\n",
    "    print(a_b)\n",
    "    # add another neuron\n",
    "    w_e, a_e, y_ft, y_test = FinetunerepAdd(w_b, a_b, x, x_test)\n",
    "    \n",
    "    print(a_e)\n",
    "    k=20\n",
    "    \n",
    "    # simulate gradient flow/descent initialized from w_s_ft_in, a_s_ft_in\n",
    "    w_s, a_s, L_og, L_test, L_pre = runCD(lr, steps, batchsize, S, x, y_ft, w_s_ft_in, a_s_ft_in, top, bottom, x_test, y_test, y_pre, grad_crit)\n",
    "    \n",
    "    result = np.transpose(w_s)*np.abs(a_s)\n",
    "    initialisation =  np.transpose(w_s_ft_in)*np.abs(a_s_ft_in)\n",
    "    \n",
    "    distance = np.linalg.norm(w_s - w_s_ft_in)**2 + np.linalg.norm(a_s - a_s_ft_in)**2\n",
    "    \n",
    "    print(w_s.size)\n",
    "    distance = np.sqrt(distance)/(w_s.size + a_s.size)\n",
    "    \n",
    "    \n",
    "    if figure:\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "        #plt.scatter(result[0][:k//2-1], result[1][:k//2-1], color = 'purple', label = '+')\n",
    "        #plt.scatter(result[0][k//2:], result[1][k//2:], color = 'orange', label = '-')\n",
    "        #plt.scatter(initialisation[0], initialisation[1], color = 'red')\n",
    "\n",
    "        #plt.plot([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "        #plt.legend()\n",
    "        #plt.savefig('dense_init.png')\n",
    "        #plt.show()\n",
    "\n",
    "        index = (a_s > 0)\n",
    "        index2 = (a_s <=0)\n",
    "\n",
    "        plt.scatter(result[0][index], result[1][index], color = 'purple', label = '+', facecolors='none')\n",
    "        plt.scatter(result[0][index2], result[1][index2], color = 'orange', label = '-', facecolors='none')\n",
    "\n",
    "\n",
    "        index = (a_s_ft_in > 0)\n",
    "        index2 = (a_s_ft_in <=0)\n",
    "\n",
    "        plt.scatter(initialisation[0][index], initialisation[1][index], color ='purple', marker = MarkerStyle(\"*\", fillstyle=\"right\"))\n",
    "        plt.scatter(initialisation[0][index2], initialisation[1][index2], color = 'orange', marker = MarkerStyle(\"*\", fillstyle=\"left\"))\n",
    "\n",
    "\n",
    "        colorlist = ['orange', 'purple']\n",
    "        \n",
    "        colorindex = a_e > 0\n",
    "        \n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[0][0] ,w_e[0][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[0]], ec=colorlist[colorindex[0]], length_includes_head = True, alpha = 0.5)\n",
    "\n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[1][0] ,w_e[1][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[1]], ec=colorlist[colorindex[1]], length_includes_head = True, alpha = 0.5)\n",
    "\n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[2][0] ,w_e[2][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[2]], ec=colorlist[colorindex[2]], length_includes_head = True, alpha =1)\n",
    "        \n",
    "        plt.arrow(0, 0, \n",
    "                  w_e[3][0] ,w_e[3][1], \n",
    "                  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[3]], ec=colorlist[colorindex[3]], length_includes_head = True, alpha =1)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "        #          w_e[3][0] ,w_e[3][1], \n",
    "        #          head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[0][0] ,w_t[0][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='orange', ec='orange', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[1][0] ,w_t[1][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='orange', ec='orange', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t[2][0] ,w_t[2][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True, alpha = 0.2)\n",
    "\n",
    "        #plt.arrow(0, 0, \n",
    "         #         w_t_ft[3][0] ,w_t_ft[3][1], \n",
    "          #        head_width=0.05, head_length=0.1, fc='purple', ec='purple', length_includes_head = True)\n",
    "\n",
    "\n",
    "        markers=[\"*\",\"o\"]\n",
    "        colors = [\"purple\", \"orange\"]\n",
    "        #plt.quiver([0,w_t[0][0]], [0,w_t[0][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[1][0]], [0,w_t[1][1]], color = 'orange')\n",
    "        #plt.plot([0,w_t[2][0]], [0,w_t[2][1]], color = 'purple')\n",
    "        #plt.scatter(white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "        #plt.scatter(-white_dot[0], white_dot[1], color = 'white', alpha = 0)\n",
    "        circ = np.linspace(-1,1, num = 500)\n",
    "        plt.plot(circ, circle(circ, '+'), color = 'black', alpha = 0.5)\n",
    "        plt.plot(circ, circle(circ, '-'), color = 'black', alpha = 0.5)\n",
    "        #plt.xlabel(r'$w_1$')\n",
    "        #plt.ylabel(r'$w_2$')\n",
    "        plt.box(False)\n",
    "        plt.gca().axes.xaxis.set_visible(False)\n",
    "        plt.gca().axes.yaxis.set_visible(False)\n",
    "        plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "        f = lambda m,c: plt.plot([],[],marker=m, color=c, ls=\"none\")[0]\n",
    "\n",
    "        handles = [f(\"s\", colors[i]) for i in range(2)]\n",
    "        handles += [f(markers[i], \"k\") for i in range(2)]\n",
    "\n",
    "        labels = [r'$+$ sign', r'$-$ sign', 'Init', 'Final']\n",
    "\n",
    "        #plt.legend(handles, labels, loc = 'lower left')\n",
    "       \n",
    "        plt.savefig(f'runftbottom{bottom}top{top}distseed{seed}twoneurons.pdf',bbox_inches='tight',dpi=100)\n",
    "        plt.show()\n",
    "    return L_og, L_test, L_pre, distance\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "0e2843f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_23376\\3649473562.py:62: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[0]], ec=colorlist[colorindex[0]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_23376\\3649473562.py:66: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[1]], ec=colorlist[colorindex[1]], length_includes_head = True, alpha = 0.5)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_23376\\3649473562.py:70: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[2]], ec=colorlist[colorindex[2]], length_includes_head = True, alpha =1)\n",
      "C:\\Users\\Tom\\AppData\\Local\\Temp\\ipykernel_23376\\3649473562.py:74: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  head_width=0.05, head_length=0.1, fc=colorlist[colorindex[3]], ec=colorlist[colorindex[3]], length_includes_head = True, alpha =1)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAGFCAYAAAASI+9IAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABcRklEQVR4nO3dd3iU95Xo8e809d6RBEJddEQvBgTYprjQbGKwDXbsbO5my73ZZPve9N3NZvcmm80m2bU3dowdN1xww2BMNb0XCZCEJJCEGupdmvLeP170orEEpkjzTjmf59HDNGmOhDRnfuWcn0FRFAUhhBACMOodgBBCCPchSUEIIYRGkoIQQgiNJAUhhBAaSQpCCCE0khSEEEJoJCkIIYTQSFIQQgihkaQghBBCI0lBCCGERpKCEEIIjSQFIYQQGkkKQgghNJIUhBBCaCQpCCGE0EhSEEIIoZGkIIQQQiNJQQghhEaSghBCCI0kBSGEEBpJCkIIITSSFIQQQmgkKQghhNCY9Q5ACFdxOBzYbDZ6e3uxWq3Y7XYAFEVx+tdgMGA2mwd8GAwG3WIXwlUkKQiPpCgKPT09tLS00NraSktLCx0dHXR2dtLV1UVnZ6f20dPTg9VqxWaz3dNzms1mAgMDtY+AgAACAwMJCgoiNDRU+wgLCyM0NBSzWf68hOcxKH1vj4RwM4qi0NraSkNDg9NHc3MzLS0t9Pb26h3iLQUFBREVFTXgIzo6msDAQL3DE2JQkhSEW+ju7qampkb7qK2tpb6+HqvVetdf02AwaO/o/fz8sFgsTh8mk0mbEur/r8PhwG63Y7PZnD56e3vp6uqiq6vrnuICCA0NJT4+3ukjJiYGk8l0T19XiHslSUG4nM1mo6qqioqKCiorK6murqa5ufm2P99isRAWFkZ4eDhhYWHa5ZCQEIKCgrSPgICAYVsHsNlsdHd309XVRUdHB21tbbS1tdHa2qr92ze1dbtMJhPx8fEkJydrH5GRkbKWIVxKkoIYdp2dnVy5coXy8nIqKiqorq7WFnlvxmAwEBUVRUxMDNHR0U4fISEhHvNCabVaaWpqorGxUfuor6+ntraWrq6ur/z8oKAgkpOTSUlJYfTo0YwYMQKjUTYNiuEjSUEMOavVSkVFBaWlpZSWllJdXc2tfs38/PyIj48nISFB+4iLi8NisbgwatdSFIW2tjZqa2upq6ujtraW6upqrl27dsvPCwgIICUlhdTUVFJTU4mLi/OYBCk8gyQFMSSampq4ePEiRUVFVFRU3HKnT0xMDCNHjiQ5OZmRI0cSGxsrL2zXdXd3c/XqVa5evUplZSWVlZV0dnbe9PGhoaFkZWWRlZVFamoqfn5+LoxWeCNJCuKuKIrC1atXKSwspLCwkLq6ups+NiEhgbS0NEaPHk1ycjJBQUEujNSzKYpCQ0MDly9fpqysjLKyspsmCbPZTGpqKllZWWRnZxMWFubiaIU3kKQgbpuiKFRWVnLu3DnOnz9Pe3v7oI+LiIggLS2NtLQ0UlNTCQ4OdnGk3ktRFOrq6igrK6OkpISysrKbjspGjRrF+PHjGTNmDKGhoS6OVHgqSQrilhRFoba2lvz8fPLz8wfdJWQwGEhOTiY7O5vs7GxiYmJkOshFrFYrZWVlFBUVUVRUNOhuJ4PBQEpKCuPGjWPcuHEyUhO3JElBDKq9vZ3Tp09z5syZQRc/zWYz6enpZGdnk5WVRUhIiA5Riv76EvjFixcpKCgY9P/NZDKRlZVFbm4uGRkZspNJDCBJQWgcDgeXLl3i5MmTFBUV4XA4nO43Go2kpaUxYcIEsrOzCQgI0ClScTvq6uooKCggPz+fhoaGAfeHhIQwadIkcnNziYmJ0SFC4Y4kKQja2to4fvw4J0+epK2tbcD9o0aNYsKECYwdO1bWBzxQ3wji3LlznDlzZtC1oNTUVKZPn05OTo6MHnycJAUf1bdofOTIEc6fPz9gVBAaGkpubi6TJ08mKipKpyjFUOsbDZ46dYqioqIBRYRhYWFMmzaNKVOmyJSgj5Kk4GPsdjv5+fkcOXKEqqoqp/uMRiNZWVlMmTJF5pt9QGdnJ2fPnuXYsWMDppdMJhMTJkxgzpw5xMXF6RSh0IMkBR/R29vLyZMnOXToEC0tLU73BQcHM3XqVKZNmyZ7232QoiiUlpZy9OhRbS2pqaSJwOhAAiMDycrKYu7cuYwaNUp2lfkASQperquri6NHj3LkyJEBRU8jRoxg5syZjB8/Xnr/CwCam5v55OVP2P7adsKywojJvrEAnZyczH333Ud2drYkBy8mScFLdXV1ceDAAY4ePTrg3AF55yduprGkkYP/epDm6mbCHg2jpLVkwMgyISGBvLw8SQ5eSpKCl+np6eHQoUMcOnSInp4e7XaDwcD48eO57777iI+P1zFC4a66m7s5+G8HqTlVQ0BkAAt/vJCwUWEUFBRw4MABamtrnR6fmJhIXl4emZmZkhy8iCQFL9Hb28vRo0c5cOCAU0tmk8lEbm4uc+fOJTIyUscIhTtz2Bwc/6/jlO4sJTg2GIPRwJKfL8ESpHaqVRSF4uJi9uzZM2CDQlJSEvfffz+pqal6hC6GmCQFD+dwODh9+jS7du1y2n9uNBrJzc1l/vz5hIeH6xih8AQXP7jI2VfPEp4STmd9JxEpESz80cIBj1MUhaKiIvbs2UN1dbXTfZmZmTzwwAOyW8nDSVLwYKWlpWzfvt1pWG8wGJg4cSILFiyQ+gJxW6pPVnP4l4cxB5gJHRFKXX4dmcszyf167k0/R1EUCgsL2b1794DfvylTppCXlydN+DyUJAUPVF9fz2effUZRUZHT7WPGjGHRokXExsbqFJnwNG1VbRz42QHaa9u1nUa1+bVM/cZUMpZkfOXnK4rC2bNn2blzp1MzPj8/P+bOncvcuXNlZ5uHkaTgQXp6etizZw9HjhxxqkBOTExkyZIlpKSk6Bid8DTWTiuHfnGI6hPVxI2Pw2A04LA7aLjYwH1/dx8jckfc/teyWjly5AhffPGF0waHqKgoli1bRmZm5nB8C2IYSFLwAIqicOHCBbZt2+b0biwsLIzFixczceJE2f0h7ojiUDj9ymmKPioiOisac4D6br6ntYeuxi4W/9NiQhPvfPqno6ODffv2cezYMac3Ljk5OSxdupSIiIih+hbEMJGk4OaamprYunUrxcXF2m1ms5n77ruPuXPnevU5xmL4lO4s5eSLJwmODyYwMlC7va26DZPFxJJfLMFkMd3116+rq2Pr1q1cvnxZu81sNjN//nzmzp2LyXT3X1sML0kKbsput3Pw4EH27t3rdLJWZmYmy5cvl+2l4q7VF9Zz8N8OotgVwkc570xrvNRI3Pg47vub++75eRRFIT8/n+3btzvtjIuPj2fFihUkJibe83OIoSdJwQ3V1tayZcsWpy1/YWFhLF26lDFjxshUkbhrXY1dHPjZARpLG4kdEzvgd6kuv46xa8Yyft34IXvOwdbCDAYDc+bMIS8vT0a7bkaSghtxOBzs37+fvXv3ai2NDQYDs2bNIi8vD39/f50jFJ7MbrVz7NfHuLz3MnHj4jCaB3bBrTtXx/Q/nU7qwqEvRKupqeGDDz5werMTHR3NihUrGDVq1JA/n7g7khTcRF1dHVu2bHGqFo2NjWXlypUkJSXpGJnwFvZeO5//zec0lzXjH+5PaGIoJj+T0/1NpU0s+N4CYscOz7bmvmnRPXv2OJ3lMGvWLO6//37ZvuoGJCnoTFEUDh8+zOeff+40Opg7dy55eXnyRyKGVGd9JxWHK7i8+zLNZc3YumzEjo/FL9iPrqYuett7eeBfHiAoJmhY47h27RoffPABlZWV2m3x8fGsXr1aenPpTJKCjtrb23n//fcpKSnRbpPRgXAFa6eVfT/ZR29HLx11HThsDowmI6GJoTz4bw9iMA7/upXD4eDIkSPs3LlT20xhNpu5//77mTlzpqyd6USSgk6Ki4vZsmULHR0d2m1z5sxh0aJFMjoQw67qeBX5b+aTOD2RmJwYLu+5TM2pGhKnJjLjz2a4NJa6ujreffddp3YZ6enprFq1So4E1YEkBRez2+3s2LGDw4cPa7eFhISwatUq0tPTdYxM+JJd/3cX9h47i36yCJOfCUVRaK1oJTguWCtkcyWbzcbOnTs5dOiQdltISAiPPfYYo0ePdnk8vkySggu1trayefNmKioqtNuysrJYsWIFwcHBOkYmfElLeQtH/uMIoUmhzP72bL3DcVJaWsr7779PW1sboK6vLVq0iPvuu0+mk1xEkoKLlJWV8c4772jTRSaTiQcffJAZM2bIL7twqd3f3421w8r8f5hPQESA3uEM0NHRwbvvvktpaal2W2ZmJqtWrSIoaHgXwIUkhWGnKAoHDhxg586d9P2ow8PDWbt2rSwmC5frae1h74/2Ygm2sPCHA89LcBcOh4N9+/axd+9ep7+bdevWkZCQoHN03k2SwjDq7e3l/fff58KFC9ptGRkZrF69Wt7xCF0c/fVRmsuamf4n04lMdf9WKSUlJbz33nvaCNtisbBy5UrGjRunc2Tea2BJoxgSLS0tvPTSS04JYcGCBaxfv14SgtCF3WqnpbwFc4DZIxICqLuQvvnNb5KcnAyoLbo3b97M7t27kfezw0NGCsOgsrKSN998U2sC5u/vz5o1a8jKytI5MuHLLn5wkfIvyhmzZgwjZ4/UO5w7YrPZ+Pjjjzl9+rR2W05ODqtWrZL2L0NMksIQO3fuHB988IFWjBMZGcn69evlNDShK0VR2PX3u1AUhcX/uNglxWlDra/6/7PPPtNGCQkJCaxfv56wsDCdo/MeMn00RBRFYd++fbz77rtaQhg9ejTf+MY3JCEI3VWfqMbeaydxaqJHJgRQt6fOnj2bJ598koAAdddUTU0Nv/vd76irq9M5Ou8hI4Uh4HA4+PTTTzl27Jh225QpU3jooYfkMBHhFr5crObp6uvr+cMf/kBTUxMAAQEBPPHEE1LoNgRkpHCPbDYbmzdvdkoIDzzwAI888ogkBOEWWspbsHXZBnRF9WQxMTE899xz2kE93d3dvPrqq5w7d07nyDyfjBTuQXd3N2+88QZXrlwBwGg0snLlSiZOnKhzZELc4O7Faveit7eXzZs3Ox1Xu3TpUmbNmqVjVJ5NRgp3qb29nZdffllLCH5+fqxfv14SgnArPa09WDusWIItXpcQQP27W7duHVOnTtVu27ZtG/v27ZMtq3dJksJdaG1t5eWXX9a6OgYFBbFx40YyMjJ0jkwIZ2dePQPA5Gcm6xvIMDIajTz88MPk5eVpt+3atcupi4C4fdKj+Q41NzfzyiuvaAtc4eHhbNiwgejoaJ0jE8KZJxar3S2DwUBeXh5+fn589tlnAOzfv5/e3l6WLVsm/cXugIwU7kBTUxMvv/yylhAiIyN59tlnJSEIt1S8tRjFrpD5UKbeobjMnDlzePjhh7UkcPToUT744AMcDofOkXkOGSncpoaGBl555RVaW1sB9cDxjRs3StGMcEuKonD1yFWMFiPJM5P1Dselpk2bhsViYcuWLSiKolVBr1ixQkYMt0FGCrehsbGR3//+91pCiI2N5dlnn5WEINyWNxSr3YtJkybx+OOPYzSqL3GnT5/mo48+kjWG2yBJ4Su0tLTwyiuvaId+xMfH88wzz8gxgcKtXfzgIgajgexHs/UORTdjx451SgwnT55k69atkhi+giSFW2hvb2fTpk20tLQAEBcXx8aNG+WUNOHWvLFY7W6NGTOG1atXa9NGx44dY/v27ZIYbkGSwk10dnayadMmGhoaAIiKimLDhg3S9lq4vZO/Owl49zbUOzF+/HhWrVqlJYbDhw+zZ88efYNyY5IUBtHT08Nrr72mNdkKDw9n48aNMmUk3J63F6vdrYkTJ7JixQrt+t69e51a04gbJCl8id1uZ/PmzVRVVQEQGhrKxo0bCQ8P1zkyIb6aLxSr3a3JkyezdOlS7frWrVspKCjQMSL3JEmhH0VR+Oijj7h06RKgdl58+umniYqK0jkyIb6aLxWr3a1Zs2Yxb948QP17f++99ygtLdU5KvciSaGf3bt3a3uazWYz69atIy4uTt+ghLhNfcVqWQ/LCX+3smjRInJzcwF1ZuDNN9+kpqZG56jchySF644fP86+ffsAtWR+9erVpKSk6ByVELenf7Fa0swkvcNxawaDgUceeYTsbHW7bm9vL6+//rq27dzXSVIASkpK+OSTT7TrS5cuZezYsTpGJMSdqTpedaNYTap2v5LRaOSxxx4jOVmt9m5tbeWNN97AarXqHJn+fD4pNDQ0sHnzZm3f8pw5c5g5c6bOUQlxZwo/LPT5YrU7ZbFYeOKJJ4iIiACgqqqK999/3+drGHw6KXR3d/P666/T3d0NQHZ2Ng888IDOUQlxZ6RY7e6FhISwfv16/P39ATh//jy7du3SOSp9+WxScDgcvPPOO1pxWlxcnFPloxCeQorV7k1cXByPPfaY9rf/xRdfcPbsWZ2j0o/PJoUdO3ZoW0+DgoJYt26d9m5BCE8hxWpDIzMz06mG4aOPPtIO0fI1PpkUzp07x6FDhwB1wWnt2rVERsq+buF5zmySYrWhMmPGDKZMmQKA1Wrlrbfe0qaWfYnPJYX6+no++ugj7fry5csZPXq0fgEJcZfsVjstFVKsNlQMBgPLly8nMTERUFvm++LCs08lhd7eXt5++216e3sBted6/wO/hfAkUqw29MxmM2vXriUwMBCAwsJCvvjiC52jci2fSQqKovDJJ59oTe7i4uJ46KGHZGFZeCQpVhs+ERERrFmzRntt2L17t0+1wvCZpHDq1CnOnFHnX/38/Fi7di1+fn46RyXE3dGK1aZJsdpwyMjIYOHChcCNHkkdHR06R+UaPpEU6urq2Lp1q3b90UcfJSYmRseIhLg3WrHaI1KsNlzmzZtHRkYGoB641Xfms7fz+qRgs9l49913sdlsAEyfPp3x48frHJUQd0+K1VzDYDCwcuVK7aTF4uJijhw5onNUw8/rk8KuXbu0/cZxcXEsWbJE54iEuDdSrOY6ISEhrFq1Sru+Y8cOqqurdYxo+Hl1UigrK9PqEUwmE2vWrMFsNusclRB3T4rVXC8jI4PZs2cDaqvt/jMP3shrk0JXV5fTHuP777+f+Ph4naMS4t5IsZo+Fi9ezIgRIwC11mn37t06RzR8vDYpfPrpp7S2tgKQlpbGrFmzdI5IiHsjxWr6MZvNrFq1CpNJXcM5ePAgFRUVOkc1PLwyKRQXF2sNrQICAli5cqVs2xMeT4rV9BUXF+e0TXXLli1eef6C1yWFnp4epzYWS5cuJSwsTMeIhLh3UqzmHubMmaMdzNPQ0MDOnTt1jmjoeV1S2LFjhzZtlJ6ezqRJk3SOSIh7J8Vq7sFoNLJy5Uptw8qRI0e8bhrJq5LC5cuXOX78OKBWLT/yyCPyByS8ghSruY+YmBgWLVoEqCO4jz/+GLvdrnNUQ8drkoLNZuPDDz/Urt9///3aMXtCeDIpVnM/s2bN0nYj1dbWelVRm9ckhYMHD9LY2AjAqFGjmD59us4RCTE0pFjN/RiNRh5++GGnpnnNzc36BjVEvCIpNDc3s2/fPmDgf5YQnkyK1dxXUlKS9ubTarXy6aefekVvJK9ICtu2bdMqDGfMmEFcXJzOEQkxNKRYzb0tWrSI0NBQQD17obCwUOeI7p3HJ4Xi4mIuXrwIqH1K8vLy9A1IiCEixWruLyAgwOls5+3bt3t8CwyPTgo2m41PP/1Uu/7ggw8SECBDbOEdij+RYjVPMHbsWNLS0gBoamri8OHDOkd0bzw6KRw5ckRbXE5JSWHChAk6RyTE0FAUhatHpVjNExgMBpYsWaKtY+7bt4/29nado7p7HpsUOjs7tbNTDQYDy5Ytk8Vl4TWkWM2zxMfHa+e99/b2enSls8cmhX379tHd3Q3A5MmTSUhI0DkiIYaOFKt5noULF2rT16dPn/bYcxc8Mik0NjZy7NgxACwWi9akSghv0HylWS1WS5JiNU8SHBzMggULAHX6b9euXTpHdHc8Mins3LlTKyufPXu2NLwTXuXUS6cAmLxxsr6BiDs2ffp0wsPDAXVn5JUrV3SO6M55XFKorq6moKAAUDPz3LlzdY5IiKEjxWqezWw2O81cfP755x5X0OZxSWHPnj3a5fnz5+Pv769fMEIMMSlW83wTJ04kNjYWgIqKCoqLi3WO6M54VFK4evWqVjEYFhamrfYL4Q2kWM07GI1GrYsqqNPdnjRa8Kik8OVRQl9PcyG8gRSreY+cnBySktT6ktraWo9qf+ExSaGyslIbhoWHh5Obm6tzREIMHSlW8y4Gg8Gp5c6+ffs8ZrTgMW+19+7dq11esGCBdoC2EJ5EURTKdpVx8sWTNBQ1oDgUwkeFM+q+Udi6bYycO1KK1bxERkYGI0aMoLq6mqqqKkpKSsjIyNA7rK/kESOF2tpabZQQEREhR2wKj1RXUMdvx/+WV+9/lbpzdUSmR1J7ppbaM7V8/tefc+KFE/iF+OkdphgiBoOB+fPna9f37t3rEaMFj0gKBw4c0C7PmTNHRgnC49Tl1/HyfS9jNBt5Zu8z/HH+HzPvb+cBYPIzMfHpiYQlhfHGI29Q8lmJztGKoZKTk+O0E8kT6hbcPik0NzeTn58PQFBQEJMnT9Y3ICHukOJQePuxtwkfFc4z+54hZX6K0xRR46VGAqMDefbAs6Q/mM7mxzfT3dKtY8RiqHx5tNDXr82duX1SOHz4MI7uBmg4zoxUO35tZ6GzEuy9eocmxG0p2VFCQ2EDD/32IQLCBy9Ia77cjLXdyvz/O5/ejl6O/faYi6MUw2XcuHFERqpbjEtKSrh27ZrOEd2aWy80d3V1cfLkSbD3YrHVMT14NxQcB3MIWEIgaCSEjIaAERCYAAHxYAkHWagTbuTkCyeJnxRP8uzkmz6mcEshhVtubFvc9be7mPlnM/ELljUGT2c0Gpk5cybbtm0D1Jb/Dz/8sM5R3ZxbJ4UTJ07Q29sLgfHkTv8mwYml0JIPpkBw2KA5Hxquv6My+qnJwj8aQtIgKPlGogiIA6NF329G+Kz6i/WkPZA2YFeRw+oY9PFGsxHFoWAJkt9Zb5Gbm8vu3bvp6enhzJkzLFq0iKCgIL3DGpTbJgWHw8Hx48e167MWrYIQA5Rugmv7wD8eQq9v71IUcPSCrR26a6G9FBS7OmIwB4M5FIJHQcYfgV+EPt+Q8FkOmwODaeDotXx/udN1g9FAzJgYxq0dx54f7AEFkEGvV/D39yc3N5fDhw9jtVo5ceIE8+bN0zusQbntmsKlS5dobm4G1P2+UVFR4BcJWd+ClHVga4O2S2pCMBjA5K+OEoJTIHwsREyAsDHgFw29zdB0BrpqdP2ehG8KGxlG3dk6p9sURaGu4MZtBpOBpJlJ/NHxP6K9tp2wpDAMRskI3mTmzJnaaPHo0aNap2d347ZJoe+8BFDb0WqMFhi5BrL+BPzC1ekkx00WnQ0msISBYoWI8RAm7QOE603aMInSz0tpKG7Qbqs6VoXdeuNFQbErNBY3YuuxcfbVs0zaKLU43iYyMpLsbPXQpLa2Ni5cuKBzRINzy6TQ1NTEpUuXALVYLTMz0/kBBgPEzIIxfwnh46DlAljbBv9i9utb++IXgcEtv13h5catHUdgdCA7/nIHDru6jlD4USHB8cGkzE/RHtdZ38nH3/wYa6eVqX8kzR690cyZM7XLJ06c0DGSm3PLV8njx49rlX/Tpk3DaLxJmCGjYex3IeF+6CwffHqo5Tz4x0DzGbB1DV/QQtyEOcDMipdXUPRREe89+R41Z2qwddkIHxnOhl0bWPzPi7WpooK3CnjgXx8gfFS4zlGL4TB69Giio6MBKCsro7GxUeeIBnK7pGCz2Th1Sj15ymQyfXXjO0sYZH4TRj8J9i5oKwLl+q4Oh00dVVgioLUIzn4PCv4Zehpu+SWFGGrZj2Tz+ObHKfywkBemvsClbZcwmo2cfe0s7TXtmAPVPR9hyWHM/vZsnaMVw8VgMDBlyhTt+smTJ3WMZnAGxc2acRQUFLB582YAJkyYwJo1a27/kxtPQOkr0HkVQrPUnUiWUJj0E+gohytvgb1Tfaw5GNI2qttXhXCRxkuNbHl2C3X5dfQ09wAQHB/M5GcnM+npSQREBBCaGKpzlGI4tbe38/Of/xyHw0FISAjf/va33ap1j9ttST1z5ox2+Y7bY0dNVesSSl6CplPqzqTkR9XEEDEOIn4EnVVw6b/B1glFvwFTACQ9CtHTpehNDLviT4tJnpnM6ldXE5oUiuJQMPu73Z+hGEYhISHk5ORw/vx52tvbKSoqYsyYMXqHpXGr6aP29nZtgTksLIzRo0ff+RcJSoacv4ARSyE0E2LnfOn+RJj4Q5jwPQhJBYcVyt+GM38PVz9Rp5yEGAZ2q53WylbMAWYiRkdgspgkIfio/lNIZ8+e1TGSgdzqNzI/Px+HQ10PmDRp0s0XmL+KJQTSn1cvG28yLLOEqtta7b1w9SNoPA61u6HuCwjLVGshzO5ZcSg8k3ay2irZGu3r0tLSCAkJ0UYK3d3dBAQM3hfL1dxqpHD69Gnt8j2fmWA03Twh9Gfyg1FrYNI/QvIKMJrVLa5nvw/5P4Fu925eJTyDnKwm+jMajYwfPx4Au93O+fPndY7oBrdJCnV1ddTUqFtKk5KSiImJcW0ABiPEzYOJP4b059T+Sr3NcP5f4Mz31OppIe5S1bEq7L12kqYnyclqAlA30vRxpykkt0kK/TNl/x+WyxkMED4GJv0IxnxX3aVk74Li/4Iz/wDXDqkL2ELcgcKPCjEYDWQ9LFNHQpWYmKjVLFy5coXW1ladI1K5ZVIYO3asjpH0E5hwfVH6+2rzPYcVKt5VF6UrP5RFaXFbmq80Y+uyEZoUisnPfbYeCn0ZDAbtDbCiKBQUFOgckcotkkJ9fT11dWpzsJEjRxIWFqZzRF9iCYHM/6XWO8TOBRSo26cmh0svgK1D7wiFGzv1klqMOfmZyfoGItxO37oCwMWLF3WM5Aa3SApuOUoYjNECI1epi9IjV6vXW4vg7A/g3A+hu+6rvoLwMd0t3Vg7rFiCLTc9dU34rpiYGG39tLy8nI4O/d9gusWW1P5JwZ2KOG7KYFTrH2LnqEmh7DW1Id/5n4EpCFKfhLDs2/tatk648oZaI2FtUQ8Kil+oVlv7RQ7v9yGG3ZlNajFm7rN3WIgpfEZOTg779+9HURQKCwudahj0oPtIoampyWnXUUREhL4B3amwLHVReuxfqX2Y7F1w6cXri9IHbvRh+jJFgYv/Du8nwZFvQG8D9NTD1Q/h1F+qt5/+G3C4Z8918dW+XKwmxGD6vxF2hykk3ZNCcXGxdjknJ0fHSO5RQJxaJT3xB+oowWGFivfVdYeK99Xr/Z35Ozj5bRi9Hh69BPfvvfGYvE/UnU8X/g0OPXXzxCLcmlasJjuOxC0kJiYSGqr2uyotLVWPINaR7kmhr60FMPDcBE9kDoaMb6iL0nHzAYM6YjjzD1D8W7C2Q+UHcP6nkPv/YPqv1aZ89h5ovX7ohn8MTPwRzH1LbeJX+EtdvyVx56RYTdwug8GgvSG22WxOr4l60DUp2Gw2ysrKALVJVHx8vJ7hDC2jRW3GN+kfYdRj6vW2EnVB+vifQ+QUdbG6/bL6Ub554NcYtQZSN0Dhf8g0koeRYjVxJ7Kzs9WWOz0NFJ/Zq+uORl0Xmq9cuYLVqk6ZZGRkeOcfT98pcTGz1KroCz9XDwTqLIcPU7/68zO/BWWvQM1nkLhs+OMVQ0KK1cRtazhGSvWvMBe+js1up6QCFMO3MYxeB5l/AtHTXBqOriMFr5s6+iqhGRCfp15OfBi4jUKmmBnqLqRm9ymDF7cmxWritiiKevDX9hlYGr9g9NTHIHUjrQkbqU/6jtqgc/t0dXbBhV0U3CIpGAwG0tJ85LAbx/VFpPvehqVHITBxkMd8aVHa6KeuOQiPIMVq4rac/2fI/zFM+md45BLp8/+3esRwyGhKLI/AIyUw8Sdw7gdw4V9dFpZuSaGlpYVr19QOpMnJyQQGBuoVimsFjlD/bb0AUVPg0RKInoXTf0XRb6DwP9Xah+56datq3+cJtybFauK2dFapo4Rxfwfj/gaMJtLT07W7L126pHZ5Hv/3MOYv4ew/QFetS0LTLSlcvnxZu9z/h+H14uaro4NLL6jXDRZoKwb6bTs1WqDjMpz7ERx4AjCpi9LC7Umxmrgtl15QT30c+9faTbGxsdrW1PLycu1sGcb9LRjMUPI/LglNt4XmK1euaJdTUlL0CsP1jBbI+CO1+jn7z6GnQS1c6xO/EGb8FjoroPDXUH9YXYu4+EtIWQvh4+TYUDclxWqCxhNqJ2WD8frf6Zf/Naj3Xfpv9fjgyg/V6xgwGIykBF0lv7KC3rAcampqSExMVNcUR61VOx+M//th/xZ0Twomk4nk5GS9wtBHzrfVbqu7HrheywBgVLevjv2r678kQM129YS4pEfB3g2lvwejP4y4/nkG3ctMfJbiUCjbXUZDUQOKQyF8VDi2bptarLZadhz5rL0roasS6HvjdosF4u4atbFmPyn1kF8OpH2dK1euqEkB1M4JVZ8MQ8AD6ZIU2tvbaWhQ3x0nJiZisVj0CEM/ljBY+BnseQiuvKm+0I/5S3WNoXyzetvVDyFoFCzeDeE5YOuC8reg5SJc/Riqt0PkZEhepZ4eJ1zCYXNw5FdHOPafx2gqbcJgMmAwGnBYHViCLMRPjmfBDxboHabQS1gOdF3llsngFlISI6F2FgSO4MqVK8yePVu9w96tTje5gC5JwWenjvoLTIAHD6p9ki6/BgU/gb526uHjYdqvYfST6kgBwBwIac+oRWw1O9R3GA3H1OFqYJJ6n1+4Tt+Mb7D12Nj82GaKPy1mwvoJrHptFSZ/Ey9OfZHxT47nWv41qo5XsWnRJp7a/hSBkT6yeULcEJ8HdbtBuZNiU6N6Hvy4vyU2688JrP81XV1dlJeXoyiKOua4+glETB6WkL9Ml6RQUVGhXfbZpABg8ofsP1U/epvVD3MI+EfffN3AaILEpTBiCTSdhIot6vpD/o9vtNgI8rHpOBfZ+idbKdlRwvqP15OxNAOA6pPVAJRsLyH32VwefuFhXl/2Om+veZsNOzd4Z0GmGJyiqLsE7yQhGC2Q/Rcw7q/BLxID6mvixYsX6ezspL6+nlhDqfq3PvHHwxZ6f7okhaqqKu2yz60n3IxfhPpxuwwGdaEqaqraJqP0ZbU0/uK/q+dLj3ocIibIovQQaSpt4tRLp1j2q2VaQuivq76LkIQQkmcks+q1Vby+/HUu77lM6sLbqFoXnklxQP0RuPAvaj+z22W4XtBoDlEbaY79S6c2+UlJSVq31KqyfGLrvqVOS41YMpTR35TLVyodDgfV1eq7q8jISN+pTxhOIaPVY0PH/R0ExKuFbmWb1CZ8NTulb9IQOP7fxwkID7jlVlO/ED+aLzcTkxNDZHokh35+yIURimHnsKl/Tzvvh9cN8IYJdsxxTggjlkHoTbozGMyAAVLWwyPF8OBhdXbgs9nqWuL1otXExET1b7Y5n6pP1kNvI8z/UJ0lcAGXjxTq6+u1fkfayroYGv5R6rsOe7f6S9ZcAFWfQs3n6qhh5Bp1ykrcsZLtJeSszsES5LwporftRpvjj7/5sdN9TSVN9Hb04hcsGwE8kr0Hqj+Dgn+EhiODP2bU49c3iUy9sRvw7Peh4J9AuX6Gu8GkTiklLodJ/wQR4258/oOH4MhzsH8tBCRA1BQSu21QeABsHVSbc+DBrRDiuhGny5NC/6kjSQrDxBQAqU+r7zZqd0HtHmg8CU2n1V+89K/f2VSVoLetl+DY4AG3F31SNOjjjWYjDptjQBIRbszWqdYNFPwEWgoGf0zas5DzF7euF4pbAPk/Qp2IcUDsPJj8L2ofsy8LTYf790BzPpS8BB1lBAb5ETlyOk3mMVSHJuEISnHplI4kBW9mNKk1DQn3Q/MZKH8Xuqog/yfqonT6cxA8Su8oPYJfqB8d15zbGdutdtpr251uMxgNxIyJIfX+VE6/dFoWmt2ZtU09ryT/x2rX4sFk/Tlk/xmEpN/++lzMLHUNwBQEuT+DhMVf/TkR42Hqz7WribWbaSoowGq1Ul9fT1xc3O099xDQNSmMGCH9fFzCYFBrGiInQ0c5lPxOXZQu/I/ri9JrIGKSLErfQvqSdE6+cJLlv1quvfsv+rgIxXFjP7rBZCBpRhIbdm7ghakvkP6gD7Vv8QS9TVD6ipoEehsHf8y4v4PMP763HXzmIHjo+rnzd/k3lZiYSEGBOlqpqqry3qSgKAp1dXWAusgcECANw1wueJS6KN3brA5Xu2ug7DUwbob4BRC/2GULWp5k2jencfBfD3L696eZ/q3pKIpC1bEqTJYbPyvFrtBY3EjZrjLqL9Sz/NfLdYxY0FULJS+qScDRO/B+UyCM/7/qiDlgiF907/ENVv83zH1n2LuKS5NCW1ubdv5obGysK59afJlfBIz5C3UxreJdaD6nLqrV7FIXwkY97rIKSk8QmRbJ5Gcns/0vthOZHklgZCD2XjsZSzNoLmvm8p7LAHTWd/LuuncZnTea0XmjdY3Z53RUQPGv4fy/DH6/f6yaBFKfctoC6o76jwz6ukm7ikuTQn19vXY5JibGlU8tbsbkD6PXq4vSdXvUpNB0BprOQUCMWgzn5n9ArvLQbx6is66T1x96nZgxMcRPiid7RTY5q3PY8d0dHPmPI6CAJcjC2nfXynrCcFIU9STDwl+qiWAwwalqEhj12I3OAB4iODiYoKAgOjs7tdkVV9EtKURHR7vyqcVXMZrUBbH4ReqooXwzdNdB/j+qi9Jpz6r1ED7M7G/ma+9/jT0/3MPRXx3lWv41Ct4s0HofBUYFYrfZCU0MJTBK6m+GlKKov5cX/59agzOYiAkw7h8g6RG1LYwHMxgMxMbGcuXKFdra2ujq6nJZTZeMFIQzgwEiJ6ofnZVqbyZbJxT9pzoHO3IlRE7x2UVpo9mIwWgg97lcUuan0FbVpnVJzViagb3XTk+LnJJ3zxSH2tvrws+g4r3BHxMzG8b9PSQ84JVNIfuSAqivnSNHjnTJ87o0KfR1RgVJCh4hKPn6onSL2ra76ypcfkPd2ho3X/1j9LFF6b6T1fxC/MhZkTPgfpPFJMVqd8Nhg2v7oeCfoeazwR+T8KB6SlnsPDDq1vXfZfrPpjQ2NnpnUugbKQQGBhIUFOTKpxb3wi8ccv432Huh8n21CK7mc7UoLjwHRn3N44frg+ls6OTMpjPUnavDYXUQMiJEWyeQk9Xukb1X/R0q+EeoPzj4Y0auhjF/BdHTffLskKioKO1yY+NNttAOA5clhd7eXlpaWgA1A8oinAcy+UHK19SdSXX7oHqHWonZfB78I9UT5fxvc62opwHaStTy/6BkCHbNu6Db0dvRy/a/2M6ZV86AAlFZUVzLv4YlxIK13UpoUigTnpwgp6vdCVsXVH2sFk42nx38MakbIOc70sjxOq9PCv2/KZk68nAGo9o3Pm4BtJxXq0J7GtShvzkY0jZCSNrgn3vtABT+St0G29cbBtQF7sxvwchVur4r7G3vZdP9m6jLr2PB9xcw5bkptFa28sLUFwgIDyB1YSr1F+p5ed7LPLXtKUbdJxXhg7K2q5sV8n8MHWWDPybzW5D9v9UGcpIEBoiMjMRgMKAoincmhebmZu1yZKRscfQKBoNa0xDxI+isUs+dtXVC0W/UGofkFRA17cYffP4/wtl/gNAsyP036LgChb9Q+8RXb4P9j6ln0c5+VbeFw4//18dcK7jGM3ueISE3gcu7L1O6sxSAtqttjH9iPKtfX80bD7/Bmyve5E+L/pSgaJkKpbcZyl5Vk0DPTfbVj/kryPoTaa1ym8xmM6GhobS2tmqzLC55Xlc9UWtrq3Y5PFxOCPM6QYnqorS1TW0l0FmhjiAq3ofYudBWpCaECT+A8d9TE8XHY9XPTVwO4/9BXcA+uB6OfgNmv+Lyb6GlooX8N/JZ8u9LuLznMpvXbqa5rBmD6ca72GO/PYbD5mDRTxbxyqJXOPqfR8n7fp7LY9Vd9zUo+R81Cdi7Bt5v9LteLfy8esqguCthYWG0trbS3t6O3W7HZBr+jR26JIXQUM8qJBF3wBKqniRn71XPmW48oY4Civ8L4haqbYYNBrWSuvWC8+eOWgPW/4IjX4esP1UXGF3o5IsnMQeZKfqoiMu7LzNh/QTWvL6GxpJG3n/qfQBsnTaO/PIIR36ptlLe+4O9zP7ObPxDvLwleWclFP9WbQk9GL+o69XCG9QW7mJIhIWFaZfb2tqIiIgY9ufUJSn0/0aFlzL5qZWkI1fDye+o6wcBCXDi/4A5DEJvsuaQugHyf6i+ALk4KVQdqyIwMpDyL8pZv3U96Q+oDe2uHrk6+CcYAAUcvQ7XBekqbSVqw8Si/xj8/qBR6ugu5Wtgkb/n4dL/tbK1tVWSgvACBiM0HFcvl7/x1Y83miDt63DhX2HWS8Mb25d0NXbRWtHKQ//1kJYQAK2vUR+D0UBYchgt5eo8r7XLSiAevCVXUdTzAy7+XD3WdTDhY9Vq4eQVahdQ4RJfTgqu4PKk4O/vj7+/lw+1hTNrM8TfrxYnOboH3l/0G8h4HqJnqlNLwaPB1q5OMbnwpLiupi6MZiOTN07Wbutu6cbW22+XlAHiJ8Wz+g+reXney3Q1dBEY6WEJQXGohy5d+Jm6Q2gw0TPVNtIjlshpfTry6qTQ2dkJQEhIiKueUrgLU4C642TaSdj/OLRcAPpNuTisUP6OeupVzCywtaojDKNrTy3rae3BYXPw31P+G8WhEBQTRFBMEPbefmdcK1BzqobfjP3NjZsUZZCv5kYcdqg/AAU/hepPB39M/GIY97dqpbqLf+7i5oKDb5z21/caOtxckhQURdFaZvv5SQsAnxM9Q+1fM+O/YOlx2LkIGo6qhWsAWd9ST4RrOKoWxVW8q85Z27vUuodh1t3czftPv09HrXqyWndLN+1V7RgtRioOVcCtXvMNuF9bC4dVPWC+4J/g2heDPyZ5BYz5a/X/xsdalXiS/q+Xfa+hw80lScFut+NwqO8MJSn4oMz/BcW/UbecjnocWotuJARQ35mOXKW+UF15W+2EmbAEzv4ALCHqSVhDfQjKdT1tPbyy6BWaLzcTlhxGVGYUl3dfBqC7qZtp35xG8+VmLn16acDnRoyOoLtlkOkwV7N3Q9VWtVq46dTgjxn9JIz5rpyw52G8NilYrVbtssUiQ1OfEzEBRiyDE38KihV6bzRGJH6hej+oxyWe/6k6Ssj9mTqlZG2D8z9Tz7tNfRLCsm//eVuLofMKYITQjEGLpnb85Q6aSpp49otnOf3Kac68coY5fz2Hg/9ykLarbdSeq2XK81MGJAW/UD+MZiMZSzLu4gdyj2wdaoLN/zG0D0xWAGR8E7L/j/rzkiTgsfonhf6vo8PJJUmhf4aTkYKPmvMa7MyDI89fv8EIk/4Rxv6VelRi6Rvqi5y1CRbvUQ8yj5yoHql46b/UtgmXXlTXJxKXq2sPg7XDUBxw5U0o+vXARmsjlkDWn0HSQ4A6bXRm0xlyVufw+iOv01rRCgoc/Jcbn1dxqIKK/RVOX8YvxI8lP1/CR9/4iBUvrxiyH9FN9bbA5T+oP5/umxzNmPMdtbbDx8+88DZeO1KQpCDwj4L798GHGepIwWhW1xkqP4C2QnWUMGIJTP0VhGXe+LzAeJjwffXd8eU/qPvnK96Dqx+p8+FJD99YGLX3wsEnoeIddeH0vs1q8dz5n6qV1Fc/gb0Pq/12pvyCEy+dwNZlI/8P+QBYQizYum0otn6LCP1mufr0tqsN89IeSGPk3GFo5NddD6UvqUnA1j7wfoNJLRTL+CMIHDHwfuE1+s+seFVS6D/skaTgw/wiYPlZdWRQ8S60XlTXFkY8CKlPq1M8N2MOVl8EHVao+hTqD6vN9eoPq++ORz8Nx/9UraKe9756GBDA2e+p/yY9Apl/orbQKPwlStmrpPf4YVifysnDS4mdnA0KNF5qpO7c4McfGowGFIeaMCzBFh5/+/Gh6fbbWaWOhvJ/PPj9lnA1CaQ9c/tdaIVXMJlMGI1GHA6HdyWF/t+MrCn4uKBE9d8x37m7zzdaIPlR9UW+4Qhc/VgdPRz7Flx+FXL/342E0L+VRv4/wdUt2gK3obeRhBRISKlh9vJDVJamsnfrWurO3bzmQEsIQRZCR4QSEBFwd99De5laLVz474PfH5ikJoGUJ9SzLITPMhgM+Pn50d3dLWsKQtySwaCuK8TMUg9w/2KtuhjdXADH/lxNHF3VNx5f+a76rzlUHW1cL6Kz28FkgpHpZSx+eBMlh79506fMXJFJ8QfFfP3g1wmOvc2tsoqiJqaLv1AbyA0mLFutFh65yiVbcIVn6UsKXjtSkKQghlxohrrLyN4FZddbYxT/auDjRj8N034L79wooDSZwGYLwGzuZkRqNUuf/pR9W+bR2TawyLL4g2Lic+NJmHSLrp+Kom4LvfCv6oL3YKKmqWcLJy5VF86FuIW+2RWvSgqypiCGlaKoC9Wjn4bytwdvpRE4Sm3bcOgpp5vPnltLUtweouO7sdtMtDaGYjDevFptznfmON/gsEPDYbVauOrjwT8pLk+tFo5fKNXC4o71vWZ6VVKQNQUxrAwGMAVC5AT1YPfBWml0lcMnYwZ8auqT3yD07NsAFJ3KRFGM+Ad109Hy5fbuCiZ/M+PXZqvHkBb8E9TtGTyexIdh7F9DzGypFhb3rC8pOBwOl5ypINNHwjvEzlEP9Bnz3RutNOoPfeWnhbarUzyKAlWlSZjMdix+N0a2JrOVjEmXmL9yH4lp1bD5/w78IilPqM8bmeuTB8yL4fXlWoXAwOFtwOiSpND/5KAh2cInxJdlfgu+WK3WJURMVltp3I7S3wFwtSQRu83EqJzLgMKaP3mP2KT6wT8n/XnI+TaEjZFqYTHsenp6aG1txWQy0dHR4R1J4ciRIxw/rvbU7+npccVTCl+T9Ija83//12Dyz5xbaRj9wH8EdF256afXX41h7iP7CQ7rJGeqc0I5tHUWdpuJ+97cP1zRC3FTly9f5uTJkwBUVlYSExMzrM/nstbZfdy+zbDwTEYzLPgYPl8AhzZcv1E7Gg1yfwoH19300z94YTUmi41/+P1POLFrCnvfy6OtKRQwYPHr4c9e3uuK70KIW3LFTItLkkJycjJJSUnY7XbMZpfnIeErQlLhwcOwdTzYO9QRgqMXtaHR4AlBUW7MANmt6u/m8Z3TaGvqO9xEwWq1EDrmvuGPX4hBREZGMmLECEwmE+Hhw1/M6JJX6OzsbKqqqgDZfSSGWVAiLM9XaxYq34fLb0DTyQEPUxRwONQ6BQCT2YbdZsbW6/wnETuyigfX7YSMz1wRvRADJCQkkJ2tdgeOjY0d9udzyVYJPdq/Ch8WlAih6eqOoCVH1bMZ+vlyQgCYeN9ZAI7vnkJdRbx2u603gPTlE9SvJ4QOXL2l3yVJQY9Of0IAap1A3ifgd6ORnMHgnBAAxs9Rk8LuzYtw2G/M26ZMaMYw6yWXhCrEYPpeMw0Gg/ckBT16gguhMZrU7qxLTsCkn0FotnbCZt++h9jka+p1h5Fnv/8SQWHtGM0Oahtnq22/hdBJ3+yKxWLxnoVmSQpCd0GJ6kf0FBj3lxjaS6H8PZQr72JtKiUgpAsAa48fScvX87//+Hna26KxBMkamNCXq8+3d3lSkDUF4RZC0mDsdzGO/S7ab+eGHwJgnP5TTAYDUfE3/WwhXKYvKbhqk46sKQhxXfKsZABaK1t1jkSIG1w9UpA1BSGum7hhIgBFH91miwwhhpnD4cBmswGSFIRwuayHswA4s+mMzpEIodLj2AGXTx/JmoJwV2HJahXz1SNXdY5ECJUexw7ISEGI66SDr3A3ehw7IAvNQvTjF6r+4Vk7ZUQr9Oe100cGg8HlR8oJcTcmPq0uNlcertQ5EiG8eKQA4O/vD0BXV5ernlKIOzZh/QQAzv7hrM6RCOH8etn3GjrcXJYUwsLURbyOjg7sdrurnlaIO5I4NRGAs69KUhD6a229UTPT9xo63FyeFBRFob293VVPK8QdMQeoRf4Oq0PnSITwkaQAzt+oEO5KTgkUeuv/WhkaGuqS55SkIMSXpCxIAaD5crO+gQifJyMFIdzApA2TALi45aLOkQhf19bWBqg7j7x2oRmgpaXFVU8rxB3LWJYBwNlNstgs9KMoivZaGRYW5rLiSpclhaioGweV1NfXu+pphbhjIQkhANScrtE5EuHL2tratOK1/q+fw81lSSEkJEQb/khSEO5M2l0Id9DY2Khd9sqkYDAYiImJAdTpI2mMJ9xZYHQgAL3tUoEv9OH1SQHQkoKiKE7fsBDupm+xuXx/uc6RCF/lE0khOjpauyxTSMKdjV83HoCzr8lis9BH/9fI/q+dw02XkQJAQ0ODK59aiDuSMCkBgHN/OKdzJMJX1dXVAWqX6YiICJc9r25JQUYKwp2Z/Ex6hyB8mNVqpampCYDY2FiXbn5waVKIiorSvjlJCsJTKA5pdyFcq76+XmuzEhcX59LndmlSMJvNREZGAurQyOGQpmPCfaU/mA5AY4lsihCuVVNzo0bGq5MCQGKi2prYZrNx7do1Vz+9ELet78CdC+9e0DkS4Wuqqqq0y32vma6iW1IA529cCHeTvkQdKZzZdEbnSISv6f/amJCQ4NLnlqQgxE0ExwYDUH9B1r+E69jtdmprawF1K2pAQIBLn9/lSWHEiBHaZUkKQgjh7Nq1a9hsNsD1U0egQ1Lw9/fXCjFqa2vlaE7h1kIT1YNNulu6dY5E+Ao91xNAh6QAzovNfQUaQrijiRvUxeYre6/oHInwFVevXtUu+0xSSE5O1i6Xl0tvGeG+xn9N2l0I1+p7TTQajU7T7a6iS1JISUnRLl+5Iu/AhPuKG6/uET+/+bzOkQhf0NHRoW3VT0xMxM/Pz+Ux6JIU4uLitBX1K1euyAHpwm0Zzbr8iQgf1X/mZNSoUbrEoMtvvNFo1L7hjo4OaY4nPILDLhX4Ynj1nznpP6PiSrq9DZIpJOEpsh7JAqChUN68iOHVN1IwGAy+NVIA56RQWlqqVxhCfKW+dhcFmwt0jkR4s66uLqqrqwF1ij0wMFCXOHRLComJidq6QmlpqTTHE24rbXEaAGc3yQ4kMXxKS0u19dW0tDTd4tAtKRiNRtLT1d4yXV1dTntzhXAngVHqO7am0iadIxHerKSkRLuckZGhWxy6bq3o/41funRJx0iEEEI/iqJoScFsNuu2ngCSFIS4LRGpEQB0NXbpG4jwSvX19bS0tADqeqvFYtEtFl2TQmhoKPHx8YDa76Ojo0PPcIS4qUkbJgFQtqtM50iENyoqKtIu6zl1BDonBYDMzEzAefgkhLsZ+/hYAM6+KovNYuhdvHhRu5ydna1jJG6QFPpnxcLCQh0jEeLmYnJiACj8UH5HxdBqa2ujsrISULeiRkVF6RqP7klh5MiR2n7c4uJirFarzhEJMZDRpPufivBSRUVF2lbUnJwcnaNxg6RgMpm0H0Rvb69MIQm357BJTY0YOhcu3DgDXJLCdePGjdMunz8v3SiFexqzZgwAdQVyBogYGj09PZSVqZsXwsPDdWmV/WVukRRSU1O16ubCwkLtKDoh3InW7uItaXchhkZRUZF2+mROTg4Gg0HniNwkKfSfQurp6ZFeSMItjc4bDcCZTWf0DUR4jbNnb+xmGzt2rI6R3OAWSQGcfyD5+fk6RiLE4ALC1dFs29U2nSMR3qCjo0NbQw0PD9e1irk/t0kKaWlp2i6kCxcu0NPTo3NEQggxfAoKCrRGoBMmTHCLqSNwo6RgNpsZP149D9dqtcqCs3BLffUKHdek+l7cm/5TRxMmTNAxEmdukxQAJk2apF0+c0bmbYX7mbhBXWwu3SHrXuLuNTY2agVr8fHxWrsfd+BWSSEpKYno6GgALl++THNzs74BCfElY9eoa1+y2CzuxenTp7XL7jRKADdLCgaDQUYLwq1FZagtCEq2S5GluDsOh4NTp04B6rky/V/z3IFbJQVQp5D6FlxOnjwpJ7IJt2IwusdioPBcxcXFtLWpO9iysrIIDQ3VOSJnbpcUwsPDtc6pLS0tFBcX6xyREIOz99r1DkF4oJMnT2qXp0yZomMkg3O7pAAwffp07fKxY8d0jESIgSasV+eAa87U6ByJ8DStra3a2QlhYWG6n50wGLdMCunp6URGRgLqiWyNjY06RyTEDROeUpNC/ptSZCnuzIkTJ7SOqFOmTMFodL+XYPeLCHXxZdq0adr148eP6xiNEM5G3adWnsqBO+JO2Gw2bebDaDS65dQRuGlSAMjNzcVsNgNw6tQpOWdBuA3/UH8AOq916hyJ8CRnz56ls1P9nRk3bhxhYWE6RzQ4t00KQUFBWkvtrq4up+o/IYTwJIqicPjwYe36rFmzdIzm1tw2KQDMnDlTu3zw4EHZnircRvwktQK1vaZd50iEJygrK6OuTj2HY+TIkSQlJekc0c25dVJITEwkNTUVgIaGBjnDWbiNSRvUgqPiT2XLtPhqnjJKADdPCgBz587VLh84cEBbuRdCTzkr1fM/zm6SaU1xa3V1ddo21PDwcMaMGaNzRLfm9kkhPT1daxZVWVlJeXm5zhEJARGpEQBc3nNZ1ziE+9u/f792edasWW65DbU/944OtR/Sl0cLQujNXXrfC/fW2NjIuXPnAHXzzNSpU3WO6Ku5fVIAdftWeHg4oJ5pWl1drXNEQoDBpCYGW4+cKS4Gt3//fm3Ke/bs2fj5+ekc0VfziKRgMpmcRgt79uzRLxghrutbbK4+IW9SxEAtLS1ai+yAgACn9j3uzCOSAqgl4X3FHoWFhVy9elXniISvm/iUeuDOudfP6RyJcEf79+/XttHPnDmTgIAAnSO6PR6TFMxmM/Pnz9euy2hB6C15VjIg7S7EQE1NTVo3VD8/P6eaK3fnMUkB1NYXfWsLxcXF2nF2QujBEmQBoKe1R+dIhLvZs2cPdrvaWn327NkEBQXpHNHt86ikYDKZWLBggXZ9586dUrcg3IL8Hoo+tbW1WluewMBAZs+erXNEd8ajkgKoJ7NFRalHIpaVlckhPEJXSTPUdgVtV9t0jkS4i127dmlvEubNm+cxawl9PC4pmEwmFi9erF3fsWOH9EQSupn4tLrYXPRxkc6RCHdQUVGhteMJCwvzmB1H/XlcUgAYO3YsycnqIt+1a9e0Q7CFcLXsR7MBOLPpjM6RCL0pisK2bdu06wsWLMBisegY0d3xyKRgMBh48MEHteu7d++mt7dXx4iErwobqW6Trjwkmx583dmzZ7Wt8nFxceTm5uoc0d3xyKQAMGrUKK2xVHt7O1988YXOEQlfJO0uBEBvby+ff/65dn3JkiVu3+PoZjwz6uvuv/9+TCYToJ630NDQoHNEwhf1bU21dsnpgL7qwIEDtLWpmw2ys7NJT0/XOaK759FJITo6mjlz5gBgt9v59NNPZWugcLmJG9TF5qtHpcreFzU1NWmNOk0mk9PUtify6KQA6pavvoK2S5cucfHiRZ0jEr5mwvoJAJz7g7S78DWKorB161ZsNrUp4owZM4iOjtY5qnvj8UnBz8+PJUuWaNe3bduG1SrDeOE6SdPVWgXZgeR7zp8/r9VKhYWFkZeXp29AQ8DjkwLAmDFjtDm8lpYW9u3bp3NEwpeYA8wA2HvsOkciXKmnp8dpC+qyZcvw9/fXMaKh4RVJwWAwsGzZMm3R+cCBA9TU1OgclfBFsqblO3bt2qUtLmdlZZGTk6NzREPDK5ICQExMDPfddx8ADoeDDz/8UCqdhcuMmjcKgJYrLTpHIlyhqqqKo0ePAmCxWFi+fLnXbE/2mqQAMH/+fOLi4gD1P+3gwYM6RyR8RV+7i4sfyEYHb2ez2diyZYs2KszLyyMiIkLfoIaQVyUFk8nEihUrtIy9Z88e6uvrdY5K+IKsh7IAOLtJzlbwdnv37qWurg6AhIQEZs2apXNEQ8urkgJAUlKS9p9ks9lkGkm4RMiIEACqT8rRnN6ssrKS/fv3A+qb0FWrVmlrmd7C65ICwKJFi7T22uXl5Rw6dEjniIS385b5ZHFzVqvVadpowYIFxMfH6xzV0PPKpGCxWJymkXbt2kV1tbyDE8MrIFLtm9/bIc0ZvdHu3bu16ejExERtY4u38cqkAJCSksLcuXMBtQXGe++9J0VtYlhN2jAJgIqDFTpHIoZaSUmJtnHFZDKxcuVKj21491W887u6buHChYwYMQJQz13YsWOHzhEJbzZ+3XgAzr0m7S68SUdHB++//752ffHixdouR2/k1UnBZDKxevVqzGa14vTo0aMUFckJWWJ4jMhV34BIuwvvoSgKW7Zsob29HYD09HSPO3P5Tnl1UgCIjY116lr4/vvv09IiBUZi6Jn8vGsXioAjR45ovY2Cg4NZtWqV128q8PqkADB9+nSys9VjE7u6uti8eTN2u/SpEcNHcUi7C09XVVXlNOW8atUqQkJCdIzINXwiKRgMBlauXKlVHVZWVsr6ghgWqYtTAWgqbdI5EnEvOjs7eeutt7Q3j7NnzyYjI0PnqFzDJ5ICQGBgIGvXrtUKTQ4fPsz58+d1jkp4m74dSBfeu6BzJOJuORwO3n33XW2aeeTIkdx///06R+U6PpMUQN1bvHTpUu36Bx98IEd4iiGVsVR9NymLzZ5rz549lJSUAOo6wuOPP+51Vcu34lNJAWDatGlMmKCelNXT08Mbb7xBd3e3zlEJbxEcFwzAtYJrOkci7sbFixe181iMRiOPP/44YWFhOkflWj6XFAwGA4888gixsbEA1NfX8+6770p/JCF8XH19vVM9wgMPPMDo0aP1C0gnPpcUQD3Cc926dQQGBgJQXFzM559/rnNUwluEJKg7VHpae3SORNyuzs5O/vCHP9DTo/6fjRs3zuu6n94un0wKAFFRUaxdu1YrVT948CCnT5/WNyjhFSZuUM9WuPLFFZ0jEbfDZrPx1ltv0dSk7hhLSEhw6p3ma3w2KQCkpqaybNky7fpHH31EeXm5jhEJbzD+a2q7i7OvytkK7k5RFD766COuXFETeEhICOvWrcPPz0/nyPTj00kB1MK2adOmAWrjvDfeeEMO5hH3JG6C2hen4K0CnSMRX2X//v2cOaPuFDObzaxbt47w8HCdo9KXzycFgGXLlpGWlgaoFc+vvfaa1utEiDtlsvjO9kVPdu7cOXbu3KldX716NUlJSTpG5B4kKaA2zvva175GQkICAM3NzU6LTkLcLYdddrW5o5KSkgGdT8eOHatjRO5DksJ1/v7+PPnkk9rQsbq6WnokibuWuTwTgIYiKY50N1evXuWtt97StqFPnTrVaw/MuRuSFPoJDQ3lqaee0raqXrp0iS1btkgNg7hjE59WdyCdf0daqbiT+vp6/vCHP9Dbq56ON2bMGB566CGf3Wk0GEkKXxIbG8u6deu0MxjOnTvHxx9/rJ3LKsTtSHtAXaOSHUjuo6Wlhddee43Ozk4ARo8ezZo1a7z2BLW7JT+NQYwaNYrHH39c+2U5efIk27dvl8QgbltQdBAAjcWNOkciANra2njllVdobm4G1FqEJ554QnvzJ26QpHAT2dnZrF69WhtWHj58mN27d+sclRDiTrW3t/PKK6/Q2Kgm6OjoaJ566ikCAgJ0jsw9SVK4hfHjx/Poo49q1/ft28fevXt1jEh4kvAUddNCV1OXzpH4ro6ODjZt2qTVHkVGRrJx40afOCznbklS+Aq5ubksX75cu75792527dolU0niK/WdrXB592V9A/FRnZ2dbNq0ibq6OgDCw8PZuHGjz3U9vVOSFG7DjBkzWLJkiXZ937597NixQxKDuKWxj6v73mWx2fXa2tp4+eWXqa2tBSAsLIyNGzdqpy+Km5OkcJtmz57tNGI4ePAg27Ztk8Qgbip2jNqe/eKWizpH4luam5t5+eWXuXZNPdMiNDSUjRs3EhUVpXNknkGW3u/AjBkzMJlM2hbVI0eOYLfbZZ+zGJTRLO+5XK2hoYFNmzZpR2lGRESwceNGIiMjdY7Mc0hSuENTp07FZDLxwQcfoCgKx48fp7u7m5UrV8r2NnFTDptDksQwq62t5dVXX9X6lkVHR7Nhwwafb3B3p+S39C5MnjyZ1atXa3UM+fn5vP7669IrSQyQsyoHgGvn5XjO4XTlyhV+//vfawkhPj6eZ599VhLCXZCkcJcmTJjAE088gcViAaC0tNTpl1IIuNHuouBtaaM9XAoKCnj11Vfp6lK3/iYlJfHMM8/IttO7JEnhHmRlZbFhwwatV1J1dTW/+93vaGiQJmhClbowFZAdSMPl0KFDvPPOO9hsNgDS09Od/ibFnZOkcI9GjhzJ17/+dW2Y2tTUxO9+9zvtJCfh2wIi1KrZlvIWnSPxLoqisG3bNqf2M7m5uaxfvx5/f3+do/NskhSGQGxsLM899xxxceqJW31FM3LmsxBDr7e3l7fffpvDhw9rt+Xl5fHoo49iMskBR/dKksIQCQsL4+tf/zrp6emAerTnli1b2LFjh7Te9nHRWdEAdDZ06hyJ5+sbiV+4cAEAo9HIo48+Sl5enmwLHyKSFIZQQEAATz75JDNmzNBuO3DgAG+99ZbsTPJhfYvNJZ+V6ByJZ7t8+TIvvviiVqUcEBDA+vXrmTJlis6ReRdJCkPMaDSyfPlyHnroIW3LamFhIf/zP/+jNeUSvmXsY9Lu4l4dO3aMTZs2aWchxMTE8Pzzz5ORkaFzZN7HoEifhmFTWlrK22+/TXd3NwB+fn6sXLlSzoL1MYpD4UemHwHwfeX7OkfjWaxWK5988onT+lxGRgaPPfaYtL4eJjJSGEZpaWl84xvfID4+HrixQLZ9+3Y5+9mHGIwy13036uvrefHFF50Swty5c1m/fr0khGEkSWGYRUdH89xzzzFx4kTttkOHDrFp0yZaW1t1jEzowW6VNwO3Iz8/nxdeeEFre+3n58eaNWt44IEH5PjMYSY/XRfw8/Nj1apVPPTQQ9qWuStXrvDb3/6Wixelg6YvGP/EeABqz9bqHIl765sueuedd+jt7QUgLi6Ob3zjG0yYMEHn6HyDJAUXMRgMTJ8+nWeffVY75KOrq4s333yTTz75BKvVqnOEYjhp7S7eknYXN1NTU8OLL77IsWPHtNsmTZrE888/T2xsrI6R+RZZaNZBV1cXH374obbXGtQCuMcee0xbfxDepaeth5+G/ZTg+GC+W/NdvcNxK4qicOjQIXbu3KmttZnNZpYtW8aUKVOk/sDFJCnoRFEUTpw4wfbt27VRgslkYuHChcyZM0fmTb3QDw0/BGQHUn+tra1s2bKF0tJS7baEhARWr16tdQgQriUHAOjEYDAwbdo0UlJSeOedd6itrcVut/P5559z4cIFVq5cKUNm4bUUReHUqVN89tln2pZtgDlz5rBo0SI5m0RHMlJwAzabjV27dnHo0CGtuZfZbCYvL09GDV7ktxN/S925Or5T8x1C4n23rXNTUxMfffSR0+ggLCyMVatWkZqaqmNkAiQpuJWKigq2bNni1Ho7OTmZRx55RNYavMCBfz3A53/1OSt+v4LJGyfrHY7LKYrC0aNH2blzp7azCNTF5KVLl0q7azchScHNWK1Wdu/e7TRqMBqNzJo1i7y8PPz8/HSOUNytxkuN/CrzV6QuSmXDzg16h+NStbW1fPLJJ5SXl2u3hYeH8/DDD5OZmaljZOLLJCm4qYqKCj744AOnfknh4eEsXbqUnJwc2ZHhgXyx3UV3dzd79uzh6NGjTt2Cp02bxgMPPCBnH7ghSQpuzGazceDAAb744gvtZClQT3xbtmwZkZGROkYn7oav7EBSFIVz587x2WefOR1RGxUVxaOPPsro0aP1C07ckizxuzGz2cyCBQuYMGECW7du5dKlSwAUFRVRWlrKrFmzmDdvnrzb8iQGQAFbjw2zv3f++dXU1PDpp586nT5osViYN28ec+bMkZ1Fbk5GCh5CURTOnz/Ptm3baGtr024PDg5m4cKFTJkyRXYpeYAtz2zhzCtneO7QcyTPStY7nCHV2trKrl27OHPmDP1fVnJycli6dCkRERH6BSdumyQFD9PT08MXX3zBoUOHnDqtxsXF8eCDD5Keni7rDW6s9PNSXn3gVWb8+QyW/XKZ3uEMiZ6eHvbv38+hQ4ecpjmjoqJYtmyZLCR7GEkKHqqpqYnPP/+cggLnXjopKSksWrSIlJQUnSITt9Lb0cs/h/wzAREB/J8r/4fas7XUnKkhdWEqsWM9q1jRZrNx4sQJ9u3bR0dHh3Z7YGAg8+fPZ/r06TJV5IEkKXi4iooKtm3bxtWrV51uz8jIYOHChSQlJekUmeijOBSaLzdTc6aG2jO17P3h3gGPiRsfxx+f+2MdortzNpuNU6dO8cUXXzi1fzeZTMyYMYP58+dLzYEHk6TgBRRFoaCggN27dzsVvoE6n7tgwQJGjBihU3Rizw/2aInAaDbisDvgS391STOTeP7w8zpEd/vsdruWDFpaWpzuGz9+PIsXL5YdcV5AxnZewGAwMH78eMaOHcvZs2fZs2cPzc3NAFy8eJGLFy+Snp7OvHnzSElJkTUHHTlsjkFvD4oJcnEkt6+3t5dTp05x6NAh7feqT3Z2Nnl5efKmw4vISMEL9b2j27t3r9NOJVDbZsybN4+srCxJDi7SUdfBL0b+Anvv4KeuGUwGJqybwKpXV7k4slvr6Ojg2LFjHD16lM7OTqf7srKyyMvLIzExUafoxHCRpODFrFYrp0+f5sCBAwPe4cXGxjJz5kwmTpworTNc4ONvfszJ351EsQ/8czNajEz95lSW/2q5DpEN1NjYyOHDhzl16tSAw58yMzPJy8uTtSovJknBBzgcDvLz89m/f7925m2fgIAApkyZwvTp02U+eBjVF9bz6zG/HrCWAGpSuO9v7mPhjxa6PrDrHA4Hly5d4ujRo1qRZB+j0cj48eOZM2cOCQkJOkUoXEWSgg9RFIWioiIOHDjg1JgM1HWJrKwspk2bRnp6uhTCDYM3Hn2D4q3FA0YLBpOBB372ALP/YrbLY+rs7OTUqVMcP36cpqYmp/v8/PyYMmUKs2bNksIzHyJJwUdVV1dz9OhRzp0751RwBGpv+8mTJ5ObmyujhyFUvr+cl+e9POh9j770KLnP5rokDofDQWlpKadOneLixYtORZAAERERTJ8+nSlTpsjWUh8kScHHdXR0cPLkSY4dO+a057xPWloakyZNIicnR3os3SNFUXhx+ovUnKpBcTj/2a19by1jVo0Z1udvaGjg9OnTnDlzZtD/64yMDKZPn05mZqaMFH2YJAUBqO8ei4uLOXnyJMXFxU5tjkFtzpeVlcWECRPIzMyUStW7dP6d82x+fPOA2zfs2kDqwqE/daylpYWCggLy8/OpqqoacH9QUBCTJk1i2rRpREdHD/nzC88jSUEM0NbWxunTpzl16hSNjY0D7vf392fMmDGMHTuW1NRULBaLDlF6JofdwS/TfklrufM79cU/XczMP5+JJfDef5atra2cP3+e/Px8KisrB9xvNBrJzMxk8uTJZGVlYTKZ7vk5hfeQpCBuSlEUKioqOHfuHOfPn3fqb9PHYrGQkZFBdnY2mZmZBAcH6xCp57D12Hhr1Vtc+vTSgPsCIgPIfS6XBd9bgH/o7U/VKYpCTU0NRUVFFBUVDWh50mfEiBFMmDCBiRMnEhLiu2dEi1uTpCBuS9/iZH5+PhcuXKCnp2fAYwwGAyNHjiQzM5O0tDRGjBghc9P99Hb08sbDb1B+sBwDBqditj868Uece+McJ/7rBFEZUTz9+dMERd+8yrmnp4fLly9rieDLRYp94uPjGTduHOPGjZPpIXFbJCmIO2az2bh06RKFhYUUFRUNOoIAtQYiNTWVtLQ00tLSiIqK8ukq6s1rN1O8tZintj3Fpe2X2P9P+9UFZwN8z/Y9DEYDtedq2bR4E7FjYtm4Z6P287JarVRUVFBWVkZZWRlVVVUD1n36JCQkkJOTw7hx44iN9azOq0J/khTEPXE4HFy9epXCwkIuXrzodKb0l4WGhjJy5EiSk5MZOXIkI0aM8JkF62vnr/Gbcb9hxe9XMHnjZNpr2/lF8i9w2Bz4hfjxt21/qz320vZLvLT0JRa/shiSoLy8nMrKygFbR/uYzWbS0tLIysoiMzOT8PBwV31bwgtJUhBDqrGxkdLSUsrKyigtLaWrq+umjzWZTCQmJpKUlERCQgIJCQnExsZ65cLn1j/byvm3z/Ptim9j8lO/vw+f/5BTvztFQGIAXzvwNWpqaqisrKSiooId/7SD4Nhgxq0dN+jXi42NJTU1lYyMDFnsF0PKN96mCZeJiooiKiqKadOmaQugpaWllJaWUllZ6bQWYbfbqaiooKKiQrvNZDIRGxtLQkICcXFxxMTEEB0dTUREhEcni7KdZWSszKCuoY76+npqa2u5mnWVgxzEbDXT9Xvn5Bk3Po6rh28sGEdFRZGamsro0aNJTU2VhWIxbGSkIFzG4XBw7do1KioqtHfEXz7/4WaMRiORkZFER0cTGRlJeHg4YWFh2r+hoaG6LmorikJPTw9tbW20tbXR2tpKS0sLjY2NNDY2suU7W4iaGEXqIudahJLPSvAL9WPk7JHabRaLhe4L3ZS/Uc7f5P8NSUlJhIWFufpbEj5KRgrCZYxGI/Hx8cTHxzNt2jRA7b1TU1Pj9HHt2jW+/F7F4XDQ0NBw0yRiMBgIDg4mKCjI6SMwMJCAgAAsFgt+fn5YLBbto2/k0beY2/evoijYbLYBH729vXR3d9PV1aV9dHd309HRQVtbG729vTf93h1+Dno7Bt4/7tFx2s8kPj6exMRE4uPj2fuDvRyPOs6YMcNb5SzEl0lSELoKCgrSdif1sVqtXLt2jfr6eurr67Vk0NDQMKCVcx9FUWhvb6e9vd1Vod+R5HHJNB5tZOLfTCRuRBxxcXHEx8cTFhY2YEeWw+7g7GtnyVwuB94L15OkINyOxWIhMTFxwAEuiqLQ1tZGc3OzNj3T/9+Ojg46OjoGNPgbbn5+ftoUVmhoqHY5LCyMqKgoIiMjaX+6nV9l/ork2mRmPD7jll/vwnsXaC5rZs0ba1z0HQhxgyQF4TEMBgNhYWFfOb9utVrp7OzUPnp6erBarQM++pJH31RV/ykri8WC2WzWPvqmnAICAggMDNSmpQIDA29rATwqPYopz09h+19sJzwlnOxHsgd9XPn+cj587kOyHskiaYYcZCNcTxaahXARe6+dd9e9y8UtF8lZlcO0P57GqPtGYTAYqDpRxfHfHif/zXxGzR3Fuo/W4RciJ+IJ15OkIIQLOewOTrxwgmP/eYxr56853ReZFsm0P57GjD+bgdlfBvFCH5IUhNCBoihUHq6k8VIjikMhIiWClPkpGIy+2wZEuAdJCkIIITTSwlIIIYRGkoIQQgiNJAUhhBAaSQpCCCE0khSEEEJoJCkIIYTQSFIQQgihkaQghBBCI0lBCCGERpKCEEIIjSQFIYQQGkkKQgghNJIUhBBCaCQpCCGE0EhSEEIIoZGkIIQQQiNJQQghhEaSghBCCI0kBSGEEBpJCkIIITSSFIQQQmj+P2wO7kiuEIJcAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAOIAAAGFCAYAAADgli+BAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA4DklEQVR4nO3dd3xU553v8c/MqI8kBKiggkBIAiR6MSBMx2AcU4wxccvGcexkc7PJZjf7ukk2PXF2c+9udm92czd3E6cnNrZDwGAbG9s00YtAiCIJIVAFIQlVRnVmzv3jQQcJBAg4M3NG83u/XnohidGcBzHfOec85fdYNE3TEEL4lNXXDRBCSBCFMAUJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwgSBfN0D4l9bLrRz/1XEuHb2Es8NJRGwE2U9lM271OKxB8r5+vyxSs0YMRHdbN9u+tI2CPxZgC7ExauEoQiJDaLzQyOW8y0QlR7HipyvIfirb1031SxJEcVfd7d38afmfuHz8Mkv+aQlTPzOVsJgw/e9r8mvY88M9FG0uYtWrq5j+8nQfttY/SRDFXW370jZO/OYEn97xaUbmjOz3MZqm8d4X3+P4q8f5fN7nGTFlhJdb6d/kol7cUUdTByd+c4J5/zjvtiEEsFgsfOJnnyAqMYoj//eIF1s4OEgQxR2d/ONJ3N1uZnxuxl0faw2yMuOvZ3DqtVN0NHd4oXWDhwRR3NGVk1cYMXUEkSMiB/T4jBUZONudNJY2erhlg4sEUdyRq8uFLdQ24MfbQmz6z4mBkyCKO4ocEUnD+QZc3QMLVn1xvf5zYuAkiOKOJj03CccVB+feOTegx+f9Io+UnBRiRsd4tmGDjARR3NGIqSNIyUkh95Vcutu67/jYCzsucHHHRR764kNeat3gIUEUd/XYzx7j6rmrbFi1gbb6tn4fU/J+CW+ufZP05elMfGail1vo/2RAXwxIeW45b6x5A2eHk4nPTmTcmnGE2NUUt565pxkrMlj/5/WERIb4url+R4IoBsxR6+DEb05w7L+P0VzerH8/Y0UGM784k8xPZGK1yUXW/ZAginumuTUctQ6627uJGB5BaHSor5vk9ySIQpiAXEcIYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECEkQhTECCKIQJSBCFMAEJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBIJ83QAhTEPToG4vlL8FnXVgDYXhMyHt0xAS49FDy/6IQgDU7IC8r0DzGYgcoz6cbXD1CFhDIP1lmPYvYPPMpqxyRhSicjPs+yTEzYMlOyBhMVgs6u/aa+D8L+HMP0NLISx8xyNhlDOiCGyt52HbJEheDXNfA+ttzk1XdsOuFZD5BZjxU8ObIZ01IrCd+y8IioQ5v7t9CAESFsGEf4Tzr0JXs+HNkCCKwOVshwu/g/SXICj87o/P+Dy4u+DiHwxvigRRBK5rpdDdBEkrB/b48EQYNhMa8gxvigRRBC53p/ozKGLgPxMUAa4Ow5siQRSBKzRO/dl6fmCP19xw7QKExRneFAmiCFz2VBg+B0p/NbDH1+wARxmkPm14UySIIrBl/g+o+Qhq9975ce5uOPMjiJkEcQ8b3gwJoghso56B+IWQu+b2YXS2wf5nof4gzPjPG4P9BpIBfSG6miD3CajdAwlLIeNzEJkOrjaofgdKfwOudnh4A6Ss8UgTJIhCgLr0LH8LSn4O9QdufD9kKIz5LIz9opp/6iESRCFu1lYFHXVgC4PINPWnh0kQhTAB6awRwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECEkQhTECCKIQJSBCFMAEJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECEkQhTECCKIQJSBCFMAEJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECEkQhTECCKIQJSBCFMAEJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTABCaIQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECQb5ugLiVpmm0t7fT0tJCS0sLDoeDjo4O/aOzsxOXy4Xb7cbtdqNpGgBBQUEEBwfrf4aHh2O324mIiMButxMZGcmQIUOwWuX912wkiD7U2dlJbW0t9fX11NXVUV9fz9WrV2lubsbpdHrkmFarlSFDhjB06FCGDh1KXFwcCQkJJCQkEBER4ZFjiruzaD1vp8Kj3G43NTU1VFdX6x/19fWY6dcfFRVFYmIiI0eOJDU1laSkJIKDg33drIAgQfQQTdOoq6vj4sWLXLhwgbKyMjo7O+/6cyEhIcTExBAdHa1/REZGEh4eTlhYGGFhYYSGhmKz2bBarVitViwWC5qm4XQ6cTqddHd3093dTVtbG21tbTgcDhwOB62trTQ2NtLY2EhHR8dd22Kz2UhKSiItLY2MjAxSUlLkstZDJIgGcrlclJeXU1RURFFRES0tLbd9rM1mIyEhgcTEROLi4oiLiyM2Npbo6GgsFovH29re3k5DQwNXrlzRP2pqau4Y0PDwcMaMGcPYsWMZN24cYWFhHm9noJAgPiC3282FCxc4ffo0xcXFtLe39/s4u91OWloaI0eOJDk5mREjRhAUZK5bdE3TaGhooKKigoqKCiorK6mvr+/3sTabjYyMDCZOnMi4ceMICQnxcmsHFwnifaqrqyM/P5+CggJaW1tv+XubzUZaWhrp6emMGTOG+Ph4r5zpjNba2kppaSklJSWUlpb2e8YMCgoiKyuLGTNmMGrUKL/8d/qaBPEeuFwuCgsLOXz4MJWVlbf8fWhoKJmZmWRlZZGRkUFoaKgPWuk5brebyspKCgsLOXPmTL9vQMOHD2f69OlMnToVu93ug1b6JwniADgcDo4dO8axY8duefFZrVbGjh3LlClTyMzMNN3lpqe43W4qKio4c+YMZ86coa2trc/fBwUFMXXqVObMmUNsbKyPWuk/JIh30NLSwv79+8nLy7tlXC8+Pp4ZM2YwceLEgH/ndzqdFBUVkZeXx8WLFwG4VnMNa7AVe6ydcePGMXfuXFJTU33cUvOSIPajsbGR/fv3c+LECVwul/59i8XC+PHjmT17ttwL3UZDQwO73t3F1p9vJXhoMCmzU/S/S09PZ8mSJSQnJ/uwheYkQeylra2N3Nxcjh492ieAwcHBzJgxgzlz5hATE+O7BvqBzpZODvzkABcPXiT8kXAuB1++ZRhn3LhxLF68mBEjRvioleYjQQS6u7s5fPgwe/fu7TPoHhoayqxZs5gzZ07AX34OhNvpJu/VPEq3lwLw8NcfJmlWEgUFBezZs4empib9sRaLhalTp7J06VIiIyN91GLzCOggappGUVERH3zwAc3Nzfr3g4ODycnJIScnh/DwcB+20L8Uv1vMyd+fJCI2gq7WLhb/cDFDxwwFVI/ziRMnyM3N7XOGDA0NZcGCBcyePTtgOrr6E7BBbGxs5P333+fcuXP69ywWC9OmTWPx4sVERUX5sHX+p+ZkDYd+eghbsA1rsBW3082j//YoIZF9B/qdTidHjx5lz549fcYkhw0bxsqVKxkzZoy3m24KARdEt9vNgQMH2LNnD93d3fr309PTefTRR4mPj/dh6/zTtZpr7P/X/bReamX42OE0lzcTnRLNkh8tue3POBwOdu7cyfHjx/tMfJ82bRrLly8PuCuRgApifX09mzdvprq6Wv9eVFQUK1asIDs7W3pB74Ozw8mhnx6i6kgV8RPisdqs1J6pJWNFBtNfmn7Xn798+TLvv/8+FRUV+vciIyN5/PHHycrK8mTTTSUggqhpGocPH+bjjz/WxwMtFguzZ89m8eLFg24GjDe11bex8zs7uXb5GuHDwolOiabubB3TXppG5mOZA3oOTdPIy8vjo48+6tNZNm3aNB577LGAmMc66IPocDjYtGkTpaWl+veGDx/O2rVrSUlJucNPioHQNI2msibyf5tPS3ULHY0dWKwW5n9zPonTE+/puZqbm3nvvff63LcPHz6cdevWkZSUZHTTTWVQB7G8vJyNGzf2mZY2e/ZsHnnkEVnwaiC3082u7+7CGmQlaVYSzeXNTH5+MmEx975MStM0Tp48ybZt2+jq6gLUBPqlS5eSk5MzaG8fBmUQNU1j//797NixQ+8IiIyM5MknnwzYXjlPKtxUSPXRarKezCL5IWNmzTQ0NLBx40YuXbqkf2/ChAmsWbNmUF6qDrogdnV1sXnzZgoLC/XvjRkzhieffFIGjj1A0zR2fWcXAItfWWzoGcvlcrFr1y727dunfy8+Pp5nnnmGYcOGGXYcMxhUQWxubmbDhg3U1NQAqkNm4cKFLFiwQEo8eEj1kWoKNxeSPCuZrLWe6eUsLi5m06ZNekdOWFgY69evJz093SPH84VBE8SqqireeOMNrl27BqgZG0899RSZmQPruRP3Z9d3d+F2uVn8g8VYgzz3ZldfX88bb7yhVwywWq2sWrWKadOmeeyY3jQoThMlJSX8/ve/10M4dOhQXn75ZQmhhzWVN+HqdhE5ItKjIQSIjY3lc5/7HOPHjwfUxIwtW7awZ88eU1XCu19+f0Y8deoUmzdvxu12AzBq1CiefvppqdHpBbu+twtXl4v535xPaJR3xmLdbjfbt2/n8OHD+vemT5/OypUr/fr2w69n2R4+fJj3339f/zo7O5snn3wyoCcPe0tnSyeuLhe2EJvXQgjqknTFihXExMSwfft2AI4fP053dzdr16712zD67St2//79fPTRR/rXM2fO5BOf+ITf/kf4m/zf5QMMaBqb0SwWCzk5OURFRbF582ZcLhenTp3C5XKxbt06bDab19v0oPwyiAcPHuwTwgULFrB4sbFd5+L23E4312quYQu2MSR1iM/aMXHiREJCQnjzzTdxuVycPXsWl8vF+vXr/e6qyO9OH4cPH9YvSQCWLl3KkiVLJIReVLy1GE3TGLtqrK+bwtixY3n22Wf14BUXF7Nx40a9z8Bf+FUQ8/Ly+twTLlq0iPnz5/uwRYFH0zQuH7+M1WYlaaY55n9mZGTw/PPP69MWi4qK2Lp1q1/1pvpNEIuKinj33Xf1rxcsWMDChQt92KLAdOnoJdwuN4kzEk11FZKWlsYzzzyj3x/m5+ezfft2vwmjXwSxsrKSjRs36r/UuXPnyj2hj5x79xwWq4Vxq8b5uim3SE9PZ926dfrr4tChQ+zfv9/HrRoY0wexvr6eDRs26OsIJ0+ezLJlyySEPuDNAfz7lZ2dzerVq/WvP/744z7zjs3KnL/N6zo6Onj99df1KtJpaWmsWbNGQugjJ35zAoCpn5nq24bcxbRp01iy5EaZjk2bNvVZxWFGpg2i2+3mL3/5Cw0NDQAkJCTw9NNP++UY0WDgqwH8+zV//nwmT54MqHKZGzZsuOM2eb5m2iDu2rWLkpISACIiInj22WdlPz4f0gfwX/b+AP79sFgsrF69Wi/z39rayltvvdWncLSZmDKIZ86cYe/evYCa0rR+/XqpsO1Dbqeba1euD+CP9N0A/r0KCgri6aef1l87VVVVfSaCmInpgtjY2MjWrVv1r5cvX05aWpoPWySKtxajuc0xgH+v7HY7n/zkJ/VbmkOHDnHmzBkft+pWpgqiy+Vi48aN+gLQSZMmMXv2bB+3KrCZcQD/XiUlJfHYY4/pX2/ZskXvezALUwVx9+7des3RnsrP0kPqW2YdwL9XM2bM0Dtvurq6ePvtt001Dc40QSwrK9Nrk1itVtatWyf1Rk3AzAP498JisfD4448zdKjai6OiooIDBw74uFU3mCKI3d3dfeYGLl26VPbQMwF/GMC/F6Ghoaxdu1Y/s+/atUuvb+Rrpvjt7tq1S79mT01NZe7cucYfxN0N7VfUh9t598cLvxnAvxepqanMmzcPUH0SPesZfc3nQayurubgwYOA6m5evXq1sfciTWfg6Jdg43DYPEJ9/CUWjn0FmouMO84g428D+Pdi0aJF+iapV65c4dChQz5ukY+D6HK52LJli35JumjRImJjY415ck2Ds/8C2yZC5UYY97ewYAsseBsyvwDlr8N72VD0H8Ycb5DxtwH8e2Gz2fq84e/evZvGxkaftsmnQTx69Ci1tbUAJCYmGntJWvxTyP86TPgmrKmAKT+ClNWQsgam/i94ogrGfxWO/x2U/Ldxxx0E+qzA96MB/HuRlJTErFmzANVHsW3bNp8umfJZEB0OB7t37wZUj9aqVauMqzfTXqNCOO7vYco/ga2fEu22UJj2r5D5P+D430PnVWOOPQiYaQW+Jy1ZsoTo6GhAleTsmVLpCz4L4s6dO/UdY6dOnWrsbj+lvwJLEEz67p0fZ7HApO+D5oYLvzPu+H5sMAzgD1RoaCiPPvqo/vWHH37os44bnwSxpqaG48ePA+qXsXTpUmMPUPYajHoGQmLu/tiweBj5JJT9ydg2+KmeAfykmUl+PYA/UNnZ2YwcORJQa1/z8vJ80g6fBHHnzp369fjChQuN3xym/TIMyR7446Oz1c8INYBvsTB25eC+LO1hsVj6nBV3796tX6l5k9eDWFlZqW9EOWTIEP2G2VDWYHB3Dfzx7i6wDr6tvu6VPoCfODgG8AcqJSWFSZMmAdDW1qYPp3mT13/bO3fu1D9fuHChZ+pPDpkIl+9huUvNh+pnAtDlE5f5geUHHPi3A4NyAH+glixZoncWHjp0iPb2dq8e36tBvHjxIhcvXgTUpO4pU6Z45kCZX4Da3Wow/24a8uDqEfUzgeh6j/3xV48P2gH8gRg6dKi+s1RnZ6fXB/m9GsTc3Fz980WLFnmu7EXKWogYCYdegO7W2z+uqwkOfRYi0yHpcc+0xU9cLb6K5tIG5QD+QM2fP99nZ0WvBfHSpUv62XD48OFMnOjBS0FbiJpF01oCH82Hyx+qIYoebhdUb4OPHoa2SvVYq9TCuXpOhbGprImmsibarrb5ukleFRMT0+es6M0eVK9tEHDgwAE14bq1hJwZS7DW74OwBAgbAcHRakzPSMOmwbJ9cPDTsOtRddYbNhPQ4OpRcFyEYTNg2QEYMt7YY/up4i3FFG8p1r+2Blv5euPXCbEHTkfW3LlzOX78OJqmceTIEXJycrxSsMwrQWxqauLs2bMA2IPbmBK6EwoPQ5BdfYTGQuQYiEhR4YzKUOF8UDGTYMVxqD8Ipb9W4cMCI5ZC+sswfJbxbwB+5nbTumxhNh7/+eMBFUJQV2tjx46luLiYlpYWzp49q/eoepJXgnj06FG1Gjo8gVmL/47gEWeh6SQEDwWLVU1Jaz2vLh8tVkh8FDJeNubgFgvEzVUf4hZ1p+v6fG2xWojNiuWTGz9J7HiDJuD7mZycHIqL1ZXBwYMHmThxoscnN3j8HtHlcpGfnw+oWe8z5z8OWf+gwtZZq8bw7KNgyASIzlJhjEj1dLPEdeX7yvXPLTYLybOT+fyxzwdsCEHtOp2YmAiovg1vFCf2eBCLi4txOBwAZGVlYbfbITgK0j8HaZ8Gdye0FKsAOi5C6HCo2wdNpz3dtIDXVN6E23mjE0tzaTSUNGALCeyOK4vF0meiSc90TE/yeBB79zxNn96ra9xqg5RVMO4rar5n82lwtkF4ImhONV/05HegZqdaWygMd+I3J7DH20mdd+MKpK2+jcoDlT5slTlMmDCBkBB1f3zq1Cm6uu5hptZ98GgQm5qauHDhAqAGTPutTzpsGmR/DYZOg4hktSxp0vfVXFHNDTUfQcF3oOx1cHn2lxFIelbgB4UF8cLuF1j646VYrOo+6OzGsz5une+FhIToQ2xdXV0er4Xq0c6agoICvVdu+vTpt7/hjUhW943urhsrJtL+6noQd0BtLjSdUperYXGQ/pIxvaoB7MRv1XS26S9Px2qzMu8b8xi9aDR/Xv9nKvZV+Lh15jB9+nT9srSgoEAfY/QEjwaxZ8gCuHsXcFAEENH3exYrJC5TH40noeIv0FELZ36sJmlnfE4NeYh74na6cVxx3LICP2VOCn9T9Dd0Nnf6sHXmkZyczLBhw2hoaKCsrAyHw6H6ODzAY5em9fX1eqm6lJSUB9+7YugUmPJDyPyiCqG7C879F5z8rgrpQBT+BF63QMOJB2uLn7vTCvwQewhRSVE+aJX5WCwWJkyYAKjxVk/us+ixIPY+G/b8YwxhHwmTfwDZ34DQONWxU/6G6ti5/FHfqWw3K/3N9U8Ct/MnkFbgG6H3a9eT94keC2LvRmdn38Mi3YEKGQJZX1UdOzGTAA2u7FSBvPjHWzt2XJ3QYv6dYz2t+kh1QK3Af1AJCQkMHz4cQL889QSPBLGlpYUrV64A6jp7yBAPVgKzhcDo52DyKzDiEXVf2XwW8r8G+f8IjQVwrQwq/uy5NviRkvdKsFgtg74wlFEsFgtZWVmAupooLS31yHE80llz/vx5/fPMzExPHOJWlutzSEcshfrD8GEOoMHZ/+Wd4/uBnhX40cnRWG2BswL/QWVmZur7spSUlOib2RjJI/8bvYOYkZHhiUPcWexsmP1rsNxmgWuAThDoWYE/5QUPLcgepFJSUvQNkUpLSz2yi5ThQXS73fogfnh4uLFlEu9F+ovwiRNqDis33QuV/D+49MGdO3YGiZ5SGLn/lBvQK/AfhM1mY8yYMYCqaXP5svGFxgy/NK2trdWrYKWlpRlXNPh+DMmCFcdgxxJVDkPrqVmpQe0eqN0L0Zkw6llVcNiTXF1Q+ReoeFOty7SFqtlEGX/t2fWQ10/+R352hKkvTg3oFfh3VPa6mjSC5frSOGufP8e4L1NYew5iJlFRUWH4bmWGB7Gi4sasjNRUE6yisARDy7leIUSNRTpb1aydlmI49QPVC5vxeQgZanwbKv4Mx76kJiPEPazeIFztqpZq8U9VmY6c36sJ7x7iuOLAYrUM2hL6D8TpgAN/dSN4N9OcpDZrcAWwhlBRUUFOTo6hTTA8iJWVNyYM9xRu9an6A9DVq5x+wmIYOlmVXExYpHpYy95Q9WvO/ouaLDDmRYgcbczxS38Lhz8LI59S45+96626OlVIj/89fLwAHtkLocOMOW4/gkKDaCpr0r8OiQohYnjE7X8gUNjC1YfLAfRX6dtCXHwioWPm0hmRTWVlJZqmGTr847EzYnBwsL71lU9VbLz+iVXtg5H9NTXE0WNItpqx035ZbUbj7oLzv1Bn0pTVqpzG/f7Cm4vgyOfUkq9Zv7j1eWyhkPYpGP6Qqp9z9Asw7637O9Zt9F6Bv/t7u9n9vd3614FYCgNQ+2NWvwunX4HGOy1xsqq5z5O+jzXj84xs/zPnz5/n2rVrNDY2MmyYcW+ahgaxpaWF5uZmQPU0eaPWx13V71cV3ea9BbFzbv+48ER1xuq+pvbBaL+k7umq3obYHEh6rG+AB6Lk5+pyc+bP7hzm6HEw+Udw7G/AUalmDxnk5hX4PQKqFIarCyreUsFrPdf/Y6Kzbkz4sFjBFqFmb437CgSrSvSpqan6iEBlZaV5g9gziA/4rrf0Zgu2qvu/oAFO1g2OhHFfUu+aVW9DY75aqFx3AKLGwOjnwRZ29+dxdcDF38PYLw2sI2j083Dia2oDnck/GFhbB6D3CnwIkFIYzja4+AcVvPbbrK4f9/dqZlbPooG2Knh7lLplGfcVyP76LbcJvV/TvV/rRvBYEBMSEox86vsXcZ9vCNYgSH0KRq5TQbz8oaqrc+qHKqwZf33nzpW2KuhugYQBbrATHKXO2M3GzWe8eQW+xWYheVYyL+x8gaAwrxXw87zuFij5hQqes786thaY+G0Y+2W1jK4/ESmw+jxYQ2/7mun9mvabIJri/tAIFgvEz1cfzUVQvkEVLS78yfWOnRdUBbqbuZ3qT2vwwI9lDQZ39z030e1yU7q9lGP/fYzLeZdxdjqxx9vVR8KNK4FBUwqjox7O/UwFr78J/EFRMPE713vB76GXOLKfheu9/zoykoiICNra2vwjiDabTZ8oO6gMGa8uG9uvqPs/dzecf1V17CQ/3rc8Y3jC9Xmvp1WI70Zzqx7cpMfuqUkNpQ28seYN6s7UkTA1gVELR3F6w2miUqKo2F+B5tSISYuh6WITcKMURu/yGKbXVg1F/64++hOeqIKX9sL1da2eYbFYSEhI4OLFi1y7ds3Q9YmGjbZrmkZDQwOg9rUwRUeNp4QnqEBO/BbYU9UYZdXbqqRH1VZVSTxkKCStVJdMN0+p629d5OUPwVGmCmoNUFN5E7+d/1u627qZ/OnJtFa3cnqDKrpVe7KWmNExjF0zlqaLTYxePNp/SmG0lsKRv1a/o9ct8HZK3xBGZULOH+DpDnhOg7WXVIkVD4awR3x8vP55fX29Yc9r2BnR4XDgdKrLsQdeBOwvguzqBeB2QvU7akOb+oNq0nnkKBjzEuxdoy5nRz934+duXhfpbIeC76qZNsNnD/jw737+XdxON62XWil+u5gpn5mCLcTGwZ+obcXaG9s5t+UciTMSKdtVxspfriT3h7nmKoWhaeq++MyPofz1/h8zdLq6x0tepe7dfah3T2lDQwOjRo0y5HkN+1c1NTXpnwdMEHtYg2DkWkh5Qk0guPQBXLsIrRdhyGQ4+IIan0z7tLqc7b0usv0KHHheXcIu3T3gMcv64npKPyxV/RBPT2TlL1cSYg/Rz4gAs788m5CoED7++scE24M5v/2870thaNe3PDjzT1C9tf/HxC+ACd9WK2nudcjIw3oHsbGx0bDnNSyIPeOHgGfXH5qZxaKmsMU9DC0lagpb/AI1lHHoRcj/pvq6R/63oHYHBEXCovchduCbtp749QksVgvDModRc7KG/z30f6O5NEKH3Bgq2fP9Pfrn3c5uiv5SROfPOr1bCkNzq3m9p3+kFm73J+kTMOFbarzW5IuVe59kWlpaDHteOSN6SnQmZP1P+HMM+rSpjstq0neP5tMw5ccw5jMDm2fq6lI9qxYL5949h+bWaDjfQPZT2YxfO559/7yP0OjQO57xOpo6iEr0YBDdLri0Dc78SE2070/qJ2HCP0LMFNMH72ZRUTd+dxJEfxEcCbNfhaNfBHc/+7KP+wqM+7vbbwmnaepS99zPVWeQqw0sQbQHzSA+eiQNtiyCIsI5++ezaG51v9lSfecXR3uTwXv+ubtVdb0zr6he3/6M+ayaWhg9zthj+0BoaCghISF0dXX1uQp8UIYFsa3txl56kZGRRj2t/0t/UQ3U71sPzYVArzWQzWdUJ419pLp/7N3r52yDA5+Cqs0QmaHOIE2n1FSt5nzW/+1hurtsnD44gfd+uwqX+/p45W2WWFpsFjSXRvjQ8Af797g6VE2g06+ovSX7M+4rMP6rqkd5kLFYLNjtdrq6ugzdyNSwIPYuSd5Tqlxcd7t1kQmLVFe9o1y9sK0hMPZvIGQY7F2nCis//Kaa4VO9DQq+B0B4hLr0DA5xMW1hAZdKkzm24/a9rWHDwrBarbTVt2GPvcdxr+5WNe3u9CvQdZvOiQnfUrNWwk0ym8rDel7fRpbhNyyI3d03ZoRIEPvR37rImElqZk5rqZob6e6Cov+jznyXP4AlH6mCWCW/UCszruvushAcoi5FuzptPP7Z93nkmZ385z98mbaWW69GOhrUZXFEXAThw+5yRuxsUPViz7zS/ywfW4QaPM/8wo2q7AGm5/XtdDpxu92GLH43/IxotVoH92D+/epvXWTM9ernUelqgkDnVVXG4+pRiEiDyi1QfxQKvtnnqYKCtV6fq2CfyJ3Kneq1WoOtzPryLH1QX9d+GYp+CoX/0v8PhsXDhO+oS+yBTpwf5IKDb0xb7O7u1uvZPAjDgxgcHCz1Mvtzt3WRoHpOk1erGTpYoOT/9vtUbdfCsEeps5zVCm6XFUez/Y4dkLYQmyqTca0MCv9VTdHrT2S6Gjz3RvkQP9X7iq+rq8ucQZTL0tsY6LrIng6Qaf8G+d8A7db7kJ4Q9ijKG4emWQiL6MDR3HdoIja5lodX7mfqgpOw61u3Hi9migpeypp7m6AewG4OohEMv0fsfdoWvQx0XWTPWTL1KXXPePIbd3y4pkFN2QisVjdBIV0kjr7EvDV7yZ51m6rmcQ9fn7Wy7PbDJuKOgoJuxKZ338gDPacRT9LZ2cnOnTtxOp2Gzb0bdAa6LjLqegXu2txeZygb/ddSgcbaaMY/dJaktCss+eSuW/6+pjwe68M/J37+k343eG5WJSUl5ObmYrPZWLJkiSFL/gwJotVqpbNTdalrAVq81zBR6WoxccnPVbU54E6dMHu3LCJ/z3S+99r3ATh7JIu9W+ZTU5bI5HknGTvtHBMWrPN4swON2+3G7Xab64yoaRpDhgwxrAcp4I37MuQ+oSq/Ab1H6TWt74mt/pIqd3GtKZLX/vU5asrUmdcW3EFddRwZD/XqqRWGCA4OJjw8HJvNRnj4A06QuM6QIIaEhDB37lza29sNLagTsJJXw9i/hRNfBZsdXA51TtRuvbqcMv8kVSWpnDncd8ctm03j2X94g6YRP/FaswNFWloas2erCRQ9FcAflGFrTDwx2yBgWSww46dqyzmX2gbsdnd3PZ0yRz96iNrKGzNbujrCsNo0kld/1rNtDUCemEVmeBCNumYOeBYLTPoePHYKktfq34K+C/7DI9Uc36uX43C7bsQ1NKKDurCvYQ0eREWiTMIvgtjV1SUdNkYaOhEWboJFH+jf6n152vvzF7/7GyKir2G1uYiIsTL6M9/xYkMDhyemcxr2dtkzfqhpGk6nU8YTjZb0KDyaB45KXAdexOpq1EMYGt5BZ3sYyemXeOmHf6Am+JuMfEIuST2l9xnRqNe5YUG8ebaBBNEDhk+H4dOxpTaAptF9fgNtea8xbm49BTtSON22iSlfWYN0l3mWJ6ZzGn5pCtJh4xUWC8GZzzHkmfeY9c/fB6DssG+bFCg8MZ3TsCD2ru/Y2tpftWXhKYkzEgE4+YeTPm7J4KdpGg6H6smOiDCufKNhQexdHqN32QzheVab+m/sKZchPKejo0PvrImOjjbseT0SRCNreQhhJr0LRpkyiL1LKMoZ0ftGLx4NQEuVcZXFxK16v7ZNGUS5NPWtyX81GYDTb56+yyPFg+jZVgIwdDqnYUEMDw/Xe5EkiN43/onxABT8ocDHLRncTB9Ei8WiN6yxsVHfB0N4R0+ZxCsFxm4XJvqqra3VP4+NNW6jV0M3FujZyNHtdlNX1/+W0UL4K03T9K0Ho6OjDVsCBR4KIhi/o6q4O3u8Gst1dsrViCe0tLTQ0aHqBRm9I7bHglhTU2PkU4sBmPxp1WFTtqvMtw0ZpDy5Nb2hQexdu6O6utrIpxYDMPl5FcSCP0qHjSdUVVXpnxu9Nb2hQbTb7XqHzaVLl6TDxssSJqt36VOvn/JxSwanysobe32MHDnS0Oc2fBfI1FS18YjL5eLSpUtGP724g1uqeAvDuFwu/Yw4ZMgQw/cANTyIvd8per+DCO+SxdnGunLlij7H1OizIXjwjAhQUWGivdoDRMaKDACaLjb5tiGDTO/Xcu/XuFEMD2JsbKy+PKSsrAyXq//CuMIzenpOT78hU92MVFpaqn/uiSLahgfRYrGQkaHelTs7O+Xy1MvGrlSVwmVtonGcTidlZWWA2ro7Pj7e8GMYHkRADyLA+fPnPXEIcRuhUarA89ViKSxslPLycv3+MCMjwyO7nXkkiOnp6Xpjz50754lDCOE1JSUl+ueZmZkeOYZHgmi320lOTgbUJNmrV+Xd2ZuiU9Q6ue52qTH7oDRN4+zZswDYbDbDKnvfzCNBBMjOvlEC/syZM546jOhHT4dN6Yeld3mkuJuqqip9VX56ejphYWEeOY4EcRDSp7rJ2sQH1vu1O2HCBI8dx2NBjImJISUlBVCDofX19Z46lLhJbJZaJ1e46TablYoBufmydNy4cR47lseCCH3fQU6elO50b/FEr14gKisr88plKXg4iJMmTcJqVYfIz8/H7Xbf5SeE0WSq2/07fvy4/vmUKVM8eiyPBjEyMlI/nbe2tspQhheNW6N+71fPSY/1/Whvb6ewUF3aR0REePSyFDwcRIDp06frn/d+hxGe1VPVTZZE3Z9Tp07py/imTJlCUJBnt7fzeBDT09P1JSMlJSVSfNhLMh9TA8/Sc3rvNE3j8OEbG4lMmzbN48f0eBCtVqv+D7n5Hyg8JzhC7cbVVNbk24b4oZKSEn0SyujRoz0yt/RmHg8iwMyZM/VTe15enl6ARwgzOnjwoP55Tk6OV47plSBGRkbqvU6dnZ1yr+glwzJU2ZIuh2yTN1A1NTVcvHgRgOHDhzN27FivHNcrQYS+7yyHDh2SdYpe0NNhU7Kt5C6PFD327dunfz579myvjcl6LYixsbF6F3BLS4ucFb1g4rMTAemwGaja2lp9Spvdbmfq1KleO7bXggiwYMEC/fPc3Fx9jZfwjJ5L03PvyvjtQOTm5uoTIB5++GFDdwS+G68GMTk5mfHj1WYpra2tHDt2zJuHDzgy1W3gbj4bzpw506vH92oQARYvXqy/QPbu3avvRy48S6a63dlHH33ks7Mh+CCICQkJTJyo7l3a2tr63BwL4034pJp4X3dGNgW6ndLSUn0V/pAhQ3jooYe83gavBxHUWdFmswFw4MABGhsbfdGMgNCzSLjgNemw6Y/b7Wb79u3610uXLiU4ONjr7fBJEIcNG8acOXMAVSHrww8/9EUzAsKYpaq0g/Sc9u/EiRP6nofJyclMmjTJJ+3wSRBB9aBGRkYCUFhYyIULF3zVlEEtKEzNaGq91OrjlpiPw+Hg448/1r9+9NFHfdbB5bMghoaG8sgjj+hfv/feezKcIbzqww8/pL29HVBrZz1RwXugfBZEUMtLevYRuHr1Krt37/ZlcwatuOw4ADqaZY5vjwsXLuhVI8LDw1mxYoVP2+PTIFosFlavXt2n40Z2kDJeT4dN8dZiH7fEHLq6unjnnXf0r5ctW4bdbvdhi3wcRIC4uDgWLVoEqLGuLVu2yDxUg0185vpUN9nAFIDt27frPfWpqaleWW94Nz4PIsDcuXP1HVivXLnCzp07fdyiwWVIqlqYfeEj6RArLi4mLy8PgJCQEJ544glTzEAyRRBtNhtPPPGEfom6f//+PrvviAdjhheaGTgcDrZu3ap//eijj+o7XPuaKYIIak/y3r2omzdvxuFw+LBFg5PmDsypbpqm9XlNjR07tk89JV8zTRAB5syZo+8kde3aNTZt2iQlGA3Sszbx8onLPm6Jb+Tm5uo7k9ntdlavXm2qKwVTBdFisfDEE0/oA/2lpaXs2rXLx60aHHqCWPCnwOuwuXDhgj40ZrFYeOqpp/TXmFmYKoigymqsW7dOL0y8d+9e2TvDAKMXjgYCr+e0sbGRjRs36isrlixZQlpamo9bdSvTBREgLS2N5cuX61+//fbbXLlyxYct8n+2ENUR1n613cct8Z6Ojg5ef/112traALW34bx583zcqv6ZMoig6oX0FJzq7u5mw4YNtLbKfEkxMG63m40bN1JXp5Z/xcbG8uSTT5rqvrA30wbRYrGwcuVKkpKSAGhqauK1116js7PTxy3zXyOmqbHa9obBfVbUNI0PPvhA75wJDw/nueeeIzw83Mctuz3TBhEgODiYZ599Vq8UXlNTw1tvvSUzb+7TlE+rK4zCzYN7u7a9e/dy5MgRQI1RP/PMM6YZL7wdUwcRICoqik996lP6u1lpaSlbtmyRYY370LNafzCvTTxy5EifmVmrVq1i1KhRPmzRwJg+iKDmoz777LN6tfCCggLeeecdqcNyj6KSogAozy33cUs8o6CggG3btulfL1++3KslER+EXwQR1OTcp556Sh/WOHHiBO+++66EUQBq96a3335b/3r+/PnMnTvXdw26R34TRIDx48f3CWNeXh7btm2TMN6DnmEMt2vwXNrn5+f3mYU1c+ZMlixZ4uNW3Ru/CiJAdnZ2n27oo0ePyj3jPehZm3jp6OBY93n8+HG2bNmivxnPmDGDxx9/3LTDFLfjd0EEmDhxImvXrtV/2fn5+bz55ptSamMApvyV6jk9+ceTPm7Jg9E0jYMHD7J161Y9hLNmzWLlypV+F0Lw0yACTJ48mfXr1+tLp4qLi/nTn/4kW77dRUpOCuDfPac9JRB7l0GcO3cujz32mF+GEPw4iKAuU59//nm9KnN5eTm//vWvpU7qHdiC1RtX1zX/rLDe3d3Nxo0bOXTokP69RYsWsWzZMr8NIfh5EAHGjBnDCy+8QEREBAB1dXW8+uqrlJcPzi76QNba2srvf/97zp49C6jdqNesWcOiRYv8OoQwCIIIqjDsSy+9RGxsLKBK+f/hD3+Qrd9uI2WOujx11PrPwuuKigp+8YtfUFVVBagyF88995wp6s0YYVAEEdTuri+//DLp6ekAuFwutm7dypYtW6QT5yY9PadnN571cUvuTtM0jh49yu9+9zuuXbsGqP0pXnzxRX0R+WBg0QbZIJzb7eaDDz7Q5xqC2vhm/fr1+hkz0DnqHPwk/iekzEnhpYMv+bo5t9XZ2cl7771HQcGNjqW0tDTWr1+v34oMFoMuiD16psH1nA1DQkJ4/PHHmTx5st/fTxjhB5YfAPA97Xs+bkn/Kisr2bRpU5+Ot5ycHJYtW6ZP6BhMgnzdAE+ZPHkyiYmJvPXWW9TV1dHV1cXmzZspKipi5cqVPi8oK/rndrvZt28fu3fv1idphIaGsmrVKn07v8Fo0J4Re3R1dbFt2zby8/P179ntdlauXElWVpbvGuZjP47+MV2tXXy769v6kIav1dTUsGXLFi5fvlHgauTIkaxbt46YmBjfNcwLBn0QexQWFvLOO+/oZRNAjUOuWLGC6OhoH7bMN7Z9aRtH/+soL+x+Qa9n4ytOp5M9e/awf/9+/SxosVhYuHAhCxYsGJSXojcLmCCCKtH47rvvUlRUpH8vJCSExYsXM3v27ID4D+9RdbiKX8/5NdNemsbqX632WTtKSkr44IMPuHr1qv69uLg41qxZQ0pKis/a5W0BFURQ3eGnTp1i+/btfQoYJyQksHz5cn34Y7Bzu9y8EvQK1mAr3+n6jtePX19fz/bt2/Uts0Gtpp8/fz7z5s3T154GioALYo/29nZ27NhBXl5en2VU6enpLFu2TN+LYzDzRc+pw+Fg3759HD58uM+KmdTUVFauXEl8fLzX2mImARvEHlVVVWzbtq3PdnAWi4UpU6awYMEC09c6uV+apvFD6w8BWPyjxXS1drHoB4sICvXMmai9vZ2DBw9y6NAhurpuzHONjo5m+fLlTJgwIaCHlQI+iKBelKdPn2bHjh00NTXp37dYLEyaNIn58+cTFxfnuwYa7MLHF3jzyTfpalWBsFgtaG6N5957jsxPZBp6rPb2do4cOcLBgwf7rIwJCgpi3rx5PPzwwwQHBxt6TH8UWBfit9ETuKysLI4cOUJubi4dHR1omkZBQQGnTp0iKyuLnJwcUlJS/P6du+ZkjR5CuLExTVhMmGHHaGxs5NChQ5w4caLPGdBmszF9+nTmz58fkL3VtyNnxH50dHRw5MgRDh061Ge4AyApKYnZs2czYcIEv+1Q6Gju4N+T/p3utr5zcL945ov6Nt/3Q9M0ysvLOXr0KGfPnu1z7221Wpk6dSoLFiwY9GOC90OCeAddXV0cO3aMAwcO6BOOe9jtdqZMmcKUKVNISEjwUQvv3/avbufwfx5Gc9347//qpa8SlRh1z8/lcDjIz8/n+PHjfYYhQNWmnTZtGnPmzBm099tGkCAOgNPp5PTp0xw+fLjPrI8eiYmJTJ06lezsbKKi7v2F7AvNFc38R9p/9Nkv8Ztt3yQ4fGD3a52dnRQXF3P69GlKS0tvKfpst9uZPXs2M2fOHHQTtD1BgngPNE2jsrKSI0eOUFhYeMuLz2KxkJKSQlZWFuPHjzf9GeAvz/6FsxvP4na6sQZb+Xbnt+94/9vW1kZpaSlnz56lpKQEp9N5y2PS0tKYMWMG48eP99tLd1+QIN6ntrY2Tp8+TX5+fp+hj97i4+MZM2YMY8aMYdSoUYSGhnq5lXd2+fhlfjnjlwCEDwvna1e/1ufv3W43NTU1lJSUcP78eaqqqvotXRkdHc2kSZOYPn06w4cP90rbBxsJogFqa2s5ffo0hYWF+u5DN7NarSQnJ5OamkpycjLJyclER0f7vAf2d4t+R/mecmLSYvhC4Reorq6msrKSiooKqqqqbrvpj91uZ8KECUyYMIHU1FSf/zv8nQTRYFevXqWwsJCioiKqq6vvWPw4MjKSxMRE4uLiiI2N1f/09K5FnZ2dNDY20tDQwPF3jvP2N97GlmIj66U7r0aJi4sjMzOTzMxMRo0aFVBzcz1NguhB7e3tlJWVcfHiRS5cuEB9ff2Afi40NJTo6Giio6MZMmQIkZGRhIWF6R+hoaHYbDasVitWqxWLxYKmaTidTv2ju7ubtrY2HA6H/mdLSwuNjY19hmQ0TePEr04QlRx1y2B+VFQUqamppKWlkZmZqe/KJYwnQfSia9eucenSJaqrq/WP9nZz7FUYHBxMQkICI0aMIDU1lZEjRxITEyOXnF4iQfQhTdNobW2lrq6O+vp66urquHr1Ki0tLTQ3N/fbK/kgLBYL0dHRDB06lJiYGIYOHUpcXBwjRoxg6NChEjofkiCalKZptLe309LSgsPhoKOjg87OTjo6Oujo6MDtdvf5AHVWCwoK0v+MiIggIiICu92O3W4nIiJChhRMSoIohAlIt5cQJiBBFMIEJIhCmIAEUQgTkCAKYQISRCFMQIIohAlIEIUwAQmiECYgQRTCBCSIQpiABFEIE5AgCmECEkQhTECCKIQJSBCFMAEJohAmIEEUwgQkiEKYgARRCBOQIAphAhJEIUxAgiiECUgQhTCB/w+gVHgwBuHIbQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k_test = 100\n",
    "\n",
    "x_test = np.random.normal(0,1, (k_test, d)) # should be sample from the unit sphere\n",
    "x_norm_test = np.linalg.norm(x_test, axis = 1)\n",
    "\n",
    "x_test = np.transpose(x_test)/x_norm_test\n",
    "x_test = np.transpose(x_test)\n",
    "\n",
    "# Init\n",
    "w_s_ft_in, a_s_ft_in = w_s, a_s\n",
    "\n",
    "\n",
    "#L_og_large, L_og_large_test, L_og_large_pre, dist_large= simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 1, 0, 3, x_test,y, True, False)\n",
    "L_og_small, L_og_small_test, L_og_small_pre, dist_small = simulationFT2(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 0, 2, 3, x_test,y, True, False)\n",
    "#L_og_full, L_og_full_test, L_og_full_pre, dist_full = simulationFT(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 20, 0, 3, x_test,y, True, False)\n",
    "\n",
    "L_og_grad, L_og_grad_test, L_og_grad_pre, dist_grad = simulationFT2(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 2, 0, 3, x_test,y, True, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b5ae9cf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "cd450e5f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1  1]\n",
      "[ 1 -1  1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1  1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "[ 1 -1 -1]\n",
      "[ 1 -1 -1 -1]\n",
      "mask mask\n",
      "40\n",
      "average test loss ft a pre train loss small weights\n",
      "0.0382750330466382 ci 0.039830772182384865 0.33496199943353877 ci 0.10410801105885864\n",
      "average test loss ft a pre train loss grad weights\n",
      "0.06292326409072557 ci 0.03284328659103524 0.3127188104380079 ci 0.12496587955152422\n"
     ]
    }
   ],
   "source": [
    "# static\n",
    "\n",
    "simlist = range(10)\n",
    "\n",
    "\n",
    "train_s = []\n",
    "test_s = []\n",
    "pre_s = []\n",
    "ldist_s = []\n",
    "\n",
    "\n",
    "train_g = []\n",
    "test_g = []\n",
    "pre_g = []\n",
    "ldist_g = []\n",
    "\n",
    "for i in simlist:\n",
    "\n",
    "\n",
    "    L_og_small, L_og_small_test, L_og_small_pre, dist_s = simulationFT2(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 0, 2, i, x_test,y, False, False)\n",
    "    L_og_g, L_og_g_test, L_og_g_pre, dist_g = simulationFT2(1, steps, batchsize, S, x, w_s_ft_in, a_s_ft_in, w_t, a_t, 2, 0, i, x_test,y, False, True)\n",
    "\n",
    "    \n",
    "    index_s = L_og_small.index(np.min(L_og_small))\n",
    "    test_s.append(L_og_small_test[index_s])\n",
    "    pre_s.append(L_og_small_pre[index_s])\n",
    "    ldist_s.append(dist_s)\n",
    "\n",
    "    index_g = L_og_g.index(np.min(L_og_g))\n",
    "    test_g.append(L_og_g_test[index_g])\n",
    "    pre_g.append(L_og_g_pre[index_g])\n",
    "    ldist_g.append(dist_g)\n",
    "\n",
    "\n",
    "\n",
    "print('average test loss ft a pre train loss small weights')\n",
    "print(f'{np.mean(test_s)} ci {1.96*np.std(test_s)/np.sqrt(10)}' , f'{np.mean(pre_s)} ci {1.96*np.std(pre_s)/np.sqrt(10)}')\n",
    "\n",
    "print('average test loss ft a pre train loss grad weights')\n",
    "print(f'{np.mean(test_g)} ci {1.96*np.std(test_g)/np.sqrt(10)}' , f'{np.mean(pre_g)} ci {1.96*np.std(pre_g)/np.sqrt(10)}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "d7e66562",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.09668951305581087,\n",
       " 0.07099795628957153,\n",
       " 0.04234056765015792,\n",
       " 0.007740407366188618)"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(ldist_g), 1.96*np.std(ldist_g)/np.sqrt(10) , np.mean(ldist_s), 1.96*np.std(ldist_s)/np.sqrt(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e4854f8b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
