{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 516,
   "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\n",
    "from omegaconf import OmegaConf\n",
    "from torch import nn\n",
    "from importlib import import_module\n",
    "from copy import deepcopy\n",
    "# This notebook plot the TNR and TPR of the relu net"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This is just a toy attempt all below is kinda crap and did not yield meaningful results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 517,
   "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"
   ]
  },
  {
   "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 = 5\n",
    "offset = 0.5\n",
    "bias = 1 \n",
    "train_inputs = np.array([[bias, 1, 0, offset], [bias, -1, 0, offset], [bias, 0, 1, -offset], [bias, 0, -1, -offset]]).T\n",
    "train_labels = np.array([[1, 0], [1, 0], [0, 1], [0, 1]]).T\n",
    "n = train_inputs.shape[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 0.5\n",
    "train_inputs = np.array([[bias, 1, 0, offset], [bias, -1, 0, offset], [bias, 0, 1, -offset], [bias, 0, -1, -offset]]).T\n",
    "fig = plt.figure(figsize=(5, 5))\n",
    "ax = fig.add_subplot( projection='3d')\n",
    "x = train_inputs[1].tolist()\n",
    "y = train_inputs[2].tolist()\n",
    "z = train_inputs[3].tolist()\n",
    "ax.scatter(x, y, z, marker=\"+\", c=[\"red\", \"red\", \"blue\", \"blue\"], s=250, linewidths=3)\n",
    "ax.plot([x[0], x[1]], [y[0], y[1]], [z[0], z[1]], color=\"black\",linestyle=\":\", linewidth=1.5)\n",
    "ax.plot([x[2], x[3]], [y[2], y[3]], [z[2], z[3]], color=\"black\",linestyle=\":\", linewidth=1.5)\n",
    "ax.plot([0, 0], [0, 0], [.5, -.5], color=\"black\",linestyle=\"-\", linewidth=2.2)\n",
    "# plot an arrow on the third line that has an arrow on\n",
    "# change ticks on all axes to be only at -1,0,1\n",
    "ax.set_xticks([-1, 0, 1])\n",
    "ax.set_yticks([-1, 0, 1])\n",
    "ax.set_zticks([-.5, 0, .5])\n",
    "ax.xaxis.pane.fill = False\n",
    "ax.yaxis.pane.fill = False\n",
    "ax.zaxis.pane.fill = False\n",
    "# set x y and z labels\n",
    "ax.set_xlabel(\"feature 1\", fontsize=14)\n",
    "ax.set_ylabel(\"feature 2\", fontsize=14)\n",
    "# ax.set_zlabel(\"linear feature\")\n",
    "# move location of z axis to the left\n",
    "ax.zaxis.set_ticks_position('lower')\n",
    "ax.view_init(elev=30, azim=-40)  # azim controls left/right rotation\n",
    "ax.text2D(0.02, 0.9, \"linear feature\", transform=ax.transAxes, \n",
    "          rotation=90, va='center', ha='center', fontsize=14)\n",
    "# save_figure('/relu_nets_bias/', '3D-XOR_problem', fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 536,
   "metadata": {},
   "outputs": [],
   "source": [
    "# generate a mesh over the input space to visualize the predicitons, I need this in pytorch \n",
    "n_grid = 100\n",
    "x1 = np.linspace(-1.05, 1.05, n_grid)\n",
    "x2 = np.linspace(-1.05, 1.05, n_grid)\n",
    "x3 = np.linspace(-.28, .28, n_grid)\n",
    "x1, x2, x3 = np.meshgrid(x1, x2, x3)\n",
    "x1 = x1.flatten()\n",
    "x2 = x2.flatten()\n",
    "x3 = x3.flatten()\n",
    "x4 = np.ones_like(x1)\n",
    "x_grid = np.vstack([x4, x1, x2, x3]).T\n",
    "x_grid = torch.tensor(x_grid, dtype=torch.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# train a small relu network on the task xor task \n",
    "# hyperparameters\n",
    "input_size = 4\n",
    "hidden_size = 64\n",
    "output_size = 2\n",
    "n_epochs = 18000\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 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",
    "# 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, x_grid=x_grid):\n",
    "    losses = []\n",
    "    for epoch in range(n_epochs):\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",
    "    with torch.no_grad():\n",
    "        mesh_outputs = model(x_grid).numpy()    \n",
    "    return losses, mesh_outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 539,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 1.9999992847442627\n",
      "Epoch 1000, Loss 1.9995052814483643\n",
      "Epoch 2000, Loss 1.8772284984588623\n",
      "Epoch 3000, Loss 0.9977593421936035\n",
      "Epoch 4000, Loss 0.9270333647727966\n",
      "Epoch 5000, Loss 0.39240357279777527\n",
      "Epoch 6000, Loss 0.011283309198915958\n",
      "Epoch 7000, Loss 7.405788346659392e-05\n",
      "Epoch 8000, Loss 4.4358387185639003e-07\n",
      "Epoch 9000, Loss 3.4668303783291776e-09\n",
      "Epoch 10000, Loss 3.677841087235123e-10\n",
      "Epoch 11000, Loss 2.928592923723272e-10\n",
      "Epoch 12000, Loss 2.88112922408601e-10\n",
      "Epoch 13000, Loss 2.867540371820354e-10\n",
      "Epoch 14000, Loss 2.855817804459093e-10\n",
      "Epoch 15000, Loss 2.851768265976773e-10\n",
      "Epoch 16000, Loss 2.8476099256380394e-10\n",
      "Epoch 17000, Loss 2.82861567502124e-10\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.9994821548461914\n",
      "Epoch 2000, Loss 1.871536135673523\n",
      "Epoch 3000, Loss 0.9974535703659058\n",
      "Epoch 4000, Loss 0.9252849817276001\n",
      "Epoch 5000, Loss 0.3775232434272766\n",
      "Epoch 6000, Loss 0.010542366653680801\n",
      "Epoch 7000, Loss 7.517185440519825e-05\n",
      "Epoch 8000, Loss 4.878255026596889e-07\n",
      "Epoch 9000, Loss 3.5105744977670383e-09\n",
      "Epoch 10000, Loss 3.42778694317758e-10\n",
      "Epoch 11000, Loss 3.216459043553499e-10\n",
      "Epoch 12000, Loss 3.1962485436132226e-10\n",
      "Epoch 13000, Loss 3.160571249161137e-10\n",
      "Epoch 14000, Loss 3.133350245931865e-10\n",
      "Epoch 15000, Loss 3.113028168577614e-10\n",
      "Epoch 16000, Loss 3.0830218933353137e-10\n",
      "Epoch 17000, Loss 3.0540633910725035e-10\n",
      "Epoch 0, Loss 1.9999998807907104\n",
      "Epoch 1000, Loss 1.9995453357696533\n",
      "Epoch 2000, Loss 1.8861465454101562\n",
      "Epoch 3000, Loss 0.9991480112075806\n",
      "Epoch 4000, Loss 0.9424475431442261\n",
      "Epoch 5000, Loss 0.4584870934486389\n",
      "Epoch 6000, Loss 0.01935080625116825\n",
      "Epoch 7000, Loss 0.00021268418640829623\n",
      "Epoch 8000, Loss 2.6826874091057107e-06\n",
      "Epoch 9000, Loss 4.721314894595707e-08\n",
      "Epoch 10000, Loss 1.282265627011725e-09\n",
      "Epoch 11000, Loss 3.3339933591669535e-10\n",
      "Epoch 12000, Loss 1.7783674532978466e-10\n",
      "Epoch 13000, Loss 1.2436661422920992e-10\n",
      "Epoch 14000, Loss 9.975925641114713e-11\n",
      "Epoch 15000, Loss 9.079308138648656e-11\n",
      "Epoch 16000, Loss 8.512968108220775e-11\n",
      "Epoch 17000, Loss 8.509811605383888e-11\n",
      "Epoch 0, Loss 1.9999988079071045\n",
      "Epoch 1000, Loss 1.9994373321533203\n",
      "Epoch 2000, Loss 1.8614290952682495\n",
      "Epoch 3000, Loss 0.9993071556091309\n",
      "Epoch 4000, Loss 0.9594208598136902\n",
      "Epoch 5000, Loss 0.5781101584434509\n",
      "Epoch 6000, Loss 0.03285792097449303\n",
      "Epoch 7000, Loss 0.0002488208992872387\n",
      "Epoch 8000, Loss 1.3868193491362035e-06\n",
      "Epoch 9000, Loss 8.333323364695389e-09\n",
      "Epoch 10000, Loss 4.352662674733665e-10\n",
      "Epoch 11000, Loss 3.590924779750537e-10\n",
      "Epoch 12000, Loss 3.4821473482438137e-10\n",
      "Epoch 13000, Loss 3.462909681228865e-10\n",
      "Epoch 14000, Loss 3.4653130365214224e-10\n",
      "Epoch 15000, Loss 3.4590830200187384e-10\n",
      "Epoch 16000, Loss 3.4447975028051303e-10\n",
      "Epoch 17000, Loss 3.461229358681095e-10\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.9995052814483643\n",
      "Epoch 2000, Loss 1.8767025470733643\n",
      "Epoch 3000, Loss 0.9987013936042786\n",
      "Epoch 4000, Loss 0.9416075944900513\n",
      "Epoch 5000, Loss 0.44749119877815247\n",
      "Epoch 6000, Loss 0.013518836349248886\n",
      "Epoch 7000, Loss 7.295255636563525e-05\n",
      "Epoch 8000, Loss 3.1846167303228867e-07\n",
      "Epoch 9000, Loss 1.4309486928709703e-09\n",
      "Epoch 10000, Loss 4.922680596486373e-10\n",
      "Epoch 11000, Loss 4.833203282039733e-10\n",
      "Epoch 12000, Loss 4.823418886523712e-10\n",
      "Epoch 13000, Loss 4.821706367508227e-10\n",
      "Epoch 14000, Loss 4.803575315293074e-10\n",
      "Epoch 15000, Loss 4.803554221055606e-10\n",
      "Epoch 16000, Loss 4.801988251479372e-10\n",
      "Epoch 17000, Loss 4.784441176575172e-10\n",
      "Epoch 0, Loss 1.9999995231628418\n",
      "Epoch 1000, Loss 1.9994707107543945\n",
      "Epoch 2000, Loss 1.8683961629867554\n",
      "Epoch 3000, Loss 0.9988925457000732\n",
      "Epoch 4000, Loss 0.9493739008903503\n",
      "Epoch 5000, Loss 0.5087820291519165\n",
      "Epoch 6000, Loss 0.02553420141339302\n",
      "Epoch 7000, Loss 0.00023958923702593893\n",
      "Epoch 8000, Loss 2.147344503100612e-06\n",
      "Epoch 9000, Loss 2.816405242356268e-08\n",
      "Epoch 10000, Loss 8.209586899177168e-10\n",
      "Epoch 11000, Loss 1.979007097085983e-10\n",
      "Epoch 12000, Loss 9.930788830159187e-11\n",
      "Epoch 13000, Loss 7.914587041302212e-11\n",
      "Epoch 14000, Loss 7.129131313066139e-11\n",
      "Epoch 15000, Loss 6.493839493915132e-11\n",
      "Epoch 16000, Loss 5.995367396982587e-11\n",
      "Epoch 17000, Loss 5.716365922281419e-11\n",
      "Epoch 0, Loss 2.000000238418579\n",
      "Epoch 1000, Loss 1.9996306896209717\n",
      "Epoch 2000, Loss 1.9060338735580444\n",
      "Epoch 3000, Loss 1.0010712146759033\n",
      "Epoch 4000, Loss 0.9509423971176147\n",
      "Epoch 5000, Loss 0.513775646686554\n",
      "Epoch 6000, Loss 0.02450883761048317\n",
      "Epoch 7000, Loss 0.00020758624305017292\n",
      "Epoch 8000, Loss 1.5173286556091625e-06\n",
      "Epoch 9000, Loss 1.5809170861302846e-08\n",
      "Epoch 10000, Loss 5.729702268197912e-10\n",
      "Epoch 11000, Loss 2.1471247002580185e-10\n",
      "Epoch 12000, Loss 1.7264692453444752e-10\n",
      "Epoch 13000, Loss 1.643249702976135e-10\n",
      "Epoch 14000, Loss 1.5971980682483178e-10\n",
      "Epoch 15000, Loss 1.5687491583538105e-10\n",
      "Epoch 16000, Loss 1.5525142282868387e-10\n",
      "Epoch 17000, Loss 1.536766131016165e-10\n",
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.9996120929718018\n",
      "Epoch 2000, Loss 1.902882695198059\n",
      "Epoch 3000, Loss 0.9999334812164307\n",
      "Epoch 4000, Loss 0.9369649887084961\n",
      "Epoch 5000, Loss 0.434219628572464\n",
      "Epoch 6000, Loss 0.014510626904666424\n",
      "Epoch 7000, Loss 0.00010670866322470829\n",
      "Epoch 8000, Loss 7.127007393137319e-07\n",
      "Epoch 9000, Loss 7.219543629588543e-09\n",
      "Epoch 10000, Loss 4.979747725286643e-10\n",
      "Epoch 11000, Loss 2.9219215935682996e-10\n",
      "Epoch 12000, Loss 2.7144841929782615e-10\n",
      "Epoch 13000, Loss 2.6591789881180716e-10\n",
      "Epoch 14000, Loss 2.6294499910761715e-10\n",
      "Epoch 15000, Loss 2.617429606388555e-10\n",
      "Epoch 16000, Loss 2.6007332398769734e-10\n",
      "Epoch 17000, Loss 2.609981952783613e-10\n",
      "Epoch 0, Loss 1.999999761581421\n",
      "Epoch 1000, Loss 1.9995648860931396\n",
      "Epoch 2000, Loss 1.8928577899932861\n",
      "Epoch 3000, Loss 0.9970376491546631\n",
      "Epoch 4000, Loss 0.9049615859985352\n",
      "Epoch 5000, Loss 0.29990896582603455\n",
      "Epoch 6000, Loss 0.006467265076935291\n",
      "Epoch 7000, Loss 6.403808947652578e-05\n",
      "Epoch 8000, Loss 1.0072774330183165e-06\n",
      "Epoch 9000, Loss 7.487728481692102e-08\n",
      "Epoch 10000, Loss 1.1045479197946406e-08\n",
      "Epoch 11000, Loss 1.844358887836961e-09\n",
      "Epoch 12000, Loss 4.806143261149032e-10\n",
      "Epoch 13000, Loss 2.155255834912495e-10\n",
      "Epoch 14000, Loss 1.3428710921026266e-10\n",
      "Epoch 15000, Loss 1.0129959371329988e-10\n",
      "Epoch 16000, Loss 8.306003801417106e-11\n",
      "Epoch 17000, Loss 7.189911166438634e-11\n",
      "Epoch 0, Loss 1.9999990463256836\n",
      "Epoch 1000, Loss 1.99940824508667\n",
      "Epoch 2000, Loss 1.8549251556396484\n",
      "Epoch 3000, Loss 0.9971812963485718\n",
      "Epoch 4000, Loss 0.9287554025650024\n",
      "Epoch 5000, Loss 0.40082815289497375\n",
      "Epoch 6000, Loss 0.01278101559728384\n",
      "Epoch 7000, Loss 9.728376608109102e-05\n",
      "Epoch 8000, Loss 7.383489446510794e-07\n",
      "Epoch 9000, Loss 7.98397348233948e-09\n",
      "Epoch 10000, Loss 3.69446917503069e-10\n",
      "Epoch 11000, Loss 1.7304649380101012e-10\n",
      "Epoch 12000, Loss 1.4105884516002476e-10\n",
      "Epoch 13000, Loss 1.3036126345067345e-10\n",
      "Epoch 14000, Loss 1.1986189818458115e-10\n",
      "Epoch 15000, Loss 1.103132724056266e-10\n",
      "Epoch 16000, Loss 1.0181328002900614e-10\n",
      "Epoch 17000, Loss 9.335978518043575e-11\n"
     ]
    }
   ],
   "source": [
    "def train_n_runs(n_runs, model, train_loader, optimizer, x_grid):\n",
    "    losses_list = []\n",
    "    mesh_outputs_list = []\n",
    "    for i in range(n_runs):\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",
    "        losses, mesh_outputs = train(model, train_loader, optimizer, x_grid)\n",
    "        losses_list.append(losses)\n",
    "        mesh_outputs_list.append(mesh_outputs)\n",
    "    return losses_list, np.array(mesh_outputs_list)\n",
    "\n",
    "n_runs = 10\n",
    "_, mesh_outputs_array = train_n_runs(n_runs, model, train_loader, optimizer, x_grid)\n",
    "mesh_outputs_relu_bias = np.mean(mesh_outputs_array, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 541,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 1.999998927116394\n",
      "Epoch 1000, Loss 1.9987376928329468\n",
      "Epoch 2000, Loss 1.7249114513397217\n",
      "Epoch 3000, Loss 0.9894354939460754\n",
      "Epoch 4000, Loss 0.8367661237716675\n",
      "Epoch 5000, Loss 0.15064166486263275\n",
      "Epoch 6000, Loss 0.001298275077715516\n",
      "Epoch 7000, Loss 4.821538823307492e-06\n",
      "Epoch 8000, Loss 1.6799493351982164e-08\n",
      "Epoch 9000, Loss 4.804985298534348e-10\n",
      "Epoch 10000, Loss 4.56036097773449e-10\n",
      "Epoch 11000, Loss 4.5217804500730097e-10\n",
      "Epoch 12000, Loss 4.486660765135042e-10\n",
      "Epoch 13000, Loss 4.5239700874333266e-10\n",
      "Epoch 14000, Loss 4.501830297432008e-10\n",
      "Epoch 15000, Loss 4.5022058303700874e-10\n",
      "Epoch 16000, Loss 4.499945971403463e-10\n",
      "Epoch 17000, Loss 4.498448835654756e-10\n",
      "Epoch 0, Loss 1.9999985694885254\n",
      "Epoch 1000, Loss 1.998704433441162\n",
      "Epoch 2000, Loss 1.717931866645813\n",
      "Epoch 3000, Loss 0.9914970397949219\n",
      "Epoch 4000, Loss 0.8648200631141663\n",
      "Epoch 5000, Loss 0.19342011213302612\n",
      "Epoch 6000, Loss 0.001955661689862609\n",
      "Epoch 7000, Loss 7.3807022999972105e-06\n",
      "Epoch 8000, Loss 2.5766142996985764e-08\n",
      "Epoch 9000, Loss 4.940982623047319e-10\n",
      "Epoch 10000, Loss 4.637606410007322e-10\n",
      "Epoch 11000, Loss 4.588866231447497e-10\n",
      "Epoch 12000, Loss 4.559634891876385e-10\n",
      "Epoch 13000, Loss 4.550091137200951e-10\n",
      "Epoch 14000, Loss 4.567566047608551e-10\n",
      "Epoch 15000, Loss 4.573064427138007e-10\n",
      "Epoch 16000, Loss 4.5622991495797294e-10\n",
      "Epoch 17000, Loss 4.569176981217282e-10\n",
      "Epoch 0, Loss 2.0000014305114746\n",
      "Epoch 1000, Loss 1.9990546703338623\n",
      "Epoch 2000, Loss 1.780916690826416\n",
      "Epoch 3000, Loss 0.9949988722801208\n",
      "Epoch 4000, Loss 0.9104433059692383\n",
      "Epoch 5000, Loss 0.3045789301395416\n",
      "Epoch 6000, Loss 0.004583464004099369\n",
      "Epoch 7000, Loss 1.813135349948425e-05\n",
      "Epoch 8000, Loss 6.351540093874064e-08\n",
      "Epoch 9000, Loss 5.011567272283912e-10\n",
      "Epoch 10000, Loss 4.181607282660593e-10\n",
      "Epoch 11000, Loss 4.187236113395443e-10\n",
      "Epoch 12000, Loss 4.1857012300638985e-10\n",
      "Epoch 13000, Loss 4.1742712064696263e-10\n",
      "Epoch 14000, Loss 4.1645165094195136e-10\n",
      "Epoch 15000, Loss 4.1632836067506673e-10\n",
      "Epoch 16000, Loss 4.164197320299934e-10\n",
      "Epoch 17000, Loss 4.1506287296044775e-10\n",
      "Epoch 0, Loss 1.9999998807907104\n",
      "Epoch 1000, Loss 1.9990534782409668\n",
      "Epoch 2000, Loss 1.7820614576339722\n",
      "Epoch 3000, Loss 0.9924348592758179\n",
      "Epoch 4000, Loss 0.8734716176986694\n",
      "Epoch 5000, Loss 0.20976442098617554\n",
      "Epoch 6000, Loss 0.0022507975809276104\n",
      "Epoch 7000, Loss 8.547607649234124e-06\n",
      "Epoch 8000, Loss 2.9728793649042018e-08\n",
      "Epoch 9000, Loss 5.146432169311765e-10\n",
      "Epoch 10000, Loss 4.433399203307431e-10\n",
      "Epoch 11000, Loss 4.3259454352018167e-10\n",
      "Epoch 12000, Loss 4.299564315690674e-10\n",
      "Epoch 13000, Loss 4.2769976449363867e-10\n",
      "Epoch 14000, Loss 4.278248866285139e-10\n",
      "Epoch 15000, Loss 4.269144759927457e-10\n",
      "Epoch 16000, Loss 4.2638942376882483e-10\n",
      "Epoch 17000, Loss 4.2746012285377333e-10\n",
      "Epoch 0, Loss 1.9999990463256836\n",
      "Epoch 1000, Loss 1.9988337755203247\n",
      "Epoch 2000, Loss 1.7403204441070557\n",
      "Epoch 3000, Loss 0.9924792051315308\n",
      "Epoch 4000, Loss 0.8773380517959595\n",
      "Epoch 5000, Loss 0.21765780448913574\n",
      "Epoch 6000, Loss 0.002403026446700096\n",
      "Epoch 7000, Loss 9.155364750768058e-06\n",
      "Epoch 8000, Loss 3.1824566093519024e-08\n",
      "Epoch 9000, Loss 5.091215227182033e-10\n",
      "Epoch 10000, Loss 4.5429507378180745e-10\n",
      "Epoch 11000, Loss 4.5092141132130337e-10\n",
      "Epoch 12000, Loss 4.5097461875975853e-10\n",
      "Epoch 13000, Loss 4.5080739141667436e-10\n",
      "Epoch 14000, Loss 4.5099293743966484e-10\n",
      "Epoch 15000, Loss 4.498404426733771e-10\n",
      "Epoch 16000, Loss 4.503409589684537e-10\n",
      "Epoch 17000, Loss 4.493682925765796e-10\n",
      "Epoch 0, Loss 2.000000238418579\n",
      "Epoch 1000, Loss 1.9991883039474487\n",
      "Epoch 2000, Loss 1.8097513914108276\n",
      "Epoch 3000, Loss 0.9920178055763245\n",
      "Epoch 4000, Loss 0.8642361760139465\n",
      "Epoch 5000, Loss 0.192379429936409\n",
      "Epoch 6000, Loss 0.0019377174321562052\n",
      "Epoch 7000, Loss 7.309249212994473e-06\n",
      "Epoch 8000, Loss 2.5578930973324532e-08\n",
      "Epoch 9000, Loss 5.041035922026538e-10\n",
      "Epoch 10000, Loss 4.547768273077679e-10\n",
      "Epoch 11000, Loss 4.473884873679168e-10\n",
      "Epoch 12000, Loss 4.4708237112445204e-10\n",
      "Epoch 13000, Loss 4.473525716530702e-10\n",
      "Epoch 14000, Loss 4.46535308729068e-10\n",
      "Epoch 15000, Loss 4.4493136952539203e-10\n",
      "Epoch 16000, Loss 4.48408588038518e-10\n",
      "Epoch 17000, Loss 4.482396398497457e-10\n",
      "Epoch 0, Loss 1.999999761581421\n",
      "Epoch 1000, Loss 1.998882532119751\n",
      "Epoch 2000, Loss 1.75040602684021\n",
      "Epoch 3000, Loss 0.9910372495651245\n",
      "Epoch 4000, Loss 0.8567745089530945\n",
      "Epoch 5000, Loss 0.17968237400054932\n",
      "Epoch 6000, Loss 0.0017273592529818416\n",
      "Epoch 7000, Loss 6.486724942078581e-06\n",
      "Epoch 8000, Loss 2.2648046993367643e-08\n",
      "Epoch 9000, Loss 5.011532300258636e-10\n",
      "Epoch 10000, Loss 4.673094688989465e-10\n",
      "Epoch 11000, Loss 4.648290363729046e-10\n",
      "Epoch 12000, Loss 4.626625194070755e-10\n",
      "Epoch 13000, Loss 4.613629200900249e-10\n",
      "Epoch 14000, Loss 4.6062084702036543e-10\n",
      "Epoch 15000, Loss 4.6007925247337766e-10\n",
      "Epoch 16000, Loss 4.595740732415976e-10\n",
      "Epoch 17000, Loss 4.608153858498554e-10\n",
      "Epoch 0, Loss 1.999999761581421\n",
      "Epoch 1000, Loss 1.998840093612671\n",
      "Epoch 2000, Loss 1.7437682151794434\n",
      "Epoch 3000, Loss 0.9886685013771057\n",
      "Epoch 4000, Loss 0.8258159160614014\n",
      "Epoch 5000, Loss 0.137293741106987\n",
      "Epoch 6000, Loss 0.001123737427406013\n",
      "Epoch 7000, Loss 4.1525718188495375e-06\n",
      "Epoch 8000, Loss 1.4422047556195139e-08\n",
      "Epoch 9000, Loss 4.892832805580838e-10\n",
      "Epoch 10000, Loss 4.761300242961397e-10\n",
      "Epoch 11000, Loss 4.755101867814915e-10\n",
      "Epoch 12000, Loss 4.718632706790515e-10\n",
      "Epoch 13000, Loss 4.726024016576957e-10\n",
      "Epoch 14000, Loss 4.72305305976306e-10\n",
      "Epoch 15000, Loss 4.718984647489322e-10\n",
      "Epoch 16000, Loss 4.716307344665438e-10\n",
      "Epoch 17000, Loss 4.712664147810131e-10\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.9990525245666504\n",
      "Epoch 2000, Loss 1.7825284004211426\n",
      "Epoch 3000, Loss 0.9917043447494507\n",
      "Epoch 4000, Loss 0.8632940649986267\n",
      "Epoch 5000, Loss 0.19070814549922943\n",
      "Epoch 6000, Loss 0.00190927239600569\n",
      "Epoch 7000, Loss 7.199742412922205e-06\n",
      "Epoch 8000, Loss 2.504175000694886e-08\n",
      "Epoch 9000, Loss 4.4495079842832297e-10\n",
      "Epoch 10000, Loss 4.1168918274436805e-10\n",
      "Epoch 11000, Loss 4.081793791854693e-10\n",
      "Epoch 12000, Loss 4.0837919157432623e-10\n",
      "Epoch 13000, Loss 4.0754719043967214e-10\n",
      "Epoch 14000, Loss 4.0721900851359294e-10\n",
      "Epoch 15000, Loss 4.0689263069992876e-10\n",
      "Epoch 16000, Loss 4.066490200127504e-10\n",
      "Epoch 17000, Loss 4.0632572306797954e-10\n",
      "Epoch 0, Loss 1.9999995231628418\n",
      "Epoch 1000, Loss 1.998868465423584\n",
      "Epoch 2000, Loss 1.74581778049469\n",
      "Epoch 3000, Loss 0.993962824344635\n",
      "Epoch 4000, Loss 0.8981893062591553\n",
      "Epoch 5000, Loss 0.2677733302116394\n",
      "Epoch 6000, Loss 0.0035357640590518713\n",
      "Epoch 7000, Loss 1.375309147988446e-05\n",
      "Epoch 8000, Loss 4.7959879623249435e-08\n",
      "Epoch 9000, Loss 4.977930290195332e-10\n",
      "Epoch 10000, Loss 4.3153833284570453e-10\n",
      "Epoch 11000, Loss 4.284648746910591e-10\n",
      "Epoch 12000, Loss 4.2669348609969404e-10\n",
      "Epoch 13000, Loss 4.2606784766974215e-10\n",
      "Epoch 14000, Loss 4.2577624759232435e-10\n",
      "Epoch 15000, Loss 4.287974975092368e-10\n",
      "Epoch 16000, Loss 4.285453381047688e-10\n",
      "Epoch 17000, Loss 4.2836603708629184e-10\n"
     ]
    }
   ],
   "source": [
    "input_size = 4\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.fc1_b = torch.nn.Linear(hidden_size, hidden_size, bias=True)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        # x = self.fc1_b(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",
    "# model.fc1_b.weight.data = torch.randn_like(model.fc1_b.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_bias = train(model, train_loader, optimizer)\n",
    "# train for each dataset with the offsets\n",
    "# losses_linear_bias, mesh_outputs_linear_bias = train(model, train_loader, optimizer)\n",
    "_, mesh_outputs_array = train_n_runs(n_runs, model, train_loader, optimizer, x_grid)\n",
    "mesh_outputs_linear_bias = np.mean(mesh_outputs_array, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 543,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 1.9999988079071045\n",
      "Epoch 1000, Loss 1.9989018440246582\n",
      "Epoch 2000, Loss 1.7481327056884766\n",
      "Epoch 3000, Loss 1.000471830368042\n",
      "Epoch 4000, Loss 1.0\n",
      "Epoch 5000, Loss 0.9999998211860657\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 0.9999998807907104\n",
      "Epoch 8000, Loss 1.0\n",
      "Epoch 9000, Loss 1.0000001192092896\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 1.0\n",
      "Epoch 12000, Loss 1.0\n",
      "Epoch 13000, Loss 1.0\n",
      "Epoch 14000, Loss 1.0\n",
      "Epoch 15000, Loss 0.9999999403953552\n",
      "Epoch 16000, Loss 1.0\n",
      "Epoch 17000, Loss 1.0\n",
      "Epoch 0, Loss 1.999999761581421\n",
      "Epoch 1000, Loss 1.9990160465240479\n",
      "Epoch 2000, Loss 1.7696239948272705\n",
      "Epoch 3000, Loss 1.0005853176116943\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 0.9999999403953552\n",
      "Epoch 6000, Loss 0.9999997615814209\n",
      "Epoch 7000, Loss 1.0\n",
      "Epoch 8000, Loss 0.9999998807907104\n",
      "Epoch 9000, Loss 0.9999998807907104\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 0.9999998807907104\n",
      "Epoch 12000, Loss 0.9999998807907104\n",
      "Epoch 13000, Loss 0.9999998807907104\n",
      "Epoch 14000, Loss 0.9999998211860657\n",
      "Epoch 15000, Loss 0.9999998807907104\n",
      "Epoch 16000, Loss 0.9999997615814209\n",
      "Epoch 17000, Loss 0.9999998807907104\n",
      "Epoch 0, Loss 1.9999991655349731\n",
      "Epoch 1000, Loss 1.9987802505493164\n",
      "Epoch 2000, Loss 1.7262024879455566\n",
      "Epoch 3000, Loss 1.0003836154937744\n",
      "Epoch 4000, Loss 1.0\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 0.9999999403953552\n",
      "Epoch 7000, Loss 0.9999998807907104\n",
      "Epoch 8000, Loss 0.9999999403953552\n",
      "Epoch 9000, Loss 0.9999999403953552\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 1.0000001192092896\n",
      "Epoch 12000, Loss 1.0\n",
      "Epoch 13000, Loss 0.9999999403953552\n",
      "Epoch 14000, Loss 1.0\n",
      "Epoch 15000, Loss 1.0\n",
      "Epoch 16000, Loss 1.0\n",
      "Epoch 17000, Loss 1.0\n",
      "Epoch 0, Loss 1.9999991655349731\n",
      "Epoch 1000, Loss 1.9987454414367676\n",
      "Epoch 2000, Loss 1.7201157808303833\n",
      "Epoch 3000, Loss 1.0003628730773926\n",
      "Epoch 4000, Loss 1.0000001192092896\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 0.9999998807907104\n",
      "Epoch 7000, Loss 0.9999999403953552\n",
      "Epoch 8000, Loss 0.9999998807907104\n",
      "Epoch 9000, Loss 1.0\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 1.0\n",
      "Epoch 12000, Loss 1.0000001192092896\n",
      "Epoch 13000, Loss 1.0\n",
      "Epoch 14000, Loss 1.0\n",
      "Epoch 15000, Loss 1.0\n",
      "Epoch 16000, Loss 1.0\n",
      "Epoch 17000, Loss 1.000000238418579\n",
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.9990904331207275\n",
      "Epoch 2000, Loss 1.784132957458496\n",
      "Epoch 3000, Loss 1.0006829500198364\n",
      "Epoch 4000, Loss 0.9999998807907104\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 1.0000001192092896\n",
      "Epoch 7000, Loss 0.9999998807907104\n",
      "Epoch 8000, Loss 1.0000001192092896\n",
      "Epoch 9000, Loss 1.0000001192092896\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 1.0000001192092896\n",
      "Epoch 12000, Loss 0.9999999403953552\n",
      "Epoch 13000, Loss 1.0\n",
      "Epoch 14000, Loss 1.0\n",
      "Epoch 15000, Loss 1.0\n",
      "Epoch 16000, Loss 1.0\n",
      "Epoch 17000, Loss 1.0\n",
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.9989672899246216\n",
      "Epoch 2000, Loss 1.7603310346603394\n",
      "Epoch 3000, Loss 1.0005323886871338\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 1.0000001192092896\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 0.9999998211860657\n",
      "Epoch 8000, Loss 1.0\n",
      "Epoch 9000, Loss 0.9999998211860657\n",
      "Epoch 10000, Loss 1.0\n",
      "Epoch 11000, Loss 1.0\n",
      "Epoch 12000, Loss 1.0\n",
      "Epoch 13000, Loss 1.0\n",
      "Epoch 14000, Loss 0.9999999403953552\n",
      "Epoch 15000, Loss 1.0\n",
      "Epoch 16000, Loss 0.9999999403953552\n",
      "Epoch 17000, Loss 0.9999999403953552\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.9988210201263428\n",
      "Epoch 2000, Loss 1.7334474325180054\n",
      "Epoch 3000, Loss 1.0004103183746338\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 0.9999999403953552\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 1.0\n",
      "Epoch 8000, Loss 0.9999999403953552\n",
      "Epoch 9000, Loss 1.0\n",
      "Epoch 10000, Loss 1.0000001192092896\n",
      "Epoch 11000, Loss 1.0000001192092896\n",
      "Epoch 12000, Loss 1.0\n",
      "Epoch 13000, Loss 1.0\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 0, Loss 1.999999761581421\n",
      "Epoch 1000, Loss 1.9989466667175293\n",
      "Epoch 2000, Loss 1.7564432621002197\n",
      "Epoch 3000, Loss 1.0005121231079102\n",
      "Epoch 4000, Loss 1.0\n",
      "Epoch 5000, Loss 1.0000001192092896\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 0.9999998807907104\n",
      "Epoch 8000, Loss 0.9999998807907104\n",
      "Epoch 9000, Loss 0.9999999403953552\n",
      "Epoch 10000, Loss 0.9999999403953552\n",
      "Epoch 11000, Loss 1.0\n",
      "Epoch 12000, Loss 1.0\n",
      "Epoch 13000, Loss 1.0\n",
      "Epoch 14000, Loss 1.0\n",
      "Epoch 15000, Loss 1.0\n",
      "Epoch 16000, Loss 1.0\n",
      "Epoch 17000, Loss 1.0\n",
      "Epoch 0, Loss 1.9999995231628418\n",
      "Epoch 1000, Loss 1.9987949132919312\n",
      "Epoch 2000, Loss 1.7288099527359009\n",
      "Epoch 3000, Loss 1.0003929138183594\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 1.0\n",
      "Epoch 7000, Loss 1.0\n",
      "Epoch 8000, Loss 0.9999999403953552\n",
      "Epoch 9000, Loss 0.9999998807907104\n",
      "Epoch 10000, Loss 0.9999999403953552\n",
      "Epoch 11000, Loss 0.9999998211860657\n",
      "Epoch 12000, Loss 0.9999998807907104\n",
      "Epoch 13000, Loss 0.9999998807907104\n",
      "Epoch 14000, Loss 0.9999998807907104\n",
      "Epoch 15000, Loss 0.9999998807907104\n",
      "Epoch 16000, Loss 0.9999999403953552\n",
      "Epoch 17000, Loss 0.9999999403953552\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.9990695714950562\n",
      "Epoch 2000, Loss 1.7800296545028687\n",
      "Epoch 3000, Loss 1.0006532669067383\n",
      "Epoch 4000, Loss 0.9999999403953552\n",
      "Epoch 5000, Loss 1.0\n",
      "Epoch 6000, Loss 0.9999999403953552\n",
      "Epoch 7000, Loss 1.0\n",
      "Epoch 8000, Loss 1.0\n",
      "Epoch 9000, Loss 0.9999999403953552\n",
      "Epoch 10000, Loss 0.9999998807907104\n",
      "Epoch 11000, Loss 0.9999998807907104\n",
      "Epoch 12000, Loss 0.9999999403953552\n",
      "Epoch 13000, Loss 0.9999998211860657\n",
      "Epoch 14000, Loss 0.9999998807907104\n",
      "Epoch 15000, Loss 0.9999999403953552\n",
      "Epoch 16000, Loss 0.9999998211860657\n",
      "Epoch 17000, Loss 0.9999998211860657\n"
     ]
    }
   ],
   "source": [
    "train_inputs = np.array([[-1, -1, -offset], [1, -1, offset], [-1, 1, offset], [1, 1, -offset]]).T\n",
    "    \n",
    "input_size = 3\n",
    "hidden_size = 64\n",
    "output_size = 2\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",
    "# losses_linear_no_bias, mesh_outputs_linear_no_bias = train(model, train_loader, optimizer,x_grid=x_grid[:,1:])\n",
    "_, mesh_outputs_array = train_n_runs(n_runs, model, train_loader, optimizer, x_grid[:,1:])\n",
    "mesh_outputs_linear_no_bias = np.mean(mesh_outputs_array, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 544,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 2.000001907348633\n",
      "Epoch 1000, Loss 1.9998902082443237\n",
      "Epoch 2000, Loss 1.995154619216919\n",
      "Epoch 3000, Loss 1.7777533531188965\n",
      "Epoch 4000, Loss 0.1162479817867279\n",
      "Epoch 5000, Loss 8.678616723045707e-05\n",
      "Epoch 6000, Loss 1.4268807717598975e-05\n",
      "Epoch 7000, Loss 1.3090298125462141e-05\n",
      "Epoch 8000, Loss 1.2052890269842464e-05\n",
      "Epoch 9000, Loss 1.1110669220215641e-05\n",
      "Epoch 10000, Loss 1.0253879736410454e-05\n",
      "Epoch 11000, Loss 9.47361968428595e-06\n",
      "Epoch 12000, Loss 8.762272955209482e-06\n",
      "Epoch 13000, Loss 8.113062904158141e-06\n",
      "Epoch 14000, Loss 7.519593509641709e-06\n",
      "Epoch 15000, Loss 6.97640416547074e-06\n",
      "Epoch 16000, Loss 6.478794603026472e-06\n",
      "Epoch 17000, Loss 6.022209618095076e-06\n",
      "Epoch 0, Loss 2.000000476837158\n",
      "Epoch 1000, Loss 1.999892234802246\n",
      "Epoch 2000, Loss 1.9956765174865723\n",
      "Epoch 3000, Loss 1.8094903230667114\n",
      "Epoch 4000, Loss 0.1602584570646286\n",
      "Epoch 5000, Loss 0.00012723823601845652\n",
      "Epoch 6000, Loss 3.3370929486409295e-06\n",
      "Epoch 7000, Loss 2.804367795761209e-06\n",
      "Epoch 8000, Loss 2.4340311028936412e-06\n",
      "Epoch 9000, Loss 2.1142218429304194e-06\n",
      "Epoch 10000, Loss 1.8375740182818845e-06\n",
      "Epoch 11000, Loss 1.598112021383713e-06\n",
      "Epoch 12000, Loss 1.3907280163039104e-06\n",
      "Epoch 13000, Loss 1.2107705060770968e-06\n",
      "Epoch 14000, Loss 1.054974973158096e-06\n",
      "Epoch 15000, Loss 9.197851227327192e-07\n",
      "Epoch 16000, Loss 8.023386044442304e-07\n",
      "Epoch 17000, Loss 7.003019959483936e-07\n",
      "Epoch 0, Loss 1.9999998807907104\n",
      "Epoch 1000, Loss 1.999873161315918\n",
      "Epoch 2000, Loss 1.9947271347045898\n",
      "Epoch 3000, Loss 1.7671480178833008\n",
      "Epoch 4000, Loss 0.10921996086835861\n",
      "Epoch 5000, Loss 6.648776616202667e-05\n",
      "Epoch 6000, Loss 7.200151799224841e-07\n",
      "Epoch 7000, Loss 6.221549142537697e-07\n",
      "Epoch 8000, Loss 5.573627959165606e-07\n",
      "Epoch 9000, Loss 4.997391442884691e-07\n",
      "Epoch 10000, Loss 4.4854732550447807e-07\n",
      "Epoch 11000, Loss 4.028263163036172e-07\n",
      "Epoch 12000, Loss 3.6203331887918466e-07\n",
      "Epoch 13000, Loss 3.2568169672231306e-07\n",
      "Epoch 14000, Loss 2.9313375193851243e-07\n",
      "Epoch 15000, Loss 2.639976344198658e-07\n",
      "Epoch 16000, Loss 2.3799229609267059e-07\n",
      "Epoch 17000, Loss 2.1467450039835967e-07\n",
      "Epoch 0, Loss 2.0000011920928955\n",
      "Epoch 1000, Loss 1.9999228715896606\n",
      "Epoch 2000, Loss 1.996839165687561\n",
      "Epoch 3000, Loss 1.8563854694366455\n",
      "Epoch 4000, Loss 0.2570658028125763\n",
      "Epoch 5000, Loss 0.00025402530445717275\n",
      "Epoch 6000, Loss 6.663949079666054e-06\n",
      "Epoch 7000, Loss 5.684871211997233e-06\n",
      "Epoch 8000, Loss 4.941149654769106e-06\n",
      "Epoch 9000, Loss 4.294987320463406e-06\n",
      "Epoch 10000, Loss 3.733409812411992e-06\n",
      "Epoch 11000, Loss 3.2456082408316433e-06\n",
      "Epoch 12000, Loss 2.8215511065354804e-06\n",
      "Epoch 13000, Loss 2.4528646918042796e-06\n",
      "Epoch 14000, Loss 2.132599547621794e-06\n",
      "Epoch 15000, Loss 1.8540218889029347e-06\n",
      "Epoch 16000, Loss 1.6120989130286034e-06\n",
      "Epoch 17000, Loss 1.4015417946211528e-06\n",
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.999887466430664\n",
      "Epoch 2000, Loss 1.995099425315857\n",
      "Epoch 3000, Loss 1.7767820358276367\n",
      "Epoch 4000, Loss 0.11430145800113678\n",
      "Epoch 5000, Loss 7.00691671227105e-05\n",
      "Epoch 6000, Loss 1.3314229363459162e-07\n",
      "Epoch 7000, Loss 8.804510542859134e-08\n",
      "Epoch 8000, Loss 7.955914327339997e-08\n",
      "Epoch 9000, Loss 7.196950946308789e-08\n",
      "Epoch 10000, Loss 6.51535501106082e-08\n",
      "Epoch 11000, Loss 5.9004527486195e-08\n",
      "Epoch 12000, Loss 5.3420698975514824e-08\n",
      "Epoch 13000, Loss 4.835541744796501e-08\n",
      "Epoch 14000, Loss 4.374370021764662e-08\n",
      "Epoch 15000, Loss 3.9560717368658516e-08\n",
      "Epoch 16000, Loss 3.5804255560378806e-08\n",
      "Epoch 17000, Loss 3.242349677634593e-08\n",
      "Epoch 0, Loss 2.0000016689300537\n",
      "Epoch 1000, Loss 1.9999167919158936\n",
      "Epoch 2000, Loss 1.996748447418213\n",
      "Epoch 3000, Loss 1.855902910232544\n",
      "Epoch 4000, Loss 0.2538191080093384\n",
      "Epoch 5000, Loss 0.00024763826513662934\n",
      "Epoch 6000, Loss 8.094570148386993e-06\n",
      "Epoch 7000, Loss 6.876830411783885e-06\n",
      "Epoch 8000, Loss 5.929162398388144e-06\n",
      "Epoch 9000, Loss 5.112537564855302e-06\n",
      "Epoch 10000, Loss 4.4085359149903525e-06\n",
      "Epoch 11000, Loss 3.8016733014956117e-06\n",
      "Epoch 12000, Loss 3.27854309034592e-06\n",
      "Epoch 13000, Loss 2.8272911549720448e-06\n",
      "Epoch 14000, Loss 2.4384537482546875e-06\n",
      "Epoch 15000, Loss 2.1030755306128412e-06\n",
      "Epoch 16000, Loss 1.8138132418243913e-06\n",
      "Epoch 17000, Loss 1.564440594847838e-06\n",
      "Epoch 0, Loss 2.000000238418579\n",
      "Epoch 1000, Loss 1.999898910522461\n",
      "Epoch 2000, Loss 1.995720386505127\n",
      "Epoch 3000, Loss 1.8053933382034302\n",
      "Epoch 4000, Loss 0.14297418296337128\n",
      "Epoch 5000, Loss 9.625239908928052e-05\n",
      "Epoch 6000, Loss 2.5233873657271033e-06\n",
      "Epoch 7000, Loss 2.245221367047634e-06\n",
      "Epoch 8000, Loss 2.0332622625574004e-06\n",
      "Epoch 9000, Loss 1.841559992499242e-06\n",
      "Epoch 10000, Loss 1.6679548480169615e-06\n",
      "Epoch 11000, Loss 1.5108440720723593e-06\n",
      "Epoch 12000, Loss 1.368510993415839e-06\n",
      "Epoch 13000, Loss 1.2396819784044055e-06\n",
      "Epoch 14000, Loss 1.1230214340685052e-06\n",
      "Epoch 15000, Loss 1.0173459941142937e-06\n",
      "Epoch 16000, Loss 9.217486649504281e-07\n",
      "Epoch 17000, Loss 8.350182270078221e-07\n",
      "Epoch 0, Loss 2.0000007152557373\n",
      "Epoch 1000, Loss 1.9998698234558105\n",
      "Epoch 2000, Loss 1.9938311576843262\n",
      "Epoch 3000, Loss 1.719032883644104\n",
      "Epoch 4000, Loss 0.09342595189809799\n",
      "Epoch 5000, Loss 5.748202238464728e-05\n",
      "Epoch 6000, Loss 1.463610374230484e-06\n",
      "Epoch 7000, Loss 1.361765384899627e-06\n",
      "Epoch 8000, Loss 1.2850460961999488e-06\n",
      "Epoch 9000, Loss 1.2130989262004732e-06\n",
      "Epoch 10000, Loss 1.145319174611359e-06\n",
      "Epoch 11000, Loss 1.081490381693584e-06\n",
      "Epoch 12000, Loss 1.0215883321507135e-06\n",
      "Epoch 13000, Loss 9.651162145019043e-07\n",
      "Epoch 14000, Loss 9.119354444919736e-07\n",
      "Epoch 15000, Loss 8.618918627689709e-07\n",
      "Epoch 16000, Loss 8.148123242790462e-07\n",
      "Epoch 17000, Loss 7.704567224209313e-07\n",
      "Epoch 0, Loss 1.9999994039535522\n",
      "Epoch 1000, Loss 1.9998595714569092\n",
      "Epoch 2000, Loss 1.993813157081604\n",
      "Epoch 3000, Loss 1.7249382734298706\n",
      "Epoch 4000, Loss 0.09036408364772797\n",
      "Epoch 5000, Loss 5.419928493211046e-05\n",
      "Epoch 6000, Loss 5.190430556467618e-07\n",
      "Epoch 7000, Loss 4.510567350735073e-07\n",
      "Epoch 8000, Loss 4.103039827896282e-07\n",
      "Epoch 9000, Loss 3.733781852588436e-07\n",
      "Epoch 10000, Loss 3.3996337833741563e-07\n",
      "Epoch 11000, Loss 3.0958608476794325e-07\n",
      "Epoch 12000, Loss 2.8209291258463054e-07\n",
      "Epoch 13000, Loss 2.5721899987729557e-07\n",
      "Epoch 14000, Loss 2.3448862407349225e-07\n",
      "Epoch 15000, Loss 2.1380434134243842e-07\n",
      "Epoch 16000, Loss 1.9511884374878719e-07\n",
      "Epoch 17000, Loss 1.781140781531576e-07\n",
      "Epoch 0, Loss 2.0\n",
      "Epoch 1000, Loss 1.9998745918273926\n",
      "Epoch 2000, Loss 1.9949089288711548\n",
      "Epoch 3000, Loss 1.7779338359832764\n",
      "Epoch 4000, Loss 0.14260731637477875\n",
      "Epoch 5000, Loss 0.00013092327571939677\n",
      "Epoch 6000, Loss 2.5154118702630512e-05\n",
      "Epoch 7000, Loss 2.209635749750305e-05\n",
      "Epoch 8000, Loss 1.9462844647932798e-05\n",
      "Epoch 9000, Loss 1.7149523046100512e-05\n",
      "Epoch 10000, Loss 1.5115599126147572e-05\n",
      "Epoch 11000, Loss 1.332704232481774e-05\n",
      "Epoch 12000, Loss 1.1753534636227414e-05\n",
      "Epoch 13000, Loss 1.0368493349233177e-05\n",
      "Epoch 14000, Loss 9.149136531050317e-06\n",
      "Epoch 15000, Loss 8.075079676927999e-06\n",
      "Epoch 16000, Loss 7.128821835067356e-06\n",
      "Epoch 17000, Loss 6.2950607571110595e-06\n"
     ]
    }
   ],
   "source": [
    "# # train the relu net without a bias term\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",
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001)\n",
    "# losses_relu_no_bias, mesh_outputs_relu_no_bias = train(model, train_loader, optimizer,x_grid=x_grid[:,1:])\n",
    "_, mesh_outputs_array = train_n_runs(n_runs, model, train_loader, optimizer, x_grid[:,1:])\n",
    "mesh_outputs_relu_no_bias = np.mean(mesh_outputs_array, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 545,
   "metadata": {},
   "outputs": [],
   "source": [
    "mesh_outputs_relu_bias_reshaped = mesh_outputs_relu_bias.reshape(-1, n_grid, n_grid, 2)\n",
    "mesh_outputs_linear_bias_reshaped = mesh_outputs_linear_bias.reshape(-1, n_grid, n_grid, 2)\n",
    "mesh_outputs_relu_no_bias_reshaped = mesh_outputs_relu_no_bias.reshape(-1, n_grid, n_grid, 2)\n",
    "mesh_outputs_linear_no_bias_reshaped = mesh_outputs_linear_no_bias.reshape(-1, n_grid, n_grid, 2)\n",
    "axis = 2\n",
    "mean_mesh_outputs_relu_bias_axis_2 = mesh_outputs_relu_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_bias_axis_2 = mesh_outputs_linear_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_relu_no_bias_axis_2 = mesh_outputs_relu_no_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_no_bias_axis_2 = mesh_outputs_linear_no_bias_reshaped.mean(axis=axis)\n",
    "\n",
    "axis = 1\n",
    "mean_mesh_outputs_relu_bias_axis_1 = mesh_outputs_relu_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_bias_axis_1 = mesh_outputs_linear_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_relu_no_bias_axis_1 = mesh_outputs_relu_no_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_no_bias_axis_1 = mesh_outputs_linear_no_bias_reshaped.mean(axis=axis)\n",
    "\n",
    "axis = 0\n",
    "mean_mesh_outputs_relu_bias_axis_0 = mesh_outputs_relu_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_bias_axis_0 = mesh_outputs_linear_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_relu_no_bias_axis_0 = mesh_outputs_relu_no_bias_reshaped.mean(axis=axis)\n",
    "mean_mesh_outputs_linear_no_bias_axis_0 = mesh_outputs_linear_no_bias_reshaped.mean(axis=axis)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArQAAAHBCAYAAACYOSg1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAB7CAAAewgFu0HU+AABXmElEQVR4nO3deXxU1fnH8e+dMNlJkCXsEAIYlmLCjoKAVEALVUBQqq1s0tZKRWkrFa37gv4QBOxiFUEqblUBLWApiiKISgWpWLYAEYoEYghRyTZJzu+PkDFDZkISZs/n/XqFZM49997nDvPMPHPnzD2WMcYIAAAACFG2QAcAAAAAnA8KWgAAAIQ0CloAAACENApaAAAAhDQKWgAAAIQ0CloAAACENApaAAAAhDQKWgAAAIQ0CloAAACENApaAAAAhDQKWgAAAIQ0CloAAACENApaAAAAhDQKWgAAAIQ0CloAAACENApaAAAAhDQKWgAAAIQ0CloAAACENApaAAAAhDQK2iCTnJwsy7KUmZnp0j558mRZlqVly5YFJK5A83S/nEt9v9+Acxk6dKgsy9J7771Xq/Xuu+8+WZal++67zydxAajKsixZllXr9eqa56GEghYA9P2bpso/0dHR6tChg376059q27ZtXt1fxT7O9QKTmZnp7HuuN3Q13SZQF+QIghkFbYho2bKlUlNTlZiYGOhQQgr3G2qrc+fOGjhwoAYOHKjOnTsrKytLK1as0MUXX6y//e1vgQ4vaDRt2lSpqalq2rRpoEOBn5Ejoaddu3ZKTU1VbGxsoEPxGQraEPHoo49qz549Gjt2bKBDCSncb6itOXPmaPPmzdq8ebM+//xzffXVVxo/frxKS0t1yy23KDc3N9AhBoUZM2Zoz549mjFjRqBDgZ+RI6Fn+fLl2rNnj/r16xfoUHyGghYAqnHBBRdoyZIliouL07fffqv169cHOiQgqJAjCAYUtCHC05ebKn8xIy8vT7fddpvatWunqKgoderUSQ8++KBKSko8bnfPnj2aOnWqkpOTFRUVpSZNmmjUqFF699133fY/ePCgHnvsMQ0dOlRt27ZVVFSUmjVrpiuuuEJr1qxxu857770ny7I0dOhQlZSU6PHHH1ePHj0UGxur5OTkWt8X//znPzV06FAlJiYqISFBw4cP1wcffOC2r6f7raCgQC+99JImTpyo1NRUxcfHKz4+Xunp6XrooYd0+vRpt9vLycnRb3/7W3Xp0kXR0dGKi4tTcnKyrrjiCv3pT3+q9bEgNCQkJOjCCy+UJI9j9P75z3/qqquuUvPmzRUVFaU2bdpoypQpOnDggB8jPT+ffPKJRo0apcaNGysuLk6XXHKJVq1a5bavpy+FlZaWavXq1Zo6daq6d++uxMRExcbGqmvXrrrjjjv09ddfu93e6dOn9cADD+iiiy5SXFycoqOj1bZtWw0dOlRz586Vw+Hw8tHCm8I5Ryp/oWrPnj2aMGGCmjZtqpiYGPXu3Vuvvvqqx3UdDocWL16sfv36KSEhQXFxcUpLS9PDDz+s/Pz884rrxRdfVL9+/RQfH6/GjRtrzJgx2rVr1zmPobJTp05pyZIluvrqq9WpUyfFxMQoMTFR/fv316JFizzWD19++aV+8YtfKCUlRVFRUWrYsKFSUlI0duxYvfzyy+d1XHVmEFTat29vJJlDhw65tE+aNMlIMkuXLnVpv/fee40kc9ttt5muXbuaBg0amPT0dJOcnGwkGUnmpptucruvV155xURGRhpJpmHDhiY9Pd20aNHCSDKWZZlFixZVWWfatGlGkomPjzcXXnih6dOnj2nZsqVzX3Pnzq2yzsaNG40kM3jwYDNq1CgjyXTs2NH07t3bdO/evVb3y6OPPmosyzKNGzc2ffr0MU2aNDGSjM1mM6+++mqV9Tzdbx988IGRZBo0aGDatGlj+vTpYzp37mwaNGhgJJlevXqZ/Px8l3VOnTplOnbsaCSZyMhI061bN9OrVy+TlJRkLMsyiYmJNToWBKeKx9jZj5UKqampRpLbvJg5c6YzB5KSkkzPnj1NQkKCkWQSEhLMli1bqqxT0X/jxo3VxnXo0CFn37OfF+q6zcqGDBliJJkHHnjAREZGmvj4+Cp5/cQTT1RZr+K5595773VpP3LkiDMnW7ZsaXr16mW6dOlioqOjjSSTnJxssrKyXNZxOBxmwIABzvVSU1NNnz59TKtWrYzNZjOSTG5ubo2PCb5R33Nk3rx5Jj4+3jRs2ND07t3bNGvWzLm9v/3tb1XWy8/PN8OGDXP26dq1q7noooucj+n09HTz9ddf1ziOyvE/9thjRpJp0aKF6dOnj2nYsKGRZGJiYswHH3zg8RjOPu6//e1vzte09u3bm759+5qUlBRnjKNGjTKlpaUu6xw6dMg0bdrUSDKxsbGmR48eJj093TRu3NhIMmlpabU6Jm+hoA0ydS1o7Xa7GTx4sDl69Khz2ZtvvmkiIiKMJLN7926X9Xbu3GmioqJMdHS0+etf/+rygH3zzTdNQkKCiYiIMJ999pnLemvXrjUfffSRKSsrc2nftGmTadmypYmIiDAZGRkuyyoK2oiICJOUlGQ+/PBD57KCgoJa3S8NGjQws2bNMsXFxcaY8hfCO+64w/mk+NVXX9XofsvMzDSvvvqq+fbbb13ajx07ZsaPH28kmfvuu89l2bx584wkM2LECJOTk+Oy7MsvvzQLFiyo0bEgOFX3Yr1v3z7nm51Nmza5LPvLX/5iJJkOHTq4vFiUlJSYhx56yEgybdq0qfJYD7YX6wYNGpiJEyea7777zhhjTFlZmVm0aJFz2dnPBZ4K2lOnTplly5ZVyZHc3FwzY8YMI8lMnjzZZdlrr73mfCE8cuSIy7ITJ06YJ5980pw+fbrGxwTfqO85YrfbzYwZM5xxlpWVmdmzZxtJplWrVqakpMRlvd/85jfOZZ9++qmzff/+/aZLly5Gkrn22mtrHEfl+O12u3niiSecr92nT582N9xwg5Fk2rdvX+WEjKeCdufOneYf//iHKSwsdGk/cOCAGTx4sJFkli1b5rKsIo8nTZpU5TV09+7d5umnn67VMXkLBW2QqWtBGxMTU+WFwBhjxo0bZySZ+fPnu21fuHCh2zgWL15sJJmpU6fWOPZnn33WSDIPP/ywS3tFQSvJvP766zXeXmUV94und369evUyksw999zj0u7pfqtOfn6+iYyMNJ07d3Zp/8UvfmEkmdWrV9c2fIQAdy/WeXl55l//+pfp1q2bkWQGDhzosk5RUZFp0aKFiYiIMNu3b3e73WuuucZIMsuXL3dpD7YX66SkJLdvMCueK2688UaXdk8F7bm0bdvWxMbGGofD4Wx79NFHq30+QnCo7zmSlpZW5WxlcXGx85PNyseXl5dnYmNjjSSzcuXKKtv85JNPjFT+aejZJ4FqEv9VV11VZVnFfS3JPPfcc26PoTbHnZGRYSSZ4cOHu7SPHDnSSDI7d+6s8bb8gTG0YeKKK65QmzZtqrT37dtXUvnY1wrFxcVau3atIiIiNHnyZLfbu+qqqyRJ77//fpVl2dnZWrhwoa6//npdfvnlGjRokAYNGqQnn3xSkrRz506320xMTNTVV19dm8Oq4le/+lW17f/85z9rvK2ysjKtXr1at9xyi6688kpdeumlGjRokIYPHy7LsrR//36XMU5t27aVJK1cubLacckIbVOmTHFeqzIxMVHDhw/Xnj17dN111+mtt95y6bt161ZlZWWpV69e6tmzp9vtVZdLwWTatGmKjo6u0l6X3JKkd999V7fffrtGjRqlwYMHO58n8vLylJ+fr/379zv7VuTWmjVrzntcIXyvvubI1KlTZbO5lk12u11paWmSXF9nN2/erPz8fLVr187t617fvn118cUXyxijf/3rX7WO5ZZbbqnSFhkZqZtuuklS7fK1qKhIL774oqZPn66RI0c6XwsnTZokqeprekW+vvbaazLG1Dp2X2kQ6ADgHR07dnTbnpSUJEn67rvvnG379u1TYWGhIiMj9aMf/cjtehUP0qNHj7q0r1+/Xtdee63y8vI8xnLy5Em37Z07d1ZERITng6iBrl27Vtu+b9++Gm3n1KlT+tGPfqStW7dW2y83N9d53b4pU6bo//7v/7Rs2TKtW7dOV1xxhS699FJddtllSklJqcVRIJh17txZSUlJMsYoKytLBw8elN1uV9++fXXBBRe49P38888llX8JZtCgQW63d+rUKUlVcynYnCu3jh8/rm+++UYJCQnVbqe4uFjXXXedxy+TVaj8PDFmzBglJydr/fr1atWqlTO3hg4dqu7du9fuQOBz9TVHavs6K0ldunTxOLNX9+7dtXXr1hq/blXmrdfCw4cPa8SIEdq7d6/HPme/pt9yyy16/vnn9eCDD2r58uUur4WtWrWq4RF4HwVtmIiLi3PbXvFusvK7qIpitLi4WFu2bKl2u4WFhc6/T506pYkTJyovL0833nijfvWrXyk1NVUJCQmy2WzasGGDhg8f7vHbyJ5irI2KJ46zNW/eXJL07bff1mg7s2bN0tatW5WamqpHHnlEAwYMUNOmTRUZGSlJatOmjY4ePepyLK1atdLWrVv1hz/8QWvWrNHzzz+v559/XpI0YMAAzZ8/XxdffPH5HB6CwJw5c1w+udiyZYvGjBmj3/72t2revLl++tOfOpdV5FJ2drays7Or3W5BQUGd4qn8JrC0tNRjv8qfGtTljaOn3Krc/u23356zoJ07d65WrVqlFi1a6PHHH9fgwYPVokULRUVFSZIGDRqkLVu2uORWXFycPvjgA91zzz167bXX9Morr+iVV16RJHXr1k2PPfaYRo8eXetjgm/U1xypzetsRXHrKa+k2r9uVeat18LJkydr79696t+/v+6//36lp6ercePGstvtKikpcf6uLD09XZs2bdK9996rd999V08//bSefvppWZal4cOH68knn/RYcPsSQw7qofj4eElS69atZcrHUVf7U2HdunXKzc3VxRdfrGXLlql///5q1KiRM5mPHDni89g9PSGeOHFCktSwYcNzbqOkpMR5mZXVq1dr3LhxatWqlbOYLSkpUVZWltt1u3btqtdee02nTp3Sxo0bdd9996lLly766KOPNGLEiHNOu4jQM3DgQD3zzDOSpJkzZ+qbb75xLqvIpRtuuOGceVTXqTYrz3JXcSbLncrL6jIznqfcqtxek/xasWKFJGnZsmX62c9+pvbt2zuLWcnz80SbNm303HPP6eTJk/roo480d+5c9enTR//97381ZswYffzxx7U5HPhRfcmR2qg47orXJneOHz8uqWZ5dTZvvBZ+9dVX2rhxo2JjY7V27VqNHDlSzZs3l91ul1T9a/qAAQP0z3/+U7m5uXr77bc1e/ZstWnTRuvXr9fw4cOr/X/wFQraeqhz586y2+06duyYx+EB7lQUaxdffLHbj1A8jZ31pt27d1fbXnEdxOpkZ2fr9OnTaty4sVJTU6ss37VrV7Xv8iUpKipKQ4cO1b333qtdu3Zp4MCB+u677/TSSy/V4CgQasaMGaMBAwbo5MmTmj9/vrO9W7dukuTx2o/ekJCQoBYtWpxzPxUf7UZERHj8aLQ658qt5s2bn/PsrPT988Qll1xSZVlOTs45P1Zu0KCB+vfvr9mzZ2vbtm2aOHGiSktL9dxzz51z3wic+pAjtVHxWrR7926P40y/+OILl7614Y3Xwi+//FJS+bCIxo0bV1lek9f0+Ph4jRw5UnPnztWePXvUsWNHHT16VOvWrTvnut5GQVsPxcbGauTIkSorK9OiRYtqvF5MTIyk799VVpaTk6MlS5Z4LUZPPE1eUNE+YsSIc26j4ji++eYbtx9xPf7447WKKSIiwvnlu6+++qpW6yJ0/P73v5ckLVq0yPlx4qWXXqqmTZtq586ddT67VBMVj+sXXnjBY5/ly5dLKj9bVpfhPUuWLFFRUVGV9trkllT988QTTzxxzjeLZxswYIAkcisU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2rQqyydMmKCbb75ZOTk52rhxo0aMGOHvEAEACArGGIYcoFphW9BWXOWgpvx9lYMdO3aouLhY0dHR6tWrV5Xldrtdffv21TvvvKOPP/6YghYAUG+ZMiNHMWdo4Vm9usqBO5ZlyRjj96sc7N+/X5LUrl07NWjg/u5ISUnRO++84+wLAEB9VD7koDjQYSCIhe0Z2uqucnD69GllZGTomWee0fr167VgwQK/zyaWm5srSbrgggs89qlYVtEXAIB6yRiVOLgOLaoRrgXtua5y0K1bN1111VWaO3eubr/9dvXq1cuvV0YoLCyUJEVGRnrsExUVJal8cggAAOorY4xKOEOLaoTtGdqauuOOO/TEE0/o/vvv17p16/y23+joaElScbHnBC0qKpIkxcTE+CUmAACCkTFGpUysgGoEqqANmpkCbDabOnTooI8++siv+63JcIKaDEsAAABAYARNQVtSUqKMjAyVlPh3bE7nzp0lSYcPH/a474MHD7r0BQAAQPAIiiEHubm5mjVrlk6dOqVLL73Ur/vu2bOn7Ha7CgsLtX37dvXr189lucPh0LZt2yRJ/fv392tsAADUV6asLNAhoC7CderbYcOGeVxmjFF2drYOHjyowsJC2e123X///b4OyUVCQoIuv/xyrVu3TkuWLKlS0P7973/XN998oyZNmmjo0KF+jQ0AgKBiKDQRnHxe0L733ns16tevXz899thjGjJkiG8DcuOuu+7S22+/rWeffVZDhw51Tn+7c+dOzZo1S1L5l9aquxICAAAAAsPnBe3GjRs9LrMsS3FxcUpJSQnoF64GDhyoBx98UHfffbeuv/563X333YqPj9euXbtUVlamUaNG6Te/+U3A4gMAAIBnPi9oA3HGtS7uuusupaWlacGCBfr000+VlZWlHj16aMqUKZoxY4YiIiICHSIAAADc8HlBu3z5cjVv3lwjR448Z9/169crKytLN954o6/Dcmv06NEaPXp0QPYNAACAuvH5ZbsmT56sRx55pEZ9H330UU2ZMsXHEQEAACCc+OU6tDWdNSJQs0sAAAAgdAXNxAqSlJWVpbi4uECHAQAAgBDi9TG0hw8fVmZmpktbXl6eNm3a5HGdgoICvf/++9q3bx+TFwAAAKBWvF7QLl26VA888IBL265du3TZZZdVu17FcIPbbrvN2yEBAAAgjHm9oE1OTtbgwYOd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mMaPH6/HH39cWVlZXok7nJFr5Bq55h/kGrkWKrlGQetF+/fvlyRFRUWpVatWbvukpKS49K2Nzz77TC+99JI2btyo1atX67777lNqaqoefvjhugftZRXH1a5dOzVo4P47h+dzHwSCL49p06ZNeu2117Rx40a9/vrrmj17tlJSUrRs2bLzijnckWvkGrnmH+QauRYquUZB60W5ubmSpEaNGsmyLLd9Kr61WdG3Jho1aqRf//rX2rJli44fP67CwkLt2LFDP/vZz1RaWqq7775bTz311PkfgBdUHFd1306ty30QSL44ppYtW2rOnDnatm2bcnJylJ+fry1btujKK69UQUGBpk6dqrfeeuv8gw9T5Bq5Rq75B7lGroVKrnHZLi+quBZfZGSkxz5RUVGSpIKCghpvd8yYMRozZoxLW3p6upYvX64mTZroySef1N13361JkyapYcOGtQ/ci3x1HwSSL47pF7/4RZW2Sy65RGvWrNE111yjlStX6vbbb9fo0aM9vojUZ+QauUau+Qe5Rq6FSq5xhtaLoqOjJUnFxcUe+xQVFUmSYmJivLLP+++/X1FRUcrLy9O7777rlW2ej0DcB77mz2OyLEtz586VJB04cED/+c9/zmt74YpcI9fINf8g18i1UMk1ztDW0oQJE5wD5CvbvHmz8/T8qVOnZIxx+w6kJqf5ayMhIUHdu3fX9u3blZGR4ZVtno+afETh7fvA1/x9TBdeeKEaN26skydPKiMjQ2lpaee9zVBErlWPXCPXvIVcqx65Fhq5RkFbS9u2bdOXX37pdlnFbCdFRUX66quv1Lp16yp9Dh486NLXG+x2uySppKTEa9usq4rjOnz4sEpKStwONvfFfeBLgTimYPo/DRRyrXrkGrnmLeRa9ci10Mg1hhzUUmZmpkz5hBQuP1L5twVbtGghSdqyZYvb9Sva+/fv75V4SktLtXfvXklSmzZtvLLN89GzZ0/Z7XYVFhZq+/btVZY7HA5t27ZNkvfuA1/z9zF9/fXXOnHihKTg+D8NFHKteuQaueYt5Fr1yLUQyTW/TuNQD9x88801mlHl2LFjXtnf008/bSSZiIgI87///c8r2zxfV155ZY1mHykqKgpAdHXjz2O68847jSSTmJgYUveRv5Fr5Nr5Itdqhlwj186XP3KNgtbLDh48aCIjI6ud8/rmm2+ust7f//530759ezNw4ECX9ry8PDNx4kTz8ccfu7SXlJSYv/71ryY6OtrjAzJQNm/efM75oR977LEARlh7dTmmBQsWmPbt25vrrrvOpX3Xrl3m5ptvNrt27XJpLygoMA8//LCx2WxGknnkkUd8d0BhgFwj1yqQa75FrpFrFYI51yhofeD55593/ue1bt3a9OzZ09jtdiPJ9O7d23z33XdV1qmY17p9+/Yu7bm5uUaSkWQaNWpkevbsafr27WsaNWrkbL/yyitNQUGBn46uZh566CFnfCkpKeaiiy5y3iejRo0yJSUlgQ6x1mp7TBXzWg8ZMsSlfceOHc7tNGvWzPTu3dv07t3bxMbGOtunTZvmfNGAZ+QauWYMueYP5Bq5Zkxw5xoFrY9s2bLFjB492jRu3NhERUWZ1NRUc99993lMUE+JX1xcbB5//HEzZswY06lTJ5OQkGDsdrtp0aKFGTVqlHnllVeC9sn4rbfeMsOGDTOJiYkmNjbWpKWlmSeffDIkk75CbY7JU+Ln5uaaBx980Fx55ZWmQ4cOJj4+3kRGRpo2bdqY8ePHm7fffttPRxMeyDVyjVzzD3KNXAvmXLOMOTPyGwAAAAhBXOUAAAAAIY2CFgAAACGNghYAAAAhjYIWAAAAIY2CFgAAACGNghYAAAAhjYIWAAAAIY2CFgAAACGNghYAAAAhjYIWAAAAIY2CFgAAACGNghYAAAAhjYIWAAAAIY2CFgAAACGNghYAAAAhjYLWi5KTk2VZljIzM13aJ0+eLMuytGzZsoDEFQwyMzM1ceJEJSUlyWaz1fv7A+eHXPOMXIM3kWuekWvBpUGgA0D4Kyoq0rBhw3To0CE1a9ZM/fv3V0REhJo3b+73WFatWqXPPvtMY8aMUXp6ut/3D/gSuQb4B7kWfCho/aBly5ZKTU1VYmJioEMJiH/+8586dOiQ+vTpo82bNysqKipgsaxatUrPP/+8kpOT63XihytyjVyDf5Br5FqwYciBHzz66KPas2ePxo4dG+hQAmLPnj2SpGHDhgU06RH+yDVyDf5BrpFrwYaCFj5XUFAgSYqJiQlwJEB4I9cA/yDXgpCB17Rv395IMocOHXJpnzRpkpFkli5d6tJ+7733Gknm3nvvNadOnTIzZ840bdu2NZGRkaZjx47mgQceMA6Hw+P+du/ebaZMmWLat29vIiMjTePGjc2PfvQj884777jtf+DAATN37lwzZMgQ06ZNGxMZGWmaNm1qRo4caf7xj3+4XWfjxo1GkhkyZIhxOBzmscceMz/4wQ9MTEyMad++fbX3x9KlS40ktz9nr+twOMyf//xnM3DgQJOYmGiioqJMamqqueuuu0xeXl6VbZeUlJhVq1aZKVOmmG7dupmEhAQTExNjunTpYn73u9+Z7Oxsl/6HDh3yGEvF/0HlftUdW8U61bW/9tpr5tJLLzWJiYlVHhM5OTlmzpw5pnv37iY2NtbEx8eb/v37m7/+9a+mtLS02vsU5cg1V+QaueYr5Jorci14c42C1ovqmvi33Xab6dq1q2nQoIFJT083ycnJzgfRTTfd5HZfr7zyiomMjDSSTMOGDU16erpp0aKFkWQsyzKLFi2qss60adOMJBMfH28uvPBC06dPH9OyZUvnvubOnVtlnYrEHzx4sBk1apSRZDp27Gh69+5tunfvXu39sXbtWjNw4EDTtm1bI8m0bdvWDBw40AwcONCMHz/e2S8vL88MHjzYSDI2m820b9/e/OAHP3AeX9euXc3x48ddtn3kyBFn/5YtW5pevXqZLl26mOjoaCPJJCcnm6ysLGf/Y8eOmYEDB5qkpCQjyXTu3NkZy8CBA82SJUuMMd5J/Llz5xpJpnnz5qZv376mWbNmzsfErl27TOvWrY0kExkZabp162Y6duxoLMsyksz48eNNWVlZtfcryLWzkWvkmq+Qa67IteDNNQpaL6pr4tvtdjN48GBz9OhR57I333zTREREGElm9+7dLuvt3LnTREVFmejo6Crvft58802TkJBgIiIizGeffeay3tq1a81HH31U5YG1adMm07JlSxMREWEyMjJcllUkfkREhElKSjIffvihc1lBQUGN7pfK79jdmThxopFkfvjDH5oDBw4420+ePGnGjRvnTIjKTp06ZZYtW2ZycnJc2nNzc82MGTOMJDN58uQq+/L0f1HBG4kfGRlp/vrXvzrvZ4fDYRwOh/nuu+9Mx44djSRz6623urxD/+KLL0z37t2NJPPUU0953DfKkWvukWvkmreRa+6Ra8GXaxS0XlTXxI+JiTFHjhypsr2KB/38+fPdti9cuNBtHIsXLzaSzNSpU2sc+7PPPmskmYcfftilvSLxJZnXX3+9xturrLrE37lzpzPRvvnmmyrLT58+bdq2bWssyzKZmZk13mfbtm1N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",
      "text/plain": [
       "<Figure size 800x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ((ax1, ax2, ax3), (ax4, ax5, ax6)) = plt.subplots(2, 3, figsize=(4, 2), dpi=200)\n",
    "y_tick_fontsize = 8\n",
    "x_tick_fontsize = 8\n",
    "\n",
    "# Create the image mappable objects first (don't call imshow twice)\n",
    "ax1.imshow(mean_mesh_outputs_linear_bias_axis_0[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "ax1.set_title(\"linear bias\", fontsize=8)\n",
    "ax1.set_xticks([])\n",
    "ax1.set_yticks([7, 48, 93])\n",
    "ax1.set_yticklabels([1, 0, -1])\n",
    "# ax1.set_xlabel(\"linear feature\", fontsize=8)\n",
    "ax1.set_ylabel(\"feature 2\", fontsize=8)\n",
    "# ax4.set_ylabel(\"feature 2\", fontsize=8)\n",
    "# remove the ticks themselves\n",
    "ax1.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax1.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax1.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "\n",
    "ax2.imshow(mean_mesh_outputs_relu_bias_axis_0[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "ax2.set_title(\"ReLU bias\", fontsize=8)\n",
    "ax2.set_xticks([])\n",
    "ax2.set_yticks([])\n",
    "# remove the ticks themselves\n",
    "ax2.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax2.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax2.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "\n",
    "ax3.imshow(mean_mesh_outputs_relu_no_bias_axis_0[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "ax3.set_title(\"ReLU no bias\", fontsize=8)\n",
    "# reset x and y ticks and set ticks at -1, 0, 1\n",
    "# remove x ticks\n",
    "ax3.set_xticks([])\n",
    "ax3.set_yticks([])\n",
    "\n",
    "# remove the ticks themselves\n",
    "ax3.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax3.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax3.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "\n",
    "ax4.imshow(mean_mesh_outputs_linear_bias_axis_1[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "# ax4.set_title(\"linear bias\", fontsize=8)\n",
    "ax4.set_xticks([7, 48, 93])\n",
    "ax4.set_xticklabels([-.5, 0, .5])\n",
    "ax4.set_yticks([7, 48, 93])\n",
    "ax4.set_yticklabels([1, 0, -1])\n",
    "ax4.set_xlabel(\"linear feature\", fontsize=8)\n",
    "ax4.set_ylabel(\"feature 1\", fontsize=8)\n",
    "# remove the ticks themselves\n",
    "ax4.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax4.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax4.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "\n",
    "ax5.imshow(mean_mesh_outputs_relu_bias_axis_1[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "# ax5.set_title(\"ReLU bias\", fontsize=8)\n",
    "ax5.set_xticks([7, 48, 93])\n",
    "ax5.set_xticklabels([-.5, 0, .5])\n",
    "# ax5.set_yticks([7, 48, 93])\n",
    "# ax5.set_yticklabels([1, 0, -1])\n",
    "ax5.set_yticks([])\n",
    "ax5.set_xlabel(\"linear feature\", fontsize=8)\n",
    "# ax5.set_ylabel(\"feature 2\", fontsize=8)\n",
    "# remove the ticks themselves\n",
    "ax5.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax5.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax5.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "\n",
    "ax6.imshow(mean_mesh_outputs_relu_no_bias_axis_1[:, :, 0], cmap=\"coolwarm\", vmin=0, vmax=1)\n",
    "# ax6.set_title(\"ReLU no bias\", fontsize=8)\n",
    "# reset x and y ticks and set ticks at -1, 0, 1\n",
    "ax6.set_xticks([7, 48, 93])\n",
    "ax6.set_xticklabels([-.5, 0, .5])\n",
    "# ax6.set_yticks([7, 48, 93])\n",
    "# ax6.set_yticklabels([1, 0, -1])\n",
    "ax6.set_yticks([])\n",
    "ax6.set_xlabel(\"linear feature\", fontsize=8)\n",
    "# ax6.set_ylabel(\"feature 2\", fontsize=8)\n",
    "# remove the ticks themselves\n",
    "ax6.tick_params(axis='x', which='both', length=0, labelsize=x_tick_fontsize)\n",
    "ax6.tick_params(axis='y', which='both', length=0, labelsize=y_tick_fontsize)\n",
    "# increase frame width (fixed: was applying to ax2 instead of ax1)\n",
    "for spine in ax6.spines.values():\n",
    "    spine.set_linewidth(1.3)\n",
    "# plt.tight_layout()\n",
    "save_figure('/relu_nets_bias/', '3D-XOR_problem_decision_function', 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
}
