{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4023ef89-55dd-445a-af5e-c98d431de495",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.linalg as la\n",
    "import cvxpy as cp\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import random\n",
    "import time\n",
    "import mosek\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "seed=0\n",
    "random.seed(a=seed)\n",
    "np.random.seed(seed=seed)\n",
    "\n",
    "def relu(x):\n",
    "    return np.maximum(0,x)\n",
    "def drelu(x):\n",
    "    return x>=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4ea972b8-1169-4395-9233-2c55b0595975",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.colors as mcolors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cea6e94f-1e3a-45c3-9ee3-ce429665d7f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "RANDOM_STATE = 0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81fb91e6-9411-4c6f-a036-2db1e9d298d0",
   "metadata": {},
   "source": [
    "### 1. Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "bb6ce8d5-b757-4ba9-9471-190b52eb2a25",
   "metadata": {},
   "outputs": [],
   "source": [
    "def spiral_xy(i, total_points, spiral_num, n_shape = 50):\n",
    "    \"\"\"\n",
    "    Create the data for a normalized spiral.\n",
    "\n",
    "    Arguments:\n",
    "        i runs from 0 to total_points-1.\n",
    "        total_points is the total number of points in the spiral.\n",
    "        spiral_num is 1 or -1.\n",
    "        n_shape is an int which determines the shape of spiral wrt function, unscaled_spiral_xy.\n",
    "    \"\"\"\n",
    "    # Normalize i to always fit in the range [0, 96], which is the original range.\n",
    "    i_normalized = i * n_shape / (total_points - 1)\n",
    "    φ = i_normalized / 16 * math.pi\n",
    "    r = 6.5 * ((104 - i_normalized) / 104)\n",
    "    x = (r * math.cos(φ) * spiral_num) / 13 + 0.5\n",
    "    y = (r * math.sin(φ) * spiral_num) / 13 + 0.5  # spiral_num mirrors the orientation of the spiral\n",
    "    return (x, y)\n",
    "\n",
    "\n",
    "def spiral(spiral_num, n=100, n_shape = 50):\n",
    "    \"\"\"\n",
    "    Generate either a clockwise (+1) spiral or a counter clockwise (-1) spiral for a total of n points.\n",
    "\n",
    "    Arguments:\n",
    "        spiral_num: 1 or -1 determines the orientation of the spiral.\n",
    "        n: total number of points in a spiral.\n",
    "    \"\"\"\n",
    "    return [spiral_xy(i, n, spiral_num, n_shape) for i in range(n//2)]\n",
    "\n",
    "\n",
    "def generate_spiral_data(n=100, n_train = 80, n_shape = 50, seed = RANDOM_STATE, default_label = True):\n",
    "    \"\"\"\n",
    "    Generate binary spiral classification data.\n",
    "\n",
    "    Arguments:\n",
    "        n: total number of points in a spiral.\n",
    "        n_train: numbr of training points.\n",
    "        seed: permutation randomization seed.\n",
    "        default_label: True uses label +/-1 and False uses label 0/1\n",
    "    \"\"\"\n",
    "    a = spiral(1,n,n_shape)\n",
    "    b = spiral(-1,n,n_shape)\n",
    "    # Combine spiral from both orientation as one and scaling feature space from (0,1)^2 to (-1,1)^2\n",
    "    X_all=2*np.concatenate((a,b),axis=0)-1 \n",
    "    X_all=np.append(X_all,np.ones((n,1)),axis=1) # Adding bias to the feature space\n",
    "    # concatenate the labels of the spiral, which is their orientation (+1/-1)\n",
    "    if default_label:\n",
    "        y_all=np.concatenate((np.ones(n//2),-np.ones(n//2))) \n",
    "    else:\n",
    "        y_all=np.concatenate((np.ones(n//2),np.zeros(n//2))) # reset -1 to 0.\n",
    "    # randomize data indices\n",
    "    np.random.seed(seed)\n",
    "    idx = np.random.permutation(n)\n",
    "    X_all = X_all[idx]\n",
    "    y_all = y_all[idx]\n",
    "    # Split into training and testing sets\n",
    "    X_train, y_train = X_all[:n_train], y_all[:n_train]\n",
    "    X_test, y_test = X_all[n_train:], y_all[n_train:]\n",
    "    \n",
    "    return X_all, y_all, X_train, y_train, X_test, y_test\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "953f39ea-1dd7-4467-8885-e74874a69c30",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_all, y_all, X, y, Xacc, yacc = generate_spiral_data()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6c9faa39-a92e-43ba-9dc4-114061874fe2",
   "metadata": {},
   "source": [
    "### 2. Hyperplane partitions sampling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d4f49433-f5d4-4337-b6ed-77d5329116b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "beta=1e-5\n",
    "P=1000\n",
    "n = 80\n",
    "d = 3\n",
    "np.random.seed(RANDOM_STATE)\n",
    "dmat=np.empty((n,0))\n",
    "\n",
    "## Finite approximation of all possible sign patterns\n",
    "for i in range(P):\n",
    "    u=np.random.randn(d,1)\n",
    "    dmat=np.append(dmat,drelu(np.dot(X,u)),axis=1)\n",
    "\n",
    "dmat=(np.unique(dmat,axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bb19092d-6e68-4859-b2b2-529629d00d61",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(80, 623)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dmat.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "094d90de-7578-4f0e-bf35-99d6368caa19",
   "metadata": {},
   "source": [
    "### 3. Convex solver for exact convex program reformulation of two-layer ReLU NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "95c48e53-bec4-4ddd-99ab-4047bc00e8ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2-layer convex program objective value:  0.0008144290287536936\n"
     ]
    }
   ],
   "source": [
    "# Optimal CVX\n",
    "m=dmat.shape[1]\n",
    "Uopt1=cp.Variable((d,m)) # c_i in paper\n",
    "Uopt2=cp.Variable((d,m)) # c_i' in paper\n",
    "\n",
    "## Below we use hinge loss as a performance metric for binary classification\n",
    "yopt1=cp.Parameter((n,1))\n",
    "yopt2=cp.Parameter((n,1))\n",
    "yopt1=cp.sum(cp.multiply(dmat,(X*Uopt1)),axis=1)\n",
    "yopt2=cp.sum(cp.multiply(dmat,(X*Uopt2)),axis=1)\n",
    "#cost=cp.sum(cp.pos(1-cp.multiply(y,yopt1-yopt2)))/n+beta*(cp.mixed_norm(Uopt1.T,2,1)+cp.mixed_norm(Uopt2.T,2,1))\n",
    "cost=cp.sum_squares(y-(yopt1-yopt2))/(2*n)+beta*(cp.mixed_norm(Uopt1.T,2,1)+cp.mixed_norm(Uopt2.T,2,1))\n",
    "\n",
    "constraints=[]\n",
    "constraints+=[cp.multiply((2*dmat-np.ones((n,m))),(X*Uopt1))>=0]\n",
    "constraints+=[cp.multiply((2*dmat-np.ones((n,m))),(X*Uopt2))>=0]\n",
    "prob=cp.Problem(cp.Minimize(cost),constraints)\n",
    "prob.solve(solver=cp.CLARABEL,warm_start=True)\n",
    "cvx_opt=prob.value\n",
    "if prob.status != \"optimal\":\n",
    "    print(\"Convex: Status convex: \",prob.status)\n",
    "print(\"2-layer convex program objective value: \",cvx_opt)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2cf1adf1-a1e3-4b88-921f-f50028195861",
   "metadata": {},
   "source": [
    "### 4. Comparison of Convex Solver with SGD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "abbbcba2-5244-47bd-8d1f-d3ca34b9e296",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of neurons: 623\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAG0CAYAAADehEiZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABk80lEQVR4nO3dd3gU5doG8HvTeyMkISQQOoRQAyKIAkoVC1ZUBGzHj0NQihWxgVIUC3oIeNSj2OV4FGwIBKRJkRBASugEEiAhJCGdtN35/ohZdrN1dmd3Znfv33XlurIz777zzAYyT96qEgRBABEREZEH8pI7ACIiIiK5MBEiIiIij8VEiIiIiDwWEyEiIiLyWEyEiIiIyGMxESIiIiKPxUSIiIiIPBYTISIiIvJYTISIiIjIYzERIiIiIo/FRIiIiIg8lo/cATjDL7/8gqeeegoajQbPPfccHnvsMavfq9FocOHCBYSGhkKlUjkwSiIiIpKKIAioqKhAfHw8vLxMt/uo3H3T1YaGBiQnJ2PTpk0ICwtD37598eeffyIqKsqq9587dw6JiYkOjpKIiIgcIS8vDwkJCSbPu32L0O7du9G9e3e0bt0aAHDzzTdj3bp1uP/++616f2hoKIDGDzIsLMxhcRIREZF0ysvLkZiYqH2Om6L4RGjr1q1YvHgxsrKykJ+fj1WrVmHcuHF6ZZYtW4bFixcjPz8f3bt3x5IlS3D99dcDAC5cuKBNggAgISEB58+ft/r6Td1hYWFhTISIiIhcjKVhLYofLF1VVYVevXph6dKlRs+vXLkSM2bMwJw5c7Bv3z5cf/31GDNmDHJzcwE09hE2Z+5Dqa2tRXl5ud4XERERuSfFJ0JjxozB66+/jjvvvNPo+XfeeQePPvooHnvsMXTr1g1LlixBYmIili9fDgBo3bq1XgvQuXPn0KpVK5PXW7hwIcLDw7VfHB9ERETkvhSfCJlTV1eHrKwsjBw5Uu/4yJEjsWPHDgDANddcg0OHDuH8+fOoqKjAmjVrMGrUKJN1zp49G2VlZdqvvLw8h94DERERyUfxY4TMKSoqglqtRmxsrN7x2NhYFBQUAAB8fHzw9ttvY9iwYdBoNHj22WfRokULk3X6+/vD39/foXETEZHr0Gg0qKurkzsMasbX1xfe3t521+PSiVCT5mN+BEHQO3bbbbfhtttuc3ZYRETk4urq6pCTkwONRiN3KGREREQE4uLi7Frnz6UToejoaHh7e2tbf5oUFhYatBIRERGJIQgC8vPz4e3tjcTERLOL8pFzCYKA6upqFBYWAoDZsb+WuHQi5Ofnh9TUVGRkZOCOO+7QHs/IyMDtt99uV93p6elIT0+HWq22N0wiInJBDQ0NqK6uRnx8PIKCguQOh5oJDAwE0Nj4ERMTY3M3meITocrKSpw8eVL7OicnB/v370dUVBTatGmDWbNmYeLEiejXrx8GDhyIDz/8ELm5uZgyZYpd101LS0NaWhrKy8sRHh5u720QEZGLafpD2M/PT+ZIyJSmBLW+vt59E6E9e/Zg2LBh2tezZs0CAEyePBkrVqzA+PHjUVxcjHnz5iE/Px8pKSlYs2YN2rZtK1fIRETkRrjPpHJJ8bNRfCI0dOhQo4si6po6dSqmTp3qpIiIiIjIXXDkFxEREXksJkJERETksZgImZCeno7k5GT0799f7lAAADX1aotdhERERE0KCgowffp0dOzYEQEBAYiNjcXgwYPxwQcfoLq6GgCQlJQElUoFlUqFwMBAJCUl4d5778Xvv/8uc/TOw0TIhLS0NGRnZyMzM1PuUFBYUYOuL63FpE92yx0KERG5gNOnT6NPnz5Yv349FixYgH379mHDhg2YOXMmfv75Z2zYsEFbtmmy0bFjx/D5558jIiICw4cPx/z582W8A+dR/GBpAn7afwEAsO1EkcyREBF5LkEQcKVenrXlAn29Rc2Qmjp1Knx8fLBnzx4EBwdrj/fo0QN33XWXXg9DaGgo4uLiAABt2rTBDTfcgFatWuHll1/G3XffjS5dukh3IwrERIiIiMgKV+rVSH55nSzXzp43CkF+1j2yi4uLtS1BukmQLktJ1fTp0/Haa6/hxx9/xLPPPis6XlfCrjEiIiI3cvLkSQiCYNCSEx0djZCQEISEhOC5554zW0dUVBRiYmJw5swZB0aqDGwRIiIiskKgrzey542S7dpiNW/12b17NzQaDSZMmIDa2lqL72++gbm7YiJkgjvuNSYIAl756TA6xYRg4sAkucMhInIpKpXK6u4pOXXs2BEqlQpHjx7VO96+fXsAV/foMqe4uBiXLl1Cu3btHBKjkrBrzAQlzRqTyq7TJfh851m89ONhuUMhIiIHadGiBUaMGIGlS5eiqqrKpjree+89eHl5Ydy4cdIGp0BMhNzUmoP5mLlyP2p0ZjhU1NTLGBERETnLsmXL0NDQgH79+mHlypU4cuQIjh07hi+//BJHjx7V26C0oqICBQUFyMvLw9atW/H444/j9ddfx/z589GxY0cZ78I5lN/GR7BlHcWpX+0FAHSJC8WUIR2sek9ucTXiwgPg53M1P/5x/3nsOl2C127vDh9v5s1ERK6gQ4cO2LdvHxYsWIDZs2fj3Llz8Pf3R3JyMp5++mm9/TlffvllvPzyy/Dz80NcXByuvfZabNy4UW/Dc3fGRMjNXaqwPCAOALaduISJ/9mNPm0isGrqddrj07/dDwDo1zYSd6UmOCJEIiJygFatWuFf//oX/vWvf5ks4wmzwizhn/huztrWpG8z8wAA+3JLjZ4vqaqTKCIiIiLlYCLkQbhTGRERkT4mQi4s6+xlbDtxyWwZgekPERGRSUyETFDa7vPG3LV8Byb+ZzcKK2pMltHtGnP/ZbGIiIjEYSJkgpLWEbLUqjP/1yPYm3vZ3osQERF5HCZCbuDH/Rdw57IddtXxZ06JRNEQERG5DiZCBAAoqrRumj0REZE7YSLk5gRbVmMkIiLyEEyE3JxUOwd7wAbERETkgZgIkVXYsERERE1effVV9O7d2y2uw0RIJgfOlWJD9kVcqVNbLGssCTHX5VWv1tgTGiprG6zemoOIiJQpLy8Pjz76KOLj4+Hn54e2bdti+vTpKC4uFlWPSqXC6tWr9Y49/fTT2Lhxo4TRyoeJkEwmf7Ibj32+B2dLqiSv+8Otp+16f8or69B//gaUVl/dVoNdY0REruP06dPo168fjh8/jm+++QYnT57EBx98gI0bN2LgwIEoKbFvpnBISAhatGghUbTyYiJkgqMXVIwJDQAAFJZbbnkxloSY66paczDf1rD0ZOeXS1IPEZE7EAQBVVVVsnyJnfiSlpYGPz8/rF+/HkOGDEGbNm0wZswYbNiwAefPn8ecOXMAAElJSXjttdfwwAMPICQkBPHx8XqbtCYlJQEA7rjjDqhUKu3r5l1WDz30EMaNG4cFCxYgNjYWERERmDt3LhoaGvDMM88gKioKCQkJ+OSTT/TifO6559C5c2cEBQWhffv2eOmll1BfXy/+h2MH7j5vQlpaGtLS0lBeXo7w8HDJ648J88exixVWdUGpRK4J7ePF5hsiIqlVV1cjJCRElmtXVlYiODjYqrIlJSVYt24d5s+fj8DAQL1zcXFxmDBhAlauXIlly5YBABYvXowXXngBr776KtatW4eZM2eia9euGDFiBDIzMxETE4NPP/0Uo0ePhre3t8nr/v7770hISMDWrVuxfft2PProo9i5cyduuOEG/Pnnn1i5ciWmTJmCESNGIDExEQAQGhqKFStWID4+HgcPHsQ//vEPhIaG4tlnn7XxkxKPLUIyaRniDwAotCYRMtYiZKa8t04itOHIRSz87QjUGo52JiLyBCdOnIAgCOjWrZvR8926dcPly5dx6VLjXpXXXXcdnn/+eXTu3BlPPPEE7r77brz77rsAgJYtWwIAIiIiEBcXp31tTFRUFN5//3106dIFjzzyCLp06YLq6mq88MIL6NSpE2bPng0/Pz9s375d+54XX3wRgwYNQlJSEm699VY89dRT+O9//yvVR2EVtgjJpGVYUyJkbp8wwabp7z5eV/Pbc5ev4N9bTqNrXCiC/fjjJiKyVVBQECorK2W7tlSautmani8DBw7UOz9w4EAsWbJEdL3du3eHl87zJzY2FikpKdrX3t7eaNGiBQoLC7XH/ve//2HJkiU4efIkKisr0dDQgLCwMNHXtgefjDJpGiNkqmts1+liPPHNPrx2e4rR8+b6i328DZOngrJadGgp7scttkuOiMidqVQqq7un5NSxY0eoVCpkZ2dj3LhxBuePHj2KyMhIREdHm6zDlj/CfX19DeowdkyjaZzZvGvXLtx3332YO3cuRo0ahfDwcHz77bd4++23RV/bHuwak0nLUPNdYxP/8ycuVdRiypdZov9BenOMEBGRx2rRogVGjBiBZcuW4cqVK3rnCgoK8NVXX2H8+PHaZ8uuXbv0yuzatQtdu3bVvvb19YVabXmpF7G2b9+Otm3bYs6cOejXrx86deqEs2fPSn4dS5gIyaRpjNDunBIs33wK6w8X6J2vV19t8bE2rVm97zwe/nS3ybWJOEqIiMgzLF26FLW1tRg1ahS2bt2KvLw8rF27FiNGjEDr1q0xf/58bdnt27fjzTffxPHjx5Geno7vvvsO06dP155PSkrCxo0bUVBQgMuXL0sWY8eOHZGbm4tvv/0Wp06dwvvvv49Vq1ZJVr+1mAjJJPbvMUIA8Mbao3j8iyz8548c3L70D2w7cUmvrLWDpWes3I9Nxy5hz1nDf6iCDWkQ1w4iInJNnTp1wp49e9ChQweMHz8eHTp0wOOPP45hw4Zh586diIqK0pZ96qmnkJWVhT59+uC1117D22+/jVGjRmnPv/3228jIyEBiYiL69OkjWYy33347Zs6ciWnTpqF3797YsWMHXnrpJcnqt5ZK4K6cZjVNny8rK5N8AFfS879aVe6VW5Mx9+dsAMCZRWMBNK4e3WnOb1Zf69nRXdCxZQge/yJLrx5zsXz7+LW478PGJtMXx3bDY9e3t/p6RESurqamBjk5OWjXrh0CAgLkDschkpKSMGPGDMyYMUPuUGxi7mdk7fObLUIy+vbxa60qZ6xhxpb0lRkvERGRPiZCMrq2fQuDlhljpNpBnoiIiPRx+rwJ6enpSE9Pd8hI+ebOLBprtpvM+BghG8b8iH6HcZW1Dahv0CAy2E+iGomISA5nzpyROwTZsUXIhLS0NGRnZyMzM9Mp17OmZcheYlMnU4lTyivr0Oe1DFTVNtgbEhGR4nEorXJJ8bNhIqQgG2bdYPT45zv111VoUGtQ26BxRkhm5RRVyR0CEZHDNO2rVVdXJ3MkZEp1dTUAw8UcxWDXmIJ0jAk1evxkof6S7sPf2YIzxdWi6hYE/RaenKIqtIt27gqpgiBgzcECdG0Vig4t5dm4kIjIWj4+PggKCsKlS5fg6+urt30EyUsQBFRXV6OwsBARERFmN4O1hImQCxKbBAHA4nXHkDasg/b1sLc2W+yOk3qQ9oYjhUj7ei8A53QFEhHZQ6VSoVWrVsjJyZFlxWOyrGkzWHswEVKYg6+ORI9X15s8X1FTb3Pd6ZtO2fxeKezPk25FUiIiZ/Dz80OnTp3YPaZAvr6+drUENWEipDChAeb7Oe/99y6z58WwdXf7JmLfyvGGROSKvLy83HZBReJgaZdzJL9csrqaVplWa4xnKFy+iIiI3B0TIQVafHdPp1wnI/siNh0rRPLLay2WLa9pwPdZ5zDq3a1OiIyIiMg52DWmQHf1TcAz/zvglGs9/Kl16yS9v/GE3ddizxgRESkNW4QUyMvLdfqkTlys4HpCRETkstgiRCZdKL1i9nxlTQPG/707/ekFN1tM4DhYmoiIlIYtQgo1vl+i3CFg+rf7zZ4vqrw6nVTNLIeIiFwQEyGFevW27nKHQERE5PaYCJmQnp6O5ORk9O/fX5brB/rZv0gUERERmcdEyARn7z7vCQTOGyMiIoVhIkQ244KLRETk6pgIKdgj17WTOwSzftp/Qe4QiIiI7MJESMEmDmwrdwhmrT1cIO4N7BkjIiKFYSKkYG2jguQOwa19tPU0RryzBUWVtXKHQkREMmEipGCutMK0K5q/5ghOFFbiXxJsH0JERK6JiRBJwpXXU6xTu3DwRERkFyZCCpfcKkzuECTDdIOIiJSGiZDCrU67Tu4QFONIfjneXHsUFTX1codCRERugomQwvn5uMaPSKrFEi9X1eGhT3fjlwOGU/PHvLcNyzafwoI1RyS5FhERkWs8ZcktCFYMJHon4zg2H7uEaV/vM1nm8IVyKcMiIiIPxkSIFKWkus5yISIiIokwEXIBA9u3kDsESUg1s0zqRQW4VQgRkediIuQC3r+/DwZ1UHYy5MrT5105diIisg8TIRfQMtQfX//jWrnDcA4XTUp2nS7G7B8OoJwz2oiIXIqP3AEQyU2KrrH7PtwFAPD19sK821Psr5CIiJyCLULkNC7a2CPK2eJquUMgIiIRmAgRERGRx2Ii5EKeHd1F7hAcjzO4iIjIiZgImZCeno7k5GT0799f7lC0hnWJkTsEk6yZeWXV7CxrynC+OxERSYSJkAlpaWnIzs5GZmam3KFoxYT6yx2CQ5RUcRFFIiKSBxMhF9IixDUToQulV/DJHzmorDWcWp6+6ST6vpaBz3accX5gDuAJA8KJiNwJp8+7GC8VoHGxp+0dy7bjYnmt0XOL1x0DALzy02FMHpTkxKiIiIjYIuRyfpt+g9whGGVu93lTSZCtlDxCSMmxERGRISZCLqZLXKjcIZAZLtZYR0Tk8ZgIkaKYa1kSQ6MRsOt0MSqs2PKCrThERJ6LiRBJQhAakw+NQgYwfZOZi/s+3IW7lu+wWFbKiJlUERG5FiZCJAkBwLhl23HLv/6wOhmqqVcb1iNRVrJ633kAwPGLldJUaCVlpIFERGQtJkIu6K17eskdgoGyK/U4cK4M2fnlKKpqHBxdXFmLf285ZbJ815fWOiweqRIqIiJyb0yEXNDolDi5QzCg2yXUlIQ88c0+LPztqNHyO04WOT4oK0nZncWuMSIi18JEyAWF+Ctv+SfdXS82HyuEIAjYcarYZHlTDTbWtORYs8MGd+EgIiJrKO+JSi5JpdMW8tz3BxEVLO8q2HJ1jSm9R666rgFeKhUCfL3lDoWISBHYIuSi5t3eXe4QzNpppjWI5FFTr0byy+vQ7/UNcodCRKQYTIRc1KSBSXKHoKeoUn/1aFvXA5JqHSG5KLlH7kxxFQCgsrZB5kiIiJSDiRBJYtInu/VeO7JrSsnJhmuncUREnoeJEEmipKpO7/UKC7vJm0qUrEmgmGwQEZFUmAi5sGUT+sodAjWj5NYqIiIyxETIhXnqBqxKTjaU3FrFRSaJiAwxEXJhHVqGyB2C5OR4VnvimkOCE7IiZ1yDiMheTIRc3JePDsCNXWPkDoP+5oE5lVG1DWrc9M4WPPHNPrlDISIyi4mQixvcKRqfPNRf7jBEMzVNvrJGmqndYtoipGy4YBtIo23Hi3D6UhV+/uuC3KEQEZnFRIhkUVpdb/T4ztOWF2JUeWJflsTYa0VE1IiJEMnixdWH5A5Bi3kVEZHnYiJE5IJyi6vx+Od7kHX2styhGMUGJyJyFUyEiFzQ1K+zsD77Iu5avsOm9zNRISJqxESIXA57soCzxdVyh0BE5BaYCBF5IK7xQ0TUiImQm3hxbDe5Q5BE3zYRcofgGpjHEBFJwiMSoTvuuAORkZG4++675Q7FYR4d3E7uECThxSlcVrElD2IjEBGRIY9IhJ588kl8/vnncofhUFxbR5+7df1crqpDdZ00i00CbFAiImriEYnQsGHDEBrq/huU/jb9erlDIAcou1KPPq9loNfc9XbV48xc2d0SUSJyX7InQlu3bsWtt96K+Ph4qFQqrF692qDMsmXL0K5dOwQEBCA1NRXbtm1zfqAuoFurMLlDcIo9Zy/jxrc3S7aGjkrh89AOXygDANSrryYXtiQazE2IiAzJnghVVVWhV69eWLp0qdHzK1euxIwZMzBnzhzs27cP119/PcaMGYPc3FxtmdTUVKSkpBh8Xbggfp+j2tpalJeX632R8py+VIUHP/5T7jBcFpMiIqJGPnIHMGbMGIwZM8bk+XfeeQePPvooHnvsMQDAkiVLsG7dOixfvhwLFy4EAGRlZUkWz8KFCzF37lzJ6iPHuVKvNnlOzJgpUxvAKpnrRUxEpEyytwiZU1dXh6ysLIwcOVLv+MiRI7Fjh20r6loye/ZslJWVab/y8vIcch0yTqoHvJLGqOSVVGPJhuMoqaqTOxQiImpG9hYhc4qKiqBWqxEbG6t3PDY2FgUFBVbXM2rUKOzduxdVVVVISEjAqlWr0L9/f6Nl/f394e/vb1fc5FocPUbong92oqC8BvvzSrHi4WskqdPePM8VW8GIiBxB0YlQk+bdHIIgiOr6WLdundQhKda0YR2xdNNJucOwyY/7z8sdgkMUlNcAAHaeKpY5EiIiak7RXWPR0dHw9vY2aP0pLCw0aCWiRk+P6iJ3CDZbsOaI3CGI8p8/crBkw3GHX8dYi5UtLTrObAViexMRuQpFJ0J+fn5ITU1FRkaG3vGMjAwMGjTIoddOT09HcnKyyS40JfvX/X3kDsHtCYKA137JxpINJzDxP3/qHZf8WkbSCru7xpipEBEBUEAiVFlZif3792P//v0AgJycHOzfv187PX7WrFn4+OOP8cknn+DIkSOYOXMmcnNzMWXKFIfGlZaWhuzsbGRmZjr0Oo5wa694zBrRWe4wRFP6ej66dBOJbSeK5AtEBFf6fJVMEAT8djAfeSXVcodCRBKQfYzQnj17MGzYMO3rWbNmAQAmT56MFStWYPz48SguLsa8efOQn5+PlJQUrFmzBm3btpUrZJfgxWeeTd7bcAK/HLiA/00ZhPAgX7nDIQX69WA+pn29DwBwZtFYmaMhInvJnggNHTrUYnfC1KlTMXXqVCdFRHJRwnZp7/495uc/23PMtqo5omfp851n0CYqCEO7xFgsy54t+ezOKZE7BCKSkOyJEDmGq27CqpT1f+rVGqde76+8Urz842EAjmtl4JR5aWgU8m+UiKQh+xghcozBHaPlDkG0/LIa7M0tlaQuex9V+3LN72Nm015fZs7ll10xOKbWmHmHyMtrmtXFZzkRUSMmQia48qwxAOiVGCF3CC5t12nz3R+OziNe/yUbveaux7nL1XZPn39z7VFcs2ADLv69nhHZh0kkkXthImSCK88acxe1DWq8/ks2tp907KwsJfQiNn+4fvxHDiprG7Bs8ym76162+RSKKuvwr9+dt9CmOycL5hrqiMj1MBEixVqx/Qw+/iMHExy8y7yxh/b917QR/R67YjBxXK12zFOX44Xswc+OyJ0wESLFypVxnRZfb+mbiWypsV5jfNC2LYmYM1sylNDKRkRkDSZC5PFseWg7q0VFypYnZ87Ic+euMSJyLzYlQqdOncKLL76I+++/H4WFhQCAtWvX4vDhw5IGR/Z56ZZkuUNwWZ/vPIujBeUmz0veNSayPlsur3sNJipERI1EJ0JbtmxBjx498Oeff+KHH35AZWUlAODAgQN45ZVXJA9QLq4+awwARnRz7Y1pxbTUvP5LNm58azMqaxsku/7oJdskqwsAahtMr03kjBYmjgsiIjIkOhF6/vnn8frrryMjIwN+fn7a48OGDcPOnTslDU5O7jBrrE2LILlDsIuYVouP/8jB6aIq/Dczz3EBOZAzWmhMDDciIvJoohOhgwcP4o477jA43rJlSxQXF0sSFEknbVgHuUOQxJK/t76wxFNW/bV3QUdntD8REbkC0YlQREQE8vPzDY7v27cPrVu3liQoks4TN3aSOwSbHbpwdYzOkg0nZIzEkLPyLVMJj21jhJicEBE1JzoReuCBB/Dcc8+hoKAAKpUKGo0G27dvx9NPP41JkyY5IkayQ4Cvt9wh2OyvvFK5QzBJ6vE21tbWlMzYm9M4Oikqu1Lv0PqJiKQiOhGaP38+2rRpg9atW6OyshLJycm44YYbMGjQILz44ouOiJHIatxs1tw1HH4JrUW/HXXexZyMDWtE7kX07vO+vr746quvMG/ePOzbtw8ajQZ9+vRBp06u2wXj7lQq/vKWmjM/T93cThBsX6xQ7cSgL1ezRYiIXIPoRKhJhw4d0KGDewzEdXdrnrweY96Tdio4uTbmxUREjUQnQo888ojZ85988onNwShJeno60tPToVar5Q7Fbt1ahckdgtPY0lhiy3tcMZFwzU5DIiLHEp0IXb58We91fX09Dh06hNLSUtx4442SBSa3tLQ0pKWloby8HOHh4XKHQ1bKPFOCRwa3E/UeJczAMlVd88OumIARESmZ6ERo1apVBsc0Gg2mTp2K9u3bSxIUSS8xKhB5JVfkDsPhfjtUgJyiKrnDUDx3GjN2rKAC/956CjNu6uzyi4gSkfNJsumql5cXZs6ciXfffVeK6sgBQvx95Q7BaU5crBBVXgldY9ZOx+daQIbuXLYdP+w9j0c+c91V4IlIPjYPlm7u1KlTaGiQbp8nkpYnPUCXbjqJA+fK5A5DFA/68Uiuqq5xHN/JwkqnXI8/KyL3IjoRmjVrlt5rQRCQn5+PX3/9FZMnT5YsMJKWJ/3ydkYSJNfnKdllPejfAxGROaIToX379um99vLyQsuWLfH2229bnFFG8uHO4xJz5jpCupe147ouutYkEZFDiU6ENm3a5Ig4yMFGd4/D8Ysn5Q6DTLA2wWFCS0QkLUkGS5PyTXPhzVeVyFl7jTmqC44JFRFRI6tahPr06WP1Hk579+61KyClcKcFFQHAz8cL/ZMikXnmsuXCZJGlBOX0pUosWHMEacM6WlmftbPGrCpmlIpLKhIRGbAqERo3bpyDw1AeLqhI9vjH53tw6lIVNhwptLsuR2wk60mD54mIzLEqEXrllVccHQc5gVrDp59ULH2SUi5e2XzTVZIXuxWJ3AvHCHkQNX9/O4/IRhxrfzTu+hDeeOQiThaKWwiTiEgKohMhtVqNt956C9dccw3i4uIQFRWl90XK9fCgJLlDUCRbup5cfYFKJUWfdbYEj362B8Pf2Sp3KETkgUQnQnPnzsU777yDe++9F2VlZZg1axbuvPNOeHl54dVXX3VAiCSV23vHI2PmDTj++hi5Q1EUW5IayRMJazdddcN1hA5fKJc7BCLyYKIToa+++gofffQRnn76afj4+OD+++/Hxx9/jJdffhm7du1yRIwkEZVKhU6xofDzYY+oo0mZc+gtqChhvUrh4o1rROTiRD8RCwoK0KNHDwBASEgIysoatzO45ZZb8Ouvv0obHZET2NY1Jm0M5sb+6A+WlubCrt61R0QkFdGJUEJCAvLz8wEAHTt2xPr16wEAmZmZ8Pf3lzY6Ihfj6PxCjvRlZWYu5v2c7bDkiUkZEclJdCJ0xx13YOPGjQCA6dOn46WXXkKnTp0wadIk7jVGHsPS7C2xjUxKzgWe+/4gPtmegx2niuUOhYhIcqL3Glu0aJH2+7vvvhuJiYnYvn07OnbsiNtuu03S4IgUy0TiYuuAZKunz0uUMNlSTfmVemkuLgG1RsCF0itIjAqSOxQicnGiE6Hq6moEBV395TNgwAAMGDBA0qCUwN222CDnkHzskCBAb7i0gluOnGnGyv34+a8LWDK+t9OvreTWOyIST3TXWExMDB588EGsW7cOGo3GETEpQlpaGrKzs5GZmSl3KKRAlp6FUu7rpTdY2g0zIVvu6Oe/LgAA0jedlDYYIvI4ohOhzz//HLW1tbjjjjsQHx+P6dOnM1lwQSsfvxbtooPlDsPtNCUtjhojZE9rhO57balHiesQqdk8Q0R2Ep0I3Xnnnfjuu+9w8eJFLFy4EEeOHMGgQYPQuXNnzJs3zxExkgMMaN8C8+9I0b5+5Lp2eG50Vxkjci2mnr+2PpfdsaXHWvbkMhrun0dEdrJ5Zb3Q0FA8/PDDWL9+Pf766y8EBwdj7ty5UsZGTtQuOgixYVz+wFpSJy5WtwhJdT03SbzYIkRE9rI5EaqpqcF///tfjBs3Dn379kVxcTGefvppKWMjB2sdEaj9no8T88qq6/F/X+zB2kMFVpUX24tUWdtgVV3uuOaOPXekO0wxPNDX7liIyPOInjW2fv16fPXVV1i9ejW8vb1x9913Y926dRgyZIgj4iMHattCf4yQGz5jJfPuhuNYd/gi1h2+iDOLxkr+WS367ahV5ey5bE2D+82A1Oj8IJgIEZEtRCdC48aNw9ixY/HZZ59h7Nix8PXlLx93IAie2yq0YscZtAj2wxM3dTJZ5lJlrRMjukrKTVfPFlebrthFaWTI3t3koyOiv4lOhAoKChAWFuaIWEhGgiCY7XZZ8XB/PPSp+84OfDvjuNlEqPnTz+L0eQmnWLn6g1cQBEk/D126Y6WVOKuNiJRP9BghJkHuKTLYD6EBplv3hnaJQZfYUCdGpGzOHKujN+3dBdMiSx+VPZ8lu3OJyF6iW4TIvbw+LgV7cy9jbI9WFv9qP3axwklRWSfA1+ax/q5Lxi02xA8Bb5SdX46U1uE2vZeIyNGYCHm4B69tiwevbSt3GIrXvCXGUkuEtL00gpHvXEdtg3NWoGfPGBHZwgP/pCZb/TB1kNwheDx2BRERScvmROjkyZNYt24drly5AsA91zchfX3bRModgp6aeg1eXH0Qpy5Vyh2KIamaJwT95KdWoinw7vPf1W1uhIhkIjoRKi4uxvDhw9G5c2fcfPPNyM/PBwA89thjeOqppyQPUC7p6elITk5G//795Q7FqV67vbvcIYjy5a5c3LV8h8OvU1pdr/famYmE7qVeWHXQeReWiCNnc7lPQkdEchGdCM2cORM+Pj7Izc1FUFCQ9vj48eOxdu1aSYOTk6fuPj9hgOuNF2qepDhCflmNqPKOevZvP1nsoJotszWhsfQ2JjNEJCfRidD69evxxhtvICEhQe94p06dcPbsWckCI3l4ebnvkNMN2Rcx5r1tOFpQLvq9zbt+nTmN3RGJgrn4Nx8rxP99sQdFMi0iqXRM3Ijci+hEqKqqSq8lqElRURH8/blpJynXY5/vwZH8ckz9cq/DryXpgop2rbMj/r0PfZqJdYcv4rVfsm2+rhjGkrLymnrsPFUsanf55p95aXUdDl8oszs+InJvohOhG264AZ9//rn2tUqlgkajweLFizFs2DBJgyNyBHMbnJpi7VYXTQ91paxyrBvnte2jRL23sFyaFiFLSaGxz/Lu5Ttw/0e78NWf5luZzaVJAxZsxNj3/8De3MtWRElEnkr0OkKLFy/G0KFDsWfPHtTV1eHZZ5/F4cOHUVJSgu3btzsiRlKQ9Af6YsWOHGSecd2HixRJiqkHsEryFYTs64TT3YvLW6fb05qGIqmSOUvVnL5UZXDs+MXGmYAv/XgYEwcm2XTdpvWLthy7pLgZj0SkHKJbhJKTk3HgwAFcc801GDFiBKqqqnDnnXdi37596NChgyNiJCdrFR5g8tzYnq3w3RSuJ2SJQhqE9JIosUmaZImQhXoadLq/jHXlHThXKk0gRERG2LSydFxcHObOnSt1LKQQU4Z0wCs/HZY7DIeRotVGrr3GxDK1O7s1VTb/nJyR3GkEwLvZhfJKrqBnQoTR8ly/jIjsJbpFqF27dnjppZdw7NgxR8RDCvDgtW2xbEJfucNQNGc+fu3pHLMnT5BjnJMjEhumSkRkjuhE6IknnsDatWvRrVs3pKamYsmSJdpFFck9eHupcHOPVjg0dxQev6E99r40wqCMjwtPs7flAW/t87mpbilnjUlFgSEZEDFJzICzbs+ZSycQkeOJToRmzZqFzMxMHD16FLfccguWL1+ONm3aYOTIkXqzycj1hfj74IWbuyEq2M/g3P/+6VnjhGTddNURXWNWZHZSJXNeIuoxlmTYnXiw+4yIzLB5r7HOnTtj7ty5OHbsGLZt24ZLly7h4YcfljI2UrDeiRFyh2AzsatEuzLdHEBsYuOsFhbdsMTmLHKkOFLPDCQiedk0WLrJ7t278fXXX2PlypUoKyvD3XffLVVcRApn/hEsVTeUINj3sNdtERIbkrO60nQvY6oFS9eF0iva76vrdDahNRGv1MkSu8aI3IvoFqHjx4/jlVdeQadOnXDdddchOzsbixYtwsWLF7Fy5UpHxEikKIIgWNFyYfypvDIzF7enb8fvRy+KuJ71sRm814465Wj3MBZX8xYYte5AIuYkRGQn0S1CXbt2Rb9+/ZCWlob77rsPcXFxjoiLSFGkGmby3PeNu8c/smIPziwaK02lZgiaq9+LbeGRaoyQmGqMtQjZ2wLDIUJEZI7oFqGjR49i9+7dmDFjBpMgDzf9pk5yhyAbS89WsTnELT1bmbmWHdPnzby3qLIWi347ijNFhis7A4YtQo6aCac3RsjI+ctVdQ65LhERYEMi1LlzZ0fEQS5o5gj+W5BKoK+39nt1sznkzVs0xCQGulU1T2NmrtyPD7acwu3pxrfGkSrvCdC5N0t0W7Ca5F2+YniwqbwVSaLkY3rYwkTkVqzqGouKisLx48cRHR2NyMhIs38ZlpSUSBYckVI5srtl24lLZs+X19RbXZe5afJ7/t4vruyK8foqasRvTmuMpenzumOArBksLRa7xojIHKsSoXfffRehoaHa75W4WByRM1lqZbDnf0hdw9VmEXtnjdnz3j9znP9HjbF4rf0sTZWTPA/irz8it2JVIjR58mTt9w899JCjYiFSrHNmumeMsedvBSkf3LotLLr1OrOVRMy2GcYHS5ur25rrW31567CFicitiB4j5O3tjcLCQoPjxcXF8Pa2fiyA0qWnpyM5ORn9+/eXOxSSWfaFcr3XgiDtw7VercF3WedMnrdr/y0J43RUQ4hesmYkXnP374iuNCLyLKITIVO/lGpra+HnZ7gVg6tKS0tDdnY2MjMz5Q5F0YZ2aSl3CDZ5+NPdVpc9UVghun4xqw9bGhPU/H+cmLr1ltzRW37HeQmEpSs5uuuPCyASkTlWryP0/vvvA2icQvvxxx8jJCREe06tVmPr1q3o2rWr9BGSon0yuT/av7BG7jBE23TMfPJhicW9xsSsnWNkppT2OnbuvaVbVmw60PweHJVO6HffGV7F3JhENggRkb2sToTeffddAI0tQh988IFeN5ifnx+SkpLwwQcfSB8hKZqXC+9Cby1jD2KntjLYtemqTjU6WcNuKwZC39e/jd5rh/2kmcwQkYysToRycnIAAMOGDcMPP/yAyMhIhwVF5Ema5wHNWznsSbpq6tVGj288YjjOr7kAX/2ec1ujsNRqI5h80fR+6658sbzW6piIiJqI3mJj06ZNjoiDyKVY7Bpz4LXFjBFacyDf5utYWv9HKnYNBtdRWSvNukdE5FlED5a+++67sWjRIoPjixcvxj333CNJUERSyzGxjYQlH2w5hSe/2ad3zNxj2xFrbNmTJzTo9I05c7B0TKi/zivz1xJMfK9UrhAjEVlPdCK0ZcsWjB1ruFnk6NGjsXXrVkmCIpLaHyeLbHrfot+O2vQ+ORcdFQRBuyijPbvP2+O+/olWl9VL0JhlEJGTiU6EKisrjU6T9/X1RXl5uZF3ECmAxE9YS9WdLxW3AKM912pu6ld70e3ltSisqNGvx44ZZGJ5e1n/q4VrARGRnEQnQikpKVi5cqXB8W+//RbJycmSBEXk2QQzryz77VAB1BoB32ed18ui7M03/vH5Hsz/NduqsnpJl4jB0lzzh4icTfRg6Zdeegl33XUXTp06hRtvvBEAsHHjRnzzzTf47rvvJA+QSImkfGBLNVjYoF4IiAy+2norRRfUR9tyMGestH/wJLUIkrQ+IiIxRCdCt912G1avXo0FCxbgf//7HwIDA9GzZ09s2LABQ4YMcUSMRB6rcTsP2xOlvm2uLnMhOHFYsv7AbPN6JkQYfV+TmnozK04SEdlJdCIEAGPHjjU6YJpIqSTfd9M11lPUr8cFep2MhXil2VpIct+Ho1rwiEgeoscIAUBpaSk+/vhjvPDCCygpaVyhdu/evTh//rykwZFrGOai+43ZShAcO5JFqu07BEG+qd5irmvpfn2arV7OcUREJCXRidCBAwfQuXNnvPHGG1i8eDFKS0sBAKtWrcLs2bOljo9cwJt398JDg5LkDsMtaYzsdG9rg4Tu2zTObNEScS1jrS3NlyIwVd/1naLFhGUzOZdGICLpiU6EZs2ahYceeggnTpxAQECA9viYMWO4jpCHahnqj1dv6y53GE5lqntE6kdkvdq+8TGCmME6UhKVrYnbn95UaVdbCZuIlEF0IpSZmYn/+7//MzjeunVrFBQUSBIUkdSkfnZJWZ3lumy/mukFFZX5MFdoWETkxkQnQgEBAUYXTjx27BhatvSssSLkOqzZbV0pLG3CKqbh49D5Mp16LWcZ9rZAXb2W7vcWttiwtM6QQdegidY4iRqEqmobcLG8xnJBInILohOh22+/HfPmzUN9fT2Axv7y3NxcPP/887jrrrskD5BICr8etH3zUWOkbLlo/vyWcqXll388rP3eml6yb3bnSnZta4m9W0c3GqW+noEBCzYyGSLyEKITobfeeguXLl1CTEwMrly5giFDhqBjx44IDQ3F/PnzHREjkV1qmk2/tpfkU/Gbv27eAuKA65jKtc4UVUtzLRsXb7SmrKO7z5rWLdpz5rLx6zv28kTkZKLXEQoLC8Mff/yB33//HXv37oVGo0Hfvn0xfPhwR8RHLmTFw/3x0KeZcodhYMCCjQ6oVfmPw+ZdSGLHBTVfv8dRxHaNOeuz5zR9Is9g04KKAHDjjTdqt9ggAoChXWKQ0joMh84ra/Pdsiv1ktdp6uGtUgEN9s70svJa9tRrTZVf/5mL+eNSbLyWbXucWZN8mPzsrb+MXTh5nsi9WJUIvf/++3j88ccREBCA999/32zZkJAQdO/eHQMGDJAkQHItt/SMV1wi5Gyr9tm3sKhBS44DWiasfZirnbDgkKWkSWktM8qKhojsZVUi9O6772LChAkICAjAu+++a7ZsbW0tCgsLMXPmTCxevFiSIMl1RAT6yh2CU5h7GBZW1NpXt4UnrbVjnswtxOjoJXccOY6HiQgRScmqRCgnJ8fo96ZkZGTggQceYCLkgQL9vOUOweU1bwHZkH1R7/WnO87YWK88xEyfN1bS2pW1pV7xmWsaEXkGm/Yas2Tw4MF48cUXHVE1kSI48yG5ev8FvdcllXV21+noVZgduheb2NqZ0BCRGTYlQhs3bsQtt9yCDh06oGPHjrjllluwYcMG7fnAwEBMnz5dsiDJdYQG2Dz+3mUIgukZWJuPXcJ//rDcatq8Pl0aC2Otvcz8r9VdENFwstXVI17WbtxqXTHzdViaFaZX1rCwowaPW8L8icgziE6Eli5ditGjRyM0NBTTp0/Hk08+ibCwMNx8881YunSpI2IkFzK0c4zcIdhs4n/+tKqcpRaJkir7WmwsPYBVZoY6/9Ss9ch0vSqrxgnZvMGrBBvDSl03EZExov98X7hwId59911MmzZNe+zJJ5/Eddddh/nz5+sdJ8/j5aXCY4Pb4WORrSJKsO1EkdVlpXgWF5bXICYswOC4PStLl9eYXirAlsHSzpixZWl9I2s/Dk5rJyJbiG4RKi8vx+jRow2Ojxw50ugeZHLLy8vD0KFDkZycjJ49e+K7776TOyS398dJ6xMKVyRVi0SdRPt6bT9ZhMc+y0R+2RVcKL2iPV5V26BXTjep8fOx7r++7S07tr3RqpWlnbWgoolg2CJF5F5EtwjddtttWLVqFZ555hm94z/++CNuvfVWyQKTio+PD5YsWYLevXujsLAQffv2xc0334zg4GC5Q3Nbjh6IqwSOfBjqrt3TYGnAEIAJHzd26dWpD2Lr8Usmy+nGPKJbLDYdLbQ9SCfy9db/9yR3IuKMtZWIyHmsXlCxSbdu3TB//nxs3rwZAwcOBADs2rUL27dvx1NPPeWYKO3QqlUrtGrVCgAQExODqKgolJSUMBFyIHODed2BIEjTKmFqundlzdWWnGIRM8Qullm/SaiPt8qx+3rZuNeYsU7H/klRNgbhGFJv4EtE8rJ6QUVdkZGRyM7ORnZ2tvZYREQEPvnkE9HT5rdu3YrFixcjKysL+fn5WLVqFcaNG6dXZtmyZVi8eDHy8/PRvXt3LFmyBNdff72o6wDAnj17oNFokJiYKPq9ZD1vD2gRklJptX6yY+v2FJbYUpdzxggZ/75J839OcrcIEZF7Eb2gotSqqqrQq1cvPPzww7jrrrsMzq9cuRIzZszAsmXLcN111+Hf//43xowZg+zsbLRp0wYAkJqaitpaw9V8169fj/j4eABAcXExJk2ahI8//thsPLW1tXp1KXHck9LVqd37SSVAkHRudWWzsTwG15KIwTR0I3UXVer/P5Ji9pe99xDgq79Ip9K23CAi12bzoi9FRUVQqVRo0aKFXQGMGTMGY8aMMXn+nXfewaOPPorHHnsMALBkyRKsW7cOy5cvx8KFCwEAWVlZZq9RW1uLO+64A7Nnz8agQYPMll24cCHmzp0r8i5I15miKrlDcKjfDhagVbjhbC9bNU82dKfHGxuOYioRMGg5EXHNJtV1zQdYO55eC5iR8/ERgVbVo3v/lmaiERE1ETWao7S0FGlpaYiOjkZsbCxiYmIQHR2NadOmobS0VPLg6urqkJWVhZEjR+odHzlyJHbs2GFVHYIg4KGHHsKNN96IiRMnWiw/e/ZslJWVab/y8vJsit2TuXvP2FPf/SVpgmBuunxUkJ/V9RhuRSFYeG1NnbbO/nJcImJN1TNX7nfY9YnIvVjdIlRSUoKBAwfi/PnzmDBhArp16wZBEHDkyBGsWLECGzduxI4dOxAZGSlZcEVFRVCr1YiNjdU7Hhsbi4KCAqvq2L59O1auXImePXti9erVAIAvvvgCPXr0MFre398f/v7+dsVN7k+K53xTvqg2s9t8ZLBzN7E1SKYcUKe580Z3nzf4fEy5moE335aEiMgUqxOhefPmwc/PD6dOnTJITObNm4eRI0di3rx5Fnent0Xz2TWCIFi9weLgwYOhsWIKMklncMdorG+2USiZZrDFhoXEwdTK0pYGFTff3NToBqfNX9v4X8eR6w85q9uLvWtEnsHqrrHVq1fjrbfeMkiCACAuLg5vvvkmVq1aJWlw0dHR8Pb2Nmj9KSwsNBoHKcPgTtFyh+BwUgzY3Zt7ubGuZk9ce1aW1nXqUqXea7kGGVu6qtjbFXsXtq8AwEyIyBNYnQg1TV03JSUlxeruKmv5+fkhNTUVGRkZesczMjIsDnq2V3p6OpKTk9G/f3+HXscd8S9p60z7eh8AICEySO+4xa4iKx/QpVdMb7fxd0WGh8x004lhc/LhyLWNiIiMsLprLDo6GmfOnEFCQoLR8zk5OTbNIKusrMTJkyf16tm/fz+ioqLQpk0bzJo1CxMnTkS/fv0wcOBAfPjhh8jNzcWUKVNEX0uMtLQ0pKWloby8HOHh4Q69lruJCHLuuBY5SPkwbh1p3ayoJro9vSH+Pian35vtGrPyBqTYdNXiXmK2XYKISBJWJ0KjR4/GnDlzkJGRAT8//ZkstbW1eOmll4zuQWbJnj17MGzYMO3rWbNmAQAmT56MFStWYPz48SguLsa8efOQn5+PlJQUrFmzBm3bthV9LXKOIZ1byh2Cw12utm+HeXM0FgYJWdtKExqg/9/bmnWEDK9lvcMXyhAd4o9YIxvJWst4C5h1Ubn7bEUicgyrE6G5c+eiX79+6NSpE9LS0tC1a1cAQHZ2NpYtW4ba2lp88cUXogMYOnSoxb8Yp06diqlTp4qum+Rh7UB2Vzb92/0Oq9vSYGlrW2maJyTWtAI1L2HteKXTlyox9v0/AABnFo0V1aWmG5d1g6Wtrtou7IIj8gxWJ0IJCQnYuXMnpk6ditmzZ2t/ealUKowYMQJLly7l1hVk0YB2Ufgzp0TuMBSledpoKRnQTZTMpZxipq2b8tov2ZYLAdifV2r6OlbVYD3mJ0QkJVErS7dr1w6//fYbLl++jBMnTgAAOnbsiKgoZW2KSPLy8zY9Bt8TdqYXq/lHYqlFSKPXgmKa9evv6L5H//WPVq7HY248ksX3inwfW2qISEo2bbERGRmJa665RupYFCU9PR3p6elQq9Vyh+JyAv28seCOHmjQaPD2+uMo05m9xDzIChae9PVq6xb3MajFAYslWhWHnReytGJ2E/7TIiJbiNpiw5OkpaUhOzsbmZmZcofikh4Y0AaTBiYZHGciZIz+h6LbImTskb8vt/TqeRFZhjUtL833GrNF+qaTWLHjjPVvcPA6Qray5qOtqecfSkSujokQOVTzwbamVkWmqywNUNadLl9VZ/pBbHmvMcPrZJ65bE2IZi1ed6x5JFa/157WIzl6zDYfuyTDVYlISkyEyKEMdlZnHmRAzK7xzbUINr0pq6WxRkohdtFGjhEiIikxESKHWv5gX/h6X33Se8LUentJtcVGc4brCCmP8aTIutWupf7YlPj5EJH0mAiRQ13fqSWOzLu60CbTIEMGn4mIJ7BuXmmwOXHzavXGHjnvMW/vNH6D8ybLS3tPztrclYjkxUTIBO41Jh0fnen0UWa6cqiRuBYh06mlv4/+f+/myY9SnvOWBnFbmwftPFUsUURE5EmYCJnAWWPSWvpAHwzq0AKzb+4qdyiKZ+vYnuYtGDd2jZEgGvuJ2X3eaMfY3wcPnivDx9tOo8HEB2Rq4DhbdojIHJvWESIS65ae8bilZ7zBcXObhnqKt9cf13st5rltbsiVV/NB2GZ2tW9Qa/Ra7qxxtrgKMaEBCPTzxhU7ppFb2wJ269LGLTxu6dlKVP22jkszFdU1SVHYfabk77ptqpqIFIQtQiSr9TNvkDsEWZ0vvYI/ThbpHRPTNab7HLb0wDdXralWFlNe/yUbQxZvRreX1wIA3t94wqbrAs27xoxssdrs2NGCCrP1Wdq01momqvHWyTDZ2ETk+pgIESmYpQetlC0SahEJxMd/5Oi9LqyoNVv+Sp0aaw7mo6Km3uCcpa6r5mdPFlaaLf/FrrNmz1vLmQPKiUg+TISIZGRsXzYxY1p0F6g02LzVTDXNz63Pvqht3XGEF1cfwtSv9mLa1/vMxmJujJC1/pd1Tu/1981e24sJEpF7YSJEpDCOWgjRXIL15Df7UNdg3R5mtlz3+72NyciW44YrMettImt01pjIBReblS+uqkP6ppN4+cdDHDhNRAaYCBHJyFg3jrMWVJTKz39Zt0O9KRZvV2Tg1bWGA7cXrzuGz3eexfGLV7vVLHbJmTitf5yJFZGrYyJkAtcRco64sAB0iglBcqswuUORhbFBxqJWERIxRshSF5StnvjGsLtL77omjl8sr4FGIzRL/IwMlhYZz+miKpPnmjZJ/WLnGfR5LQOHzpeZLGvqutZsXktEroOJkAlcR8g5vLxUWDfjBvzyxGC5Q1EMMd03utPWLe1ZplbQU3vzsUIMWLARj3+RpXd81+kSh1636TN66cfDKK2uxzP/OyC+EuV8jEQkASZCJDsvLxW8mi9648FKqup0Xpl/6pZWG87CMuWShZld1vp422kJ6micdbbhyEW9FiHDnesd2+rCMUNExESISGHWHb6o/V7Mczq/rEbvdbWJlZbt9fqvR0SVtzQA2vI6Q9IlK6pmc+vEzKwzFg/TKCLXx0SISOGGd7Nuqwz9liRg0W9HTZZVUkuIpVlyUoZq2H1ounJOkyfyDEyEyOn6tomQOwSXIQCIDvG36b1FldJ0hdmruMowDv2B2+IWVLSHFEmVgnJIIpIAEyFyutiwALlDcCmu/uB9J+O42fMWu8Yk/ADq1NZ3F5ruGrNchohcBxMhcjpuVGk9QWg+vVyieiWv0bQqI5vq6m8AK100zbsHmwsL8NV73XzMkDV042X3GZHrYyJEijF7TFe5Q1AkV3/UWko2LLcIWX+tvq9lmD0f5O+jX7fZMUJE5AmYCJnABRWdr0tcqNwhKI4Ax6007SyWVkawNFj6m925ksUi9SBxF//REBGYCJnEBRUdx8fL+D87FfvMDAiCgx62TnyAN/+5Zp4pwc7TxTqhmA9mffZFs+elUlhRo7/WkokPnrkPkXvxsVyESFrPjemKfXmXMXlgkt5xpkHGuXqLUHP3fLBT77WjNpkVo16twegl21CvtrzxrKO2KiEieTARIqdrHRGIbc/eaHCcDUKGBLh+90vn2BCcL71iuoATb7D5pZrGL1XVNhgMtLZmrzEicn3sGiPFsGUGjydwzKwx5z3Ox/Vpbfa8ElqEbP23p6SFKYnINkyESDFOFFbIHYLiCILg8i1ClihiCrqRPMjk5+7uPxAiD8NEiBTjRGGl3CEokiISBQdSQouQMWztIfIMTIRIMbw5SMgojeXxu6IJAtDVScsVfLL9jNnzh86XOSUOc77bk2d1Wa4sTeRemAiRYhhbb6ZDy2DnB6IggqA/Rqh/UqRkdbcMtW0PM7H+yis1e/6UE1sCjSUueSXVeP3XIwbHCyuM79UmZp80IlI+JkKkGF5GMqHPHrlGhkiUo6K2AZd0Nk8N9DM/0TMswPUmgqplblYpra43enzZ5lNGj7vbcgZEno6JECmGsa6xhMggGSJRjr/ySrEvt1T7WhAEjOoea7K8mEe0Up7nVizdY5W2Laz7t3KmqErvtYn1PU3S3ydN3HuJSHmYCJnALTacT7dFKNTfB3tfGmFzXbNGdJYiJMXZdqIIanOji618MAtQTrdO80HJDVJlRsauBQFD39qsd8zb0h4g5upTxkdIRHZgImQCt9hwPi+dFqFlD/ZFVLCfzXW5YheRtTYcKTR5zhVbhJp3NVXVqR12LWP37CVykL5g4nsick1MhEgxdB+IeSVmViImk8RM+VZKImS2hcvBVCrLm8I2p/sZc4o9ketjIkSKofs8qm1wXKuAO7P2sSwIyukaq6ht0D/gwLCaV320oAK3L90urg5lfGxEJBEmQqQcOpmQUhfZUzoxD2mlPNCbx2HrLDJb70dsV5xuAqmQj5CI7MBEiBRDd6yGhpmQTa7UW/dQP3i+TLEP8ZWZ1i9uKJYU3XACBwkRuRUmQqQYul1jDXY+sPh8Mu+b3bmK/ZDWHMx3WN3D39kiqrxaI6CuQX8Wm4/31V+bkXYM6CciZWAiRIoRGXT1oeLIKdTUSCljhJpTUlwdXliD1NcyUKPT0qY7uDrYz1uGqIhISkyESDFGp8Rpv7e3RYizzixTyhih5pQWV0Vtg95+aPpbbBCRq2MiRIqhu7CdvftgZRwpsDcct7fn7GW5QzBKaYlQc7rLPJx04j5pROQYTIRIMXy8ryZCt/aMt6uumnp2rbkqY3nQ1uOXrHif8zOoV3467PRrEpG03Hf5XXI5MaEBuP+aRHh7qRAe5GtnXf64ZGL3cFI2Y4sUTvpktwyRGKf0FisiEoeJECnKwjt7Ghzr0yZCu/Ho1KEd4Ovthfc2njBbzx19WuPwhXJHhEgeTkmDuYnIfuwaI8Xr0DJE+/2zo7tiphUbqvrYsZEmuSZnDZBnixCRe2EiZAJ3n3c9vjpjjOLCA2SMhNyNSm/Vc2ZCRO6EiZAJ3H1eOcb8Pa3e0kwylc6SjD5e/KftqpSeaCg7OiISi2OESPFu7BqD1WnXoV10sNlyug9QFXvGXJbC8yBmQkRuhokQKZ5KpULvxAiL5XSfT9d1jHZYPORYtuYZIf4+qGy+k70DMA8ici/sPyC3odsiFODLrQ9clbHp89aQYkNVU/RWk1Z8kxURicFEiFxSqL9hYyafT57tis5+YI7Ef2ZE7oWJELmkiQPbGhxLf6CvDJGQ1JSeaCh9MDcRicMxQuQ2xvZsharanmgR4me5MCmXAvMM3cH3zIOI3AtbhMglxUcE6r1eNXUQAODe/om4qVssAOCR69o5PS5yf0yEiNwLEyFySeP7J+KhQUn4aFI/nFk0Fn3aRBqUubZ9lPb7Hq3Dnd511ish3KnXcxfMM4jImZgIkUvy9fbCq7d1x4jkWJNleulMuf/5icEY27OVVXUPaBdluZAVGhw4iwkwPmCcHGftoQIcOl/GWWNEboa/ScltxYYFYOszwxAaIO6fuVTTsB296WuAnzcqnLBujjP1SoxAWXWd3GEYyL5Qjpd+PAwAiAvj9i1E7oQtQuTW2rQIQmSwuMHTY3q0QtqwDg6KSDpuubGsoMy93VfsOKP9XpkREpGtmAiRR/vH9YYDqh8alIRnRnW16v0fTky1qpxU3W26vN0wEVJqinHqUpX2+4vltTJGQkRSYyJEHuWaZglJj4QIgzKmEowWRlqWRnaPs+q6vt7S/1dzx6EqguBa9/V/Q9rLHQIR2YmJEHmU9+7rrff61p6t8P0/B1n13i5xoTZfl5vAWkcjCC61YGFYgK/cIRCRnZgIkUdpFX51/aGIIF+oVCqkto3EwPYtAEBvYHXWi8Mx97bu2tfRIf5m6549xnR3msoBmZCvt/tlV7UNGpRW18sdBhF5ECZC5HHu658IAPhBpyXo638MwIqH++P3p4Zqj7UI8cfkQUkY/PdO9o8MNr5A4/f/HIRnRnXBY9eb7iaxZsq12MHPXm7YzHSysNIpO8hLhVPpiVwfEyHyOIvu6omchTejfcsQ7TGVSoWhXWLQMtSw1eezR67BnheHo7fOukS6UttGIm1YR4OxRWN76K9b9OqtySZjuic1AaumXifiLoBgriMkO+ZBRK6PiRB5JDFdVd5eKm23WNaLw61+X7voYO33ggC0DDW+/kyIvw8W39MLyfFhVtcNAPdf00ZUeTE+ntTPYXU7S6twx6/3wzyIyPUxETIhPT0dycnJ6N+/v9yhkIK0CPHH/pdH4B/Xt8P+l0eYLhfsh0mD2mpf90wIR5e4EKNlm1qSxE6Hzzp72eqyumOdrDHczIrdrsIZA5nZIkTk+pgImZCWlobs7GxkZmbKHQopTESQH+aMTUZEkOF0+g2zhmDasI74/amhCNHpunp0cDt0jAnF148NwIZZN+i95617emm/T4jU30zWlLUzrkeViLE0Xi605lDnWOMJo1jOuGcurkjk+jjIgEhCHWNC8PSoLtrX827vDhUaW5IAYNDfA6916e6XVq/WmKx7ypAO+GDLKQBATGgAEqOsS5p6tA7HdR0aZ8X5+XghOtgPF8pqrHqvHI5frJSkHmekfmwRInJ9bBEicqBJA5MwcWCSwfEvHx2Ati2C8PU/BhiUbzLn5m56554f0xVv3t0Tb97VE1HBfpg8yLBeY3y9VWjfMgS/PzUEmS8Mxxt39xR7G4rTNPPPHGdMqmMeROT62CJEJIPBnaKx5ZlhBscfu74dSqvrMKxLDAZ1jEZiVBD25l5G2rCOAIB7+11NABIig0zWP6RzS2w5fgnA1Yd10yy56zu1lOgu5GPNYPc+bSIcvvFt+RWueUTk6tgiRKQg/j7emDM2WduFNjolDi/c3A3hgcYH/mbPG4WpQzugU4z+uJonb+qk/V6jMWy3iA65Or7JEfugOZo1w3+m39TZ4XHobsZKRK6JiRCRCwvy88Gzo7vif1OuLg7p7dW4WvaM4Z0Q6u+D+Xf0MHjf0yMbxzF1jQvFsK4xRuv+Me06bX29TKyhZEmwn7dN77PEmr3bghx0bSJyL+waI3ID4UG+OPDqSBw6V4ZOsY17os0Y3hlP3NjJ6LT8e/slIiEyCD1ahyM0wAeLfjuqPTfx2sZp/70SI3Bm0VgAja1Kvx7MxxPf7BMVV1Wd2tZbMsvYwpfNiV2OgIg8E1uEiNxEWIAvBnWM1ksSTCUDXl4qDO4UjfAgX3h5qXD0tdGI/3sBwilDOxgtf2uveKtjmXd7d/w8bbB2exJjdBecFGNsz1Z41MR2J7rccQsSIpIeEyEiQoCvN9bNvAG759yE1hGmp+UbG080tmcrfPBgKrJeHI5hXVpi41NDMGlgEnokhOPDSakm62q+BUlzv02/3ujx9Af6IsBXv9urTZT+wPHkVmHw83HOr7dOc9ZgzcF8FFbUoKbeMS1gROQ47BojIgBAaIAvQi2sxvzm3T1xJL8co7rHQaVSQa0R9FqdPn34Gr3yQX4+OL3gZtzz752oV2tw4FwZAKB1RCCmDuuApZtOmrxWXJj5LTJeHNsNr/96BEDjQpadX/xNe+6naeL2bbNFoK83rtSrUa8WMPWrvQbn48ICUFBeg2FdWqJXYgRC/H1QUlWHZZtP4ZlRXfDT/gsorqrF0yO7oLK2ASVVdeifFAV/Xy+cLKxEoK832rYIxpV6NVoE+yHY3wehAT4I9PVGRU0D4nS2EGna/LWmXgMvL8DP28uqmXWCIIjabobIHakEbp9sVnl5OcLDw1FWVoawMHF7QRGRvi3HL+HLXWexZHxvBPv7IOn5X7XnNj09FMPe2gwAePOunri3fyKKKmvxw95zyDp7Gb8fLcTvTw1Fok7rz4XSKwgP9NVuQFtYXoMgfx/tqt7zfs7GJ9tzHHIvR+aNxqglW5FbUu2Q+q3RmPAAtQ2mF+IEgABfL8SGBaCqtgFFlXVGy/RpE4H80hoUlNdok7gm/j5eqG3QwM/bC51iQ/SWJbi1Vzz8fbzwv6xzABoXCM3IvoiYUH8kRQejZYg/iiprUVxVh14JEQgP9MUn23MQGeSLy9X1iA7xwz39ElFZ04Dfjxbi9t7xCPT1xtsZx7XXGN09DknRwQjx98Y3u/MwJiUOIQE+qK5T48OtpwEAN3aNwe9HC9EpJgRjerSCIAgoqqxD64gAFFbUIiLIDy1D/VHXoIEgCOgaF4Z6jQb/zcxDbkk1hneLRevIQCREBEItCCiqrEWnmFCoVEBeSTU0AhAfEQivvz/v+gYNjhZUoLK2AYM6tICXlwrHCyoQHxGIlqH+UGsEBPh6a/8teqkAqICKmgbU1mvg56NCRJAfLlXUIjLID5er6+DjpUKLEH/4+XhB/fdsT28vFTSCgNp6DSKCGv9QUWsE+Hl7oU6tQUlVHSpqGtAuOhjeXip4e6kgCAI0QuOiosZWWG9Qa+ClUhmca1Br4GPFRARXYe3zm4mQBUyEiByrpl5t0NXlCFfq1FCpgL25l5HaNhJlV+pxzfyNuLNPa1zbvgWGJ8di4MKNqG3Q4ONJ/fDUd3/hyZs6YfLAtkh+eR2u7xSNhXf1wBc7z2LSwCSDAdsFZTXIOnsZpVfq8NP+Cwj088bmY5cwMjkWLUP9UVXbgDWHClBnIWkhklKArxc0GqBOrUF0iJ9eItw84QWAxKhA5JVcAQDEhvnD19sL5y5f0SvTJipI+wdAbJg/4sICcLm6Hrkl1Qj190HF39v/9EwIR4CvN3bnlMDbS6VN7lpHBOJ86dU67+2XgEV39pR8WxwmQhJhIkREcmpaB6pBI6CmQQ1BA6gFAXUNGmgEARpBwJU6NQQ0dtdtPn4JCRGBqG3QINDPG6XVdX8vvimgoqYBO08XIyzAF/ERAbhSp8Hq/efRPykSXeLCsPNUESKD/PDHySLc1isem44VIirYH5U19bhUWYv80hrclZqAP3NK8FdeKQBg2rCOCPTzxnsbTiAhMhB39Gmt15ozuGM0Ms+UoEEjoHt8GIL8vLHrdInBfV7bPkp7XPd7Xe2ig5FTVAUA6BQTghOF4rZjaWqFAoAOLYOhEaCtz5SWof64VFELoPEBfqmiFnVmtsJpzkvVOHBfLQjcksWMbx+/Fte2byFpnUyEJMJEiIiI7CX8nQg1DckSBEAjCPBSqVCvaeyq0ggC1JrGbi3vvwsKEFCvFqBSAfUNGmgEwMdLhTq1BgG+3qiqbYDm77Fel6saW3tC/H3+TpKB6roGhPj7oLymAd4qFQL9vHCpog6Bft7w8VLhUmUtLpbVIDY8AKcvVaFnQjiqahtw+EI5+raJhEoF/Hm6BMnxYVhzMB+dY0MRGeSLerUGDRoBSdHBjV1xGuB4YQUSI4NQXFmLTccu4Z5+CdAIwMnCShSW16BrXCjWHi5Al9hQhAT4YPOxS/D2UmHCgDa4t1+i5OPVmAhJhIkQERGR67H2+e0+o6KIiIiIRGIiRERERB6LiRARERF5LCZCRERE5LGYCBEREZHHYiJEREREHouJEBEREXksJkJERETksZgIERERkcdiIkREREQei4kQEREReSwmQkREROSxmAgRERGRx3L7RKiiogL9+/dH79690aNHD3z00Udyh0REREQK4SN3AI4WFBSELVu2ICgoCNXV1UhJScGdd96JFi1ayB0aERERycztW4S8vb0RFBQEAKipqYFarYYgCDJHRUREREogeyK0detW3HrrrYiPj4dKpcLq1asNyixbtgzt2rVDQEAAUlNTsW3bNlHXKC0tRa9evZCQkIBnn30W0dHREkVPRERErkz2RKiqqgq9evXC0qVLjZ5fuXIlZsyYgTlz5mDfvn24/vrrMWbMGOTm5mrLpKamIiUlxeDrwoULAICIiAj89ddfyMnJwddff42LFy+ajKe2thbl5eV6X0REROSeVIKC+olUKhVWrVqFcePGaY8NGDAAffv2xfLly7XHunXrhnHjxmHhwoWir/HPf/4TN954I+655x6j51999VXMnTvX4HhZWRnCwsJEX4+IiIicr7y8HOHh4Raf37K3CJlTV1eHrKwsjBw5Uu/4yJEjsWPHDqvquHjxorZVp7y8HFu3bkWXLl1Mlp89ezbKysq0X3l5ebbfABERESmaomeNFRUVQa1WIzY2Vu94bGwsCgoKrKrj3LlzePTRRyEIAgRBwLRp09CzZ0+T5f39/eHv729X3EREROQaFJ0INVGpVHqvBUEwOGZKamoq9u/f74CoiIiIyNUpumssOjoa3t7eBq0/hYWFBq1ERERERGIpOhHy8/NDamoqMjIy9I5nZGRg0KBBDr12eno6kpOT0b9/f4deh4iIiOQje9dYZWUlTp48qX2dk5OD/fv3IyoqCm3atMGsWbMwceJE9OvXDwMHDsSHH36I3NxcTJkyxaFxpaWlIS0tTTvqnIiIiNyP7InQnj17MGzYMO3rWbNmAQAmT56MFStWYPz48SguLsa8efOQn5+PlJQUrFmzBm3btpUrZCIiInITilpHSImaWoQuXLjAdYSIiIhcRHl5OeLj4y2uIyR7i5CriI+PlzsEIiIikpiiB0sTERERORJbhExIT09Heno61Go1ALBrjIiIyIU0dY1ZwjFCFli7VwkREREph1vsNUZERETkSEyEiIiIyGMxESIiIiKPxUSIiIiIPBYTIRO41xgREZH746wxCzhrjIiIyPVw1hgRERGRBUyEiIiIyGMxESIiIiKPxUSIiIiIPBYTISIiIvJYTISIiIjIYzERMoHrCBEREbk/riNkQVlZGSIiIpCXl8d1hIiIiFxEeXk5EhMTUVpaivDwcJPlfJwYk0uqqKgAACQmJsocCREREYlVUVFhNhFii5AFGo0GFy5cQGhoKFQqlWT1NmWqntLSxPt1f552z7xf98b7dX2CIKCiogLx8fHw8jI9EogtQhZ4eXkhISHBYfWHhYW5zT86a/B+3Z+n3TPv173xfl2buZagJhwsTURERB6LiRARERF5LCZCMvH398crr7wCf39/uUNxCt6v+/O0e+b9ujfer+fgYGkiIiLyWGwRIiIiIo/FRIiIiIg8FhMhIiIi8lhMhIiIiMhjMRGSybJly9CuXTsEBAQgNTUV27ZtkzskixYuXIj+/fsjNDQUMTExGDduHI4dO6ZXRhAEvPrqq4iPj0dgYCCGDh2Kw4cP65Wpra3FE088gejoaAQHB+O2227DuXPn9MpcvnwZEydORHh4OMLDwzFx4kSUlpY6+hZNWrhwIVQqFWbMmKE95o73ev78eTz44INo0aIFgoKC0Lt3b2RlZWnPu9M9NzQ04MUXX0S7du0QGBiI9u3bY968edBoNNoyrny/W7duxa233or4+HioVCqsXr1a77wz7y03Nxe33norgoODER0djSeffBJ1dXVOu9/6+no899xz6NGjB4KDgxEfH49JkybhwoULbnm/zf3f//0fVCoVlixZonfcle7XoQRyum+//Vbw9fUVPvroIyE7O1uYPn26EBwcLJw9e1bu0MwaNWqU8OmnnwqHDh0S9u/fL4wdO1Zo06aNUFlZqS2zaNEiITQ0VPj++++FgwcPCuPHjxdatWollJeXa8tMmTJFaN26tZCRkSHs3btXGDZsmNCrVy+hoaFBW2b06NFCSkqKsGPHDmHHjh1CSkqKcMsttzj1fpvs3r1bSEpKEnr27ClMnz5de9zd7rWkpERo27at8NBDDwl//vmnkJOTI2zYsEE4efKktow73fPrr78utGjRQvjll1+EnJwc4bvvvhNCQkKEJUuWuMX9rlmzRpgzZ47w/fffCwCEVatW6Z131r01NDQIKSkpwrBhw4S9e/cKGRkZQnx8vDBt2jSn3W9paakwfPhwYeXKlcLRo0eFnTt3CgMGDBBSU1P16nCX+9W1atUqoVevXkJ8fLzw7rvvuuz9OhITIRlcc801wpQpU/SOde3aVXj++edlisg2hYWFAgBhy5YtgiAIgkajEeLi4oRFixZpy9TU1Ajh4eHCBx98IAhC4y8kX19f4dtvv9WWOX/+vODl5SWsXbtWEARByM7OFgAIu3bt0pbZuXOnAEA4evSoM25Nq6KiQujUqZOQkZEhDBkyRJsIueO9Pvfcc8LgwYNNnne3ex47dqzwyCOP6B278847hQcffFAQBPe63+YPSmfe25o1awQvLy/h/Pnz2jLffPON4O/vL5SVlTnlfo3ZvXu3AED7B6g73u+5c+eE1q1bC4cOHRLatm2rlwi58v1KjV1jTlZXV4esrCyMHDlS7/jIkSOxY8cOmaKyTVlZGQAgKioKAJCTk4OCggK9e/P398eQIUO095aVlYX6+nq9MvHx8UhJSdGW2blzJ8LDwzFgwABtmWuvvRbh4eFO/4zS0tIwduxYDB8+XO+4O97rTz/9hH79+uGee+5BTEwM+vTpg48++kh73t3uefDgwdi4cSOOHz8OAPjrr7/wxx9/4Oabbwbgfvery5n3tnPnTqSkpCA+Pl5bZtSoUaitrdXrdnW2srIyqFQqREREAHC/+9VoNJg4cSKeeeYZdO/e3eC8u92vPbjpqpMVFRVBrVYjNjZW73hsbCwKCgpkiko8QRAwa9YsDB48GCkpKQCgjd/YvZ09e1Zbxs/PD5GRkQZlmt5fUFCAmJgYg2vGxMQ49TP69ttvsXfvXmRmZhqcc7d7BYDTp09j+fLlmDVrFl544QXs3r0bTz75JPz9/TFp0iS3u+fnnnsOZWVl6Nq1K7y9vaFWqzF//nzcf//92jibYtflqvery5n3VlBQYHCdyMhI+Pn5yXb/NTU1eP755/HAAw9oNxh1t/t944034OPjgyeffNLoeXe7X3swEZKJSqXSey0IgsExJZs2bRoOHDiAP/74w+CcLffWvIyx8s78jPLy8jB9+nSsX78eAQEBJsu5w7020Wg06NevHxYsWAAA6NOnDw4fPozly5dj0qRJ2nLucs8rV67El19+ia+//hrdu3fH/v37MWPGDMTHx2Py5MkmY3XV+zXGWfempPuvr6/HfffdB41Gg2XLllks74r3m5WVhffeew979+4VfU1XvF97sWvMyaKjo+Ht7W2QKRcWFhpk1Ur1xBNP4KeffsKmTZuQkJCgPR4XFwcAZu8tLi4OdXV1uHz5stkyFy9eNLjupUuXnPYZZWVlobCwEKmpqfDx8YGPjw+2bNmC999/Hz4+Pto43OFem7Rq1QrJycl6x7p164bc3FwA7vXzBYBnnnkGzz//PO677z706NEDEydOxMyZM7Fw4UJtnID73K8uZ95bXFycwXUuX76M+vp6p99/fX097r33XuTk5CAjI0PbGtQUp7vc77Zt21BYWIg2bdpof3+dPXsWTz31FJKSkrRxusv92ouJkJP5+fkhNTUVGRkZesczMjIwaNAgmaKyjiAImDZtGn744Qf8/vvvaNeund75du3aIS4uTu/e6urqsGXLFu29paamwtfXV69Mfn4+Dh06pC0zcOBAlJWVYffu3doyf/75J8rKypz2Gd100004ePAg9u/fr/3q168fJkyYgP3796N9+/Zuc69NrrvuOoPlEI4fP462bdsCcK+fLwBUV1fDy0v/V6C3t7d2+ry73a8uZ97bwIEDcejQIeTn52vLrF+/Hv7+/khNTXXofepqSoJOnDiBDRs2oEWLFnrn3el+J06ciAMHDuj9/oqPj8czzzyDdevWAXCv+7Wb04Zlk1bT9Pn//Oc/QnZ2tjBjxgwhODhYOHPmjNyhmfXPf/5TCA8PFzZv3izk5+drv6qrq7VlFi1aJISHhws//PCDcPDgQeH+++83OiU3ISFB2LBhg7B3717hxhtvNDpls2fPnsLOnTuFnTt3Cj169JBt+nwT3VljguB+97p7927Bx8dHmD9/vnDixAnhq6++EoKCgoQvv/xSW8ad7nny5MlC69attdPnf/jhByE6Olp49tln3eJ+KyoqhH379gn79u0TAAjvvPOOsG/fPu0sKWfdW9P06ptuuknYu3evsGHDBiEhIUHy6dXm7re+vl647bbbhISEBGH//v16v79qa2vd7n6NaT5rzNXu15GYCMkkPT1daNu2reDn5yf07dtXOwVdyQAY/fr000+1ZTQajfDKK68IcXFxgr+/v3DDDTcIBw8e1KvnypUrwrRp04SoqCghMDBQuOWWW4Tc3Fy9MsXFxcKECROE0NBQITQ0VJgwYYJw+fJlJ9ylac0TIXe8159//llISUkR/P39ha5duwoffvih3nl3uufy8nJh+vTpQps2bYSAgAChffv2wpw5c/QejK58v5s2bTL6/3Xy5MlOv7ezZ88KY8eOFQIDA4WoqChh2rRpQk1NjdPuNycnx+Tvr02bNrnd/RpjLBFypft1JJUgCIIzWp6IiIiIlIZjhIiIiMhjMREiIiIij8VEiIiIiDwWEyEiIiLyWEyEiIiIyGMxESIiIiKPxUSIiIiIPBYTISIiIvJYTISIiMxISkrCkiVL5A6DiByEiRARKcZDDz2EcePGAQCGDh2KGTNmOO3aK1asQEREhMHxzMxMPP74406Lg4icy0fuAIiIHKmurg5+fn42v79ly5YSRkNESsMWISJSnIceeghbtmzBe++9B5VKBZVKhTNnzgAAsrOzcfPNNyMkJASxsbGYOHEiioqKtO8dOnQopk2bhlmzZiE6OhojRowAALzzzjvo0aMHgoODkZiYiKlTp6KyshIAsHnzZjz88MMoKyvTXu/VV18FYNg1lpubi9tvvx0hISEICwvDvffei4sXL2rPv/rqq+jduze++OILJCUlITw8HPfddx8qKioc+6ERkU2YCBGR4rz33nsYOHAg/vGPfyA/Px/5+flITExEfn4+hgwZgt69e2PPnj1Yu3YtLl68iHvvvVfv/Z999hl8fHywfft2/Pvf/wYAeHl54f3338ehQ4fw2Wef4ffff8ezzz4LABg0aBCWLFmCsLAw7fWefvppg7gEQcC4ceNQUlKCLVu2ICMjA6dOncL48eP1yp06dQqrV6/GL7/8gl9++QVbtmzBokWLHPRpEZE92DVGRIoTHh4OPz8/BAUFIS4uTnt8+fLl6Nu3LxYsWKA99sknnyAxMRHHjx9H586dAQAdO3bEm2++qVen7nijdu3a4bXXXsM///lPLFu2DH5+fggPD4dKpdK7XnMbNmzAgQMHkJOTg8TERADAF198ge7duyMzMxP9+/cHAGg0GqxYsQKhoaEAgIkTJ2Ljxo2YP3++fR8MEUmOLUJE5DKysrKwadMmhISEaL+6du0KoLEVpkm/fv0M3rtp0yaMGDECrVu3RmhoKCZNmoTi4mJUVVVZff0jR44gMTFRmwQBQHJyMiIiInDkyBHtsaSkJG0SBACtWrVCYWGhqHslIudgixARuQyNRoNbb70Vb7zxhsG5Vq1aab8PDg7WO3f27FncfPPNmDJlCl577TVERUXhjz/+wKOPPor6+nqrry8IAlQqlcXjvr6+eudVKhU0Go3V1yEi52EiRESK5OfnB7VarXesb9+++P7775GUlAQfH+t/fe3ZswcNDQ14++234eXV2BD+3//+1+L1mktOTkZubi7y8vK0rULZ2dkoKytDt27drI6HiJSDXWNEpEhJSUn4888/cebMGRQVFUGj0SAtLQ0lJSW4//77sXv3bpw+fRrr16/HI488YjaJ6dChAxoaGvCvf/0Lp0+fxhdffIEPPvjA4HqVlZXYuHEjioqKUF1dbVDP8OHD0bNnT0yYMAF79+7F7t27MWnSJAwZMsRodxwRKR8TISJSpKeffhre3t5ITk5Gy5YtkZubi/j4eGzfvh1qtRqjRo1CSkoKpk+fjvDwcG1LjzG9e/fGO++8gzfeeAMpKSn46quvsHDhQr0ygwYNwpQpUzB+/Hi0bNnSYLA10NjFtXr1akRGRuKGG27A8OHD0b59e6xcuVLy+yci51AJgiDIHQQRERGRHNgiRERERB6LiRARERF5LCZCRERE5LGYCBEREZHHYiJEREREHouJEBEREXksJkJERETksZgIERERkcdiIkREREQei4kQEREReSwmQkREROSx/h8VbM6epW9NMgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# BP\n",
    "sigma=1e-2\n",
    "mu=0.5\n",
    "print(\"Number of neurons:\",m)\n",
    "mbp=2*m\n",
    "ITERS=15000\n",
    "U=sigma*np.random.randn(d,mbp)\n",
    "w=sigma*np.random.randn(mbp,1)\n",
    "yall=y.reshape(-1,1)\n",
    "obj_bp=np.empty((ITERS,1))\n",
    "batch_size=n\n",
    "nb=batch_size\n",
    "for i in range(ITERS):\n",
    "    if i%8000 == 0 and i>0:\n",
    "        mu=mu/5\n",
    "    samp=np.random.choice(n,batch_size)\n",
    "    Xgd=X[samp,:]\n",
    "    ygd=yall[samp,:]\n",
    "    a1=np.dot(Xgd,U)\n",
    "    yest=np.dot(relu(a1),w)\n",
    "    yest_all=np.dot(relu(np.dot(X,U)),w)\n",
    "    obj_bp[i]=np.linalg.norm(yall-yest_all)**2/(2*n)+(beta/2)*(np.linalg.norm(U,'fro')**2+np.linalg.norm(w,'fro')**2)\n",
    "    gradw= relu(a1).T@(yest-ygd)/nb\n",
    "    gradU=np.zeros((d,mbp))\n",
    "\n",
    "    gradU=Xgd.T@(drelu(a1)*((yest-ygd)@w.T))/nb\n",
    "\n",
    "    U=(1-mu*beta)*U-mu*gradU\n",
    "    w=(1-mu*beta)*w-mu*gradw\n",
    "\n",
    "\n",
    "# Plot\n",
    "plt.figure(0)\n",
    "plt.semilogy(obj_bp,label='GD')\n",
    "plt.axhline(cvx_opt,color='k',label='Optimal')\n",
    "plt.ylabel('Objective value')\n",
    "plt.xlabel('Iteration')\n",
    "plt.savefig('bp_vs_cvx.pdf', bbox_inches='tight')\n",
    "\n",
    "plt.legend();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "356caf90-8f66-4ef4-bb27-a56ecc5e6e33",
   "metadata": {},
   "outputs": [],
   "source": [
    "### 4 (a). Plotting Decision boundaries: cvx (left); sgd (right)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b72614d6-ccbc-479a-9e57-57ba027b68c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "samp=100\n",
    "x1=np.linspace(-1,1,samp).reshape(-1,1)\n",
    "x2=np.linspace(-1,1,samp).reshape(-1,1)\n",
    "\n",
    "Xtest=np.ones((samp**2,d))\n",
    "count=0\n",
    "for i in range(samp):\n",
    "    for j in range(samp):\n",
    "        Xtest[count]=[x1[i, 0],x2[j, 0],1]\n",
    "        count+=1\n",
    "\n",
    "ntest=Xtest.shape[0]\n",
    "\n",
    "Uopt1v=Uopt1.value\n",
    "Uopt2v=Uopt2.value\n",
    "\n",
    "yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "yest_bp=np.dot(relu(np.dot(Xtest,U)),w)\n",
    "\n",
    "\n",
    "pos_cvx=np.where(np.sign(yest_cvx)==1)\n",
    "neg_cvx=np.where(np.sign(yest_cvx)==-1)\n",
    "pos_bp=np.where(np.sign(yest_bp)==1)\n",
    "neg_bp=np.where(np.sign(yest_bp)==-1)\n",
    "pos=np.where(y==1)\n",
    "neg=np.where(y==-1)\n",
    "pos_test=np.where(yacc==1)\n",
    "neg_test=np.where(yacc==-1)\n",
    "\n",
    "\n",
    "def plot_result(pos1, neg1, pos2, neg2, name):\n",
    "\n",
    "    def mix_with_white(color, alpha):\n",
    "        white = np.array([1, 1, 1])\n",
    "        return (1 - alpha) * white + alpha * np.array(color)\n",
    "\n",
    "    # Define the original colors\n",
    "    cyan = [0, 1, 1]\n",
    "    magenta = [1, 0, 1]\n",
    "\n",
    "    # Mix the colors with white\n",
    "    cyan_mixed = mix_with_white(cyan, 0.3)\n",
    "    magenta_mixed = mix_with_white(magenta, 0.3)\n",
    "\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(7, 3))\n",
    "\n",
    "    ax1.plot(Xtest[pos1,0],Xtest[pos1,1],'o', label = 'Train data', color=cyan_mixed);\n",
    "    ax1.plot(Xtest[neg1,0],Xtest[neg1,1],'o', label = 'Test data', color=magenta_mixed);\n",
    "    ax1.plot(X[pos,0],X[pos,1],'cx');\n",
    "    ax1.plot(X[neg,0],X[neg,1],'mx');\n",
    "    ax1.plot(Xacc[pos_test,0],Xacc[pos_test,1],'cx',marker ='^');\n",
    "    ax1.plot(Xacc[neg_test,0],Xacc[neg_test,1],'mx',marker ='^');\n",
    "        \n",
    "\n",
    "    ax2.set_yticklabels([])\n",
    "\n",
    "    ax2.plot(Xtest[pos2,0],Xtest[pos2,1],'o', color=cyan_mixed);\n",
    "    ax2.plot(Xtest[neg2,0],Xtest[neg2,1],'o', color=magenta_mixed);\n",
    "    ax2.plot(X[pos,0],X[pos,1],'cx');\n",
    "    ax2.plot(X[neg,0],X[neg,1],'mx');\n",
    "    ax2.plot(Xacc[pos_test,0],Xacc[pos_test,1],'cx',marker ='^');\n",
    "    ax2.plot(Xacc[neg_test,0],Xacc[neg_test,1],'mx',marker ='^');\n",
    "    \n",
    "    plt.legend()\n",
    "\n",
    "    plt.savefig(f'{name}.pdf', bbox_inches='tight')\n",
    "\n",
    "\n",
    "plot_result(pos_cvx, neg_cvx, pos_bp, neg_bp, 'full_data')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e6c08576-49ae-4262-ae12-1dec6fc6096e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Another way of plotting decision boundary of cvx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "61f966ad-60c5-4398-ae1b-f3b6cf398b5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_decision_boundary(X, y, X_test, y_test, Uopt1v, Uopt2v, selected_indices, name):\n",
    "    # Define the grid range based on the data range\n",
    "    x_min, x_max = -1.5, 1.5 # 1.5\n",
    "    y_min, y_max = -1.5, 1.5\n",
    "\n",
    "    # Create a grid of points\n",
    "    x1 = np.linspace(x_min, x_max, 100)\n",
    "    x2 = np.linspace(y_min, y_max, 100)\n",
    "    x1, x2 = np.meshgrid(x1, x2)\n",
    "    Xtest = np.c_[x1.ravel(), x2.ravel()]\n",
    "    Xtest = np.append(Xtest, np.ones((Xtest.shape[0], 1)), axis=1)  # Add the bias term\n",
    "    \n",
    "    yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "    yest_cvx = yest_cvx.reshape(x1.shape)\n",
    "    \n",
    "    # Map labels back to -1 and 1 for visualization\n",
    "    y_train_mapped = np.where(y == 1, 1, -1)\n",
    "    y_test_mapped = np.where(y_test == 1, 1, -1)\n",
    "    \n",
    "    X_selected = X[selected_indices]\n",
    "    y_selected = y_train_mapped[selected_indices]\n",
    "\n",
    "    # Create subplots\n",
    "    fig, ax = plt.subplots(figsize=(7, 7))\n",
    "\n",
    "    # Define the custom colors\n",
    "    colors = ['#920783', '#00b7c7']  # Switched the colors to match the image\n",
    "    cmap = mcolors.ListedColormap(colors)\n",
    "\n",
    "    # Plot the decision boundary with custom colors\n",
    "    ax.contourf(x1, x2, yest_cvx, alpha=0.3, cmap=cmap)\n",
    "    scatter_train = ax.scatter(X[:, 0], X[:, 1], c=y_train_mapped, edgecolor='k', s=20, cmap=cmap,\n",
    "                               label='Train Data')\n",
    "    scatter_test = ax.scatter(X_test[:, 0], X_test[:, 1], c=y_test_mapped, edgecolor='k', s=20, cmap=cmap,\n",
    "                              marker='^', label = 'Test Data')\n",
    "    scatter_select = ax.scatter(X_selected[:,0], X_selected[:,1], c=y_selected, s=80, cmap=cmap, marker='x',\n",
    "                               label='Queried Data')\n",
    "    \n",
    "    ax.set_xlabel('x1')\n",
    "    ax.set_ylabel('x2')\n",
    "    ax.set_xlim(x_min, x_max)\n",
    "    ax.set_ylim(y_min, y_max)\n",
    "    ax.set_title(f'{name}')\n",
    "    plt.legend()\n",
    "    #plt.savefig(f'{name}.pdf', bbox_inches='tight')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "bf9049e0-bfaa-4c8a-bede-eca9a7b7ba1d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary(X, y, Xacc, yacc, Uopt1v, Uopt2v, [1], 'full')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "913f3273-4953-4685-929d-c5bddd5e56b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Accuracy rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e07fe43f-216b-4c21-89cc-83902cc8af9c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "accuracy cvx: 1.0, accuracy bp: 1.0\n"
     ]
    }
   ],
   "source": [
    "yacc_cvx = np.sign(np.sum(drelu(Xacc@Uopt1v)*(Xacc@Uopt1v)-drelu(Xacc@Uopt2v)*(Xacc@Uopt2v),axis=1))\n",
    "yacc_bp = np.sign(np.dot(relu(np.dot(Xacc,U)),w))\n",
    "\n",
    "acc_cvx = np.sum(yacc_cvx == yacc) / len(yacc)\n",
    "acc_bp = np.sum(yacc_bp.flatten() == yacc) / len(yacc)\n",
    "\n",
    "print(f'accuracy cvx: {acc_cvx}, accuracy bp: {acc_bp}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a43df995-fe6f-449b-b4b7-92ef7b4b0824",
   "metadata": {},
   "source": [
    "### 5. Cutting-plane AL via a Two-layer ReLU NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "adad2f8f-187c-4eab-a8a3-901b247b271c",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = len(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6b2d5c33-cb60-477e-beb9-6067ec58a75a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sign(a):\n",
    "    return 2 * int(a >= 0) - 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "eb7a66c7-b92c-4dc6-931c-dcfb074b3b4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute analytic center\n",
    "def center(S, R=1, boxinit=False, reg=False, reg_value=2e-4):\n",
    "    \"\"\"S is list of affine inequalities described as tuple of LHS vector/matrix and RHS scalar/vector\"\"\"\n",
    "    s = cp.Variable(2*d*m)\n",
    "    obj = 0 if boxinit else cp.log(R - cp.norm(s))\n",
    "    constraints = []\n",
    "    if reg:\n",
    "        U = cp.reshape(s, (2*d, m), order='F')\n",
    "        #obj += cp.log(reg_value - beta*(cp.mixed_norm(U[:d].T,2,1)+cp.mixed_norm(U[d:].T,2,1)))\n",
    "        constraints = [beta*(cp.mixed_norm(U[:d].T,2,1)+cp.mixed_norm(U[d:].T,2,1)) <= reg_value]\n",
    "    if len(S) > 0:\n",
    "        obj += cp.sum([cp.log(rhs - lhs @ s) for lhs, rhs in S])\n",
    "    prob = cp.Problem(cp.Maximize(obj), constraints)\n",
    "    prob.solve(solver=cp.MOSEK)\n",
    "    return s.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "063ba43a-81d8-43d9-8fd1-cfdb057838c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# cut set\n",
    "def cut(S, x, y, dmat_row):\n",
    "    m = len(dmat_row)\n",
    "    # f = cp.sum(cp.multiply(dmat, X*(Uopt1 - Uopt2)), axis=1)\n",
    "    # f_i = dmat[i, 0] * X[i, :] [I - I] var[:, 0] + dmat[i, 1] * X[i, :] [I - I] var[:, 1] + ...  where var = [Uopt1; Uopt2]\n",
    "    # f_i = dmat[i, :] @ [X[i, :] [I - I] var[:, 0]; X[i, :] [I - I] var[:, 1]; ...]\n",
    "    S.append((-y * dmat_row @ np.kron(np.eye(m), np.concatenate((x, -x)).T), 0))\n",
    "\n",
    "    relu_constraint = -np.kron(np.diag(2*dmat_row-np.ones(m)), np.kron(np.eye(2), x))\n",
    "    for lhs in relu_constraint:\n",
    "        S.append((lhs, 0))\n",
    "    # potentially remove redundant constraints here"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "2071b586-c316-4a3f-b31d-af90c6a946fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pred_point(i, U1v, U2v): # corresponds to <w(theta), x>\n",
    "    y1 = np.sum(np.multiply(dmat[i],(X[i][np.newaxis, :] @ U1v)),axis=1)\n",
    "    y2 = np.sum(np.multiply(dmat[i],(X[i][np.newaxis, :] @ U2v)),axis=1)\n",
    "    return y1 - y2\n",
    "\n",
    "def pred_point_simplified(i, U1v, U2v):\n",
    "    var = np.vstack((U1v, U2v)).flatten(order='F')\n",
    "    return (dmat[i] @ np.kron(np.eye(len(dmat[i])), np.concatenate((X[i], -X[i])).T)) @ var\n",
    "\n",
    "def pred_point_simplified_vec(i, vec):\n",
    "    return (dmat[i] @ np.kron(np.eye(len(dmat[i])), np.concatenate((X[i], -X[i])).T)) @ vec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "e76dc7c1-8559-42bc-89a8-649cf5afc1d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def constraint(i, U1v, U2v):\n",
    "    return np.vstack((\n",
    "        np.multiply((2*dmat[i]-np.ones((1,m))),(X[i] @ U1v)),\n",
    "        np.multiply((2*dmat[i]-np.ones((1,m))),(X[i] @ U2v))\n",
    "    )).flatten(order='F')\n",
    "\n",
    "def constraint_simplified(i, U1v, U2v):\n",
    "    var = np.vstack((U1v, U2v)).flatten(order='F')\n",
    "    return np.kron(np.diag(2*dmat[i]-np.ones(m)), np.kron(np.eye(2), X[i])) @ var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "46649b58-d3b5-4cee-8ffc-f33ef6eb0ef1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def in_Ct(c, Ct, eps=1e-3):\n",
    "    for lhs, rhs in Ct:\n",
    "        if lhs @ c > rhs + eps:\n",
    "            return False\n",
    "    return True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "95aa59fa-207d-42a3-8837-60bb90b02b1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_lattice(S, R=1):\n",
    "    d = 3\n",
    "    l = cp.Variable(2*d*m)\n",
    "    d = np.random.randn(2*d*m)\n",
    "    obj = (d / np.linalg.norm(d)) @ l\n",
    "    prob = cp.Problem(cp.Maximize(obj), [cp.norm(l) <= R] + [lhs @ l <= rhs for lhs, rhs in S])\n",
    "    prob.solve(cp.MOSEK)\n",
    "    return l.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "fec4eb3d-b364-4b95-aed0-9af32f3a5d45",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = 1\n",
    "\n",
    "C0_lower = -R*np.ones(2*d*m)\n",
    "C0_upper = R*np.ones(2*d*m)\n",
    "\n",
    "def sample_classifier(Ct, c, maxiter=10**5):\n",
    "    for _ in range(maxiter):\n",
    "        #candidate = np.random.uniform(C0_lower, C0_upper)\n",
    "        candidate = c + np.random.randn(*c.shape)\n",
    "        if in_Ct(candidate, Ct):\n",
    "            return candidate\n",
    "    print(f'Failed to sample after {maxiter} tries.')\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "af53aa60-7c7c-4397-98f9-124e11008a5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def query(C, c, data_tried, data_used, M=100):\n",
    "\n",
    "    mini = np.inf\n",
    "    i_mini = -1\n",
    "\n",
    "    maxi = -np.inf\n",
    "    i_maxi = -1\n",
    "\n",
    "    minabs = np.inf\n",
    "    i_minabs = -1\n",
    "\n",
    "    #theta_s = np.zeros(2*d*m)\n",
    "    #for _ in range(M):\n",
    "    #    th = sample_classifier(C, c)\n",
    "    #    #th = sample_lattice(C)\n",
    "    #    if th is None:\n",
    "    #        return None, None, None\n",
    "    #    theta_s += (1/M) * th\n",
    "\n",
    "    #theta_matrix = np.reshape(c, (2*d, m), order='F')\n",
    "    #U1_query=theta_matrix[:d]\n",
    "    #U2_query=theta_matrix[d:]\n",
    "\n",
    "    for i in range(N): # search in finite data (D implicit) set to re-use dmat then\n",
    "        if i not in data_tried and i not in data_used:\n",
    "            pred = pred_point_simplified_vec(i, c)\n",
    "            if pred < mini:\n",
    "                i_mini = 1*i\n",
    "                mini = pred\n",
    "            if pred > maxi:\n",
    "                i_maxi = 1*i\n",
    "                maxi = pred\n",
    "            if abs(pred) < minabs:\n",
    "                i_minabs = 1*i\n",
    "                minabs = abs(pred)\n",
    "\n",
    "    return i_mini, i_maxi, i_minabs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2c61d42a-c4e2-47f8-8cc4-282518210798",
   "metadata": {},
   "outputs": [],
   "source": [
    "# final convex solve\n",
    "\n",
    "def convex_solve(used):\n",
    "\n",
    "    used_unique = list(set(used))\n",
    "\n",
    "    Uopt1_final=cp.Variable((d,m)) # c_i in paper\n",
    "    Uopt2_final=cp.Variable((d,m)) # c_i' in paper\n",
    "\n",
    "    yopt1_final=cp.sum(cp.multiply(dmat[used_unique],(X[used_unique]*Uopt1_final)),axis=1)\n",
    "    yopt2_final=cp.sum(cp.multiply(dmat[used_unique],(X[used_unique]*Uopt2_final)),axis=1)\n",
    "\n",
    "    cost=cp.sum_squares(y[used_unique]-(yopt1_final-yopt2_final))/(2*n)+beta*(cp.mixed_norm(Uopt1_final.T,2,1)+cp.mixed_norm(Uopt2_final.T,2,1))\n",
    "\n",
    "    constraints=[]\n",
    "    constraints+=[cp.multiply((2*dmat[used_unique]-np.ones((len(used_unique),m))),(X[used_unique]*Uopt1_final))>=0]\n",
    "    constraints+=[cp.multiply((2*dmat[used_unique]-np.ones((len(used_unique),m))),(X[used_unique]*Uopt2_final))>=0]\n",
    "    prob_final=cp.Problem(cp.Minimize(cost),constraints)\n",
    "    prob_final.solve(solver=cp.CLARABEL,warm_start=True)\n",
    "\n",
    "    return Uopt1_final.value, Uopt2_final.value, beta*(cp.mixed_norm(Uopt1_final.value.T,2,1)+cp.mixed_norm(Uopt2_final.value.T,2,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "51627406-b9af-4ae9-8ccb-9c26ed9f91e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# cutting plane method\n",
    "\n",
    "def cutting_plane(n_points=100, maxit=10000, boxinit=False):\n",
    "    \n",
    "    data_tried = []\n",
    "    data_used = []\n",
    "    \n",
    "    Ct = []\n",
    "    if boxinit:\n",
    "        for i, (l, u) in enumerate(zip(C0_lower, C0_upper)):\n",
    "            one_vec = np.zeros(2*d*m)\n",
    "            one_vec[i] = 1\n",
    "            Ct.append((one_vec, u))\n",
    "            Ct.append((-one_vec, -l))\n",
    "    \n",
    "    c = None\n",
    "    did_cut = True\n",
    "    it = 0\n",
    "    while len(data_used) < n_points and it < maxit: # TODO: replace by proper termination criterion\n",
    "        if len(data_tried) == N:\n",
    "            data_tried = []\n",
    "        if did_cut:\n",
    "            #if len(data_used) > 0:\n",
    "            #    _, _, reg_value = convex_solve(data_used)\n",
    "            #else:\n",
    "            #    reg_value = 1e-5\n",
    "            c = center(Ct, R=R)\n",
    "            did_cut = False\n",
    "        i_mini, i_maxi, i_minabs = query(Ct, c, data_tried, data_used)\n",
    "        if i_mini is None:\n",
    "            return Ct, c, data_used\n",
    "        data_tried += [i_mini, i_maxi]\n",
    "        data_tried = list(set(data_tried))\n",
    "        #if it >= 30:\n",
    "        #    print(X[i_mini], np.sign(pred_point_simplified_vec(i_mini, c)), y[i_mini])\n",
    "        #    print(X[i_maxi], np.sign(pred_point_simplified_vec(i_maxi, c)), y[i_maxi])\n",
    "            #print(X[i_minabs], np.sign(pred_point_simplified_vec(i_minabs, c)), y[i_minabs])\n",
    "        if True: #len(data_used) < 4 * n_points // 5:\n",
    "            if np.sign(pred_point_simplified_vec(i_mini, c)) != y[i_mini]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_mini], y[i_mini], dmat[i_mini])\n",
    "                data_used.append(i_mini)\n",
    "                did_cut = True\n",
    "            if np.sign(pred_point_simplified_vec(i_maxi, c)) != y[i_maxi]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_maxi], y[i_maxi], dmat[i_maxi])\n",
    "                data_used.append(i_maxi)\n",
    "                did_cut = True\n",
    "        else:\n",
    "            if np.sign(pred_point_simplified_vec(i_minabs, c)) != y[i_minabs]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_minabs], y[i_minabs], dmat[i_minabs])\n",
    "                data_used.append(i_minabs)\n",
    "                did_cut = True\n",
    "        it += 1\n",
    "        \n",
    "        #data_used = list(set(data_used))\n",
    "        \n",
    "        #print(len(data_tried))\n",
    "    \n",
    "    return Ct, c, data_used"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "56d0692b-999e-4ddd-a4dd-c76a5aa6df2e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cutting at iteration 0\n",
      "Cutting at iteration 0\n",
      "Cutting at iteration 1\n",
      "Cutting at iteration 8\n",
      "Cutting at iteration 16\n",
      "Cutting at iteration 16\n",
      "Cutting at iteration 17\n",
      "Cutting at iteration 21\n",
      "Cutting at iteration 24\n",
      "Cutting at iteration 25\n",
      "Cutting at iteration 25\n",
      "Cutting at iteration 27\n",
      "Cutting at iteration 29\n",
      "Cutting at iteration 35\n",
      "Cutting at iteration 35\n",
      "Cutting at iteration 40\n",
      "Cutting at iteration 40\n",
      "Cutting at iteration 43\n",
      "Cutting at iteration 48\n",
      "Cutting at iteration 63\n",
      "size of C: 24940\n",
      "used: [0, 0, 29, 55, 25, 27, 2, 65, 13, 18, 30, 5, 47, 14, 3, 52, 52, 62, 46, 28]\n"
     ]
    }
   ],
   "source": [
    "C, c, used = cutting_plane(20)\n",
    "print(f'size of C: {len(C)}')\n",
    "print(f'used: {used}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "69d4f9e8-22f9-48f5-b7da-9f560c6ce01b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visualize(Uopt1v_list, Uopt2v_list, title):\n",
    "\n",
    "    pos_cvx = []\n",
    "    neg_cvx = []\n",
    "    \n",
    "    for Uopt1v, Uopt2v in zip(Uopt1v_list, Uopt2v_list):\n",
    "    \n",
    "        yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "        pos_cvx.append(np.where(np.sign(yest_cvx)==1))\n",
    "        neg_cvx.append(np.where(np.sign(yest_cvx)==-1))\n",
    "        \n",
    "        yacc_cvx = np.sign(np.sum(drelu(Xacc@Uopt1v)*(Xacc@Uopt1v)-drelu(Xacc@Uopt2v)*(Xacc@Uopt2v),axis=1))\n",
    "        print(f'# of correct classificationsn on the test set: {np.sum(yacc_cvx == yacc)}')\n",
    "        acc_cvx = np.sum(yacc_cvx == yacc) / len(yacc)\n",
    "        print(f'accuracy cvx on the test set: {acc_cvx}')\n",
    "\n",
    "        ytrain_cvx = np.sign(np.sum(drelu(X@Uopt1v)*(X@Uopt1v)-drelu(X@Uopt2v)*(X@Uopt2v),axis=1))\n",
    "        print(f'# of correct classificationsn on the train set: {np.sum(ytrain_cvx == y)}')\n",
    "        acc_train = np.sum(ytrain_cvx == y) / len(y)\n",
    "        print(f'accuracy cvx on the train set: {acc_train}')\n",
    "\n",
    "    plot_result(pos_cvx[0], neg_cvx[0], pos_cvx[1], neg_cvx[1], title)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "53a54965-5bdf-4ee6-93a9-b78d899a3c3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visualize_boundary(Uopt1v_list, Uopt2v_list, title):\n",
    "    \n",
    "    for Uopt1v, Uopt2v in zip(Uopt1v_list, Uopt2v_list):\n",
    "    \n",
    "        yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "        \n",
    "        yacc_cvx = np.sign(np.sum(drelu(Xacc@Uopt1v)*(Xacc@Uopt1v)-drelu(Xacc@Uopt2v)*(Xacc@Uopt2v),axis=1))\n",
    "        print(f'# of correct classificationsn on the test set: {np.sum(yacc_cvx == yacc)}')\n",
    "        acc_cvx = np.sum(yacc_cvx == yacc) / len(yacc)\n",
    "        print(f'accuracy cvx on the test set: {acc_cvx}')\n",
    "\n",
    "        ytrain_cvx = np.sign(np.sum(drelu(X@Uopt1v)*(X@Uopt1v)-drelu(X@Uopt2v)*(X@Uopt2v),axis=1))\n",
    "        print(f'# of correct classificationsn on the train set: {np.sum(ytrain_cvx == y)}')\n",
    "        acc_train = np.sum(ytrain_cvx == y) / len(y)\n",
    "        print(f'accuracy cvx on the train set: {acc_train}')\n",
    "\n",
    "    plot_result(pos_cvx[0], neg_cvx[0], pos_cvx[1], neg_cvx[1], title)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "75383687-a11f-4f58-8cbf-0e6fac3437e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# of correct classificationsn on the test set: 12\n",
      "accuracy cvx on the test set: 0.6\n",
      "# of correct classificationsn on the train set: 67\n",
      "accuracy cvx on the train set: 0.8375\n",
      "# of correct classificationsn on the test set: 20\n",
      "accuracy cvx on the test set: 1.0\n",
      "# of correct classificationsn on the train set: 80\n",
      "accuracy cvx on the train set: 1.0\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "theta_matrix = np.reshape(c, (2*d, m), order='F')\n",
    "Uopt1_final_v, Uopt2_final_v, _ = convex_solve(used)\n",
    "visualize([theta_matrix[:d], Uopt1_final_v], [theta_matrix[d:], Uopt2_final_v], 'norefine')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "644fc1d4-fe18-453d-b72b-0f15ab931909",
   "metadata": {},
   "source": [
    "### 6. Linear cutting-plane AL method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "10078760-513e-452f-b79b-53e91321efe2",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 80"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "57717ed6-0878-42ab-9dde-55303e1aa277",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "57b0ed54-a2b5-4d0e-a2ff-4d755ada1a9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def linear_center(S, R=1):\n",
    "    \"\"\"S is a list of affine inequalities described as (LHS vector, RHS scalar) tuples.\"\"\"\n",
    "    w = cp.Variable(d)\n",
    "    obj = cp.log(R - cp.norm(w)) # Objective for finding the center (log-barrier)\n",
    "    constraints = []\n",
    "    \n",
    "    if len(S) > 0:\n",
    "        obj += cp.sum([cp.log(rhs - lhs @ w) for lhs, rhs in S])  # Add log-barrier constraints\n",
    "\n",
    "    prob = cp.Problem(cp.Maximize(obj), constraints)\n",
    "    prob.solve(solver=cp.MOSEK)\n",
    "    \n",
    "    return w.value  # Return the center of the current feasible region"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "f1194f19-453c-47f3-a589-6f344e1e9d45",
   "metadata": {},
   "outputs": [],
   "source": [
    "def linear_query(w, X, y, data_tried, data_used, M=100):\n",
    "\n",
    "    mini = np.inf\n",
    "    i_mini = -1\n",
    "\n",
    "    maxi = -np.inf\n",
    "    i_maxi = -1\n",
    "\n",
    "    minabs = np.inf\n",
    "    i_minabs = -1\n",
    "    \n",
    "    for i in range(N): # search in finite data (D implicit) set to re-use dmat then\n",
    "        if i not in data_tried and i not in data_used:\n",
    "            pred = y[i] * np.dot(w, X[i])\n",
    "            if pred < mini:\n",
    "                i_mini = 1*i\n",
    "                mini = pred\n",
    "            if pred > maxi:\n",
    "                i_maxi = 1*i\n",
    "                maxi = pred\n",
    "            if abs(pred) < minabs:\n",
    "                i_minabs = 1*i\n",
    "                minabs = abs(pred)\n",
    "\n",
    "    return i_mini, i_maxi, i_minabs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "3295bd46-41e9-4283-8cf6-98cbfca0f37c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def linear_cut(S, x, y):\n",
    "    \"\"\"\n",
    "    Add a new cutting-plane constraint for a linear classifier.\n",
    "    \n",
    "    Arguments:\n",
    "    - S: current list of constraints\n",
    "    - x: the feature vector of the queried point\n",
    "    - y: the label of the queried point\n",
    "    \"\"\"\n",
    "    # The constraint is simply: y * <w, x> >= 0, which means adding (y * x, 0) to the constraint set\n",
    "    S.append((y * x, 0))  # Add new constraint y * <w, x> >= 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "7b1c606a-9459-4fed-89c2-647ea61d8fca",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = 1\n",
    "\n",
    "C0_lower_linear = -R*np.ones(d)\n",
    "C0_upper_linear = R*np.ones(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "6b0f7441-ef83-44e1-a32b-a3d1f24e037c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def linear_cutting_plane(n_points=100, maxit=10000, boxinit=False):\n",
    "\n",
    "    data_tried = []\n",
    "    data_used = []\n",
    "\n",
    "    Ct = []\n",
    "    if boxinit:\n",
    "        for i, (l, u) in enumerate(zip(C0_lower_linear, C0_upper_linear)):\n",
    "            one_vec = np.zeros(d)\n",
    "            one_vec[i] = 1\n",
    "            Ct.append((one_vec, u))\n",
    "            Ct.append((-one_vec, -l))\n",
    "\n",
    "    c = None\n",
    "    did_cut = True\n",
    "    it = 0\n",
    "    #print(it)\n",
    "    #print(len(data_used))\n",
    "    while len(data_used) < n_points and it < maxit: \n",
    "        if len(data_tried) == N:\n",
    "            data_tried = []\n",
    "        if did_cut:\n",
    "            c = linear_center(Ct, R=R) # cannot be 0\n",
    "            # Offset the center if it's too close to zero\n",
    "            if np.all(np.abs(c) < 1e-6):  # If all values of `c` are very close to zero\n",
    "                c += 1e-6 * np.random.randn(d)  # Apply small random offset\n",
    "            #print(c)\n",
    "            did_cut = False\n",
    "        i_mini, i_maxi, i_minabs = linear_query(c, X, y, data_tried, data_used)\n",
    "        if i_mini is None:\n",
    "            return Ct, c, data_used\n",
    "        data_tried += [i_mini, i_maxi]\n",
    "        data_tried = list(set(data_tried))\n",
    "        if True: \n",
    "            if y[i_mini]*np.dot(c,X[i_mini]) < 0:\n",
    "                #print(1,'y')\n",
    "                #print(f'Cutting at iteration {it}')\n",
    "                linear_cut(Ct, X[i_mini], y[i_mini])\n",
    "                data_used.append(i_mini)\n",
    "                did_cut = True\n",
    "            if y[i_maxi]*np.dot(c,X[i_maxi]) < 0:\n",
    "                #print(2,'y')\n",
    "                #print(f'Cutting at iteration {it}')\n",
    "                linear_cut(Ct, X[i_maxi], y[i_maxi])\n",
    "                data_used.append(i_maxi)\n",
    "                did_cut = True\n",
    "        else:\n",
    "            if y[i_minabs]*np.dot(c,X[i_minabs])<0:\n",
    "                #print(3,'y')\n",
    "                #print(f'Cutting at iteration {it}')\n",
    "                linear_cut(Ct, X[i_minabs], y[i_minabs])\n",
    "                data_used.append(i_minabs)\n",
    "                did_cut = True\n",
    "        it += 1\n",
    "\n",
    "        #data_used = list(set(data_used))\n",
    "\n",
    "        #print(len(data_tried))\n",
    "\n",
    "    return Ct, c, data_used"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "c8cae586-eef9-46cd-a71f-97370d2b0b60",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cutting at iteration 0\n",
      "Cutting at iteration 1\n",
      "Cutting at iteration 2\n",
      "Cutting at iteration 3\n",
      "Cutting at iteration 4\n",
      "Cutting at iteration 5\n",
      "Cutting at iteration 6\n",
      "Cutting at iteration 7\n",
      "Cutting at iteration 8\n",
      "Cutting at iteration 9\n",
      "Cutting at iteration 10\n",
      "Cutting at iteration 11\n",
      "Cutting at iteration 12\n",
      "Cutting at iteration 13\n",
      "Cutting at iteration 14\n",
      "Cutting at iteration 15\n",
      "Cutting at iteration 16\n",
      "Cutting at iteration 17\n",
      "Cutting at iteration 18\n",
      "Cutting at iteration 19\n",
      "size of C: 20\n",
      "used: [57, 53, 18, 66, 61, 15, 71, 54, 35, 0, 17, 58, 16, 76, 70, 36, 46, 6, 45, 68]\n"
     ]
    }
   ],
   "source": [
    "C, c, used = linear_cutting_plane(20)\n",
    "print(f'size of C: {len(C)}')\n",
    "print(f'used: {used}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "73b2139b-5986-4877-a989-2e722d41d526",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cal_linear_acc(X, y, X_test, y_test, itr_ls):\n",
    "    acc_linear_train = []\n",
    "    acc_linear_test = []\n",
    "    for i in range(len(itr_ls)):\n",
    "        C, c, used = linear_cutting_plane(itr_ls[i])\n",
    "        y_pred_train = np.sign(np.dot(X, c))\n",
    "        y_pred_test = np.sign(np.dot(X_test, c))\n",
    "        accuracy_train = np.sum(y_pred_train == y) / len(y)\n",
    "        accuracy_test = np.sum(y_pred_test == y_test) / len(y_test)\n",
    "        acc_linear_train.append(accuracy_train)\n",
    "        acc_linear_test.append(accuracy_test)\n",
    "    return acc_linear_train, acc_linear_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "9101ad3b-c949-4768-a4ef-33d1c8df2889",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_decision_boundary_linear(X, y, X_test, y_test, c, selected_indices, name):\n",
    "    # Define the grid range based on the data range\n",
    "    x_min, x_max = -1.5, 1.5 # 1.5\n",
    "    y_min, y_max = -1.5, 1.5\n",
    "\n",
    "    # Create a grid of points\n",
    "    x1 = np.linspace(x_min, x_max, 100)\n",
    "    x2 = np.linspace(y_min, y_max, 100)\n",
    "    x1, x2 = np.meshgrid(x1, x2)\n",
    "    Xtest = np.c_[x1.ravel(), x2.ravel()]\n",
    "    Xtest = np.append(Xtest, np.ones((Xtest.shape[0], 1)), axis=1)  # Add the bias term\n",
    "    \n",
    "    # Predict the labels for both training and test data\n",
    "    y_pred_train = np.sign(np.dot(X, c))  # Predictions for training data\n",
    "    y_pred_test = np.sign(np.dot(X_test, c))  # Predictions for test data\n",
    "    y_pred_all = np.sign(np.dot(X_all,c))\n",
    "    y_pred_1 = np.sign(np.dot(Xtest,c))\n",
    "    y_pred_1 = y_pred_1.reshape(x1.shape)\n",
    "    \n",
    "    # Map labels back to -1 and 1 for visualization\n",
    "    y_train_mapped = np.where(y == 1, 1, -1)\n",
    "    y_test_mapped = np.where(y_test == 1, 1, -1)\n",
    "\n",
    "    # Compute accuracy on training and test sets\n",
    "    accuracy_train = np.sum(y_pred_train == y) / len(y)\n",
    "    accuracy_test = np.sum(y_pred_test == y_test) / len(y_test)\n",
    "\n",
    "    print(f'Accuracy on training set: {accuracy_train * 100:.2f}%')\n",
    "    print(f'Accuracy on test set: {accuracy_test * 100:.2f}%')\n",
    "    \n",
    "    X_selected = X[selected_indices]\n",
    "    y_selected = y_train_mapped[selected_indices]\n",
    "\n",
    "    # Create subplots\n",
    "    fig, ax = plt.subplots(figsize=(7, 7))\n",
    "\n",
    "    # Define the custom colors\n",
    "    colors = ['#920783', '#00b7c7']  # Switched the colors to match the image\n",
    "    cmap = mcolors.ListedColormap(colors)\n",
    "\n",
    "    # Plot the decision boundary with custom colors\n",
    "    ax.contourf(x1, x2, y_pred_1, alpha=0.3, cmap=cmap)\n",
    "    scatter_train = ax.scatter(X[:, 0], X[:, 1], c=y_train_mapped, edgecolor='k', s=20, cmap=cmap,\n",
    "                               label='Train Data')\n",
    "    scatter_test = ax.scatter(X_test[:, 0], X_test[:, 1], c=y_test_mapped, edgecolor='k', s=20, cmap=cmap,\n",
    "                              marker='^', label = 'Test Data')\n",
    "    scatter_select = ax.scatter(X_selected[:,0], X_selected[:,1], c=y_selected, s=80, cmap=cmap, marker='x',\n",
    "                               label='Queried Data')\n",
    "    \n",
    "    ax.set_xlabel('x1')\n",
    "    ax.set_ylabel('x2')\n",
    "    ax.set_xlim(x_min, x_max)\n",
    "    ax.set_ylim(y_min, y_max)\n",
    "    ax.set_title(f'{name}')\n",
    "    plt.legend()\n",
    "    plt.savefig(f'{name}.pdf', bbox_inches='tight')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "9bea8ee7-5551-4960-b689-e989a16323cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy on training set: 50.00%\n",
      "Accuracy on test set: 50.00%\n"
     ]
    },
    {
     "data": {
      "image/png": "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j4spU6YIAGLTpk1yvQSrkJWVVfxzGICYP3++iI+PF5cvXxZC8JyuLpWd5+o6nxn4yjBmzBgBoNTX7t27i7cBIJYvXy6EECI7O1tEREQId3d3YWNjIxo0aCDGjBkjkpKS5HkBVqKy8yxE0dIs7733nvDy8hJarVaEhYWJxMRE8xdvRVJTU8WIESOEk5OTcHJyEiNGjCh1eT/P56r54osvhK+vr7C1tRXt2rUTMTExxY+NGTNGdOvWrcT2e/bsEUFBQcLW1lb4+fmJr776yswVW6/KzPXcuXNF48aNhZ2dnahdu7bo0qWL+Omnn2So2rrcXf7j/q8xY8YIIXhOV5fKznN1nc+SEH9/wpKIiIiIFInLshAREREpHAMfERERkcIx8BEREREpHAMfERERkcIx8BEREREpHAMfERERkcIx8BEREREpHAMfERERkcIx8BEREREpHAMfEZGJXL16FcOHD0ezZs2gUqkwadIkuUsiohqKgY+IyETy8vLg7u6OqVOnok2bNnKXQ0Q1GAMfEVEVpaSkwMvLC7Nnzy4eO3ToEGxtbbFjxw74+fnh008/xejRo6HT6WSslIhqOo3cBRARWSt3d3d8++23GDhwICIiIhAQEICRI0diwoQJiIiIkLs8IqJiDHxERA+hX79+eP755zFixAh06NABdnZ2mDNnjtxlERGVwLd0iYge0scff4zCwkJERkZi9erVsLOzk7skIqISGPiIiB7ShQsXcOXKFRgMBly+fFnucoiISuFbukREDyE/Px8jRozA0KFDERAQgHHjxiExMRGenp5yl0ZEVIyBj4joIUydOhUZGRn47LPP4OjoiJ9//hnjxo3Djz/+CABISEgAANy+fRspKSlISEiAra0tWrRoIWPVRFTTSEIIIXcRRETWaM+ePejVqxd2796NLl26AACSkpLQunVrfPjhhxg/fjwkSSq1n6+vLy5dumTmaomoJmPgIyIiIlI4XrRBREREpHAMfEREREQKx8BHREREpHAMfEREREQKx8BHREREpHAMfEREREQKx8BHREREpHAMfEREREQKx8BHREREpHAMfEREREQKx8BHREREpHD/Dwx3xzs6r4vdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_decision_boundary_linear(X, y, Xacc, yacc, c, used, 'Linear')"
   ]
  }
 ],
 "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
