{
 "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_no_bias\"\n",
    "folder = \"model_runs_linear\"\n",
    "save_folder = \"linear_nets_no_bias\"\n",
    "bias_input = False\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_control_planet = False\n",
    "batch_size = 8\n",
    "\n",
    "train_inputs, train_labels,_ = load_data(batch_size,\n",
    "                                        include_head_property,\n",
    "                                        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.00000115\n",
    "step_size = 0.001 # should load this from the wandb config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8, 15000)"
      ]
     },
     "execution_count": 9,
     "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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(15000, 14, 8)"
      ]
     },
     "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": [
    {
     "data": {
      "image/png": "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mF2TXuDhSgAAaDyPhtmVK1ea3QvatWunl19+uUn7eemll9S+fXtJUk5OjlasWOG2Go/Hww8/rMGDB0uSKioqdN555+n888/XRx99pMWLF2vOnDm655571L9/f4d+ta+//rrDAxQATxrUwfmQd7+nM7oGAMD3eXRorj/++MOcnjZtmiIiIpq0n4iICE2bNk3/+te/zP2OGjXKLTUej5iYGM2bN0+nnXaa+Szl2bNna/bs2U7bW61W/etf/9LVV1/twSoBRz1bxyo8NEQVVXaH5TuzinWorFJxtjAvVQYAQP08emU2MzPTnO7Zs+dx7avm9llZWce1L3dq3bq1fvvtNz388MNKTnY+6LzFYtFpp52mZcuW6Y477vBwhYCj8NAQ9WvrfIiudXQ1AAD4OI9emQ0NPXq4ysrK49pXze1r7tcXhIeH67HHHtPf//53/fzzz9qxY4cyMzMVFRWldu3aady4cWrVqpW3ywRMAzu01Oo9+bWWr92br7Hdk2pvAACAj/BoCqw5juqaNWuOa19r1651ul9fEhoaqgkTJmjChAneLgWo06AOLZ0uX7WbfrMAAN/m0W4GR26OMgxDn332mcNYs42RnZ2tmTNnmvODBg1yR3lA0Brs5CawMKtF5w1u64VqAABoOI+G2d69e6tTp06yWCwqKCjQ5Zdf3uBHvx5RXl6uyy+/XPn5+ZIOP2ygT58+zVAtEDw6JETq9pO66ez+Rx/cUVltKCLU6sWqAACon8cfmnD//feb48J+//33Gjt2rFauXNmgbZcvX64xY8bo+++/l3T4Rqr777+/2WoFgoXFYtE9p/XUlaM7yVLj6baLt/rOzZUAADjj8TunbrzxRr333ntasWKFLBaLVq1apdGjR2vQoEGaNGmSBg4cqFatWikqKkolJSXKzMzU2rVrNW/ePId+shaLRSNHjtSNN97o6ZcABKzuKTFqHWfTgYIySdKa9HzziXsAAPgij4fZkJAQff311xo3bpw2bdpkPtb2999/r/OmsCNXc4+079u3r77++ms+ZAE3ahkVps5J0WaYTcspUW5xhRJjmjYmNAAAzc3j3QwkKSEhQStWrNB1113nEFIlmY+prfl17PobbrhBy5cvV3y88ycXAWgai8WiYakJ5nxReZWW78zxYkUAANTNK2FWkqKjo/X2229r48aNuuWWW9ShQwczuB7LMAx1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GgAAQMAizLrJNddcI8v/HtKcl5enl156yWXbyspKPf300+b80KFDNWDAgGavEQAAINAQZt1k4MCBuuiii8z5Rx99VN9//32tdtXV1brlllu0bt06c9mTTz7pkRoBAAACDePMutHzzz+vn3/+WXv37lVZWZnOPPNMXXHFFTrnnHPUsmVLbdu2TW+99ZZWrVplbnPttdfqtNNO82LVAAAA/osw60Zt27bV3LlzdcYZZygjI0NVVVWaMWOGZsyY4bT9ueeeqzfeeMPDVQIAAAQOuhm42cCBA7VhwwZdffXViox0/ti91NRUvfHGG/riiy8UFhbm4QoBAAACB1dmm0FiYqJmzJihl156SQsXLlR6eroKCwuVkpKiXr16adSoUebNYgAAAGg6wmwzio2N1eTJk71dBgAAQMCimwEAAAD8FmEWAAAAfoswCwAAAL9FmAUAAIDfIswCAADAbxFmAQAA4LcYmsvPGIbhMF9aWipJKisrc5hHcOC8ByfOe3DivAenQD3vx76eY/NNYxBm/cyR/9RHJCYmeqkSAAAA9ygrK1NUVFSTtqWbAQAAAPwWYRYAAAB+y2IcTycFeJzdbld+fr45b7PZZLFYvFcQAABAIxmG4dB1smXLlgoJado1VsIsAAAA/BbdDAAAAOC3CLMAAADwW4RZAAAA+C3CLAAAAPwWYRYAAAB+izALAAAAv0WYBQAAgN8izLrR9u3b9fDDD2vYsGFKSUmRzWZT586dNWnSJL377rsqKSlp9hp+/vln3XTTTerbt69atmyp2NhY9erVS5dffrnmz5+vpg4rnJeXp1dffVUTJ05Uhw4dZLPZ1LZtW51wwgl65plndODAATe/Ev/hrfOelZWlTz75RLfeeqvGjh2rlJQURUREKCYmRh07dtRZZ52l5557TllZWY3ar8ViafTXGWec0Syv0Zd547w/+uijTTo/y5cvb9RxeL+75unz/u677zbpnNf8WrRokcv9836vW1ZWlubPn6/HH39ckydPVps2bRy+F48++qjHauHzvQ4Gjlt1dbXx9NNPG+Hh4YYkl1/du3c3li9f3iw15OfnG5dddlmdx5dknH766cb+/fsbte+5c+caKSkpde43NjbWmDFjRrO8Nl/lrfO+dOlS46STTjKsVmu951uSERERYTz22GNGZWVlg/bfkH06+38VLLz5fn/kkUeadH6W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AH6LMAsAAAC/RZgFAACA3yLMAgAAwG8RZgEAAOC3Qr1dAAD4ooKCAq1atUo7duxQfn6+ysvLFR0drcTERKWmpqpXr15KSUnxdpkAEPQIswBQw5dffqlXXnlFP/74o+p72nf79u01duxYnXHGGbrgggsUHR1dq82iRYu0aNEiSVLLli111113NUPVcKf8/Hy98MIL5vxVV12lzp07e68gAHWyGPX9tAaAIJCfn68rrrhCc+fObdL2y5Yt06hRo2otf/TRR/XYY49JklJTU5WWlnY8ZcID5s+frzPPPNOc37t3r9q1a+fFigDUhSuzAIJecXGxTjvtNP36668Oy0eMGKETTzxRXbp0UVRUlAoLC5WRkaHVq1drxYoVysvL81LFaE41/x+0bt2aIAuflJ+fr1WrVunXX3/Vb7/9pt9++027d++W5Bu/OBcWFqpv375KT09v9poIswCC3qOPPuoQYPr37693331XQ4YMcblNVVWVFi1apP/+97/66KOPPFEmPKTm/4Xhw4d7sRLAtcGDB3s9sNblwQcfNINsc2M0AwBBrbi4WK+88oo5365dO/300091BllJCg0N1SmnnKJ///vf2rt3r3r16tXcpcJDaobZYcOGebESwLWavUQTExN12mmnKSYmxosVHfXLL7/otddek81mU2xsbLMfjyuzAILajz/+qLKyMnP+9ttvV3x8fKP2kZiY6O6y6rRlyxatXr1amZmZKi0tVatWrdS7d2+NHDlSISHuuUZRUlKiRYsWKT09XXl5eWrdurUGDRqkQYMGNWl/hYWFWrVqlf744w8VFBSoqqpKUVFRat26tTp37qyBAwcqMjLSLbUfj/T0dB08eNCcJ8zCV912221KTU3VsGHDzBsUO3XqpKKiIq/WVV5eruuvv16GYejhhx/Wm2++qcLCwuY9qAEAQeyFF14wJJlf8+fPd8t+a+6zIV+pqal17q+iosJ48cUXjc6dO7vcR3JysvHkk08aZWVlDarxqquuMrcdP368YRiGUVxcbNx+++1GbGys02P07t27Ud+jtLQ049JLLzVsNludrz8sLMw48cQTjdmzZzd43+6ybds2t58vwBtSU1O9/v/zb3/7myHJ6Nevn1FRUeGRmuhmACColZSUOMzXvErrK3bs2KEBAwbozjvv1K5du1y2y8rK0l//+lcNHz5cGRkZjT5ORkaGRo4cqZdfftnllZTNmzdr0qRJ+vvf/17v/hYtWqR+/frpo48+qvf7WllZqSVLlmjWrFmNrvt4rVmzptHbDBgwwP2FAF6ybt063XrrrerTp49atGihyMhIde7cWVdccYV++eWXRu3n2WefVUhIiN5++22FhYU1Y9VH0c0AQFBLTk52mP/mm280ZcqU495v165dJUm5ubnmqAehoaFKTU112r59+/ZOl2/evFkTJkxQZmamuaxNmzaaPHmy+vbtq+joaO3Zs0dffvmlGcrWr1+vCRMm6LfffmtwHzq73a7LLrtMGzZskCSNGTNGZ555plJSUpSVlaVvv/3WHC9Xkp544gnFx8fr7rvvdrq/zMxMnXfeeQ5/8hw1apQmTpyo1NRU2Ww2FRYWau/evVq7dq1++uknlZaWNqhWd9u/f795vg4cOGD+ghMdHa3WrVs73WbcuHEeqw9oLna7Xffdd59eeOEF2e12h3VpaWlKS0vTBx98oNtuu00vvPCCrFary31VV1fruuuuU2VlpW655RanQxU2m2a75gsAfmDDhg0Ofz62Wq3GjBkz3Lb/Rx55pMl/mi4tLTX69etnbm+xWIy///3vRmlpqdP2r7/+umG1Ws32N9xwQ537r9nNICQkxJBk2Gw2Y+bMmU7bf/XVV0Z0dLS5TUREhLF582anbR999FGHdl9//XWdtZSUlBgffvih8eyzz9bZrrn17dvXrPvOO+/0ai1AYzX2T/rXX3+9+f998ODBxuuvv2788MMPxm+//WZ88sknxqmnnmquf+CBB+rc13PPPWdIMtq2bWsUFBQ0uaamIMwCCHqjR4+u1Sdy4MCBxrPPPmusWrXKqKysbPK+jyfMPv744w41TZ8+vd5tavYBtlgsxvbt2122rRlmj3x9/PHHde7/888/d2g/depUp+3GjRvnd6GwpKTE4ZeB9957z9slAY3SmOBY87389NNPu2x3//33m7/ou/p5sn37diMyMtKQZHz22WdNrqmp6DMLIOi98cYbtf4cv3btWt1///0aOnSoYmNjNWrUKN12223673//q3379jV7TeXl5Xr11VfN+bFjxzboUbh33HGHevfuLenw0D1vvPFGg4950kkn6aKLLqqzzZQpU3TWWWeZ81999ZXD3f9H1Oyz27NnzwbX4E1r165VdXW1OV/f8GyAP3vyySclSRMnTtRf/vIX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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
}
