{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "be1a763e",
   "metadata": {},
   "source": [
    "# Setup"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0e8e157",
   "metadata": {},
   "source": [
    "Please ensure all the relevant modules are installed before running the below! This can be simply achieved via the command below in your virtual environment:\n",
    "```\n",
    "pip install -r requirements.txt\n",
    "```\n",
    "This can be run locally on a personal laptop."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1e343669",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d9ae6626",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.stats\n",
    "import scipy.special\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import time\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "34578160",
   "metadata": {},
   "source": [
    "# Utility Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0526b47",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Data Generation ###\n",
    "\n",
    "def expand_to_polynomial_basis(X_input, degree):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X_input.ndim != 2 or X_input.shape[1] != 1:\n",
    "        raise ValueError(\"Input X_input must be of shape (M, 1)\")\n",
    "    \n",
    "    if degree < 0:\n",
    "        raise ValueError(\"Degree must be non-negative\")\n",
    "    \n",
    "    M = X_input.shape[0]\n",
    "    X_expanded = np.zeros((M, degree + 1))\n",
    "\n",
    "    for p in range(degree + 1):\n",
    "        X_expanded[:, p] = X_input[:, 0] ** p\n",
    "\n",
    "    return X_expanded\n",
    "\n",
    "def generate_synthetic_polynomial_data(M, true_degree, true_sigma_scale, randomize_w=True):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    D_true = true_degree + 1\n",
    "\n",
    "    if randomize_w:\n",
    "        true_w_mean = np.random.randn(D_true) * 1.0\n",
    "\n",
    "    else:\n",
    "        base_w = np.array([0, -0.5, 0.3, 0.002, 1.1, 0.7, -0.2, 0.05, -0.1, 0.01])\n",
    "        true_w_mean = np.pad(base_w, (0, D_true - len(base_w))) if D_true > len(base_w) else base_w[:D_true]\n",
    "\n",
    "    true_w = true_w_mean.reshape(D_true, 1)\n",
    "\n",
    "    X_base = np.random.uniform(-2.5, 2.5, size=(M, 1))\n",
    "    X_poly_true = expand_to_polynomial_basis(X_base, true_degree)\n",
    "\n",
    "    y_mean = X_poly_true @ true_w\n",
    "    errors = np.random.normal(0, true_sigma_scale, size=(M, 1))\n",
    "\n",
    "    y = y_mean + errors\n",
    "\n",
    "    return X_base, y, true_w, X_poly_true\n",
    "\n",
    "\n",
    "### Bayesian Linear Regression Model Utility Functions (Gaussian Error) ###\n",
    "\n",
    "def potential_U_gaussian(theta_phi, w, X, y):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    phi1, phi2 = theta_phi\n",
    "    sigma_sq, alpha = np.exp(phi1), np.exp(phi2)\n",
    "    M, D = X.shape\n",
    "    w = w.reshape(D, 1)\n",
    "\n",
    "    if sigma_sq < 1e-12:\n",
    "        return 1e20\n",
    "    \n",
    "    log_L_term = (0.5 / sigma_sq) * np.sum((y - X @ w) ** 2)\n",
    "    log_P_w_term = (0.5 * alpha) * np.sum(w ** 2)\n",
    "\n",
    "    const_L = (M / 2) * (np.log(2 * np.pi) + phi1)\n",
    "    const_P_w = (D / 2) * (np.log(2 * np.pi) - phi2)\n",
    "\n",
    "    val = log_L_term + log_P_w_term + const_L + const_P_w\n",
    "\n",
    "    return val if np.isfinite(val) else 1e20\n",
    "\n",
    "def grad_U_theta_phi_gaussian(theta_phi, w, X, y):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    phi1, phi2 = theta_phi\n",
    "    sigma_sq, alpha = np.exp(phi1), np.exp(phi2)\n",
    "    M, D = X.shape\n",
    "    w = w.reshape(D, 1)\n",
    "\n",
    "    grad_phi1 = - (0.5 / sigma_sq) * np.sum((y - X @ w) ** 2) + M / 2 if sigma_sq > 1e-12 else M / 2\n",
    "    grad_phi2 = (0.5 * alpha) * np.sum(w ** 2) - D / 2\n",
    "\n",
    "    return np.nan_to_num(np.array([grad_phi1, grad_phi2]), nan=0.0, posinf=1e10, neginf=-1e10)\n",
    "\n",
    "def grad_U_w_gaussian(theta_phi, w, X, y):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    phi1, phi2 = theta_phi\n",
    "    sigma_sq, alpha = np.exp(phi1), np.exp(phi2)\n",
    "    D_feat = X.shape[1]\n",
    "    w = w.reshape(D_feat, 1)\n",
    "\n",
    "    if sigma_sq < 1e-12:\n",
    "        sigma_sq = 1e-12\n",
    "\n",
    "    grad = (1 / sigma_sq) * X.T @ (X @ w - y) + alpha * w\n",
    "\n",
    "    return np.nan_to_num(grad, nan=0.0, posinf=1e10, neginf=-1e10)\n",
    "\n",
    "def initialize_particles_gaussian(theta_phi, X, y, N_particles, D_features):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    sigma_sq, alpha = np.exp(theta_phi[0]), np.exp(theta_phi[1])\n",
    "    sigma_sq, alpha = max(sigma_sq, 1e-12), max(alpha, 1e-12)\n",
    "\n",
    "    Sigma_post_inv_0 = (1 / sigma_sq) * X.T @ X + alpha * np.eye(D_features) + 1e-9 * np.eye(D_features)\n",
    "\n",
    "    try:\n",
    "        Sigma_post_0 = np.linalg.inv(Sigma_post_inv_0)\n",
    "\n",
    "    except np.linalg.LinAlgError:\n",
    "        Sigma_post_0 = np.linalg.pinv(Sigma_post_inv_0)\n",
    "\n",
    "    mu_post_0 = Sigma_post_0 @ ((1 / sigma_sq) * X.T @ y)\n",
    "\n",
    "    return np.random.multivariate_normal(mu_post_0.flatten(), Sigma_post_0, size=N_particles)\n",
    "\n",
    "def analytical_marginal_likelihood_gaussian(theta_phi, X, y, return_log=True):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    phi1, phi2 = theta_phi\n",
    "    sigma_sq, alpha = np.exp(phi1), np.exp(phi2)\n",
    "    M, D = X.shape\n",
    "\n",
    "    if not (1e-12 < sigma_sq < 1e12 and 1e-12 < alpha < 1e12):\n",
    "        return -np.inf if return_log else 0.0\n",
    "    \n",
    "    Sigma_y = sigma_sq * np.eye(M) + (1/alpha) * (X @ X.T) + 1e-9 * np.eye(M)\n",
    "    \n",
    "    try:\n",
    "        L = np.linalg.cholesky(Sigma_y)\n",
    "        logdet_Sigma_y = 2 * np.sum(np.log(np.diag(L)))\n",
    "        alpha_vec = np.linalg.solve(L, y.flatten())\n",
    "        log_ml = -0.5 * (M * np.log(2 * np.pi) + logdet_Sigma_y + np.dot(alpha_vec, alpha_vec))\n",
    "\n",
    "    except np.linalg.LinAlgError: \n",
    "        return -np.inf if return_log else 0.0\n",
    "    \n",
    "    return log_ml if return_log and np.isfinite(log_ml) else (-np.inf if return_log else 0.0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6393a436",
   "metadata": {},
   "source": [
    "# JALA-EM\n",
    "\n",
    "Implementation of the JALA-EM algorithm, as described in \"Learning Latent Variable Models via Jarzynski-adjusted Langevin Algorithm\" (see: https://arxiv.org/pdf/2505.18427). Specifically see Appendix C.5 of the aforementioned paper."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa733715",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_jala_em(X_data, y_data, model_fns, K_iters, N_particles, h_langevin, opt_learning_rate=0.01, ess_threshold_frac=0.5, use_resampling=True):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    M, D_features = X_data.shape\n",
    "\n",
    "    theta_phi_k = np.array(model_fns['theta_phi_initial'], dtype=float)\n",
    "    particles_X_k = model_fns['initialize_particles_fn'](theta_phi_k, X_data, y_data, N_particles, D_features)\n",
    "    A_k = np.zeros(N_particles)\n",
    "    m_opt = np.zeros(model_fns['D_theta'])\n",
    "\n",
    "    beta_momentum = 0.9\n",
    "\n",
    "    log_Z_0_val = model_fns['estimate_Z0_fn'](theta_phi_k, X_data, y_data)\n",
    "\n",
    "    if np.isnan(log_Z_0_val) or np.isinf(log_Z_0_val):\n",
    "        log_Z_0_val = 0.0\n",
    "\n",
    "    potential_U_fn, grad_U_theta_phi_fn, grad_U_w_fn = model_fns['potential_U_fn'], model_fns['grad_U_theta_phi_fn'], model_fns['grad_U_w_fn']\n",
    "\n",
    "    phi_clips = model_fns.get('phi_clips', [(-20, 20)] * model_fns['D_theta'])\n",
    "\n",
    "    for k in range(K_iters):\n",
    "        W_k = np.exp(A_k - np.max(A_k))\n",
    "        W_k /= np.sum(W_k)\n",
    "\n",
    "        g_k_accum = sum(W_k[i] * grad_U_theta_phi_fn(theta_phi_k, particles_X_k[i, :].reshape(D_features, 1), X_data, y_data) for i in range(N_particles))\n",
    "\n",
    "        m_opt = beta_momentum * m_opt + (1 - beta_momentum) * g_k_accum\n",
    "\n",
    "        theta_phi_k_plus_1 = np.clip(theta_phi_k - opt_learning_rate * m_opt, [c[0] for c in phi_clips], [c[1] for c in phi_clips])\n",
    "        particles_X_k_plus_1, A_k_plus_1 = np.zeros_like(particles_X_k), np.zeros_like(A_k)\n",
    "\n",
    "        for i in range(N_particles):\n",
    "            x_curr = particles_X_k[i, :].reshape(D_features,1)\n",
    "            U_curr_val = potential_U_fn(theta_phi_k, x_curr, X_data, y_data)\n",
    "            grad_w_U_curr = grad_U_w_fn(theta_phi_k, x_curr, X_data, y_data)\n",
    "\n",
    "            xi_noise = np.random.normal(size=(D_features,1))\n",
    "            x_next = x_curr - h_langevin * grad_w_U_curr + np.sqrt(2 * h_langevin) * xi_noise\n",
    "\n",
    "            particles_X_k_plus_1[i, :] = x_next.flatten()\n",
    "            U_next_val = potential_U_fn(theta_phi_k_plus_1, x_next, X_data, y_data)\n",
    "            A_k_plus_1[i] = A_k[i] - (U_next_val - U_curr_val)\n",
    "\n",
    "        theta_phi_k, A_k, particles_X_k = np.copy(theta_phi_k_plus_1), np.copy(A_k_plus_1), np.copy(particles_X_k_plus_1)\n",
    "\n",
    "        if use_resampling and (1.0 / np.sum(np.square(W_k))) < ess_threshold_frac * N_particles:\n",
    "            indices = np.random.choice(N_particles, size=N_particles, p=W_k, replace=True)\n",
    "            particles_X_k, A_k = particles_X_k[indices, :], A_k[indices]\n",
    "            \n",
    "    final_log_Z_k_est = log_Z_0_val + (scipy.special.logsumexp(A_k) - np.log(N_particles))\n",
    "    \n",
    "\n",
    "    return theta_phi_k, final_log_Z_k_est"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e6aa0b9d",
   "metadata": {},
   "source": [
    "# Experiment Pipeline\n",
    "\n",
    "Logic to run the core experimental trial for a number of different seeds."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67d7ef86",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_bic_for_models(X_base, y, max_degree_to_test):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    M = len(y)\n",
    "    bic_scores = []\n",
    "\n",
    "    for p_order in range(1, max_degree_to_test + 1):\n",
    "        X_poly = expand_to_polynomial_basis(X_base, p_order)\n",
    "        D_model = X_poly.shape[1]\n",
    "\n",
    "        w_mle, residuals, _, _ = np.linalg.lstsq(X_poly, y, rcond=None)\n",
    "        sigma_sq_mle = max(residuals[0] / M if residuals.size > 0 else 1e-12, 1e-12)\n",
    "\n",
    "        log_likelihood = -M/2 * np.log(2 * np.pi * sigma_sq_mle) - (1 / (2 * sigma_sq_mle)) * np.sum((y - X_poly @ w_mle) ** 2)\n",
    "\n",
    "        bic = (D_model + 1) * np.log(M) - 2 * log_likelihood\n",
    "        bic_scores.append(bic)\n",
    "\n",
    "    return np.argmin(bic_scores) + 1, bic_scores\n",
    "\n",
    "\n",
    "def run_full_experiment(config):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    results = []\n",
    "    total_runs = len(config['TRUE_DEGREE_RANGE']) * len(config['NOISE_LEVELS']) * config['N_SEEDS']\n",
    "\n",
    "    pbar = tqdm(total=total_runs, desc=\"Running Experiments\")\n",
    "\n",
    "    for true_degree in config['TRUE_DEGREE_RANGE']:\n",
    "        for noise in config['NOISE_LEVELS']:\n",
    "            for seed in range(config['N_SEEDS']):\n",
    "                np.random.seed(seed)\n",
    "                X_base, y, _, _ = generate_synthetic_polynomial_data(\n",
    "                    M=config['M_DATA'], \n",
    "                    true_degree=true_degree, \n",
    "                    true_sigma_scale=noise,\n",
    "                )\n",
    "                jala_log_mls = []\n",
    "                for p_order in config['ORDERS_TO_TEST']:\n",
    "                    X_poly = expand_to_polynomial_basis(X_base, p_order)\n",
    "                    model_fns = {\n",
    "                        'potential_U_fn': potential_U_gaussian, \n",
    "                        'grad_U_theta_phi_fn': grad_U_theta_phi_gaussian,\n",
    "                        'grad_U_w_fn': grad_U_w_gaussian, \n",
    "                        'initialize_particles_fn': initialize_particles_gaussian,\n",
    "                        'estimate_Z0_fn': analytical_marginal_likelihood_gaussian,\n",
    "                        'theta_phi_initial': np.array([np.log(1.0), np.log(1.0)]),\n",
    "                        'D_theta': 2, \n",
    "                        'model_name': f'PolyOrder_{p_order}', \n",
    "                        'phi_clips': [(-15, 15), (-15, 15)]\n",
    "                    }\n",
    "                    _, final_log_z = run_jala_em(\n",
    "                        X_data=X_poly, \n",
    "                        y_data=y, \n",
    "                        model_fns=model_fns, \n",
    "                        K_iters=config['K_ITERS'],\n",
    "                        N_particles=config['N_PARTICLES'], \n",
    "                        h_langevin=config['H_LANGEVIN'], \n",
    "                        opt_learning_rate=config['OPT_LR'], \n",
    "                        use_resampling=False,\n",
    "                    )\n",
    "                    jala_log_mls.append(final_log_z)\n",
    "\n",
    "                best_order_jala = config['ORDERS_TO_TEST'][np.argmax(jala_log_mls)]\n",
    "                best_order_bic, _ = calculate_bic_for_models(X_base, y, config['MAX_DEGREE_TO_TEST'])\n",
    "                \n",
    "                results.append({\n",
    "                    'true_degree': true_degree, \n",
    "                    'noise_level': noise, \n",
    "                    'seed': seed,\n",
    "                    'jala_selected_order': best_order_jala, \n",
    "                    'bic_selected_order': best_order_bic,\n",
    "                    'jala_abs_error': abs(best_order_jala - true_degree),\n",
    "                    'bic_abs_error': abs(best_order_bic - true_degree)\n",
    "                })\n",
    "                pbar.update(1)\n",
    "    \n",
    "    pbar.close()\n",
    "    \n",
    "    return pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3729ce2e",
   "metadata": {},
   "source": [
    "## Experiment: $d_{y} = 500$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "75b445d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Running Experiments: 100%|██████████| 700/700 [1:15:27<00:00,  6.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Experiment finished in 4527.40 seconds!\n",
      "\n",
      "Results saved @ model_order_selection_results_dy=500.csv\n",
      "\n",
      "Performance SUMMARY:\n",
      "Overall JALA-EM Accuracy: 82.00%\n",
      "Overall BIC Accuracy:     78.43%\n",
      "----------------------------------------\n",
      "Overall JALA-EM Mean Absolute Error: 0.224\n",
      "Overall BIC Mean Absolute Error:     0.274\n",
      "----------------------------------------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "experiment_config = {\n",
    "    \"N_SEEDS\": 100, \n",
    "    \"TRUE_DEGREE_RANGE\": [2, 3, 4, 5, 6, 7, 8],\n",
    "    \"NOISE_LEVELS\": [7.5], \n",
    "    \"MAX_DEGREE_TO_TEST\": 10,\n",
    "    \"M_DATA\": 500, \n",
    "    \"K_ITERS\": 200, \n",
    "    \"N_PARTICLES\": 50,\n",
    "    \"H_LANGEVIN\": 1e-6, \n",
    "    \"OPT_LR\": 0.005,\n",
    "}\n",
    "experiment_config[\"ORDERS_TO_TEST\"] = list(range(1, experiment_config[\"MAX_DEGREE_TO_TEST\"] + 1))\n",
    "\n",
    "print(\"Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\")\n",
    "start_time = time.time()\n",
    "results_df = run_full_experiment(experiment_config)\n",
    "print(f\"\\nExperiment finished in {time.time() - start_time:.2f} seconds!\")\n",
    "\n",
    "results_df.to_csv(f\"model_order_selection_results_dy={experiment_config['M_DATA']}.csv\", index=False)\n",
    "print(f\"\\nResults saved @ model_order_selection_results_dy={experiment_config['M_DATA']}.csv\")\n",
    "\n",
    "\n",
    "print(\"\\nPerformance SUMMARY:\")\n",
    "jala_total_accuracy = np.mean(results_df['jala_selected_order'] == results_df['true_degree'])\n",
    "bic_total_accuracy = np.mean(results_df['bic_selected_order'] == results_df['true_degree'])\n",
    "jala_mae = results_df['jala_abs_error'].mean()\n",
    "bic_mae = results_df['bic_abs_error'].mean()\n",
    "print(f\"Overall JALA-EM Accuracy: {jala_total_accuracy:.2%}\")\n",
    "print(f\"Overall BIC Accuracy:     {bic_total_accuracy:.2%}\")\n",
    "print(\"-\" * 40)\n",
    "print(f\"Overall JALA-EM Mean Absolute Error: {jala_mae:.3f}\")\n",
    "print(f\"Overall BIC Mean Absolute Error:     {bic_mae:.3f}\")\n",
    "print(\"-\" * 40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ac560601",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 7.5\n",
      "0.35\n",
      "0.35\n",
      "#####\n",
      "\n",
      "3 7.5\n",
      "0.25\n",
      "0.34\n",
      "#####\n",
      "\n",
      "4 7.5\n",
      "0.3\n",
      "0.3\n",
      "#####\n",
      "\n",
      "5 7.5\n",
      "0.27\n",
      "0.35\n",
      "#####\n",
      "\n",
      "6 7.5\n",
      "0.18\n",
      "0.23\n",
      "#####\n",
      "\n",
      "7 7.5\n",
      "0.09\n",
      "0.15\n",
      "#####\n",
      "\n",
      "8 7.5\n",
      "0.13\n",
      "0.2\n",
      "#####\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>true_degree</th>\n",
       "      <th>noise_level</th>\n",
       "      <th>seed</th>\n",
       "      <th>jala_selected_order</th>\n",
       "      <th>bic_selected_order</th>\n",
       "      <th>jala_abs_error</th>\n",
       "      <th>bic_abs_error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>11</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>12</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>13</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>16</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>17</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>18</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>19</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>20</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>21</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>22</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>23</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>24</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>25</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>26</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>27</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>28</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>29</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>30</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>31</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>32</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>33</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>34</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>35</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>36</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>37</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>38</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>39</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>40</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>41</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>42</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>43</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>44</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>45</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>46</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>47</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>48</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>49</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>50</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>51</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>52</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>53</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>54</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>55</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>56</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>57</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>58</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>59</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    true_degree  noise_level  seed  jala_selected_order  bic_selected_order  \\\n",
       "0             2          7.5     0                    2                   2   \n",
       "1             2          7.5     1                    2                   2   \n",
       "2             2          7.5     2                    2                   2   \n",
       "3             2          7.5     3                    1                   1   \n",
       "4             2          7.5     4                    2                   2   \n",
       "5             2          7.5     5                    2                   2   \n",
       "6             2          7.5     6                    1                   1   \n",
       "7             2          7.5     7                    1                   1   \n",
       "8             2          7.5     8                    2                   2   \n",
       "9             2          7.5     9                    2                   2   \n",
       "10            2          7.5    10                    3                   3   \n",
       "11            2          7.5    11                    2                   2   \n",
       "12            2          7.5    12                    2                   2   \n",
       "13            2          7.5    13                    1                   1   \n",
       "14            2          7.5    14                    1                   1   \n",
       "15            2          7.5    15                    1                   1   \n",
       "16            2          7.5    16                    1                   1   \n",
       "17            2          7.5    17                    2                   2   \n",
       "18            2          7.5    18                    1                   1   \n",
       "19            2          7.5    19                    2                   2   \n",
       "20            2          7.5    20                    2                   2   \n",
       "21            2          7.5    21                    2                   2   \n",
       "22            2          7.5    22                    2                   2   \n",
       "23            2          7.5    23                    2                   2   \n",
       "24            2          7.5    24                    1                   1   \n",
       "25            2          7.5    25                    2                   2   \n",
       "26            2          7.5    26                    2                   2   \n",
       "27            2          7.5    27                    2                   2   \n",
       "28            2          7.5    28                    2                   2   \n",
       "29            2          7.5    29                    2                   2   \n",
       "30            2          7.5    30                    2                   2   \n",
       "31            2          7.5    31                    1                   1   \n",
       "32            2          7.5    32                    2                   2   \n",
       "33            2          7.5    33                    2                   2   \n",
       "34            2          7.5    34                    2                   2   \n",
       "35            2          7.5    35                    2                   2   \n",
       "36            2          7.5    36                    1                   1   \n",
       "37            2          7.5    37                    2                   2   \n",
       "38            2          7.5    38                    1                   1   \n",
       "39            2          7.5    39                    2                   2   \n",
       "40            2          7.5    40                    2                   2   \n",
       "41            2          7.5    41                    1                   1   \n",
       "42            2          7.5    42                    2                   2   \n",
       "43            2          7.5    43                    1                   1   \n",
       "44            2          7.5    44                    2                   2   \n",
       "45            2          7.5    45                    3                   1   \n",
       "46            2          7.5    46                    2                   2   \n",
       "47            2          7.5    47                    2                   2   \n",
       "48            2          7.5    48                    2                   2   \n",
       "49            2          7.5    49                    2                   2   \n",
       "50            2          7.5    50                    3                   1   \n",
       "51            2          7.5    51                    2                   2   \n",
       "52            2          7.5    52                    3                   1   \n",
       "53            2          7.5    53                    2                   2   \n",
       "54            2          7.5    54                    1                   1   \n",
       "55            2          7.5    55                    2                   2   \n",
       "56            2          7.5    56                    2                   2   \n",
       "57            2          7.5    57                    2                   2   \n",
       "58            2          7.5    58                    2                   2   \n",
       "59            2          7.5    59                    1                   1   \n",
       "\n",
       "    jala_abs_error  bic_abs_error  \n",
       "0                0              0  \n",
       "1                0              0  \n",
       "2                0              0  \n",
       "3                1              1  \n",
       "4                0              0  \n",
       "5                0              0  \n",
       "6                1              1  \n",
       "7                1              1  \n",
       "8                0              0  \n",
       "9                0              0  \n",
       "10               1              1  \n",
       "11               0              0  \n",
       "12               0              0  \n",
       "13               1              1  \n",
       "14               1              1  \n",
       "15               1              1  \n",
       "16               1              1  \n",
       "17               0              0  \n",
       "18               1              1  \n",
       "19               0              0  \n",
       "20               0              0  \n",
       "21               0              0  \n",
       "22               0              0  \n",
       "23               0              0  \n",
       "24               1              1  \n",
       "25               0              0  \n",
       "26               0              0  \n",
       "27               0              0  \n",
       "28               0              0  \n",
       "29               0              0  \n",
       "30               0              0  \n",
       "31               1              1  \n",
       "32               0              0  \n",
       "33               0              0  \n",
       "34               0              0  \n",
       "35               0              0  \n",
       "36               1              1  \n",
       "37               0              0  \n",
       "38               1              1  \n",
       "39               0              0  \n",
       "40               0              0  \n",
       "41               1              1  \n",
       "42               0              0  \n",
       "43               1              1  \n",
       "44               0              0  \n",
       "45               1              1  \n",
       "46               0              0  \n",
       "47               0              0  \n",
       "48               0              0  \n",
       "49               0              0  \n",
       "50               1              1  \n",
       "51               0              0  \n",
       "52               1              1  \n",
       "53               0              0  \n",
       "54               1              1  \n",
       "55               0              0  \n",
       "56               0              0  \n",
       "57               0              0  \n",
       "58               0              0  \n",
       "59               1              1  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for order in experiment_config['TRUE_DEGREE_RANGE']:\n",
    "    for noise_std in experiment_config['NOISE_LEVELS']:\n",
    "        print(order, noise_std)\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['jala_abs_error']))\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['bic_abs_error']))\n",
    "        print('#####\\n')\n",
    "\n",
    "display(results_df.head(60))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2050ea82",
   "metadata": {},
   "source": [
    "## Experiment: $d_{y} = 100$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "24814b43",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Running Experiments: 100%|██████████| 700/700 [52:52<00:00,  4.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Experiment finished in 3172.19 seconds!\n",
      "\n",
      "Results saved @ model_order_selection_results_dy=100.csv\n",
      "\n",
      "Performance SUMMARY:\n",
      "Overall JALA-EM Accuracy: 65.29%\n",
      "Overall BIC Accuracy:     58.29%\n",
      "----------------------------------------\n",
      "Overall JALA-EM Mean Absolute Error: 0.500\n",
      "Overall BIC Mean Absolute Error:     0.611\n",
      "----------------------------------------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "experiment_config = {\n",
    "    \"N_SEEDS\": 100, \n",
    "    \"TRUE_DEGREE_RANGE\": [2, 3, 4, 5, 6, 7, 8],\n",
    "    \"NOISE_LEVELS\": [7.5], \n",
    "    \"MAX_DEGREE_TO_TEST\": 10,\n",
    "    \"M_DATA\": 100, \n",
    "    \"K_ITERS\": 200, \n",
    "    \"N_PARTICLES\": 50,\n",
    "    \"H_LANGEVIN\": 1e-6, \n",
    "    \"OPT_LR\": 0.005,\n",
    "}\n",
    "experiment_config[\"ORDERS_TO_TEST\"] = list(range(1, experiment_config[\"MAX_DEGREE_TO_TEST\"] + 1))\n",
    "\n",
    "print(\"Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\")\n",
    "start_time = time.time()\n",
    "results_df = run_full_experiment(experiment_config)\n",
    "print(f\"\\nExperiment finished in {time.time() - start_time:.2f} seconds!\")\n",
    "\n",
    "results_df.to_csv(f\"model_order_selection_results_dy={experiment_config['M_DATA']}.csv\", index=False)\n",
    "print(f\"\\nResults saved @ model_order_selection_results_dy={experiment_config['M_DATA']}.csv\")\n",
    "\n",
    "\n",
    "print(\"\\nPerformance SUMMARY:\")\n",
    "jala_total_accuracy = np.mean(results_df['jala_selected_order'] == results_df['true_degree'])\n",
    "bic_total_accuracy = np.mean(results_df['bic_selected_order'] == results_df['true_degree'])\n",
    "jala_mae = results_df['jala_abs_error'].mean()\n",
    "bic_mae = results_df['bic_abs_error'].mean()\n",
    "print(f\"Overall JALA-EM Accuracy: {jala_total_accuracy:.2%}\")\n",
    "print(f\"Overall BIC Accuracy:     {bic_total_accuracy:.2%}\")\n",
    "print(\"-\" * 40)\n",
    "print(f\"Overall JALA-EM Mean Absolute Error: {jala_mae:.3f}\")\n",
    "print(f\"Overall BIC Mean Absolute Error:     {bic_mae:.3f}\")\n",
    "print(\"-\" * 40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5c0dd8e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 7.5\n",
      "0.67\n",
      "0.64\n",
      "#####\n",
      "\n",
      "3 7.5\n",
      "0.73\n",
      "0.9\n",
      "#####\n",
      "\n",
      "4 7.5\n",
      "0.73\n",
      "0.8\n",
      "#####\n",
      "\n",
      "5 7.5\n",
      "0.51\n",
      "0.64\n",
      "#####\n",
      "\n",
      "6 7.5\n",
      "0.35\n",
      "0.49\n",
      "#####\n",
      "\n",
      "7 7.5\n",
      "0.23\n",
      "0.44\n",
      "#####\n",
      "\n",
      "8 7.5\n",
      "0.28\n",
      "0.37\n",
      "#####\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>true_degree</th>\n",
       "      <th>noise_level</th>\n",
       "      <th>seed</th>\n",
       "      <th>jala_selected_order</th>\n",
       "      <th>bic_selected_order</th>\n",
       "      <th>jala_abs_error</th>\n",
       "      <th>bic_abs_error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>11</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>13</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>15</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>16</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>17</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>18</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>19</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>20</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>21</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>22</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>23</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>24</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>25</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>26</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>27</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>28</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>29</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>30</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>31</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>32</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>33</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>34</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>35</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>36</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>37</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>38</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>39</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>40</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>41</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>42</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>43</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>44</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>45</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>46</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>47</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>48</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>49</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>51</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>52</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>53</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>54</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>55</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>56</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>57</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>58</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>59</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    true_degree  noise_level  seed  jala_selected_order  bic_selected_order  \\\n",
       "0             2          7.5     0                    1                   2   \n",
       "1             2          7.5     1                    1                   2   \n",
       "2             2          7.5     2                    2                   2   \n",
       "3             2          7.5     3                    1                   1   \n",
       "4             2          7.5     4                    2                   1   \n",
       "5             2          7.5     5                    2                   2   \n",
       "6             2          7.5     6                    1                   1   \n",
       "7             2          7.5     7                    1                   1   \n",
       "8             2          7.5     8                    3                   2   \n",
       "9             2          7.5     9                    2                   2   \n",
       "10            2          7.5    10                    2                   5   \n",
       "11            2          7.5    11                    1                   1   \n",
       "12            2          7.5    12                    1                   1   \n",
       "13            2          7.5    13                    1                   1   \n",
       "14            2          7.5    14                    1                   1   \n",
       "15            2          7.5    15                    2                   1   \n",
       "16            2          7.5    16                    1                   1   \n",
       "17            2          7.5    17                    1                   1   \n",
       "18            2          7.5    18                    1                   1   \n",
       "19            2          7.5    19                    1                   1   \n",
       "20            2          7.5    20                    1                   1   \n",
       "21            2          7.5    21                    2                   2   \n",
       "22            2          7.5    22                    1                   1   \n",
       "23            2          7.5    23                    1                   1   \n",
       "24            2          7.5    24                    1                   2   \n",
       "25            2          7.5    25                    1                   1   \n",
       "26            2          7.5    26                    2                   2   \n",
       "27            2          7.5    27                    2                   2   \n",
       "28            2          7.5    28                    1                   1   \n",
       "29            2          7.5    29                    2                   2   \n",
       "30            2          7.5    30                    1                   1   \n",
       "31            2          7.5    31                    1                   1   \n",
       "32            2          7.5    32                    2                   2   \n",
       "33            2          7.5    33                    2                   2   \n",
       "34            2          7.5    34                    2                   2   \n",
       "35            2          7.5    35                    1                   1   \n",
       "36            2          7.5    36                    1                   1   \n",
       "37            2          7.5    37                    1                   1   \n",
       "38            2          7.5    38                    1                   1   \n",
       "39            2          7.5    39                    1                   1   \n",
       "40            2          7.5    40                    2                   3   \n",
       "41            2          7.5    41                    1                   1   \n",
       "42            2          7.5    42                    1                   1   \n",
       "43            2          7.5    43                    1                   3   \n",
       "44            2          7.5    44                    2                   2   \n",
       "45            2          7.5    45                    1                   1   \n",
       "46            2          7.5    46                    1                   1   \n",
       "47            2          7.5    47                    2                   2   \n",
       "48            2          7.5    48                    1                   1   \n",
       "49            2          7.5    49                    1                   1   \n",
       "50            2          7.5    50                    1                   1   \n",
       "51            2          7.5    51                    2                   2   \n",
       "52            2          7.5    52                    1                   1   \n",
       "53            2          7.5    53                    2                   2   \n",
       "54            2          7.5    54                    1                   1   \n",
       "55            2          7.5    55                    2                   2   \n",
       "56            2          7.5    56                    2                   1   \n",
       "57            2          7.5    57                    2                   2   \n",
       "58            2          7.5    58                    1                   1   \n",
       "59            2          7.5    59                    1                   1   \n",
       "\n",
       "    jala_abs_error  bic_abs_error  \n",
       "0                1              0  \n",
       "1                1              0  \n",
       "2                0              0  \n",
       "3                1              1  \n",
       "4                0              1  \n",
       "5                0              0  \n",
       "6                1              1  \n",
       "7                1              1  \n",
       "8                1              0  \n",
       "9                0              0  \n",
       "10               0              3  \n",
       "11               1              1  \n",
       "12               1              1  \n",
       "13               1              1  \n",
       "14               1              1  \n",
       "15               0              1  \n",
       "16               1              1  \n",
       "17               1              1  \n",
       "18               1              1  \n",
       "19               1              1  \n",
       "20               1              1  \n",
       "21               0              0  \n",
       "22               1              1  \n",
       "23               1              1  \n",
       "24               1              0  \n",
       "25               1              1  \n",
       "26               0              0  \n",
       "27               0              0  \n",
       "28               1              1  \n",
       "29               0              0  \n",
       "30               1              1  \n",
       "31               1              1  \n",
       "32               0              0  \n",
       "33               0              0  \n",
       "34               0              0  \n",
       "35               1              1  \n",
       "36               1              1  \n",
       "37               1              1  \n",
       "38               1              1  \n",
       "39               1              1  \n",
       "40               0              1  \n",
       "41               1              1  \n",
       "42               1              1  \n",
       "43               1              1  \n",
       "44               0              0  \n",
       "45               1              1  \n",
       "46               1              1  \n",
       "47               0              0  \n",
       "48               1              1  \n",
       "49               1              1  \n",
       "50               1              1  \n",
       "51               0              0  \n",
       "52               1              1  \n",
       "53               0              0  \n",
       "54               1              1  \n",
       "55               0              0  \n",
       "56               0              1  \n",
       "57               0              0  \n",
       "58               1              1  \n",
       "59               1              1  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for order in experiment_config['TRUE_DEGREE_RANGE']:\n",
    "    for noise_std in experiment_config['NOISE_LEVELS']:\n",
    "        print(order, noise_std)\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['jala_abs_error']))\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['bic_abs_error']))\n",
    "        print('#####\\n')\n",
    "\n",
    "display(results_df.head(60))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "95bf91cc",
   "metadata": {},
   "source": [
    "## Experiment: $d_{y} = 250$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0d55d48b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Running Experiments: 100%|██████████| 700/700 [4:56:39<00:00, 25.43s/it]      "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Experiment finished in 17799.28 seconds!\n",
      "\n",
      "Results saved @ model_order_selection_results_dy=250.csv\n",
      "\n",
      "Performance SUMMARY:\n",
      "Overall JALA-EM Accuracy: 74.86%\n",
      "Overall BIC Accuracy:     70.86%\n",
      "----------------------------------------\n",
      "Overall JALA-EM Mean Absolute Error: 0.343\n",
      "Overall BIC Mean Absolute Error:     0.400\n",
      "----------------------------------------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "experiment_config = {\n",
    "    \"N_SEEDS\": 100,\n",
    "    \"TRUE_DEGREE_RANGE\": [2, 3, 4, 5, 6, 7, 8],\n",
    "    \"NOISE_LEVELS\": [7.5],\n",
    "    \"MAX_DEGREE_TO_TEST\": 10,\n",
    "    \"M_DATA\": 250,\n",
    "    \"K_ITERS\": 200,\n",
    "    \"N_PARTICLES\": 50,\n",
    "    \"H_LANGEVIN\": 1e-6,\n",
    "    \"OPT_LR\": 0.005,\n",
    "}\n",
    "experiment_config[\"ORDERS_TO_TEST\"] = list(range(1, experiment_config[\"MAX_DEGREE_TO_TEST\"] + 1))\n",
    "\n",
    "print(\"Starting evaluation of JALA-EM vs. OLS & BIC Baseline...\")\n",
    "start_time = time.time()\n",
    "results_df = run_full_experiment(experiment_config)\n",
    "print(f\"\\nExperiment finished in {time.time() - start_time:.2f} seconds!\")\n",
    "\n",
    "results_df.to_csv(f\"model_order_selection_results_dy={experiment_config['M_DATA']}.csv\", index=False)\n",
    "print(f\"\\nResults saved @ model_order_selection_results_dy={experiment_config['M_DATA']}.csv\")\n",
    "\n",
    "\n",
    "print(\"\\nPerformance SUMMARY:\")\n",
    "jala_total_accuracy = np.mean(results_df['jala_selected_order'] == results_df['true_degree'])\n",
    "bic_total_accuracy = np.mean(results_df['bic_selected_order'] == results_df['true_degree'])\n",
    "jala_mae = results_df['jala_abs_error'].mean()\n",
    "bic_mae = results_df['bic_abs_error'].mean()\n",
    "print(f\"Overall JALA-EM Accuracy: {jala_total_accuracy:.2%}\")\n",
    "print(f\"Overall BIC Accuracy:     {bic_total_accuracy:.2%}\")\n",
    "print(\"-\" * 40)\n",
    "print(f\"Overall JALA-EM Mean Absolute Error: {jala_mae:.3f}\")\n",
    "print(f\"Overall BIC Mean Absolute Error:     {bic_mae:.3f}\")\n",
    "print(\"-\" * 40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1e1904cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 7.5\n",
      "0.45\n",
      "0.46\n",
      "#####\n",
      "\n",
      "3 7.5\n",
      "0.41\n",
      "0.42\n",
      "#####\n",
      "\n",
      "4 7.5\n",
      "0.49\n",
      "0.6\n",
      "#####\n",
      "\n",
      "5 7.5\n",
      "0.4\n",
      "0.42\n",
      "#####\n",
      "\n",
      "6 7.5\n",
      "0.31\n",
      "0.32\n",
      "#####\n",
      "\n",
      "7 7.5\n",
      "0.15\n",
      "0.28\n",
      "#####\n",
      "\n",
      "8 7.5\n",
      "0.19\n",
      "0.3\n",
      "#####\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>true_degree</th>\n",
       "      <th>noise_level</th>\n",
       "      <th>seed</th>\n",
       "      <th>jala_selected_order</th>\n",
       "      <th>bic_selected_order</th>\n",
       "      <th>jala_abs_error</th>\n",
       "      <th>bic_abs_error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>11</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>13</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>14</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>16</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>17</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>18</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>19</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>20</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>21</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>22</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>23</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>24</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>25</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>26</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>27</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>28</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>29</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>30</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>31</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>32</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>33</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>34</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>35</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>36</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>37</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>38</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>39</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>40</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>41</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>42</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>43</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>44</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>45</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>46</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>47</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>48</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>49</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>50</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>51</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>52</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>53</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>54</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>55</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>56</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>57</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>58</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>2</td>\n",
       "      <td>7.5</td>\n",
       "      <td>59</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    true_degree  noise_level  seed  jala_selected_order  bic_selected_order  \\\n",
       "0             2          7.5     0                    2                   2   \n",
       "1             2          7.5     1                    1                   1   \n",
       "2             2          7.5     2                    2                   2   \n",
       "3             2          7.5     3                    1                   1   \n",
       "4             2          7.5     4                    2                   2   \n",
       "5             2          7.5     5                    2                   2   \n",
       "6             2          7.5     6                    1                   1   \n",
       "7             2          7.5     7                    1                   1   \n",
       "8             2          7.5     8                    2                   2   \n",
       "9             2          7.5     9                    2                   2   \n",
       "10            2          7.5    10                    2                   2   \n",
       "11            2          7.5    11                    1                   1   \n",
       "12            2          7.5    12                    1                   1   \n",
       "13            2          7.5    13                    1                   1   \n",
       "14            2          7.5    14                    2                   1   \n",
       "15            2          7.5    15                    1                   1   \n",
       "16            2          7.5    16                    3                   2   \n",
       "17            2          7.5    17                    2                   1   \n",
       "18            2          7.5    18                    1                   1   \n",
       "19            2          7.5    19                    2                   2   \n",
       "20            2          7.5    20                    2                   2   \n",
       "21            2          7.5    21                    2                   2   \n",
       "22            2          7.5    22                    2                   2   \n",
       "23            2          7.5    23                    4                   2   \n",
       "24            2          7.5    24                    1                   1   \n",
       "25            2          7.5    25                    1                   1   \n",
       "26            2          7.5    26                    2                   2   \n",
       "27            2          7.5    27                    2                   1   \n",
       "28            2          7.5    28                    1                   1   \n",
       "29            2          7.5    29                    2                   2   \n",
       "30            2          7.5    30                    2                   2   \n",
       "31            2          7.5    31                    1                   1   \n",
       "32            2          7.5    32                    1                   1   \n",
       "33            2          7.5    33                    2                   2   \n",
       "34            2          7.5    34                    2                   2   \n",
       "35            2          7.5    35                    2                   2   \n",
       "36            2          7.5    36                    1                   1   \n",
       "37            2          7.5    37                    1                   1   \n",
       "38            2          7.5    38                    1                   1   \n",
       "39            2          7.5    39                    1                   1   \n",
       "40            2          7.5    40                    2                   2   \n",
       "41            2          7.5    41                    1                   1   \n",
       "42            2          7.5    42                    2                   1   \n",
       "43            2          7.5    43                    1                   1   \n",
       "44            2          7.5    44                    2                   2   \n",
       "45            2          7.5    45                    2                   1   \n",
       "46            2          7.5    46                    2                   2   \n",
       "47            2          7.5    47                    2                   2   \n",
       "48            2          7.5    48                    1                   1   \n",
       "49            2          7.5    49                    2                   2   \n",
       "50            2          7.5    50                    2                   2   \n",
       "51            2          7.5    51                    2                   2   \n",
       "52            2          7.5    52                    1                   1   \n",
       "53            2          7.5    53                    2                   2   \n",
       "54            2          7.5    54                    1                   1   \n",
       "55            2          7.5    55                    2                   2   \n",
       "56            2          7.5    56                    2                   2   \n",
       "57            2          7.5    57                    2                   2   \n",
       "58            2          7.5    58                    2                   2   \n",
       "59            2          7.5    59                    1                   1   \n",
       "\n",
       "    jala_abs_error  bic_abs_error  \n",
       "0                0              0  \n",
       "1                1              1  \n",
       "2                0              0  \n",
       "3                1              1  \n",
       "4                0              0  \n",
       "5                0              0  \n",
       "6                1              1  \n",
       "7                1              1  \n",
       "8                0              0  \n",
       "9                0              0  \n",
       "10               0              0  \n",
       "11               1              1  \n",
       "12               1              1  \n",
       "13               1              1  \n",
       "14               0              1  \n",
       "15               1              1  \n",
       "16               1              0  \n",
       "17               0              1  \n",
       "18               1              1  \n",
       "19               0              0  \n",
       "20               0              0  \n",
       "21               0              0  \n",
       "22               0              0  \n",
       "23               2              0  \n",
       "24               1              1  \n",
       "25               1              1  \n",
       "26               0              0  \n",
       "27               0              1  \n",
       "28               1              1  \n",
       "29               0              0  \n",
       "30               0              0  \n",
       "31               1              1  \n",
       "32               1              1  \n",
       "33               0              0  \n",
       "34               0              0  \n",
       "35               0              0  \n",
       "36               1              1  \n",
       "37               1              1  \n",
       "38               1              1  \n",
       "39               1              1  \n",
       "40               0              0  \n",
       "41               1              1  \n",
       "42               0              1  \n",
       "43               1              1  \n",
       "44               0              0  \n",
       "45               0              1  \n",
       "46               0              0  \n",
       "47               0              0  \n",
       "48               1              1  \n",
       "49               0              0  \n",
       "50               0              0  \n",
       "51               0              0  \n",
       "52               1              1  \n",
       "53               0              0  \n",
       "54               1              1  \n",
       "55               0              0  \n",
       "56               0              0  \n",
       "57               0              0  \n",
       "58               0              0  \n",
       "59               1              1  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for order in experiment_config['TRUE_DEGREE_RANGE']:\n",
    "    for noise_std in experiment_config['NOISE_LEVELS']:\n",
    "        print(order, noise_std)\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['jala_abs_error']))\n",
    "        print(np.mean(results_df.loc[(results_df['true_degree'] == order) & (results_df['noise_level'] == noise_std)]['bic_abs_error']))\n",
    "        print('#####\\n')\n",
    "\n",
    "display(results_df.head(60))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
