{
 "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_shallow, 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 = \"shallow_net\"\n",
    "folder = \"model_runs_linear\"\n",
    "save_folder = \"shallow_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_bias_input = 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",
    "                                        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, vt_input_cov =  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"
   ]
  },
  {
   "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_shallow(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": [
    "# 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": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArMAAAKZCAYAAACr0KNLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAABolAAAaJQGH6LfgAAB9sklEQVR4nO3dd3xUVf7/8ffMpDcIafRQJUBo0kEQbIAFARXsuva171rXtf/sfl17d9Vdy6qIXVFRUFSq9N4DoYRU0vvc3x+BS4ZM+pRM5vV8PPLILefe+RAO+uZy7jkWwzAMAQAAAD7I6u0CAAAAgKYizAIAAMBnEWYBAADgswizAAAA8FmEWQAAAPgswiwAAAB8FmEWAAAAPoswCwAAAJ9FmAUAAIDPIswCAADAZxFmAQAA4LMIswAAAPBZhFkAAAD4rABvF4DGsdvtOnTokLkfEhIii8XivYIAAAAayTAMlZSUmPtt27aV1dq0Z6yEWR9z6NAhxcTEeLsMAAAAl8nKylK7du2adC3DDAAAAOCzCLMAAADwWQwz8DEhISEO+1lZWQoNDW3w9evXr5ckJScnu7Qu4Aj6GNyJ/gV3o495RnFxscOwyWPzTWMQZn3MsS97hYaGNirMHuksjbkGaAz6GNyJ/gV3o495R3NeZmeYAQAAAHwWYRYAAAA+izALAAAAn0WYBQAAgM8izAIAAMBnEWYBAADgswizAAAA8FmEWQAAAPgsvw2zGRkZmjt3rh5++GFNnTpVHTp0kMViMb8efPDBRt9z+/btev3113XppZdqyJAhateunQIDA9W2bVsdd9xxuuCCC/Tf//5XJSUlrv8FAQAA+CG/WwEsLS1No0aN0u7du112z3feeUf/+te/zCXwjpWbm6vc3Fxt27ZNH330ke688069/PLLOuecc1xWAwAAgD/yuyezJSUlLg2ykjRnzpwaQTYsLEwDBgzQxIkTNWLECIWFhZnnDh48qHPPPVdPPfWUS+sAAADwN373ZLa6uLg4DR06VMOGDdOwYcM0bdq0Zt0vJiZGF110kWbNmqXhw4crMDDQPFdaWqp3331Xd9xxh/Lz8yVJd911lwYPHqzTTjutWZ8LAADgr/wuzLZr106zZ8/W8OHDlZiY6JJ7durUSc8//7yuueYahYSEOG0THBysa6+9VkOHDtX48eNVXFwsqSrQEmYBAACaxu+GGURFRencc891WZCVpNdff10333xzrUG2umHDhunmm28291evXq2dO3e6rBYAAAB/4ndhtiWYOnWqw/7mzZu9VAkAAIBvI8x6QUxMjMN+Xl6elyoBAADwbYRZL0hJSXHYj4+P904hAAAAPo4w6wWffvqpuR0YGKihQ4d6sRoAAADfRZj1sN27d+uDDz4w908//XS1adPGixUBAAD4Lr+bmsub7Ha7/vKXv5jTclmtVj3yyCPNuuf69esbNIuCJC1JLdKWA7naX1CpiamFig0PVK92Qc36fOBYmZmZkqR169Z5uRK0RvQvuBt9zDNKSkpcdi/CrAfdfffdWrBggbl/7733Kjk52e2faxiG5mzM10frclVaaUiSFh3IUkSQVR+e20kWi8XtNQAAALgDYdZDXnvtNT399NPm/oknnqj777+/2fdNTk5WaGhove2u+eZnM8geUVBmV8cefRQbEdzsOoAjjjzNGDBggJcrQWtE/4K70cc848i/UrsCY2Y94KOPPtINN9xg7g8aNEiff/65bDabx2roGR/u9PiO9AKP1QAAAOBqhFk3+/LLL3XJJZfIbrdLkpKSkvTjjz8qOjrao3X0jItwenx7BmEWAAD4LsKsG82dO1czZ85URUWFJKlnz576+eefvTKvbK9452F2R3qhhysBAABwHcKsm8ybN08zZsxQWVmZJCkxMVHz589Xx44dvVJPbU9md/BkFgAA+DDCrBssWLBAZ599tjntROfOnTV//nx17drVazURZgEAQGtEmHWxhQsX6swzzzTf0uvYsaPmz5+vHj16eLWuhKhgRQTXnLxi36FiFZdVeqEiAACA5iPMutDixYt1xhlnqKioSJKUkJCg+fPnq3fv3l6uTLJYLOoZV3NGA8OQdmbydBYAAPgmwqyLLF++XJMnT1ZBQVUwjIuL0/z589WnTx8vV3ZU7UMNeAkMAAD4JsKsC6xevVqTJk1SXl6eJCk2NlY///yz+vXr5+XKHPWsdUYDnswCAADf5JcrgF199dV677336mzzyCOP6Iknnqhx/Mcff9T48eMdjl144YXKyckx99u1a6c77rijwfVcfPHFuvjiixvcvqmYaxYAALQ2fhlmy8vLVVpaWmebyspKVVbWfDHqyOIH1R0ZI3vE1q1btXXr1gbXM2rUqAa3bY5erAIGAABaGYYZ+JGu7cJltdQ8viuz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HmaHDRvmxUoANARhFoBf+/nnn1VSUmLu33TTTfUG2WPFxMS4uqw6bdmyRStXrlR6erqKi4sVHx+vvn37auTIkbJaXTPjYlFRkX755RelpqYqJydH7du31+DBgzV48OAm3S8/P18rVqzQ5s2blZubq4qKCoWFhal9+/bq3r27Bg0apNDQUJfU3hypqak6ePCguU+YBXyAAQB+7LnnnjMkmV9z5851yX2r37MhX4mJiXXer6yszHj++eeN7t2713qPuLg447HHHjNKSkoaVONll11mXnviiScahmEYhYWFxk033WRERkY6/Yy+ffs26meUkpJiXHjhhUZISEidv/7AwEBj3Lhxxmeffdbge7vKtm3bXP77BcBzWDQBgF8rKipy2K/+lLal2LFjhwYOHKhbbrlFu3btqrVdRkaG7rnnHg0fPlxpaWmN/py0tDSNHDlSL774ovLz85222bRpk6ZMmaL77ruv3vv98ssvSk5O1ocffljvz7W8vFy//fab5syZ0+i6m2v16tWNvmbgwIGuLwRAkzDMAIBfi4uLc9j//vvvNW3atGbft2fPnpKk7Oxsc9aDgIAAJSYmOm3fuXNnp8c3bdqkCRMmKD093TzWoUMHTZ06Vf3791d4eLj27NmjL7/80gxl69at04QJE/Tnn38qIiKiQfXa7XZddNFFWr9+vSRp7NixOv3005WQkKCMjAz98MMP5ny5kvTII48oOjpaf//7353eLz09XdOnT1dBQYF5bNSoUZo4caISExMVEhKi/Px87d27V2vWrNGvv/6q4uLiBtXqavv37zd/vw4cOGD+BSc8PFzt27d3es348eM9Vh+Aenj70TAAeNP69esd/vnYZrMZ77zzjsvu/8ADDzT5n6aLi4uN5ORk83qLxWLcd999RnFxsdP2r776qmGz2cz2V199dZ33rz7MwGq1GpKMkJAQY/bs2U7bf/XVV0Z4eLh5TXBwsLFp0yanbR988EGHdt9++22dtRQVFRkffPCB8dRTT9XZzt369+9v1n3LLbd4tRYADcMwAwB+rX///ho9erS5X1lZqb/85S8aPHiwnn76aa1cuVIVFRVeqe3pp582n5RK0r/+9S89/PDDCgkJcdr+uuuu0zPPPGPuv/XWW9qxY0eDPstut0uS3n33XZ177rlO25x11ll6//33zf3S0lL985//dNp2/vz5DnVVX4TAmdDQUF144YW64447GlSvOxQXF2vz5s3mfl1TswFoOQizAPzea6+9VuOf49esWaM777xTQ4cOVWRkpEaNGqUbb7xR//vf/7Rv3z6311RaWqqXX37Z3D/hhBMatBTuzTffrL59+0qSDMPQa6+91uDPPOmkkzRr1qw620ybNk1nnHGGuf/VV185vP1/RPUxu3369GlwDd60Zs0aVVZWmvuEWcA3EGYB+L2BAwdq/vz56t69u9PzJSUlWrp0qV5++WVdeOGF6ty5s8aOHav33nvPfKLpaj/99JNDSKxtbOqxLBaLLrvsMnN/3rx5Df7Ma6+9ttHtKioq9N1339VoU32arUWLFjW4Bm9auXKluR0SEqKkpCQvVgOgoQizAKCqlZ42bdqkF154Qf369au3/aJFi3TppZfq+OOP15YtW1xez2+//WZuBwQEaNKkSQ2+duTIkeb2+vXrVVhY2KDrTjvttAa1O/XUUx0WiVi2bFmNNkOHDjW333//fT344IO1zpDQUlQPswMHDlRAAO9IA76AMAsAhwUHB+umm27Shg0btH79er344os6//zz1adPn1oXI1izZo1GjhypDRs2uLSW6tNFdevWTWFhYQ2+NiEhwdyurKzUgQMH6r2mS5cuatu2bYPuHxISot69e5v7zsL8dddd5/Aze+ihh9ShQwedc845euWVV7Ru3Tq3PdVuquphdsiQIV6sBEBjEGYBwIn+/fubY2Q3b96svLw8/fTTT7r11lsVGxvr0DY3N1fnnXeew3jL5srKyjK3t2/fLovF0uCvY58sH5karC7x8fGNqq/6lGbO7j98+HA988wzslgs5rHCwkJ99tlnuuGGGzRw4EDFxcXpnHPO0UcffeT1+X3Lysoc/kLCeFnAdxBmAaABwsPDdfLJJ+vZZ5/Vrl27dN111zmc37Rpkz799FOXfV5ubq7L7nXswhDONHYp2fDwcHO7+lyy1d1666365ZdfNG7cOKfns7Oz9dlnn+mCCy5Qz549HWZK8LT169errKzM3OfJLOA7GBAEAI0UERGhV199VVlZWZo9e7Z5/Jtvvql3NoCGqj6soK7J+xuitqm8qmvsggXVx+HWtTDD+PHjtXDhQm3btk1z587Vr7/+qkWLFtVYoWz//v265JJLtGvXrgatLuZq1YcYBAQEaMCAAR6vAUDTEGYBoInuvPNOhzBb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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",
    "ax.set_xlim([-100, 3600])\n",
    "ax.plot(ana_loss, color='C0', linestyle=\"--\", label=\"Analytical\", linewidth=2.5)\n",
    "ax.get_legend().remove()\n",
    "fig_folder = f\"/{save_folder}/shallow_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
}
