{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ed16e2ff",
   "metadata": {},
   "source": [
    "## Part 0: imported packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "fafc94bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from itertools import product\n",
    "from scipy.stats import norm\n",
    "from scipy.optimize import brentq\n",
    "import pandas as pd\n",
    "from scipy.stats import truncnorm\n",
    "from tqdm.notebook  import tqdm\n",
    "\n",
    "from scipy.integrate import quad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "525e738a",
   "metadata": {},
   "outputs": [],
   "source": [
    "class DataDistribution(object):\n",
    "    def __init__(self, alpha_min, x_max, theta_star, x, rng):\n",
    "        self.alpha_min = alpha_min\n",
    "        self.x_theta = x @ theta_star\n",
    "        self.x_max_theta = x_max @ theta_star\n",
    "        self.b = self.x_max_theta / self.x_theta\n",
    "        self.rng = rng\n",
    "\n",
    "        self.b_tilde = alpha_min / (2 * (1 - alpha_min))\n",
    "        self.a = ((self.b + 3 * self.b_tilde + 1) - np.sqrt((self.b + 3 * self.b_tilde + 1) ** 2 - 4 * (self.b + self.b_tilde + 2 * self.b_tilde * self.b))) / 2\n",
    "        self.c = (2 * self.b_tilde) / (self.a - 1) - 1\n",
    "        self.h = (1 - alpha_min) / (2 * self.x_theta)\n",
    "\n",
    "        self.y_min = - self.x_max_theta\n",
    "        self.y_max = self.x_max_theta\n",
    "\n",
    "        self.pdf_max = max(self.h, self.h * self.c)\n",
    "\n",
    "        # Precompute slopes/intercepts for each linear segment of the symmetric PDF\n",
    "        self.linear_slope = self.h * (self.c - 1) / ((self.a - 1) * self.x_theta)\n",
    "        self.linear_intercept = self.h - self.linear_slope * self.x_theta\n",
    "        self.segments = [\n",
    "            (-self.x_max_theta, -self.a * self.x_theta, 0.0, self.h * self.c),\n",
    "            (-self.a * self.x_theta, -self.x_theta, -self.linear_slope, self.linear_intercept),\n",
    "            (-self.x_theta, self.x_theta, 0.0, self.h),\n",
    "            (self.x_theta, self.a * self.x_theta, self.linear_slope, self.linear_intercept),\n",
    "            (self.a * self.x_theta, self.x_max_theta, 0.0, self.h * self.c)\n",
    "        ]\n",
    "\n",
    "    def get_pdf(self, y):\n",
    "        abs_y = np.abs(y)\n",
    "        if abs_y <= self.x_theta:\n",
    "            return self.h\n",
    "        elif abs_y < self.a * self.x_theta:\n",
    "            frac = (abs_y - self.x_theta) / (self.a * self.x_theta - self.x_theta)\n",
    "            return (1-frac) * self.h + frac * self.h * self.c\n",
    "        elif abs_y <= self.x_max_theta:\n",
    "            return self.h * self.c\n",
    "        else:\n",
    "            return 0\n",
    "\n",
    "    def _get_cdf_pos(self, y):\n",
    "        if y < self.x_theta:\n",
    "            return self.h * y + 1 / 2\n",
    "        elif y < self.a * self.x_theta:\n",
    "            s = 1 / 2 + self.h * self.x_theta\n",
    "            frac = (y - self.x_theta) / (self.a * self.x_theta - self.x_theta)\n",
    "\n",
    "            h1 = self.h\n",
    "            h2 = (1-frac) * self.h + frac * self.h * self.c\n",
    "            area  = (h1 + h2) / 2 * (y - self.x_theta)\n",
    "            return s + area\n",
    "        elif y < self.x_max_theta:\n",
    "            return 1 - (self.x_max_theta - y) * self.c * self.h\n",
    "        else:\n",
    "            return 1\n",
    "    \n",
    "    def get_cdf(self, y):\n",
    "        \"\"\"\n",
    "        Cumulative Distribution Function for the symmetric piecewise linear PDF.\n",
    "        The PDF is symmetric around 0, so we compute CDF for y >= 0 and handle negative y by symmetry.\n",
    "        \"\"\"\n",
    "        if y >= 0:\n",
    "            return self._get_cdf_pos(y)\n",
    "        else:\n",
    "            return 1 - self._get_cdf_pos(-y)\n",
    "\n",
    "    def get_piecewise_segments(self):\n",
    "        \"\"\"Return list of (start, end, slope, intercept) describing the base PDF.\"\"\"\n",
    "        return self.segments\n",
    "\n",
    "    def sample(self):\n",
    "        f_max = self.pdf_max\n",
    "        g_max = 1 / (self.y_max - self.y_min) # uniform distribution\n",
    "        M = f_max / g_max\n",
    "        while True:\n",
    "            u = self.rng.uniform(low=0, high=1, size=1)\n",
    "            x = self.rng.uniform(low=self.y_min, high=self.y_max, size=1)\n",
    "            if u <= self.get_pdf(x) / (g_max * (self.y_max - self.y_min)):\n",
    "                return x\n",
    "\n",
    "    def quantile_interval(self, gamma_lo, gamma_hi):\n",
    "        q1 = brentq(lambda x: self.get_cdf(x) - gamma_lo, -100, 100, xtol=1e-12, rtol=1e-10, maxiter=200)\n",
    "        q2 = brentq(lambda x: self.get_cdf(x) - gamma_hi, -100, 100, xtol=1e-12, rtol=1e-10, maxiter=200)\n",
    "        return q2 - q1\n",
    "\n",
    "\n",
    "x = np.linspace(-20, 20, 500)\n",
    "data = DataDistribution(0.05, np.array([20, 20]), np.array([2, 2]), np.array([1, 1]), rng=np.random.default_rng(42))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "442a983b",
   "metadata": {},
   "outputs": [],
   "source": [
    "class GaussianSmoothedDistribution(object):\n",
    "    def __init__(self, base_dist, sigma_factor=0.1):\n",
    "        \"\"\"\n",
    "        sigma = sigma_factor * x^T theta\n",
    "        \"\"\"\n",
    "        self.base = base_dist\n",
    "        self.sigma = sigma_factor * float(base_dist.x_theta)\n",
    "        self.rng = base_dist.rng\n",
    "\n",
    "        self.y_min_base = base_dist.y_min\n",
    "        self.y_max_base = base_dist.y_max\n",
    "\n",
    "        self.y_min = self.y_min_base - 8 * self.sigma\n",
    "        self.y_max = self.y_max_base + 8 * self.sigma\n",
    "        self.segments = base_dist.get_piecewise_segments()\n",
    "\n",
    "    @staticmethod\n",
    "    def _A(z):\n",
    "        return z * norm.cdf(z) + norm.pdf(z)\n",
    "\n",
    "    @staticmethod\n",
    "    def _B(z):\n",
    "        Phi = norm.cdf(z)\n",
    "        phi = norm.pdf(z)\n",
    "        return 0.5 * z ** 2 * Phi + 0.5 * z * phi - 0.5 * Phi\n",
    "\n",
    "    def _pdf_segment(self, y, seg):\n",
    "        start, end, slope, intercept = seg\n",
    "        s1 = (start - y) / self.sigma\n",
    "        s2 = (end - y) / self.sigma\n",
    "        delta = norm.cdf(s2) - norm.cdf(s1)\n",
    "        phi_diff = norm.pdf(s1) - norm.pdf(s2)\n",
    "        return (slope * y + intercept) * delta + slope * self.sigma * phi_diff\n",
    "\n",
    "    def _cdf_segment(self, y, seg):\n",
    "        start, end, slope, intercept = seg\n",
    "        su = (y - start) / self.sigma\n",
    "        sv = (y - end) / self.sigma\n",
    "        delta_A = self._A(su) - self._A(sv)\n",
    "        delta_B = self._B(su) - self._B(sv)\n",
    "        return self.sigma * ((slope * y + intercept) * delta_A - slope * self.sigma * delta_B)\n",
    "\n",
    "    def get_pdf(self, y):\n",
    "        y_arr = np.asarray(y, dtype=float)\n",
    "        res = np.zeros_like(y_arr)\n",
    "        for seg in self.segments:\n",
    "            res += self._pdf_segment(y_arr, seg)\n",
    "        res = np.maximum(res, 0.0)\n",
    "        if res.shape == ():\n",
    "            return float(res)\n",
    "        return res\n",
    "\n",
    "    def get_cdf(self, y):\n",
    "        y_arr = np.asarray(y, dtype=float)\n",
    "        res = np.zeros_like(y_arr)\n",
    "        for seg in self.segments:\n",
    "            res += self._cdf_segment(y_arr, seg)\n",
    "        res = np.clip(res, 0.0, 1.0)\n",
    "        if res.shape == ():\n",
    "            return float(res)\n",
    "        return res\n",
    "\n",
    "    def sample(self):\n",
    "        y_base = self.base.sample()\n",
    "        noise = self.rng.normal(loc=0.0, scale=self.sigma, size=1)\n",
    "        return y_base + noise\n",
    "\n",
    "    def quantile_interval(self, gamma_lo, gamma_hi):\n",
    "        q1 = brentq(lambda z: self.get_cdf(z) - gamma_lo,\n",
    "                    self.y_min, self.y_max,\n",
    "                    xtol=1e-8, rtol=1e-6, maxiter=200)\n",
    "        q2 = brentq(lambda z: self.get_cdf(z) - gamma_hi,\n",
    "                    self.y_min, self.y_max,\n",
    "                    xtol=1e-8, rtol=1e-6, maxiter=200)\n",
    "        return q2 - q1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "912a3141",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Dataset(object):\n",
    "    def __init__(self, d, alpha_min, rng):\n",
    "        self.d = d\n",
    "        self.rng = rng\n",
    "        self.alpha_min = alpha_min \n",
    "        self._X_min = 1\n",
    "        self._X_max = 20\n",
    "        self._theta_min = 1\n",
    "        self._theta_max = 2\n",
    "\n",
    "        self.theta = self.rng.uniform(low=self._theta_min, high=self._theta_max, size=(d,))\n",
    "        self.x_max = np.array([self._X_max, self._X_max])\n",
    "\n",
    "    def get_data_distribution(self, x):\n",
    "        base = DataDistribution(self.alpha_min, self.x_max, self.theta, x=x, rng=self.rng)\n",
    "        smoothed = GaussianSmoothedDistribution(\n",
    "            base_dist=base,\n",
    "            sigma_factor=0.05    # σ = 0.1 * x^T θ\n",
    "        )\n",
    "        return smoothed\n",
    "\n",
    "    def generate_X_y(self, n):\n",
    "        X = self.rng.uniform(low=self._X_min, high=self._X_max, size=(n, self.d))\n",
    "        distributions = [self.get_data_distribution(x_i) for x_i in X]\n",
    "        y = np.array([distribution.sample() for distribution in distributions]).flatten()\n",
    "        return X, y, distributions\n",
    "\n",
    "dataset = Dataset(2, 0.05, np.random.default_rng(42))\n",
    "X, y, _ = dataset.generate_X_y(100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "84dc8df0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((100, 2), (100,))"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape, y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "37c76dff",
   "metadata": {},
   "outputs": [],
   "source": [
    "# -------------------------- Quantile SGD (symmetric) --------------------------\n",
    "def pinball_loss(x, gamma):\n",
    "    return np.where(x >= 0, gamma * x, (gamma - 1) * x)\n",
    "\n",
    "def pinball_grad(x, gamma):\n",
    "    return np.where(x < 0, gamma-1, gamma)\n",
    "\n",
    "def sgd_quantile(X, Y, gamma, epochs=400, batch_size=64, lr0=0.00001, lr_decay=0.99, rng=None):\n",
    "    n, d = X.shape\n",
    "    theta = np.zeros(d) \n",
    "    theta_list = [theta.copy()]\n",
    "    loss_list = [np.mean(pinball_loss(Y - X @ theta, gamma))]\n",
    "    for ep in range(epochs):\n",
    "        idx = rng.permutation(n)\n",
    "        X_ep, Y_ep = X[idx], Y[idx]\n",
    "        lr = lr0 * (lr_decay**ep)\n",
    "        for start in range(0, n, batch_size):\n",
    "            stop = min(start+batch_size, n)\n",
    "            xb, yb = X_ep[start:stop], Y_ep[start:stop]\n",
    "            ghat = -xb.T @ pinball_grad(yb - xb @ theta, gamma) / (stop-start)\n",
    "            theta -= lr * ghat\n",
    "        theta_list.append(theta.copy())\n",
    "        loss_list.append(np.mean(pinball_loss(Y - X @ theta, gamma)))\n",
    "    return theta, theta_list, np.array(loss_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "2610a741",
   "metadata": {},
   "outputs": [],
   "source": [
    "# -------------------------- CQR utilities --------------------------\n",
    "def cqr_nc_score(X, Y, theta_lo, theta_hi):\n",
    "    t_low  = X @ theta_lo\n",
    "    t_high = X @ theta_hi\n",
    "    return np.maximum(t_low - Y, Y - t_high)\n",
    "\n",
    "def calibration_threshold(X_cal, y_cal, theta_lo, theta_hi, alpha):\n",
    "    m = len(y_cal)\n",
    "    nc_scores = cqr_nc_score(X_cal, y_cal, theta_lo, theta_hi)\n",
    "    k = int(np.ceil((1 - alpha) * (m + 1)))\n",
    "    cqr_threshold = np.partition(nc_scores, k-1)[k-1]\n",
    "    return cqr_threshold\n",
    "\n",
    "def excess_length(X, dataset, theta_n_lo, theta_n_hi, q_hat):\n",
    "    C_lo = X @ theta_n_lo - q_hat\n",
    "    C_up = X @ theta_n_hi + q_hat\n",
    "    true_interval = X @ dataset.theta_hi - X @ dataset.theta_lo\n",
    "    excess_len = (C_up - C_lo) - true_interval\n",
    "    return  true_interval, excess_len\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "677a7d2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def successive_halving_lr0_tuning(X_train, y_train, gamma, rng, epochs=1, \n",
    "                                 lr0_candidates=None, n_iterations=3, \n",
    "                                 eta=2, min_budget=1, debug=False):\n",
    "    \"\"\"\n",
    "    Successive Halving algorithm for tuning lr0 hyperparameter.\n",
    "    \n",
    "    Parameters:\n",
    "    -----------\n",
    "    X_train, y_train : training data\n",
    "    gamma : quantile level\n",
    "    rng : random number generator\n",
    "    epochs : number of training epochs\n",
    "    lr0_candidates : list of learning rates to try (if None, will generate automatically)\n",
    "    n_iterations : number of successive halving iterations\n",
    "    eta : elimination factor (how many candidates to eliminate each round)\n",
    "    min_budget : minimum number of candidates to keep\n",
    "    \n",
    "    Returns:\n",
    "    --------\n",
    "    best_lr0 : best learning rate found\n",
    "    best_loss : corresponding loss value\n",
    "    tuning_history : list of (iteration, candidates, losses) for each round\n",
    "    \"\"\"\n",
    "    def pprint(text):\n",
    "        if debug:\n",
    "            print(text)\n",
    "    \n",
    "    # Generate learning rate candidates if not provided\n",
    "    if lr0_candidates is None:\n",
    "        # Use log-uniform distribution for learning rates\n",
    "        lr0_candidates = np.logspace(-5, 0, 20)  # From 1e-5 to 1e-1\n",
    "    \n",
    "    tuning_history = []\n",
    "    current_candidates = lr0_candidates.copy()\n",
    "    \n",
    "    pprint(f\"Starting Successive Halving with {len(current_candidates)} candidates\")\n",
    "    pprint(f\"Learning rate range: [{min(current_candidates):.2e}, {max(current_candidates):.2e}]\")\n",
    "    \n",
    "    for iteration in range(n_iterations):\n",
    "        pprint(f\"\\n--- Iteration {iteration + 1} ---\")\n",
    "        pprint(f\"Evaluating {len(current_candidates)} candidates\")\n",
    "        \n",
    "        # Evaluate all current candidates\n",
    "        candidate_losses = []\n",
    "        \n",
    "        for i, lr0 in enumerate(current_candidates):\n",
    "            # Train model with current lr0\n",
    "            theta, _, loss_list = sgd_quantile(X_train, y_train, gamma=gamma, \n",
    "                                          rng=rng, epochs=epochs, lr0=lr0)\n",
    "            \n",
    "            # Use the last (final) loss value as evaluation metric\n",
    "            final_loss = loss_list[-1]\n",
    "            candidate_losses.append(final_loss)\n",
    "            \n",
    "            pprint(f\"  lr0={lr0:.2e}: final_loss={final_loss:.6f}\")\n",
    "        \n",
    "        # Store history\n",
    "        tuning_history.append({\n",
    "            'iteration': iteration + 1,\n",
    "            'candidates': current_candidates.copy(),\n",
    "            'losses': candidate_losses.copy()\n",
    "        })\n",
    "        \n",
    "        # Select top candidates for next round\n",
    "        if iteration < n_iterations - 1:  # Don't eliminate on last iteration\n",
    "            # Sort by loss (lower is better for quantile regression)\n",
    "            sorted_indices = np.argsort(candidate_losses)\n",
    "            \n",
    "            # Keep top candidates (eliminate worst ones)\n",
    "            n_keep = max(min_budget, len(current_candidates) // eta)\n",
    "            top_indices = sorted_indices[:n_keep]\n",
    "            \n",
    "            current_candidates = current_candidates[top_indices]\n",
    "            pprint(f\"Kept top {len(current_candidates)} candidates for next round\")\n",
    "        else:\n",
    "            best_idx = np.argmin(candidate_losses)\n",
    "            best_lr0 = current_candidates[best_idx]\n",
    "            best_loss = candidate_losses[best_idx]\n",
    "            \n",
    "            pprint(f\"\\nFinal best: lr0={best_lr0:.2e}, loss={best_loss:.6f}\")\n",
    "    \n",
    "    return theta, best_lr0, best_loss, tuning_history\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0099e3d0",
   "metadata": {},
   "source": [
    "## Part 2: Fix m = 5000, vary n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36b5b612",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n: 200, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 3.3031331109599043n: 200, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 112.67089019947825\n",
      "\n",
      "n: 350, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 6.118316717442887\n",
      "n: 200, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 104.69647137487657\n",
      "n: 200, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 5.518161288922621\n",
      "n: 500, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 4.536816517539787\n",
      "n: 500, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 112.6443775901215\n",
      "n: 200, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 63.229993498668954\n",
      "n: 350, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 5.739853082852192\n",
      "n: 200, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 49.044480285041836n: 350, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 91.31170996372606\n",
      "\n",
      "n: 200, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 8.424365251484964\n",
      "n: 500, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 3.7877803748892704\n",
      "n: 1000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 2.257518733714104\n",
      "n: 350, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 3.82877019289111\n",
      "n: 500, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 75.51573325668238\n",
      "n: 350, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 86.9933616223812\n",
      "n: 200, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 22.39371474714981\n",
      "n: 200, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 6.470986528485362\n",
      "n: 350, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 4.60045247330948\n",
      "n: 500, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 3.011410265540734\n",
      "n: 350, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 57.71213558326229\n",
      "n: 200, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 20.29795119281221\n",
      "n: 500, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 3.440247196783789\n",
      "n: 200, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 5.086552178545853\n",
      "n: 350, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 3.6462039072251424\n",
      "n: 350, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 52.81914631630173\n",
      "n: 2000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 1.0919139379342953\n",
      "n: 500, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 39.09270919874833\n",
      "n: 1000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 17.834467262327568\n",
      "n: 500, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 28.622902338491805\n",
      "n: 350, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 114.05212899352459\n",
      "n: 350, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 5.115913117848949\n",
      "n: 350, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 4.473577409729187\n",
      "n: 350, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 6.920930104025347n: 500, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 3.848479456742646n: 350, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 7.335745518815982\n",
      "\n",
      "\n",
      "n: 500, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 5.655975722463987\n",
      "n: 350, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 1.9574426119876325\n",
      "n: 500, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 123.00728359641795\n",
      "n: 1000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 2.8590629480035594\n",
      "n: 350, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 2.9084600370069484\n",
      "n: 500, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 4.036589816381368\n",
      "n: 500, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 5.18652013821874\n",
      "n: 350, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 1.5655796067711714\n",
      "n: 1000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 16.10250692475423\n",
      "n: 1000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 2.4569207140912512\n",
      "n: 500, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 18.04496771426125\n",
      "n: 350, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 3.0674802562555388\n",
      "n: 500, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 15.597585369837477\n",
      "n: 500, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 2.2401513455517232\n",
      "n: 500, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 29.3713481547758\n",
      "n: 1000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 2.6797183180173154\n",
      "n: 1000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 3.0307064037572813\n",
      "n: 5000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 1.7061799529196495\n",
      "n: 500, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 3.41473435611067\n",
      "n: 2000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 2.2152010915665294\n",
      "n: 1000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 7.000621390903671\n",
      "n: 4000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 4.780747510264398\n",
      "n: 6000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 0.914213495398169\n",
      "n: 1000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 2.850276590411242\n",
      "n: 1000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 2.5320238346048654\n",
      "n: 2000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 4.380860357645977\n",
      "n: 7000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 1.1797367542584944\n",
      "n: 1000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 0.979801822370444\n",
      "n: 1000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 2.594383770514733\n",
      "n: 1000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 3.0120515640953225\n",
      "n: 2000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 9.506656822962693\n",
      "n: 1000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 2.1130210668396776\n",
      "n: 1000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 1.8888988513559888\n",
      "n: 2000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 3.0886241907927734\n",
      "n: 1000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 2.603416022908118\n",
      "n: 4000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 5.109288428846197\n",
      "n: 2000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 8.698611800512106\n",
      "n: 1000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 2.1414408099871025\n",
      "n: 5000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 0.5669697066802047\n",
      "n: 4000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 0.23731795169936046\n",
      "n: 1000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 4.050503999471364\n",
      "n: 2000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 3.0101976775775783\n",
      "n: 2000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 1.8067221820650385\n",
      "n: 6000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 2.4457642897970984\n",
      "n: 2000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 4.026631844217846\n",
      "n: 5000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 1.7863345996782034\n",
      "n: 2000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 2.912862946952342\n",
      "n: 2000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 1.0165206599196552\n",
      "n: 7000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 0.8889785303277309\n",
      "n: 4000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 5.425918403011801\n",
      "n: 4000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 2.541428028570095\n",
      "n: 5000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 0.9777689635146884\n",
      "n: 2000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 5.857728096053836\n",
      "n: 2000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 3.1415922420548896\n",
      "n: 2000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 12.41253312256598\n",
      "n: 7000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 6.2931579798252315\n",
      "n: 2000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 3.7493268917406293\n",
      "n: 2000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 0.9415031705820804\n",
      "n: 4000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 11.815216138984068\n",
      "n: 6000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 1.1457099630458085\n",
      "n: 4000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 6.395874750670226\n",
      "n: 2000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 0.7557295232145042\n",
      "n: 2000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 5.436905766847034\n",
      "n: 200, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 9.301933216208752\n",
      "n: 5000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 1.11354787935645n: 6000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 6.940405114281309\n",
      "\n",
      "n: 4000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 5.656993129310264\n",
      "n: 200, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 8.812581267129797n: 350, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 5.659674299568342\n",
      "\n",
      "n: 200, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 8.88908905761356\n",
      "n: 350, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 1.7572764443438058\n",
      "n: 200, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 8.331649922322256\n",
      "n: 350, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 4.880881614207097n: 200, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 8.241888548186642\n",
      "\n",
      "n: 7000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 1.4199309023295625\n",
      "n: 200, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 17.357942941258557\n",
      "n: 350, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 6.301578787199563\n",
      "n: 350, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 87.0888803381268\n",
      "n: 500, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 81.346374748788\n",
      "n: 350, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 9.176207436095975\n",
      "n: 4000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 1.8881384573003137\n",
      "n: 350, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 7.493405032879136\n",
      "n: 500, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 30.466568860256057\n",
      "n: 350, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 7.059915543868904\n",
      "n: 500, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 15.17825885428669\n",
      "n: 350, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 6.840175564990662\n",
      "n: 500, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 4.206910118282351\n",
      "n: 500, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 4.812616218763557\n",
      "n: 500, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 5.303634771271611\n",
      "n: 500, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 49.30668571796713\n",
      "n: 500, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 4.216223352413835\n",
      "n: 6000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 1.283826007360252\n",
      "n: 5000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 22.033364672499587\n",
      "n: 500, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 5.572674181721872\n",
      "n: 1000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 31.004466780713898\n",
      "n: 4000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 7.094925932307915\n",
      "n: 5000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 3.347747245288215\n",
      "n: 7000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 5.934039666753\n",
      "n: 1000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 35.116272960516376\n",
      "n: 4000, m: 5000, alpha: 0.125, seed: 0, excess_len_avg: 0.07905081980404134\n",
      "n: 2000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 4.673622827327959\n",
      "n: 1000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 4.721856598526928\n",
      "n: 6000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 5.7109723121022675\n",
      "n: 1000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 3.5637657189271614\n",
      "n: 7000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 1.3569022053366717\n",
      "n: 2000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 3.1488633200936103\n",
      "n: 1000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 4.457437049411614\n",
      "n: 200, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 5.8721878152495846\n",
      "n: 200, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 4.014962369548877\n",
      "n: 200, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 40.073221712646784\n",
      "n: 200, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 28.564952592002925\n",
      "n: 1000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 3.5883254962190256\n",
      "n: 200, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 17.150187845764194\n",
      "n: 200, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 6.537214741822678\n",
      "n: 4000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 3.971562924939447\n",
      "n: 200, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 3.4057916152977485\n",
      "n: 2000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 3.684536969123251\n",
      "n: 4000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 1.0117876994200825\n",
      "n: 1000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 4.566356331680474\n",
      "n: 5000, m: 5000, alpha: 0.15, seed: 0, excess_len_avg: 2.645613913584594\n",
      "n: 6000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 1.4604660691337434\n",
      "n: 5000, m: 5000, alpha: 0.025, seed: 1, excess_len_avg: 7.140883841597428\n",
      "n: 1000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 1.7517413551970917\n",
      "n: 2000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 4.300721507272882\n",
      "n: 1000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 4.946155440424448\n",
      "n: 4000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 3.000471116007758\n",
      "n: 2000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 4.578752187354541\n",
      "n: 7000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 6.382411800976568\n",
      "n: 4000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 1.2421052501424852\n",
      "n: 6000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 5.571102091727763\n",
      "n: 4000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 3.7013136072942663\n",
      "n: 5000, m: 5000, alpha: 0.175, seed: 0, excess_len_avg: 2.33887435076186\n",
      "n: 2000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 4.844140107682598\n",
      "n: 6000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 1.3786695043848967\n",
      "n: 5000, m: 5000, alpha: 0.05, seed: 1, excess_len_avg: 6.254555835116855\n",
      "n: 5000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 2.0550727112373286\n",
      "n: 4000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 2.057505685917906\n",
      "n: 2000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 3.374682347529275\n",
      "n: 4000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 0.8825551633973098\n",
      "n: 2000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 4.107445195282459\n",
      "n: 4000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 5.984327527359588\n",
      "n: 4000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 3.4733245213550217\n",
      "n: 5000, m: 5000, alpha: 0.2, seed: 0, excess_len_avg: 1.4378689710247703\n",
      "n: 2000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 4.681348444601679\n",
      "n: 5000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 4.876222067939281\n",
      "n: 6000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 5.2253774035047025\n",
      "n: 5000, m: 5000, alpha: 0.075, seed: 1, excess_len_avg: 3.4961412319448364\n",
      "n: 7000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 5.82113640355967\n",
      "n: 5000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 0.4153428776323025\n",
      "n: 7000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 0.3091476117643045\n",
      "n: 4000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 2.093534793373823\n",
      "n: 4000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 5.239193348320988\n",
      "n: 4000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 4.319856794988739\n",
      "n: 5000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 3.8824912251864685\n",
      "n: 6000, m: 5000, alpha: 0.01, seed: 0, excess_len_avg: 1.047901175377039\n",
      "n: 4000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 1.0148547580985494\n",
      "n: 4000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 3.2645919861333823\n",
      "n: 350, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 19.555417119079486\n",
      "n: 6000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 4.41528623345622\n",
      "n: 5000, m: 5000, alpha: 0.1, seed: 1, excess_len_avg: 3.9120732297060763n: 350, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 3.9271953669694506\n",
      "\n",
      "n: 350, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.839209807882113\n",
      "n: 6000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 3.2042218441310077\n",
      "n: 350, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 6.640124630220187\n",
      "n: 350, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 4.310364893115019\n",
      "n: 350, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 6.9053464867004095\n",
      "n: 350, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 11.198601867457146\n",
      "n: 350, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 7.722587760120275\n",
      "n: 5000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 3.8339282214829793\n",
      "n: 7000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 3.566056371136271\n",
      "n: 500, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 26.823822227403486\n",
      "n: 200, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 101.43042082782917\n",
      "n: 7000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 0.9645243363431569\n",
      "n: 200, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 12.249390146006078\n",
      "n: 200, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 16.37266646867798\n",
      "n: 7000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 4.066106666621\n",
      "n: 500, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 4.936784703248901\n",
      "n: 200, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 22.969975455158917\n",
      "n: 200, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 8.972845635809017\n",
      "n: 4000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 2.46153509783582\n",
      "n: 500, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 3.5707268054917614\n",
      "n: 200, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 7.740897111521164\n",
      "n: 200, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 7.792744931787845\n",
      "n: 500, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.285214968374071\n",
      "n: 200, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 5.8302797124430255\n",
      "n: 200, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 7.418728803106642\n",
      "n: 500, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 4.541547618645829\n",
      "n: 350, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 65.09562713345034\n",
      "n: 500, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 10.410758415529948\n",
      "n: 6000, m: 5000, alpha: 0.025, seed: 0, excess_len_avg: 0.6558854347479925\n",
      "n: 500, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 5.5324845754698435\n",
      "n: 1000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 3.365115979593322\n",
      "n: 500, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 5.145058512962194\n",
      "n: 500, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 7.016548138287945\n",
      "n: 1000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 6.232482996325666\n",
      "n: 6000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 2.640220229990252\n",
      "n: 5000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 5.215361711353595\n",
      "n: 1000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 41.90327803628541\n",
      "n: 1000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 5.281671394593891\n",
      "n: 5000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 3.0849785065904527\n",
      "n: 4000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 1.8234754493896985\n",
      "n: 1000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 6.9845078061391455\n",
      "n: 1000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 6.365768106747071\n",
      "n: 6000, m: 5000, alpha: 0.125, seed: 1, excess_len_avg: 3.623884156818315\n",
      "n: 1000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 4.930903332879619\n",
      "n: 1000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 3.261786847980011\n",
      "n: 2000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 6.87335408155063\n",
      "n: 7000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 1.7812846737403285\n",
      "n: 1000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 3.8498186876709086\n",
      "n: 2000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 4.865631247663441\n",
      "n: 7000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 6.521281777614322\n",
      "n: 6000, m: 5000, alpha: 0.05, seed: 0, excess_len_avg: 1.8755903402071927\n",
      "n: 6000, m: 5000, alpha: 0.2, seed: 2, excess_len_avg: 3.4486189206483218\n",
      "n: 5000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 3.9610797687066928\n",
      "n: 2000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 4.941090168201554\n",
      "n: 5000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 3.741747992844876\n",
      "n: 6000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 3.5912795443466807\n",
      "n: 2000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 43.470982858092015\n",
      "n: 2000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 5.242322395713581\n",
      "n: 2000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 15.929153391673779\n",
      "n: 6000, m: 5000, alpha: 0.15, seed: 1, excess_len_avg: 3.4774144711288084\n",
      "n: 5000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 6.136862830443573\n",
      "n: 5000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 3.017116976517783\n",
      "n: 2000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 4.902781967540603\n",
      "n: 7000, m: 5000, alpha: 0.075, seed: 0, excess_len_avg: 1.0230295571073864\n",
      "n: 4000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 6.062982430952541\n",
      "n: 6000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 3.157216672341967\n",
      "n: 7000, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 5.057156613206518\n",
      "n: 2000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 27.114741550670523\n",
      "n: 5000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 6.040920300778688\n",
      "n: 2000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 5.47863998027118\n",
      "n: 7000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 3.9751037199438755\n",
      "n: 5000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 5.51210502565269\n",
      "n: 4000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 5.152016840612159\n",
      "n: 5000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 3.057866829310451\n",
      "n: 6000, m: 5000, alpha: 0.175, seed: 1, excess_len_avg: 3.2731356735345853\n",
      "n: 6000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 3.0610498717000225\n",
      "n: 6000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 4.692812447047606\n",
      "n: 4000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 4.9080927632653255\n",
      "n: 7000, m: 5000, alpha: 0.1, seed: 0, excess_len_avg: 1.576449132415371\n",
      "n: 5000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 5.453635210703273\n",
      "n: 7000, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 3.3700718167183976\n",
      "n: 200, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 9.00532955684434\n",
      "n: 200, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 4.475377689934277\n",
      "n: 200, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 7.972990102525086\n",
      "n: 5000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 3.428769544066062\n",
      "n: 350, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 80.32625810882277\n",
      "n: 350, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 2.5588267670109914n: 7000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 3.470848439747116\n",
      "\n",
      "n: 350, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 107.29400410259046\n",
      "n: 350, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 76.39348728720053\n",
      "n: 500, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 114.84835987260563\n",
      "n: 350, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 39.8411362442858\n",
      "n: 500, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 40.70729135567364\n",
      "n: 350, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 17.34111161138954\n",
      "n: 4000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.509482411283497\n",
      "n: 500, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 3.4980608458535576\n",
      "n: 350, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 19.24906831150907\n",
      "n: 350, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 5.958673065487072\n",
      "n: 500, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 1.7928275726884135\n",
      "n: 7000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 2.139188567511005\n",
      "n: 350, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 20.90971577958591\n",
      "n: 200, m: 5000, alpha: 0.01, seed: 2, excess_len_avg: 10.023575741526045\n",
      "n: 5000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.789966367752453\n",
      "n: 500, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 11.572258232854608\n",
      "n: 200, m: 5000, alpha: 0.025, seed: 2, excess_len_avg: 59.05092680807787\n",
      "n: 6000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 1.8897329797814317\n",
      "n: 6000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.384273096289404\n",
      "n: 200, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 10.010816392690005\n",
      "n: 500, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 2.637770160233812\n",
      "n: 6000, m: 5000, alpha: 0.2, seed: 1, excess_len_avg: 3.4688418706423754\n",
      "n: 1000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 1.5118319937610034\n",
      "n: 500, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 4.943225324774153\n",
      "n: 500, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 3.444041609002612\n",
      "n: 4000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 4.404447679516267\n",
      "n: 7000, m: 5000, alpha: 0.05, seed: 2, excess_len_avg: 3.2907370300318295\n",
      "n: 1000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 2.840564457857993\n",
      "n: 500, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 21.298528984738144\n",
      "n: 2000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 1.4361817928246567\n",
      "n: 7000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 3.9096739367499476\n",
      "n: 1000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 2.027419226411224\n",
      "n: 1000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 54.627955998537075\n",
      "n: 5000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 5.0898906837097275\n",
      "n: 1000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 2.340194255715939\n",
      "n: 6000, m: 5000, alpha: 0.1, seed: 3, excess_len_avg: 4.329415654252533\n",
      "n: 4000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 4.332857349801179\n",
      "n: 2000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 1.9006630928343067\n",
      "n: 6000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 3.0185406031406283\n",
      "n: 1000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 0.48489616184716694\n",
      "n: 1000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 2.285186622518554\n",
      "n: 2000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 3.570371993855174\n",
      "n: 7000, m: 5000, alpha: 0.075, seed: 2, excess_len_avg: 3.565059281792809\n",
      "n: 5000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 4.750988076243888\n",
      "n: 4000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 4.019665446397109\n",
      "n: 7000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 2.2033427402494388\n",
      "n: 4000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 5.714432142255857\n",
      "n: 1000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 4.461637548217682\n",
      "n: 7000, m: 5000, alpha: 0.01, seed: 1, excess_len_avg: 6.21496654064473\n",
      "n: 1000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 4.16105034947843\n",
      "n: 6000, m: 5000, alpha: 0.125, seed: 3, excess_len_avg: 3.9400483319239883\n",
      "n: 2000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 4.598916590623761\n",
      "n: 6000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 2.9888847960234943\n",
      "n: 4000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 4.774037350987281\n",
      "n: 5000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 4.954511840873526\n",
      "n: 2000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 19.21503271005361\n",
      "n: 2000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 3.307092194434864\n",
      "n: 4000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 3.138054096665438\n",
      "n: 7000, m: 5000, alpha: 0.1, seed: 2, excess_len_avg: 3.555433640130941\n",
      "n: 7000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 3.645200508781335\n",
      "n: 5000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 1.1386338220987666\n",
      "n: 4000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 4.624650470374889\n",
      "n: 2000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 3.94486460460687\n",
      "n: 2000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 12.575596120561848\n",
      "n: 6000, m: 5000, alpha: 0.15, seed: 3, excess_len_avg: 4.488740045955441\n",
      "n: 5000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 4.906403321128775\n",
      "n: 2000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 1.8873553586796248\n",
      "n: 4000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 2.6150695568402424\n",
      "n: 7000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 6.590263757000497\n",
      "n: 4000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 4.703283511181149\n",
      "n: 7000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 3.957841568991174\n",
      "n: 6000, m: 5000, alpha: 0.175, seed: 3, excess_len_avg: 4.258125533465544\n",
      "n: 200, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 4.901922749221972\n",
      "n: 7000, m: 5000, alpha: 0.125, seed: 2, excess_len_avg: 3.5007548417285106\n",
      "n: 5000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 5.052015737487756\n",
      "n: 200, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 81.46554741828085\n",
      "n: 5000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 0.9898636962929728\n",
      "n: 200, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 50.63381465386342\n",
      "n: 200, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 27.572617952354804\n",
      "n: 200, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 51.691330344721926\n",
      "n: 200, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 5.758506528590691\n",
      "n: 4000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 2.6058502508244996\n",
      "n: 4000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 3.971342183776355\n",
      "n: 6000, m: 5000, alpha: 0.2, seed: 3, excess_len_avg: 4.590596486916687\n",
      "n: 6000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 5.955461135495148\n",
      "n: 7000, m: 5000, alpha: 0.15, seed: 2, excess_len_avg: 3.2471674043141094\n",
      "n: 7000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 6.277547443274151\n",
      "n: 6000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 5.908651855656259\n",
      "n: 5000, m: 5000, alpha: 0.01, seed: 4, excess_len_avg: 5.588821304777816\n",
      "n: 4000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 5.596771115761916\n",
      "n: 6000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 4.9347488949068685\n",
      "n: 7000, m: 5000, alpha: 0.01, seed: 3, excess_len_avg: 6.109812090862153\n",
      "n: 7000, m: 5000, alpha: 0.175, seed: 2, excess_len_avg: 3.748234828490488\n",
      "n: 4000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 5.479649661336214\n",
      "n: 5000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 4.352312836917949\n",
      "n: 6000, m: 5000, alpha: 0.025, seed: 4, excess_len_avg: 4.233771592602329\n",
      "n: 7000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 3.703763926878805\n",
      "n: 7000, m: 5000, alpha: 0.025, seed: 3, excess_len_avg: 5.269926412753033\n",
      "n: 4000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 2.0175334475107114\n",
      "n: 5000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 2.601104552479301\n",
      "n: 6000, m: 5000, alpha: 0.05, seed: 4, excess_len_avg: 3.366665257714203\n",
      "n: 7000, m: 5000, alpha: 0.05, seed: 3, excess_len_avg: 4.785697400799536\n",
      "n: 7000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 3.1195242319278487\n",
      "n: 5000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 2.720395475366461\n",
      "n: 7000, m: 5000, alpha: 0.075, seed: 3, excess_len_avg: 4.5270026037601\n",
      "n: 6000, m: 5000, alpha: 0.075, seed: 4, excess_len_avg: 3.1628333955690997\n",
      "n: 7000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 3.9599719068822288\n",
      "n: 5000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 2.8069026240372903\n",
      "n: 6000, m: 5000, alpha: 0.1, seed: 4, excess_len_avg: 3.029159247368616\n",
      "n: 5000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 0.8289961026283504\n",
      "n: 7000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 3.760775364376373\n",
      "n: 6000, m: 5000, alpha: 0.125, seed: 4, excess_len_avg: 2.8379052676999326\n",
      "n: 5000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 1.3999846677507353\n",
      "n: 7000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 2.8840382568000074\n",
      "n: 6000, m: 5000, alpha: 0.15, seed: 4, excess_len_avg: 2.4748648903910766\n",
      "n: 7000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 2.3098155696063363\n",
      "n: 6000, m: 5000, alpha: 0.175, seed: 4, excess_len_avg: 1.6113828733257256\n",
      "n: 6000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 1.5912195661347759\n",
      "n: 7000, m: 5000, alpha: 0.2, seed: 4, excess_len_avg: 1.475227149225645\n",
      "     n  alpha  seed      q_hat  excess_len_avg  coverage\n",
      "0  200  0.010     0  13.976136      112.670890     0.997\n",
      "1  200  0.025     0 -25.059040      104.696471     0.974\n",
      "2  200  0.050     0  12.917609       63.229993     0.942\n",
      "3  200  0.075     0  10.996995       49.044480     0.913\n",
      "4  200  0.100     0  14.542872        8.424365     0.896\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import multiprocess as mp\n",
    "\n",
    "GLOBAL_X_CAL = None\n",
    "GLOBAL_Y_CAL = None\n",
    "GLOBAL_X_TEST = None\n",
    "GLOBAL_Y_TEST = None\n",
    "GLOBAL_TRUE_INTERVALS = None\n",
    "GLOBAL_ALPHA_VALUES = None\n",
    "GLOBAL_ALPHA_INDEX = None\n",
    "\n",
    "\n",
    "def precompute_true_intervals(distributions, alphas):\n",
    "    alpha_values = np.array(sorted({float(a) for a in alphas}), dtype=float)\n",
    "    n_dist = len(distributions)\n",
    "    n_alpha = len(alpha_values)\n",
    "    intervals = np.empty((n_dist, n_alpha))\n",
    "    for i, dist in enumerate(distributions):\n",
    "        for j, alpha in enumerate(alpha_values):\n",
    "            intervals[i, j] = dist.quantile_interval(alpha / 2, 1 - alpha / 2)\n",
    "    return alpha_values, intervals\n",
    "\n",
    "\n",
    "def init_worker(X_cal, y_cal, X_test, y_test, true_intervals, alpha_values):\n",
    "    global GLOBAL_X_CAL, GLOBAL_Y_CAL, GLOBAL_X_TEST, GLOBAL_Y_TEST, GLOBAL_TRUE_INTERVALS, GLOBAL_ALPHA_VALUES, GLOBAL_ALPHA_INDEX\n",
    "    GLOBAL_X_CAL = X_cal\n",
    "    GLOBAL_Y_CAL = y_cal\n",
    "    GLOBAL_X_TEST = X_test\n",
    "    GLOBAL_Y_TEST = y_test\n",
    "    GLOBAL_TRUE_INTERVALS = true_intervals\n",
    "    GLOBAL_ALPHA_VALUES = alpha_values\n",
    "    GLOBAL_ALPHA_INDEX = {float(a): idx for idx, a in enumerate(alpha_values)}\n",
    "\n",
    "\n",
    "def process_single_run(seed, n, m, alpha):\n",
    "    global GLOBAL_X_CAL, GLOBAL_Y_CAL, GLOBAL_X_TEST, GLOBAL_Y_TEST, GLOBAL_TRUE_INTERVALS, GLOBAL_ALPHA_INDEX\n",
    "\n",
    "    rng = np.random.default_rng(seed)\n",
    "    alpha_0 = 0.009\n",
    "    assert alpha > alpha_0\n",
    "\n",
    "    dataset = Dataset(2, alpha_0, rng)\n",
    "\n",
    "    try:\n",
    "        X_train, y_train, _ = dataset.generate_X_y(n=n)\n",
    "    except Exception as e:\n",
    "        print(f\"Error: {e}\")\n",
    "        return None\n",
    "\n",
    "    theta_n_hi, _, _, _ = successive_halving_lr0_tuning(\n",
    "        X_train=X_train, y_train=y_train,\n",
    "        gamma=1 - alpha / 2, rng=rng, epochs=1,\n",
    "        n_iterations=3, eta=2, debug=False\n",
    "    )\n",
    "    theta_n_lo, _, _, _ = successive_halving_lr0_tuning(\n",
    "        X_train=X_train, y_train=y_train,\n",
    "        gamma=alpha / 2, rng=rng, epochs=1,\n",
    "        n_iterations=3, eta=2, debug=False\n",
    "    )\n",
    "\n",
    "    q_hat = calibration_threshold(GLOBAL_X_CAL, GLOBAL_Y_CAL, theta_n_lo, theta_n_hi, alpha=alpha)\n",
    "\n",
    "    alpha_idx = GLOBAL_ALPHA_INDEX[float(alpha)]\n",
    "    true_interval = GLOBAL_TRUE_INTERVALS[:, alpha_idx]\n",
    "    excess_len = GLOBAL_X_TEST @ (theta_n_hi - theta_n_lo) + 2 * q_hat - true_interval\n",
    "\n",
    "    res = {\n",
    "        'n': n,\n",
    "        'alpha': alpha,\n",
    "        'seed': seed,\n",
    "        'q_hat': q_hat,\n",
    "        'excess_len_avg': np.mean(np.abs(excess_len)).item(),\n",
    "        'coverage': np.mean(\n",
    "            (GLOBAL_Y_TEST >= GLOBAL_X_TEST @ theta_n_lo - q_hat) &\n",
    "            (GLOBAL_Y_TEST <= GLOBAL_X_TEST @ theta_n_hi + q_hat)\n",
    "        ).tolist()\n",
    "    }\n",
    "\n",
    "    print(f'n: {n}, m: {m}, alpha: {alpha}, seed: {seed}, excess_len_avg: {res[\"excess_len_avg\"]}')\n",
    "    return res\n",
    "\n",
    "\n",
    "def generate_parameter_combinations(n_list, m_list, seeds, alphas):\n",
    "    \"\"\"生成所有参数组合\"\"\"\n",
    "    parameters = []\n",
    "    for seed in seeds:\n",
    "        for n in n_list:\n",
    "            for m in m_list:\n",
    "                for alpha in alphas:\n",
    "                    parameters.append((seed, n, m, alpha))\n",
    "    return parameters\n",
    "\n",
    "\n",
    "if __name__ == '__main__':\n",
    "    n_list = [200, 350, 500, 1000, 2000, 4000, 5000, 6000, 7000]\n",
    "    m_list = [5000]\n",
    "    seeds = list(range(0, 5))\n",
    "    alphas = [0.01, 0.025, 0.05, 0.075, 0.1, 0.125, 0.15, 0.175, 0.2]\n",
    "    \n",
    "    rng = np.random.default_rng(777)\n",
    "    dataset = Dataset(2, 0.009, rng)\n",
    "    X_cal, y_cal, _ = dataset.generate_X_y(n=m_list[0])\n",
    "    X_test, y_test, test_distributions = dataset.generate_X_y(n=1000)\n",
    "\n",
    "    alpha_values, true_intervals = precompute_true_intervals(test_distributions, alphas)\n",
    "\n",
    "    param_combinations = generate_parameter_combinations(n_list, m_list, seeds, alphas)\n",
    "\n",
    "    with mp.Pool(\n",
    "        processes=mp.cpu_count(),\n",
    "        initializer=init_worker,\n",
    "        initargs=(X_cal, y_cal, X_test, y_test, true_intervals, alpha_values)\n",
    "    ) as pool:\n",
    "        results = pool.starmap(process_single_run, param_combinations)\n",
    "\n",
    "    df = pd.DataFrame(results)\n",
    "    print(df.head())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e7593795",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(results)\n",
    "df.to_csv(\"./conv_cqr_vary_n_uniform_conv.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9720cdc8",
   "metadata": {},
   "source": [
    "## Part 3: Fix n = 5000, vary m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9b76e358",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n: 5000, m: 25, alpha: 0.15 seed: 0 excess_len_avg: 4.430325303963604\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 0 excess_len_avg: 0.3642168675201806\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 0 excess_len_avg: 0.5086689003720694\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 0 excess_len_avg: 0.9818441624546985\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 1 excess_len_avg: 5.1869129409002435\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 0 excess_len_avg: 0.8405955595556587\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 0 excess_len_avg: 1.0997911088137515\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 0 excess_len_avg: 6.482284211488232\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 1 excess_len_avg: 3.617799832292398\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 0 excess_len_avg: 87.01208583828475\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 0 excess_len_avg: 6.471154547860379\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 0 excess_len_avg: 0.9188369343987529\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 0 excess_len_avg: 0.40034269612292517\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 0 excess_len_avg: 1.574902359595544\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 1 excess_len_avg: 7.07254659873721\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 0 excess_len_avg: 0.3858964810079858\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 0 excess_len_avg: 0.42738860716866084\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 0 excess_len_avg: 4.650007558848412\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 1 excess_len_avg: 7.253500219235197\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 0 excess_len_avg: 3.125562045426851\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 0 excess_len_avg: 12.44517466668455\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 0 excess_len_avg: 1.1059720541589206\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 0 excess_len_avg: 0.5275984261048497\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 0 excess_len_avg: 0.6941535103421178\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 1 excess_len_avg: 8.888491203103753\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 0 excess_len_avg: 0.31344915809463203\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 0 excess_len_avg: 0.2670419236884408\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 0 excess_len_avg: 3.5235314393725496\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 0 excess_len_avg: 1.1422520881297695\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 1 excess_len_avg: 3.111562013233526\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 0 excess_len_avg: 1.1270378420336333\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 0 excess_len_avg: 1.7921950221739122\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 0 excess_len_avg: 0.8281099561915449\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 1 excess_len_avg: 10.682311195292899\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 0 excess_len_avg: 0.1394079001999553\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 0 excess_len_avg: 1.1119865998519822\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 0 excess_len_avg: 0.5215576093500365\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 0 excess_len_avg: 2.9323533108044924\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 0 excess_len_avg: 2.4849397106898516\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 0 excess_len_avg: 0.9150731757109934\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 1 excess_len_avg: 0.8193179740262364\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 1 excess_len_avg: 12.47026618863753\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 0 excess_len_avg: 0.4972405657786959\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 0 excess_len_avg: 4.038752297986614\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 0 excess_len_avg: 0.4575123911150891\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 0 excess_len_avg: 0.5072339628648911\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 0 excess_len_avg: 0.8179531290515168\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 0 excess_len_avg: 3.9667230854649618\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 0 excess_len_avg: 2.5075405019609422\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 0 excess_len_avg: 1.8352961606649911\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 1 excess_len_avg: 10.101937686769844\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 1 excess_len_avg: 0.45214750126729814\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 0 excess_len_avg: 0.026002017947182002\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 0 excess_len_avg: 1.5306572005448182\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 0 excess_len_avg: 0.11794094245204281\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 0 excess_len_avg: 0.21417858157544592\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 0 excess_len_avg: 0.8731239056979179\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 0 excess_len_avg: 2.1406586673068717\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 0 excess_len_avg: 1.0269002256522681\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 1 excess_len_avg: 1.0857371186628142\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 0 excess_len_avg: 1.1449589526257942\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 1 excess_len_avg: 2.643509225992185\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 0 excess_len_avg: 1.1422758457682343\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 0 excess_len_avg: 0.9818315451190476\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 0 excess_len_avg: 0.6590373876126736\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 0 excess_len_avg: 1.1081940282099603\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 0 excess_len_avg: 1.792167616398167\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 0 excess_len_avg: 0.10908403980894517\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 0 excess_len_avg: 1.3633492657478823\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 1 excess_len_avg: 1.9715318082317057\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 0 excess_len_avg: 0.44862756476575766\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 0 excess_len_avg: 2.5081374197168382\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 1 excess_len_avg: 0.5000318106303743\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 0 excess_len_avg: 0.513336980712911\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 0 excess_len_avg: 0.8535296905325562\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 0 excess_len_avg: 0.37173004194815257\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 0 excess_len_avg: 1.4485516880841152\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 0 excess_len_avg: 1.44855436621268\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 1 excess_len_avg: 0.4671577453057295\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 0 excess_len_avg: 0.17388714552177897\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 0 excess_len_avg: 0.1364254786390571\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 0 excess_len_avg: 1.3902049811600008\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 0 excess_len_avg: 2.1407997533289764\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 0 excess_len_avg: 3.966722600656455\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 1 excess_len_avg: 3.102908297439221\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 0 excess_len_avg: 0.07421727472045216\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 0 excess_len_avg: 2.382968884539054\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 0 excess_len_avg: 1.0509311559018513\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 1 excess_len_avg: 0.27345514496037904\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 0 excess_len_avg: 0.016759593994320057\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 0 excess_len_avg: 3.334213045851045\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 0 excess_len_avg: 1.43665609228579\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 0 excess_len_avg: 0.41147494779038707\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 1 excess_len_avg: 5.187472704070165\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 0 excess_len_avg: 0.6498895897149972\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 0 excess_len_avg: 0.7844216388663613\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 0 excess_len_avg: 0.0628281248208101\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 0 excess_len_avg: 6.5274294582931685\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 0 excess_len_avg: 1.1840390665800469\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 1 excess_len_avg: 3.5618534320325255\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 0 excess_len_avg: 2.5528304724217494\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 0 excess_len_avg: 1.0457923180339816\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 0 excess_len_avg: 0.9318023693649884\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 1 excess_len_avg: 1.4340773908481852\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 0 excess_len_avg: 0.31095284227981673\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 0 excess_len_avg: 0.06000862361180045\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 0 excess_len_avg: 0.4346087716306802\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 0 excess_len_avg: 4.6692476191206485\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 0 excess_len_avg: 4.980375198306765\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 0 excess_len_avg: 0.5255628631359844\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 1 excess_len_avg: 7.2292395647130325\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 0 excess_len_avg: 1.1051646660550731\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 0 excess_len_avg: 0.002723659977891923\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 1 excess_len_avg: 2.6074718599589595\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 0 excess_len_avg: 0.794589547902465\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 0 excess_len_avg: 0.23509586977701577\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 0 excess_len_avg: 0.14680176399733125\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 0 excess_len_avg: 3.529672650779905\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 0 excess_len_avg: 0.120935673921542\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 1 excess_len_avg: 2.5922762741162053\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 0 excess_len_avg: 0.9661003189646366\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 0 excess_len_avg: 1.1326016470269458\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 1 excess_len_avg: 4.741528206326589\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 0 excess_len_avg: 0.3197356945566834\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 0 excess_len_avg: 1.2105937867585457\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 1 excess_len_avg: 2.658687857687971\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 0 excess_len_avg: 0.40326063498800807\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 0 excess_len_avg: 2.9342959236360815\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 0 excess_len_avg: 0.6325215324236049\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 0 excess_len_avg: 0.6513004084654906\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 1 excess_len_avg: 0.8315691640456321\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 1 excess_len_avg: 4.31751976026292\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 0 excess_len_avg: 0.05268991184389851\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 0 excess_len_avg: 4.038804118680879\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 0 excess_len_avg: 0.4764019116299595\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 1 excess_len_avg: 0.49731004062672424\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 0 excess_len_avg: 0.008414929239035602\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 0 excess_len_avg: 0.49194264700610496\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 0 excess_len_avg: 3.038676338426434\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 1 excess_len_avg: 0.2734557347790881\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 0 excess_len_avg: 0.06888113601459515\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 0 excess_len_avg: 0.6868701871659417\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 1 excess_len_avg: 0.28635865800673316\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 0 excess_len_avg: 1.5306317594204935\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 0 excess_len_avg: 1.1507342627539638\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 1 excess_len_avg: 1.447024245536616\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 1 excess_len_avg: 3.1011546557276364\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 0 excess_len_avg: 0.2230150675559231\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 0 excess_len_avg: 4.667611448772475\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 1 excess_len_avg: 0.8229819635906036\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 0 excess_len_avg: 0.6792995036188957\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 1 excess_len_avg: 1.3657288069653766\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 1 excess_len_avg: 1.8082796524381266\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 1 excess_len_avg: 0.9937122248846321\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 1 excess_len_avg: 0.902110968364942\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 1 excess_len_avg: 1.3565919371141348\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 2 excess_len_avg: 11.097908508756337\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 2 excess_len_avg: 3.1242687337641817\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 2 excess_len_avg: 0.1744891733278174\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 1 excess_len_avg: 0.2866987179752866\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 1 excess_len_avg: 1.1710800897714475\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 1 excess_len_avg: 0.7237022079058454\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 2 excess_len_avg: 2.2162711763658227\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 1 excess_len_avg: 0.5031743325279806\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 1 excess_len_avg: 0.6218797053762637\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 1 excess_len_avg: 1.1040984242148693\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 2 excess_len_avg: 12.379079488433918\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 2 excess_len_avg: 0.031439259335922246\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 2 excess_len_avg: 3.4231199543886586\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 1 excess_len_avg: 0.38042923297712544\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 1 excess_len_avg: 0.583974505228221\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 1 excess_len_avg: 0.5226207686303205\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 2 excess_len_avg: 4.17160864276848\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 2 excess_len_avg: 8.188909403468358\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 1 excess_len_avg: 1.0641731637041592\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 1 excess_len_avg: 1.0203276203623846\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 2 excess_len_avg: 1.5115384090715642\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 1 excess_len_avg: 3.5552411301792772\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 1 excess_len_avg: 0.5131870870733516\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 2 excess_len_avg: 2.69170009144607\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 1 excess_len_avg: 1.044206672170258\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 1 excess_len_avg: 1.1390107790305608\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 1 excess_len_avg: 0.31529054830988024\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 2 excess_len_avg: 1.429843972494874\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 1 excess_len_avg: 0.8315887216844592\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 1 excess_len_avg: 0.12846193071021877\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 2 excess_len_avg: 1.9722478485570851\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 2 excess_len_avg: 2.0847871511388765\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 2 excess_len_avg: 1.8930333427327986\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 1 excess_len_avg: 0.8799791486913721\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 1 excess_len_avg: 1.0956178822292573\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 1 excess_len_avg: 0.40545547592094305\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 1 excess_len_avg: 0.2734561083273388\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 1 excess_len_avg: 1.1924753409970372\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 1 excess_len_avg: 0.6666725400356709\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 2 excess_len_avg: 1.7879420027134356\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 2 excess_len_avg: 2.655252654761785\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 2 excess_len_avg: 4.71131150741224\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 1 excess_len_avg: 3.1196940630527377\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 2 excess_len_avg: 0.32054222758252404\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 1 excess_len_avg: 1.0613959624001112\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 2 excess_len_avg: 2.912339583524843\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 1 excess_len_avg: 1.150671863416775\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 2 excess_len_avg: 0.9189764160327679\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 1 excess_len_avg: 0.9577083802482899\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 1 excess_len_avg: 1.0583300815473466\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 1 excess_len_avg: 3.5754555709571467\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 2 excess_len_avg: 7.575881434895299\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 1 excess_len_avg: 0.8319169633469049\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 2 excess_len_avg: 0.4158293375878793\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 1 excess_len_avg: 0.6808249902789325\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 1 excess_len_avg: 1.238347800800329\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 2 excess_len_avg: 0.3604425411051532\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 1 excess_len_avg: 1.0111481939099052\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 1 excess_len_avg: 0.9168571556768141\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 2 excess_len_avg: 2.217197851963802\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 1 excess_len_avg: 0.5014801582517098\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 2 excess_len_avg: 9.967937662663568\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 1 excess_len_avg: 0.6262072011445874\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 2 excess_len_avg: 0.8531954182127836\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 1 excess_len_avg: 0.12845970311074056\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 2 excess_len_avg: 0.17450926543057552\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 1 excess_len_avg: 0.9089567038053021\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 1 excess_len_avg: 0.6741274673847231\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 1 excess_len_avg: 1.2515129483256051\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 2 excess_len_avg: 4.992146410553722\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 1 excess_len_avg: 1.3657513098634997\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 2 excess_len_avg: 8.510747680337172\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 1 excess_len_avg: 2.5668040378492814\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 1 excess_len_avg: 0.09834303039233445\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 2 excess_len_avg: 0.04919284161591586\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 2 excess_len_avg: 0.1453140336334153\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 1 excess_len_avg: 0.9192695786756778\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 1 excess_len_avg: 1.0967953437680231\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 1 excess_len_avg: 0.41022981397441594\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 1 excess_len_avg: 1.4470284880566529\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 2 excess_len_avg: 1.5659599601758774\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 2 excess_len_avg: 2.896764413849077\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 2 excess_len_avg: 1.511537967876763\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 2 excess_len_avg: 0.27287732829032957\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 1 excess_len_avg: 1.773237283758002\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 1 excess_len_avg: 0.6287156091085567\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 1 excess_len_avg: 1.0409365565031243\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 1 excess_len_avg: 0.6808009000657521\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 1 excess_len_avg: 1.3150308087184968\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 1 excess_len_avg: 0.77482970172563\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 2 excess_len_avg: 4.663987142635218\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 2 excess_len_avg: 1.7878443811853102\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 2 excess_len_avg: 1.0952232171672505\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 1 excess_len_avg: 2.0651368703511936\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 2 excess_len_avg: 2.1848655942905535\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 1 excess_len_avg: 0.6174478174150568\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 2 excess_len_avg: 1.4605827781239786\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 1 excess_len_avg: 0.6074537909848551\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 1 excess_len_avg: 0.6218797181169804\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 2 excess_len_avg: 3.132187685285744\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 1 excess_len_avg: 1.1691860170859658\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 2 excess_len_avg: 1.0233339095699383\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 2 excess_len_avg: 2.121388149640221\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 1 excess_len_avg: 1.5400842460615378\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 1 excess_len_avg: 0.32113537818453597\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 2 excess_len_avg: 2.9004388953844336\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 2 excess_len_avg: 2.6728920680997614\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 2 excess_len_avg: 3.6775165573289392\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 1 excess_len_avg: 1.5663642776726092\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 2 excess_len_avg: 1.6973320618596444\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 1 excess_len_avg: 1.0366014126711898\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 1 excess_len_avg: 97.37876942930717\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 2 excess_len_avg: 1.3778165535109566\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 1 excess_len_avg: 1.1452591191604156\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 1 excess_len_avg: 1.3877364275141513\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 2 excess_len_avg: 1.2370935304832695\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 1 excess_len_avg: 1.7272237719626253\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 2 excess_len_avg: 5.6555696188619855\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 1 excess_len_avg: 1.1390230724810677\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 2 excess_len_avg: 2.2232966122070987\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 2 excess_len_avg: 0.7878312819347782\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 1 excess_len_avg: 0.6174503520539751\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 2 excess_len_avg: 1.9006370123350562\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 1 excess_len_avg: 4.692737828031742\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 1 excess_len_avg: 1.0956197580603952\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 2 excess_len_avg: 1.4983782100456167\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 2 excess_len_avg: 0.6307940793307746\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 1 excess_len_avg: 0.32711859746217054\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 1 excess_len_avg: 1.4050159393086625\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 1 excess_len_avg: 0.6658788683851082\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 2 excess_len_avg: 7.157087520017802\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 2 excess_len_avg: 4.994964385108231\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 2 excess_len_avg: 1.699030001428518\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 1 excess_len_avg: 0.7572469239134082\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 1 excess_len_avg: 0.9691881426188977\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 2 excess_len_avg: 0.697183600200168\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 1 excess_len_avg: 1.209283207960506\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 2 excess_len_avg: 0.9185366910169515\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 2 excess_len_avg: 1.4854985898304958\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 2 excess_len_avg: 8.510523433427455\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 1 excess_len_avg: 0.3230364140249402\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 2 excess_len_avg: 6.2543459929098315\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 2 excess_len_avg: 0.41735050919998185\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 2 excess_len_avg: 0.4123540952118965\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 2 excess_len_avg: 0.7450702365093791\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 2 excess_len_avg: 0.43531552502202964\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 2 excess_len_avg: 0.7985452621398943\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 2 excess_len_avg: 9.812399862253086\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 2 excess_len_avg: 0.7326423732275112\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 3 excess_len_avg: 0.738329088082758\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 3 excess_len_avg: 3.9354266448351374\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 3 excess_len_avg: 0.0848952717173169\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 2 excess_len_avg: 0.19040853758572743\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 3 excess_len_avg: 12.418262786734793\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 3 excess_len_avg: 0.004432564524569672\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 2 excess_len_avg: 0.47173293254192544\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 3 excess_len_avg: 0.7625393035551106\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 2 excess_len_avg: 0.46625116414350176\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 2 excess_len_avg: 0.23179805967993394\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 3 excess_len_avg: 0.7201609477876291\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 3 excess_len_avg: 2.196806692182786\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 3 excess_len_avg: 1.3940763305826402\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 2 excess_len_avg: 0.5585417312135644\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 3 excess_len_avg: 0.34833970694022043\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 3 excess_len_avg: 0.2531619907720703\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 2 excess_len_avg: 0.3709565555482276\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 2 excess_len_avg: 0.17451130691817596\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 3 excess_len_avg: 1.0224323785234952\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 2 excess_len_avg: 0.1640723894041689\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 3 excess_len_avg: 0.7567412320218437\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 3 excess_len_avg: 1.1714769613873217\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 3 excess_len_avg: 0.8411805906814616\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 3 excess_len_avg: 0.17672178894074267\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 2 excess_len_avg: 1.0629553030647523\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 2 excess_len_avg: 0.03144276920227593\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 2 excess_len_avg: 0.5582543620370322\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 3 excess_len_avg: 1.044001576393293\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 3 excess_len_avg: 12.442278331501058\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 2 excess_len_avg: 0.45665202953468426\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 3 excess_len_avg: 0.5258047668029615\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 3 excess_len_avg: 0.9638244954930624\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 3 excess_len_avg: 0.08640688773571494\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 2 excess_len_avg: 0.09678475166446918\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 2 excess_len_avg: 0.5500214254626703\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 3 excess_len_avg: 13.130570171465411\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 3 excess_len_avg: 1.1067801591834492\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 2 excess_len_avg: 0.30068048759136357\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 2 excess_len_avg: 0.13947689737232685\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 3 excess_len_avg: 0.899028682138137\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 3 excess_len_avg: 1.1347185031227465\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 3 excess_len_avg: 14.297768911006827\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 3 excess_len_avg: 2.647149686804847\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 2 excess_len_avg: 0.7302400907068655\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 3 excess_len_avg: 0.7557763676156086\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 2 excess_len_avg: 0.7467356174345842\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 3 excess_len_avg: 1.9759027629719421\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 3 excess_len_avg: 0.26880206484250097\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 2 excess_len_avg: 0.2729164186855027\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 2 excess_len_avg: 0.1502261649691572\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 3 excess_len_avg: 1.6194490194278575\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 3 excess_len_avg: 1.6777651679874392\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 3 excess_len_avg: 1.7940651567870238\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 3 excess_len_avg: 0.8269121562683923\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 3 excess_len_avg: 3.9407499089622107\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 2 excess_len_avg: 0.5325351804244881\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 2 excess_len_avg: 0.3839794672301659\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 3 excess_len_avg: 1.1714287732251265\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 3 excess_len_avg: 0.08548996930307812\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 2 excess_len_avg: 0.06504316405142191\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 3 excess_len_avg: 23.133386219139283\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 3 excess_len_avg: 0.16016741843669685\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 3 excess_len_avg: 0.600366140354687\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 2 excess_len_avg: 0.04852122692269747\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 3 excess_len_avg: 0.6553832909200782\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 3 excess_len_avg: 0.9638152018264556\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 3 excess_len_avg: 2.199602170611484\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 2 excess_len_avg: 0.3170501351191759\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 2 excess_len_avg: 0.2787802896915848\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 3 excess_len_avg: 0.5498089618330191\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 3 excess_len_avg: 1.7219363112724126\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 3 excess_len_avg: 0.881101240395158\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 3 excess_len_avg: 1.027604687185513\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 2 excess_len_avg: 0.3220488333153314\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 3 excess_len_avg: 1.5556699443066981\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 3 excess_len_avg: 0.286511469655949\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 3 excess_len_avg: 1.975902409642155\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 2 excess_len_avg: 0.45644353598025067\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 3 excess_len_avg: 0.8421171843476797\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 3 excess_len_avg: 0.5577966874308392\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 2 excess_len_avg: 0.5316967091206929\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 3 excess_len_avg: 0.6988389311349344\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 3 excess_len_avg: 0.1086631657218016\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 3 excess_len_avg: 1.5886702687488816\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 2 excess_len_avg: 0.7711535683322904\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 2 excess_len_avg: 0.4984461608647231\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 3 excess_len_avg: 1.044119646092984\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 3 excess_len_avg: 0.12159007559334471\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 3 excess_len_avg: 0.08610853392057471\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 3 excess_len_avg: 0.3665182704086852\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 2 excess_len_avg: 0.049163596032024456\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 3 excess_len_avg: 12.431968999746545\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 3 excess_len_avg: 0.0778332468125532\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 2 excess_len_avg: 0.43768972729296585\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 3 excess_len_avg: 12.40363864885575\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 3 excess_len_avg: 1.1056270768540808\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 3 excess_len_avg: 0.3507912644078151\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 3 excess_len_avg: 0.8809003012354026\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 2 excess_len_avg: 0.30812807318420543\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 2 excess_len_avg: 0.24998362539318367\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 3 excess_len_avg: 0.4883103933910018\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 3 excess_len_avg: 14.292927822556566\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 3 excess_len_avg: 1.619295912269057\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 2 excess_len_avg: 0.6126552275869332\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 3 excess_len_avg: 0.6380844510803076\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 3 excess_len_avg: 0.20144415304965962\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 3 excess_len_avg: 1.6292257373205665\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 2 excess_len_avg: 0.4420110570836041\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 3 excess_len_avg: 1.0772839062939892\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 2 excess_len_avg: 0.3362567031874387\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 3 excess_len_avg: 0.568693753818851\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 3 excess_len_avg: 1.1713926342817413\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 3 excess_len_avg: 1.676174090000998\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 3 excess_len_avg: 0.678341970921241\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 3 excess_len_avg: 2.3627996104317006\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 2 excess_len_avg: 0.10733759145598845\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 2 excess_len_avg: 0.7156939325092303\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 3 excess_len_avg: 12.399550816537039\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 3 excess_len_avg: 0.766554788295857\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 3 excess_len_avg: 0.11808390240651978\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 2 excess_len_avg: 0.4981533523681842\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 3 excess_len_avg: 0.9638083505260066\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 3 excess_len_avg: 0.15966041709051115\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 3 excess_len_avg: 3.0924629674312016\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 2 excess_len_avg: 0.33261274474075114\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 3 excess_len_avg: 13.09272060853114\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 3 excess_len_avg: 0.9105684421926769\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 3 excess_len_avg: 1.7219367479684247\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 2 excess_len_avg: 0.6235245176944498\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 3 excess_len_avg: 0.6469676887305845\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 2 excess_len_avg: 0.37734525527215623\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 3 excess_len_avg: 1.0149739287593702\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 3 excess_len_avg: 0.8809587506839756\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 3 excess_len_avg: 1.7784077086253103\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 3 excess_len_avg: 0.7543836016300198\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 3 excess_len_avg: 1.938334763053405\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 3 excess_len_avg: 0.7258768297538747\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 3 excess_len_avg: 0.7546914113551358\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 2 excess_len_avg: 0.5071098117732658\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 3 excess_len_avg: 0.06988248905882222\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 2 excess_len_avg: 0.4425573552292014\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 3 excess_len_avg: 0.42064414392284083\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 3 excess_len_avg: 0.10628043541784944\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 3 excess_len_avg: 0.4690633267848958\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 3 excess_len_avg: 0.9186889948599498\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 4 excess_len_avg: 66.04078033798946\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 3 excess_len_avg: 0.3397086374084238\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 3 excess_len_avg: 0.21841759287613086\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 3 excess_len_avg: 0.1193640218986971\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 4 excess_len_avg: 2.877914012445554\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 3 excess_len_avg: 0.1502416043665434\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 4 excess_len_avg: 59.77811459571803\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 4 excess_len_avg: 0.9126099264931209\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 4 excess_len_avg: 8.940802933242237\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 4 excess_len_avg: 0.8887557213004955\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 4 excess_len_avg: 7.11861646132557\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 3 excess_len_avg: 0.25937494280989476\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 4 excess_len_avg: 3.6593615866667677\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 4 excess_len_avg: 0.4935049943651471\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 3 excess_len_avg: 0.19865832901849576\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 4 excess_len_avg: 1.9821745357818261\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 4 excess_len_avg: 0.9726842973176176\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 4 excess_len_avg: 62.4254154786246\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 4 excess_len_avg: 0.9506536711052215\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 4 excess_len_avg: 6.57107945830379\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 4 excess_len_avg: 4.587357449186075\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 4 excess_len_avg: 0.2905638856313906\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 3 excess_len_avg: 0.10736285128310516\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 4 excess_len_avg: 9.714963563834425\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 4 excess_len_avg: 1.8934320938687683\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 4 excess_len_avg: 1.2505479057754234\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 4 excess_len_avg: 3.975529980637475\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 4 excess_len_avg: 7.852469944493834\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 4 excess_len_avg: 0.2921241047369803\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 4 excess_len_avg: 0.49311545175114674\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 4 excess_len_avg: 59.73413586765583\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 3 excess_len_avg: 0.04773144125233999\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 4 excess_len_avg: 2.7301178919940474\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 4 excess_len_avg: 6.946885642774073\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 4 excess_len_avg: 8.771073489904511\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 4 excess_len_avg: 0.9780154538359533\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 4 excess_len_avg: 3.9824621276049323\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 4 excess_len_avg: 0.290181387896515\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 4 excess_len_avg: 0.47483239709286273\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 4 excess_len_avg: 3.2554792424456\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 3 excess_len_avg: 0.022609127495319604\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 4 excess_len_avg: 33.45105980947569\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 4 excess_len_avg: 9.866893607161499\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 4 excess_len_avg: 4.626307169599188\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 4 excess_len_avg: 2.706628149512616\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 4 excess_len_avg: 0.6070664316884556\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 4 excess_len_avg: 0.7749574363967663\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 4 excess_len_avg: 3.8613497508644925\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 4 excess_len_avg: 0.7996041418688937\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 3 excess_len_avg: 0.1977385054374468\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 4 excess_len_avg: 3.9696141439407446\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 4 excess_len_avg: 2.9428028134556916\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 4 excess_len_avg: 4.135720683793001\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 4 excess_len_avg: 59.79065864218869\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 4 excess_len_avg: 0.6570180601836946\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 4 excess_len_avg: 1.0562685977571142\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 3 excess_len_avg: 0.3675923684796138\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 4 excess_len_avg: 1.1231111844488777\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 4 excess_len_avg: 14.571057998739777\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 4 excess_len_avg: 2.0259620616989737\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 4 excess_len_avg: 5.449914048049201\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 4 excess_len_avg: 1.4573135307808205\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 3 excess_len_avg: 0.3441435566748737\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 4 excess_len_avg: 1.4775401874187792\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 4 excess_len_avg: 62.43097441630056\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 4 excess_len_avg: 0.8032537119857901\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 4 excess_len_avg: 1.0265984910275898\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 4 excess_len_avg: 3.3178503357164706\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 4 excess_len_avg: 3.659366663909528\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 4 excess_len_avg: 1.9822674878201758\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 4 excess_len_avg: 0.04077747967596902\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 4 excess_len_avg: 1.2203237864535341\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 4 excess_len_avg: 3.977326140982249\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 4 excess_len_avg: 0.8849090240685\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 3 excess_len_avg: 0.6130693088400626\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 4 excess_len_avg: 0.4221666031614616\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 4 excess_len_avg: 5.362921911982128\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 4 excess_len_avg: 2.355868655017197\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 4 excess_len_avg: 0.28839594211243436\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 4 excess_len_avg: 1.3538686377816707\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 4 excess_len_avg: 1.6304719075734146\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 4 excess_len_avg: 1.1766805320380214\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 4 excess_len_avg: 4.253764443092535\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 3 excess_len_avg: 0.2683846032284649\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 4 excess_len_avg: 2.8779229529557413\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 4 excess_len_avg: 2.7427119275165834\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 4 excess_len_avg: 0.14990335130805157\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 4 excess_len_avg: 0.289003990794306\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 4 excess_len_avg: 59.71345556196907\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 4 excess_len_avg: 1.1366478563689666\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 4 excess_len_avg: 1.3560205973296804\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 4 excess_len_avg: 2.282830828157915\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 4 excess_len_avg: 5.395121333957728\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 4 excess_len_avg: 3.511639913552011\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 3 excess_len_avg: 0.08531268690647364\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 4 excess_len_avg: 0.042753971470278165\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 4 excess_len_avg: 1.3517545964724582\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 4 excess_len_avg: 1.2050284586248967\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 4 excess_len_avg: 2.8729096238263154\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 4 excess_len_avg: 0.39947450631160236\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 4 excess_len_avg: 4.135757652620726\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 4 excess_len_avg: 4.076500126843265\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 3 excess_len_avg: 0.26517559937505486\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 4 excess_len_avg: 59.732410295804605\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 4 excess_len_avg: 1.1532568426473677\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 4 excess_len_avg: 1.4679793009549598\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 4 excess_len_avg: 0.1807091616440115\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 4 excess_len_avg: 5.848346402432791\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 4 excess_len_avg: 2.8542853547502913\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 4 excess_len_avg: 0.5022749188207416\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 4 excess_len_avg: 39.03234148702207\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 3 excess_len_avg: 0.26612616424879293\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 4 excess_len_avg: 1.711401311534019\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 4 excess_len_avg: 0.22950697685099028\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 4 excess_len_avg: 3.7109685197161295\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 4 excess_len_avg: 62.406794769420856\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 4 excess_len_avg: 0.9323102765918645\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 4 excess_len_avg: 3.9798783198914354\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 4 excess_len_avg: 0.30110940564998556\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 4 excess_len_avg: 1.9097540521317238\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 3 excess_len_avg: 0.43663838716372866\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 4 excess_len_avg: 3.8780061281350955\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 4 excess_len_avg: 0.2713177467070267\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 4 excess_len_avg: 5.466157582012275\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 4 excess_len_avg: 64.54564179129217\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 4 excess_len_avg: 0.7208130043243131\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 4 excess_len_avg: 2.281948684687598\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 4 excess_len_avg: 0.19609018925312308\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 4 excess_len_avg: 2.204824579432988\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 4 excess_len_avg: 0.11469554187125207\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 4 excess_len_avg: 2.816812749134022\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 4 excess_len_avg: 3.771612291560955\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 4 excess_len_avg: 0.7067949573523613\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 4 excess_len_avg: 0.5635578581033305\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 4 excess_len_avg: 0.48487042642987277\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "# from multiprocessing import Pool\n",
    "from functools import partial\n",
    "# import multiprocessing\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import multiprocess as mp\n",
    "\n",
    "def process_single_run(seed, n, m, alpha):\n",
    "    rng = np.random.default_rng(seed)\n",
    "    alpha_min = 0.009\n",
    "    assert alpha > alpha_min\n",
    "    dataset = Dataset(2, alpha_min, rng)\n",
    "    \n",
    "\n",
    "    try:\n",
    "        X_cal, y_cal, _ = dataset.generate_X_y(n=m)\n",
    "        X_test, y_test, test_distributions = dataset.generate_X_y(n=2000)\n",
    "    except Exception as e:\n",
    "        print(f\"Error: {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "    theta_n_hi = dataset.theta * (1-alpha) / (1-alpha_min)\n",
    "    theta_n_lo = - dataset.theta * (1-alpha) / (1-alpha_min)\n",
    "\n",
    "\n",
    "\n",
    "    def calibration_threshold(X_cal, y_cal, theta_lo, theta_hi, alpha):\n",
    "        m = len(y_cal)\n",
    "        nc_scores = cqr_nc_score(X_cal, y_cal, theta_lo, theta_hi)\n",
    "        k = min(int(np.ceil((1 - alpha) * (m + 1))), len(nc_scores))\n",
    "        cqr_threshold = sorted(nc_scores)[k-1]\n",
    "        return cqr_threshold\n",
    "\n",
    "    # Calibration\n",
    "    q_hat = calibration_threshold(X_cal, y_cal, theta_n_lo, theta_n_hi, alpha=alpha)\n",
    "\n",
    "    # Evaluate excess length\n",
    "    true_interval = [d.quantile_interval(alpha/2, 1-alpha/2) for d in test_distributions]\n",
    "    excess_len = X_test @ (theta_n_hi - theta_n_lo) + 2 * q_hat - true_interval\n",
    "\n",
    "    res = {'n': n, 'alpha': alpha, 'm': m, 'seed': seed, \n",
    "           'q_hat': q_hat,\n",
    "           'excess_len_avg': np.mean(np.abs(excess_len)).item(),\n",
    "           'coverage': np.mean((y_test >= X_test @ theta_n_lo - q_hat) & (y_test <= X_test @ theta_n_hi + q_hat)).tolist()\n",
    "          }\n",
    "    \n",
    "    print(f'n: {n}, m: {m}, alpha: {alpha} seed: {seed} excess_len_avg: {res[\"excess_len_avg\"]}')\n",
    "    return res\n",
    "\n",
    "if __name__ == '__main__':\n",
    "    n_list = [5000]\n",
    "    m_list = [10, 25, 50, 75, 100, 150, 200, 300, 400, 500, 1000, 2000, 3000]\n",
    "    seeds = list(range(0, 5))\n",
    "    alphas = [0.01, 0.025, 0.05, 0.075, 0.1, 0.125, 0.15, 0.175, 0.2]\n",
    "\n",
    "    param_combinations = generate_parameter_combinations(n_list, m_list, seeds, alphas)\n",
    "    \n",
    "    with mp.Pool(processes=mp.cpu_count()) as pool:\n",
    "        results = pool.starmap(process_single_run, param_combinations)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "c41556b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(results)\n",
    "df.to_csv(\"./conv_cqr_vary_m_uniform_conv.csv\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "quantdata",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
