{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from src.neural_nets.retrieve_logged_data.load_network_metrics import load_metrics\n",
    "from src.plotting.network_plotting_functions import plot_single_metric, plot_several_metrics\n",
    "from src.plotting.human_plotting_functions import _save_figure\n",
    "from src.neural_nets.linear_nets.training_modules import load_data\n",
    "from src.analytical_solutions.analytical_solutions import analytical_svs, ana_weights, ana_outputs, ana_loss\n",
    "from src.compute_network_stats import compute_summary_stats"
   ]
  },
  {
   "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\n",
    "model_name = \"linear_net_bias\"\n",
    "folder = \"model_runs_linear\"\n",
    "save_folder = \"linear_net_bias\"\n",
    "bias_input = True\n",
    "metrics = [\"loss\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded loss from /loss.npy\n"
     ]
    }
   ],
   "source": [
    "metric_dict = load_metrics(model_name, choice_temp, scale, metrics, bias_input, folder)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_loss, se_loss = compute_summary_stats(metric_dict, \"loss\", bucket_size=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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",
    "train_inputs, train_labels,_ = load_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": [
    {
     "data": {
      "text/plain": [
       "array([[8., 1., 1., 1., 1., 1., 1., 1., 1.],\n",
       "       [1., 1., 0., 0., 0., 0., 0., 0., 0.],\n",
       "       [1., 0., 1., 0., 0., 0., 0., 0., 0.],\n",
       "       [1., 0., 0., 1., 0., 0., 0., 0., 0.],\n",
       "       [1., 0., 0., 0., 1., 0., 0., 0., 0.],\n",
       "       [1., 0., 0., 0., 0., 1., 0., 0., 0.],\n",
       "       [1., 0., 0., 0., 0., 0., 1., 0., 0.],\n",
       "       [1., 0., 0., 0., 0., 0., 0., 1., 0.],\n",
       "       [1., 0., 0., 0., 0., 0., 0., 0., 1.]])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_inputs @ train_inputs.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.   , 0.125, 0.125, 0.125, 0.125, 0.125, 0.125, 0.125, 0.125],\n",
       "       [0.125, 0.125, 0.   , 0.   , 0.   , 0.   , 0.   , 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.125, 0.   , 0.   , 0.   , 0.   , 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.125, 0.   , 0.   , 0.   , 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.   , 0.125, 0.   , 0.   , 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.   , 0.   , 0.125, 0.   , 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.   , 0.   , 0.   , 0.125, 0.   , 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.   , 0.   , 0.   , 0.   , 0.125, 0.   ],\n",
       "       [0.125, 0.   , 0.   , 0.   , 0.   , 0.   , 0.   , 0.   , 0.125]])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "input_covar"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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, vt_input_cov =  np.linalg.svd(input_covar, full_matrices=False)\n",
    "delta = delta[:,np.newaxis]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# hyperparameters\n",
    "t= np.arange(0, 15000, 1)[np.newaxis]\n",
    "a_0 = 0.00000115\n",
    "step_size = 0.001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 15000)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# get solutions\n",
    "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": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(15000, 14, 9)"
      ]
     },
     "execution_count": 12,
     "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": 13,
   "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": 14,
   "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": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArMAAAKZCAYAAACr0KNLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAABolAAAaJQGH6LfgAACKJElEQVR4nO3dd3gU5doG8Hu2JJveE0hCEkoIJfQWCFWRpiJFwYIFxYYI9qMej2JvnwdQFJCjYEFFigpIEem991BCSYWQ3rMpu/P9gQxZsptskt2d3ez9u65cTHln5lkmm70zeecdQRRFEUREREREDkghdwFERERERA3FMEtEREREDothloiIiIgcFsMsERERETkshlkiIiIiclgMs0RERETksBhmiYiIiMhhMcwSERERkcNimCUiIiIih8UwS0REREQOi2GWiIiIiBwWwywREREROSyGWSIiIiJyWCq5C6D60ev1yM/Pl+Y1Gg0EQZCvICIiIqJ6EkURWq1Wmvf19YVC0bBrrAyzDiY/Px8BAQFyl0FERERkMTk5OfD392/QtuxmQEREREQOi2GWiIiIiBwWuxk4GI1GYzCfk5MDNzc3nDx5EgAQGxsrR1kkE55358Tz7px43p1TUz3vZWVlBt0mb8439cEw62BuvtnLzc0Nbm5u0jeBm5ubHGWRTHjenRPPu3PieXdOznLeG3MzO7sZEBEREZHDYpglIiIiIofFMEtEREREDothloiIiIgcFsMsERERETkshlkiIiIiclgMs0RERETksBhmiYiIiMhhMcwSERERkcNy2jCblZWFdevW4Z133sHo0aPRvHlzCIIgfc2cObPe+zx//jwWLFiAhx56CN26dYO/vz/UajV8fX3Rtm1b3Hffffj++++h1Wot/4KIiIiInJDTPc42IyMDcXFxSE5Ottg+Fy1ahP/+97/S85NvVlBQgIKCAiQmJuKXX37BK6+8gi+//BLjx4+3WA1EREREzsjprsxqtVqLBlkAWLFiRY0g6+7ujk6dOmHIkCHo3bs33N3dpXVXr17F3XffjU8++cSidRARERE5G6e7MltdUFAQevTogZ49e6Jnz54YM2ZMo/YXEBCABx54ABMnTkSvXr2gVquldeXl5Vi8eDFefvllFBUVAQD+9a9/oWvXrhg2bFijjktERETkrJwuzPr7+2PZsmXo1asXIiMjLbLP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iWoVGBgoTRcXF5vd9/XKlSsG8wEBARati4iIiKipY5i1gHbtDC/TJycnm7VdSkqKNB0SEgI/Pz+L1kVERETU1DHMWkDHjh0N5o8cOWLWdocPH5am27dvb9GaiIiIiJwBw6wFREZGIjIyUprfvr3uQZrLy8uxb98+aX7w4MHWKI2IiIioSWOYtZAxY8ZI08uXL6/zRrCVK1ca3AA2duxYa5VGRERE1GQxzFrI5MmTIfzz4Oe8vDx8/vnnJttWVlbio48+kuZ79OiBzp07W71GIiIioqaGYdZCunTpgokTJ0rzM2fOxMaNG2u00+l0mDp1Ko4fPy4t++CDD2xSIxEREVFTw3FmLeizzz7Dzp07kZaWBq1Wi1GjRuHBBx/EnXfeCV9fXyQmJuLrr7/GoUOHpG0effRRDBs2TMaqiYiIiBwXw6wFhYaGYs2aNRgxYgQyMjJQVVWFRYsWYdGiRUbb33XXXZg/f76NqyQiIiJqOtjNwMK6dOmCkydP4pFHHoGbm5vRNpGRkZg/fz5+//13qNW1P+qOiIiIiEzjlVkrCAgIwKJFi/D5559jy5YtSE1NRVFREUJCQtCuXTvExcVJN4sRERERUcMxzFqRl5cXRo8eLXcZRERERE0WuxkQERERkcNimCUiIiIih8UwS0REREQOi2GWiIiIiBwWwywREREROSyGWSIiIiJyWByay8GIomgwX1ZWBgDQarUG8+QceN6dE8+7c+J5d05N9bzf/Hpuzjf1wTDrYK5/U18XEBAgUyVERERElqHVauHu7t6gbdnNgIiIiIgcFsMsERERETksQWxMJwWyOb1ej/z8fGleo9FAEAT5CiIiIiKqJ1EUDbpO+vr6QqFo2DVWhlkiIiIicljsZkBEREREDothloiIiIgcFsMsERERETkshlkiIiIiclgMs0RERETksBhmiYiIiMhhMcwSERERkcNimLWg8+fP480330TPnj0REhICjUaDli1bYuTIkVi8eDFKS0utXsPOnTvx5JNPomPHjvD19YWXlxfatWuHSZMmYd26dWjosMJ5eXn48ssvMWTIELRo0QIajQahoaHo168fPv74Y1y5csXCr8RxyHXes7KysHTpUjzzzDPo378/QkJC4OrqCk9PT0REROD222/Hp59+iqysrHrtVxCEen+NGDHCKq/Rnslx3mfOnNmg87N37956HYfv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",
      "text/plain": [
       "<Figure size 714x680 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plot_single_metric(metric_array=mean_loss, \n",
    "                            se_array=se_loss,\n",
    "                            y_label=\"Loss\",\n",
    "                            chance_level=None,\n",
    "                            log_interval=log_interval, \n",
    "                            legend_str=\"Empirical\",\n",
    "                            line_width=1.4)\n",
    "\n",
    "ax.set_xlim([-100, 11100])\n",
    "ax.plot(ana_loss, color='C0', linestyle=\"--\", label=\"Analytical\", linewidth=2.5)\n",
    "# ax.legend()\n",
    "ax.get_legend().remove()\n",
    "fig_folder = f\"/{save_folder}/linear_net_scale{scale}_choice_temp{choice_temp}/\"\n",
    "fig_name = \"loss_analytical\"\n",
    "# _save_figure(fig_folder, fig_name, 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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
