{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ed16e2ff",
   "metadata": {},
   "source": [
    "## Part 0: imported packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "442a983b",
   "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",
    "    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 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": 22,
   "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",
    "        return DataDistribution(self.alpha_min, self.x_max, self.theta, x=x, rng=self.rng)\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": 23,
   "id": "84dc8df0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((100, 2), (100,))"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape, y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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, lasso_lambda=0.001):\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",
    "            l1_grad = lasso_lambda * np.sign(theta)\n",
    "            ghat = -xb.T @ pinball_grad(yb - xb @ theta, gamma) / (stop-start) + l1_grad\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": 25,
   "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": 26,
   "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": 27,
   "id": "1bdec2d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n: 200, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 8.535104905049538\n",
      "n: 500, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 24.43404859236199\n",
      "n: 1000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 1.290326036732802\n",
      "n: 200, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 7.314840978478316\n",
      "n: 1000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 5.245168473257842\n",
      "n: 4000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 1.3817202826505903\n",
      "n: 6000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 3.1640003756999944\n",
      "n: 200, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 76.25033550729175\n",
      "n: 8000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 1.6409879614088496\n",
      "n: 500, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 11.204035040301008\n",
      "n: 1000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 9.705431678286866\n",
      "n: 200, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 7.596753243666864\n",
      "n: 1000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 6.77013566522081\n",
      "n: 15000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 2.446550853663727\n",
      "n: 200, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 28.400471114415662\n",
      "n: 4000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 1.4330870294333296\n",
      "n: 500, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 12.497108644943525\n",
      "n: 1000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 5.852056361681109\n",
      "n: 200, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 5.794350675970441\n",
      "n: 6000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 0.0638656371410189\n",
      "n: 20000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 1.71011998672354\n",
      "n: 1000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 7.088340773322389\n",
      "n: 200, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 34.99025543447421\n",
      "n: 8000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 0.984745375886267\n",
      "n: 500, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 12.064796053079192\n",
      "n: 4000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 3.3379296238961107\n",
      "n: 2000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 3.8354776118879608\n",
      "n: 500, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 129.84466200556614\n",
      "n: 200, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 27.629547742437776\n",
      "n: 1000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 5.7467692413524984\n",
      "n: 500, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 8.989460683760782\n",
      "n: 6000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 2.9734992154120654\n",
      "n: 2000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 4.192174142425714\n",
      "n: 500, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 104.52477458598146\n",
      "n: 15000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 1.7149344044734056\n",
      "n: 200, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 19.10204503520589\n",
      "n: 4000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 3.3637060268184906\n",
      "n: 8000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 1.3465037623602598\n",
      "n: 500, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 15.889761631584705\n",
      "n: 1000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 5.90632291441861\n",
      "n: 200, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 25.42409772954644\n",
      "n: 2000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 0.3312327984816435\n",
      "n: 500, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 62.32496222000616\n",
      "n: 6000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 0.4430730018087971\n",
      "n: 1000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 13.857536880280469\n",
      "n: 20000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 1.47613385855231\n",
      "n: 4000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 3.0669602197564414\n",
      "n: 1000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 8.063091955727103\n",
      "n: 200, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 7.3264751361955165\n",
      "n: 2000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 2.063617108293768\n",
      "n: 500, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 14.219392576377665\n",
      "n: 1000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 3.5830018567007262\n",
      "n: 10000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 1.503833352792881\n",
      "n: 6000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 1.5992893918478375\n",
      "n: 200, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 17.191468026114684\n",
      "n: 1000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 0.817572371946243\n",
      "n: 15000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 1.0514146430829086\n",
      "n: 4000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 2.1296836346514487\n",
      "n: 500, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 12.246935994459998\n",
      "n: 1000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 2.727356337150496\n",
      "n: 2000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 2.2060649459233916\n",
      "n: 500, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 138.75468769800776\n",
      "n: 1000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 1.9446164674335338\n",
      "n: 1000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 4.633199711123417\n",
      "n: 6000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 0.5354990154389374\n",
      "n: 4000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 8.349093635467545\n",
      "n: 500, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 6.115671718901498\n",
      "n: 2000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 0.8022869708277446\n",
      "n: 10000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 4.2893559201188705\n",
      "n: 500, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 49.679492641829526\n",
      "n: 20000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 1.4133873547676297\n",
      "n: 1000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 13.298073772318153\n",
      "n: 1000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 3.7865898469525545\n",
      "n: 500, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 10.053411056350837\n",
      "n: 2000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 10.702274587066778\n",
      "n: 500, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 27.62625063660071\n",
      "n: 15000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 0.11899227996621188\n",
      "n: 4000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 3.0570758794369026\n",
      "n: 8000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 0.5655636654016885\n",
      "n: 1000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 1.9025540496311468\n",
      "n: 2000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 13.171915432805553\n",
      "n: 500, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 3.053757658458072\n",
      "n: 10000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 1.2257306793539455\n",
      "n: 2000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 3.8800947976347375\n",
      "n: 2000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 0.533936256950156\n",
      "n: 4000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 0.3751640790307571\n",
      "n: 500, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 17.363596766636427\n",
      "n: 2000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 5.141967501038953\n",
      "n: 4000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 2.5003739647309167\n",
      "n: 2000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 2.2424373987748254\n",
      "n: 8000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 2.5028992134961463\n",
      "n: 20000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 1.6399057818946021\n",
      "n: 2000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 2.010878914569077\n",
      "n: 15000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 0.9508595506375135\n",
      "n: 6000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 2.12436709055808\n",
      "n: 10000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 1.5386972343291114\n",
      "n: 2000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 0.6594984535809617\n",
      "n: 4000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 1.8661500076828743\n",
      "n: 2000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 6.401483612109196\n",
      "n: 8000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 1.7451510327317281\n",
      "n: 8000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 2.738801709815962\n",
      "n: 6000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 1.6175031880205684\n",
      "n: 10000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 1.6755346228236563\n",
      "n: 2000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 12.913812530675209\n",
      "n: 10000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 1.8559296980461737\n",
      "n: 4000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 6.523652076792177\n",
      "n: 15000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 2.0478488578628466\n",
      "n: 20000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 2.0131507931460924\n",
      "n: 8000, m: 5000, alpha: 0.075 seed: 0 excess_len_avg: 1.9373552332322725\n",
      "n: 6000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 0.6801791251144391\n",
      "n: 8000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 2.01375352058327\n",
      "n: 2000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 1.9309611126993733\n",
      "n: 15000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 3.3376290433878886\n",
      "n: 200, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 73.65151714663044\n",
      "n: 10000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 3.1904719698891184\n",
      "n: 6000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 0.8259866822158111\n",
      "n: 10000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 1.7622307275616316\n",
      "n: 2000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 4.730304778970047\n",
      "n: 200, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 145.07954348661337\n",
      "n: 8000, m: 5000, alpha: 0.1 seed: 0 excess_len_avg: 2.2487468209868267\n",
      "n: 15000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 1.9517309478867646\n",
      "n: 8000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 1.1083436126560475\n",
      "n: 200, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 53.041346619581965\n",
      "n: 6000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 2.2585428329081387\n",
      "n: 20000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 3.716485171580006\n",
      "n: 200, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 39.5369815788389\n",
      "n: 4000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 0.8495527041170754\n",
      "n: 10000, m: 5000, alpha: 0.15 seed: 0 excess_len_avg: 2.175464718254128\n",
      "n: 10000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 1.9978958867660381\n",
      "n: 15000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 2.8551492118769604\n",
      "n: 8000, m: 5000, alpha: 0.125 seed: 0 excess_len_avg: 1.645898992933011\n",
      "n: 200, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 20.00364182517177\n",
      "n: 200, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 17.891824497273586\n",
      "n: 500, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 9.853186891209592\n",
      "n: 8000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 2.0086338067679574\n",
      "n: 200, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 19.55621760207084\n",
      "n: 4000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 0.4769174412645278\n",
      "n: 6000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 1.1953002445630343\n",
      "n: 15000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 1.9502952840759489\n",
      "n: 200, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 107.11325093029016\n",
      "n: 500, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 5.687978870158477\n",
      "n: 200, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 10.75595092096438\n",
      "n: 10000, m: 5000, alpha: 0.175 seed: 0 excess_len_avg: 0.6110854437628382\n",
      "n: 10000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 3.549687203474402\n",
      "n: 500, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 3.9658995069994614\n",
      "n: 200, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 87.15356893992902\n",
      "n: 200, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 19.007956827732183\n",
      "n: 4000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 2.2412384273583434\n",
      "n: 8000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 1.3678724253209609\n",
      "n: 6000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 2.59583190050736\n",
      "n: 15000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 3.57632108736803\n",
      "n: 500, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 7.643525806486772\n",
      "n: 200, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 18.548569451547433\n",
      "n: 200, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 38.192795268838935\n",
      "n: 10000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 1.315212842092421\n",
      "n: 500, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 8.551177845946873\n",
      "n: 15000, m: 5000, alpha: 0.2 seed: 0 excess_len_avg: 1.669567628585904\n",
      "n: 500, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 9.594020192987907\n",
      "n: 4000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 1.5594682285309829\n",
      "n: 200, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 20.407002877041382\n",
      "n: 500, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 8.676499303608676\n",
      "n: 10000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 3.4023705587589466\n",
      "n: 1000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 8.386285735706208\n",
      "n: 6000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 1.134677660507942\n",
      "n: 500, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 76.64289356979812\n",
      "n: 8000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 2.2325849010562497\n",
      "n: 200, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 15.506786281908209\n",
      "n: 1000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 2.2219369780854583\n",
      "n: 1000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 1.7893960542294527\n",
      "n: 500, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 34.78961961713084\n",
      "n: 4000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 1.654694822350298\n",
      "n: 1000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 2.834678048906062\n",
      "n: 1000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 9.122459926795734\n",
      "n: 4000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 2.188623840521661\n",
      "n: 6000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 1.148286208245826\n",
      "n: 20000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 1.5047752010821855\n",
      "n: 10000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 2.6553153934713936\n",
      "n: 6000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 0.3841234863647989\n",
      "n: 20000, m: 5000, alpha: 0.01 seed: 0 excess_len_avg: 4.433546263321338\n",
      "n: 8000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 3.952505738241546\n",
      "n: 1000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 11.205105453064094\n",
      "n: 4000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 1.350615413655117\n",
      "n: 2000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 1.1229762185624241\n",
      "n: 4000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 2.243021322055578\n",
      "n: 1000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 3.244111580401358\n",
      "n: 2000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 1.3735778302906603\n",
      "n: 6000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 0.8779521222875508\n",
      "n: 6000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 0.9377776804768005\n",
      "n: 8000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 0.45061748152739517\n",
      "n: 1000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 6.071725265894121\n",
      "n: 4000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 2.2334599187069037\n",
      "n: 2000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 5.0318395531496956\n",
      "n: 8000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 2.0938267104446564\n",
      "n: 1000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 9.634262092839837\n",
      "n: 6000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 1.4499481787463746\n",
      "n: 4000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 3.34963528754986\n",
      "n: 15000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 1.7982979014268585\n",
      "n: 2000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 1.000076096830238\n",
      "n: 6000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 2.7057684555509516\n",
      "n: 20000, m: 5000, alpha: 0.025 seed: 0 excess_len_avg: 1.7250651441476388\n",
      "n: 8000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 1.1073626681937714\n",
      "n: 20000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 1.1241922271015787\n",
      "n: 2000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 2.0613381069228147\n",
      "n: 6000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 0.7165377436758338\n",
      "n: 4000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 3.5526895701559926\n",
      "n: 8000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 3.220237685811537\n",
      "n: 8000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 1.6812890757869596\n",
      "n: 15000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 5.786332042577747\n",
      "n: 2000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 1.2494592219793634\n",
      "n: 6000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 1.6252029573519196\n",
      "n: 4000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 4.35362982537985\n",
      "n: 6000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 4.038905274788031\n",
      "n: 2000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 0.3737477637422496\n",
      "n: 15000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 2.1968215331564362\n",
      "n: 4000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 11.550596629807986\n",
      "n: 20000, m: 5000, alpha: 0.05 seed: 0 excess_len_avg: 2.7676007869956885\n",
      "n: 10000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 0.8749937328317214\n",
      "n: 10000, m: 5000, alpha: 0.01 seed: 1 excess_len_avg: 1.1482790468774131\n",
      "n: 6000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 2.406738873430108\n",
      "n: 2000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 0.22718393755352825\n",
      "n: 200, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 5.631278706878895\n",
      "n: 15000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 1.3755370426057099\n",
      "n: 20000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 1.7544035142400873\n",
      "n: 4000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 3.0235288350831953\n",
      "n: 2000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 1.2747458027225969\n",
      "n: 200, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 19.0018305326337\n",
      "n: 20000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 1.3588637844141895\n",
      "n: 8000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 0.5218800896577854\n",
      "n: 10000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 2.6675299900937386\n",
      "n: 200, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 19.037241081759564\n",
      "n: 1000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 13.025606013336795\n",
      "n: 4000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 3.549140785426173\n",
      "n: 10000, m: 5000, alpha: 0.025 seed: 1 excess_len_avg: 1.8513074110159757\n",
      "n: 500, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 5.031918623080801\n",
      "n: 15000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 12.100068408040675\n",
      "n: 1000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 0.2994648006694235\n",
      "n: 15000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 1.5625687230621403\n",
      "n: 500, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 27.915869472692513\n",
      "n: 8000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 0.15224438282354938\n",
      "n: 6000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 4.453936623901512n: 1000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 2.819878701530903\n",
      "\n",
      "n: 10000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 0.9072238506680584\n",
      "n: 500, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 5.587538664263058\n",
      "n: 20000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 1.1006367801961154\n",
      "n: 1000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 1.2346292291989691\n",
      "n: 20000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 2.1801196266231044\n",
      "n: 500, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 20.84640155623586\n",
      "n: 10000, m: 5000, alpha: 0.05 seed: 1 excess_len_avg: 0.2313024533758596\n",
      "n: 6000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 1.8091466805697995\n",
      "n: 8000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 4.479812671967473\n",
      "n: 1000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 3.4748744755585523\n",
      "n: 15000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 1.4053059993115664\n",
      "n: 500, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 5.964422102962686\n",
      "n: 10000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 1.219969866978084\n",
      "n: 15000, m: 5000, alpha: 0.075 seed: 1 excess_len_avg: 1.6551880174999802\n",
      "n: 2000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 2.52752096489191\n",
      "n: 1000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 21.21277753529\n",
      "n: 500, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 4.281747869336967\n",
      "n: 6000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 1.56763602229045\n",
      "n: 8000, m: 5000, alpha: 0.075 seed: 2 excess_len_avg: 2.560466501595285\n",
      "n: 1000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 3.205462749849255\n",
      "n: 2000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 0.3154325174616064\n",
      "n: 500, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 16.166802152973233\n",
      "n: 20000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 2.26031787017881\n",
      "n: 10000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 1.690448196242961\n",
      "n: 4000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 3.285744511004286\n",
      "n: 1000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 3.9882803574330365\n",
      "n: 2000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 3.6683096375271917\n",
      "n: 15000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 1.046654407001062\n",
      "n: 500, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 6.723041669046496\n",
      "n: 8000, m: 5000, alpha: 0.1 seed: 2 excess_len_avg: 1.7466808033847916\n",
      "n: 1000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 4.426208248207673\n",
      "n: 20000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 0.963949364550065\n",
      "n: 2000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 3.87818628717896\n",
      "n: 4000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 8.457944674540052n: 500, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 11.371132816017328\n",
      "\n",
      "n: 15000, m: 5000, alpha: 0.1 seed: 1 excess_len_avg: 1.0760144044226485\n",
      "n: 2000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 1.7233399148601498\n",
      "n: 10000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 2.6543194049318455\n",
      "n: 2000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 68.5973043695575\n",
      "n: 4000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 3.576838853019347\n",
      "n: 8000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 0.15937407004710663\n",
      "n: 8000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 1.1978462038077673\n",
      "n: 2000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 17.0638855104422\n",
      "n: 15000, m: 5000, alpha: 0.125 seed: 2 excess_len_avg: 0.3091749470998386\n",
      "n: 20000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 1.2724931124667578\n",
      "n: 2000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 9.230677912882106\n",
      "n: 6000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 0.620348656244298\n",
      "n: 2000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 4.096416833144793\n",
      "n: 10000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 2.4352371758156224\n",
      "n: 4000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 2.8276411878383807\n",
      "n: 8000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 1.21421079066588\n",
      "n: 10000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 1.9224077181212107\n",
      "n: 15000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 0.8753228770207115\n",
      "n: 6000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 1.41601869096919\n",
      "n: 20000, m: 5000, alpha: 0.125 seed: 1 excess_len_avg: 2.7210429266913\n",
      "n: 15000, m: 5000, alpha: 0.15 seed: 2 excess_len_avg: 1.2480678222052224\n",
      "n: 4000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 1.109892008868929\n",
      "n: 20000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 2.4692309587683288\n",
      "n: 10000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 4.4069805290844135\n",
      "n: 8000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 0.6933825517920528\n",
      "n: 15000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 0.442179462553931\n",
      "n: 200, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 22.039080981265005\n",
      "n: 10000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 0.8556981888157871\n",
      "n: 6000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 0.6845972568132631\n",
      "n: 4000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 1.3700742219276156\n",
      "n: 200, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 21.889150845640206\n",
      "n: 8000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 1.5194196169616407\n",
      "n: 4000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 2.4664569357293358\n",
      "n: 6000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 9.849307305189328\n",
      "n: 10000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 4.5430761644088\n",
      "n: 15000, m: 5000, alpha: 0.175 seed: 2 excess_len_avg: 0.21552361088638558\n",
      "n: 10000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 2.913696195642641\n",
      "n: 15000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 1.2924781407336046\n",
      "n: 200, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 106.9625663926382\n",
      "n: 4000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 4.043108103709422\n",
      "n: 20000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 1.3760403572744508\n",
      "n: 500, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 11.025749382497663\n",
      "n: 6000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 0.29296432016239937\n",
      "n: 8000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 0.9592425880007517\n",
      "n: 20000, m: 5000, alpha: 0.15 seed: 1 excess_len_avg: 3.906499644009453\n",
      "n: 200, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 86.51496836817229\n",
      "n: 10000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 1.070171097705329\n",
      "n: 200, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 155.81864343109584\n",
      "n: 4000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 2.7281289468138876\n",
      "n: 500, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 1.86431186548279\n",
      "n: 6000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 0.7415423699772741\n",
      "n: 15000, m: 5000, alpha: 0.2 seed: 2 excess_len_avg: 0.8377473193542098\n",
      "n: 200, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 56.10004019118316\n",
      "n: 15000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 1.5000465198990283\n",
      "n: 200, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 66.06737034370619\n",
      "n: 8000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 1.5467657571526492\n",
      "n: 1000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 2.5469937854782256\n",
      "n: 200, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 79.15223231503161\n",
      "n: 500, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 9.996090780038157\n",
      "n: 10000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 5.5713804108825675\n",
      "n: 200, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 45.61977231923992\n",
      "n: 6000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 0.3627488888042616\n",
      "n: 200, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 62.829417370827755\n",
      "n: 8000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 3.458199393912819\n",
      "n: 500, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 18.129281638811776\n",
      "n: 1000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 1.28584547922019\n",
      "n: 200, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 18.90215263234808\n",
      "n: 200, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 46.50660242662381\n",
      "n: 6000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 1.2522290363656685\n",
      "n: 20000, m: 5000, alpha: 0.175 seed: 1 excess_len_avg: 2.3346454799327683\n",
      "n: 10000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 4.610924480484691\n",
      "n: 20000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 2.355717696590797\n",
      "n: 200, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 6.997258247691322\n",
      "n: 500, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 11.681458641364763\n",
      "n: 20000, m: 5000, alpha: 0.01 seed: 2 excess_len_avg: 1.3268243691095514\n",
      "n: 1000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 3.309347537867945\n",
      "n: 200, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 18.80336461576826\n",
      "n: 8000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 2.1557679731646324\n",
      "n: 6000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 0.17777080471779982\n",
      "n: 500, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 10.500190574380253\n",
      "n: 200, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 18.47411751342596\n",
      "n: 2000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 1.6198647627243472\n",
      "n: 4000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 1.9208110291931648\n",
      "n: 8000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 3.314975782597534\n",
      "n: 15000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 0.7829179205026262\n",
      "n: 1000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 7.8933839243153265\n",
      "n: 500, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 99.82283827744034\n",
      "n: 20000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 0.981822365355745\n",
      "n: 2000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 4.916286219223118\n",
      "n: 6000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 2.2181444913952006\n",
      "n: 20000, m: 5000, alpha: 0.025 seed: 2 excess_len_avg: 0.7699387915306256\n",
      "n: 4000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 0.8063016621843869\n",
      "n: 1000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 5.288577409093306\n",
      "n: 10000, m: 5000, alpha: 0.01 seed: 3 excess_len_avg: 1.8155997279664997\n",
      "n: 500, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 73.7624762218739\n",
      "n: 20000, m: 5000, alpha: 0.2 seed: 1 excess_len_avg: 2.1317984006320714\n",
      "n: 2000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 1.222705441288168\n",
      "n: 15000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 0.8871966891490997\n",
      "n: 1000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 3.8261221589089747\n",
      "n: 500, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 30.32853946259703\n",
      "n: 6000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 1.0123126639862134\n",
      "n: 4000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 5.408288321911121\n",
      "n: 20000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 1.8543671938408026\n",
      "n: 10000, m: 5000, alpha: 0.025 seed: 3 excess_len_avg: 1.9647324885091462\n",
      "n: 2000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 9.249008103486014\n",
      "n: 1000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 6.738067251804112\n",
      "n: 8000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 1.7179206071535582\n",
      "n: 20000, m: 5000, alpha: 0.05 seed: 2 excess_len_avg: 1.3333234011974742\n",
      "n: 15000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 1.2113632732519242\n",
      "n: 4000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 4.03564643635117\n",
      "n: 6000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 2.52177814782448\n",
      "n: 2000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 13.947291907900912\n",
      "n: 1000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 5.2763199506121\n",
      "n: 10000, m: 5000, alpha: 0.05 seed: 3 excess_len_avg: 2.3329186330493568\n",
      "n: 20000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 0.8367717328536608\n",
      "n: 15000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 1.2497443366558927\n",
      "n: 2000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 8.704819313336072\n",
      "n: 4000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 3.7419447400214025\n",
      "n: 1000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 6.9804411091812195\n",
      "n: 8000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 1.528679932443302\n",
      "n: 6000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 0.8711879425250101\n",
      "n: 15000, m: 5000, alpha: 0.075 seed: 3 excess_len_avg: 3.112388959493972\n",
      "n: 2000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 6.876630401516499\n",
      "n: 4000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 5.0677092444052\n",
      "n: 20000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 0.3835783567914969\n",
      "n: 6000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 1.6884640257245112\n",
      "n: 8000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 6.280413087207464\n",
      "n: 20000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 0.9353991562571232\n",
      "n: 2000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 3.275992163224669\n",
      "n: 15000, m: 5000, alpha: 0.1 seed: 3 excess_len_avg: 2.0731820388332416\n",
      "n: 15000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 1.3622815881601635\n",
      "n: 4000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 7.664783668756585\n",
      "n: 2000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 1.2226029312705222\n",
      "n: 6000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 1.378237106024743\n",
      "n: 4000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 5.175293005171076\n",
      "n: 10000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 2.105661590613602\n",
      "n: 15000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 1.9202594162110027\n",
      "n: 20000, m: 5000, alpha: 0.125 seed: 3 excess_len_avg: 1.1447796905549594\n",
      "n: 20000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 1.7519166425391957\n",
      "n: 15000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 1.8841959894145082\n",
      "n: 4000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 46.03907430366001\n",
      "n: 8000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 1.4726748985769105\n",
      "n: 10000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 1.746996351483277\n",
      "n: 20000, m: 5000, alpha: 0.15 seed: 3 excess_len_avg: 0.7587404098952373\n",
      "n: 6000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 2.141424505954726\n",
      "n: 8000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 1.2327761646234319\n",
      "n: 15000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 1.9743048314607845\n",
      "n: 20000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 1.755776059973621\n",
      "n: 10000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 1.9803853545440062\n",
      "n: 6000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 2.6640528577509532\n",
      "n: 20000, m: 5000, alpha: 0.175 seed: 3 excess_len_avg: 1.0477360242667653\n",
      "n: 8000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 18.530555860963247\n",
      "n: 6000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 2.1416824004893655\n",
      "n: 10000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 3.153990160850375\n",
      "n: 15000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 2.2295034764932846\n",
      "n: 8000, m: 5000, alpha: 0.075 seed: 4 excess_len_avg: 1.6944337026453387\n",
      "n: 20000, m: 5000, alpha: 0.2 seed: 3 excess_len_avg: 1.2954565013665797\n",
      "n: 20000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 1.466243673069386\n",
      "n: 10000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 2.6672241905498724\n",
      "n: 8000, m: 5000, alpha: 0.1 seed: 4 excess_len_avg: 2.9319915609708658\n",
      "n: 15000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 1.8829257327945674\n",
      "n: 10000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 2.419890332449924\n",
      "n: 8000, m: 5000, alpha: 0.125 seed: 4 excess_len_avg: 1.8823145323336368\n",
      "n: 20000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 1.9620158852447682\n",
      "n: 15000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 0.6198976092329667\n",
      "n: 10000, m: 5000, alpha: 0.15 seed: 4 excess_len_avg: 2.8186684094276355\n",
      "n: 20000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 2.3008317002289376\n",
      "n: 10000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 1.7691835217175576\n",
      "n: 15000, m: 5000, alpha: 0.175 seed: 4 excess_len_avg: 0.22983411996845843\n",
      "n: 10000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 2.218410722949552\n",
      "n: 15000, m: 5000, alpha: 0.2 seed: 4 excess_len_avg: 2.3047402153586356\n",
      "n: 20000, m: 5000, alpha: 0.01 seed: 4 excess_len_avg: 0.8838967064140826\n",
      "n: 20000, m: 5000, alpha: 0.025 seed: 4 excess_len_avg: 2.3725154553666155\n",
      "n: 20000, m: 5000, alpha: 0.05 seed: 4 excess_len_avg: 2.5625365817698915\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import multiprocess as mp\n",
    "from functools import partial\n",
    "\n",
    "def process_single_run(seed, n, m, alpha):\n",
    "    rng = np.random.default_rng(seed)\n",
    "    alpha_min = 0.005\n",
    "    assert alpha > alpha_min\n",
    "    dataset = Dataset(2, alpha_min, rng)\n",
    "    \n",
    "\n",
    "    try:\n",
    "        X_train, y_train, _ = dataset.generate_X_y(n=n)\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",
    "    # Train models\n",
    "    theta_n_hi, best_lr0_hi, best_loss_hi, history_hi = successive_halving_lr0_tuning(\n",
    "        X_train=X_train, \n",
    "        y_train=y_train, \n",
    "        gamma=1-alpha/2,  # Same gamma as in your original line\n",
    "        rng=rng, \n",
    "        epochs=1,  # Same epochs as in your original line\n",
    "        n_iterations=3,  # Number of elimination rounds\n",
    "        eta=2,  # Eliminate half the candidates each round\n",
    "        debug=False,\n",
    "    )\n",
    "\n",
    "    theta_n_lo, best_lr0_lo, best_loss_lo, history_lo = successive_halving_lr0_tuning(\n",
    "        X_train=X_train, \n",
    "        y_train=y_train, \n",
    "        gamma=alpha/2,  # Same gamma as in your original line\n",
    "        rng=rng, \n",
    "        epochs=1,  # Same epochs as in your original line\n",
    "        n_iterations=3,  # Number of elimination rounds\n",
    "        eta=2,  # Eliminate half the candidates each round\n",
    "        debug=False,\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) - true_interval\n",
    "\n",
    "    res = {'n': n, 'alpha': alpha, '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",
    "def generate_parameter_combinations(n_list, m_list, seeds, alphas):\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",
    "if __name__ == '__main__':\n",
    "    n_list = [200, 500, 1000, 2000, 4000, 6000, 8000, 10000, 15000, 20000]\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",
    "    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",
    "    df = pd.DataFrame(results)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7593795",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(results)\n",
    "df.to_csv(\"./cqr_vary_n_uniform_l1.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9720cdc8",
   "metadata": {},
   "source": [
    "## Part 3: Fix n = 5000, vary m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "9b76e358",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n: 5000, m: 75, alpha: 0.075 seed: 0 excess_len_avg: 0.5530291758092261n: 5000, m: 25, alpha: 0.15 seed: 0 excess_len_avg: 4.582879530675664\n",
      "\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 0 excess_len_avg: 4.601192314514702\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 0 excess_len_avg: 1.173072373752188\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 0 excess_len_avg: 56.48562375193453\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 1 excess_len_avg: 5.14266775436377\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 1 excess_len_avg: 0.18537719765975827\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 0 excess_len_avg: 0.5605855628992888\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 0 excess_len_avg: 0.21013770116389408\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 0 excess_len_avg: 0.41837761088627234\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 0 excess_len_avg: 4.929179141824093\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 0 excess_len_avg: 1.8963126274318365\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 0 excess_len_avg: 3.4140276376417504\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 0 excess_len_avg: 1.607906066815815\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 0 excess_len_avg: 1.3021726444892865\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 1 excess_len_avg: 3.3352359251690884\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 1 excess_len_avg: 2.334072370318229\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 0 excess_len_avg: 0.09835027760676301\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 0 excess_len_avg: 0.2169894086797898\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 0 excess_len_avg: 5.140616972296303\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 0 excess_len_avg: 1.4354198428487583\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 0 excess_len_avg: 0.8498050611244152\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 0 excess_len_avg: 1.0509401257434177\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 0 excess_len_avg: 1.039813087085563\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 1 excess_len_avg: 1.1308783845067174\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 1 excess_len_avg: 4.482767542976979\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 0 excess_len_avg: 0.09702039141243222\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 0 excess_len_avg: 0.419243899862124\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 0 excess_len_avg: 0.15494597571258018\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 0 excess_len_avg: 0.5431879519440288\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 0 excess_len_avg: 1.6410370414691156\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 0 excess_len_avg: 1.799420990588027\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 0 excess_len_avg: 0.5114591812155942\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 0 excess_len_avg: 0.40484960950511045\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 1 excess_len_avg: 0.18537719765975874\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 1 excess_len_avg: 6.6314627156351955\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 0 excess_len_avg: 0.031522999700046773\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 0 excess_len_avg: 2.5217957467375727\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 0 excess_len_avg: 0.8617303053524504\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 0 excess_len_avg: 2.4163636107661706\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 0 excess_len_avg: 2.344896064629371\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 1 excess_len_avg: 2.6578090641553067\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 0 excess_len_avg: 0.40328508552632\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 1 excess_len_avg: 8.780157888293681\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 0 excess_len_avg: 0.3307518437232221\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 0 excess_len_avg: 0.5201148109239079\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 0 excess_len_avg: 4.500403541531646\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 0 excess_len_avg: 0.12358755262521004\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 0 excess_len_avg: 0.7902542758118323\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 0 excess_len_avg: 1.9248912297895386\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 0 excess_len_avg: 3.2395960790542895\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 1 excess_len_avg: 1.5158440128523631\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 0 excess_len_avg: 0.4209484095999901\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 1 excess_len_avg: 2.721467088866302\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 0 excess_len_avg: 6.479011336324786\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 0 excess_len_avg: 0.5530291758093901\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 0 excess_len_avg: 56.48562375193613\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 0 excess_len_avg: 0.05928874324332725\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 0 excess_len_avg: 0.8314987070686382\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 0 excess_len_avg: 2.8894921014740316\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 1 excess_len_avg: 1.1441968078685871\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 0 excess_len_avg: 8.457619131118179\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 0 excess_len_avg: 0.008220893502622851\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 1 excess_len_avg: 5.332551710971842\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 0 excess_len_avg: 1.8963126274322508\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 0 excess_len_avg: 1.302172644488634\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 0 excess_len_avg: 0.035979992106227064\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 0 excess_len_avg: 0.1814612512994344\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 0 excess_len_avg: 3.710336759521382\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 0 excess_len_avg: 0.7276070910227561\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 0 excess_len_avg: 2.6909739967888178\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 1 excess_len_avg: 0.38739067972553504\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 0 excess_len_avg: 0.17677792931100123\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 1 excess_len_avg: 3.7569242135464784n: 5000, m: 50, alpha: 0.125 seed: 0 excess_len_avg: 0.8498050611239745\n",
      "\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 0 excess_len_avg: 0.8499470034586613\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 0 excess_len_avg: 3.627157332387719\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 0 excess_len_avg: 0.09732165303881618\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 0 excess_len_avg: 2.939507798404597\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 0 excess_len_avg: 2.2674378899550085\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 0 excess_len_avg: 0.7121485703980188\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 1 excess_len_avg: 2.8728518672117196\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 0 excess_len_avg: 0.11781371394275814\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 0 excess_len_avg: 1.185477041078415\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 1 excess_len_avg: 1.1308783845071568\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 0 excess_len_avg: 0.1589746559224352\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 0 excess_len_avg: 25.3071435742039\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 0 excess_len_avg: 0.3885749377525622\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 0 excess_len_avg: 2.133537727433333\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 0 excess_len_avg: 3.710336759521382\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 0 excess_len_avg: 1.8963126274318365\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 1 excess_len_avg: 0.1534404995550201\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 0 excess_len_avg: 0.06296160050389578\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 1 excess_len_avg: 1.4951674445341816\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 0 excess_len_avg: 1.1528018177254606\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 0 excess_len_avg: 0.8519740135987779\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 0 excess_len_avg: 0.7902542758118389\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 0 excess_len_avg: 0.23955373417147866\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 0 excess_len_avg: 2.568473443740666\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 0 excess_len_avg: 1.8119299718176616\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 0 excess_len_avg: 0.6580450265432918\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 1 excess_len_avg: 1.8002477995250274\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 1 excess_len_avg: 2.334072370317986\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 0 excess_len_avg: 0.4209484096001181\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 0 excess_len_avg: 0.5530291758100534\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 0 excess_len_avg: 0.30465286153005117\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 0 excess_len_avg: 1.3862379704178318\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 0 excess_len_avg: 0.15494597571371946\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 0 excess_len_avg: 0.0983502776066993\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 0 excess_len_avg: 2.2674378899550085\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 0 excess_len_avg: 0.5543505110492487\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 1 excess_len_avg: 0.3228495431791554\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 1 excess_len_avg: 4.004895123985923\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 0 excess_len_avg: 2.3448960646293973\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 0 excess_len_avg: 0.5431879519446182\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 0 excess_len_avg: 0.8617303053523351\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 0 excess_len_avg: 3.567883783937958\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 0 excess_len_avg: 0.00522383247554043\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 0 excess_len_avg: 0.18146125130122434\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 1 excess_len_avg: 6.217017414653305\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 1 excess_len_avg: 0.1853771976597584\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 0 excess_len_avg: 0.016990319530527855\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 0 excess_len_avg: 3.2395960790536655\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 0 excess_len_avg: 0.49966610213961105\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 0 excess_len_avg: 0.6820499514287213\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 0 excess_len_avg: 3.4868574859952295\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 0 excess_len_avg: 0.3335724462827761\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 0 excess_len_avg: 0.29880364489752265\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 1 excess_len_avg: 1.3090300549600828\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 0 excess_len_avg: 0.09506881887117477\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 1 excess_len_avg: 1.048508703929703\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 1 excess_len_avg: 0.10340697894608432\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 0 excess_len_avg: 0.585457795863354\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 1 excess_len_avg: 0.23191695286215283\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 1 excess_len_avg: 0.05462098819658755\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 0 excess_len_avg: 0.01810559536407912\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 0 excess_len_avg: 0.12358755262525749\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 1 excess_len_avg: 2.721467088866293\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 0 excess_len_avg: 0.41059329985607435\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 1 excess_len_avg: 0.6190393112709379\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 1 excess_len_avg: 0.8365547179456674\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 1 excess_len_avg: 0.7464055971410704\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 1 excess_len_avg: 0.10926921898809909\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 0 excess_len_avg: 0.28528808830186614\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 1 excess_len_avg: 0.5606658654082295\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 2 excess_len_avg: 7.406564146921951\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 0 excess_len_avg: 0.2291739948144157\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 1 excess_len_avg: 2.26855651804665\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 1 excess_len_avg: 0.8509114297280493\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 0 excess_len_avg: 0.023890617351553914\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 1 excess_len_avg: 0.4992014872911853\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 2 excess_len_avg: 9.161310363882047\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 1 excess_len_avg: 0.4343983076623638\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 2 excess_len_avg: 1.0102820568877349\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 1 excess_len_avg: 0.5334693750558798\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 1 excess_len_avg: 0.1534404995563685\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 2 excess_len_avg: 5.741447552992402\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 1 excess_len_avg: 0.06627619435240444\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 2 excess_len_avg: 1.5566924708167331\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 1 excess_len_avg: 0.3320857193471472\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 0 excess_len_avg: 0.16750290537001028\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 1 excess_len_avg: 0.5488022798743375\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 1 excess_len_avg: 0.9474047157870532\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 1 excess_len_avg: 0.2117298668474947\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 0 excess_len_avg: 0.15589678537260715\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 2 excess_len_avg: 2.024642878952309\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 1 excess_len_avg: 1.317146518191844\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 2 excess_len_avg: 2.1031028847458018\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 1 excess_len_avg: 0.3871376565898781\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 2 excess_len_avg: 0.9775675408794557\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 1 excess_len_avg: 0.3675479292471627\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 2 excess_len_avg: 2.174049547903848\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 1 excess_len_avg: 0.1833769390443688\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 1 excess_len_avg: 0.32284954317913955\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 1 excess_len_avg: 0.92080412314929\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 1 excess_len_avg: 2.268556518046642\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 2 excess_len_avg: 0.7675580225774958\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 2 excess_len_avg: 0.5777314435816951\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 0 excess_len_avg: 0.2204173314177022\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 0 excess_len_avg: 0.17038799980995006\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 1 excess_len_avg: 0.06744688883959177\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 1 excess_len_avg: 0.06095062733442981\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 1 excess_len_avg: 0.9465971010291953\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 1 excess_len_avg: 0.9061064611123475\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 2 excess_len_avg: 2.512683586036459\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 2 excess_len_avg: 0.7324067726778809\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 1 excess_len_avg: 0.15344049955810343\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 1 excess_len_avg: 0.7622551673314307\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 1 excess_len_avg: 1.0485087039297025\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 2 excess_len_avg: 4.257809149493583\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 2 excess_len_avg: 0.4103850193277001\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 0 excess_len_avg: 0.23102510143432034\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 1 excess_len_avg: 0.7421915968453736\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 1 excess_len_avg: 0.6203509782564122\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 1 excess_len_avg: 0.84805749137231\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 0 excess_len_avg: 0.28338979138678133\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 2 excess_len_avg: 5.651817929961773\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 2 excess_len_avg: 0.6058474480879206\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 2 excess_len_avg: 0.4103850193269509\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 1 excess_len_avg: 0.42343720099675397\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 1 excess_len_avg: 0.6190393112714404\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 1 excess_len_avg: 0.21198111364196132\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 1 excess_len_avg: 0.6812768159077603\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 1 excess_len_avg: 0.6274004277824825\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 1 excess_len_avg: 0.32284954317829045\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 2 excess_len_avg: 7.40656414692195\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 2 excess_len_avg: 0.8689057140078282\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 2 excess_len_avg: 0.0825387709706657\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 1 excess_len_avg: 0.3320857193471473\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 2 excess_len_avg: 4.318531932859792\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 2 excess_len_avg: 1.010282056887856\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 1 excess_len_avg: 1.5977508124179682\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 1 excess_len_avg: 0.1384911325706675\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 1 excess_len_avg: 0.1853771976600183\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 1 excess_len_avg: 0.3623644645441957\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 2 excess_len_avg: 0.4638716429588787\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 0 excess_len_avg: 0.43808864688982535\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 2 excess_len_avg: 5.678972485904314\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 1 excess_len_avg: 0.38739067972553537\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 2 excess_len_avg: 1.5566924708167316\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 2 excess_len_avg: 0.7049887168158688\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 1 excess_len_avg: 0.0003243572605009426\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 1 excess_len_avg: 0.8809936060357142\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 1 excess_len_avg: 0.6939295658173666\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 1 excess_len_avg: 5.401230251247477\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 1 excess_len_avg: 0.8646052686524797\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 2 excess_len_avg: 0.41038501932718235\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 2 excess_len_avg: 1.5706608265715618\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 1 excess_len_avg: 2.8012997537561524\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 2 excess_len_avg: 0.5482989486255978\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 1 excess_len_avg: 0.03086411580427257\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 2 excess_len_avg: 0.0825387709692564\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 1 excess_len_avg: 0.7170910525372962\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 1 excess_len_avg: 4.112013147656484\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 1 excess_len_avg: 0.665583372100278\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 2 excess_len_avg: 1.6486749642830172\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 2 excess_len_avg: 1.21379391884328\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 1 excess_len_avg: 0.3944286251768282\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 1 excess_len_avg: 68.39896076247011\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 2 excess_len_avg: 0.8400807980765137\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 2 excess_len_avg: 0.5777314435816951\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 1 excess_len_avg: 0.3320857193460902\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 1 excess_len_avg: 1.963317974998517\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 2 excess_len_avg: 1.2791863982462408\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 1 excess_len_avg: 0.03864879421018133\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 1 excess_len_avg: 0.6203509782564125\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 1 excess_len_avg: 1.3171465181922548n: 5000, m: 150, alpha: 0.15 seed: 2 excess_len_avg: 1.279186398246137\n",
      "\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 1 excess_len_avg: 0.13094417502879546\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 2 excess_len_avg: 0.7324067726778807\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 1 excess_len_avg: 0.07972890519318063\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 2 excess_len_avg: 0.5777314435816955\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 2 excess_len_avg: 0.016383992897986872\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 1 excess_len_avg: 0.38713765658987787\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 2 excess_len_avg: 0.22563159666283666\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 1 excess_len_avg: 0.8509114297266391\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 1 excess_len_avg: 1.1308783845070733\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 2 excess_len_avg: 0.1251479584529205\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 1 excess_len_avg: 0.7111160000938548\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 2 excess_len_avg: 0.012262705102003214\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 2 excess_len_avg: 0.21617714055551265\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 2 excess_len_avg: 0.5668421171520108\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 1 excess_len_avg: 2.0116893433177387\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 2 excess_len_avg: 0.12514795845006105\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 2 excess_len_avg: 0.24602013678591447\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 2 excess_len_avg: 0.2179940508668617\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 1 excess_len_avg: 1.003625098752389\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 2 excess_len_avg: 0.7363088097559587\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 1 excess_len_avg: 0.10107231339222812n: 5000, m: 3000, alpha: 0.125 seed: 1 excess_len_avg: 0.06806060749153439\n",
      "\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 2 excess_len_avg: 0.12514795845111248\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 1 excess_len_avg: 0.1601517829548966\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 2 excess_len_avg: 0.6058474480873409\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 2 excess_len_avg: 0.3693962864318385\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 2 excess_len_avg: 1.0740201069541695\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 2 excess_len_avg: 0.21471511129815793\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 2 excess_len_avg: 0.08253877096936213\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 1 excess_len_avg: 0.9208041231490386\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 2 excess_len_avg: 0.043633923675062254\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 2 excess_len_avg: 0.7052666790187492\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 2 excess_len_avg: 0.4720671112645621\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 2 excess_len_avg: 0.654596254147357\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 3 excess_len_avg: 1.4041849230876926\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 2 excess_len_avg: 0.00563534792082716\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 1 excess_len_avg: 0.5307575377994689\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 1 excess_len_avg: 0.08416930500100057\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 2 excess_len_avg: 0.3396751215805297\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 2 excess_len_avg: 0.5734833285744412\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 1 excess_len_avg: 0.032624444044329494\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 3 excess_len_avg: 0.9230458433308267\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 2 excess_len_avg: 0.09909141488560348n: 5000, m: 300, alpha: 0.2 seed: 2 excess_len_avg: 0.5668421171519852\n",
      "\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 2 excess_len_avg: 0.35533095268680037\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 2 excess_len_avg: 0.7789128734035458\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 3 excess_len_avg: 0.12114737707099288n: 5000, m: 3000, alpha: 0.1 seed: 2 excess_len_avg: 0.034079178215014536\n",
      "\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 1 excess_len_avg: 0.7381489456070601\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 2 excess_len_avg: 0.3207834675302856\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 2 excess_len_avg: 0.12514795844991716\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 2 excess_len_avg: 0.05772188694101078\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 2 excess_len_avg: 0.0729997864474552\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 3 excess_len_avg: 0.6807510891893037\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 1 excess_len_avg: 0.10024058598403497\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 2 excess_len_avg: 1.21379391884398\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 3 excess_len_avg: 0.7767159552328453\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 2 excess_len_avg: 0.8197604605355553\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 2 excess_len_avg: 0.246020136786268\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 2 excess_len_avg: 0.12529209935218638\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 3 excess_len_avg: 0.44711283992169637\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 3 excess_len_avg: 1.7896009035761686\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 3 excess_len_avg: 1.3829782725890292\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 1 excess_len_avg: 0.2483413535444831\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 2 excess_len_avg: 0.2528365446987582\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 2 excess_len_avg: 0.032401833134195326\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 2 excess_len_avg: 0.7868681664949689\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 3 excess_len_avg: 0.12741222259830146\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 3 excess_len_avg: 1.6292784601727246\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 2 excess_len_avg: 0.09084921747588522\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 2 excess_len_avg: 0.1576110084322825\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 3 excess_len_avg: 0.9535998938731596\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 1 excess_len_avg: 0.1364741609620641\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 2 excess_len_avg: 0.22563159666283672\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 3 excess_len_avg: 1.0504722165796152\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 3 excess_len_avg: 2.0959728787758185\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 3 excess_len_avg: 0.043408559827450316\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 2 excess_len_avg: 0.4469209803633364\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 2 excess_len_avg: 0.11456898989102172\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 2 excess_len_avg: 0.16661290913131263\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 3 excess_len_avg: 1.3886303528101234\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 3 excess_len_avg: 1.3754006630795719\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 2 excess_len_avg: 0.5668421171519908\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 3 excess_len_avg: 0.6324645350571955\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 2 excess_len_avg: 0.021668308297892732\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 2 excess_len_avg: 0.26139544083579425\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 1 excess_len_avg: 0.29811262164666424\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 3 excess_len_avg: 2.3659768765420175\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 3 excess_len_avg: 1.3112276318263578\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 2 excess_len_avg: 0.12514795845103688\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 3 excess_len_avg: 0.02867965864864876\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 2 excess_len_avg: 0.12514795845107174\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 1 excess_len_avg: 0.4180624062494461\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 3 excess_len_avg: 0.04340855982634374\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 2 excess_len_avg: 0.08154926289179307\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 2 excess_len_avg: 2.4200146680547423\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 2 excess_len_avg: 0.2762027204415391\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 3 excess_len_avg: 1.3286214052676901\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 3 excess_len_avg: 0.6807510891893034\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 2 excess_len_avg: 0.24602013678622603\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 2 excess_len_avg: 0.26692293110473614\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 2 excess_len_avg: 0.13074598637374943\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 3 excess_len_avg: 0.6324645350573692\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 2 excess_len_avg: 1.3671669378789642\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 3 excess_len_avg: 0.3325527073046282\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 3 excess_len_avg: 0.5761113791420881\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 2 excess_len_avg: 0.7868681664951145\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 3 excess_len_avg: 0.12114737707099425n: 5000, m: 300, alpha: 0.05 seed: 2 excess_len_avg: 0.005635347921443523\n",
      "\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 2 excess_len_avg: 0.3875792790812199\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 3 excess_len_avg: 0.12741222259763138\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 2 excess_len_avg: 0.00028098186147582636\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 3 excess_len_avg: 0.8523775253317272\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 2 excess_len_avg: 0.07767477645784111\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 1 excess_len_avg: 0.166575065114388\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 2 excess_len_avg: 0.6545962541473566\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 3 excess_len_avg: 0.3939680013720433\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 3 excess_len_avg: 0.2735749862938962\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 3 excess_len_avg: 0.671740422848678\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 2 excess_len_avg: 2.142325496041514\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 3 excess_len_avg: 0.8990275657802308\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 2 excess_len_avg: 0.1694347564939942\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 2 excess_len_avg: 0.14964702391993007\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 2 excess_len_avg: 0.5668421171519847\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 3 excess_len_avg: 0.4471128399214995\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 3 excess_len_avg: 1.382978272589029\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 3 excess_len_avg: 0.5314530299474016\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 2 excess_len_avg: 3.8970717130017634\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 3 excess_len_avg: 1.5411155835079153\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 2 excess_len_avg: 0.05772188694101098\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 3 excess_len_avg: 1.4041849230875358\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 3 excess_len_avg: 2.1706466298330906\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 3 excess_len_avg: 0.12741222259830162\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 3 excess_len_avg: 2.000544750387395\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 3 excess_len_avg: 0.29285314433886483n: 5000, m: 2000, alpha: 0.2 seed: 1 excess_len_avg: 0.4040285248335883\n",
      "\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 2 excess_len_avg: 5.651817929961679\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 3 excess_len_avg: 1.0279312791594708\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 2 excess_len_avg: 0.053792192413049285\n",
      "n: 5000, m: 10, alpha: 0.025 seed: 3 excess_len_avg: 0.923045843330993\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 3 excess_len_avg: 0.33255270730360903\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 3 excess_len_avg: 2.6045280964077184\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 3 excess_len_avg: 1.235352513273998\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 3 excess_len_avg: 1.9502682417206474\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 3 excess_len_avg: 1.496691606839079\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 2 excess_len_avg: 0.15714104428535738\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 3 excess_len_avg: 0.12114737707099173\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 3 excess_len_avg: 1.1157489330757067\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 2 excess_len_avg: 0.16709105191012588\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 3 excess_len_avg: 2.295451383590701\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 3 excess_len_avg: 0.033990702968871904\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 3 excess_len_avg: 1.375400663079487\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 3 excess_len_avg: 1.1598844745410983\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 3 excess_len_avg: 1.7366564003315448\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 3 excess_len_avg: 0.37069107292312764\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 3 excess_len_avg: 0.6807510891897759\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 3 excess_len_avg: 0.8990275657800855\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 3 excess_len_avg: 0.33255270730444875\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 3 excess_len_avg: 1.1805644434965525\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 3 excess_len_avg: 2.0658708803997445\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 2 excess_len_avg: 0.2269443302911876\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 3 excess_len_avg: 1.482649555449605\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 3 excess_len_avg: 1.786748315860194\n",
      "n: 5000, m: 25, alpha: 0.075 seed: 4 excess_len_avg: 0.8399253327809924\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 3 excess_len_avg: 0.11707574474548116\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 3 excess_len_avg: 1.4087143674575\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 3 excess_len_avg: 2.2845480217098992\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 3 excess_len_avg: 0.8523775253320687\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 3 excess_len_avg: 2.672243393088604\n",
      "n: 5000, m: 75, alpha: 0.01 seed: 4 excess_len_avg: 1.1342053449667564\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 3 excess_len_avg: 2.0550918083305847\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 3 excess_len_avg: 0.59567164665725\n",
      "n: 5000, m: 25, alpha: 0.1 seed: 4 excess_len_avg: 0.27498863346126495\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 3 excess_len_avg: 3.0864464879702016\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 3 excess_len_avg: 2.7497831827345474\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 2 excess_len_avg: 0.1793012946917279\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 3 excess_len_avg: 0.7651874031178079\n",
      "n: 5000, m: 100, alpha: 0.15 seed: 4 excess_len_avg: 2.1435407818456853\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 3 excess_len_avg: 0.09522991530954072\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 3 excess_len_avg: 1.6984504128128044\n",
      "n: 5000, m: 75, alpha: 0.025 seed: 4 excess_len_avg: 0.38509884272532663\n",
      "n: 5000, m: 25, alpha: 0.125 seed: 4 excess_len_avg: 1.5519464972893735\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 3 excess_len_avg: 3.888344954230503\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 3 excess_len_avg: 2.39547313403017\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 3 excess_len_avg: 1.2353525132740815\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 3 excess_len_avg: 0.4021900051487086\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 3 excess_len_avg: 1.8363482412825023\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 3 excess_len_avg: 3.8954396426054636\n",
      "n: 5000, m: 100, alpha: 0.175 seed: 4 excess_len_avg: 2.8395051770613198\n",
      "n: 5000, m: 75, alpha: 0.05 seed: 4 excess_len_avg: 1.5169671384346197\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 3 excess_len_avg: 0.3325527073042739\n",
      "n: 5000, m: 25, alpha: 0.15 seed: 4 excess_len_avg: 0.04904129403880104\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 3 excess_len_avg: 0.01774263125551439\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 3 excess_len_avg: 1.171154403119804\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 2 excess_len_avg: 0.23124000550741503\n",
      "n: 5000, m: 10, alpha: 0.01 seed: 4 excess_len_avg: 10.555280136715794\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 3 excess_len_avg: 0.09892729040219428\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 3 excess_len_avg: 0.8523775253314059\n",
      "n: 5000, m: 100, alpha: 0.2 seed: 4 excess_len_avg: 3.0900724074712858\n",
      "n: 5000, m: 200, alpha: 0.075 seed: 4 excess_len_avg: 1.76900879881223\n",
      "n: 5000, m: 75, alpha: 0.075 seed: 4 excess_len_avg: 0.1073654496590622\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 3 excess_len_avg: 1.8004980131050818\n",
      "n: 5000, m: 25, alpha: 0.175 seed: 4 excess_len_avg: 1.0523628498922986\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 3 excess_len_avg: 0.011603219043650118\n",
      "n: 5000, m: 300, alpha: 0.05 seed: 3 excess_len_avg: 0.2928531443388986n: 5000, m: 10, alpha: 0.025 seed: 4 excess_len_avg: 9.72620192988918\n",
      "\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 3 excess_len_avg: 0.2994250794065672\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 3 excess_len_avg: 2.131211227954201\n",
      "n: 5000, m: 75, alpha: 0.1 seed: 4 excess_len_avg: 0.2749886334615005\n",
      "n: 5000, m: 150, alpha: 0.01 seed: 4 excess_len_avg: 0.5157959225736662\n",
      "n: 5000, m: 200, alpha: 0.1 seed: 4 excess_len_avg: 3.152934288618336\n",
      "n: 5000, m: 25, alpha: 0.2 seed: 4 excess_len_avg: 0.05362285023566428\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 2 excess_len_avg: 0.1417585931266471\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 3 excess_len_avg: 1.4966916068404421\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 3 excess_len_avg: 1.9739286223826162\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 3 excess_len_avg: 0.22097698499458893\n",
      "n: 5000, m: 10, alpha: 0.05 seed: 4 excess_len_avg: 8.344404918510643\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 3 excess_len_avg: 0.02551870625927456\n",
      "n: 5000, m: 75, alpha: 0.125 seed: 4 excess_len_avg: 1.5519464972897703\n",
      "n: 5000, m: 150, alpha: 0.025 seed: 4 excess_len_avg: 0.1627320206044107\n",
      "n: 5000, m: 50, alpha: 0.01 seed: 4 excess_len_avg: 1.1342053449701777\n",
      "n: 5000, m: 200, alpha: 0.125 seed: 4 excess_len_avg: 2.668751238366753\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 3 excess_len_avg: 1.6292784601722565\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 3 excess_len_avg: 2.041485823425455\n",
      "n: 5000, m: 10, alpha: 0.075 seed: 4 excess_len_avg: 6.9626079071328935\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 3 excess_len_avg: 0.31468915159605093\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 3 excess_len_avg: 2.0158731116386903\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 3 excess_len_avg: 0.01977640252385597\n",
      "n: 5000, m: 75, alpha: 0.15 seed: 4 excess_len_avg: 2.817216872993874\n",
      "n: 5000, m: 50, alpha: 0.025 seed: 4 excess_len_avg: 0.3850988427240119\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 2 excess_len_avg: 0.07491733837846544\n",
      "n: 5000, m: 150, alpha: 0.05 seed: 4 excess_len_avg: 1.5169671384353434\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 3 excess_len_avg: 0.4314823606134959\n",
      "n: 5000, m: 200, alpha: 0.15 seed: 4 excess_len_avg: 2.143540781845687\n",
      "n: 5000, m: 10, alpha: 0.1 seed: 4 excess_len_avg: 5.580810895752054\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 3 excess_len_avg: 0.4912654657576398\n",
      "n: 5000, m: 75, alpha: 0.175 seed: 4 excess_len_avg: 5.317482300070858\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 3 excess_len_avg: 0.8523775253312688\n",
      "n: 5000, m: 50, alpha: 0.05 seed: 4 excess_len_avg: 0.08295122942898862\n",
      "n: 5000, m: 400, alpha: 0.01 seed: 4 excess_len_avg: 0.05471373081137568\n",
      "n: 5000, m: 150, alpha: 0.075 seed: 4 excess_len_avg: 1.7690087988126744\n",
      "n: 5000, m: 200, alpha: 0.175 seed: 4 excess_len_avg: 2.670460825811585\n",
      "n: 5000, m: 500, alpha: 0.15 seed: 4 excess_len_avg: 1.5591350675803566\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 3 excess_len_avg: 0.05945566122275715\n",
      "n: 5000, m: 10, alpha: 0.125 seed: 4 excess_len_avg: 4.1990138843729765\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 3 excess_len_avg: 0.7432325817902427\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 3 excess_len_avg: 0.8310447653301888\n",
      "n: 5000, m: 75, alpha: 0.2 seed: 4 excess_len_avg: 4.981812801250585\n",
      "n: 5000, m: 50, alpha: 0.075 seed: 4 excess_len_avg: 0.8399253327805216\n",
      "n: 5000, m: 150, alpha: 0.1 seed: 4 excess_len_avg: 3.152934288618337\n",
      "n: 5000, m: 400, alpha: 0.025 seed: 4 excess_len_avg: 0.004984799488962021\n",
      "n: 5000, m: 200, alpha: 0.2 seed: 4 excess_len_avg: 2.8147344070782\n",
      "n: 5000, m: 500, alpha: 0.175 seed: 4 excess_len_avg: 1.325057943271241\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 3 excess_len_avg: 0.7632252235833166\n",
      "n: 5000, m: 10, alpha: 0.15 seed: 4 excess_len_avg: 2.817216872993874\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 3 excess_len_avg: 0.02991841120858989\n",
      "n: 5000, m: 50, alpha: 0.1 seed: 4 excess_len_avg: 0.27498863346150076\n",
      "n: 5000, m: 100, alpha: 0.01 seed: 4 excess_len_avg: 1.1342053449707943\n",
      "n: 5000, m: 150, alpha: 0.125 seed: 4 excess_len_avg: 1.8345933556295018\n",
      "n: 5000, m: 400, alpha: 0.05 seed: 4 excess_len_avg: 1.55083175060277\n",
      "n: 5000, m: 300, alpha: 0.01 seed: 4 excess_len_avg: 0.23825029010113846\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 3 excess_len_avg: 0.8391734837081521\n",
      "n: 5000, m: 10, alpha: 0.175 seed: 4 excess_len_avg: 1.435419861614769\n",
      "n: 5000, m: 500, alpha: 0.2 seed: 4 excess_len_avg: 1.503457432453105\n",
      "n: 5000, m: 2000, alpha: 0.075 seed: 4 excess_len_avg: 0.29746522871202885\n",
      "n: 5000, m: 50, alpha: 0.125 seed: 4 excess_len_avg: 1.5519464972896868\n",
      "n: 5000, m: 100, alpha: 0.025 seed: 4 excess_len_avg: 2.104362767715705\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 3 excess_len_avg: 0.07109447520911343\n",
      "n: 5000, m: 150, alpha: 0.15 seed: 4 excess_len_avg: 2.9389270537833174\n",
      "n: 5000, m: 300, alpha: 0.025 seed: 4 excess_len_avg: 0.004984799490294729\n",
      "n: 5000, m: 400, alpha: 0.075 seed: 4 excess_len_avg: 1.822085215934435\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 3 excess_len_avg: 0.8184349094581208\n",
      "n: 5000, m: 10, alpha: 0.2 seed: 4 excess_len_avg: 8.140555818613189\n",
      "n: 5000, m: 50, alpha: 0.15 seed: 4 excess_len_avg: 2.143540781845687\n",
      "n: 5000, m: 1000, alpha: 0.01 seed: 4 excess_len_avg: 0.054713730810217465\n",
      "n: 5000, m: 100, alpha: 0.05 seed: 4 excess_len_avg: 1.6448822916777968\n",
      "n: 5000, m: 150, alpha: 0.175 seed: 4 excess_len_avg: 4.045224037457069\n",
      "n: 5000, m: 25, alpha: 0.01 seed: 4 excess_len_avg: 4.563243035235828n: 5000, m: 300, alpha: 0.05 seed: 4 excess_len_avg: 1.604119799428389\n",
      "\n",
      "n: 5000, m: 2000, alpha: 0.1 seed: 4 excess_len_avg: 0.3111028616150031\n",
      "n: 5000, m: 400, alpha: 0.1 seed: 4 excess_len_avg: 2.0990187708209067\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 3 excess_len_avg: 0.020772031939082804\n",
      "n: 5000, m: 50, alpha: 0.175 seed: 4 excess_len_avg: 1.435419861614769\n",
      "n: 5000, m: 100, alpha: 0.075 seed: 4 excess_len_avg: 1.4661704117319787\n",
      "n: 5000, m: 150, alpha: 0.2 seed: 4 excess_len_avg: 3.216097024589213\n",
      "n: 5000, m: 1000, alpha: 0.025 seed: 4 excess_len_avg: 0.16273202060396008\n",
      "n: 5000, m: 25, alpha: 0.025 seed: 4 excess_len_avg: 3.848533968272167\n",
      "n: 5000, m: 300, alpha: 0.075 seed: 4 excess_len_avg: 1.7690087988121654\n",
      "n: 5000, m: 400, alpha: 0.125 seed: 4 excess_len_avg: 1.8345933556288023\n",
      "n: 5000, m: 50, alpha: 0.2 seed: 4 excess_len_avg: 3.711480931945881\n",
      "n: 5000, m: 100, alpha: 0.1 seed: 4 excess_len_avg: 1.794173682813163\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 3 excess_len_avg: 0.007269560130320317\n",
      "n: 5000, m: 200, alpha: 0.01 seed: 4 excess_len_avg: 0.5157959225743162\n",
      "n: 5000, m: 2000, alpha: 0.125 seed: 4 excess_len_avg: 0.5890594975794777\n",
      "n: 5000, m: 25, alpha: 0.05 seed: 4 excess_len_avg: 1.6448822916772605\n",
      "n: 5000, m: 300, alpha: 0.1 seed: 4 excess_len_avg: 2.308669379761968\n",
      "n: 5000, m: 1000, alpha: 0.05 seed: 4 excess_len_avg: 0.4888618999609771\n",
      "n: 5000, m: 400, alpha: 0.15 seed: 4 excess_len_avg: 2.091762073037088\n",
      "n: 5000, m: 100, alpha: 0.125 seed: 4 excess_len_avg: 1.5519464972885073\n",
      "n: 5000, m: 200, alpha: 0.025 seed: 4 excess_len_avg: 0.004984799487829026\n",
      "n: 5000, m: 300, alpha: 0.125 seed: 4 excess_len_avg: 1.8345933556295013\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 3 excess_len_avg: 0.1258043236191799\n",
      "n: 5000, m: 400, alpha: 0.175 seed: 4 excess_len_avg: 2.2039560717898947\n",
      "n: 5000, m: 2000, alpha: 0.15 seed: 4 excess_len_avg: 0.46474750035604895\n",
      "n: 5000, m: 1000, alpha: 0.075 seed: 4 excess_len_avg: 0.4182892346349191\n",
      "n: 5000, m: 200, alpha: 0.05 seed: 4 excess_len_avg: 1.6041197994286784\n",
      "n: 5000, m: 300, alpha: 0.15 seed: 4 excess_len_avg: 2.110412640044516\n",
      "n: 5000, m: 400, alpha: 0.2 seed: 4 excess_len_avg: 1.8524623744276987\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 3 excess_len_avg: 0.10842219965005878\n",
      "n: 5000, m: 1000, alpha: 0.1 seed: 4 excess_len_avg: 0.629322650576508\n",
      "n: 5000, m: 300, alpha: 0.175 seed: 4 excess_len_avg: 1.8331003266563293\n",
      "n: 5000, m: 2000, alpha: 0.175 seed: 4 excess_len_avg: 0.3286896517165814\n",
      "n: 5000, m: 500, alpha: 0.01 seed: 4 excess_len_avg: 0.17124389505590984\n",
      "n: 5000, m: 300, alpha: 0.2 seed: 4 excess_len_avg: 2.212245891403848\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 3 excess_len_avg: 0.2413534290434518\n",
      "n: 5000, m: 1000, alpha: 0.125 seed: 4 excess_len_avg: 0.5102194411673888\n",
      "n: 5000, m: 500, alpha: 0.025 seed: 4 excess_len_avg: 0.0049847994879939775\n",
      "n: 5000, m: 2000, alpha: 0.2 seed: 4 excess_len_avg: 0.26619629718622534\n",
      "n: 5000, m: 1000, alpha: 0.15 seed: 4 excess_len_avg: 0.27442220847643556\n",
      "n: 5000, m: 500, alpha: 0.05 seed: 4 excess_len_avg: 1.5876725661980897\n",
      "n: 5000, m: 1000, alpha: 0.175 seed: 4 excess_len_avg: 0.04329984478822897\n",
      "n: 5000, m: 500, alpha: 0.075 seed: 4 excess_len_avg: 1.7085637741478978\n",
      "n: 5000, m: 3000, alpha: 0.01 seed: 4 excess_len_avg: 0.09350372934390049\n",
      "n: 5000, m: 500, alpha: 0.1 seed: 4 excess_len_avg: 1.9184390213792621\n",
      "n: 5000, m: 1000, alpha: 0.2 seed: 4 excess_len_avg: 0.3936824071144024\n",
      "n: 5000, m: 500, alpha: 0.125 seed: 4 excess_len_avg: 1.337120298625484\n",
      "n: 5000, m: 3000, alpha: 0.025 seed: 4 excess_len_avg: 0.04878426795796707\n",
      "n: 5000, m: 2000, alpha: 0.01 seed: 4 excess_len_avg: 0.0935037293440175\n",
      "n: 5000, m: 3000, alpha: 0.05 seed: 4 excess_len_avg: 0.017180439502963378\n",
      "n: 5000, m: 2000, alpha: 0.025 seed: 4 excess_len_avg: 0.13746726908369636\n",
      "n: 5000, m: 2000, alpha: 0.05 seed: 4 excess_len_avg: 0.4161661387698355\n",
      "n: 5000, m: 3000, alpha: 0.075 seed: 4 excess_len_avg: 0.18032889517111647\n",
      "n: 5000, m: 3000, alpha: 0.1 seed: 4 excess_len_avg: 0.25916078440879525\n",
      "n: 5000, m: 3000, alpha: 0.125 seed: 4 excess_len_avg: 0.3399807356949709\n",
      "n: 5000, m: 3000, alpha: 0.15 seed: 4 excess_len_avg: 0.012231259756362236\n",
      "n: 5000, m: 3000, alpha: 0.175 seed: 4 excess_len_avg: 0.011082550724051078\n",
      "n: 5000, m: 3000, alpha: 0.2 seed: 4 excess_len_avg: 0.14426737851019852\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import multiprocess as mp\n",
    "from functools import partial\n",
    "\n",
    "\n",
    "def process_single_run(seed, n, m, alpha):\n",
    "    rng = np.random.default_rng(seed)\n",
    "    alpha_min = 0.005\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": null,
   "id": "c41556b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(results)\n",
    "df.to_csv(\"./cqr_vary_m_uniform_l1.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
}
