{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from reluNets.plotting.network_plotting_functions import plot_single_metric_axis, plot_several_metrics, save_figure\n",
    "from reluNets.analytical_solutions.analytical_solutions import analytical_svs, ana_weights, ana_outputs, ana_loss\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "import matplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [],
   "source": [
    "choice_temp = 0.2\n",
    "scale = 0.0002\n",
    "bucket_size = 1\n",
    "log_interval = 1 * bucket_size\n",
    "model_name = \"relu_net\"\n",
    "folder = \"model_runs_local\"\n",
    "save_folder = \"relu_nets_bias\"\n",
    "bias_input = True\n",
    "metrics = [\"loss\", \"accuracy\",\"TPR_top_level\", \n",
    "            \"TPR_mid_level\", \"TPR_bottom_level\", \"TNR_top_level\",\n",
    "            \"TNR_mid_level\", \"TNR_bottom_level\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# lets get our exact solutions for the weights now\n",
    "# start with loading data\n",
    "n = 4\n",
    "\n",
    "train_inputs = np.array([[1, -1, 0], [1, 0, 1], [1, 0, -1], [1, 1, 0]]).T\n",
    "train_labels = np.array([[1, 0], [0, 1], [0, 1], [1, 0]]).T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the input and output covariance matrices\n",
    "input_covar = 1/(n)*(train_inputs @ train_inputs.T)\n",
    "output_covar = 1/(n)*(train_labels @ train_inputs.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the decomposition of these matrices\n",
    "u, s, vt =  np.linalg.svd(output_covar, full_matrices=False)\n",
    "s = s[:,np.newaxis]\n",
    "_, delta, _ =  np.linalg.svd(input_covar, full_matrices=False)\n",
    "delta = delta[:,np.newaxis]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[-0.70710678],\n",
       "        [-0.70710678]]),\n",
       " array([[0.70710678]]),\n",
       " array([[-1.,  0.,  0.]]),\n",
       " array([[1.]]))"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "s = s[:1]\n",
    "vt = vt[:1]\n",
    "u = u[:,:1]\n",
    "delta = delta[:1]\n",
    "u, s , vt, delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# hyperparameters\n",
    "t= np.arange(0, 20000, 1)[np.newaxis]\n",
    "a_0 = 0.0000013\n",
    "step_size = 0.001 # should load this from the wandb config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "ana_sol_svs = analytical_svs(t, s, delta, a_0, step_size=step_size, batch_size=n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the analytical outputs (time x outputs x n)\n",
    "ana_outputs = ana_outputs(u, ana_sol_svs, vt, train_inputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "# calculate the analytical loss at each time step\n",
    "ana_loss_bias = ana_loss(u, ana_sol_svs, vt, train_inputs, train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 2.000000238418579\n",
      "Epoch 1000, Loss 1.9995911121368408\n",
      "Epoch 2000, Loss 1.8941981792449951\n",
      "Epoch 3000, Loss 1.0032507181167603\n",
      "Epoch 4000, Loss 0.9999669194221497\n",
      "Epoch 5000, Loss 0.9998496174812317\n",
      "Epoch 6000, Loss 0.9993806481361389\n",
      "Epoch 7000, Loss 0.997461199760437\n",
      "Epoch 8000, Loss 0.9896934032440186\n",
      "Epoch 9000, Loss 0.9596346616744995\n",
      "Epoch 10000, Loss 0.860362708568573\n",
      "Epoch 11000, Loss 0.6367102861404419\n",
      "Epoch 12000, Loss 0.3205082416534424\n",
      "Epoch 13000, Loss 0.09451418370008469\n",
      "Epoch 14000, Loss 0.027407724410295486\n",
      "Epoch 15000, Loss 0.009068422950804234\n",
      "Epoch 16000, Loss 0.00323014915920794\n",
      "Epoch 17000, Loss 0.00120796007104218\n",
      "Epoch 18000, Loss 0.0004641306586563587\n",
      "Epoch 19000, Loss 0.00018118336447514594\n"
     ]
    }
   ],
   "source": [
    "# train a small relu network on the task xor task \n",
    "# hyperparameters\n",
    "input_size = 3\n",
    "hidden_size = 64\n",
    "output_size = 2\n",
    "\n",
    "# define a pytorch model and initialize weights as small gaussian\n",
    "class ReluNet(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(ReluNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=False)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return torch.relu(self.fc1(x))\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    \n",
    "# initialize the model\n",
    "model = ReluNet()\n",
    "# initialize the weights\n",
    "model.fc1.weight.data = torch.randn_like(model.fc1.weight.data)*0.0002\n",
    "model.fc2.weight.data = torch.randn_like(model.fc2.weight.data)*0.0002\n",
    "\n",
    "# initialize the biases to zero on the hidden layer if they are present\n",
    "if model.fc1.bias is not None:\n",
    "    init_bias_1 = torch.randn_like(model.fc1.bias.data)*0.0002\n",
    "    model.fc1.bias.data = init_bias_1\n",
    "if model.fc2.bias is not None:\n",
    "    init_bias_2 = torch.randn_like(model.fc2.bias.data)*0.0002\n",
    "    model.fc2.bias.data = init_bias_2\n",
    "    \n",
    "# load the data we do not need test data with pytorch dataloaders\n",
    "train_loader = DataLoader(torch.utils.data.TensorDataset(torch.tensor(train_inputs.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=True)\n",
    "\n",
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001)\n",
    "\n",
    "# define the loss function\n",
    "loss = torch.nn.MSELoss(reduction='sum')\n",
    "\n",
    "# train the model\n",
    "def train(model, train_loader, optimizer):\n",
    "    losses = []\n",
    "    representations = []\n",
    "    for epoch in range(20000):\n",
    "        for inputs, labels in train_loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            loss_val = 1/2 * loss(outputs, labels)\n",
    "            loss_val.backward()\n",
    "            optimizer.step()\n",
    "            losses.append(loss_val.item())\n",
    "            # print every 1000th epoch\n",
    "            if epoch % 1000 == 0:\n",
    "                print(f\"Epoch {epoch}, Loss {loss_val.item()}\")\n",
    "                \n",
    "    return losses, np.array(representations)\n",
    "\n",
    "losses, rep = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 2.0000009536743164\n",
      "Epoch 1000, Loss 1.9990614652633667\n",
      "Epoch 2000, Loss 1.7784323692321777\n",
      "Epoch 3000, Loss 1.00064218044281\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 0.9999999403953552\n",
      "Epoch 8000, Loss 1.0\n",
      "Epoch 9000, Loss 1.0000001192092896\n",
      "Epoch 10000, Loss 1.0000001192092896\n",
      "Epoch 11000, Loss 1.0000001192092896\n",
      "Epoch 12000, Loss 1.0000001192092896\n",
      "Epoch 13000, Loss 1.0000001192092896\n",
      "Epoch 14000, Loss 1.0000001192092896\n",
      "Epoch 15000, Loss 1.0000001192092896\n",
      "Epoch 16000, Loss 1.0000001192092896\n",
      "Epoch 17000, Loss 1.0000001192092896\n",
      "Epoch 18000, Loss 1.0000001192092896\n",
      "Epoch 19000, Loss 1.0000001192092896\n"
     ]
    }
   ],
   "source": [
    "input_size = 3\n",
    "hidden_size = 64\n",
    "output_size = 2\n",
    "\n",
    "class LinearNet(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(LinearNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=False)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return self.fc1(x)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "model = LinearNet()\n",
    "# initialize the weights\n",
    "model.fc1.weight.data = torch.randn_like(model.fc1.weight.data)*0.0002\n",
    "model.fc2.weight.data = torch.randn_like(model.fc2.weight.data)*0.0002\n",
    "\n",
    "# initialize the biases to zero on the hidden layer if they are present\n",
    "if model.fc1.bias is not None:\n",
    "    init_bias_1 = torch.randn_like(model.fc1.bias.data)*0.0002\n",
    "    model.fc1.bias.data = init_bias_1\n",
    "if model.fc2.bias is not None:\n",
    "    init_bias_2 = torch.randn_like(model.fc2.bias.data)*0.0002\n",
    "    model.fc2.bias.data = init_bias_2\n",
    "\n",
    "# load the data we do not need test data with pytorch dataloaders\n",
    "train_loader = DataLoader(torch.utils.data.TensorDataset(torch.tensor(train_inputs.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=True)\n",
    "\n",
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001)\n",
    "\n",
    "losses_linear_bias, rep_linear_bias = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# lets get our exact solutions for the weights for linear net without a bias term\n",
    "# start with loading data\n",
    "n = 4\n",
    "train_inputs = np.array([[-1, 0], [0, 1], [0, -1], [1, 0]]).T\n",
    "# code xor labels as 1-hot\n",
    "train_labels = np.array([[1, 0], \n",
    "                         [0, 1], \n",
    "                         [0, 1], \n",
    "                         [1, 0]]).T\n",
    "# load the input and output covariance matrices\n",
    "input_covar = 1/(n)*(train_inputs @ train_inputs.T)\n",
    "output_covar = 1/(n)*(train_labels @ train_inputs.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the decomposition of these matrices\n",
    "u, s, vt =  np.linalg.svd(output_covar, full_matrices=False)\n",
    "s = s[:,np.newaxis]\n",
    "_, delta, _ =  np.linalg.svd(input_covar, full_matrices=False)\n",
    "delta = delta[:,np.newaxis]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[1., 0.],\n",
       "        [0., 1.]]),\n",
       " array([[0.],\n",
       "        [0.]]),\n",
       " array([[1., 0.],\n",
       "        [0., 1.]]),\n",
       " array([[0.5],\n",
       "        [0.5]]))"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u, s, vt, delta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ana_sol_svs = analytical_svs(t, s, delta, a_0, step_size=step_size, batch_size=n)\n",
    "ana_loss_no_bias = ana_loss(u, ana_sol_svs, vt, train_inputs, train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 2.0\n",
      "Epoch 2000, Loss 2.0\n",
      "Epoch 3000, Loss 2.0\n",
      "Epoch 4000, Loss 2.0\n",
      "Epoch 5000, Loss 2.0\n",
      "Epoch 6000, Loss 2.0\n",
      "Epoch 7000, Loss 2.0\n",
      "Epoch 8000, Loss 2.0\n",
      "Epoch 9000, Loss 2.0\n",
      "Epoch 10000, Loss 2.0\n",
      "Epoch 11000, Loss 2.0\n",
      "Epoch 12000, Loss 2.0\n",
      "Epoch 13000, Loss 2.0\n",
      "Epoch 14000, Loss 2.0\n",
      "Epoch 15000, Loss 2.0\n",
      "Epoch 16000, Loss 2.0\n",
      "Epoch 17000, Loss 2.0\n",
      "Epoch 18000, Loss 2.0\n",
      "Epoch 19000, Loss 2.0\n"
     ]
    }
   ],
   "source": [
    "input_size = 2\n",
    "hidden_size = 64\n",
    "output_size = 2\n",
    "\n",
    "class LinearNet(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(LinearNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=False)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return self.fc1(x)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "\n",
    "model = LinearNet()\n",
    "# initialize the weights\n",
    "model.fc1.weight.data = torch.randn_like(model.fc1.weight.data)*0.0002\n",
    "model.fc2.weight.data = torch.randn_like(model.fc2.weight.data)*0.0002\n",
    "\n",
    "# load the data we do not need test data with pytorch dataloaders\n",
    "train_loader = DataLoader(torch.utils.data.TensorDataset(torch.tensor(train_inputs.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=True)\n",
    "\n",
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001)\n",
    "\n",
    "losses_linear_no_bias ,_ = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.9999842643737793\n",
      "Epoch 2000, Loss 1.999882459640503\n",
      "Epoch 3000, Loss 1.9991334676742554\n",
      "Epoch 4000, Loss 1.993621826171875\n",
      "Epoch 5000, Loss 1.9538893699645996\n",
      "Epoch 6000, Loss 1.704699993133545\n",
      "Epoch 7000, Loss 0.8955293297767639\n",
      "Epoch 8000, Loss 0.199192613363266\n",
      "Epoch 9000, Loss 0.02230796590447426\n",
      "Epoch 10000, Loss 0.0020130202174186707\n",
      "Epoch 11000, Loss 0.00019310330389998853\n",
      "Epoch 12000, Loss 1.9713668734766543e-05\n",
      "Epoch 13000, Loss 2.09785275728791e-06\n",
      "Epoch 14000, Loss 2.2989834747022542e-07\n",
      "Epoch 15000, Loss 2.6521735918549894e-08\n",
      "Epoch 16000, Loss 4.666213637705141e-09\n",
      "Epoch 17000, Loss 2.0616999218958654e-09\n",
      "Epoch 18000, Loss 1.6362221577637115e-09\n",
      "Epoch 19000, Loss 1.5377038531383391e-09\n"
     ]
    }
   ],
   "source": [
    "input_size = 2\n",
    "hidden_size = 64\n",
    "output_size = 2\n",
    "class ReluNet(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(ReluNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=False)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "\n",
    "    def get_hidden(self, x):\n",
    "        return torch.relu(self.fc1(x))\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "\n",
    "model = ReluNet()\n",
    "# initialize the weights\n",
    "model.fc1.weight.data = torch.randn_like(model.fc1.weight.data)*0.0002\n",
    "model.fc2.weight.data = torch.randn_like(model.fc2.weight.data)*0.0002\n",
    "\n",
    "# load the data we do not need test data with pytorch dataloaders\n",
    "train_loader = DataLoader(torch.utils.data.TensorDataset(torch.tensor(train_inputs.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=True)\n",
    "\n",
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001)\n",
    "\n",
    "losses_relu_no_bias, rep_relu_no_bias = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 680x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses = np.array(losses)\n",
    "fig, (ax2, ax3) = plt.subplots(1, 2, figsize=(3.4, 2), dpi=200)\n",
    "# plot the dataset\n",
    "# make a symbol list with plus and minus for the scatterplot\n",
    "y_tick_fontsize = 7\n",
    "x_tick_fontsize = 7\n",
    "plot_single_metric_axis(ax2, \n",
    "                        metric_array=losses, \n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=log_interval, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.6, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=11)\n",
    "ax2.plot(losses_linear_bias, color=color_list[1], label=\"linear\", linewidth=1.6)\n",
    "ax2.plot(ana_loss_bias, color=color_list[2], linestyle=\"--\", label=\"Analytical\", linewidth=2)\n",
    "ax2.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax2.set_xlim([-100, 12800])\n",
    "# set title \n",
    "ax2.set_title(\"Bias\", fontsize=10)\n",
    "ax2.xaxis.get_offset_text().set_fontsize(9)\n",
    "\n",
    "plot_single_metric_axis(ax3,\n",
    "                        metric_array=np.array(losses_relu_no_bias), \n",
    "                        y_label=None,\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=log_interval, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.6, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=11)\n",
    "ax3.yaxis.set_tick_params(labelleft=False)\n",
    "\n",
    "ax3.plot(losses_linear_no_bias, color=color_list[1], label=\"Linear\", linewidth=1.6)\n",
    "\n",
    "ax3.legend(prop={'size': 5})\n",
    "ax3.set_xlim([-200, 12800])\n",
    "# set title \n",
    "ax3.set_title(\"No Bias\", fontsize=10)\n",
    "ax3.xaxis.get_offset_text().set_fontsize(9)\n",
    "plt.tight_layout()\n",
    "\n",
    "save_figure('/relu_nets_bias/', 'Input_bias_relu_vs_linear_xor_loss', fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vlauXFnfJTm9++67OnnypCZNmuQMSElq0aKFnn76aY0aNUqrVq2qcY8yNTVVkrRgwQJnQErSoEGDlJiYqO3bt+vTTz9V165dParPNE2VlJS43f7tLnd41n9YiMwAf+fPe26r+dGCV7rz2w88at/QlZaWqry83PnztY7xcNXUx8OTzw9ff3bY8YS3BhOSktStWzeFh4fr7bffru9SXKSlpUmS7rzzzirzKqe5sweYlpamZs2aqX///lXmVYbknj17PA7J4uJijw7VViTf5VH/CgyQbuogSTIfGCKz1LOLqpraYeTK0wSSdOLECfn5Xdt3UjEerpr6eHj0+eHjz47i4mKP2rujQYVkaWmpLl68aMuG1kXlRTVXO5waERGhyMjIGi+8KSws1NmzZ9WrVy+Xh75XquybC3gAoOFoUCH5xhtvqLS0VNdff319l+IiLy9PkuRwOK46Pzw8XF999VWd+7iynSdCQkLUo0cPt9t/9cpbHvVvhoXIHDlYkmRsfkdGkWd/xPT4yzyP2jd0paWlOn78uKTLRz8CAwPruaL6xXi4aurj4cnnh68/O0JCQjxq7456D8mSkhKdOXNGr732mhYuXCjDMHTXXR4eDrzGGYahoKAgt9sPyXzX7bYl5y9oz20jZJRdPsdiFBUr7r1XFeTBCXVPamssKo8GBAYGNsnt8xTj4aopj4e7nx/18dnh6T357vDp90nWxDRNtW/fXikpKTZW5LnKvT+rvbz8/HzLPURP+riynZ3qesVYUJtWDeKqMwC+V5f/+43xs8P2M8ruPkAgJCREY8eO1fvvv6/rrrvO7rI8Ut35wpycHGVnZ9d4+0ezZs0UHR2tL774wnnl25WqO+8JAKgf9f59kgEBAYqIiFDXrl0VEFDvR3+vKi4uTosWLdLOnTs1atQol3k7d+50tnGnnw0bNujAgQNVnk27Y8cOt/sBAPgG3yfphkGDBqlz585at26dfv3rX+snP/mJJKmgoEDz589XQECAJk6c6GyfnZ2t7OxsRUZGKjIy0jn9oYce0oYNGzRnzhy98847zuPtu3bt0o4dOzRw4ECPb/8AANinad3AY5OAgACtWLFCFRUVGjBggB566CHNnDlTvXv31r///W/NnTvXJdyWLVumH/3oR1q2bJlLPwkJCZo8ebL27dunPn366Le//a0mTJigu+++W+Hh4frb3/7m600DAFTD9pD08/NT+/bt3W5/ww03NMjDrgkJCdq/f79uv/12bdq0Sc8//7xat26ttWvX6qmnnnK7n+XLl2vJkiUyDENLlizRtm3bdO+99+qDDz7w6DYOAID9fJJGnj4qyI5HC3lDv3799NZbNd8jNHfuXM2dO/eq8/z8/DRjxgzNmDHDy9UBALytwR1uLSkpaXKPcQIANE4NKo1yc3P17bffqmXLlvVdCgAA3j/c+vHHH+vIkSMu0y5evKiXXnrJchnTNJWbm6tXX31VFRUV6tu3r7fLAgDAY14Pyddff13PPPOMy7T8/HxNmjSpxmVN05RhGPrNb37j7bIAAPCY10OyZcuW6tixo/Pfp0+flp+fX7UPLffz81N4eLh69eqlhx56SAMGDPB2Wail4DatdOe3Hzi/sqbHX+Y1uWdRAvC+pvLZ4fWQfOSRR/TII484/+3n56c2bdroiy++8PaqAACwle23gKSkpKh58+Z2rwYAAK/zSUgCANAYNahbQAAAaEh8+vy39957T/v379dXX32lwsJCyyfrGIahv//9774sDQCAKnwSkpmZmRozZowyMjJcplfe8nG1aYQkAKC+2R6S//nPf3THHXfo66+/VlRUlOLi4rRp0yaFhobqF7/4hc6dO6f09HQVFBQoMjJSd999t90lAQDgFtvPST733HP6+uuvFRsbq5MnT2rDhg2SJIfDoZdeekk7d+7UN998o1mzZik7O1uhoaFatWqV3WUBAFAj2/ckt23bJsMwtHDhQoWFhV21TbNmzfTHP/5RJSUlWrJkiRISEjRy5Ei7SwMAoFq270mePHlShmFUeYpOSUlJlbazZ8+WJL344ot2lwUAQI1sD8nS0lI5HA6XL1IOCwtTQUFBlbZRUVFyOBz6+OOP7S4LAIAa2R6S1113nfLy8lRWVuacFhUVpbKyMn3++ecubUtLS5Wfn6+8vDy7ywIAoEa2h+QNN9wg0zR15swZ57Rbb71VkrR27VqXtqtXr1ZFRYXat29vd1kAANTI9pC88847JUnbt293Ths3bpxM09SCBQv08MMPKzU1VdOnT9f06dNlGIaGDx9ud1kAANTI9pAcNmyYOnTooH379jmn3X333Ro1apTKysr0wgsvaOrUqfrb3/6m0tJSde/eXb///e/tLgsAgBrZfgtI165dderUqSrTX3nlFSUkJGjjxo06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mGFhYWZQUJB5ww03mL/85S/NY8eO+WhLPJOenm4mJSWZDofDDA0NNW+55RZz7dq1VdpV90FYXl5uLlmyxOzZs6cZHBxstm7d2hwxYoTL3ldjUNexePbZZ834+HjzuuuuM4OCgsywsDDz5ptvNp966qkGfzTlhyqPoli9rtz2pvDeMEzzBydbAACAJC7cAQDAEiEJAIAFQhIAAAuEJAAAFghJAAAsEJIAAFggJAEAsEBIAgBggZAEAMACIQkAgAVCEgAAC4QkAAAWCEkAACwQkgAAWCAkAQCwQEgCNps7d64Mw3Dr1RA899xzmjt3ro4cOVLfpdguNzdXb775pn7/+9/rnnvuUXR0tPN3sXr16vouDw1AQH0XAFxLoqKi6ruEGj333HM6ffq0YmJi9JOf/KS+y7HVG2+8oUmTJtV3GWjACEnAh86dO1ffJeAH2rVrpz59+qhv377q27evfvGLX9R3SWhACEkA16yxY8dq4sSJ9V0GGjDOSQINWF5env7whz8oNjZWERERCg4OVocOHTR69Gi9//77lsudOHFCixcv1uDBg3XjjTcqNDRU4eHh6tOnj+bMmaPs7Owqy1SeOz19+rQkadKkSZbnTNPS0tw6j1rZJi0tzWX6D5c/fPiwkpOTdf311yswMFDx8fEu7cvLy7V69WolJiYqKipKQUFBatOmjRITE7VhwwaZplltHVYCAthPQPV4hwANVHp6uoYNG6asrCxJkr+/v8LCwvTVV19pw4YN2rhxo/7whz/od7/7XZVlExMTnWFnGIYcDofy8vJ05MgRHTlyRKtXr9auXbvUrVs35zLNmzdXVFSUzp8/r4qKCoWHhys0NNT27Xzttdc0evRolZaWKjw8vEpwZWVladiwYUpPT3dOczgcys7O1s6dO7Vz506tX79emzdvVlBQkO314trCniTQAJ06dUpJSUnKysrSiBEj9H//938qLi5Wfn6+srKy9PTTT8vf319PPvmk3njjjSrL/+xnP9PSpUv12Wefqbi4WDk5OSouLtY777yjfv366euvv9aYMWNclpk5c6bOnTunDh06SJL++te/6ty5cy4vO0ycOFFDhgzRsWPHlJeXp4sXLyo1NVWSVFJSonvvvVfp6enq27evtm3bpsLCQuXm5uq7777TmjVr1LZtW23dulVPPPGELfXhGmcCsFVKSoopyZRkRkVFWb7+9a9/OZcZMWKEKckcN26cZb//+7//a0oye/fu7VE9BQUFZlRUlCnJ3LdvX5X5nTp1MiWZq1atsuxj9+7dzm2qTmWb3bt3Wy7fr18/s6ys7KrLL1u2zJRk9uzZ08zPz79qmw8//NA0DMMMCgoys7Kyqq3HHZV1Vbf9uHawJwn4UFZWluWrtLRUknThwgVt2bJFkjR79mzLvsaPHy9J+uijj5yHZN3RvHlzxcXFSZL2799f203xmlmzZsnf3/+q81asWCFJ+p//+R+1aNHiqm1++tOfqmfPniopKdHu3bttqxPXJs5JAj5kunGBycGDB1VRUSFJuuOOO9zq9/Tp01XuwfzHP/6hl19+WYcOHVJWVpaKioqqLPfVV1+51b+d+vfvf9XpBQUF+vjjjyVJTz/9tJ555hnLPi5cuCBJzvOwgLcQkkAD88033zh/dncP8coArKio0NixY7V+/XrntICAAEVERDgvbMnLy1NxcbEKCwu9VHXttW3b9qrTz5075/xjoTIEa3K1PwSAuiAkgQamvLxckhQaGlqrD/2///3vWr9+vfz9/fXUU09p3Lhx6ty5s/z8vj+7Mm7cOK1du7bWt054k9Wh1spxkKT3339fsbGxvioJcOKcJNDAtGvXTpJ08eJFffbZZx4vv2HDBknS5MmTNW/ePN10000uASnV/ck/V96mUVxcfNU2eXl5dVrHlYePP/nkkzr1BdQWIQk0MLfddpvzJvvKwPPEmTNnJEl9+vS56vzvvvvO5Z7DH6oM1Or2MiMiIqqs74eqW4c7IiIi1KNHD0m1GwfAGwhJoIFp27athg0bJklavHixPv3002rb//B8ncPhkHT5qtermT9/vgoKCiz7Cw8Pl3T5GzKsdO3a1fmggddee63K/IqKCi1atKjaut3x0EMPSZJ27dpVY1C6e94S8AQhCTRAf/7zn9W6dWvl5+fr9ttv18qVK10OX2ZnZ2vLli26//77NXr0aJdlk5KSJEmpqal68cUXVVJSIunyIdbHHntMf/rTn9S6dWvLdffq1UuS9OqrryonJ+eqbQIDA50PAl+4cKE2bdrkXM+JEyd03333WYa0J6ZOneo8Fzlu3DjNmTPHZc+1qKhIaWlpmj59um688cZarSM7O9vlVem7775zmc5FQdeoer5PE2jyrnyYgCcyMjLMmJgY57KGYZgRERFm8+bNndMkmYMHD3ZZLicnx+zevbtzvp+fn9myZUvTMAxTkvmrX/3KnDBhginJnDBhQpX17tmzx9nW39/fjI6ONjt16mR26tTJpd2ZM2fM6667zrmewMBAMzw83JRktmjRwkxLS3PrYQI1OX/+vHnHHXe4bHN4eLjLNkkyAwICPBrfSlf2W90rJSWlVv2jcWNPEmig+vTpo6NHj2rZsmUaPHiwIiMjVVBQoIqKCnXp0kVjxozRhg0bnA8eqNSyZUu99957evTRRxUTEyN/f38FBAQoPj5e69ev1wsvvFDtegcOHKht27Zp8ODBcjgcysrK0unTp6vcg3j99dcrPT1dkydPVvv27SVdflDB+PHjlZGR4XxgQV1FRkbqnXfe0ZtvvqkRI0aoQ4cOunTpki5evKj27dvrrrvu0rJly3Tq1CmvrA+4kmGaDeAacAAAGiD2JAEAsEBIAgBggZAEAMACIQkAgAVCEgAAC4QkAAAWCEkAACwQkgAAWCAkAQCwQEgCAGCBkAQAwAIhCQCABUISAAALhCQAABYISQAALBCSAABYICQBALBASAIAYIGQBADAAiEJAIAFQhIAAAuEJAAAFghJAAAs/D+r9bTB2i74QgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 420x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax1) = plt.subplots(1, 1, figsize=(2.1, 2), dpi=200)\n",
    "y_tick_fontsize = 7\n",
    "x_tick_fontsize = 7\n",
    "symbol_list = [\"+\", \"x\"]\n",
    "ax1.scatter(train_inputs[0, :], train_inputs[1, :], c=train_labels[0, :], cmap=\"coolwarm\", s=100, marker=symbol_list[0])\n",
    "# ax1.set_title(\"XOR-type dataset\", fontsize=8, fontweight=\"bold\")\n",
    "for spine in ax1.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "ax1.tick_params(axis='x', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "ax1.tick_params(axis='y', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "# add x and y axis labels\n",
    "ax1.set_xlabel(\"Feature 1\", fontsize=9)\n",
    "ax1.set_ylabel(\"Feature 2\", fontsize=9)\n",
    "# ad a grid\n",
    "ax1.grid(alpha=0.6)\n",
    "# set x and y limits\n",
    "ax1.set_xlim([-1.2, 1.2])\n",
    "ax1.set_ylim([-1.2, 1.2])\n",
    "# save the figure\n",
    "save_figure('/relu_nets_bias/', 'xor_dataset', fig)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "behav-analysis-fmri",
   "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.10.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
