{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5439e3c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy.optimize import curve_fit\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# google_gemma-3-1b-pt\n",
    "# meta-llama_Llama-3.2-1B\n",
    "# EleutherAI_pythia-410m\n",
    "# EleutherAI_pythia-1b\n",
    "# EleutherAI_pythia-1.4b\n",
    "# EleutherAI_pythia-2.8b\n",
    "MODELS = [\n",
    "    'google_gemma-3-1b-pt',\n",
    "    'google_gemma-3-1b-it',\n",
    "    'google_gemma-3-270m',\n",
    "    'meta-llama_Llama-3.2-1B',\n",
    "    'EleutherAI_pythia-160m',\n",
    "    'EleutherAI_pythia-410m',\n",
    "    'EleutherAI_pythia-1b',\n",
    "    'EleutherAI_pythia-1.4b',\n",
    "    'EleutherAI_pythia-2.8b',\n",
    "    'Qwen_Qwen2.5-0.5B',\n",
    "    'Qwen_Qwen2.5-1.5B'\n",
    "]   \n",
    "\n",
    "def sigmoid(x, L, x0, k):\n",
    "    return 1 / (1 + np.exp(-k * (x - x0)))\n",
    "\n",
    "def crossing_nearest(x, y, threshold=0.5, max_tol=0.1):\n",
    "    if len(x) == 0:\n",
    "        return np.nan\n",
    "    idx = np.argmin(np.abs(y - threshold))\n",
    "    if np.abs(y - threshold)[idx] > max_tol:\n",
    "        return np.nan\n",
    "    return float(x[idx])\n",
    "\n",
    "import os \n",
    "def plot_accessibility_curve(model, fit_sigmoid=True, save=False):\n",
    "    file_path = f'runs/{model}/data_rnd_vocab_100k.csv'\n",
    "    if not os.path.exists(file_path):\n",
    "        return None\n",
    "    data = pd.read_csv(file_path)\n",
    "    agg_dict = {\n",
    "        'repeatability': 'mean',\n",
    "        'curr_avg_repeatability': 'mean',\n",
    "        'best_acc': 'mean',\n",
    "        'num_steps': 'mean'\n",
    "    }\n",
    "    grouped = data.groupby(['n_mem', 'length']).agg(agg_dict).reset_index()\n",
    "\n",
    "    n_mems = sorted(grouped['n_mem'].unique())\n",
    "    cmap = plt.get_cmap('Blues')\n",
    "    colors = cmap(np.linspace(0.4, 0.9, max(1, len(n_mems))))\n",
    "\n",
    "    crossings = []  # list of (n_mem, crossing_x)\n",
    "\n",
    "    # Create a single figure with two subplots: left = sigmoid fits, right = crossings & linear fit\n",
    "    fig, (ax_sig, ax_lin) = plt.subplots(1, 2, figsize=(10, 4), gridspec_kw={'width_ratios': [2, 1]})\n",
    "    for i, n_mem in enumerate(n_mems):\n",
    "        subset = grouped[grouped['n_mem'] == n_mem]\n",
    "        x_data = subset['length'].values\n",
    "        y_data = subset['repeatability'].values\n",
    "\n",
    "        x_cross = np.nan\n",
    "        if fit_sigmoid and len(x_data) >= 3:\n",
    "            try:\n",
    "                p0 = [1.0, float(np.median(x_data)), 0.1]\n",
    "                popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
    "                x_smooth = np.linspace(x_data.min(), x_data.max(), 200)\n",
    "                y_smooth = sigmoid(x_smooth, *popt)\n",
    "\n",
    "                ax_sig.plot(x_smooth, y_smooth, color=colors[i], linewidth=1, linestyle='-', alpha=1, label=n_mem)\n",
    "                ax_sig.plot(x_data, y_data, color=colors[i], linestyle=':', alpha=0.3, )\n",
    "                ax_sig.scatter(x_data, y_data, color=colors[i], s=8, alpha=0.35)\n",
    "\n",
    "                if popt[1] > 1000 or popt[1] < 0 : raise Exception\n",
    "                x_cross = float(popt[1])  # sigmoid center = 50% crossing\n",
    "                ax_sig.axvline(x=x_cross, ymax=0.5, color=colors[i], linestyle='--', alpha=1, linewidth=1)\n",
    "\n",
    "            except Exception:\n",
    "                x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "                ax_sig.plot(x_data, y_data, label=str(n_mem), color=colors[i], markersize=4)\n",
    "                if not np.isnan(x_cross):\n",
    "                    ax_sig.axvline(x=x_cross, ymax=0.5, color=colors[i], linestyle='--', alpha=1, linewidth=1)\n",
    "\n",
    "        else:\n",
    "            ax_sig.plot(x_data, y_data, label=str(n_mem), color=colors[i], markersize=4)\n",
    "            x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "            if not np.isnan(x_cross):\n",
    "                ax_sig.axvline(x=x_cross, ymax=0.5, color=colors[i], linestyle='--', alpha=1, linewidth=1)\n",
    "\n",
    "        crossings.append((int(n_mem), float(x_cross) if not np.isnan(x_cross) else np.nan))\n",
    "\n",
    "    # Style left (sigmoid) axis\n",
    "    ax_sig.set_xlabel('$n$ (tokens)', fontsize=10)\n",
    "    ax_sig.set_ylabel('Accessibility', fontsize=10)\n",
    "    ax_sig.set_yticks([0.0, 0.5, 1.0])\n",
    "    ax_sig.set_title(model, fontsize=10)\n",
    "    ax_sig.set_ylim(-0.1, 1.1)\n",
    "    ax_sig.spines['top'].set_visible(False)\n",
    "    ax_sig.spines['right'].set_visible(False)\n",
    "    ax_sig.xaxis.set_ticks_position('bottom')\n",
    "    ax_sig.yaxis.set_ticks_position('left')\n",
    "    ax_sig.grid(False)\n",
    "    legend = ax_sig.legend(fontsize=9, title='$m$ (tokens)', title_fontsize=9, loc='upper right')\n",
    "    legend.get_frame().set_linewidth(0.)\n",
    "\n",
    "    # Right axis: crossings vs n_mem with linear fit\n",
    "    mems = np.array([m for m, cx in crossings])\n",
    "    cxs = np.array([cx for m, cx in crossings], dtype=float)\n",
    "    mask = ~np.isnan(cxs)\n",
    "    mem_arr = mems[mask].astype(float)\n",
    "    cross_arr = cxs[mask].astype(float)\n",
    "\n",
    "    ax_lin.set_title('', fontsize=10)\n",
    "    ax_lin.set_xlabel('$m$ (tokens)', fontsize=10)\n",
    "    ax_lin.set_ylabel('$n$ at Accessibility=50%', fontsize=10)\n",
    "    ax_lin.spines['top'].set_visible(False)\n",
    "    ax_lin.spines['right'].set_visible(False)\n",
    "    ax_lin.xaxis.set_ticks_position('bottom')\n",
    "    ax_lin.yaxis.set_ticks_position('left')\n",
    "    ax_lin.grid(False)\n",
    "\n",
    "    if mem_arr.size > 0:\n",
    "        cmap2 = plt.get_cmap('Blues')\n",
    "        colors2 = cmap2(np.linspace(0.4, 0.9, len(mem_arr)))\n",
    "        for i, (m, cx) in enumerate(zip(mem_arr, cross_arr)):\n",
    "            ax_lin.scatter(m, cx, color=colors2[i], s=40, zorder=5)\n",
    "\n",
    "    if mem_arr.size >= 2:\n",
    "        slope, intercept = np.polyfit(mem_arr, cross_arr, 1)\n",
    "        y_pred = slope * mem_arr + intercept\n",
    "        ss_res = np.sum((cross_arr - y_pred) ** 2)\n",
    "        ss_tot = np.sum((cross_arr - np.mean(cross_arr)) ** 2)\n",
    "        r2 = 1.0 - ss_res / ss_tot if ss_tot != 0 else np.nan\n",
    "\n",
    "        xs = np.linspace(mem_arr.min() - 0.2, mem_arr.max() + 0.2, 200)\n",
    "        ys = slope * xs + intercept\n",
    "        ax_lin.plot(xs, ys, color='black', linewidth=1, label='Linear fit', zorder=2, alpha=0.8, linestyle='--')\n",
    "        legend = ax_lin.legend(fontsize=9, title=f'$R^2$ = {r2:.3f}\\n$a = {slope:.2f}$', title_fontsize=9, loc='lower right')    \n",
    "        legend.get_frame().set_linewidth(0.)\n",
    "\n",
    "    else:\n",
    "        r2 = np.nan\n",
    "        ax_lin.legend([], [], frameon=False)  # no legend entries\n",
    "\n",
    "    plt.tight_layout()\n",
    "    if save:\n",
    "        plt.savefig(f'figures/{model}_rand.pdf', format='pdf', bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "    return crossings\n",
    "\n",
    "for model in MODELS:\n",
    "    plot_accessibility_curve(model, fit_sigmoid=True, save=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05513dbf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy.optimize import curve_fit\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# google_gemma-3-1b-pt\n",
    "# meta-llama_Llama-3.2-1B\n",
    "# EleutherAI_pythia-410m\n",
    "# EleutherAI_pythia-1b\n",
    "# EleutherAI_pythia-1.4b\n",
    "# EleutherAI_pythia-2.8b\"#D2583A\"\n",
    "MODELS = [\n",
    "    'google_gemma-3-1b-pt',\n",
    "    'google_gemma-3-270m',\n",
    "    'meta-llama_Llama-3.2-1B',\n",
    "    'EleutherAI_pythia-160m',\n",
    "    'EleutherAI_pythia-410m',\n",
    "    'EleutherAI_pythia-1b',\n",
    "    'EleutherAI_pythia-1.4b',\n",
    "    'EleutherAI_pythia-2.8b',\n",
    "    'Qwen_Qwen2.5-0.5B',\n",
    "    'Qwen_Qwen2.5-1.5B'\n",
    "]   \n",
    "\n",
    "def sigmoid(x, L, x0, k):\n",
    "    return 1 / (1 + np.exp(-k * (x - x0)))\n",
    "\n",
    "import os \n",
    "\n",
    "def _r2(y_true, y_pred):\n",
    "    ss_res = np.sum((y_true - y_pred) ** 2)\n",
    "    ss_tot = np.sum((y_true - np.mean(y_true)) ** 2)\n",
    "    return np.nan if ss_tot == 0 else 1.0 - ss_res / ss_tot\n",
    "\n",
    "def crossing_nearest(x, y, threshold=0.5, max_tol=0.1):\n",
    "    if len(x) == 0:\n",
    "        return np.nan\n",
    "    idx = np.argmin(np.abs(y - threshold))\n",
    "    if np.abs(y - threshold)[idx] > max_tol:\n",
    "        return np.nan\n",
    "    return float(x[idx])\n",
    "\n",
    "\n",
    "def plot_accessibility_curves(model, fit_sigmoid=True, save=False):\n",
    "    print(model)\n",
    "    file_path_rand = f'runs/{model}/data_rnd_vocab_100k.csv'\n",
    "    if not os.path.exists(file_path_rand):\n",
    "        return None\n",
    "    data_rand = pd.read_csv(file_path_rand)\n",
    "    data = pd.read_csv(f'runs/{model}/data_dataset.csv')\n",
    "    agg_dict = {\n",
    "        'repeatability': 'mean',\n",
    "        'curr_avg_repeatability': 'mean',\n",
    "        'best_acc': 'mean',\n",
    "        'num_steps': 'mean'\n",
    "    }\n",
    "    grouped_rand = data_rand.groupby(['n_mem', 'length']).agg(agg_dict).reset_index()\n",
    "    grouped = data.groupby(['n_mem', 'length']).agg(agg_dict).reset_index()\n",
    "\n",
    "    n_mems = sorted(grouped['n_mem'].unique())\n",
    "    n_mems = [x for x in n_mems if x <=5]\n",
    "    cmap = plt.get_cmap('Blues')\n",
    "    cmap_rand = plt.get_cmap('Reds')\n",
    "    colors = cmap(np.linspace(0.4, 0.9, max(1, len(n_mems))))\n",
    "    colors_rand = cmap_rand(np.linspace(0.4, 0.9, max(1, len(n_mems))))\n",
    "\n",
    "    fig = plt.figure(figsize=(12, 4))\n",
    "    gs = fig.add_gridspec(2, 2, width_ratios=[1.8, 1], height_ratios=[1, 1], wspace=0.2, hspace=0.3)\n",
    "    ax_dataset = fig.add_subplot(gs[0, 0])\n",
    "    ax_rand = fig.add_subplot(gs[1, 0], sharex=ax_dataset)\n",
    "    ax_lin = fig.add_subplot(gs[:, 1])\n",
    "\n",
    "    crossings = []\n",
    "    crossings_rand = []\n",
    "\n",
    "    # Dataset subplot (top-left)\n",
    "    for i, n_mem in enumerate(n_mems):\n",
    "        subset = grouped[grouped['n_mem'] == n_mem]\n",
    "        if subset.empty:\n",
    "            crossings.append((int(n_mem), np.nan))\n",
    "            continue\n",
    "        x_data = subset['length'].values\n",
    "        y_data = subset['repeatability'].values\n",
    "\n",
    "        x_cross = np.nan\n",
    "        if fit_sigmoid and len(x_data) >= 3:\n",
    "            p0 = [1.0, float(np.median(x_data)), 0.1]\n",
    "            popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
    "            x_smooth = np.linspace(x_data.min(), x_data.max(), 200)\n",
    "            y_smooth = sigmoid(x_smooth, *popt)\n",
    "            y_fit = sigmoid(x_data, *popt)\n",
    "            r2_fit = _r2(y_data, y_fit)\n",
    "            print(f\"{model} - Dataset n_mem={n_mem}: R²={r2_fit:.3f}\")\n",
    "\n",
    "            ax_dataset.plot(x_smooth, y_smooth, color=colors[i], linewidth=1, linestyle='-', alpha=1, label=n_mem)\n",
    "            ax_dataset.plot(x_data, y_data, color=colors[i], linestyle=':', alpha=0.3)\n",
    "            ax_dataset.scatter(x_data, y_data, color=colors[i], s=8, alpha=0.35)\n",
    "\n",
    "            if popt[1] > 1000 or popt[1] < 0:\n",
    "                x_cross = np.nan\n",
    "            else:\n",
    "                x_cross = float(popt[1])\n",
    "                ax_dataset.axvline(x=x_cross, ymax=0.5, color=colors[i], linestyle='--', alpha=1, linewidth=1)\n",
    "        else:\n",
    "            ax_dataset.plot(x_data, y_data, label=str(n_mem), color=colors[i], markersize=4)\n",
    "            x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "            if not np.isnan(x_cross):\n",
    "                ax_dataset.axvline(x=x_cross, ymax=0.5, color=colors[i], linestyle='--', alpha=1, linewidth=1)\n",
    "\n",
    "        crossings.append((int(n_mem), float(x_cross) if not np.isnan(x_cross) else np.nan))\n",
    "\n",
    "    # Random subplot (bottom-left)\n",
    "    for i, n_mem in enumerate(n_mems):\n",
    "        subset_r = grouped_rand[grouped_rand['n_mem'] == n_mem]\n",
    "        if subset_r.empty:\n",
    "            crossings_rand.append((int(n_mem), np.nan))\n",
    "            continue\n",
    "        x_data = subset_r['length'].values\n",
    "        y_data = subset_r['repeatability'].values\n",
    "\n",
    "        x_cross = np.nan\n",
    "        if fit_sigmoid and len(x_data) >= 3:\n",
    "            p0 = [1.0, float(np.median(x_data)), 0.1]\n",
    "            popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
    "            x_smooth = np.linspace(x_data.min(), x_data.max(), 200)\n",
    "            y_smooth = sigmoid(x_smooth, *popt)\n",
    "            y_fit = sigmoid(x_data, *popt)\n",
    "\n",
    "            r2_fit = _r2(y_data, y_fit)\n",
    "            print(f\"{model} - Random n_mem={n_mem}: R²={r2_fit:.3f}\")\n",
    "\n",
    "            ax_rand.plot(x_smooth, y_smooth, color=colors_rand[i], linewidth=1, linestyle='-', alpha=0.9, label=n_mem)\n",
    "            ax_rand.plot(x_data, y_data, color=colors_rand[i], linestyle=':', alpha=0.3)\n",
    "            ax_rand.scatter(x_data, y_data, color=colors_rand[i], s=8, alpha=0.35)\n",
    "\n",
    "            if not (popt[1] > 1000 or popt[1] < 0):\n",
    "                x_cross = float(popt[1])\n",
    "                ax_rand.axvline(x=x_cross, ymax=0.5, color=colors_rand[i], linestyle='--', alpha=0.9, linewidth=1)\n",
    "        else:\n",
    "            ax_rand.plot(x_data, y_data, color=colors_rand[i], markersize=4)\n",
    "            x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "            if not np.isnan(x_cross):\n",
    "                ax_rand.axvline(x=x_cross, ymax=0.5, color=colors_rand[i], linestyle='--', alpha=0.9, linewidth=1)\n",
    "\n",
    "        crossings_rand.append((int(n_mem), float(x_cross) if not np.isnan(x_cross) else np.nan))\n",
    "\n",
    "    # Styling for dataset subplot\n",
    "    ax_dataset.set_ylabel('Acc. (PG19)', fontsize=10)\n",
    "    ax_dataset.set_yticks([0.0, 0.5, 1.0])\n",
    "    ax_dataset.set_title(f'{model.split(\"_\")[-1].capitalize()}', fontsize=10)\n",
    "    ax_dataset.set_ylim(-0.1, 1.1)\n",
    "    ax_dataset.spines['top'].set_visible(False)\n",
    "    ax_dataset.spines['right'].set_visible(False)\n",
    "    ax_dataset.xaxis.set_ticks_position('bottom')\n",
    "    ax_dataset.yaxis.set_ticks_position('left')\n",
    "    ax_dataset.grid(False)\n",
    "    legend_ds = ax_dataset.legend(fontsize=9, title='$m$ (tokens)', title_fontsize=9, loc='upper right')\n",
    "    legend_ds.get_frame().set_linewidth(0.)\n",
    "    ax_dataset.tick_params(labelbottom=False)  # share x-axis; hide top labels\n",
    "\n",
    "    # Styling for random subplot\n",
    "    ax_rand.set_xlabel('$n$ (tokens)', fontsize=10)\n",
    "    ax_rand.set_ylabel('Acc. (Random)', fontsize=10)\n",
    "    ax_rand.set_yticks([0.0, 0.5, 1.0])\n",
    "    # ax_rand.set_title('Random', fontsize=10)\n",
    "    ax_rand.set_ylim(-0.1, 1.1)\n",
    "    ax_rand.spines['top'].set_visible(False)\n",
    "    ax_rand.spines['right'].set_visible(False)\n",
    "    ax_rand.xaxis.set_ticks_position('bottom')\n",
    "    ax_rand.yaxis.set_ticks_position('left')\n",
    "    ax_rand.grid(False)\n",
    "    legend_rand = ax_rand.legend(fontsize=9, title='$m$ (tokens)', title_fontsize=9, loc='upper right')\n",
    "    legend_rand.get_frame().set_linewidth(0.)\n",
    "\n",
    "\n",
    "    # Right axis unchanged\n",
    "    mems = np.array([m for m, cx in crossings])\n",
    "    cxs = np.array([cx for m, cx in crossings], dtype=float)\n",
    "    mask = ~np.isnan(cxs)\n",
    "    mem_arr = mems[mask].astype(float)\n",
    "    cross_arr = cxs[mask].astype(float)\n",
    "\n",
    "    mems_r = np.array([m for m, cx in crossings_rand])\n",
    "    cxs_r = np.array([cx for m, cx in crossings_rand], dtype=float)\n",
    "    mask_r = ~np.isnan(cxs_r)\n",
    "    mem_arr_r = mems_r[mask_r].astype(float)\n",
    "    cross_arr_r = cxs_r[mask_r].astype(float)\n",
    "\n",
    "    ax_lin.set_title('', fontsize=10)\n",
    "    ax_lin.set_xlabel('$m$ (tokens)', fontsize=10)\n",
    "    ax_lin.set_ylabel('$n$ at Accessibility=50%', fontsize=10)\n",
    "    ax_lin.spines['top'].set_visible(False)\n",
    "    ax_lin.spines['right'].set_visible(False)\n",
    "    ax_lin.xaxis.set_ticks_position('bottom')\n",
    "    ax_lin.yaxis.set_ticks_position('left')\n",
    "    ax_lin.grid(False)\n",
    "\n",
    "    if mem_arr.size > 0:\n",
    "        cmap2 = plt.get_cmap('Blues')\n",
    "        colors2 = cmap2(np.linspace(0.4, 0.9, len(mem_arr)))\n",
    "        for i, (m, cx) in enumerate(zip(mem_arr, cross_arr)):\n",
    "            ax_lin.scatter(m, cx, color=colors2[i], s=40, zorder=5, label=None)\n",
    "\n",
    "    if mem_arr_r.size > 0:\n",
    "        cmap3 = plt.get_cmap('Reds')\n",
    "        colors3 = cmap3(np.linspace(0.4, 0.9, len(mem_arr_r)))\n",
    "        for i, (m, cx) in enumerate(zip(mem_arr_r, cross_arr_r)):\n",
    "            ax_lin.scatter(m, cx, color=colors3[i], s=40, marker='x', zorder=5, label=None)\n",
    "\n",
    "    legends = []\n",
    "    if mem_arr.size >= 2:\n",
    "        slope, intercept = np.polyfit(mem_arr, cross_arr, 1)\n",
    "        y_pred = slope * mem_arr + intercept\n",
    "        ss_res = np.sum((cross_arr - y_pred) ** 2)\n",
    "        ss_tot = np.sum((cross_arr - np.mean(cross_arr)) ** 2)\n",
    "        r2 = 1.0 - ss_res / ss_tot if ss_tot != 0 else np.nan\n",
    "\n",
    "        xs = np.linspace(mem_arr.min() - 0.2, mem_arr.max() + 0.2, 200)\n",
    "        ys = slope * xs + intercept\n",
    "        l1, = ax_lin.plot(xs, ys, color='black', linewidth=1, linestyle='--', zorder=2)\n",
    "        legends.append((l1, f'Dataset fit: $R^2$={r2:.3f}, a={slope:.2f}'))\n",
    "\n",
    "    if mem_arr_r.size >= 2:\n",
    "        slope_r, intercept_r = np.polyfit(mem_arr_r, cross_arr_r, 1)\n",
    "        y_pred_r = slope_r * mem_arr_r + intercept_r\n",
    "        ss_res_r = np.sum((cross_arr_r - y_pred_r) ** 2)\n",
    "        ss_tot_r = np.sum((cross_arr_r - np.mean(cross_arr_r)) ** 2)\n",
    "        r2_r = 1.0 - ss_res_r / ss_tot_r if ss_tot_r != 0 else np.nan\n",
    "\n",
    "        xs_all_min = min(mem_arr.min() if mem_arr.size > 0 else mem_arr_r.min(), mem_arr_r.min())\n",
    "        xs_all_max = max(mem_arr.max() if mem_arr.size > 0 else mem_arr_r.max(), mem_arr_r.max())\n",
    "        xs_r = np.linspace(xs_all_min - 0.2, xs_all_max + 0.2, 200)\n",
    "        ys_r = slope_r * xs_r + intercept_r\n",
    "        l2, = ax_lin.plot(xs_r, ys_r, color='gray', linewidth=1, linestyle=':', zorder=2)\n",
    "        legends.append((l2, f'Rand fit: $R^2$={r2_r:.3f}, a={slope_r:.2f}'))\n",
    "\n",
    "    if legends:\n",
    "        handles, labels = zip(*legends)\n",
    "        ax_lin.legend(handles, labels, fontsize=9, loc='upper left', frameon=False)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    if save:\n",
    "        plt.savefig(f'figures/{model}_both.pdf', format='pdf', bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "    return crossings\n",
    "\n",
    "for model in MODELS:\n",
    "    plot_accessibility_curves(model, fit_sigmoid=True, save=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea6974f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/2287763085.py:26: RuntimeWarning: overflow encountered in exp\n",
      "  return 1 / (1 + np.exp(-k * (x - x0)))\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
      "/tmp/ipykernel_3102395/1910863949.py:42: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n"
     ]
    },
    {
     "data": {
      "image/png": "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qQt1DJ6zvcqP89vSQViaP/gW7pdffuGdd97BzMyMfv36ERISwqlTp7hz5w4zZ84kJycHCwsLgoOD6dKlCwCbNm3ik08+AaBBgwasWbMGd3d3NBoNr732Gn/88Qf29vZ06dKF06dPG2+I77V7924WL15Mfn4+CoWCpUuXEhgYeN84k5KSGD9+PDdv3qR+/frY29vj5eXFggUL0Gg0vP/+++zfv5/CwkJatGjB6tWrqVu3LhMmTMDMzIxr165x9epVAgMDmTp1Km+//TYJCQkMGTKEzz//HIAePXrQrl07IiIiiIuLY/z48QQEBLBkyRJu3rzJzJkzef311wF48803OXToEBqNBqVSydq1a/H09Cwx9rvJBIBKpbrv9cXCwqJI751OnTrx6aeflrhtSEgIkyZNMr7evHkzISEhADRu3JgePXrw888/89JLL5XpvKpamROKN954g2+++YbAwEC++uorJkyYwPvvv8+ZM2dYvHgxbdu2JTg4mP79+1dFvIIgCIJQandbJ+zdzHFrIVonhCfD7du3mThxIkePHsXLy4sNGzaQlpZGYWEhw4YNY+3atQQFBfHnn3/y3HPPERsbS1xcHG+99RanT5/G3d2dDz/8kJdeeonff/+dNWvWEBMTw4ULFwDu27X92rVrLFiwgN27d6NUKomNjaVbt27ExcVhbm5e4ntmzpxJQEAACxcuJDk5GT8/P7y8vAD45JNPsLa25uTJkwAsXryYefPm8eWXXwIQFRXFgQMHkMvleHt7k5GRwd69eyksLKRJkyZMmjSJVq1aARAfH8+BAwfIysrCw8ODjIwMjhw5QmJiIp6enkycOBE7OzvmzJljvNn//vvvee2119i1a9d9P+tx48Zx4MABwPDAvTS++OILnn322WLLb9y4waFDh9i0aZNxWUJCAo0aNTK+9vDwICEhwfi6tOdV1cqcUISGhrJnzx7atWtHeno6nTp14v3338fMzIzFixczatQoXn75ZZFQCIIgCDVKnftP64RvoGidEKqehZmC35YOqpbjPMjx48fx9fU13piPHz+eqVOnUlBQgFwuJygoCICuXbvi4uJCZGQkZ8+epV+/fri7uwMwbdo0Fi1ahE6nY9++fYwdOxZTU1Pj/tatW1fsuLt27SI2Npbu3bsbl8nlchISEmjevHmJse7bt894A+/q6sqgQf98ftu2bUOl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FZ780xO5RynJP/uEI/coJflHiHCQgiIEzz77rMrOzlYWi0WNGzdOLV++vFvxvvzySwUc9DNr1qxuxT1UTEC9/PLL3Yp73XXXqZycHGWxWFRycrKaOnVqr31DV0qpK6+8UqWnpyuLxaL69eunrrzySrVjx45ux/3www/V8OHDldVqVYMHD1Yvvvhit2MqpdSCBQsUoLZu3RqWeEop5XA41C233KKys7OVzWZT+fn56r777lNut7vbsd98802Vn5+vLBaLSktLUzfddJNqaWk5phhHeg3ouq4eeOABlZqaqqxWq5o6dWpY/376inDnHqV6Jv/09dyjVHjyT0/lHqUk/ygVntyjlOQfIcJBUyoMR+UKIYQQQgghTknSQyGEEEIIIYQImRQUQgghhBBCiJBJQSGEEEIIIYQImRQUQgghhBBCiJBJQSGEEEIIIYQImRQUQgghhBBCiJBJQSGEEEIIIYQImRQUQgghhBBCiJBJQSGEEEIIIYQImRQUQgghhBBCiJBJQSH6hMbGRlJSUigvL+92rLPOOotbb72123FC9ZOf/IQnn3zyhD2+EOLoSe4RQogjk4JC9Alz5sxh5syZ5ObmBq+d6DfnUN1///3MmTOH1tbWEz0UIcQRSO4RQogjk4JC9HpOp5OXXnqJ66+//kQPJSyGDx9O//79eeWVV070UIQQP0ByjxBCHB0pKESPKi8vR9M03nnnHc444wzsdjtjx45l165dfPPNN0yYMIGIiAimTp1KS0vLIWN88sknWK1WJkyYELx27bXXsnjxYp555hk0TUPTNMrLy3G73dx8882kpKRgs9mYPHkyq1at+sExfvzxx8TGxvLqq68CoOs6c+fOJS8vD7vdTlFREW+//Xbw9meddRY333wzd955JwkJCaSlpTF79uwuMd9++20KCwux2+0kJiYybdo0Ojo6gr+/+OKLeeONN47xb1MIcbQk90juEUIcR0qIHvT+++8rQE2dOlV98803as2aNSorK0tNmTJFXXjhhWrVqlVq+fLlKjExUT311FOHjHHzzTer888/v8u1lpYWNXHiRPXf//3fqrq6WlVXVyufz6duvvlmlZGRoT755BO1ceNGNWvWLBUfH68aGxuD9z3zzDPVLbfcopRS6tVXX1XR0dHqww8/DP7+d7/7nRo8eLD69NNP1c6dO9XLL7+srFar+uqrr4L3j4mJUbNnz1bbtm1T//znP5Wmaeqzzz5TSim1Z88eZTKZ1FNPPaXKysrUunXr1PPPP6/a2tqCjzF//nxlsViUy+UKy9+zEKIryT2Se4QQx48UFKJHzZ49WyUkJKiGhobgtZ/97GcqNzdXdXR0BK+df/756s477zxkjJkzZ6rrrrvuoOsHvjkrpVR7e7sym83q1VdfDV7zeDwqIyNDzZs376D7Pffccyo2Njb4Zq2UUi6XS0VERKhvv/22y2Ndf/316qqrrgref/LkyV1+P3bsWHXXXXcppZRavXq1AlR5eflh/15KSkqOeBshROgk9xya5B4hRE8wncjZEXHyKykp4bLLLiMxMTF4bdeuXVx55ZVERER0uTZz5sxDxujs7MRmsx3xsXbu3InX62XSpEnBa2azmXHjxrF58+Yut3377bepq6tj6dKljB07Nnh9x44dOJ1Ozj333C6393g8jBo1KvjnESNGdPl9eno6dXV1ABQVFTF16lQKCwuZPn065513Hpdffjnx8fHB29vtdiCwRlsIEX6SeyT3CCGOH+mhED2quLiY8ePHd7lWUlLSZU2yy+Vi69atFBUVHTJGUlISzc3NYR3XqFGjSE5O5u9//ztKqeD19vZ2ILC2ubi4OPizadOmLmuZzWZzl3iapqHrOgBGo5GFCxcyf/58hg4dyrPPPsugQYMoKysL3r6pqQmA5OTksD4vIUSA5B7JPUKI40cKCtFjHA4H5eXlXb5dKysro7W1tcu19evXo5SisLDwkHFGjRrFpk2bDrpusVjw+/3BP/fv3x+LxcLSpUuD17xeL6tWrWLo0KFd7tu/f3++/PJLPvjgA379618Hrw8dOhSr1cquXbsoKCjo8pOVlXXUz13TNCZNmsTDDz/M2rVrsVgsvPfee8Hfb9iwgczMTJKSko46phDi6EjukdwjhDi+ZMmT6DElJSUYjUaGDx8evFZcXExCQgI5OTldrvXv35+oqKhDxpk+fTr33HMPzc3NXabuc3NzWbFiBeXl5URFRZGQkMAvf/lLfvvb35KQkEB2djbz5s3D6XQectvHgQMH8uWXX3LWWWdhMpl4+umniY6O5o477uA3v/kNuq4zefJkWltbWbp0KTExMcyaNeuIz3vFihUsWrSI8847j5SUFFasWEF9fT1DhgwJ3uabb77hvPPOO6q/RyHEsZHcI7lHCHF8SUEhekxJSQmDBg3qsga5pKSkyzeE+64dbskBQGFhIaNHj+att97iF7/4RfD6HXfcwaxZsxg6dCidnZ2UlZXx+OOPo+s611xzDW1tbYwZM4YFCxZ0+TBwoEGDBvHFF19w1llnYTQaefLJJ3n00UdJTk5m7ty5lJaWEhcXx+jRo7n33nuP6nnHxMTw9ddf8/TTT+NwOMjJyeHJJ5/kggsuAALLLN5//30+/fTTo4onhDg2knsk9wghji9NHbiIU4he6uOPP+a3v/0tGzZswGDo2yv1XnjhBd577z0+++yzEz0UIcQRSO4RQogjkxkK0SfMmDGD7du3U1VVdUzriXsjs9nMs88+e6KHIYQ4CpJ7hBDiyGSGQgghhBBCCBGyvj1/K4QQQgghhDihpKAQQgghhBBChEwKCiGEEEIIIUTIpKAQQgghhBBChEwKCiGEEEIIIUTIpKAQQgghhBBChEwKCiGEEEIIIUTIpKAQQgghhBBChEwKCiGEEEIIIUTIpKAQQgghhBBChOz/A/XaYC7/ZIkWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax_l, ax_r) = plt.subplots(1, 2, figsize=(8, 3), sharey=True)\n",
    "models_colors = {\n",
    "    'google_gemma-3-1b-pt'  :   \"#6FA8DC\",\n",
    "    'google_gemma-3-270m' :     \"#2E5FA7\",\n",
    "    'meta-llama_Llama-3.2-1B' : \"#2F7D32\",\n",
    "    'EleutherAI_pythia-160m' :  \"#E6D9F2\",\n",
    "    'EleutherAI_pythia-410m' :  \"#C3A6E8\",\n",
    "    'EleutherAI_pythia-1b' :    \"#9A6FD6\",\n",
    "    'EleutherAI_pythia-1.4b' :  \"#6F42B8\",\n",
    "    'EleutherAI_pythia-2.8b' :  \"#4B1F8C\",\n",
    "    'Qwen_Qwen2.5-0.5B' :       \"#D2583A\"\n",
    "}\n",
    "cmap = plt.get_cmap('tab10')\n",
    "\n",
    "agg_dict = {'repeatability': 'mean'}\n",
    "\n",
    "for i, m in enumerate(MODELS):\n",
    "    file_rnd = f'runs/{m}/data_rnd_vocab_100k.csv'\n",
    "    file_ds  = f'runs/{m}/data_dataset.csv'\n",
    "\n",
    "    for ax, fp, marker, label in [\n",
    "        (ax_l, file_rnd, 'x', 'rnd'),\n",
    "        (ax_r, file_ds,  'o', 'dataset')\n",
    "    ]:\n",
    "        if not os.path.exists(fp):\n",
    "            continue\n",
    "        df = pd.read_csv(fp)\n",
    "        grouped = df.groupby(['n_mem', 'length']).agg(agg_dict).reset_index()\n",
    "        mems = sorted(grouped['n_mem'].unique())\n",
    "        xs = []\n",
    "        ys = []\n",
    "        for n_mem in mems:\n",
    "            sub = grouped[grouped['n_mem'] == n_mem]\n",
    "            x_data = sub['length'].values\n",
    "            y_data = sub['repeatability'].values\n",
    "            if len(x_data) == 0:\n",
    "                continue\n",
    "            x_cross = np.nan\n",
    "            if len(x_data) >= 3:\n",
    "                try:\n",
    "                    p0 = [1.0, float(np.median(x_data)), 0.1]\n",
    "                    popt, _ = curve_fit(sigmoid, x_data, y_data, p0=p0, maxfev=10000)\n",
    "                    if 0 <= popt[1] <= 1000:\n",
    "                        x_cross = float(popt[1])\n",
    "                except Exception:\n",
    "                    x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "            else:\n",
    "                x_cross = crossing_nearest(x_data, y_data, 0.5, max_tol=0.1)\n",
    "\n",
    "            if not np.isnan(x_cross):\n",
    "                xs.append(float(n_mem))\n",
    "                ys.append(x_cross)\n",
    "\n",
    "        if xs:\n",
    "            ax.plot(xs, ys, color=models_colors[m],  label=m if ax is ax_r else None, alpha=0.9)\n",
    "\n",
    "# style\n",
    "for ax, title in [(ax_l, 'rnd'), (ax_r, 'dataset')]:\n",
    "    ax.set_xlabel('$m$ (tokens)')\n",
    "    ax.set_title(title)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.xaxis.set_ticks_position('bottom')\n",
    "    ax.yaxis.set_ticks_position('left')\n",
    "    ax.set_yticks([0, 500, 1000])\n",
    "    ax.set_xticks([0, 1, 2,3,4,5,6,7,8,9,10])\n",
    "ax_l.set_ylabel('$n$ at Accessibility=50%')\n",
    "ax_r.legend(fontsize=8, bbox_to_anchor=(1.02, 1), loc='upper left')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5974cd56",
   "metadata": {},
   "source": [
    "## Elementary operations "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1160f6b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "cmap = plt.get_cmap('Blues', 10)    # 2 discrete colors\n",
    "colors = cmap([0.4, 0.5, 0.6, 0.7, 0.8])  # Select two colors from the colormap\n",
    "print(colors)\n",
    "# Read the CSV file\n",
    "data_1 = pd.read_csv('../../llm_vis/base_operations_results.bkp.csv')\n",
    "# Plot 2: Repeatability metrics\n",
    "# Group by length and calculate mean repeatability and curr_avg_repeatability\n",
    "d = {\n",
    "    'equal': 'mean',\n",
    "    'id_sample': 'last'\n",
    "}\n",
    "# model,perturb_type,perturb_prop,input_length,id_sample,equal\n",
    "grouped_data_1 = data_1.groupby(['model', 'input_length', 'perturb_prop']).agg(d).reset_index()\n",
    "grouped_data_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d9ebc54",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "data = grouped_data_1[~(grouped_data_1['input_length'] == 512)]\n",
    "# draw one curve per model (sorted by perturb_prop)\n",
    "models = data['model'].unique()\n",
    "lengths = data['input_length'].unique()\n",
    "model_cmap = plt.get_cmap('tab10')\n",
    "model_markers = ['o', 's', '^', 'D', 'v', 'P', '*', 'X', '<', '>']\n",
    "# one marker for each length\n",
    "length_marker_map = {length: model_markers[i % len(model_markers)] for i, length in enumerate(lengths)}\n",
    "print(data['input_length'].map(length_marker_map))\n",
    "# scatter points with a marker per input_length (no legend entries here)\n",
    "for length in lengths:\n",
    "    mk = length_marker_map[length]\n",
    "    sub = data[data['input_length'] == length]\n",
    "    ax.scatter(sub['perturb_prop'], sub['equal'],\n",
    "               s=50, alpha=0.9, edgecolor='k', linewidth=0.3,\n",
    "               marker=mk, label='_nolegend_')\n",
    "\n",
    "# create a separate legend for input_length markers\n",
    "handles = [ax.scatter([], [], s=60, edgecolor='k', linewidth=0.3, marker=length_marker_map[l], color='gray') \n",
    "           for l in length_marker_map]\n",
    "labels = [str(l) for l in length_marker_map]\n",
    "len_legend = ax.legend(handles, labels, title='input_length', loc='lower left', fontsize=8)\n",
    "ax.add_artist(len_legend)\n",
    "\n",
    "for i, model in enumerate(models):\n",
    "    g = grouped_data_1[grouped_data_1['model'] == model].sort_values('perturb_prop')\n",
    "    ax.plot(g['perturb_prop'], g['equal'],\n",
    "            label=model, color=model_cmap(i % 10), linewidth=1.5)\n",
    "\n",
    "ax.set_xlabel('prob (perturb_prop)', fontsize=10)\n",
    "ax.set_ylabel('equal', fontsize=10)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.xaxis.set_ticks_position('bottom')\n",
    "ax.yaxis.set_ticks_position('left')\n",
    "# ax.set_xscale('log')\n",
    "# ax.set_yscale('log')\n",
    "ax.legend(fontsize=8, bbox_to_anchor=(1.02, 1), loc='upper left')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b06898c",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axes = plt.subplots(1, len(lengths), figsize=(15, 4), sharey=True)\n",
    "\n",
    "for ax, length in zip(axes.ravel(), lengths):\n",
    "    sub = data[data['input_length'] == length]\n",
    "    # scatter the points for this input_length\n",
    "    mk = length_marker_map[length]\n",
    "    ax.scatter(sub['perturb_prop'], sub['equal'],\n",
    "               s=50, alpha=0.9, edgecolor='k', linewidth=0.3,\n",
    "               marker=mk, color='gray', label='_nolegend_')\n",
    "    # plot one line per model for this input_length\n",
    "    for i, model in enumerate(models):\n",
    "        g = grouped_data_1[(grouped_data_1['model'] == model) & (grouped_data_1['input_length'] == length)].sort_values('perturb_prop')\n",
    "        if not g.empty:\n",
    "            ax.plot(g['perturb_prop'], g['equal'],\n",
    "                    label=model if (length == lengths[0]) else None,  # show legend labels only on first subplot\n",
    "                    color=model_cmap(i % 10), linewidth=1.5)\n",
    "    ax.set_title(f'input_length = {length}', fontsize=10)\n",
    "    ax.set_xlabel('prob (perturb_prop)', fontsize=10)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.xaxis.set_ticks_position('bottom')\n",
    "    ax.yaxis.set_ticks_position('left')\n",
    "    # ax.set_xscale('log')\n",
    "\n",
    "# shared y label\n",
    "axes[0].set_ylabel('equal', fontsize=10)\n",
    "\n",
    "# legend for models (place on the first subplot)\n",
    "axes[0].legend(fontsize=8, bbox_to_anchor=(1.02, 1), loc='upper left')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d15f496d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llm_vis",
   "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.9.23"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
