{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from gpt_pkg.model import GPTConfig, GPT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model    |    Estimate (Kaplan) |     Exact (no embeddings) |       Diff\n",
      "---------------------------------------------------------------------------\n",
      "FlashAttention will be used.\n",
      "gpt_A    |               0.39M |                   0.40M |    -0.00M\n",
      "gpt_B    |               0.88M |                   0.89M |    -0.01M\n",
      "gpt_C    |               1.04M |                   1.05M |    -0.01M\n",
      "gpt_D    |               1.43M |                   1.44M |    -0.01M\n",
      "gpt_E    |               1.38M |                   1.39M |    -0.01M\n",
      "gpt_F    |               2.08M |                   2.09M |    -0.01M\n",
      "gpt_G    |               3.15M |                   3.16M |    -0.02M\n",
      "gpt_H    |               4.15M |                   4.17M |    -0.02M\n",
      "gpt_I    |               4.99M |                   5.02M |    -0.03M\n",
      "gpt_J    |               7.08M |                   7.10M |    -0.02M\n",
      "gpt_K    |               8.85M |                   8.88M |    -0.03M\n",
      "gpt_L    |              10.62M |                  10.65M |    -0.03M\n",
      "gpt_M    |              14.16M |                  14.20M |    -0.04M\n",
      "gpt_N    |              17.69M |                  17.75M |    -0.05M\n",
      "gpt_O    |              21.23M |                  21.30M |    -0.06M\n",
      "gpt_P    |              28.90M |                  28.98M |    -0.07M\n",
      "gpt_Q    |              37.75M |                  37.83M |    -0.08M\n",
      "gpt_R    |              47.78M |                  47.87M |    -0.10M\n",
      "gpt_S    |              58.98M |                  59.09M |    -0.11M\n",
      "gpt_T    |              84.93M |                  85.06M |    -0.13M\n",
      "gpt_U    |             102.21M |                 102.36M |    -0.15M\n",
      "gpt_V    |             127.40M |                 127.59M |    -0.19M\n",
      "gpt_W    |             154.14M |                 154.34M |    -0.20M\n",
      "gpt_X    |             176.16M |                 176.36M |    -0.20M\n",
      "gpt_Y    |             251.66M |                 251.93M |    -0.28M\n",
      "gpt_Z    |             301.99M |                 302.32M |    -0.33M\n",
      "gpt_Z1   |             471.86M |                 472.27M |    -0.41M\n",
      "gpt_Z2   |             679.48M |                 679.97M |    -0.49M\n"
     ]
    }
   ],
   "source": [
    "\n",
    "def estimate_gpt_params(n_layer, n_head, n_embd, non_embedding=True):\n",
    "    \"\"\"\n",
    "    Kaplan-style param estimate: 12 * L * d^2\n",
    "    \"\"\"\n",
    "    return int(12 * n_layer * n_embd**2)\n",
    "\n",
    "def exact_param_count(n_layer, n_head, n_embd, non_embedding=True):\n",
    "    \"\"\"\n",
    "    Get exact number of params from model.\n",
    "    \"\"\"\n",
    "    cfg = GPTConfig(n_layer=n_layer, n_head=n_head, n_embd=n_embd)\n",
    "    model = GPT(cfg)\n",
    "    return model.get_num_params(non_embedding=non_embedding)\n",
    "\n",
    "# Model configs for scaling laws\n",
    "# --- Model config ---\n",
    "gpt_models = {\n",
    "    'gpt_A': dict(n_layer=2, n_head=2, n_embd=128),\n",
    "    'gpt_B': dict(n_layer=2, n_head=3, n_embd=192),\n",
    "    'gpt_C': dict(n_layer=2, n_head=4, n_embd=208),\n",
    "    'gpt_D': dict(n_layer=2, n_head=4, n_embd=244),\n",
    "    'gpt_E': dict(n_layer=2, n_head=4, n_embd=240),\n",
    "    'gpt_F': dict(n_layer=4, n_head=4, n_embd=208),\n",
    "    'gpt_G': dict(n_layer=4, n_head=4, n_embd=256),\n",
    "    'gpt_H': dict(n_layer=6, n_head=6, n_embd=240),\n",
    "    'gpt_I': dict(n_layer=8, n_head=6, n_embd=228),\n",
    "    'gpt_J': dict(n_layer=4, n_head=6, n_embd=384),\n",
    "    'gpt_K': dict(n_layer=5, n_head=6, n_embd=384),\n",
    "    'gpt_L': dict(n_layer=6, n_head=6, n_embd=384),\n",
    "    'gpt_M': dict(n_layer=8, n_head=6, n_embd=384),\n",
    "    'gpt_N': dict(n_layer=10, n_head=6, n_embd=384),\n",
    "    'gpt_O': dict(n_layer=12, n_head=6, n_embd=384),\n",
    "    'gpt_P': dict(n_layer=12, n_head=8, n_embd=448),\n",
    "    'gpt_Q': dict(n_layer=12, n_head=8, n_embd=512),\n",
    "    'gpt_R': dict(n_layer=12, n_head=8, n_embd=576),\n",
    "    'gpt_S': dict(n_layer=12, n_head=8, n_embd=640),\n",
    "    'gpt_T': dict(n_layer=12, n_head=12, n_embd=768),\n",
    "    'gpt_U': dict(n_layer=14, n_head=12, n_embd=780),\n",
    "    'gpt_V': dict(n_layer=18, n_head=12, n_embd=768),\n",
    "    'gpt_W': dict(n_layer=16, n_head=14, n_embd=896),\n",
    "    'gpt_X': dict(n_layer=14, n_head=16, n_embd=1024),\n",
    "    'gpt_Y': dict(n_layer=20, n_head=16, n_embd=1024),\n",
    "    'gpt_Z': dict(n_layer=24, n_head=16, n_embd=1024),\n",
    "    'gpt_Z1': dict(n_layer=24, n_head=20, n_embd=1280),\n",
    "    'gpt_Z2': dict(n_layer=24, n_head=24, n_embd=1536),\n",
    "}\n",
    "\n",
    "\n",
    "# Print header\n",
    "print(f\"{'Model':<8} | {'Estimate (Kaplan)':>20} | {'Exact (no embeddings)':>25} | {'Diff':>10}\")\n",
    "print('-' * 75)\n",
    "\n",
    "# Loop and print\n",
    "for name, cfg in gpt_models.items():\n",
    "    est = estimate_gpt_params(cfg['n_layer'], cfg['n_head'], cfg['n_embd'], non_embedding=True)\n",
    "    exact = exact_param_count(cfg['n_layer'], cfg['n_head'], cfg['n_embd'], non_embedding=True)\n",
    "    diff = est - exact\n",
    "    print(f\"{name:<8} | {est/1e6:>18.2f}M | {exact/1e6:>22.2f}M | {diff/1e6:>8.2f}M\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model    |    1.0e+17 |    3.0e+17 |    6.0e+17 |    1.0e+18 |    3.0e+18 |    6.0e+18 |    1.0e+19 |    3.0e+19 |    6.0e+19\n",
      "-----------------------------------------------------------------------------------------------------------------------------\n",
      "gpt_A    |    1766063 |    5298190 |   10596381 |   17660635 |   52981906 |  105963812 |  176606354 |  529819064 | 1059638129 |\n",
      "gpt_B    |     784917 |    2354751 |    4709502 |    7849171 |   23547513 |   47095027 |   78491713 |  235475139 |  470950279 |\n",
      "gpt_C    |     668805 |    2006415 |    4012830 |    6688051 |   20064153 |   40128307 |   66880513 |  200641539 |  401283078 |\n",
      "gpt_D    |     486011 |    1458034 |    2916069 |    4860115 |   14580347 |   29160694 |   48601157 |  145803472 |  291606945 |\n",
      "gpt_E    |     502346 |    1507040 |    3014081 |    5023469 |   15070408 |   30140817 |   50234696 |  150704089 |  301408179 |\n",
      "gpt_F    |     334402 |    1003207 |    2006415 |    3344025 |   10032076 |   20064153 |   33440256 |  100320769 |  200641539 |\n",
      "gpt_G    |     220757 |     662273 |    1324547 |    2207579 |    6622738 |   13245476 |   22075794 |   66227383 |  132454766 |\n",
      "gpt_H    |     167448 |     502346 |    1004693 |    1674489 |    5023469 |   10046939 |   16744898 |   50234696 |  100469393 |\n",
      "gpt_I    |     139154 |     417462 |     834925 |    1391542 |    4174628 |    8349257 |   13915428 |   41746285 |   83492570 |\n",
      "gpt_J    |      98114 |     294343 |     588687 |     981146 |    2943439 |    5886878 |    9811464 |   29434392 |   58868784 |\n",
      "gpt_K    |      78491 |     235475 |     470950 |     784917 |    2354751 |    4709502 |    7849171 |   23547513 |   47095027 |\n",
      "gpt_L    |      65409 |     196229 |     392458 |     654097 |    1962292 |    3924585 |    6540976 |   19622928 |   39245856 |\n",
      "gpt_M    |      49057 |     147171 |     294343 |     490573 |    1471719 |    2943439 |    4905732 |   14717196 |   29434392 |\n",
      "gpt_N    |      39245 |     117737 |     235475 |     392458 |    1177375 |    2354751 |    3924585 |   11773756 |   23547513 |\n",
      "gpt_O    |      32704 |      98114 |     196229 |     327048 |     981146 |    1962292 |    3270488 |    9811464 |   19622928 |\n",
      "gpt_P    |      24028 |      72084 |     144168 |     240280 |     720842 |    1441684 |    2402807 |    7208422 |   14416845 |\n",
      "gpt_Q    |      18396 |      55189 |     110378 |     183964 |     551894 |    1103789 |    1839649 |    5518948 |   11037897 |\n",
      "gpt_R    |      14535 |      43606 |      87213 |     145355 |     436065 |     872130 |    1453550 |    4360650 |    8721301 |\n",
      "gpt_S    |      11773 |      35321 |      70642 |     117737 |     353212 |     706425 |    1177375 |    3532127 |    7064254 |\n",
      "gpt_T    |       8176 |      24528 |      49057 |      81762 |     245286 |     490573 |     817622 |    2452866 |    4905732 |\n",
      "gpt_U    |       6794 |      20382 |      40765 |      67942 |     203826 |     407652 |     679421 |    2038263 |    4076526 |\n",
      "gpt_V    |       5450 |      16352 |      32704 |      54508 |     163524 |     327048 |     545081 |    1635244 |    3270488 |\n",
      "gpt_W    |       4505 |      13515 |      27031 |      45052 |     135157 |     270315 |     450526 |    1351579 |    2703158 |\n",
      "gpt_X    |       3942 |      11826 |      23652 |      39421 |     118263 |     236526 |     394210 |    1182631 |    2365263 |\n",
      "gpt_Y    |       2759 |       8278 |      16556 |      27594 |      82784 |     165568 |     275947 |     827842 |    1655684 |\n",
      "gpt_Z    |       2299 |       6898 |      13797 |      22995 |      68986 |     137973 |     229956 |     689868 |    1379737 |\n",
      "gpt_Z1   |       1471 |       4415 |       8830 |      14717 |      44151 |      88303 |     147171 |     441515 |     883031 |\n",
      "gpt_Z2   |       1022 |       3066 |       6132 |      10220 |      30660 |      61321 |     102202 |     306608 |     613216 |\n"
     ]
    }
   ],
   "source": [
    "from gpt_pkg.model import GPT, GPTConfig\n",
    "\n",
    "# Settings\n",
    "context_len = 1500 #600\n",
    "B = [16]*len(gpt_models.keys())  # batch sizes\n",
    "G = [1] *len(gpt_models.keys())     # grad accum\n",
    "\n",
    "compute_budgets = [1e17, 3e17, 6e17, 1e18, 3e18, 6e18, 1e19, 3e19, 6e19]  # Chinchilla-style C = 6*N*tokens\n",
    "\n",
    "\n",
    "# Compute optimizer steps\n",
    "def compute_max_iters(N_params, B, G, C_l, compute_budget):\n",
    "    max_iters = []\n",
    "    for N, b, g in zip(N_params, B, G):\n",
    "        tokens_per_step = b * g * C_l\n",
    "        max_iter = compute_budget / (6 * N * tokens_per_step)\n",
    "        max_iters.append(int(max_iter))\n",
    "    return max_iters\n",
    "\n",
    "# Header\n",
    "header = f\"{'Model':<8} | \" + \" | \".join([f\"{c:>10.1e}\" for c in compute_budgets]) \n",
    "print(header)\n",
    "print(\"-\" * len(header))\n",
    "\n",
    "# Compute optimizer steps per model and compute and print\n",
    "model_names = list(gpt_models.keys())\n",
    "exact_params = [estimate_gpt_params(**gpt_models[name]) for name in model_names]\n",
    "\n",
    "for i, name in enumerate(model_names):\n",
    "    row = f\"{name:<8} |\"\n",
    "    for budget in compute_budgets:\n",
    "        steps = compute_max_iters([exact_params[i]],\n",
    "         [B[i]], [G[i]], context_len, budget)[0]\n",
    "        row += f\" {steps:>10} |\"\n",
    "    print(row)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model    |    1.0e+17 |    3.0e+17 |    6.0e+17 |    1.0e+18 |    3.0e+18 |    6.0e+18 |    1.0e+19 |    3.0e+19 |    6.0e+19 | (optimizer steps)\n",
      "-------------------------------------------------------------------------------------------------------------------------------------------------\n",
      "gpt_A    |    1745607 |    5236821 |   10473643 |   17456072 |   52368216 |  104736432 |  174560721 |  523682164 | 1047364328 |\n",
      "gpt_B    |     778832 |    2336497 |    4672995 |    7788325 |   23364975 |   46729950 |   77883250 |  233649751 |  467299502 |\n",
      "gpt_C    |     664016 |    1992049 |    3984099 |    6640165 |   19920496 |   39840993 |   66401655 |  199204965 |  398409930 |\n",
      "gpt_D    |     483042 |    1449126 |    2898252 |    4830420 |   14491261 |   28982523 |   48304205 |  144912616 |  289825233 |\n",
      "gpt_E    |     499226 |    1497680 |    2995360 |    4992267 |   14976803 |   29953607 |   49922679 |  149768039 |  299536078 |\n",
      "gpt_F    |     332338 |     997016 |    1994032 |    3323387 |    9970162 |   19940325 |   33233876 |   99701628 |  199403257 |\n",
      "gpt_G    |     219649 |     658949 |    1317898 |    2196496 |    6589490 |   13178981 |   21964968 |   65894905 |  131789811 |\n",
      "gpt_H    |     166600 |     499801 |     999603 |    1666005 |    4998016 |    9996033 |   16660055 |   49980167 |   99960335 |\n",
      "gpt_I    |     138433 |     415299 |     830599 |    1384332 |    4152998 |    8305996 |   13843327 |   41529983 |   83059966 |\n",
      "gpt_J    |      97785 |     293357 |     586714 |     977857 |    2933571 |    5867143 |    9778571 |   29335715 |   58671430 |\n",
      "gpt_K    |      78237 |     234711 |     469422 |     782370 |    2347111 |    4694222 |    7823703 |   23471110 |   46942221 |\n",
      "gpt_L    |      65202 |     195606 |     391213 |     652022 |    1956066 |    3912133 |    6520223 |   19560669 |   39121338 |\n",
      "gpt_M    |      48906 |     146718 |     293436 |     489060 |    1467182 |    2934364 |    4890608 |   14671824 |   29343648 |\n",
      "gpt_N    |      39126 |     117380 |     234761 |     391269 |    1173809 |    2347618 |    3912698 |   11738094 |   23476188 |\n",
      "gpt_O    |      32606 |      97820 |     195641 |     326069 |     978209 |    1956419 |    3260699 |    9782098 |   19564196 |\n",
      "gpt_P    |      23966 |      71899 |     143798 |     239664 |     718992 |    1437984 |    2396640 |    7189921 |   14379843 |\n",
      "gpt_Q    |      18355 |      55065 |     110131 |     183551 |     550655 |    1101310 |    1835516 |    5506550 |   11013100 |\n",
      "gpt_R    |      14506 |      43519 |      87038 |     145064 |     435194 |     870388 |    1450646 |    4351940 |    8703881 |\n",
      "gpt_S    |      11752 |      35257 |      70515 |     117525 |     352577 |     705155 |    1175258 |    3525776 |    7051552 |\n",
      "gpt_T    |       8163 |      24491 |      48983 |      81639 |     244918 |     489837 |     816396 |    2449189 |    4898379 |\n",
      "gpt_U    |       6784 |      20352 |      40705 |      67842 |     203528 |     407056 |     678427 |    2035281 |    4070562 |\n",
      "gpt_V    |       5442 |      16328 |      32656 |      54428 |     163284 |     326568 |     544280 |    1632842 |    3265684 |\n",
      "gpt_W    |       4499 |      13498 |      26997 |      44995 |     134986 |     269973 |     449956 |    1349868 |    2699737 |\n",
      "gpt_X    |       3937 |      11813 |      23626 |      39377 |     118131 |     236262 |     393771 |    1181313 |    2362626 |\n",
      "gpt_Y    |       2756 |       8269 |      16538 |      27564 |      82693 |     165386 |     275644 |     826933 |    1653867 |\n",
      "gpt_Z    |       2297 |       6891 |      13782 |      22970 |      68911 |     137823 |     229705 |     689116 |    1378232 |\n",
      "gpt_Z1   |       1470 |       4411 |       8822 |      14704 |      44113 |      88226 |     147043 |     441130 |     882261 |\n",
      "gpt_Z2   |       1021 |       3063 |       6127 |      10212 |      30638 |      61277 |     102128 |     306385 |     612770 |\n",
      "\n",
      "Estimated training time (in hours):\n",
      "Model    |    1.0e+17 |    3.0e+17 |    6.0e+17 |    1.0e+18 |    3.0e+18 |    6.0e+18 |    1.0e+19 |    3.0e+19 |    6.0e+19 | (hours)\n",
      "---------------------------------------------------------------------------------------------------------------------------------------\n",
      "gpt_A    |       16.2 |       48.5 |       97.0 |      161.6 |      484.9 |      969.8 |     1616.3 |     4848.9 |     9697.8 |\n",
      "gpt_B    |        7.2 |       21.6 |       43.3 |       72.1 |      216.3 |      432.7 |      721.1 |     2163.4 |     4326.8 |\n",
      "gpt_C    |        6.1 |       18.4 |       36.9 |       61.5 |      184.4 |      368.9 |      614.8 |     1844.5 |     3689.0 |\n",
      "gpt_D    |        4.5 |       13.4 |       26.8 |       44.7 |      134.2 |      268.4 |      447.3 |     1341.8 |     2683.6 |\n",
      "gpt_E    |        4.6 |       13.9 |       27.7 |       46.2 |      138.7 |      277.3 |      462.2 |     1386.7 |     2773.5 |\n",
      "gpt_F    |        3.1 |        9.2 |       18.5 |       30.8 |       92.3 |      184.6 |      307.7 |      923.2 |     1846.3 |\n",
      "gpt_G    |        2.0 |        6.1 |       12.2 |       20.3 |       61.0 |      122.0 |      203.4 |      610.1 |     1220.3 |\n",
      "gpt_H    |        1.5 |        4.6 |        9.3 |       15.4 |       46.3 |       92.6 |      154.3 |      462.8 |      925.6 |\n",
      "gpt_I    |        1.3 |        3.8 |        7.7 |       12.8 |       38.5 |       76.9 |      128.2 |      384.5 |      769.1 |\n",
      "gpt_J    |        0.9 |        2.7 |        5.4 |        9.1 |       27.2 |       54.3 |       90.5 |      271.6 |      543.3 |\n",
      "gpt_K    |        0.7 |        2.2 |        4.3 |        7.2 |       21.7 |       43.5 |       72.4 |      217.3 |      434.7 |\n",
      "gpt_L    |        0.6 |        1.8 |        3.6 |        6.0 |       18.1 |       36.2 |       60.4 |      181.1 |      362.2 |\n",
      "gpt_M    |        0.5 |        1.4 |        2.7 |        4.5 |       13.6 |       27.2 |       45.3 |      135.9 |      271.7 |\n",
      "gpt_N    |        0.4 |        1.1 |        2.2 |        3.6 |       10.9 |       21.7 |       36.2 |      108.7 |      217.4 |\n",
      "gpt_O    |        0.3 |        0.9 |        1.8 |        3.0 |        9.1 |       18.1 |       30.2 |       90.6 |      181.1 |\n",
      "gpt_P    |        0.2 |        0.7 |        1.3 |        2.2 |        6.7 |       13.3 |       22.2 |       66.6 |      133.1 |\n",
      "gpt_Q    |        0.2 |        0.5 |        1.0 |        1.7 |        5.1 |       10.2 |       17.0 |       51.0 |      102.0 |\n",
      "gpt_R    |        0.1 |        0.4 |        0.8 |        1.3 |        4.0 |        8.1 |       13.4 |       40.3 |       80.6 |\n",
      "gpt_S    |        0.1 |        0.3 |        0.7 |        1.1 |        3.3 |        6.5 |       10.9 |       32.6 |       65.3 |\n",
      "gpt_T    |        0.1 |        0.2 |        0.5 |        0.8 |        2.3 |        4.5 |        7.6 |       22.7 |       45.4 |\n",
      "gpt_U    |        0.1 |        0.2 |        0.4 |        0.6 |        1.9 |        3.8 |        6.3 |       18.8 |       37.7 |\n",
      "gpt_V    |        0.1 |        0.2 |        0.3 |        0.5 |        1.5 |        3.0 |        5.0 |       15.1 |       30.2 |\n",
      "gpt_W    |        0.0 |        0.1 |        0.2 |        0.4 |        1.2 |        2.5 |        4.2 |       12.5 |       25.0 |\n",
      "gpt_X    |        0.0 |        0.1 |        0.2 |        0.4 |        1.1 |        2.2 |        3.6 |       10.9 |       21.9 |\n",
      "gpt_Y    |        0.0 |        0.1 |        0.2 |        0.3 |        0.8 |        1.5 |        2.6 |        7.7 |       15.3 |\n",
      "gpt_Z    |        0.0 |        0.1 |        0.1 |        0.2 |        0.6 |        1.3 |        2.1 |        6.4 |       12.8 |\n",
      "gpt_Z1   |        0.0 |        0.0 |        0.1 |        0.1 |        0.4 |        0.8 |        1.4 |        4.1 |        8.2 |\n",
      "gpt_Z2   |        0.0 |        0.0 |        0.1 |        0.1 |        0.3 |        0.6 |        0.9 |        2.8 |        5.7 |\n"
     ]
    }
   ],
   "source": [
    "# Compute time in hours given number of steps\n",
    "def compute_time_from_steps(steps, time_per_step_min=1/1800): # estimate (not entirely accurate for all)\n",
    "    return steps * time_per_step_min / 60  # convert minutes to hours\n",
    "\n",
    "# First table: steps\n",
    "header = f\"{'Model':<8} | \" + \" | \".join([f\"{c:>10.1e}\" for c in compute_budgets]) + \" | (optimizer steps)\"\n",
    "print(header)\n",
    "print(\"-\" * len(header))\n",
    "\n",
    "steps_table = []\n",
    "model_names = list(gpt_models.keys())\n",
    "exact_params = [exact_param_count(**gpt_models[name]) for name in model_names]\n",
    "\n",
    "for i, name in enumerate(model_names):\n",
    "    row = f\"{name:<8} |\"\n",
    "    steps_row = []\n",
    "    for budget in compute_budgets:\n",
    "        steps = compute_max_iters([exact_params[i]], [B[i]], [G[i]], context_len, budget)[0]\n",
    "        row += f\" {steps:>10} |\"\n",
    "        steps_row.append(steps)\n",
    "    print(row)\n",
    "    steps_table.append(steps_row)\n",
    "\n",
    "# Second table: estimated time\n",
    "print(\"\\nEstimated training time (in hours):\")\n",
    "header = f\"{'Model':<8} | \" + \" | \".join([f\"{c:>10.1e}\" for c in compute_budgets]) + \" | (hours)\"\n",
    "print(header)\n",
    "print(\"-\" * len(header))\n",
    "\n",
    "for name, step_row in zip(model_names, steps_table):\n",
    "    row = f\"{name:<8} |\"\n",
    "    for steps in step_row:\n",
    "        hours = compute_time_from_steps(steps)\n",
    "        row += f\" {hours:10.1f} |\"\n",
    "    print(row)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0005477225575051661\n"
     ]
    }
   ],
   "source": [
    "def adjust_learning_rate(new_batch_size, old_batch_size=16, old_lr=1e-4, scaling='sqrt'):\n",
    "    \"\"\"\n",
    "    Adjust the learning rate based on batch size change.\n",
    "    \n",
    "    Args:\n",
    "        new_batch_size (int): The new batch size you want to use.\n",
    "        old_batch_size (int): The old batch size (default 16).\n",
    "        old_lr (float): The old learning rate (default 0.0001).\n",
    "        scaling (str): 'sqrt' for square-root scaling (safe) or 'linear' for linear scaling (aggressive).\n",
    "    \n",
    "    Returns:\n",
    "        float: New adjusted learning rate.\n",
    "    \"\"\"\n",
    "    k = new_batch_size / old_batch_size\n",
    "    if scaling == 'sqrt':\n",
    "        scale_factor = k ** 0.5\n",
    "    elif scaling == 'linear':\n",
    "        scale_factor = k\n",
    "    else:\n",
    "        raise ValueError(\"scaling must be 'sqrt' or 'linear'\")\n",
    "    \n",
    "    new_lr = old_lr * scale_factor\n",
    "    return new_lr\n",
    "# for batch 8 its 0.00007\n",
    "lr=adjust_learning_rate(480)\n",
    "print(lr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9.6421553856e+19\n"
     ]
    }
   ],
   "source": [
    "def compute_training_flops(model_size_str, batch_size, context_length, num_iterations):\n",
    "    \"\"\"\n",
    "    Calculate the total training compute in FLOPs using 6ND.\n",
    "\n",
    "    Parameters:\n",
    "        model_size_str (str): Model size as a string, e.g., '38M' or '1.5B'\n",
    "        batch_size (int): Number of sequences per batch\n",
    "        context_length (int): Number of tokens per sequence\n",
    "        num_iterations (int): Total number of training steps\n",
    "\n",
    "    Returns:\n",
    "        float: Total compute used (in FLOPs)\n",
    "    \"\"\"\n",
    "    # Convert model size string to number\n",
    "    if model_size_str.lower().endswith('m'):\n",
    "        D = float(model_size_str[:-1]) * 1e6\n",
    "    elif model_size_str.lower().endswith('b'):\n",
    "        D = float(model_size_str[:-1]) * 1e9\n",
    "    else:\n",
    "        raise ValueError(\"Model size must end with 'M' or 'B'.\")\n",
    "\n",
    "    N = batch_size * context_length * num_iterations\n",
    "    compute_flops = 6 * N * D\n",
    "    return compute_flops\n",
    "\n",
    "budget= compute_training_flops('38M', 480, 4100, 214889)\n",
    "print(budget)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "685307\n"
     ]
    }
   ],
   "source": [
    "def compute_num_iterations(compute_budget, model_size_str, batch_size, context_length):\n",
    "    \"\"\"\n",
    "    Calculate the number of training iterations given a compute budget.\n",
    "\n",
    "    Parameters:\n",
    "        compute_budget (float): Total compute budget in FLOPs\n",
    "        model_size_str (str): Model size as a string, e.g., '38M' or '1.5B'\n",
    "        batch_size (int): Number of sequences per batch\n",
    "        context_length (int): Number of tokens per sequence\n",
    "\n",
    "    Returns:\n",
    "        int: Number of iterations that fit within the compute budget\n",
    "    \"\"\"\n",
    "    # Convert model size string to number of parameters\n",
    "    if model_size_str.lower().endswith('m'):\n",
    "        D = float(model_size_str[:-1]) * 1e6\n",
    "    elif model_size_str.lower().endswith('b'):\n",
    "        D = float(model_size_str[:-1]) * 1e9\n",
    "    else:\n",
    "        raise ValueError(\"Model size must end with 'M' or 'B'.\")\n",
    "\n",
    "    tokens_per_iter = batch_size * context_length\n",
    "    iterations = compute_budget / (6 * tokens_per_iter * D)\n",
    "    return int(iterations)\n",
    "\n",
    "itr= compute_num_iterations(1e18, '38M', 8, 800)\n",
    "print(itr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3092965/1830618305.py:279: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  plt.tight_layout(w_pad=0.0)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1650x390 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "\n",
    "import wandb\n",
    "import math\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import FuncFormatter, LogFormatterMathtext, LogLocator\n",
    "from matplotlib import cm\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "\n",
    "def truncate_colormap(cmap, minval=0.2, maxval=1.0, n=100):\n",
    "    return LinearSegmentedColormap.from_list(\n",
    "        f\"trunc({cmap.name},{minval},{maxval})\",\n",
    "        cmap(np.linspace(minval, maxval, n))\n",
    "    )\n",
    "\n",
    "# Settings\n",
    "FONTSIZE = 6\n",
    "plt.rcParams.update({\n",
    "    'text.usetex': True,\n",
    "    'font.family': 'serif',\n",
    "    'font.serif': ['Times'],\n",
    "    'text.latex.preamble': r'\\usepackage{amsmath} \\usepackage{type1cm}',\n",
    "    'font.size': FONTSIZE,\n",
    "})\n",
    "\n",
    "# Helpers \n",
    "def estimate_kaplan(n_layer, n_embd):\n",
    "    return 12 * n_layer * n_embd**2\n",
    "\n",
    "def format_large(x, _):\n",
    "    if x >= 1e12:\n",
    "        return f'{x*1e-12:.0f}T'\n",
    "    elif x >= 1e9:\n",
    "        return f'{x*1e-9:.0f}B'\n",
    "    elif x >= 1e6:\n",
    "        return f'{x*1e-6:.0f}M'\n",
    "    else:\n",
    "        return str(int(x))\n",
    "\n",
    "# Load runs \n",
    "api = wandb.Api()\n",
    "runs = api.runs()\n",
    "compute_points = {cb: [] for cb in compute_budgets}\n",
    "\n",
    "for run in runs:\n",
    "    if run.state != \"finished\":\n",
    "        continue\n",
    "    tags = run.tags or []\n",
    "    # Find a gpt_* tag that ends in _final\n",
    "    gpt_tag = next((t for t in tags if any(t.startswith(model) and t.endswith(\"_final\") for model in gpt_models)), None)\n",
    "    if not gpt_tag:\n",
    "        continue\n",
    "\n",
    "    # find all model-keys that are a prefix of this tag\n",
    "    cands = [m for m in gpt_models if gpt_tag.startswith(m)]\n",
    "    if not cands:\n",
    "        continue\n",
    "\n",
    "    # pick the longest one so Z2 wins over Z\n",
    "    model_type = max(cands, key=len)\n",
    "    parts = gpt_tag.split('_')\n",
    "    compute_str = next((p for p in parts if 'e' in p), None)\n",
    "    try:\n",
    "        compute = float(compute_str)\n",
    "    except:\n",
    "        continue\n",
    "    if compute not in compute_budgets:\n",
    "        continue\n",
    "    arch = gpt_models[model_type]\n",
    "    N = estimate_kaplan(arch['n_layer'], arch['n_embd'])\n",
    "    log_params = math.log10(N)\n",
    "    loss = run.summary.get(\"test/loss\", run.summary.get(\"val/loss\", None))\n",
    "    if loss is not None:\n",
    "        compute_points[compute].append((log_params, loss, gpt_tag, run.name))\n",
    "\n",
    "# Extract best runs \n",
    "min_loss_per_compute = {\n",
    "    cb: min(pts, key=lambda x: x[1]) for cb, pts in compute_points.items() if pts\n",
    "}\n",
    "\n",
    "compute_vs_params = []\n",
    "flops_vs_tokens = []\n",
    "tags_list = []\n",
    "\n",
    "for compute_budget, (log_params, loss, gpt_tag, run_name) in min_loss_per_compute.items():\n",
    "    parts = gpt_tag.split('_')\n",
    "    model_type = parts[0] + '_' + parts[1] if parts[1][0].isalpha() else parts[0]\n",
    "    if model_type not in gpt_models:\n",
    "        continue\n",
    "    arch = gpt_models[model_type]\n",
    "    N = estimate_kaplan(arch['n_layer'], arch['n_embd'])\n",
    "\n",
    "    compute_vs_params.append((compute_budget, N))\n",
    "    flops_vs_tokens.append((compute_budget, compute_budget / (6 * N)))\n",
    "    tags_list.append(gpt_tag)\n",
    "\n",
    "compute_vs_params = np.array(compute_vs_params)\n",
    "flops_vs_tokens = np.array(flops_vs_tokens)\n",
    "\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "from matplotlib import ticker, cm\n",
    "import numpy as np\n",
    "\n",
    "# Figure setup\n",
    "fig, axes = plt.subplots(1, 3, figsize=(5.5, 1.3), dpi=300, gridspec_kw={'wspace': 0.4})\n",
    "ax0, ax1, ax2 = axes\n",
    "\n",
    "# Truncate PuBu to skip lightest colors (0.0–0.2) \n",
    "def truncate_colormap(cmap, minval=0.2, maxval=1.0, n=100):\n",
    "    new_cmap = LinearSegmentedColormap.from_list(\n",
    "        f\"trunc({cmap.name},{minval},{maxval})\",\n",
    "        cmap(np.linspace(minval, maxval, n))\n",
    "    )\n",
    "    return new_cmap\n",
    "\n",
    "trunc_cmap = truncate_colormap(cm.PuBu, minval=0.2, maxval=1.0)\n",
    "\n",
    "norm = mpl.colors.LogNorm(vmin=min(compute_points.keys()), vmax=max(compute_points.keys()))\n",
    "sm = plt.cm.ScalarMappable(cmap=trunc_cmap, norm=norm)\n",
    "sm.set_array([])\n",
    "\n",
    "# Plot 1: Test Loss vs Parameters \n",
    "\n",
    "colors = cm.PuBu(np.linspace(0.2, 1.0, len(compute_points)))\n",
    "\n",
    "for idx, (compute_budget, points) in enumerate(compute_points.items()):\n",
    "    if not points:\n",
    "        continue\n",
    "    x_log, y, tags, _ = zip(*points)\n",
    "    color = colors[idx]\n",
    "    x = [10**v for v in x_log]\n",
    "    ax0.scatter(x, y, color=color, s=3)\n",
    "    coeffs = np.polyfit(np.log10(x), y, deg=2)\n",
    "    poly = np.poly1d(coeffs)\n",
    "    x_fit = np.logspace(np.log10(min(x)) - 0.1, np.log10(max(x)) + 0.1, 200)\n",
    "    y_fit = poly(np.log10(x_fit))\n",
    "    ax0.plot(x_fit, y_fit, linestyle='--', color=color, linewidth=0.5)\n",
    "\n",
    "ax0.set_xscale(\"log\")\n",
    "ax0.xaxis.set_minor_locator(LogLocator(base=10.0, subs=[2, 5], numticks=100))\n",
    "ax0.xaxis.set_minor_formatter(ticker.NullFormatter())\n",
    "ax0.set_xticks([1e6, 1e7, 3e8])\n",
    "ax0.set_xticklabels(['1M', '10M', '300M'])\n",
    "ax0.set_yticks([0.08, 0.13, 0.17])\n",
    "ax0.set_yticklabels(['0.08', '0.13', '0.17'])\n",
    "ax0.set_xlabel(\"Parameters\")\n",
    "ax0.set_ylabel(\"Test Loss\")\n",
    "ax0.tick_params(axis='both', which='both', direction='inout', length=0)\n",
    "ax0.grid(True, which='both', ls='--', lw=0.3)\n",
    "\n",
    "# Insert horizontal colorbar \n",
    "# Position of ax0\n",
    "pos = ax0.get_position()\n",
    "\n",
    "# Define colorbar position relative to figure\n",
    "cbar_left = pos.x0 + 0.005   # % left of the first plot\n",
    "cbar_bottom = pos.y0 + 0.015 \n",
    "cbar_width = 0.01            # Thin\n",
    "cbar_height = pos.height * 0.3   # Span ~30% of ax0\n",
    "\n",
    "# Add colorbar\n",
    "cbar_ax = fig.add_axes([cbar_left, cbar_bottom, cbar_width, cbar_height])\n",
    "cbar = fig.colorbar(sm, cax=cbar_ax, orientation='vertical')\n",
    "\n",
    "# Set only 1e17 and 6e19 as major ticks with labels\n",
    "cbar.set_ticks([1e17, 6e19])\n",
    "cbar.set_ticklabels(['1e17', '6e19'])\n",
    "\n",
    "# Minor ticks at 3e17, 6e17, etc.\n",
    "minor_locator = ticker.FixedLocator([3e17, 6e17, 1e18, 3e18, 6e18, 1e19, 3e19])\n",
    "cbar.ax.yaxis.set_minor_locator(minor_locator)\n",
    "\n",
    "# Hide labels for minor ticks\n",
    "cbar.ax.yaxis.set_minor_formatter(ticker.NullFormatter())\n",
    "\n",
    "# Tick appearance lightgray ticks, black labels\n",
    "cbar.ax.tick_params(axis='y', which='both', color='lightgray', labelcolor='black', size=1.5, width=0.4, pad=1)\n",
    "\n",
    "# Align first label bottom, last label top\n",
    "yticklabels = cbar.ax.get_yticklabels()\n",
    "yticklabels[0].set_verticalalignment('bottom')\n",
    "yticklabels[-1].set_verticalalignment('top')\n",
    "\n",
    "\n",
    "# Style the colorbar\n",
    "cbar.ax.tick_params(direction='out')\n",
    "cbar.outline.set_visible(False)\n",
    "\n",
    "# Plot 2: Compute vs Parameters\n",
    "ax = axes[1]\n",
    "x1, y1 = compute_vs_params[:,0], compute_vs_params[:,1]\n",
    "\n",
    "n_fit = 4\n",
    "logx = np.log10(x1[:n_fit])\n",
    "logy = np.log10(y1[:n_fit])\n",
    "slope, intercept = np.polyfit(logx, logy, 1)\n",
    "\n",
    "x_break = x1[n_fit]\n",
    "y_break = y1[n_fit]\n",
    "\n",
    "x_hit = 10 ** ((np.log10(y_break) - intercept) / slope)\n",
    "\n",
    "x_slope = np.logspace(np.log10(3e16), np.log10(x_hit), 200)\n",
    "\n",
    "y_slope = 10**(intercept + slope * np.log10(x_slope))\n",
    "\n",
    "x_plateau = np.logspace(np.log10(x_hit), np.log10(2e20), 200)\n",
    "y_plateau = np.full_like(x_plateau, y_break)\n",
    "\n",
    "ax.plot(x_slope, y_slope, '--', color='#6699CC', linewidth=0.5)\n",
    "ax.plot(x_plateau, y_plateau, '--', color='#6699CC', linewidth=0.5)\n",
    "\n",
    "ax.loglog(x1, y1, 'o', color='black', markersize=2)\n",
    "ax.set_xticks([1e17, 3e18, 1e20])\n",
    "ax.set_xticklabels(['3e17', '3e18', '1e20'])\n",
    "\n",
    "\n",
    "# For x-axis minor ticks\n",
    "\n",
    "ax.set_yticks([3_000_000, 10_000_000, 20_000_000, 38_000_000])\n",
    "ax.set_yticklabels(['3M', '10M', '20M', '38M'])\n",
    "\n",
    "\n",
    "ax.yaxis.set_minor_locator(plt.NullLocator())\n",
    "\n",
    "ax.set_xlabel(\"FLOPs\")\n",
    "ax.set_ylabel(\"Parameters\")\n",
    "ax.tick_params(axis='both', which='major')\n",
    "ax.xaxis.set_minor_locator(LogLocator(base=10.0, subs=[2, 5], numticks=100))\n",
    "ax.xaxis.set_minor_formatter(ticker.NullFormatter())\n",
    "ax.grid(True, which='both', ls='--', lw=0.3)\n",
    "\n",
    "ax.set_xlim([3e16, 3e20])\n",
    "\n",
    "\n",
    "# Plot 3: Compute vs Tokens \n",
    "ax = axes[2]\n",
    "x2, y2 = flops_vs_tokens[:,0], flops_vs_tokens[:,1]\n",
    "\n",
    "ax.loglog(x2, y2, marker='o', linestyle='none', color='black', markersize=2)\n",
    "\n",
    "slope, intercept = np.polyfit(np.log10(x2), np.log10(y2), 1)\n",
    "x_fit = np.logspace(np.log10(min(x2)) - 0.5, np.log10(max(x2)) + 0.5, 100)\n",
    "y_fit = 10**(slope * np.log10(x_fit) + intercept)\n",
    "ax.plot(x_fit, y_fit, linestyle='--', color='#6699CC', linewidth=0.5)\n",
    "\n",
    "\n",
    "ax.yaxis.set_minor_locator(plt.NullLocator())\n",
    "\n",
    "\n",
    "ax.set_yticks([1e9, 10e9, 100e9, 440e9])\n",
    "ax.set_yticklabels(['1B', '10B', '100B', '440B'])\n",
    "ax.set_xticks([1e17, 3e18, 1e20])\n",
    "ax.set_xticklabels(['3e17', '3e18', '1e20'])\n",
    "\n",
    "\n",
    "ax.set_xlabel(\"FLOPs\")\n",
    "ax.set_ylabel(\"Tokens\", labelpad=1)\n",
    "ax.tick_params(axis='both', which='major')\n",
    "ax.grid(True, which=\"both\", ls=\"--\", linewidth=0.3)\n",
    "ax.xaxis.set_minor_locator(LogLocator(base=10.0, subs=[2, 5], numticks=100))\n",
    "ax.xaxis.set_minor_formatter(ticker.NullFormatter())\n",
    "\n",
    "for ax in axes:\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_color('lightgray')  # Light gray frame\n",
    "\n",
    "    # Make only the tick linesgray, but leave labels black\n",
    "    ax.tick_params(axis='both', which='both', color='lightgray', labelcolor='black')\n",
    "\n",
    "ax.tick_params(axis='both', which='both', direction='inout', length=0)  # set length=0 to hide tick lines\n",
    "\n",
    "ax.set_xlim([3e16, 3e20])\n",
    "\n",
    "\n",
    "plt.tight_layout(w_pad=0.0)\n",
    "plt.savefig('plots/scaling_laws.pdf', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "treconlm",
   "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.5"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
