{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7880881b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import pandas as pd\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "46a17f55",
   "metadata": {},
   "outputs": [],
   "source": [
    "fitting_data = pd.read_csv('get_fitting_data_chinchilla.csv')\n",
    "m = fitting_data['d_model'].values\n",
    "ell = fitting_data['n_layers'].values\n",
    "D = fitting_data['num_tokens'].values\n",
    "losses = fitting_data['loss'].values\n",
    "\n",
    "nr_of_models_excluded = 40 # 40 is good\n",
    "\n",
    "sorted_losses = sorted(losses)\n",
    "if nr_of_models_excluded == 0:\n",
    "    indices = list(range(len(m)))\n",
    "else:\n",
    "    sorted_losses = sorted(losses)\n",
    "    indices = [i for i in range(len(m)) if losses[i] < sorted_losses[-nr_of_models_excluded]]\n",
    "\n",
    "m = torch.tensor(m[indices])\n",
    "ell = (torch.tensor(ell[indices])) * 100\n",
    "D = torch.tensor(D[indices]) / 1e+6\n",
    "losses = torch.tensor(losses[indices])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6bd156b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "slope: 0.6046665568815158, intercept: 3.270733122141155\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "slope, intercept = np.polyfit(torch.log(m).numpy(), torch.log(ell).numpy(), 1)\n",
    "print(f'slope: {slope}, intercept: {intercept}')\n",
    "plt.plot(m, ell, 'o', alpha=0.2, color='black')\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1d38bd36",
   "metadata": {},
   "outputs": [],
   "source": [
    "# lnc_m, lnc_ell, lnc_D, a_m, a_ell, a_D, lnE\n",
    "#params = nn.Parameter(torch.tensor([4.0, 4.0, 4.0, 1.0, 1.0, 0.33, np.log(1.69)]))\n",
    "coeffs = nn.Parameter(torch.tensor([np.log(200), np.log(200), np.log(10)]))\n",
    "exponents = nn.Parameter(torch.tensor([1.0, 1.0, 0.33]))\n",
    "E = nn.Parameter(torch.tensor(1.69))\n",
    "num_epochs = 50000\n",
    "risks = []\n",
    "optimizer = torch.optim.Adam([{'params': coeffs, 'lr': 0.005}, \n",
    "                              {'params': exponents, 'lr': 0.0005}, \n",
    "                              {'params': E, 'lr': 0.005}])\n",
    "\n",
    "for epoch in range(num_epochs):\n",
    "    optimizer.zero_grad()\n",
    "    \n",
    "    # Extract parameters\n",
    "    lnc_m, lnc_ell, lnc_D = coeffs\n",
    "    a_m, a_ell, a_D = exponents\n",
    "    \n",
    "    # Calculate the model output\n",
    "\n",
    "    expected_log_loss = ((lnc_D - a_D * D.log()).exp() + (lnc_m - a_m * m.log()).exp() + (lnc_ell - a_ell * ell.log()).exp() + E).log()\n",
    "\n",
    "    risk = (losses.log() - expected_log_loss).pow(2).mean() * 100\n",
    "    risks.append(risk.item())\n",
    "    \n",
    "    # Backpropagation\n",
    "    risk.backward()\n",
    "    \n",
    "    # Update parameters\n",
    "    optimizer.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b2759513",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(risks)\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0be7db33",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0030680681655081803"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "risks[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9d9ecdfb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitted parameters:\n",
      "c_m: 333.3808501910344, a_m: 0.9769136309623718\n",
      "c_ell: 1284.3676595484178, a_ell: 1.201390266418457\n",
      "c_D: 8.48674282280199, a_D: 0.29909613728523254\n",
      "E: 1.7503269910812378\n"
     ]
    }
   ],
   "source": [
    "print(\"Fitted parameters:\")\n",
    "print(f\"c_m: {coeffs[0].exp().item()}, a_m: {exponents[0].item()}\")\n",
    "print(f\"c_ell: {coeffs[1].exp().item()}, a_ell: {exponents[1].item()}\")\n",
    "print(f\"c_D: {coeffs[2].exp().item()}, a_D: {exponents[2].item()}\")\n",
    "print(f\"E: {E.item()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cc23bc4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Residual variance: 0.0002014224949138708\n",
      "Standard errors of the estimates:\n",
      "c_D: 0.08904847001356753\n",
      "c_m: 0.5126208485738366\n",
      "c_ell: 1.8237893515285493\n",
      "a_D: 0.013913373827828632\n",
      "a_m: 0.08327255081534041\n",
      "a_ell: 0.2685404712170156\n",
      "E: 0.025556400259412002\n"
     ]
    }
   ],
   "source": [
    "# Calculate standard errors using the Jacobian\n",
    "# Enable gradient computation for all parameters\n",
    "coeffs.requires_grad = True\n",
    "exponents.requires_grad = True\n",
    "E.requires_grad = True\n",
    "\n",
    "# Calculate residuals\n",
    "lnc_m, lnc_ell, lnc_D = coeffs\n",
    "a_m, a_ell, a_D = exponents\n",
    "expected_log_loss = ((lnc_D - a_D * D.log()).exp() + (lnc_m - a_m * m.log()).exp() + (lnc_ell - a_ell * ell.log()).exp() + E).log()\n",
    "residuals = losses - expected_log_loss.exp()\n",
    "relative_residuals = residuals / losses\n",
    "\n",
    "# Number of observations and parameters\n",
    "n = len(losses)\n",
    "p = 7  # total number of parameters (3 coeffs + 3 exponents + 1 E)\n",
    "\n",
    "# Calculate Jacobian matrix using autograd\n",
    "jacobian = []\n",
    "for i in range(n):\n",
    "    grads = torch.autograd.grad(residuals[i], [coeffs, exponents, E], \n",
    "                                 retain_graph=True, create_graph=False)\n",
    "    # Flatten all gradients into a single vector\n",
    "    grad_vec = torch.cat([grads[0], grads[1], grads[2].unsqueeze(0)])\n",
    "    jacobian.append(grad_vec.detach())\n",
    "\n",
    "J = torch.stack(jacobian)  # Shape: (n, p)\n",
    "\n",
    "# Calculate residual variance (Mean Squared Error)\n",
    "residual_variance = (residuals.detach() ** 2).sum() / (n - p)\n",
    "print(f\"Residual variance: {residual_variance.item()}\")\n",
    "\n",
    "# Calculate covariance matrix: Cov = residual_variance * (J^T J)^(-1)\n",
    "JTJ = J.T @ J\n",
    "try:\n",
    "    covariance_matrix = residual_variance * torch.linalg.inv(JTJ)\n",
    "    \n",
    "    # Standard errors are the square root of the diagonal elements\n",
    "    standard_errors = torch.sqrt(torch.diag(covariance_matrix))\n",
    "    \n",
    "    print(\"Standard errors of the estimates:\")\n",
    "    print(f\"c_D: {standard_errors[2].item()}\")\n",
    "    print(f\"c_m: {standard_errors[0].item()}\")\n",
    "    print(f\"c_ell: {standard_errors[1].item()}\")\n",
    "    print(f\"a_D: {standard_errors[5].item()}\")\n",
    "    print(f\"a_m: {standard_errors[3].item()}\")\n",
    "    print(f\"a_ell: {standard_errors[4].item()}\")\n",
    "    print(f\"E: {standard_errors[6].item()}\")\n",
    "    \n",
    "except RuntimeError as e:\n",
    "    print(f\"Could not invert matrix: {e}\")\n",
    "    print(\"Using pseudo-inverse instead...\")\n",
    "    covariance_matrix = residual_variance * torch.linalg.pinv(JTJ)\n",
    "    standard_errors = torch.sqrt(torch.diag(covariance_matrix))\n",
    "    \n",
    "    print(\"Standard errors of the estimates (using pseudo-inverse):\")\n",
    "    print(f\"c_D: {standard_errors[2].item()}\")\n",
    "    print(f\"c_m: {standard_errors[0].item()}\")\n",
    "    print(f\"c_ell: {standard_errors[1].item()}\")\n",
    "    print(f\"a_D: {standard_errors[5].item()}\")\n",
    "    print(f\"a_m: {standard_errors[3].item()}\")\n",
    "    print(f\"a_ell: {standard_errors[4].item()}\")\n",
    "    print(f\"E: {standard_errors[6].item()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "68a24007",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0101, dtype=torch.float64)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "residuals.detach().abs().mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "eca01b3e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0040, dtype=torch.float64)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "relative_residuals.detach().abs().mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "24fc6611",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min loss at index: 202, loss value: 2.0773942450664395\n",
      "min loss contributions - m: 0.11236475266608222, ell: 0.06042401073346225, D: 0.19190516726774523\n"
     ]
    }
   ],
   "source": [
    "min_loss_idx = torch.argmin(losses)\n",
    "print(f\"min loss at index: {min_loss_idx}, loss value: {losses[min_loss_idx].item()}\")\n",
    "min_loss_m = coeffs[0].exp().item() / m[min_loss_idx].item() ** exponents[0].item()\n",
    "min_loss_ell = coeffs[1].exp().item() / ((ell[min_loss_idx].item()) ** exponents[1].item())\n",
    "min_loss_D = coeffs[2].exp().item() / (D[min_loss_idx].item() ** exponents[2].item())\n",
    "print(f\"min loss contributions - m: {min_loss_m}, ell: {min_loss_ell}, D: {min_loss_D}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f20cbf69",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_indices = [i for i in range(len(ell)) if ell[i] < 5000] # all data\n",
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(ell[p_indices].numpy() / 100, losses[p_indices].numpy() - coeffs[0].exp().item() / m[p_indices].numpy() ** exponents[0].item()\n",
    "         - coeffs[2].exp().item() / D[p_indices].numpy() ** exponents[2].item() - E.item(), 'ok', alpha = 0.5)\n",
    "plt.plot(np.arange(8, 64), coeffs[1].exp().item() / (np.arange(8, 64)*100) ** exponents[1].item(), 'k--')\n",
    "plt.xscale('log', base = 2)\n",
    "#plt.ylim(2**(-5.1), None)\n",
    "plt.yscale('log', base = 2)\n",
    "plt.xlabel(r'Depth, $\\ell$')\n",
    "plt.ylabel('Loss (depth part)')\n",
    "plt.savefig('../figures/loss_vs_depth_depth_part.png', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "53e45d16",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Loss (width part)')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_indices = [i for i in range(len(ell)) if ell[i] < 5000] # all data\n",
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(m.numpy(), losses.numpy() - coeffs[1].exp().item() / ell.numpy() ** exponents[1].item()\n",
    "         - coeffs[2].exp().item() / D.numpy() ** exponents[2].item() - E.item(), 'ok', alpha = 0.5)\n",
    "plt.plot(np.arange(2**9, 2**13), coeffs[0].exp().item() / (np.arange(2**9, 2**13)) ** exponents[0].item(), 'k--')\n",
    "plt.xscale('log', base = 2)\n",
    "#plt.ylim(2**(-5.1), None)\n",
    "plt.yscale('log', base = 2)\n",
    "plt.xlabel(r'Width, $m$')\n",
    "plt.ylabel('Loss (width part)')\n",
    "#plt.savefig('../figures/loss_vs_depth_depth_part.png', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f986c607",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Loss (dataset part)')"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x210 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2.8,2.1), constrained_layout=True)\n",
    "plt.plot(D.numpy(), losses.numpy() - coeffs[1].exp().item() / ell.numpy() ** exponents[1].item()\n",
    "         - coeffs[0].exp().item() / m.numpy() ** exponents[0].item() - E.item(), 'ok', alpha = 0.5)\n",
    "plt.plot(np.arange(2**11, 2**19), coeffs[2].exp().item() / (np.arange(2**11, 2**19)) ** exponents[2].item(), 'k--')\n",
    "plt.xscale('log', base = 2)\n",
    "#plt.ylim(2**(-5.1), None)\n",
    "plt.yscale('log', base = 2)\n",
    "plt.xlabel(r'Dataset size, $D$')\n",
    "plt.ylabel('Loss (dataset part)')\n",
    "#plt.savefig('../figures/loss_vs_depth_depth_part.png', dpi = 300)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
