{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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",
    "from reluNets.plotting.data_figs import plot_SVD, plot_data, plot_data_axis\n",
    "# This notebook plot the TNR and TPR of the relu net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "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": 6,
   "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# hyperparameters\n",
    "t= np.arange(0, 15000, 1)[np.newaxis]\n",
    "a_0 = 0.0000006\n",
    "step_size = 0.001 # should load this from the wandb config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 15000)"
      ]
     },
     "execution_count": 9,
     "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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(15000, 14, 9)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# getting the analytical weights\n",
    "ana_weights = ana_weights(u, ana_sol_svs, vt)\n",
    "ana_weights.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the analytical outputs (time x outputs x batch_size)\n",
    "ana_outputs = ana_outputs(u, ana_sol_svs, vt, train_inputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# calculate the analytical loss at each time step\n",
    "ana_loss = ana_loss(u, ana_sol_svs, vt, train_inputs, train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 12.0\n",
      "Epoch 1000, Loss 8.658472061157227\n",
      "Epoch 2000, Loss 8.44019603729248\n",
      "Epoch 3000, Loss 5.4652276039123535\n",
      "Epoch 4000, Loss 3.501857280731201\n",
      "Epoch 5000, Loss 1.9565945863723755\n",
      "Epoch 6000, Loss 1.6089951992034912\n",
      "Epoch 7000, Loss 0.6614187955856323\n",
      "Epoch 8000, Loss 0.06495455652475357\n",
      "Epoch 9000, Loss 0.0022686359006911516\n",
      "Epoch 10000, Loss 6.410726200556383e-05\n",
      "Epoch 11000, Loss 1.9693518424901413e-06\n",
      "Epoch 12000, Loss 7.176765848271316e-08\n",
      "Epoch 13000, Loss 4.896494321116052e-09\n",
      "Epoch 14000, Loss 1.9597945488669666e-09\n",
      "Epoch 15000, Loss 1.465327414962303e-09\n",
      "Epoch 16000, Loss 1.2566316875961547e-09\n",
      "Epoch 17000, Loss 1.189449316818525e-09\n",
      "Epoch 18000, Loss 1.142387295871572e-09\n",
      "Epoch 19000, Loss 1.1127978538638672e-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_epochs = 20000\n",
    "\n",
    "# define a pytorch relu_model and initialize weights as small gaussian\n",
    "class ReluNet(torch.nn.Module):\n",
    "    def __init__(self, input_size=input_size, hidden_size=hidden_size, output_size=output_size):\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",
    "        self.leaky_relu = torch.nn.LeakyReLU(0.5)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        # x = self.fc1(x)\n",
    "        # x = self.leaky_relu(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        # x = self.fc1(x)\n",
    "        # return self.leaky_relu(x)\n",
    "        return torch.relu(self.fc1(x))\n",
    "    \n",
    "# initialize the relu_model\n",
    "relu_model = ReluNet(input_size, hidden_size, output_size)\n",
    "# initialize the weights\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(relu_model.fc1.weight.data)*0.0002\n",
    "init_weights_2 = torch.randn_like(relu_model.fc2.weight.data)*0.0002\n",
    "\n",
    "relu_model.fc1.weight.data = init_weights_1\n",
    "relu_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.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(relu_model.parameters(), lr=0.001)\n",
    "\n",
    "# define the loss function\n",
    "loss = torch.nn.MSELoss(reduction='sum')\n",
    "\n",
    "# train the relu_model\n",
    "def train(model, train_loader, optimizer):\n",
    "    losses = []\n",
    "    hidden_activations = []\n",
    "    weights_1 = []\n",
    "    weights_2 = []\n",
    "    for epoch in range(n_epochs):\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",
    "            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",
    "            if epoch % 10 == 0:\n",
    "                weights_1.append(model.fc1.weight.data.detach().cpu().numpy().copy())\n",
    "                weights_2.append(model.fc2.weight.data.detach().cpu().numpy().copy())\n",
    "\n",
    "    return np.array(weights_1), np.array(weights_2), np.array(hidden_activations), losses\n",
    "\n",
    "weights_1_relu, weights_2_relu, hidden_activations_relu, losses_relu = train(relu_model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0, Loss 11.999998092651367\n",
      "Epoch 1000, Loss 8.527804374694824\n",
      "Epoch 2000, Loss 8.396817207336426\n",
      "Epoch 3000, Loss 5.090627670288086\n",
      "Epoch 4000, Loss 2.9101662635803223\n",
      "Epoch 5000, Loss 1.899439811706543\n",
      "Epoch 6000, Loss 1.3981608152389526\n",
      "Epoch 7000, Loss 0.3679288625717163\n",
      "Epoch 8000, Loss 0.019132934510707855\n",
      "Epoch 9000, Loss 0.00042958560516126454\n",
      "Epoch 10000, Loss 8.079021426965483e-06\n",
      "Epoch 11000, Loss 1.4875739395847631e-07\n",
      "Epoch 12000, Loss 3.900412437474188e-09\n",
      "Epoch 13000, Loss 2.059453052538629e-09\n",
      "Epoch 14000, Loss 1.8732744244687183e-09\n",
      "Epoch 15000, Loss 1.7932415552479597e-09\n",
      "Epoch 16000, Loss 1.7628485338150313e-09\n",
      "Epoch 17000, Loss 1.7396628582133644e-09\n",
      "Epoch 18000, Loss 1.726546239311233e-09\n",
      "Epoch 19000, Loss 1.7109509364843234e-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",
    "    \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",
    "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.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",
    "weights_1_linear, weights_2_linear, hidden_activations_linear, losses_linear = train(model, train_loader, optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAFcCAYAAAAESfN6AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAd+0lEQVR4nO3de3BU9f3/8ddCgFx3DZabkCIuCDGgSHRAUCBABO+tRkWbKjIOtmr51WmkUANaixeQdiqdItJaLwSsQhkVcZQEIkKLcrE/KjFmJEYIlwotsIGGUi6f3x9+d39sE0gOea/L8n0+ZjIru4fX+WySd16cPceszznnBACAoVbxXgAA4OxDuQAAzFEuAABzlAsAwBzlAgAwR7kAAMxRLgAAc5QLAMAc5QIAMHfGlctLL70kn8+nDRs2nHSbL7/8Uj6fTy+99NI3tzBD77//vnw+n3w+n9auXdvg8XHjxik9Pf20st955x099thjLVyhreZ8TfHNCH8twh9JSUnq0qWLxo4dq88///y0MsPfz4sXLz7pNj6fTw8++GCjjy1evFg+n0/vv/9+s9aenJysrVu3Nnh8+PDh6tu3r6e1hy1cuFC//vWvT+vvxspjjz0mn8+nf/zjH/Feymk548qlObp06aK1a9fquuuui/dSWmzSpEmmee+8845+/vOfm2bi7PPiiy9q7dq1Kisr04MPPqi33npLV155pfbt2xfvpTXp8OHDKi4uNs08E8sl0SVkubRr106DBg1Shw4d4r2Uk6qvr29ymzFjxmjNmjVaunTpN7Cib96RI0d09OjReC8Djejbt68GDRqk4cOH65FHHtHkyZO1e/duvfHGG/FeWpPGjBmjhQsXatOmTfFeSkwcOnRIZ8OvfEzIcmnsZbHwIWRFRYXuuOMOBQIBderUSePHj1coFIr6+845zZkzR/3791dKSooyMzNVUFCgL774Imq70tJS3XTTTerWrZuSk5PVs2dP3XfffQ0OU8P7/vjjj1VQUKDMzEwFg8Emn8e4ceN00UUXacqUKTp27FiT27/22mu64oorlJaWpvT0dI0ePVp//etfo/J++9vfSlLUSx9ffvmlbr31VuXk5ETl3XDDDfL5fFq0aFHkvo8//lg+ny+q8DZv3qybbrpJmZmZSk5OVv/+/fXyyy9HZYVfGpk/f75+8pOfqGvXrmrXrp22bNnS6HPZtWuXcnNz1atXr9N+OQZ2LrvsMknSV199FXX/hg0bdOONN6p9+/ZKTk7WpZdeqtdffz0eS4yYNGmSzj33XP30pz9tctvmzPrw4cO1bNkybd26NWpuJOnyyy9v8ApJv3795PP5tH79+sh9S5Yskc/n0yeffBK5b82aNRo5cqQyMjKUmpqqwYMHa9myZVFZ4Zf6li9frvHjx6tDhw5KTU3V4cOHG30+n332mS644AINHDhQu3fvbvqTFUcJWS6ncsstt+jCCy/Un/70J02ePFkLFy7UQw89FLXNfffdpx//+McaNWqU3njjDc2ZM0cVFRUaPHhw1HBVV1friiuu0HPPPafly5dr2rRp+uijj3TllVfqyJEjDfZ98803q2fPnlq0aJHmzp3b5Fpbt26tp556ShUVFQ1+WP+3J598UnfccYcuuugivf7665o/f74OHDigq666Sp9++qkkaerUqSooKJAkrV27NvLRpUsXjRo1Sp9++ql27dolSTp69KhWrVqllJQUlZaWRvZTVlampKQkDR8+XJJUVVWlwYMHq6KiQrNnz9aSJUt00UUXady4cZo5c2aDdU6ZMkXbtm3T3LlztXTpUnXs2LHBNps3b9bAgQPVrl07rV27Vr169Wryc4XYqqmpkSRdeOGFkfvKy8s1ZMgQ7d+/X3PnztWbb76p/v376/bbb4/r+c6MjAwVFxfrvffe08qVK0+5bXNmfc6cORoyZIg6d+4cNTeSNGrUKH3wwQeRef/qq6+0efPmRuemU6dO6tevnyRp1apVGjFihEKhkF544QW9+uqrysjI0A033KDXXnutwTrHjx+vNm3aaP78+Vq8eLHatGnTYJtVq1Zp8ODBuvjii1VeXt7obJ1R3BnmxRdfdJLc+vXrT7pNTU2Nk+RefPHFyH2PPvqok+RmzpwZte3999/vkpOT3fHjx51zzq1du9ZJcr/85S+jtqutrXUpKSlu0qRJje7z+PHj7siRI27r1q1OknvzzTcb7HvatGnNeo7l5eVOklu0aJFzzrkrr7zSdevWzR06dMg559zdd9/t0tLSIttv27bNJSUluR/96EdROQcOHHCdO3d2t912W+S+Bx54wDX2Zd2yZYuT5F555RXnnHNr1qxxktykSZNcjx49Itvl5+e7wYMHR/48duxY165dO7dt27aovGuuucalpqa6/fv3Rz2noUOHNtj3iV/T0tJS5/f7XUFBQeT54psT/lp8+OGH7siRI+7AgQPu3XffdZ07d3ZDhw51R44ciWzbp08fd+mll0bd55xz119/vevSpYs7duyYc67h93NjJLkHHnig0ccWLVrkJLny8vJmrX39+vXu8OHD7oILLnCXXXZZZLaHDRvmcnJyItt7mfXrrrvOde/evcE+y8rKnCT3wQcfOOecKykpcRkZGe7+++93eXl5ke169erl7rzzzsifBw0a5Dp27OgOHDgQue/o0aOub9++rlu3bpE1h5/TXXfd1WDf4Z8re/bscfPnz3dt27Z1EydOjHzez3Rn3ZHLjTfeGPXniy++WP/+978jh5Bvv/22fD6fCgsLdfTo0chH586ddckll0RdsbJ792794Ac/UFZWlpKSktSmTRt1795dklRZWdlg37fccstprXnGjBnavn27nn322UYff++993T06FHdddddUWtOTk7WsGHDmrzKRpKCwaDOP/98lZWVSfr6Jb9+/fqpsLBQNTU1qq6u1uHDh7VmzRqNGjUq8vdWrlypkSNHKisrKypv3Lhxqq+vb3C126k+By+//LKuvfZa3XvvvXr99deVnJzc5LoRG4MGDVKbNm2UkZGhMWPGKDMzU2+++aaSkpIkSVu2bNFnn32m733ve5IU9X137bXXateuXaqqqorb+tu2bavp06drw4YNJ32Zzsusn8yQIUOUnJwcNTfDhw/XmDFj9Je//EX19fWqra3V559/Hpmbf/3rX/roo49UUFAQddVn69at9f3vf1/bt29v8Lk71dw88cQTGjdunJ5++mk9++yzatUqMX5sJ8YqPTj33HOj/tyuXTtJX58kk74+rHXOqVOnTmrTpk3Ux4cffhg5n3L8+HFdffXVWrJkiSZNmqQVK1Zo3bp1+vDDD6PyTtSlS5fTWvPgwYP1ne98R08//XSjV+uED98vv/zyBmt+7bXXmn2p4siRI7VixQpJXx/G5+fnq1+/furUqZPKysr05z//WYcOHYoql3/+85+NPq/zzjsv8viJTvU5+OMf/6iUlBTde++9kde0ER+vvPKK1q9fr5UrV+q+++5TZWWl7rjjjsjj4e+5oqKiBt9z999/vyR5ukS2devWJz2vGL7oo7GXgk5l7NixGjBggB555JFGX6Zu7qyfSnJysoYMGRIplxUrVig/P1/Dhw/XsWPHtHr16sjLY+G52bdvn5xzZnNTUlKirl27auzYsU2u90ySFO8FfNO+9a1vyefzafXq1ZHiOVH4vs2bN2vTpk166aWXdPfdd0ceP9kJakkt+oH51FNPqW/fvnryyScbXbP09f8PED5yOh0jR47UCy+8oHXr1umjjz6KXM45YsQIlZaWauvWrUpPT9egQYMif+fcc8+NnKc50c6dO6PWFnaqz8GCBQs0depUDRs2TMuXL1f//v1P+7mgZbKzsyMn8fPy8nTs2DH9/ve/1+LFi1VQUBD5uk6ZMkU333xzoxm9e/du9v46deqkHTt2NPpY+P5OnTp5eQry+XyaMWOG8vPzNW/evAaPN3fWmzJy5EhNmzZN69at0/bt25Wfn6+MjAxdfvnlKi0t1c6dO3XhhRdGju4zMzPVqlUrs7l59913dfvtt+uqq67SihUrWvQz4Jt01h25NOX666+Xc047duzQZZdd1uAjfEIu/MX+72/A559/Pibr6tOnj8aPH6/f/OY32rZtW9Rjo0ePVlJSkqqrqxtdc/iHxInrbezIauTIkfL5fJo6dapatWqloUOHSvr6X1zl5eUqLS3V0KFDo/4FOXLkSK1cuTIyFGGvvPKKUlNTo4qoKe3bt1dZWZmys7OVl5cXOQpE/M2cOVOZmZmaNm2ajh8/rt69e6tXr17atGnTSb/nMjIymp0f/h7bs2dP1P3OOS1atEjnn3++evbs6Xndo0aNUn5+vh5//HEdPHgw6rHmzrr09dw0NjPhfRw9elRTp05Vt27d1KdPn8j9ZWVlWrlyZdTRflpamgYOHKglS5ZEZR4/flwlJSXq1q1b1IUTTenevXukIK+66qqEubryjD1yWblypb788ssG91977bUtyh0yZIgmTJige+65Rxs2bNDQoUOVlpamXbt2ac2aNerXr59++MMfqk+fPgoGg5o8ebKcc2rfvr2WLl0adYWItccee0wLFixQeXm50tLSIveff/75evzxx/XII4/oiy++iLxG/tVXX2ndunVKS0uL/I+T4YGZMWOGrrnmGrVu3VoXX3yx2rZtq44dO6pv375avny58vLylJqaKunrIdm7d6/27t2rX/3qV1FrevTRR/X2228rLy9P06ZNU/v27bVgwQItW7ZMM2fOVCAQ8PQcMzIy9O677+rmm29Wfn6+3nrrLeXl5bXk0wYDmZmZ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",
      "text/plain": [
       "<Figure size 500x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "net_func_linear = weights_2_linear[150] @ weights_1_linear[150] @ train_inputs\n",
    "net_func_relu = weights_2_relu[150] @ weights_1_relu[150] @ train_inputs\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1,2, figsize=(5, 10))\n",
    "x_tick_labels = ['$\\hat{\\mathbf{y}}_1$', '$\\hat{\\mathbf{y}}_2$', '$\\hat{\\mathbf{y}}_3$', '$\\hat{\\mathbf{y}}_4$', \n",
    "                  '$\\hat{\\mathbf{y}}_5$', '$\\hat{\\mathbf{y}}_6$', '$\\hat{\\mathbf{y}}_7$', '$\\hat{\\mathbf{y}}_8$']\n",
    "plot_data_axis(ax1, net_func_linear *2 , x_tick_labels)\n",
    "# increase the x tick size\n",
    "# ax1.tick_params(axis='x', which='major', labelsize=10)\n",
    "# remove the x ticks\n",
    "ax1.set_xticks([])\n",
    "# increase the width of the grid lines\n",
    "ax1.grid(True, which='minor', linewidth=1)\n",
    "# make title\n",
    "ax1.set_title('Linear Network', fontsize=12)\n",
    "\n",
    "plot_data_axis(ax2, net_func_relu *2 , x_tick_labels)\n",
    "# increase the x tick size\n",
    "# ax2.tick_params(axis='x', which='major', labelsize=10)\n",
    "# remove x ticks\n",
    "ax2.set_xticks([])\n",
    "# increase the width of the grid lines\n",
    "ax2.grid(True, which='minor', linewidth=1)\n",
    "# make title\n",
    "ax2.set_title('ReLU Network', fontsize=12)\n",
    "save_figure('/relu_nets_bias/', 'Early_network_functions', fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "bias_norm_relu = np.linalg.norm(weights_1_relu[:,:,0], axis=1)\n",
    "weight_norm_relu = np.linalg.norm(weights_1_relu[:,:,1:], axis=(1,2))\n",
    "bias_norm_linear = np.linalg.norm(weights_1_linear[:,:,0], axis=1)\n",
    "weight_norm_linear = np.linalg.norm(weights_1_linear[:,:,1:], axis=(1,2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 460x460 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))\n",
    "fig, (ax1) = plt.subplots(1, 1, figsize=(2.3, 2.3), 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=bias_norm_relu, \n",
    "                        y_label=\"Frobenius norm\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=10, \n",
    "                        legend_str=\"ReLU $b$\",\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=11,\n",
    "                        y_label_fontsize=11)\n",
    "# fig, ax = plt.subplots()\n",
    "ax1.plot(np.arange(0,20000, 10), weight_norm_relu, color=color_list[2], label=\"ReLU $W_1$\", linewidth=1.6)\n",
    "ax1.plot(np.arange(0,20000, 10), bias_norm_linear, color='C0', linestyle='dotted', label=\"Linear $b$\", linewidth=1.6)\n",
    "ax1.plot(np.arange(0,20000, 10), weight_norm_linear, color=color_list[2],linestyle='dotted', label=\"Linear $W_1$\", linewidth=1.6)\n",
    "# ax1.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",
    "ax1.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax1.set_xlim([-100, 9100])\n",
    "ax1.set_ylim(-0.05, 4)\n",
    "# set title \n",
    "# ax1.set_title(\"Input bias, same initial weights\", fontsize=8, fontweight=\"bold\")\n",
    "ax1.xaxis.get_offset_text().set_fontsize(10)\n",
    "plt.tight_layout()\n",
    "# save_figure('/relu_nets_bias/', 'Frobenius_norm_ReLU_vs_linear', fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 460x460 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses = np.array(losses_relu)\n",
    "losses_linear = np.array(losses_linear)\n",
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))\n",
    "fig, (ax1) = plt.subplots(1, 1, figsize=(2.3, 2.3), 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_linear, \n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=log_interval, \n",
    "                        legend_str=\"Empirical linear+bias\",\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=11,\n",
    "                        y_label_fontsize=11)\n",
    "# fig, ax = plt.subplots()\n",
    "ax1.plot(losses, color=color_list[2], label=\"Empirical relu+bias\", linewidth=1.6)\n",
    "# ax1.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",
    "ax1.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax1.set_xlim([-100, 10100])\n",
    "# set title \n",
    "ax1.set_title(\"Input bias, same initial weights\", fontsize=8, fontweight=\"bold\")\n",
    "ax1.xaxis.get_offset_text().set_fontsize(10)\n",
    "plt.tight_layout()\n",
    "save_figure('/relu_nets_bias/', 'relu_no_bias_loss_same_weights', 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
}
