{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "d1475818",
   "metadata": {},
   "source": [
    "# Paper figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "879c5fc9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Recommend (Ubuntu):\n",
      "  sudo apt-get install cm-super dvipng fonts-cmu texlive-latex-extra\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from torch import Tensor\n",
    "from typing import Any\n",
    "import math\n",
    "\n",
    "import qkernels\n",
    "import plot_utils\n",
    "\n",
    "plot_utils.configure()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0eae7ffc",
   "metadata": {},
   "source": [
    "## Theoretical"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "18f56595",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L40S hardware intensity 419 flops/byte\n",
      "m=400, k=n=large operational intensity 400.0\n",
      "m=400, k=n=8192 compute_time 0.15 ms, transfer_time 0.17 ms\n"
     ]
    }
   ],
   "source": [
    "l40s_bw = 864e9\n",
    "l40s_bf16_flops = 362e12\n",
    "print(f\"L40S hardware intensity {l40s_bf16_flops/ l40s_bw:.0f} flops/byte\")\n",
    "print(\"m=400, k=n=large operational intensity\", 1/(1/400) * (2/2))\n",
    "print(f\"m=400, k=n=8192 compute_time {2*400*8192*8192/l40s_bf16_flops*1000:.2f} ms, transfer_time {(400*8192 + 8192*8192 + 400*8192)*2/l40s_bw*1000:.2f} ms\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "10545aa7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "P_w = 16, m_critical = 418, peak speedup = 1.0\n",
      "P_w = 4.25, m_critical = 111, peak speedup = 3.8\n",
      "P_w = 1.25, m_critical = 32, peak speedup = 12.8\n"
     ]
    }
   ],
   "source": [
    "def l40s_critical_m(P_w: float) -> float:\n",
    "    return (P_w / 16) * (l40s_bf16_flops / l40s_bw)\n",
    "for P_w in [16, 4.25, 1.25]:\n",
    "    print(f\"P_w = {P_w}, m_critical = {math.floor(l40s_critical_m(P_w)):.0f}, peak speedup = {16/P_w:.1f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "f7865be1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "remote: Updating references: 100% (1/1)           \n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 550x225 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def l40_speedup_ratio(P_w1: float, P_w2: float, m: Tensor) -> Tensor:\n",
    "    one = torch.tensor(1.0)\n",
    "    return (torch.maximum(one, (P_w1 / (16*m)) * (l40s_bf16_flops / l40s_bw))\n",
    "            / torch.maximum(one, (P_w2 / (16*m)) * (l40s_bf16_flops / l40s_bw)))\n",
    "\n",
    "_, ax = plt.subplots(figsize=(5.5, 2.25))\n",
    "m = torch.arange(1, 4099)\n",
    "ax.plot(m, l40_speedup_ratio(16, 4.25, m), label=r\"$4.25$ bits\")\n",
    "ax.plot(m, l40_speedup_ratio(16, 1.25, m), label=r\"$1.25$ bits\")\n",
    "ax.set_yticks(torch.arange(2, 14, 2))\n",
    "ax.axhline(y=1, color=\"#888888\", ls=\"--\", lw=1, zorder=-1)\n",
    "for speedup in [1, 3.8, 12.8]:\n",
    "    ax.annotate(f\"${speedup}\\\\times$\", xy=(1, speedup), xytext=(4, 5), textcoords=\"offset points\", fontsize=10)\n",
    "ax.legend(title=\"$P_{w2}$\", fontsize=12, title_fontsize=12)\n",
    "ax.set_xlabel(\"Batch size $m$\")\n",
    "ax.set_ylabel(r\"Speedup $t_1 / t_2$\")\n",
    "ax.set_xscale(\"log\", base=2)\n",
    "ax.set_yscale(\"log\")\n",
    "ax.set_xticks(2**torch.arange(0, 13, 2))\n",
    "ax.set_xlim((1, m.max()))\n",
    "ax.xaxis.set_major_formatter(\"{x:.0f}\")\n",
    "ax.yaxis.set_major_formatter(\"{x:.0f}\")\n",
    "\n",
    "plot_utils.tidy(ax.figure)\n",
    "plot_utils.save(\"perf_theoretical\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4553904d",
   "metadata": {},
   "source": [
    "## `code/dequant_matmul.py`, `code/dequant_matmul_defer_scale.py`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "09b22e6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "On branch master\n",
      "Your branch is up to date with 'origin/master'.\n",
      "\n",
      "nothing to commit, working tree clean\n",
      "Error running \"git -C /home/ubuntu/FusedDequantisationKernels/notebooks/paper commit -m 'Update figures' --quiet\" -- aborting\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "remote: Updating references: 100% (1/1)           \n"
     ]
    }
   ],
   "source": [
    "def dequant_matmul() -> Any:\n",
    "    def dequant_matmul(x, Wq, Wscale, lut8):\n",
    "        \"\"\"\n",
    "        x      :: batch_size x input_size x bf16\n",
    "        Wq     :: output_size x (input_size//elements_per_byte) x uint8\n",
    "        Wscale :: output_size x (input_size//block_size) x bf16\n",
    "        lut8   :: 256 x elements_per_byte x bf16\n",
    "        return :: batch_size x output_size x bf16\n",
    "        \"\"\"\n",
    "        Wu = lut8[Wq.long()].flatten(start_dim=1)\n",
    "        B = Wu.shape[1] // Wscale.shape[1]\n",
    "        W = Wu.view(*Wscale.shape, B).mul(Wscale.unsqueeze(2)).flatten(start_dim=1)\n",
    "        return x @ W.T\n",
    "    return dequant_matmul  # IGNORE\n",
    "\n",
    "def dequant_matmul_defer_scale() -> Any:\n",
    "    def dequant_matmul_defer_scale(x, Wq, Wscale, lut8):\n",
    "        Wu = lut8[Wq.long()].flatten(start_dim=1)\n",
    "        B = Wu.shape[1] // Wscale.shape[1]\n",
    "        z = torch.einsum(\"mGg,hGg->mhG\", x.unflatten(1, (-1, B)), Wu.unflatten(1, (-1, B)))\n",
    "        return torch.einsum(\"mhG,hG->mh\", z, Wscale)\n",
    "    return dequant_matmul_defer_scale  # IGNORE\n",
    "\n",
    "def test_dequant_matmul():\n",
    "    torch.manual_seed(0)\n",
    "    x = torch.randn(5, 32, device=\"cuda\")\n",
    "    Wq = torch.randint(0, 256, (70, 32//2), device=\"cuda\", dtype=torch.uint8)\n",
    "    Wscale = torch.randn((70, 8), device=\"cuda\")\n",
    "    lut8 = torch.randn((256, 2), device=\"cuda\")\n",
    "    ref = torch.compiler.disable(qkernels.mm_lut_ref)(x, Wq, lut8, Wscale)\n",
    "    out = dequant_matmul()(x, Wq, Wscale, lut8)\n",
    "    torch.testing.assert_close(ref, out)\n",
    "    out_defer = dequant_matmul_defer_scale()(x, Wq, Wscale, lut8)\n",
    "    torch.testing.assert_close(ref, out_defer)\n",
    "    # torch.testing.assert_close(out, out_defer, atol=0, rtol=0)  # not an exact match (expected!)\n",
    "\n",
    "test_dequant_matmul()\n",
    "\n",
    "plot_utils.save_code(dequant_matmul)\n",
    "plot_utils.save_code(dequant_matmul_defer_scale)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "43620dde",
   "metadata": {},
   "source": [
    "# Micro-benchmarks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "67f53340",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "device NVIDIA L40S\n",
      "torch_version 2.9.1+cu128\n",
      "cuda_version 12.8\n",
      "triton_version 3.5.1\n",
      "reps 100 x 100\n",
      "\n",
      "m [  1   4  16  64 256]\n",
      "k [8192 6144 4096 3072]\n",
      "element_bits [16  8  4  2  1]\n",
      "impl ['Torch' 'Triton' 'torch.compile:unscaled' 'torch.compile' 'Marlin']\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>m</th>\n",
       "      <th>k</th>\n",
       "      <th>element_bits</th>\n",
       "      <th>bytes_rw</th>\n",
       "      <th>ops</th>\n",
       "      <th>avg_time</th>\n",
       "      <th>avg_time_stderr</th>\n",
       "      <th>gb_s</th>\n",
       "      <th>tflops</th>\n",
       "      <th>tflops_stderr</th>\n",
       "      <th>avg_bits</th>\n",
       "      <th>impl</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8192</td>\n",
       "      <td>16</td>\n",
       "      <td>134250496</td>\n",
       "      <td>134217728</td>\n",
       "      <td>0.000182</td>\n",
       "      <td>2.073154e-08</td>\n",
       "      <td>739.281668</td>\n",
       "      <td>0.739101</td>\n",
       "      <td>0.000084</td>\n",
       "      <td>16.00</td>\n",
       "      <td>Torch</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>8192</td>\n",
       "      <td>16</td>\n",
       "      <td>134250496</td>\n",
       "      <td>134217728</td>\n",
       "      <td>0.000176</td>\n",
       "      <td>1.946425e-08</td>\n",
       "      <td>764.350473</td>\n",
       "      <td>0.764164</td>\n",
       "      <td>0.000085</td>\n",
       "      <td>16.00</td>\n",
       "      <td>Triton</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>8192</td>\n",
       "      <td>8</td>\n",
       "      <td>69238784</td>\n",
       "      <td>134217728</td>\n",
       "      <td>0.000090</td>\n",
       "      <td>2.303511e-09</td>\n",
       "      <td>769.148813</td>\n",
       "      <td>1.490977</td>\n",
       "      <td>0.000038</td>\n",
       "      <td>8.25</td>\n",
       "      <td>torch.compile:unscaled</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1</td>\n",
       "      <td>8192</td>\n",
       "      <td>8</td>\n",
       "      <td>69238784</td>\n",
       "      <td>134217728</td>\n",
       "      <td>0.000283</td>\n",
       "      <td>3.898155e-07</td>\n",
       "      <td>244.655836</td>\n",
       "      <td>0.474259</td>\n",
       "      <td>0.000653</td>\n",
       "      <td>8.25</td>\n",
       "      <td>torch.compile</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1</td>\n",
       "      <td>8192</td>\n",
       "      <td>8</td>\n",
       "      <td>69238784</td>\n",
       "      <td>134217728</td>\n",
       "      <td>0.000096</td>\n",
       "      <td>1.730201e-08</td>\n",
       "      <td>723.931694</td>\n",
       "      <td>1.403324</td>\n",
       "      <td>0.000254</td>\n",
       "      <td>8.25</td>\n",
       "      <td>Triton</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   m     k  element_bits   bytes_rw        ops  avg_time  avg_time_stderr  \\\n",
       "0  1  8192            16  134250496  134217728  0.000182     2.073154e-08   \n",
       "1  1  8192            16  134250496  134217728  0.000176     1.946425e-08   \n",
       "4  1  8192             8   69238784  134217728  0.000090     2.303511e-09   \n",
       "5  1  8192             8   69238784  134217728  0.000283     3.898155e-07   \n",
       "6  1  8192             8   69238784  134217728  0.000096     1.730201e-08   \n",
       "\n",
       "         gb_s    tflops  tflops_stderr  avg_bits                    impl  \n",
       "0  739.281668  0.739101       0.000084     16.00                   Torch  \n",
       "1  764.350473  0.764164       0.000085     16.00                  Triton  \n",
       "4  769.148813  1.490977       0.000038      8.25  torch.compile:unscaled  \n",
       "5  244.655836  0.474259       0.000653      8.25           torch.compile  \n",
       "6  723.931694  1.403324       0.000254      8.25                  Triton  "
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_json(\"../out/l40s-py-2026-01-17T22-56-28.jsonl\", lines=True)\n",
    "\n",
    "print(\"device\", *df.device.unique())\n",
    "print(\"torch_version\", *df.torch_version.unique())\n",
    "print(\"cuda_version\", *df.cuda_version.unique())\n",
    "print(\"triton_version\", *df.triton_version.unique())\n",
    "print(\"reps\", *df.outer_reps.unique(), \"x\", *df.inner_reps.unique())\n",
    "print()\n",
    "\n",
    "df = df.drop(columns=[\n",
    "    \"n\", \"g\", \"copies\", \"inner_reps\", \"outer_reps\",\n",
    "    \"id\", \"device\", \"cuda_version\", \"torch_version\", \"triton_version\", \"commit\",\n",
    "])\n",
    "df = df.rename(columns=dict(bits=\"element_bits\"))\n",
    "\n",
    "df[\"gb_s\"] = df[\"bytes_rw\"] / df[\"avg_time\"] / 1e9\n",
    "df[\"tflops\"] = df[\"ops\"] / df[\"avg_time\"] / 1e12\n",
    "df[\"tflops_stderr\"] = df[\"ops\"] * df[\"avg_time_stderr\"] / df[\"avg_time\"]**2 / 1e12\n",
    "df[\"avg_bits\"] = df[\"element_bits\"].apply(lambda b: b + 0.25*(b < 16))\n",
    "\n",
    "# Remove \"mm\" tests where \"mv\" was also run, for batch size 1\n",
    "df = df[~((df.m == 1) & df.test.isin([\"mm\", \"mm_ref\", \"mm_lut8_ref_unscaled\", \"mm_lut8_ref\", \"mm_lut8\"]))]\n",
    "\n",
    "# Rename test -> impl\n",
    "df = df.pipe(\n",
    "    lambda d: d.assign(impl=d.test.apply(dict(\n",
    "        mm=\"Triton\", mv=\"Triton\",\n",
    "        mm_ref=\"Torch\", mv_ref=\"Torch\",\n",
    "        mm_lut8_ref_unscaled=\"torch.compile:unscaled\", mv_lut8_ref_unscaled=\"torch.compile:unscaled\",\n",
    "        mv_lut8_ref=\"torch.compile\", mm_lut8_ref=\"torch.compile\",\n",
    "        mv_lut8=\"Triton\", mm_lut8=\"Triton\",\n",
    "        marlin=\"Marlin\",\n",
    "    ).__getitem__))\n",
    ").drop(columns=[\"test\"])\n",
    "assert df.groupby([\"m\", \"k\", \"element_bits\", \"impl\"]).avg_time.count().max() == 1, \"duplicate entries with same impl name\"\n",
    "\n",
    "\n",
    "for k in  [\"m\", \"k\", \"element_bits\", \"impl\"]:\n",
    "    print(k, df[k].unique())\n",
    "\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b8e66aea",
   "metadata": {},
   "source": [
    "## `perf_micro_m_k_bits_impl`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4931af7d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative 2*stderr mean 0.002302992657486617\n",
      "Relative 2*stderr max 0.01174619574004101\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 938.177x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = (df\n",
    "    .pipe(lambda d: d[~d.impl.isin([\"torch.compile\", \"torch.compile:unscaled\"])])\n",
    "    .pipe(lambda d: d[d.element_bits.isin([1, 4, 16])])\n",
    "    .pipe(lambda d: d[d.m.isin([1, 16, 256])])\n",
    ")\n",
    "\n",
    "print(\"Relative 2*stderr mean\", 2 * (d.tflops_stderr / d.tflops).mean())\n",
    "print(\"Relative 2*stderr max\", 2 * (d.tflops_stderr / d.tflops).max())\n",
    "\n",
    "g = sns.relplot(\n",
    "    data=d,\n",
    "    y=\"tflops\", x=\"k\", col=\"m\",\n",
    "    style=\"impl\", style_order=[\"Triton\", \"Marlin\", \"Torch\"],\n",
    "    hue=\"avg_bits\", hue_norm=matplotlib.colors.LogNorm(), palette=plot_utils.SEQ_PALETTE,\n",
    "    kind=\"line\", markers=True, height=3, aspect=0.9, mew=0,\n",
    ")\n",
    "for ax in g.axes.flatten():\n",
    "    ax.set_xscale(\"log\", base=2)\n",
    "    ax.xaxis.set_major_formatter(\"{x:.0f}\")\n",
    "    ax.set_xticks([3072, 4096, 6144, 8192])\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.yaxis.set_major_formatter(\"{x:.0f}\")\n",
    "\n",
    "for m, ax in g.axes_dict.items():\n",
    "    ax.set_title(f\"$m={m}$\")\n",
    "g.figure.legend(\n",
    "    handles=g.legend.legend_handles,\n",
    "    labels=[text.get_text() for text in g.legend.get_texts()],\n",
    "    loc=\"center left\",\n",
    "    bbox_to_anchor=(1, 0.5),\n",
    ")\n",
    "g.legend.remove()\n",
    "\n",
    "plot_utils.tidy(g.figure)\n",
    "plot_utils.save(\"perf_micro_m_k_bits_impl\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "863ee789",
   "metadata": {},
   "source": [
    "## `tables/perf_micro_m1_impl`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "b405a4dc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_34f31\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th id=\"T_34f31_level0_col0\" class=\"col_heading level0 col0\" >avg_bits</th>\n",
       "      <th id=\"T_34f31_level0_col1\" class=\"col_heading level0 col1\" >impl</th>\n",
       "      <th id=\"T_34f31_level0_col2\" class=\"col_heading level0 col2\" >avg_time</th>\n",
       "      <th id=\"T_34f31_level0_col3\" class=\"col_heading level0 col3\" >avg_time_stderr</th>\n",
       "      <th id=\"T_34f31_level0_col4\" class=\"col_heading level0 col4\" >speedup_ratio</th>\n",
       "      <th id=\"T_34f31_level0_col5\" class=\"col_heading level0 col5\" >theoretical_speedup_ratio</th>\n",
       "      <th id=\"T_34f31_level0_col6\" class=\"col_heading level0 col6\" >gb_s</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row0_col0\" class=\"data row0 col0\" >16.000000</td>\n",
       "      <td id=\"T_34f31_row0_col1\" class=\"data row0 col1\" >Torch</td>\n",
       "      <td id=\"T_34f31_row0_col2\" class=\"data row0 col2\" >181.6 us</td>\n",
       "      <td id=\"T_34f31_row0_col3\" class=\"data row0 col3\" >2.1e-08</td>\n",
       "      <td id=\"T_34f31_row0_col4\" class=\"data row0 col4\" >1.000000</td>\n",
       "      <td id=\"T_34f31_row0_col5\" class=\"data row0 col5\" >1.000000</td>\n",
       "      <td id=\"T_34f31_row0_col6\" class=\"data row0 col6\" >739 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row1_col0\" class=\"data row1 col0\" >16.000000</td>\n",
       "      <td id=\"T_34f31_row1_col1\" class=\"data row1 col1\" >Triton</td>\n",
       "      <td id=\"T_34f31_row1_col2\" class=\"data row1 col2\" >175.6 us</td>\n",
       "      <td id=\"T_34f31_row1_col3\" class=\"data row1 col3\" >1.9e-08</td>\n",
       "      <td id=\"T_34f31_row1_col4\" class=\"data row1 col4\" >1.033910</td>\n",
       "      <td id=\"T_34f31_row1_col5\" class=\"data row1 col5\" >1.000000</td>\n",
       "      <td id=\"T_34f31_row1_col6\" class=\"data row1 col6\" >764 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row2_col0\" class=\"data row2 col0\" >4.250000</td>\n",
       "      <td id=\"T_34f31_row2_col1\" class=\"data row2 col1\" >torch.compile</td>\n",
       "      <td id=\"T_34f31_row2_col2\" class=\"data row2 col2\" >772.3 us</td>\n",
       "      <td id=\"T_34f31_row2_col3\" class=\"data row2 col3\" >5.7e-07</td>\n",
       "      <td id=\"T_34f31_row2_col4\" class=\"data row2 col4\" >0.235145</td>\n",
       "      <td id=\"T_34f31_row2_col5\" class=\"data row2 col5\" >3.762167</td>\n",
       "      <td id=\"T_34f31_row2_col6\" class=\"data row2 col6\" >46 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row3_col0\" class=\"data row3 col0\" >4.250000</td>\n",
       "      <td id=\"T_34f31_row3_col1\" class=\"data row3 col1\" >Marlin</td>\n",
       "      <td id=\"T_34f31_row3_col2\" class=\"data row3 col2\" >53.5 us</td>\n",
       "      <td id=\"T_34f31_row3_col3\" class=\"data row3 col3\" >3.2e-08</td>\n",
       "      <td id=\"T_34f31_row3_col4\" class=\"data row3 col4\" >3.391979</td>\n",
       "      <td id=\"T_34f31_row3_col5\" class=\"data row3 col5\" >3.762167</td>\n",
       "      <td id=\"T_34f31_row3_col6\" class=\"data row3 col6\" >667 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row4_col0\" class=\"data row4 col0\" >4.250000</td>\n",
       "      <td id=\"T_34f31_row4_col1\" class=\"data row4 col1\" >Triton</td>\n",
       "      <td id=\"T_34f31_row4_col2\" class=\"data row4 col2\" >49.5 us</td>\n",
       "      <td id=\"T_34f31_row4_col3\" class=\"data row4 col3\" >8.0e-09</td>\n",
       "      <td id=\"T_34f31_row4_col4\" class=\"data row4 col4\" >3.666746</td>\n",
       "      <td id=\"T_34f31_row4_col5\" class=\"data row4 col5\" >3.762167</td>\n",
       "      <td id=\"T_34f31_row4_col6\" class=\"data row4 col6\" >721 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row5_col0\" class=\"data row5 col0\" >1.250000</td>\n",
       "      <td id=\"T_34f31_row5_col1\" class=\"data row5 col1\" >torch.compile</td>\n",
       "      <td id=\"T_34f31_row5_col2\" class=\"data row5 col2\" >770.4 us</td>\n",
       "      <td id=\"T_34f31_row5_col3\" class=\"data row5 col3\" >3.3e-07</td>\n",
       "      <td id=\"T_34f31_row5_col4\" class=\"data row5 col4\" >0.235719</td>\n",
       "      <td id=\"T_34f31_row5_col5\" class=\"data row5 col5\" >12.763240</td>\n",
       "      <td id=\"T_34f31_row5_col6\" class=\"data row5 col6\" >14 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td id=\"T_34f31_row6_col0\" class=\"data row6 col0\" >1.250000</td>\n",
       "      <td id=\"T_34f31_row6_col1\" class=\"data row6 col1\" >Triton</td>\n",
       "      <td id=\"T_34f31_row6_col2\" class=\"data row6 col2\" >24.0 us</td>\n",
       "      <td id=\"T_34f31_row6_col3\" class=\"data row6 col3\" >1.4e-07</td>\n",
       "      <td id=\"T_34f31_row6_col4\" class=\"data row6 col4\" >7.563547</td>\n",
       "      <td id=\"T_34f31_row6_col5\" class=\"data row6 col5\" >12.763240</td>\n",
       "      <td id=\"T_34f31_row6_col6\" class=\"data row6 col6\" >438 GB/s</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x753dd14e9bd0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrr} \\toprule\n",
      "  $P_w$ & Implementation & Time (Speedup) & Effective Bandwidth \\\\\\midrule\n",
      "  $16$ & Torch & $181.6\\,\\mathrm{\\upmu s}$ ($1.0\\times$) & $739\\,\\mathrm{GB/s}$ \\\\\n",
      "  $16$ & Triton & $175.6\\,\\mathrm{\\upmu s}$ ($1.0\\times$) & $764\\,\\mathrm{GB/s}$ \\\\\n",
      "  $4.25$ & torch.compile & $772.3\\,\\mathrm{\\upmu s}$ ($0.2\\times$) & $46\\,\\mathrm{GB/s}$ \\\\\n",
      "  $4.25$ & Marlin & $53.5\\,\\mathrm{\\upmu s}$ ($3.4\\times$) & $667\\,\\mathrm{GB/s}$ \\\\\n",
      "  $4.25$ & Triton & $49.5\\,\\mathrm{\\upmu s}$ ($3.7\\times$) & $721\\,\\mathrm{GB/s}$ \\\\\n",
      "  $1.25$ & torch.compile & $770.4\\,\\mathrm{\\upmu s}$ ($0.2\\times$) & $14\\,\\mathrm{GB/s}$ \\\\\n",
      "  $1.25$ & Triton & $24.0\\,\\mathrm{\\upmu s}$ ($7.6\\times$) & $438\\,\\mathrm{GB/s}$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "remote: Updating references: 100% (1/1)           \n"
     ]
    }
   ],
   "source": [
    "d = (df\n",
    "    .pipe(lambda d: d[~d.impl.isin([\"torch.compile:unscaled\"])])\n",
    "    .pipe(lambda d: d[d.element_bits.isin([1, 4, 16])])\n",
    "    .pipe(lambda d: d[d.m == 1])\n",
    "    .pipe(lambda d: d[d.k == 8192])\n",
    "    .pipe(lambda d: d.assign(speedup_ratio=lambda d: d[d.impl==\"Torch\"].iloc[0].avg_time / d.avg_time))\n",
    "    .pipe(lambda d: d.assign(theoretical_speedup_ratio=lambda d: d[d.impl==\"Torch\"].iloc[0].bytes_rw / d.bytes_rw))\n",
    "    .pipe(lambda d: d.assign(avg_time_str=d.apply(lambda s: f\"${s.avg_time*1e6:.1f}\\\\,\\\\mathrm{{\\\\upmu s}}$ (${s.speedup_ratio:.1f}\\\\times$)\", axis=1)))\n",
    "    .pipe(lambda d: d.assign(gb_s_str=d.gb_s.apply(lambda x: f\"${x:.0f}\\\\,\\\\mathrm{{GB/s}}$\")))\n",
    "    .pipe(lambda d: d.assign(avg_time_stderr_str=d.avg_time_stderr.apply(lambda s: f\"${s*1e6:.2f}\\\\,\\\\mathrm{{\\\\upmu s}}$\")))\n",
    "    .sort_values([\"avg_bits\", \"avg_time\"], ascending=False)\n",
    ")\n",
    "\n",
    "display(d[[\"avg_bits\", \"impl\", \"avg_time\", \"avg_time_stderr\", \"speedup_ratio\", \"theoretical_speedup_ratio\", \"gb_s\"]]\n",
    "    .style.format(dict(avg_time=lambda x: f\"{x*1e6:.1f} us\", gb_s=\"{:.0f} GB/s\", avg_time_stderr=\"{:.1e}\")).hide())\n",
    "\n",
    "cols = dict(avg_bits=\"\", impl=\"\", avg_time_str=\"Time (Speedup)\", gb_s_str=\"Effective Bandwidth\")\n",
    "align = \"llrr\"\n",
    "print(plot_utils.fmt_latex_booktabs(d, cols=cols, align=align))\n",
    "plot_utils.save_table(\"perf_micro_m1_impl\", d, cols=cols, align=align)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67c7bba9",
   "metadata": {},
   "source": [
    "# Model benchmarks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "10d866ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch_version 2.9.1+cu128\n",
      "cuda_version 12.8\n",
      "triton_version 3.5.1\n",
      "device NVIDIA L40S\n",
      "reps 100\n",
      "block_size nan 64.0\n",
      "\n",
      "Dropping 5 runs with errors\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>batch_size</th>\n",
       "      <th>parameters</th>\n",
       "      <th>bytes_rw</th>\n",
       "      <th>ops</th>\n",
       "      <th>avg_time</th>\n",
       "      <th>avg_time_stderr</th>\n",
       "      <th>element_bits</th>\n",
       "      <th>skip</th>\n",
       "      <th>impl</th>\n",
       "      <th>avg_bits</th>\n",
       "      <th>tokens_s</th>\n",
       "      <th>tokens_s_stderr</th>\n",
       "      <th>gb_s</th>\n",
       "      <th>tflops</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4B</td>\n",
       "      <td>1</td>\n",
       "      <td>3.883552e+09</td>\n",
       "      <td>6.979099e+09</td>\n",
       "      <td>7.767103e+09</td>\n",
       "      <td>0.011257</td>\n",
       "      <td>2.453627e-07</td>\n",
       "      <td>16</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Torch</td>\n",
       "      <td>16.00</td>\n",
       "      <td>88.837412</td>\n",
       "      <td>0.001936</td>\n",
       "      <td>620.005062</td>\n",
       "      <td>0.690009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>4B</td>\n",
       "      <td>1</td>\n",
       "      <td>3.883552e+09</td>\n",
       "      <td>2.432735e+09</td>\n",
       "      <td>7.767103e+09</td>\n",
       "      <td>0.005260</td>\n",
       "      <td>2.127769e-07</td>\n",
       "      <td>4</td>\n",
       "      <td>^lm_head$</td>\n",
       "      <td>Triton</td>\n",
       "      <td>4.25</td>\n",
       "      <td>190.100723</td>\n",
       "      <td>0.007689</td>\n",
       "      <td>462.464725</td>\n",
       "      <td>1.476532</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4B</td>\n",
       "      <td>1</td>\n",
       "      <td>3.883552e+09</td>\n",
       "      <td>2.432735e+09</td>\n",
       "      <td>7.767103e+09</td>\n",
       "      <td>0.006600</td>\n",
       "      <td>3.088614e-07</td>\n",
       "      <td>4</td>\n",
       "      <td>^lm_head$</td>\n",
       "      <td>Marlin</td>\n",
       "      <td>4.25</td>\n",
       "      <td>151.521331</td>\n",
       "      <td>0.007091</td>\n",
       "      <td>368.611281</td>\n",
       "      <td>1.176882</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4B</td>\n",
       "      <td>1</td>\n",
       "      <td>3.883552e+09</td>\n",
       "      <td>2.432735e+09</td>\n",
       "      <td>7.767103e+09</td>\n",
       "      <td>0.006404</td>\n",
       "      <td>2.966344e-07</td>\n",
       "      <td>4</td>\n",
       "      <td>^lm_head$</td>\n",
       "      <td>Marlin (Linear)</td>\n",
       "      <td>4.25</td>\n",
       "      <td>156.151749</td>\n",
       "      <td>0.007233</td>\n",
       "      <td>379.875862</td>\n",
       "      <td>1.212847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4B</td>\n",
       "      <td>1</td>\n",
       "      <td>3.883552e+09</td>\n",
       "      <td>2.432735e+09</td>\n",
       "      <td>7.767103e+09</td>\n",
       "      <td>0.006666</td>\n",
       "      <td>2.674960e-07</td>\n",
       "      <td>4</td>\n",
       "      <td>^lm_head$</td>\n",
       "      <td>torch.compile</td>\n",
       "      <td>4.25</td>\n",
       "      <td>150.004711</td>\n",
       "      <td>0.006019</td>\n",
       "      <td>364.921746</td>\n",
       "      <td>1.165102</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  model  batch_size    parameters      bytes_rw           ops  avg_time  \\\n",
       "0    4B           1  3.883552e+09  6.979099e+09  7.767103e+09  0.011257   \n",
       "1    4B           1  3.883552e+09  2.432735e+09  7.767103e+09  0.005260   \n",
       "2    4B           1  3.883552e+09  2.432735e+09  7.767103e+09  0.006600   \n",
       "3    4B           1  3.883552e+09  2.432735e+09  7.767103e+09  0.006404   \n",
       "4    4B           1  3.883552e+09  2.432735e+09  7.767103e+09  0.006666   \n",
       "\n",
       "   avg_time_stderr  element_bits       skip             impl  avg_bits  \\\n",
       "0     2.453627e-07            16        NaN            Torch     16.00   \n",
       "1     2.127769e-07             4  ^lm_head$           Triton      4.25   \n",
       "2     3.088614e-07             4  ^lm_head$           Marlin      4.25   \n",
       "3     2.966344e-07             4  ^lm_head$  Marlin (Linear)      4.25   \n",
       "4     2.674960e-07             4  ^lm_head$    torch.compile      4.25   \n",
       "\n",
       "     tokens_s  tokens_s_stderr        gb_s    tflops  \n",
       "0   88.837412         0.001936  620.005062  0.690009  \n",
       "1  190.100723         0.007689  462.464725  1.476532  \n",
       "2  151.521331         0.007091  368.611281  1.176882  \n",
       "3  156.151749         0.007233  379.875862  1.212847  \n",
       "4  150.004711         0.006019  364.921746  1.165102  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# df = pd.read_json(\"../out/l40s-models-2026-01-20T14-17-30.jsonl\", lines=True)\n",
    "df = pd.read_json(\"../out/l40s-models-2026-01-28T22-37-52.jsonl\", lines=True)\n",
    "\n",
    "print(\"torch_version\", *df.torch_version.unique())\n",
    "print(\"cuda_version\", *df.cuda_version.unique())\n",
    "print(\"triton_version\", *df.triton_version.unique())\n",
    "print(\"device\", *df.device.unique())\n",
    "print(\"reps\", *df.reps.unique())\n",
    "print(\"block_size\", *df.block_size.unique())\n",
    "print()\n",
    "# assert len(df.commit.unique()) == 1\n",
    "assert all(df.model.apply(lambda s: s.startswith(\"custom-llama-\")))\n",
    "\n",
    "df = df.drop(columns=[\n",
    "    \"reps\", \"id\", \"device\", \"cuda_version\", \"torch_version\", \"triton_version\", \"block_size\",\n",
    "    \"output\", \"commit\",\n",
    "])\n",
    "df[\"model\"] = df[\"model\"].apply(lambda s: s.replace(\"custom-llama-\", \"\"))\n",
    "df = df.rename(columns=dict(bits=\"element_bits\"))\n",
    "print(\"Dropping\", sum(~df.error.isna()), \"runs with errors\")\n",
    "df = df[df.error.isna()].drop(columns=[\"error\"])\n",
    "df[\"impl\"] = df[\"kernel\"].fillna(\"torch\").apply(lambda k: {\n",
    "    \"marlin\": \"Marlin (Linear)\", \"marlin-lut\": \"Marlin\",\n",
    "    \"torch\": \"Torch\", \"triton\": \"Triton\", \"torch.compile\": \"torch.compile\",\n",
    "}[k])\n",
    "df = df.drop(columns=[\"kernel\"])\n",
    "df[\"element_bits\"] = df[\"element_bits\"].fillna(16).astype(int)\n",
    "df[\"avg_bits\"] = df[\"element_bits\"].apply(lambda b: b + 0.25*(b < 16))\n",
    "\n",
    "df[\"tokens_s\"] = df[\"batch_size\"] / df[\"avg_time\"]\n",
    "df[\"tokens_s_stderr\"] = df[\"batch_size\"] * df[\"avg_time_stderr\"] / df[\"avg_time\"]**2\n",
    "df[\"gb_s\"] = df[\"bytes_rw\"] / df[\"avg_time\"] / 1e9\n",
    "df[\"tflops\"] = df[\"ops\"] / df[\"avg_time\"] / 1e12\n",
    "\n",
    "assert df.groupby([\"model\", \"batch_size\", \"element_bits\", \"impl\"]).count().avg_time.max() == 1\n",
    "\n",
    "display(df.head())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c75f8208",
   "metadata": {},
   "source": [
    "## `perf_model_params_m_bits_impl`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4c3baff7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative 2*stderr mean 0.0003937507972367792\n",
      "Relative 2*stderr max 0.00169051247200207\n"
     ]
    },
    {
     "data": {
      "image/png": "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iIiIiIgoCnBh4wC5fv06AMBsNoe5JkQULqtWrUJiYmLQr8O8ISLmDRGFSqjyhoi8w06cALl06RIAoKKiIsw1IaJwaWtrg0qlCvp1mDdExLwholAJVd4QkXfiRFEUw12J2WBoaAinTp1CWloa5s+fH9CyzWYzKioqUFtbC4VCEdCyZzO2m2/Ybr4L1Z0q5k3kYbv5hu3mO+ZN7GK7+Ybt5juOxCGKLByJEyBLlizBtm3bgnoNhULBXnAfsN18w3aLXMybyMV28w3bLXIxbyIX2803bDciinZc2JiIiIiIiIiIKApwJA4RERERERFRmAwPDyMvLw/Lly/Hvffei6SkJFy4cAEfffQR1Go10tLSMDo6ig8++ABjY2Po6ekJWl36+/tRU1ODM2fO4O2330ZqamrQrkW+YScOERERERERUZgMDQ1BqVSipaVFOtbd3Y1du3Zh165dUKvV0nGtVhvUuqjVahw9ehQbNmwI6nXId5xORURERERERBQmFosFer3e5XPJyckOj7dv347h4eGg1oejbyIbO3GiwNKlS7F7924sXbo03FWJKmw337DdYhs/f9+w3XzDdott/Px9w3bzDduNItnw8LDDaBtPMjIyMDQ0FOQaUSTjFuNEREREREQUU9avX+/w+L333gtTTWydOFNHv9inU7W3t0OhUEx7fqBlZWVxTZwIxZE4REREREREFDWKiopQWVmJy5cv4/DhwygsLITZbMZbb72F7du34/XXX8fVq1c9njeVv+VdvXrV5/cz046S1NRUtLW14ciRI2hqasKRI0fQ3d0tPd/d3Q2tVgu1Wg2z2YympiZotVqYzWaHc6qqqqTX9/f3O11naGgITU1NaGpqws6dOx2uQeHDhY2JiIiIiIiIosSRI0cwMjKCqqoq6dizzz6LTz/9FKWlpcjLy0NmZia0Wi16enpQWloKk8kEi8UCAGhra0Nra6vDQsparRbt7e0O13njjTfwzDPPAADWrl2LnTt3uuzsodDidCoiIiIiIiKKKZE0ncoVd9OphoeHsWHDBqepTmazGVqtFh9++KHDec3NzU7r7ajVatTW1iIvL0967WOPPYbu7m6pzKysLPzyl7+UznF3XQo9jsSJIlarFceOHUNrayusVit0Oh2SkpIAAKOjoxAEATqdDvn5+WGuaWRhuwUG2zG28PP2DdstMNiOsYWft+/Y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uLgYSUlJbs91dafEl3Jcfdl6KhuA9COkr6/P4e4V4Hkutz9lTFenyR555BGYTCb09fVNO2+8sbERer1eqo+761itVlitVp9/nPBHDUUa5o37Mpg3RIHFvHFfBvOGiCj42IlDQWEwGFBXV4e2tjZpWGpnZydGRkZcnu/uS3Om5fjCXq5Go5nx7gcGgwE6nW7GZczkR4Jer4fBYEBLS8u0P3Ls7WKvj8VicbqWfYvU6eoQ6K1U7W1FFGjMG8+YN0SBw7zxjHlDRBR8XBOHgqKyshLl5eUO84on/zCZvCNDKMrxRKVSQSaTOd1hAuA0D9rdD4OZlOGL+vp6dHV1eRx23NnZCa1W61AfV9c+f/48tmzZ4nR86o8ab4dau8O7WRQqzBv3ZfiCeUPkHvPGfRm+YN4QEc0cO3HIa/YvQYvF4vNrXc33tg999becyc+7e+xOfX09GhsbHc63Wq3o7e11OC8nJwfnz58HAKc52d6WMZP3a6dSqfDSSy9h7969Ln/YdXZ2SudNro/BYHC4lslkwsDAAKqrqx1er9FoHH7U2Ofnu/usvWlnT21FNB3mDfNm8vOeHgPMG/IP84Z5M/l5T48B5g0RhV+cKIpiuCtBkc1qteLYsWN46623YDKZIJfLsWXLFhQXFzvcQZrMZDLh2LFjyM3Nlb54NRoNnn76acjlchQXF0MQBHR2dsJgMEClUiEnJwfl5eUOdzi8KcdqtcJgMMBgMEh1q6ioQG1tLbq6uiAIAnQ6HXQ6HSwWC1paWtDV1QWVSoVHHnlE2nHBZDJJZdjrMHV4rCAIqKyslL6wp+7W4KmMvr6+ad+vN2prazEwMAC5XD7tMOfJ9QFsd/nKyspcDkF+7rnnkJubC5lMhuTkZFgsFum9lpeXA8C07bxlyxaUlZVJCx56aisiV5g332DeMG8ouJg332DeMG+IKHqwE4eIiIiIiIiIKApwOhURERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURT4/wfQXCT8zMdEAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 938.177x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = (df\n",
    "    .pipe(lambda d: d[~d.impl.isin([\"torch.compile\", \"Marlin (Linear)\"])])\n",
    "    .pipe(lambda d: d[d.batch_size.isin([1, 64, 256])])\n",
    ")\n",
    "print(\"Relative 2*stderr mean\", 2 * (d.tokens_s_stderr / d.tokens_s).mean())\n",
    "print(\"Relative 2*stderr max\", 2 * (d.tokens_s_stderr / d.tokens_s).max())\n",
    "\n",
    "g = sns.relplot(data=d, y=\"tokens_s\", x=\"parameters\", col=\"batch_size\", hue=\"avg_bits\",\n",
    "                style=\"impl\", style_order=[\"Triton\", \"Marlin\", \"Torch\"],\n",
    "                kind=\"line\", palette=plot_utils.SEQ_PALETTE,\n",
    "                height=3, aspect=0.9, mew=0, markers=True)\n",
    "for m, ax in g.axes_dict.items():\n",
    "    ax.set_xscale(\"log\", base=2)\n",
    "    ax.xaxis.set_major_formatter(lambda x, _: f\"{x/2**30:.0f} B\")\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.yaxis.set_major_formatter(\"{x:.0f}\")\n",
    "    ax.set_title(f\"$m={m}$\")\n",
    "g.figure.legend(\n",
    "    handles=g.legend.legend_handles,\n",
    "    labels=[text.get_text() for text in g.legend.get_texts()],\n",
    "    loc=\"center left\",\n",
    "    bbox_to_anchor=(1, 0.5),\n",
    ")\n",
    "plot_utils.tidy(g.figure)\n",
    "# plot_utils.save(\"perf_model_params_m_bits_impl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a7c7789a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative 2*stderr mean 0.0003937507972367792\n",
      "Relative 2*stderr max 0.00169051247200207\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "remote: Updating references: 100% (1/1)           \n"
     ]
    },
    {
     "data": {
      "image/png": "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iIiIiIgoCnBh4wC5fv06AMBsNoe5JkQULqtWrUJiYmLQr8O8ISLmDRGFSqjyhoi8w06cALl06RIAoKKiIsw1IaJwaWtrg0qlCvp1mDdExLwholAJVd4QkXfiRFEUw12J2WBoaAinTp1CWloa5s+fH9CyzWYzKioqUFtbC4VCEdCyZzO2m2/Ybr4L1Z0q5k3kYbv5hu3mO+ZN7GK7+Ybt5juOxCGKLByJEyBLlizBtm3bgnoNhULBXnAfsN18w3aLXMybyMV28w3bLXIxbyIX2803bDciinZc2JiIiIiIiIiIKApwJA4RERERERFRmAwPDyMvLw/Lly/Hvffei6SkJFy4cAEfffQR1Go10tLSMDo6ig8++ABjY2Po6ekJWl36+/tRU1ODM2fO4O2330ZqamrQrkW+YScOERERERERUZgMDQ1BqVSipaVFOtbd3Y1du3Zh165dUKvV0nGtVhvUuqjVahw9ehQbNmwI6nXId5xORURERERERBQmFosFer3e5XPJyckOj7dv347h4eGg1oejbyIbO3GiwNKlS7F7924sXbo03FWJKmw337DdYhs/f9+w3XzDdott/Px9w3bzDduNItnw8LDDaBtPMjIyMDQ0FOQaUSTjFuNEREREREQUU9avX+/w+L333gtTTWydOFNHv9inU7W3t0OhUEx7fqBlZWVxTZwIxZE4REREREREFDWKiopQWVmJy5cv4/DhwygsLITZbMZbb72F7du34/XXX8fVq1c9njeVv+VdvXrV5/cz046S1NRUtLW14ciRI2hqasKRI0fQ3d0tPd/d3Q2tVgu1Wg2z2YympiZotVqYzWaHc6qqqqTX9/f3O11naGgITU1NaGpqws6dOx2uQeHDhY2JiIiIiIiIosSRI0cwMjKCqqoq6dizzz6LTz/9FKWlpcjLy0NmZia0Wi16enpQWloKk8kEi8UCAGhra0Nra6vDQsparRbt7e0O13njjTfwzDPPAADWrl2LnTt3uuzsodDidCoiIiIiIiKKKZE0ncoVd9OphoeHsWHDBqepTmazGVqtFh9++KHDec3NzU7r7ajVatTW1iIvL0967WOPPYbu7m6pzKysLPzyl7+UznF3XQo9jsSJIlarFceOHUNrayusVit0Oh2SkpIAAKOjoxAEATqdDvn5+WGuaWRhuwUG2zG28PP2DdstMNiOsYWft+/Y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uLgYSUlJbs91dafEl3Jcfdl6KhuA9COkr6/P4e4V4Hkutz9lTFenyR555BGYTCb09fVNO2+8sbERer1eqo+761itVlitVp9/nPBHDUUa5o37Mpg3RIHFvHFfBvOGiCj42IlDQWEwGFBXV4e2tjZpWGpnZydGRkZcnu/uS3Om5fjCXq5Go5nx7gcGgwE6nW7GZczkR4Jer4fBYEBLS8u0P3Ls7WKvj8VicbqWfYvU6eoQ6K1U7W1FFGjMG8+YN0SBw7zxjHlDRBR8XBOHgqKyshLl5eUO84on/zCZvCNDKMrxRKVSQSaTOd1hAuA0D9rdD4OZlOGL+vp6dHV1eRx23NnZCa1W61AfV9c+f/48tmzZ4nR86o8ab4dau8O7WRQqzBv3ZfiCeUPkHvPGfRm+YN4QEc0cO3HIa/YvQYvF4vNrXc33tg999becyc+7e+xOfX09GhsbHc63Wq3o7e11OC8nJwfnz58HAKc52d6WMZP3a6dSqfDSSy9h7969Ln/YdXZ2SudNro/BYHC4lslkwsDAAKqrqx1er9FoHH7U2Ofnu/usvWlnT21FNB3mDfNm8vOeHgPMG/IP84Z5M/l5T48B5g0RhV+cKIpiuCtBkc1qteLYsWN46623YDKZIJfLsWXLFhQXFzvcQZrMZDLh2LFjyM3Nlb54NRoNnn76acjlchQXF0MQBHR2dsJgMEClUiEnJwfl5eUOdzi8KcdqtcJgMMBgMEh1q6ioQG1tLbq6uiAIAnQ6HXQ6HSwWC1paWtDV1QWVSoVHHnlE2nHBZDJJZdjrMHV4rCAIqKyslL6wp+7W4KmMvr6+ad+vN2prazEwMAC5XD7tMOfJ9QFsd/nKyspcDkF+7rnnkJubC5lMhuTkZFgsFum9lpeXA8C07bxlyxaUlZVJCx56aisiV5g332DeMG8ouJg332DeMG+IKHqwE4eIiIiIiIiIKApwOhURERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURRgJw4RERERERERURT4/wfQXCT8zMdEAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 938.177x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = (df\n",
    "    .pipe(lambda d: d[~d.impl.isin([\"torch.compile\", \"Marlin (Linear)\"])])\n",
    "    .pipe(lambda d: d[d.batch_size.isin([1, 64, 256])])\n",
    ")\n",
    "print(\"Relative 2*stderr mean\", 2 * (d.tokens_s_stderr / d.tokens_s).mean())\n",
    "print(\"Relative 2*stderr max\", 2 * (d.tokens_s_stderr / d.tokens_s).max())\n",
    "\n",
    "g = sns.relplot(data=d, y=\"tokens_s\", x=\"parameters\", col=\"batch_size\", hue=\"avg_bits\",\n",
    "                style=\"impl\", style_order=[\"Triton\", \"Marlin\", \"Torch\"],\n",
    "                kind=\"line\", palette=plot_utils.SEQ_PALETTE,\n",
    "                height=3, aspect=0.9, mew=0, markers=True)\n",
    "for m, ax in g.axes_dict.items():\n",
    "    ax.set_xscale(\"log\", base=2)\n",
    "    ax.xaxis.set_major_formatter(lambda x, _: f\"{x/2**30:.0f} B\")\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.yaxis.set_major_formatter(\"{x:.0f}\")\n",
    "    ax.set_title(f\"$m={m}$\")\n",
    "g.figure.legend(\n",
    "    handles=g.legend.legend_handles,\n",
    "    labels=[text.get_text() for text in g.legend.get_texts()],\n",
    "    loc=\"center left\",\n",
    "    bbox_to_anchor=(1, 0.5),\n",
    ")\n",
    "plot_utils.tidy(g.figure)\n",
    "plot_utils.save(\"perf_model_params_m_bits_impl\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc88f062",
   "metadata": {},
   "source": [
    "## `tables/perf_model_m1_impl`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7342db4d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative 2*stderr mean 0.00011349147933765257\n",
      "Relative 2*stderr max 0.0003671654151743351\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>4B</th>\n",
       "      <th>12B</th>\n",
       "      <th>31B</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>avg_bits</th>\n",
       "      <th>impl</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1.25</th>\n",
       "      <th>Triton</th>\n",
       "      <td>245.586348</td>\n",
       "      <td>119.964358</td>\n",
       "      <td>60.722270</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">4.25</th>\n",
       "      <th>Marlin</th>\n",
       "      <td>151.521331</td>\n",
       "      <td>64.099803</td>\n",
       "      <td>32.360355</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Marlin (Linear)</th>\n",
       "      <td>156.151749</td>\n",
       "      <td>65.471591</td>\n",
       "      <td>32.826245</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Triton</th>\n",
       "      <td>190.100723</td>\n",
       "      <td>79.284413</td>\n",
       "      <td>35.389009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16.00</th>\n",
       "      <th>Torch</th>\n",
       "      <td>88.837412</td>\n",
       "      <td>30.002909</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "model                             4B         12B        31B\n",
       "avg_bits impl                                              \n",
       "1.25     Triton           245.586348  119.964358  60.722270\n",
       "4.25     Marlin           151.521331   64.099803  32.360355\n",
       "         Marlin (Linear)  156.151749   65.471591  32.826245\n",
       "         Triton           190.100723   79.284413  35.389009\n",
       "16.00    Torch             88.837412   30.002909        NaN"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_3954f\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"blank\" >&nbsp;</th>\n",
       "      <th class=\"index_name level0\" >model</th>\n",
       "      <th id=\"T_3954f_level0_col0\" class=\"col_heading level0 col0\" >4B</th>\n",
       "      <th id=\"T_3954f_level0_col1\" class=\"col_heading level0 col1\" >12B</th>\n",
       "      <th id=\"T_3954f_level0_col2\" class=\"col_heading level0 col2\" >31B</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >avg_bits</th>\n",
       "      <th class=\"index_name level1\" >impl</th>\n",
       "      <th class=\"blank col0\" >&nbsp;</th>\n",
       "      <th class=\"blank col1\" >&nbsp;</th>\n",
       "      <th class=\"blank col2\" >&nbsp;</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_3954f_level0_row0\" class=\"row_heading level0 row0\" >1.250000</th>\n",
       "      <th id=\"T_3954f_level1_row0\" class=\"row_heading level1 row0\" >Triton</th>\n",
       "      <td id=\"T_3954f_row0_col0\" class=\"data row0 col0\" >312 GB/s</td>\n",
       "      <td id=\"T_3954f_row0_col1\" class=\"data row0 col1\" >322 GB/s</td>\n",
       "      <td id=\"T_3954f_row0_col2\" class=\"data row0 col2\" >372 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_3954f_level0_row1\" class=\"row_heading level0 row1\" rowspan=\"3\">4.250000</th>\n",
       "      <th id=\"T_3954f_level1_row1\" class=\"row_heading level1 row1\" >Marlin</th>\n",
       "      <td id=\"T_3954f_row1_col0\" class=\"data row1 col0\" >369 GB/s</td>\n",
       "      <td id=\"T_3954f_row1_col1\" class=\"data row1 col1\" >424 GB/s</td>\n",
       "      <td id=\"T_3954f_row1_col2\" class=\"data row1 col2\" >551 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_3954f_level1_row2\" class=\"row_heading level1 row2\" >Marlin (Linear)</th>\n",
       "      <td id=\"T_3954f_row2_col0\" class=\"data row2 col0\" >380 GB/s</td>\n",
       "      <td id=\"T_3954f_row2_col1\" class=\"data row2 col1\" >433 GB/s</td>\n",
       "      <td id=\"T_3954f_row2_col2\" class=\"data row2 col2\" >559 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_3954f_level1_row3\" class=\"row_heading level1 row3\" >Triton</th>\n",
       "      <td id=\"T_3954f_row3_col0\" class=\"data row3 col0\" >462 GB/s</td>\n",
       "      <td id=\"T_3954f_row3_col1\" class=\"data row3 col1\" >524 GB/s</td>\n",
       "      <td id=\"T_3954f_row3_col2\" class=\"data row3 col2\" >602 GB/s</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_3954f_level0_row4\" class=\"row_heading level0 row4\" >16.000000</th>\n",
       "      <th id=\"T_3954f_level1_row4\" class=\"row_heading level1 row4\" >Torch</th>\n",
       "      <td id=\"T_3954f_row4_col0\" class=\"data row4 col0\" >620 GB/s</td>\n",
       "      <td id=\"T_3954f_row4_col1\" class=\"data row4 col1\" >660 GB/s</td>\n",
       "      <td id=\"T_3954f_row4_col2\" class=\"data row4 col2\" >nan GB/s</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x7490777b6ad0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrr} \\toprule\n",
      "  $P_w$ & Implementation & 4B & 12B & 31B \\\\\\midrule\n",
      "  $16$ & Torch & \\color{blue}{$88.8$} & $30.0$ & OOM \\\\\n",
      "  $4.25$ & Triton & $190.1$ & \\color{blue}{$79.3$} & $35.4$ \\\\\n",
      "  $4.25$ & Marlin & $151.5$ & $64.1$ & $32.4$ \\\\\n",
      "  $4.25$ & Marlin (Linear) & $156.2$ & $65.5$ & $32.8$ \\\\\n",
      "  $1.25$ & Triton & $245.6$ & $120.0$ & \\color{blue}{$60.7$} \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "remote: Updating references: 100% (1/1)           \n"
     ]
    }
   ],
   "source": [
    "def token_s_highlighted(s: pd.Series) -> str:\n",
    "    text = f\"${s.tokens_s:.1f}$\"\n",
    "    if (s.impl, s.element_bits, s.model) in {(\"Torch\", 16, \"4B\"), (\"Triton\", 4, \"12B\"), (\"Triton\", 1, \"31B\")}:\n",
    "        text = f\"\\\\color{{blue}}{{{text}}}\"\n",
    "    return text\n",
    "\n",
    "d = (df\n",
    "    .pipe(lambda d: d[d.batch_size==1])\n",
    "    .pipe(lambda d: d[d.impl!=\"torch.compile\"])\n",
    "    .pipe(lambda d: d.assign(tokens_s_str=d.apply(token_s_highlighted, axis=1)))\n",
    ")\n",
    "t = (d\n",
    "    .pivot(index=[\"avg_bits\", \"impl\"], columns=\"model\", values=\"tokens_s_str\")[[\"4B\", \"12B\", \"31B\"]].reset_index()\n",
    "    .pipe(lambda d: d.assign(rank=d.apply(lambda s: (-s.avg_bits, [\"Torch\", \"Triton\", \"Marlin\", \"Marlin (Linear)\"].index(s.impl)), axis=1)))\n",
    "    .sort_values(\"rank\").drop(columns=[\"rank\"])\n",
    ")\n",
    "\n",
    "print(\"Relative 2*stderr mean\", 2 * (d.tokens_s_stderr / d.tokens_s).mean())\n",
    "print(\"Relative 2*stderr max\", 2 * (d.tokens_s_stderr / d.tokens_s).max())\n",
    "\n",
    "display(d.pivot(index=[\"avg_bits\", \"impl\"], columns=\"model\", values=\"tokens_s\")[[\"4B\", \"12B\", \"31B\"]])\n",
    "display(d.pivot(index=[\"avg_bits\", \"impl\"], columns=\"model\", values=\"gb_s\")[[\"4B\", \"12B\", \"31B\"]].style.format(\"{:.0f} GB/s\"))\n",
    "\n",
    "args = dict(cols={k: \"\" for k in [\"avg_bits\", \"impl\", \"4B\", \"12B\", \"31B\"]},\n",
    "            align=\"llrrr\", nan_str=\"OOM\")\n",
    "print(plot_utils.fmt_latex_booktabs(t, **args))\n",
    "plot_utils.save_table(\"perf_model_m1_impl\", t, **args)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "quantisation-benchmarking",
   "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.13.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
