{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from reluNets.plotting.network_plotting_functions import plot_single_metric_axis, save_figure\n",
    "from reluNets.hieararchical_data.make_dataset import load_hierarchy_data\n",
    "from reluNets.analytical_solutions.analytical_solutions import analytical_svs, ana_weights, ana_outputs, ana_loss\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1461,
   "metadata": {},
   "outputs": [],
   "source": [
    "choice_temp = 0.2\n",
    "scale = 0.0002\n",
    "bucket_size = 1\n",
    "log_interval = 1 * bucket_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# lets get our exact solutions for the weights now\n",
    "# start with loading data\n",
    "include_head_property = False\n",
    "include_bias_input = True\n",
    "include_control_planet = False\n",
    "batch_size = 8\n",
    "n = 8\n",
    "\n",
    "train_inputs, train_labels,_ = load_hierarchy_data(batch_size,\n",
    "                                                    include_head_property,\n",
    "                                                    include_bias_input)\n",
    "\n",
    "train_inputs = np.transpose(train_inputs)\n",
    "train_labels = np.transpose(train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1466,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the input and output covariance matrices\n",
    "input_covar = 1/(batch_size)*(train_inputs @ train_inputs.T)\n",
    "output_covar = 1/(batch_size)*(train_labels @ train_inputs.T)\n",
    "# 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": [],
   "source": [
    "# hyperparameters\n",
    "t= np.arange(0, 15000, 1)[np.newaxis]\n",
    "a_0 = 0.0000013\n",
    "step_size = 0.001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1477,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 15000)"
      ]
     },
     "execution_count": 1477,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ana_sol_svs = analytical_svs(t, s, delta, a_0, step_size=step_size, batch_size=batch_size)\n",
    "ana_sol_svs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(15000, 14, 9)"
      ]
     },
     "execution_count": 1478,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# getting the analytical weights\n",
    "ana_weights_bias = ana_weights(u, ana_sol_svs, vt)\n",
    "ana_weights.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the analytical outputs (time x outputs x batch_size)\n",
    "ana_outputs_bias = ana_outputs(u, ana_sol_svs, vt, train_inputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1480,
   "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 12.000000953674316\n",
      "Epoch 1000, Loss 8.689836502075195\n",
      "Epoch 2000, Loss 8.44283390045166\n",
      "Epoch 3000, Loss 5.501303672790527\n",
      "Epoch 4000, Loss 3.5104429721832275\n",
      "Epoch 5000, Loss 1.975797414779663\n",
      "Epoch 6000, Loss 1.701277494430542\n",
      "Epoch 7000, Loss 0.8378723859786987\n",
      "Epoch 8000, Loss 0.11079584807157516\n",
      "Epoch 9000, Loss 0.004492070991545916\n",
      "Epoch 10000, Loss 0.00012109307863283902\n",
      "Epoch 11000, Loss 3.1617933018424083e-06\n",
      "Epoch 12000, Loss 8.780376248296307e-08\n",
      "Epoch 13000, Loss 4.311140777701894e-09\n",
      "Epoch 14000, Loss 2.001581789201623e-09\n",
      "Epoch 15000, Loss 1.5969990885267293e-09\n",
      "Epoch 16000, Loss 1.4411111193268766e-09\n",
      "Epoch 17000, Loss 1.371218028012322e-09\n",
      "Epoch 18000, Loss 1.3191354675257116e-09\n",
      "Epoch 19000, Loss 1.2850078778825491e-09\n"
     ]
    }
   ],
   "source": [
    "# train a small relu network on the task xor task \n",
    "# hyperparameters\n",
    "input_size = 9\n",
    "hidden_size = 64\n",
    "output_size = 14\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 forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    \n",
    "    def get_weights(self):\n",
    "        return self.fc1.weight.data, self.fc2.weight.data\n",
    "    \n",
    "    def get_preactivation(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return torch.relu(self.fc1(x))\n",
    "    \n",
    "# initialize the model\n",
    "model = ReluNet()\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(model.fc1.weight.data)*scale\n",
    "init_weights_2 = torch.randn_like(model.fc2.weight.data)*scale\n",
    "\n",
    "model.fc1.weight.data = init_weights_1\n",
    "model.fc2.weight.data = init_weights_2\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)*scale\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)*scale\n",
    "    model.fc2.bias.data = init_bias_2\n",
    "\n",
    "# copy and detach weights to keep them for later use\n",
    "init_weights_1 = init_weights_1.detach().clone()\n",
    "init_weights_2 = init_weights_2.detach().clone()\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=False)\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",
    "    hidden_activations = []\n",
    "    preactivations = []\n",
    "    weights_1 = []\n",
    "    weights_2 = []\n",
    "    for epoch in range(20000):\n",
    "        for inputs, labels in train_loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            hidden_activation = model.get_hidden(inputs)    \n",
    "            # convert to numpy array\n",
    "            hidden_activations.append(hidden_activation.detach().numpy())\n",
    "            preactivations.append(model.get_preactivation(inputs).detach().numpy())\n",
    "            w1, w2 = model.get_weights()\n",
    "            weights_1.append(w1.detach().clone().numpy())\n",
    "            weights_2.append(w2.detach().clone().numpy())\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",
    "    return np.array(hidden_activations), np.array(weights_1), np.array(weights_2), np.array(preactivations), np.array(losses)\n",
    "\n",
    "_, weights_1_relu, weights_2_relu, preactivations_relu, losses_relu = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 11.999996185302734\n",
      "Epoch 1000, Loss 8.531205177307129\n",
      "Epoch 2000, Loss 8.389110565185547\n",
      "Epoch 3000, Loss 5.059357643127441\n",
      "Epoch 4000, Loss 2.8819079399108887\n",
      "Epoch 5000, Loss 1.906154990196228\n",
      "Epoch 6000, Loss 1.4212700128555298\n",
      "Epoch 7000, Loss 0.36440736055374146\n",
      "Epoch 8000, Loss 0.017335833981633186\n",
      "Epoch 9000, Loss 0.00037753608194179833\n",
      "Epoch 10000, Loss 7.065304544084938e-06\n",
      "Epoch 11000, Loss 1.2970770058018388e-07\n",
      "Epoch 12000, Loss 3.673576554064084e-09\n",
      "Epoch 13000, Loss 2.157379608291876e-09\n",
      "Epoch 14000, Loss 1.992879417045401e-09\n",
      "Epoch 15000, Loss 1.9325052669216802e-09\n",
      "Epoch 16000, Loss 1.8893975273215347e-09\n",
      "Epoch 17000, Loss 1.867232812813313e-09\n",
      "Epoch 18000, Loss 1.8478102381536132e-09\n",
      "Epoch 19000, Loss 1.830235407673797e-09\n"
     ]
    }
   ],
   "source": [
    "class LinearNet(torch.nn.Module):\n",
    "    def __init__(self, input_size, output_size):\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 forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def get_weights(self):\n",
    "        return self.fc1.weight.data, self.fc2.weight.data\n",
    "    def get_preactivation(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "\n",
    "model = LinearNet(input_size, output_size)\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(model.fc1.weight.data)*scale\n",
    "init_weights_2 = torch.randn_like(model.fc2.weight.data)*scale\n",
    "model.fc1.weight.data = init_weights_1\n",
    "model.fc2.weight.data = init_weights_2\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)*scale\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)*scale\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=False)\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",
    "_, _ , _, _, losses_linear = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 12.0\n",
      "Epoch 1000, Loss 11.999259948730469\n",
      "Epoch 2000, Loss 11.91522216796875\n",
      "Epoch 3000, Loss 7.070807933807373\n",
      "Epoch 4000, Loss 2.305082321166992\n",
      "Epoch 5000, Loss 1.2580896615982056\n",
      "Epoch 6000, Loss 0.5300766229629517\n",
      "Epoch 7000, Loss 0.10797753185033798\n",
      "Epoch 8000, Loss 0.011499805375933647\n",
      "Epoch 9000, Loss 0.0009656046167947352\n",
      "Epoch 10000, Loss 8.336327300639823e-05\n",
      "Epoch 11000, Loss 8.21537287265528e-06\n",
      "Epoch 12000, Loss 9.583650353306439e-07\n",
      "Epoch 13000, Loss 1.316716407018248e-07\n",
      "Epoch 14000, Loss 2.330848403175878e-08\n",
      "Epoch 15000, Loss 7.683397029722983e-09\n",
      "Epoch 16000, Loss 4.505653627973061e-09\n",
      "Epoch 17000, Loss 3.6492142641009195e-09\n",
      "Epoch 18000, Loss 3.3697158396961413e-09\n",
      "Epoch 19000, Loss 3.209747800880791e-09\n"
     ]
    }
   ],
   "source": [
    "train_inputs_no_bias = train_inputs[1:]\n",
    "input_size = 8\n",
    "hidden_size = 64\n",
    "output_size = 14\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 forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def get_weights(self):\n",
    "        return self.fc1.weight.data, self.fc2.weight.data\n",
    "    def get_preactivation(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return torch.relu(self.fc1(x))\n",
    "    \n",
    "# initialize the model\n",
    "model = ReluNet()\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(model.fc1.weight.data)*scale\n",
    "init_weights_2 = torch.randn_like(model.fc2.weight.data)*scale\n",
    "\n",
    "model.fc1.weight.data = init_weights_1\n",
    "model.fc2.weight.data = init_weights_2\n",
    "\n",
    "# copy and detach weights to keep them for later use\n",
    "init_weights_1 = init_weights_1.detach().clone()\n",
    "init_weights_2 = init_weights_2.detach().clone()\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_no_bias.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=False)\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",
    "_, _, _, _, losses_relu_no_bias = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1484,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 12.0\n",
      "Epoch 1000, Loss 11.998702049255371\n",
      "Epoch 2000, Loss 11.780805587768555\n",
      "Epoch 3000, Loss 5.287203311920166\n",
      "Epoch 4000, Loss 2.9846935272216797\n",
      "Epoch 5000, Loss 1.8919873237609863\n",
      "Epoch 6000, Loss 1.3532578945159912\n",
      "Epoch 7000, Loss 0.30966252088546753\n",
      "Epoch 8000, Loss 0.013615447096526623\n",
      "Epoch 9000, Loss 0.00029138894751667976\n",
      "Epoch 10000, Loss 5.439354026748333e-06\n",
      "Epoch 11000, Loss 1.002722669340983e-07\n",
      "Epoch 12000, Loss 3.8316159134410555e-09\n",
      "Epoch 13000, Loss 2.324297421196775e-09\n",
      "Epoch 14000, Loss 2.135675414294269e-09\n",
      "Epoch 15000, Loss 2.0693828872708764e-09\n",
      "Epoch 16000, Loss 2.0295964908711994e-09\n",
      "Epoch 17000, Loss 2.001537158236033e-09\n",
      "Epoch 18000, Loss 1.9860455502396235e-09\n",
      "Epoch 19000, Loss 1.9752555147078965e-09\n"
     ]
    }
   ],
   "source": [
    "class LinearNet(torch.nn.Module):\n",
    "    def __init__(self, input_size, output_size):\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 forward(self, x):\n",
    "        x = self.fc1(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def get_weights(self):\n",
    "        return self.fc1.weight.data, self.fc2.weight.data\n",
    "    \n",
    "    def get_preactivation(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return self.fc1(x)\n",
    "    \n",
    "\n",
    "model = LinearNet(input_size, output_size)\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(model.fc1.weight.data)*scale\n",
    "init_weights_2 = torch.randn_like(model.fc2.weight.data)*scale\n",
    "model.fc1.weight.data = init_weights_1\n",
    "model.fc2.weight.data = init_weights_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_no_bias.T, dtype=torch.float32), \n",
    "                                                          torch.tensor(train_labels.T, dtype=torch.float32)), \n",
    "                          batch_size=n, shuffle=False)\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",
    "\n",
    "_, _,_, _,losses_linear_no_bias = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1487,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the input and output covariance matrices\n",
    "input_covar = 1/(batch_size)*(train_inputs_no_bias @ train_inputs_no_bias.T)\n",
    "output_covar = 1/(batch_size)*(train_labels @ train_inputs_no_bias.T)\n",
    "# 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]\n",
    "# hyperparameters\n",
    "t= np.arange(0, 15000, 1)[np.newaxis]\n",
    "a_0 = 0.0000013\n",
    "step_size = 0.001 # should load this from the wandb config\n",
    "ana_sol_svs = analytical_svs(t, s, delta, a_0, step_size=step_size, batch_size=batch_size)\n",
    "ana_loss_no_bias = ana_loss(u, ana_sol_svs, vt, train_inputs_no_bias, train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1491,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AoKDgzFs2DA899xzmDRpkl355cuXY+jQodi3bx9OnTqF/Px8VFRUIDw8HIMHD8YjjzyC2bNnO1wiy8vLs/3829/+tsn9+vbbbyM0NBTbtm1Dbm4uLl26BACIjo5ucl2erO6GkePHj7faPq69zHju3DnExsa22r7IMzFOMU61RIeJU62S7hJRs7j6SkF3efnll21nKXyVK2citm7dajtLkJ6e3irteOedd2z7OHnyZKvsg8gdGKfani/FKd78ROTD9u7dCwC2GxWofvfddx+6d+8OAPjDH/7g9IHjda6/YeT6s1XXq6iowFtvvQXgylmPfv36taC1RB0L45RrOkqcYmJK5KNMJhMOHjyIiRMnIi4urr2b02YMBgOKiopsH6vVCuDK222uXV5RUWHbxs/PD2vXroWiKDhy5AiGDx+OlJQU1NTU2MpkZWVh/fr1iI2Nxdq1a+32OXXqVCxZsgQZGRl2b+oxGo347LPPMHz4cJw8eRIA8NJLLzlcoiXyVYxTPhinWuU8LBE1S1tfIvNFdZfEGvvMmTPHYdvNmzfb3Ryi0WgkLCzMdodz3WflypV229X9u+LqTSldunSRkJAQuxtadDqdrFq1qo16gaj5GKdany/HKd78RETkokcffRRjx47F2rVrsWvXLpw7dw6lpaUIDAxE//79MWLECNtrFa/1xhtv4Msvv8T+/ftx4cIFFBQUoLq6GqGhoejbty/GjBmDxx9/vFXfP01EvsHb45Qi0sArIoiIiIiI2ggnMhERERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BGYmBIRERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BGYmBIRERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BGYmBIRERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BGYmBIRERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BGYmBIRERGRR2BiSkREREQegYkpEREREXkEJqZERERE5BH+P7gK3pj26F1EAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 680x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses = np.array(losses_relu)\n",
    "losses_relu_no_bias = np.array(losses_relu_no_bias)\n",
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))\n",
    "fig, (ax1, ax2) = 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",
    "# set x and y limits\n",
    "plot_single_metric_axis(ax1, \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",
    "# fig, ax = plt.subplots()\n",
    "ax1.plot(np.array(losses_linear), color=color_list[1], label=\"Linear\", linewidth=1.6)\n",
    "# ax1.plot(ana_loss_relu, color=color_list[2], linestyle=\"--\", label=\"Analytical relu + bias\", linewidth=1)\n",
    "ax1.plot(ana_loss_bias, color=color_list[2], linestyle=\"--\", label=\"Analytical\", linewidth=2)\n",
    "# ax.plot(losses_linear_no_bias, color=color_list[1], label=\"Empirical linear+no bias\", linewidth=1.5)\n",
    "# ax.plot(losses_linear_bias, color=color_list[1], label=\"Empirical linear+bias\", ;)\n",
    "# ax.plot(losses, label=\"Empirical\", linewidth=1.4)\n",
    "ax1.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax1.set_xlim([-100, 8100])\n",
    "# set title \n",
    "ax1.set_title(\"Bias\", fontsize=10)\n",
    "ax1.xaxis.get_offset_text().set_fontsize(9)\n",
    "\n",
    "plot_single_metric_axis(ax2, \n",
    "                        metric_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",
    "# fig, ax = plt.subplots()\n",
    "ax2.plot(losses_linear_no_bias, color=color_list[1], label=\"Linear\", linewidth=1.6)\n",
    "ax2.plot(ana_loss_no_bias, color=color_list[2], linestyle=\"--\", label=\"Analytical\", linewidth=2)\n",
    "# turn of y labels on ax2 but dont remove the grid lines\n",
    "ax2.yaxis.set_tick_params(labelleft=False)\n",
    "# ax2.plot(ana_loss, color=color_list[2], linestyle=\"--\", label=\"Analytical linear + bias\", linewidth=2.5)\n",
    "# ax.plot(losses_linear_no_bias, color=color_list[1], label=\"Empirical linear+no bias\", linewidth=1.5)\n",
    "# ax.plot(losses_linear_bias, color=color_list[1], label=\"Empirical linear+bias\", ;)\n",
    "# ax.plot(losses, label=\"Empirical\", linewidth=1.4)\n",
    "ax2.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax2.set_xlim([-100, 8100])\n",
    "\n",
    "# set title \n",
    "ax2.set_title(\"No Bias\", fontsize=10)\n",
    "ax2.xaxis.get_offset_text().set_fontsize(9)\n",
    "plt.tight_layout()\n",
    "save_figure('/relu_nets_bias/', 'linear_and_ReLU_loss_exact_solution', 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
}
