{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "FZCFxdGmMi3R"
      },
      "source": [
        "# OptTx Large-PINN Fisher Timing Probe in Colab\n",
        "\n",
        "It does **not** compare loss or training quality. It only measures steady-state\n",
        "`CG-Fisher` step time after JIT compilation.\n",
        "\n",
        "The target questions are:\n",
        "\n",
        "1. How does `CG-Fisher` step time scale when the network becomes much wider?\n",
        "2. How does `CG-Fisher` step time scale when depth increases at fixed width?\n",
        "3. Is width scaling different from depth scaling on an L4 GPU?\n",
        "\n",
        "Planned sweeps:\n",
        "\n",
        "- width sweep: `32x2`, `64x2`, `128x2`, `256x2`\n",
        "- depth sweep: `128x2`, `128x3`, `128x4`, `128x5`\n",
        "\n",
        "Timing protocol:\n",
        "\n",
        "- fixed Poisson PINN batch\n",
        "- explicit JIT compile before timing\n",
        "- a small untimed warmup after compile\n",
        "- then exactly `10` timed steps\n",
        "\n",
        "Memory note:\n",
        "\n",
        "- this notebook uses a smaller fixed batch than the paper-matched benchmark\n",
        "- that is intentional, because `CG-Fisher` builds per-sample parameter-space\n",
        "  VJPs and large widths can otherwise overflow a 24GB L4"
      ],
      "id": "FZCFxdGmMi3R"
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "gzaKNwi-Mi3S"
      },
      "source": [
        "## Colab Setup\n",
        "\n",
        "Use a GPU runtime before running the next cell.\n",
        "\n",
        "Sources:\n",
        "\n",
        "- OptTx on PyPI: https://pypi.org/project/opttx/\n",
        "- JAX installation docs: https://docs.jax.dev/en/latest/installation.html\n",
        "- NVIDIA L4 specs: https://www.nvidia.com/en-eu/data-center/l4/\n",
        "- Google Colab Enterprise L4 runtime note: https://docs.cloud.google.com/colab/docs/default-runtimes-with-gpus"
      ],
      "id": "gzaKNwi-Mi3S"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "K3goTCiwMi3S"
      },
      "outputs": [],
      "source": [
        "import os\n",
        "os.environ[\"XLA_PYTHON_CLIENT_PREALLOCATE\"] = \"false\"\n",
        "\n",
        "!pip install -q -U pip\n",
        "!pip install -q -U \"jax[cuda13]\" opttx pandas matplotlib"
      ],
      "id": "K3goTCiwMi3S"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "J3XwITX6Mi3T",
        "outputId": "f9090972-3e9f-4911-e88d-a01e71a5b9fb"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "JAX version: 0.9.2\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "ERROR:jax._src.xla_bridge:Jax plugin configuration error: Exception when calling jax_plugins.xla_cuda12.initialize()\n",
            "Traceback (most recent call last):\n",
            "  File \"/usr/local/lib/python3.12/dist-packages/jax/_src/xla_bridge.py\", line 487, in discover_pjrt_plugins\n",
            "    plugin_module.initialize()\n",
            "  File \"/usr/local/lib/python3.12/dist-packages/jax_plugins/xla_cuda12/__init__.py\", line 373, in initialize\n",
            "    c_api = xb.register_plugin(\n",
            "            ^^^^^^^^^^^^^^^^^^^\n",
            "  File \"/usr/local/lib/python3.12/dist-packages/jax/_src/xla_bridge.py\", line 625, in register_plugin\n",
            "    c_api = xla_client.load_pjrt_plugin_dynamically(plugin_name, library_path)\n",
            "            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "  File \"/usr/local/lib/python3.12/dist-packages/jaxlib/xla_client.py\", line 117, in load_pjrt_plugin_dynamically\n",
            "    return _xla.load_pjrt_plugin(plugin_name, library_path, c_api=None)\n",
            "           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
            "jax.errors.JaxRuntimeError: ALREADY_EXISTS: PJRT_Api already exists for device type cuda\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Devices: [CudaDevice(id=0)]\n",
            "Default backend: gpu\n"
          ]
        }
      ],
      "source": [
        "import gc\n",
        "import time\n",
        "from typing import Any, Dict, Sequence, Tuple\n",
        "\n",
        "import jax\n",
        "import jax.numpy as jnp\n",
        "import matplotlib.pyplot as plt\n",
        "import numpy as np\n",
        "import pandas as pd\n",
        "from flax import linen as nn\n",
        "from IPython.display import display\n",
        "\n",
        "from opttx import CGOptimizer, Objective, TermSpec, TrainState\n",
        "\n",
        "jax.config.update(\"jax_enable_x64\", True)\n",
        "\n",
        "print(\"JAX version:\", jax.__version__)\n",
        "print(\"Devices:\", jax.devices())\n",
        "print(\"Default backend:\", jax.default_backend())\n",
        "if jax.default_backend() == \"cpu\":\n",
        "    print(\"Warning: notebook is running on CPU, not GPU.\")"
      ],
      "id": "J3XwITX6Mi3T"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wQ-fnk57Mi3T",
        "outputId": "77d2da48-bef0-45d4-e86c-5ce644a3b7ba"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "{'use_float64': True,\n",
              " 'seed': 42,\n",
              " 'n_interior_batch': 256,\n",
              " 'n_boundary_batch': 64,\n",
              " 'weight_pde': 1.0,\n",
              " 'weight_bc': 100.0,\n",
              " 'warmup_steps': 2,\n",
              " 'timing_steps': 10,\n",
              " 'show_partial_table': True,\n",
              " 'cgf_lr': 1.0,\n",
              " 'cg_iters': 20,\n",
              " 'damping': 0.001,\n",
              " 'width_sweep': [(32, 2), (64, 2), (128, 2), (256, 2)],\n",
              " 'depth_sweep': [(128, 2), (128, 3), (128, 4), (128, 5)]}"
            ]
          },
          "metadata": {},
          "execution_count": 3
        }
      ],
      "source": [
        "RUN_MODE = \"full\"  # \"full\" or \"quick\"\n",
        "\n",
        "if RUN_MODE == \"full\":\n",
        "    CONFIG = {\n",
        "        \"use_float64\": True,\n",
        "        \"seed\": 42,\n",
        "        \"n_interior_batch\": 256,\n",
        "        \"n_boundary_batch\": 64,\n",
        "        \"weight_pde\": 1.0,\n",
        "        \"weight_bc\": 100.0,\n",
        "        \"warmup_steps\": 2,\n",
        "        \"timing_steps\": 10,\n",
        "        \"show_partial_table\": True,\n",
        "        \"cgf_lr\": 1.0,\n",
        "        \"cg_iters\": 20,\n",
        "        \"damping\": 1e-3,\n",
        "        \"width_sweep\": [(32, 2), (64, 2), (128, 2), (256, 2)],\n",
        "        \"depth_sweep\": [(128, 2), (128, 3), (128, 4), (128, 5)],\n",
        "    }\n",
        "else:\n",
        "    CONFIG = {\n",
        "        \"use_float64\": True,\n",
        "        \"seed\": 42,\n",
        "        \"n_interior_batch\": 128,\n",
        "        \"n_boundary_batch\": 32,\n",
        "        \"weight_pde\": 1.0,\n",
        "        \"weight_bc\": 100.0,\n",
        "        \"warmup_steps\": 1,\n",
        "        \"timing_steps\": 4,\n",
        "        \"show_partial_table\": True,\n",
        "        \"cgf_lr\": 1.0,\n",
        "        \"cg_iters\": 10,\n",
        "        \"damping\": 1e-3,\n",
        "        \"width_sweep\": [(32, 2), (64, 2), (128, 2), (256, 2)],\n",
        "        \"depth_sweep\": [(128, 2), (128, 3)],\n",
        "    }\n",
        "\n",
        "CONFIG"
      ],
      "id": "wQ-fnk57Mi3T"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "TxkBQ4yzMi3T"
      },
      "outputs": [],
      "source": [
        "class PoissonPINN(nn.Module):\n",
        "    hidden_layers: Sequence[int]\n",
        "    dtype: jnp.dtype = jnp.float64\n",
        "\n",
        "    @nn.compact\n",
        "    def __call__(self, x: jnp.ndarray) -> jnp.ndarray:\n",
        "        for width in self.hidden_layers:\n",
        "            x = nn.Dense(width, dtype=self.dtype, param_dtype=self.dtype)(x)\n",
        "            x = nn.tanh(x)\n",
        "        return nn.Dense(1, dtype=self.dtype, param_dtype=self.dtype)(x)\n",
        "\n",
        "    def laplacian(self, x: jnp.ndarray) -> jnp.ndarray:\n",
        "        def single_point_laplacian(point: jnp.ndarray) -> jnp.ndarray:\n",
        "            x_val, y_val = point[0], point[1]\n",
        "\n",
        "            def u_at_x(t: jax.Array) -> jax.Array:\n",
        "                pt = jnp.array([t, y_val], dtype=point.dtype)\n",
        "                return self(pt[None, :])[0, 0]\n",
        "\n",
        "            def u_at_y(t: jax.Array) -> jax.Array:\n",
        "                pt = jnp.array([x_val, t], dtype=point.dtype)\n",
        "                return self(pt[None, :])[0, 0]\n",
        "\n",
        "            u_xx = jax.grad(jax.grad(u_at_x))(x_val)\n",
        "            u_yy = jax.grad(jax.grad(u_at_y))(y_val)\n",
        "            return -(u_xx + u_yy)\n",
        "\n",
        "        return jax.vmap(single_point_laplacian)(x)[:, None]\n",
        "\n",
        "\n",
        "def true_solution(x: jnp.ndarray, y: jnp.ndarray) -> jnp.ndarray:\n",
        "    return jnp.sin(2 * jnp.pi * x) * jnp.sin(2 * jnp.pi * y)\n",
        "\n",
        "\n",
        "def source_term(x: jnp.ndarray, y: jnp.ndarray) -> jnp.ndarray:\n",
        "    return 8 * (jnp.pi**2) * jnp.sin(2 * jnp.pi * x) * jnp.sin(2 * jnp.pi * y)\n",
        "\n",
        "\n",
        "def generate_batch(\n",
        "    key: jax.Array,\n",
        "    n_interior: int,\n",
        "    n_boundary_total: int,\n",
        "    dtype: jnp.dtype,\n",
        ") -> Dict[str, Tuple[jnp.ndarray, jnp.ndarray]]:\n",
        "    if n_boundary_total % 4 != 0:\n",
        "        raise ValueError(\"n_boundary_total must be divisible by 4\")\n",
        "\n",
        "    key_int_x, key_int_y, key_b0, key_b1, key_b2, key_b3 = jax.random.split(key, 6)\n",
        "\n",
        "    x_int = jax.random.uniform(key_int_x, (n_interior,), dtype=dtype)\n",
        "    y_int = jax.random.uniform(key_int_y, (n_interior,), dtype=dtype)\n",
        "    interior_points = jnp.stack([x_int, y_int], axis=1)\n",
        "    interior_targets = source_term(x_int, y_int)[:, None]\n",
        "\n",
        "    n_side = n_boundary_total // 4\n",
        "    x_bottom = jax.random.uniform(key_b0, (n_side,), dtype=dtype)\n",
        "    x_top = jax.random.uniform(key_b1, (n_side,), dtype=dtype)\n",
        "    y_left = jax.random.uniform(key_b2, (n_side,), dtype=dtype)\n",
        "    y_right = jax.random.uniform(key_b3, (n_side,), dtype=dtype)\n",
        "\n",
        "    bottom = jnp.stack([x_bottom, jnp.zeros(n_side, dtype=dtype)], axis=1)\n",
        "    top = jnp.stack([x_top, jnp.ones(n_side, dtype=dtype)], axis=1)\n",
        "    left = jnp.stack([jnp.zeros(n_side, dtype=dtype), y_left], axis=1)\n",
        "    right = jnp.stack([jnp.ones(n_side, dtype=dtype), y_right], axis=1)\n",
        "\n",
        "    boundary_points = jnp.concatenate([bottom, top, left, right], axis=0)\n",
        "    boundary_targets = true_solution(boundary_points[:, 0], boundary_points[:, 1])[:, None]\n",
        "\n",
        "    return {\n",
        "        \"interior\": (interior_points, interior_targets),\n",
        "        \"boundary\": (boundary_points, boundary_targets),\n",
        "    }\n",
        "\n",
        "\n",
        "def pde_loss_fn(pred: jnp.ndarray, batch: Tuple[jnp.ndarray, jnp.ndarray]) -> jax.Array:\n",
        "    _, target = batch\n",
        "    return jnp.mean((pred - target) ** 2)\n",
        "\n",
        "\n",
        "def bc_loss_fn(pred: jnp.ndarray, batch: Tuple[jnp.ndarray, jnp.ndarray]) -> jax.Array:\n",
        "    _, target = batch\n",
        "    return jnp.mean((pred - target) ** 2)\n",
        "\n",
        "\n",
        "def count_parameters(params: Any) -> int:\n",
        "    return int(sum(leaf.size for leaf in jax.tree_util.tree_leaves(params)))\n",
        "\n",
        "\n",
        "def build_problem(width: int, depth: int, cfg: Dict[str, Any]):\n",
        "    dtype = jnp.float64 if cfg[\"use_float64\"] else jnp.float32\n",
        "    hidden_layers = tuple([width] * depth)\n",
        "    model = PoissonPINN(hidden_layers=hidden_layers, dtype=dtype)\n",
        "\n",
        "    init_key = jax.random.PRNGKey(cfg[\"seed\"])\n",
        "    batch_key = jax.random.PRNGKey(cfg[\"seed\"] + 1)\n",
        "    batch = generate_batch(\n",
        "        batch_key,\n",
        "        n_interior=cfg[\"n_interior_batch\"],\n",
        "        n_boundary_total=cfg[\"n_boundary_batch\"],\n",
        "        dtype=dtype,\n",
        "    )\n",
        "    variables = model.init(init_key, batch[\"interior\"][0])\n",
        "\n",
        "    def model_apply(variables: Dict[str, Any], batch_item: Any, method: str | None = None):\n",
        "        points, _ = batch_item\n",
        "        if method == \"laplacian\":\n",
        "            return model.apply(variables, points, method=lambda m, x: m.laplacian(x))\n",
        "        return model.apply(variables, points)\n",
        "\n",
        "    objective = Objective(\n",
        "        terms=[\n",
        "            TermSpec(name=\"pde\", batch_key=\"interior\", loss_fn=pde_loss_fn, method=\"laplacian\"),\n",
        "            TermSpec(name=\"bc\", batch_key=\"boundary\", loss_fn=bc_loss_fn),\n",
        "        ],\n",
        "        loss_weights={\n",
        "            \"pde\": cfg[\"weight_pde\"],\n",
        "            \"bc\": cfg[\"weight_bc\"],\n",
        "        },\n",
        "    )\n",
        "\n",
        "    state = TrainState.create(apply_fn=model_apply, params=variables[\"params\"])\n",
        "    metadata = {\n",
        "        \"width\": width,\n",
        "        \"depth\": depth,\n",
        "        \"param_count\": count_parameters(state.params),\n",
        "        \"dtype\": str(dtype),\n",
        "    }\n",
        "    return objective, state, batch, dtype, metadata\n",
        "\n",
        "\n",
        "def create_cg_optimizer(objective: Objective, cfg: Dict[str, Any]):\n",
        "    return CGOptimizer(\n",
        "        objective,\n",
        "        learning_rate=cfg[\"cgf_lr\"],\n",
        "        damping=cfg[\"damping\"],\n",
        "        cg_iters=cfg[\"cg_iters\"],\n",
        "        curvature_type=\"fisher\",\n",
        "    )\n",
        "\n",
        "\n",
        "def compile_step(jit_step: Any, state: TrainState, batch: Dict[str, Any]) -> None:\n",
        "    _, metrics = jit_step(state, batch)\n",
        "    jax.block_until_ready(metrics[\"loss\"])\n",
        "\n",
        "\n",
        "def summarize_times(times: Sequence[float]) -> Dict[str, float]:\n",
        "    arr = np.asarray(times, dtype=np.float64)\n",
        "    return {\n",
        "        \"step_time_mean\": float(arr.mean()),\n",
        "        \"step_time_std\": float(arr.std()),\n",
        "        \"step_time_min\": float(arr.min()),\n",
        "        \"step_time_max\": float(arr.max()),\n",
        "        \"step_time_median\": float(np.median(arr)),\n",
        "    }\n",
        "\n",
        "\n",
        "def time_cg_fisher(objective: Objective, base_state: TrainState, batch: Dict[str, Any], cfg: Dict[str, Any]):\n",
        "    optimizer = create_cg_optimizer(objective, cfg)\n",
        "    state = optimizer.init(base_state.replace(step=jnp.array(0), opt_state=None), example_batch=batch)\n",
        "    jit_step = jax.jit(optimizer.step)\n",
        "    print(\"  compiling jitted CG-Fisher step...\")\n",
        "    compile_step(jit_step, state, batch)\n",
        "\n",
        "    print(f\"  warmup: {cfg['warmup_steps']} steps\")\n",
        "    for _ in range(cfg[\"warmup_steps\"]):\n",
        "        state, metrics = jit_step(state, batch)\n",
        "        jax.block_until_ready(metrics[\"loss\"])\n",
        "\n",
        "    print(f\"  timing: {cfg['timing_steps']} steps\")\n",
        "    times = []\n",
        "    losses = []\n",
        "    for _ in range(cfg[\"timing_steps\"]):\n",
        "        t0 = time.perf_counter()\n",
        "        state, metrics = jit_step(state, batch)\n",
        "        jax.block_until_ready(metrics[\"loss\"])\n",
        "        times.append(time.perf_counter() - t0)\n",
        "        losses.append(float(metrics[\"loss\"]))\n",
        "\n",
        "    return {\n",
        "        \"times\": times,\n",
        "        \"losses\": losses,\n",
        "        \"final_loss\": float(losses[-1]),\n",
        "        **summarize_times(times),\n",
        "    }\n",
        "\n",
        "\n",
        "def estimate_vjp_buffer_gb(param_count: int, batch_size: int, dtype: jnp.dtype) -> float:\n",
        "    dtype_bytes = np.dtype(dtype).itemsize\n",
        "    return float(param_count * batch_size * dtype_bytes / 1e9)\n",
        "\n",
        "\n",
        "def benchmark_architecture(width: int, depth: int, cfg: Dict[str, Any]) -> Dict[str, Any]:\n",
        "    objective, state, batch, dtype, metadata = build_problem(width, depth, cfg)\n",
        "    param_count = int(metadata[\"param_count\"])\n",
        "\n",
        "    cg = time_cg_fisher(objective, state, batch, cfg)\n",
        "\n",
        "    return {\n",
        "        \"width\": width,\n",
        "        \"depth\": depth,\n",
        "        \"param_count\": param_count,\n",
        "        \"dtype\": metadata[\"dtype\"],\n",
        "        \"n_interior_batch\": int(cfg[\"n_interior_batch\"]),\n",
        "        \"n_boundary_batch\": int(cfg[\"n_boundary_batch\"]),\n",
        "        \"estimated_interior_vjp_buffer_gb\": estimate_vjp_buffer_gb(param_count, int(cfg[\"n_interior_batch\"]), dtype),\n",
        "        \"estimated_boundary_vjp_buffer_gb\": estimate_vjp_buffer_gb(param_count, int(cfg[\"n_boundary_batch\"]), dtype),\n",
        "        \"cg_step_time_mean\": cg[\"step_time_mean\"],\n",
        "        \"cg_step_time_median\": cg[\"step_time_median\"],\n",
        "        \"cg_final_loss\": cg[\"final_loss\"],\n",
        "    }\n",
        "\n",
        "\n",
        "def run_sweep(architectures: Sequence[Tuple[int, int]], cfg: Dict[str, Any], label: str) -> pd.DataFrame:\n",
        "    rows = []\n",
        "    for width, depth in architectures:\n",
        "        print(f\"[{label}] width={width}, depth={depth}\")\n",
        "        gc.collect()\n",
        "        try:\n",
        "            row = benchmark_architecture(width, depth, cfg)\n",
        "            row[\"status\"] = \"ok\"\n",
        "            rows.append(row)\n",
        "            print(\n",
        "                f\"  done: cg_step_time_mean={row['cg_step_time_mean']:.6f}s, \"\n",
        "                f\"params={row['param_count']}\"\n",
        "            )\n",
        "        except Exception as exc:\n",
        "            rows.append({\n",
        "                \"width\": width,\n",
        "                \"depth\": depth,\n",
        "                \"status\": f\"error: {type(exc).__name__}: {exc}\",\n",
        "            })\n",
        "            print(f\"  failed: {type(exc).__name__}: {exc}\")\n",
        "        finally:\n",
        "            if cfg.get(\"show_partial_table\", False):\n",
        "                display(pd.DataFrame(rows))\n",
        "            gc.collect()\n",
        "            try:\n",
        "                jax.clear_caches()\n",
        "            except Exception:\n",
        "                pass\n",
        "    return pd.DataFrame(rows)"
      ],
      "id": "TxkBQ4yzMi3T"
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Hyw1vVFfMi3T"
      },
      "source": [
        "## Run The Large-Width Sweep\n",
        "\n",
        "This sweep keeps depth fixed at `2` and increases width."
      ],
      "id": "Hyw1vVFfMi3T"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 963
        },
        "id": "q7x2YGr0Mi3U",
        "outputId": "d4a1291f-6213-46fd-a14c-96f79c60c0cb"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[width] width=32, depth=2\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.007996s, params=1185\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0     32      2         1185  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.002427   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.000607           0.007996             0.007879   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0   9.673472e+07     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.000607</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>0.007879</td>\n",
              "      <td>9.673472e+07</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[width] width=64, depth=2\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.015170s, params=4417\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0     32      2         1185  <class 'jax.numpy.float64'>               256   \n",
              "1     64      2         4417  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.002427   \n",
              "1                64                          0.009046   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.000607           0.007996             0.007879   \n",
              "1                          0.002262           0.015170             0.015136   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0   9.673472e+07     ok  \n",
              "1   1.525451e+02     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.000607</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>0.007879</td>\n",
              "      <td>9.673472e+07</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>64</td>\n",
              "      <td>2</td>\n",
              "      <td>4417</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.009046</td>\n",
              "      <td>0.002262</td>\n",
              "      <td>0.015170</td>\n",
              "      <td>0.015136</td>\n",
              "      <td>1.525451e+02</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[width] width=128, depth=2\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.036282s, params=17025\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0     32      2         1185  <class 'jax.numpy.float64'>               256   \n",
              "1     64      2         4417  <class 'jax.numpy.float64'>               256   \n",
              "2    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.002427   \n",
              "1                64                          0.009046   \n",
              "2                64                          0.034867   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.000607           0.007996             0.007879   \n",
              "1                          0.002262           0.015170             0.015136   \n",
              "2                          0.008717           0.036282             0.036252   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0   9.673472e+07     ok  \n",
              "1   1.525451e+02     ok  \n",
              "2   1.603290e+03     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.000607</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>0.007879</td>\n",
              "      <td>9.673472e+07</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>64</td>\n",
              "      <td>2</td>\n",
              "      <td>4417</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.009046</td>\n",
              "      <td>0.002262</td>\n",
              "      <td>0.015170</td>\n",
              "      <td>0.015136</td>\n",
              "      <td>1.525451e+02</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036282</td>\n",
              "      <td>0.036252</td>\n",
              "      <td>1.603290e+03</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[width] width=256, depth=2\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.112348s, params=66817\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0     32      2         1185  <class 'jax.numpy.float64'>               256   \n",
              "1     64      2         4417  <class 'jax.numpy.float64'>               256   \n",
              "2    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "3    256      2        66817  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.002427   \n",
              "1                64                          0.009046   \n",
              "2                64                          0.034867   \n",
              "3                64                          0.136841   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.000607           0.007996             0.007879   \n",
              "1                          0.002262           0.015170             0.015136   \n",
              "2                          0.008717           0.036282             0.036252   \n",
              "3                          0.034210           0.112348             0.112326   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0   9.673472e+07     ok  \n",
              "1   1.525451e+02     ok  \n",
              "2   1.603290e+03     ok  \n",
              "3   8.631019e+04     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.000607</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>0.007879</td>\n",
              "      <td>9.673472e+07</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>64</td>\n",
              "      <td>2</td>\n",
              "      <td>4417</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.009046</td>\n",
              "      <td>0.002262</td>\n",
              "      <td>0.015170</td>\n",
              "      <td>0.015136</td>\n",
              "      <td>1.525451e+02</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036282</td>\n",
              "      <td>0.036252</td>\n",
              "      <td>1.603290e+03</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>256</td>\n",
              "      <td>2</td>\n",
              "      <td>66817</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.136841</td>\n",
              "      <td>0.034210</td>\n",
              "      <td>0.112348</td>\n",
              "      <td>0.112326</td>\n",
              "      <td>8.631019e+04</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0     32      2         1185  <class 'jax.numpy.float64'>               256   \n",
              "1     64      2         4417  <class 'jax.numpy.float64'>               256   \n",
              "2    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "3    256      2        66817  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.002427   \n",
              "1                64                          0.009046   \n",
              "2                64                          0.034867   \n",
              "3                64                          0.136841   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.000607           0.007996             0.007879   \n",
              "1                          0.002262           0.015170             0.015136   \n",
              "2                          0.008717           0.036282             0.036252   \n",
              "3                          0.034210           0.112348             0.112326   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0   9.673472e+07     ok  \n",
              "1   1.525451e+02     ok  \n",
              "2   1.603290e+03     ok  \n",
              "3   8.631019e+04     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.000607</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>0.007879</td>\n",
              "      <td>9.673472e+07</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>64</td>\n",
              "      <td>2</td>\n",
              "      <td>4417</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.009046</td>\n",
              "      <td>0.002262</td>\n",
              "      <td>0.015170</td>\n",
              "      <td>0.015136</td>\n",
              "      <td>1.525451e+02</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036282</td>\n",
              "      <td>0.036252</td>\n",
              "      <td>1.603290e+03</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>256</td>\n",
              "      <td>2</td>\n",
              "      <td>66817</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.136841</td>\n",
              "      <td>0.034210</td>\n",
              "      <td>0.112348</td>\n",
              "      <td>0.112326</td>\n",
              "      <td>8.631019e+04</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        }
      ],
      "source": [
        "width_df = run_sweep(CONFIG[\"width_sweep\"], CONFIG, label=\"width\")\n",
        "display(width_df)"
      ],
      "id": "q7x2YGr0Mi3U"
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "1K5XPF9CMi3U"
      },
      "source": [
        "## Run The Large-Depth Sweep\n",
        "\n",
        "This sweep keeps width fixed at `128` and increases depth."
      ],
      "id": "1K5XPF9CMi3U"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 963
        },
        "id": "NlNkDJMzMi3U",
        "outputId": "0ff8b79e-ee24-4b2f-acc7-69378f072db1"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[depth] width=128, depth=2\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.036302s, params=17025\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.034867   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.008717           0.036302             0.036288   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0    1603.289622     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>0.036288</td>\n",
              "      <td>1603.289622</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[depth] width=128, depth=3\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.066385s, params=33537\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "1    128      3        33537  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.034867   \n",
              "1                64                          0.068684   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.008717           0.036302             0.036288   \n",
              "1                          0.017171           0.066385             0.066328   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0    1603.289622     ok  \n",
              "1   33958.208402     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>0.036288</td>\n",
              "      <td>1603.289622</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>128</td>\n",
              "      <td>3</td>\n",
              "      <td>33537</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.068684</td>\n",
              "      <td>0.017171</td>\n",
              "      <td>0.066385</td>\n",
              "      <td>0.066328</td>\n",
              "      <td>33958.208402</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[depth] width=128, depth=4\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.096736s, params=50049\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "1    128      3        33537  <class 'jax.numpy.float64'>               256   \n",
              "2    128      4        50049  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.034867   \n",
              "1                64                          0.068684   \n",
              "2                64                          0.102500   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.008717           0.036302             0.036288   \n",
              "1                          0.017171           0.066385             0.066328   \n",
              "2                          0.025625           0.096736             0.096695   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0    1603.289622     ok  \n",
              "1   33958.208402     ok  \n",
              "2    1956.398347     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>0.036288</td>\n",
              "      <td>1603.289622</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>128</td>\n",
              "      <td>3</td>\n",
              "      <td>33537</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.068684</td>\n",
              "      <td>0.017171</td>\n",
              "      <td>0.066385</td>\n",
              "      <td>0.066328</td>\n",
              "      <td>33958.208402</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>4</td>\n",
              "      <td>50049</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.102500</td>\n",
              "      <td>0.025625</td>\n",
              "      <td>0.096736</td>\n",
              "      <td>0.096695</td>\n",
              "      <td>1956.398347</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[depth] width=128, depth=5\n",
            "  compiling jitted CG-Fisher step...\n",
            "  warmup: 2 steps\n",
            "  timing: 10 steps\n",
            "  done: cg_step_time_mean=0.126626s, params=66561\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "1    128      3        33537  <class 'jax.numpy.float64'>               256   \n",
              "2    128      4        50049  <class 'jax.numpy.float64'>               256   \n",
              "3    128      5        66561  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.034867   \n",
              "1                64                          0.068684   \n",
              "2                64                          0.102500   \n",
              "3                64                          0.136317   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.008717           0.036302             0.036288   \n",
              "1                          0.017171           0.066385             0.066328   \n",
              "2                          0.025625           0.096736             0.096695   \n",
              "3                          0.034079           0.126626             0.126567   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0    1603.289622     ok  \n",
              "1   33958.208402     ok  \n",
              "2    1956.398347     ok  \n",
              "3      91.177536     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>0.036288</td>\n",
              "      <td>1603.289622</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>128</td>\n",
              "      <td>3</td>\n",
              "      <td>33537</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.068684</td>\n",
              "      <td>0.017171</td>\n",
              "      <td>0.066385</td>\n",
              "      <td>0.066328</td>\n",
              "      <td>33958.208402</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>4</td>\n",
              "      <td>50049</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.102500</td>\n",
              "      <td>0.025625</td>\n",
              "      <td>0.096736</td>\n",
              "      <td>0.096695</td>\n",
              "      <td>1956.398347</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>128</td>\n",
              "      <td>5</td>\n",
              "      <td>66561</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.136317</td>\n",
              "      <td>0.034079</td>\n",
              "      <td>0.126626</td>\n",
              "      <td>0.126567</td>\n",
              "      <td>91.177536</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count                        dtype  n_interior_batch  \\\n",
              "0    128      2        17025  <class 'jax.numpy.float64'>               256   \n",
              "1    128      3        33537  <class 'jax.numpy.float64'>               256   \n",
              "2    128      4        50049  <class 'jax.numpy.float64'>               256   \n",
              "3    128      5        66561  <class 'jax.numpy.float64'>               256   \n",
              "\n",
              "   n_boundary_batch  estimated_interior_vjp_buffer_gb  \\\n",
              "0                64                          0.034867   \n",
              "1                64                          0.068684   \n",
              "2                64                          0.102500   \n",
              "3                64                          0.136317   \n",
              "\n",
              "   estimated_boundary_vjp_buffer_gb  cg_step_time_mean  cg_step_time_median  \\\n",
              "0                          0.008717           0.036302             0.036288   \n",
              "1                          0.017171           0.066385             0.066328   \n",
              "2                          0.025625           0.096736             0.096695   \n",
              "3                          0.034079           0.126626             0.126567   \n",
              "\n",
              "   cg_final_loss status  \n",
              "0    1603.289622     ok  \n",
              "1   33958.208402     ok  \n",
              "2    1956.398347     ok  \n",
              "3      91.177536     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>dtype</th>\n",
              "      <th>n_interior_batch</th>\n",
              "      <th>n_boundary_batch</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>estimated_boundary_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>cg_step_time_median</th>\n",
              "      <th>cg_final_loss</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.008717</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>0.036288</td>\n",
              "      <td>1603.289622</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>128</td>\n",
              "      <td>3</td>\n",
              "      <td>33537</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.068684</td>\n",
              "      <td>0.017171</td>\n",
              "      <td>0.066385</td>\n",
              "      <td>0.066328</td>\n",
              "      <td>33958.208402</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>4</td>\n",
              "      <td>50049</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.102500</td>\n",
              "      <td>0.025625</td>\n",
              "      <td>0.096736</td>\n",
              "      <td>0.096695</td>\n",
              "      <td>1956.398347</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>128</td>\n",
              "      <td>5</td>\n",
              "      <td>66561</td>\n",
              "      <td>&lt;class 'jax.numpy.float64'&gt;</td>\n",
              "      <td>256</td>\n",
              "      <td>64</td>\n",
              "      <td>0.136317</td>\n",
              "      <td>0.034079</td>\n",
              "      <td>0.126626</td>\n",
              "      <td>0.126567</td>\n",
              "      <td>91.177536</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        }
      ],
      "source": [
        "depth_df = run_sweep(CONFIG[\"depth_sweep\"], CONFIG, label=\"depth\")\n",
        "display(depth_df)"
      ],
      "id": "NlNkDJMzMi3U"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 765
        },
        "id": "FGEmMuPFMi3U",
        "outputId": "75a8fe42-e5da-4e5a-94f9-96c5d86b9fc1"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x400 with 2 Axes>"
            ],
            "image/png": "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GjVK/PLLL+KXX34Rd+/eFUIIERAQIMqXLy88PT3FhAkTxHfffSfatWsnAIg9e/a88DGdPHlSABAjR44Uubm5z+2nVquFg4OD+Oijj7RtS5YsEXK5XMjlcpGSkqLtZ2dnJyZPnqztt379eiGTyUTnzp3Ft99+KxYsWCC8vLyEg4ODCA8P1/a7cuWKsLe3F76+vmLBggVi+fLlonXr1kImk4mtW7dq++W/rvz9/UWrVq3EN998Iz788EMhl8tF69athUajeeFjJiIyRvzM5GemENJ+Zub3Xbdu3QufByGEqFy5sqhRo4Zwd3cX06ZNE8uXLxcNGjQQMplMXLlyRdsvJiZGuLu7C1tbW/Hpp5+KxYsXi7p16wq5XK6TM3+8fX19Rb169cTixYvFvHnzREZGhhg6dKhQqVTC19dXjB49WqxYsUI0b95cm7V8+fJiypQp4ttvvxW1a9cWCoVC3Lt3T7vtM2fOiKpVq4pPPvlErF69WsyePVtUqFBB2Nvbi+joaG2//N+bpx//zJkzdX4vTp48qX1N5f8MHjxYABArVqzQjmunTp2ElZWVmDhxoli9erUYO3asMDMzE7169dJ5Ht9++20BQLz11lti+fLlom/fvqJOnToCgJg5c+YLxyD/OfP39xd16tQRixcvFp988olQqVSievXqIjMzUwghxO3btwUA8e233+rcPjs7Wzg6OooRI0a88H7yn/9q1aqJd955Ryxfvlx0795dABCfffaZTt+KFSuKMWPGiOXLl4vFixeLJk2aCABi165dOv0AiFq1aglXV1cxa9YssWLFCu17mD7bqFOnjvD09BTz588X8+fPF/b29qJSpUpi+fLlwtfXVyxatEhMnz5dWFhYiLZt277wcQohRHR0tChfvrx27FatWiU+++wzUatWLe17XlFf0/m/T0//3gpR+HtbUd6XXvbeRi/HwhRRGVWUney8vDyRnZ2t05aUlCTc3d11Pijzdxbs7OxEXFycTv8ePXoIKysrnZ2L27dvCzMzM52difv37wuFQiHmzJmjc/vLly8LMzOzAu3Punr1qgAgvvjiCyGEELm5ucLa2lr8/PPPQggh3N3dtTslqampQqFQiJEjR2pv/+wHUU5OjnBzcxP16tXTeQ7WrFkjAGh3soV4slP1vJ3FgIAAAUCsX79e25adnS08PDxEv379XviYNBqN9vbu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qMNiIyIiIuoqnBMRUWdjYYqIqAXZ2dn47rvv2vWcOXPmYNq0aZ0TEBEREZECOCcios6mUToAIqJAFBERgYiICKXDICIiIlIU50RE1Nm4YoqIQsaWLVsQGxsLj8cDADh06BAkScJvfvMb35if/exnuO+++1pctv6HP/wBCQkJiImJwdy5c1FbW+s799RTT+G1117D5s2bIUkSJElCTk6O7/zJkydxyy23IDIyEsOGDcPevXs79VqJiIiIroRzIiIKJCxMEVHIuPnmm+F0OnHw4EEAwM6dO2GxWPwmSzt37sSECROaPXfDhg146qmn8PTTTyMvLw+JiYl4/vnnfecXL16MmTNnYsqUKSgqKkJRURHGjBnjO//b3/4WixcvxqFDhzBgwADMmjULbre7066ViIiI6Eo4JyKiQMLCFBGFDIPBgOHDh/smXTk5OXjsscdw8OBBVFVVobCwEPn5+Rg/fnyz5z733HOYO3cu5s6di4EDB+L3v/89Bg8e7DsfHR2NiIgI6HQ6WK1WWK1WaLVa3/nFixdj6tSpGDBgAFasWIEzZ84gPz+/06+ZiIiI6HKcExFRIGFhiohCyvjx45GTkwMhBD799FNMnz4d1113HXbv3o2dO3ciKSkJ/fv3b/a8b775BhkZGX7HMjMz2/x1hw4d6vt3YmIiAKC0tPQar4KIiIjo++GciIgCBZufE1FImTBhAl555RV8+eWXCAsLw6BBgzBhwgTk5OSgvLy8xd8MdoSwsDDfvyVJAgDIstwpX4uIiIioNZwTEVGg4IopIgopjT0V/vKXv/gmXI2TsJycnBZ7KQDAddddh3379vkd+/zzz/0ea7VaXxNRIiIiokDGORERBQoWpogopBiNRgwdOhT/+te/fBOucePG4cCBA/juu++u+NvBRx55BK+88grWrl2L7777DsuXL8fXX3/tN6ZXr144fPgwjh07hrKyMrhcrs6+HCIiIqJrwjkREQUKFqaIKOSMHz8eHo/HNwkzmUwYPHgwrFYrBg4c2OJzsrOz8eSTT+LXv/41RowYgTNnzmDBggV+Y+bNm4eBAwciPT0dcXFx2LNnT2dfChEREdE145yIiAKBJIQQSgdBREREREREREShhyumiIiIiIiIiIhIESxMERERERERERGRIliYIiIiIiIiIiIiRbAwRUREREREREREimBhioiIiIiIiIiIFMHCFBERERERERERKYKFKSIiIiIiIiIiUgQLU0REREREREREpAgWpoiIiIiIiIiISBEsTBERERERERERkSJYmCIiIiIiIiIiIkX8f7Hsm0W2nbGDAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x400 with 2 Axes>"
            ],
            "image/png": "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aNEi1/G5ubmMGjUKPz8/IiIi+L//+7+6uGwRERGRa6I5lIi4gwpTInLDmTx5MuvWreN///d/WbVqFWvXrmXLli2u9x9//HE2bNjAkiVL2L59O3fddRcJCQns37/ftc+ZM2d48cUXef/99/nmm284ffo0d999NwBjxozh6aefpnPnzmRmZpKZmcmYMWNcx06fPp3f/va3bN++naSkJMaOHcupU6fqLgEiIiIiJmgOJSJuYYiI3EAKCwsNLy8v41//+pdr28mTJw1fX19jwoQJxuHDhw0PDw/j2LFjFY4bPHiwMXXqVMMwDGPhwoUGYHz77beu9zMyMgzA+O677wzDMIznn3/eiI6OvuzzAePZZ591vS4qKjIAIzk5uSYvU0RERKRGaQ4lIu7i6b6SmIhIzTt48CDnzp0jNjbWtS0kJITIyEgAduzYQVlZGTfffHOF4xwOB40bN3a99vT0pFevXq7XHTt2pFGjRmRkZNC7d++rxtCtWzfXf/v7+2O328nJybmm6xIRERGpTZpDiYi7qDAlIg1KUVERHh4epKWl4eHhUeG9gICAGvkMm81W4bXFYsHpdNbIuUVERETcQXMoEaktWmNKRG4oN910Ezabje+++861LS8vj3379gEQExNDWVkZOTk5dOjQocJPWFiY65jS0lI2b97ser13715Onz5NVFQUAF5eXpSVldXRVYmIiIjULs2hRMRdVJgSkRtKQEAADzzwAJMnT2bNmjXs3LmT8ePHY7WW/+/u5ptvZuzYsYwbN47/+Z//4dChQ2zcuJEZM2awbNky13lsNhtPPPEE3333HWlpaYwfP54+ffq4WtDbtm3LoUOHSE9PJzc3F4fD4ZbrFREREakJmkOJiLuoMCUiN5xXX32V/v37M2LECIYMGUK/fv3o2bOn6/2FCxcybtw4nn76aSIjIxk5ciSbNm2idevWrn38/Pz4z//8T+69915uvfVWAgIC+Oijj1zv33nnnSQkJDBo0CCaNm3Khx9+WKfXKCIiIlLTNIcSEXewGIZhuDsIEZHryaJFi5g4cSKnT592dygiIiIi9YbmUCJihjqmRERERERERETELVSYEhERERERERERt9CtfCIiIiIiIiIi4hbqmBIREREREREREbdQYUpERERERERERNxChSkREREREREREXELFaZERERERERERMQtVJgSERERERERERG3UGFKRERERERERETcQoUpERERERERERFxCxWmRERERERERETELf4fF3tLjJm/VQUAAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "def plot_scaling(df: pd.DataFrame, *, x_col: str, title: str) -> None:\n",
        "    ok = df[df[\"status\"] == \"ok\"].copy()\n",
        "    fig, axes = plt.subplots(1, 2, figsize=(12, 4))\n",
        "\n",
        "    axes[0].plot(ok[x_col], ok[\"cg_step_time_mean\"], marker=\"o\", label=\"CG-Fisher\")\n",
        "    axes[0].set_xlabel(x_col)\n",
        "    axes[0].set_ylabel(\"steady-state step time (s)\")\n",
        "    axes[0].set_title(title)\n",
        "    axes[0].grid(True, alpha=0.25)\n",
        "    axes[0].legend()\n",
        "\n",
        "    axes[1].plot(ok[x_col], ok[\"cg_step_time_mean\"] / ok[\"param_count\"], marker=\"o\", color=\"tab:red\")\n",
        "    axes[1].set_xlabel(x_col)\n",
        "    axes[1].set_ylabel(\"step time / param\")\n",
        "    axes[1].set_title(f\"{title}: normalized by param count\")\n",
        "    axes[1].grid(True, alpha=0.25)\n",
        "\n",
        "    plt.tight_layout()\n",
        "    plt.show()\n",
        "\n",
        "\n",
        "plot_scaling(width_df, x_col=\"width\", title=\"Large Width Sweep\")\n",
        "plot_scaling(depth_df, x_col=\"depth\", title=\"Large Depth Sweep\")"
      ],
      "id": "FGEmMuPFMi3U"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 366
        },
        "id": "TXS54hiuMi3U",
        "outputId": "cd9e5c0a-749c-4faf-ae60-e41b0fdc72b5"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "=== Width Sweep ===\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count  estimated_interior_vjp_buffer_gb  \\\n",
              "0     32      2         1185                          0.002427   \n",
              "1     64      2         4417                          0.009046   \n",
              "2    128      2        17025                          0.034867   \n",
              "3    256      2        66817                          0.136841   \n",
              "\n",
              "   cg_step_time_mean status  \n",
              "0           0.007996     ok  \n",
              "1           0.015170     ok  \n",
              "2           0.036282     ok  \n",
              "3           0.112348     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>32</td>\n",
              "      <td>2</td>\n",
              "      <td>1185</td>\n",
              "      <td>0.002427</td>\n",
              "      <td>0.007996</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>64</td>\n",
              "      <td>2</td>\n",
              "      <td>4417</td>\n",
              "      <td>0.009046</td>\n",
              "      <td>0.015170</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.036282</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>256</td>\n",
              "      <td>2</td>\n",
              "      <td>66817</td>\n",
              "      <td>0.136841</td>\n",
              "      <td>0.112348</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "=== Depth Sweep ===\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "   width  depth  param_count  estimated_interior_vjp_buffer_gb  \\\n",
              "0    128      2        17025                          0.034867   \n",
              "1    128      3        33537                          0.068684   \n",
              "2    128      4        50049                          0.102500   \n",
              "3    128      5        66561                          0.136317   \n",
              "\n",
              "   cg_step_time_mean status  \n",
              "0           0.036302     ok  \n",
              "1           0.066385     ok  \n",
              "2           0.096736     ok  \n",
              "3           0.126626     ok  "
            ],
            "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>width</th>\n",
              "      <th>depth</th>\n",
              "      <th>param_count</th>\n",
              "      <th>estimated_interior_vjp_buffer_gb</th>\n",
              "      <th>cg_step_time_mean</th>\n",
              "      <th>status</th>\n",
              "    </tr>\n",
              "  </thead>\n",
              "  <tbody>\n",
              "    <tr>\n",
              "      <th>0</th>\n",
              "      <td>128</td>\n",
              "      <td>2</td>\n",
              "      <td>17025</td>\n",
              "      <td>0.034867</td>\n",
              "      <td>0.036302</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>1</th>\n",
              "      <td>128</td>\n",
              "      <td>3</td>\n",
              "      <td>33537</td>\n",
              "      <td>0.068684</td>\n",
              "      <td>0.066385</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>2</th>\n",
              "      <td>128</td>\n",
              "      <td>4</td>\n",
              "      <td>50049</td>\n",
              "      <td>0.102500</td>\n",
              "      <td>0.096736</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "    <tr>\n",
              "      <th>3</th>\n",
              "      <td>128</td>\n",
              "      <td>5</td>\n",
              "      <td>66561</td>\n",
              "      <td>0.136317</td>\n",
              "      <td>0.126626</td>\n",
              "      <td>ok</td>\n",
              "    </tr>\n",
              "  </tbody>\n",
              "</table>\n",
              "</div>"
            ]
          },
          "metadata": {}
        }
      ],
      "source": [
        "print(\"=== Width Sweep ===\")\n",
        "display(\n",
        "    width_df[\n",
        "        [\n",
        "            \"width\",\n",
        "            \"depth\",\n",
        "            \"param_count\",\n",
        "            \"estimated_interior_vjp_buffer_gb\",\n",
        "            \"cg_step_time_mean\",\n",
        "            \"status\",\n",
        "        ]\n",
        "    ]\n",
        ")\n",
        "\n",
        "print(\"=== Depth Sweep ===\")\n",
        "display(\n",
        "    depth_df[\n",
        "        [\n",
        "            \"width\",\n",
        "            \"depth\",\n",
        "            \"param_count\",\n",
        "            \"estimated_interior_vjp_buffer_gb\",\n",
        "            \"cg_step_time_mean\",\n",
        "            \"status\",\n",
        "        ]\n",
        "    ]\n",
        ")"
      ],
      "id": "TXS54hiuMi3U"
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "R4mTxiHnMi3U",
        "outputId": "f6048f5e-7797-474b-d470-d04d441edb65"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Saved:\n",
            "- large_width_timing_summary.csv\n",
            "- large_depth_timing_summary.csv\n"
          ]
        }
      ],
      "source": [
        "width_df.to_csv(\"large_width_timing_summary.csv\", index=False)\n",
        "depth_df.to_csv(\"large_depth_timing_summary.csv\", index=False)\n",
        "\n",
        "print(\"Saved:\")\n",
        "print(\"- large_width_timing_summary.csv\")\n",
        "print(\"- large_depth_timing_summary.csv\")"
      ],
      "id": "R4mTxiHnMi3U"
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python",
      "version": "3.12"
    },
    "colab": {
      "provenance": [],
      "machine_shape": "hm",
      "gpuType": "L4"
    },
    "accelerator": "GPU"
  },
  "nbformat": 4,
  "nbformat_minor": 5
}