{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b77e9cb5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==========================================\n",
    "# Imports\n",
    "# ==========================================\n",
    "\n",
    "from typing import List, Sequence\n",
    "import numpy as np\n",
    "import xgboost as xgb\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_squared_error, r2_score\n",
    "from treehfd import XGBTreeHFD\n",
    "from anova_module import batch_shapley_values, ModelAnalysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c3353a5f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==========================================\n",
    "# Main Comparison\n",
    "# ==========================================\n",
    "\n",
    "# ==========================================\n",
    "# 1. Utility & Generation Functions\n",
    "# ==========================================\n",
    "\n",
    "def generate_hypergrid(N):\n",
    "    d = len(N)\n",
    "    grid = np.indices(N)\n",
    "    return grid.reshape(d, -1).T\n",
    "\n",
    "def generate_random_proba(N):\n",
    "    dim = np.prod(N)\n",
    "    Z = np.random.normal(0 , 1 , dim)**2\n",
    "    P = Z / np.sum(Z)\n",
    "    return P\n",
    "\n",
    "def generate_random_dataset(N, P, n):\n",
    "    d = len(N)\n",
    "    total_combinations = np.prod(N)\n",
    "    grid = generate_hypergrid(N)\n",
    "    chosen_indices = np.random.choice(total_combinations, size=n, p=P)\n",
    "    dataset = grid[chosen_indices]\n",
    "    return dataset \n",
    "\n",
    "def f_target(X):\n",
    "    d = X.shape[1]\n",
    "    # Set seed for target function reproducibility\n",
    "    np.random.seed(42) \n",
    "    W = np.random.normal(0, 1, d)\n",
    "    \n",
    "    W1 = W[:d//2]\n",
    "    W2 = W[d//2:]\n",
    "    X1 = X[:, :d//2]\n",
    "    X2 = X[:, d//2:]\n",
    "    \n",
    "    res = np.sum((X1 * W1) * (X2 * W2), axis=1)\n",
    "    # Reset seed for the rest\n",
    "    np.random.seed(None) \n",
    "    return res\n",
    "\n",
    "def build_L(S: Sequence[Sequence[int]]) -> List[List[int]]:\n",
    "    \"\"\"Builds the hierarchy of pair sets included in main effects.\"\"\"\n",
    "    singleton_positions: List[int] = []\n",
    "    singleton_value_to_L_index = {}\n",
    "\n",
    "    for idx, subset in enumerate(S):\n",
    "        if len(subset) == 1:\n",
    "            val = next(iter(subset)) if not isinstance(subset, list) else subset[0]\n",
    "            singleton_value_to_L_index[val] = len(singleton_positions)\n",
    "            singleton_positions.append(idx)\n",
    "\n",
    "    m = len(singleton_positions)\n",
    "    L: List[List[int]] = [[] for _ in range(m)]\n",
    "\n",
    "    for idx, subset in enumerate(S):\n",
    "        if len(subset) == 2:\n",
    "            if isinstance(subset, list):\n",
    "                a, b = subset\n",
    "            else:\n",
    "                a, b = sorted(subset)\n",
    "            \n",
    "            if a in singleton_value_to_L_index:\n",
    "                L[singleton_value_to_L_index[a]].append(idx)\n",
    "            if b in singleton_value_to_L_index:\n",
    "                L[singleton_value_to_L_index[b]].append(idx)\n",
    "    return L\n",
    "\n",
    "def train_xgb_model(X, y):\n",
    "    X_train, X_test, y_train, y_test = train_test_split(\n",
    "        X, y, test_size=0.2, random_state=42\n",
    "    )\n",
    "    y_train = y_train.astype(float)\n",
    "    \n",
    "    model = xgb.XGBRegressor(\n",
    "        n_estimators=100,\n",
    "        learning_rate=0.1,\n",
    "        max_depth=2,\n",
    "        objective=\"reg:squarederror\",\n",
    "        random_state=42,\n",
    "        n_jobs=-1\n",
    "    )\n",
    "    model.fit(X_train, y_train)\n",
    "    \n",
    "    # Calculate global R2 of the model (Pure ML performance)\n",
    "    y_pred = model.predict(X_test)\n",
    "    global_r2 = r2_score(y_test, y_pred)\n",
    "    \n",
    "    return model, global_r2\n",
    "\n",
    "# ==========================================\n",
    "# 2. Launcher Class (Main Logic)\n",
    "# ==========================================\n",
    "\n",
    "class BenchmarkLauncher:\n",
    "    def __init__(self, N_val, d, n_samples=10000):\n",
    "        self.d = d\n",
    "        self.N_val = N_val\n",
    "        self.N = self.N_val * np.ones(self.d).astype(int)\n",
    "        self.n_samples = n_samples\n",
    "        \n",
    "    def run(self):\n",
    "        print(f\"--- Starting Benchmark (d={self.d}, N={self.N_val}, n={self.n_samples}) ---\")\n",
    "        \n",
    "        # 1. Data Generation\n",
    "        print(\"1. Data Generation...\")\n",
    "        X_uniq = generate_hypergrid(self.N)\n",
    "        Proba = generate_random_proba(self.N)\n",
    "        X = generate_random_dataset(self.N, Proba, self.n_samples)\n",
    "        y = f_target(X)\n",
    "        \n",
    "        # 2. Model Training\n",
    "        print(\"2. XGBoost Training...\")\n",
    "        model, global_r2 = train_xgb_model(X, y)\n",
    "        \n",
    "        # 3. Functional ANOVA (previously BHD)\n",
    "        print(\"3. ANOVA Analysis (Functional ANOVA)...\")\n",
    "        # Note: ModelAnalysis signature based on provided code\n",
    "        A = ModelAnalysis(X, model.predict, 100, 1, 0)\n",
    "        S, ANOVA_matrix = A.functional_anova()\n",
    "        \n",
    "        # Extraction ANOVA Metrics\n",
    "        P = A.get_P() # Proba distribution on grid\n",
    "        y_tot = A.get_Y()\n",
    "        \n",
    "        anova_l2_err = A.get_L2_Error()\n",
    "        anova_l2_rel = A.get_L2_Error_rel()\n",
    "        \n",
    "        # ANOVA Orthogonality\n",
    "        L_S = build_L(S)\n",
    "        non_empty_indices = [i + 1 for i, a in enumerate(L_S) if len(a) != 0]\n",
    "        if len(non_empty_indices) > 0:\n",
    "            anova_ortho = np.max([\n",
    "                np.max(np.abs(ANOVA_matrix[:, L_S[i-1]].T * P @ ANOVA_matrix[:, i])) \n",
    "                for i in non_empty_indices\n",
    "            ])\n",
    "        else:\n",
    "            anova_ortho = 0.0\n",
    "\n",
    "        # ANOVA Explainability\n",
    "        Main_effects_ANOVA = np.sum(np.abs(ANOVA_matrix.T * P)[1 : self.d+1] , axis=1)\n",
    "        Shap_ANOVA = batch_shapley_values(self.d, S, ANOVA_matrix)\n",
    "\n",
    "        # 4. TreeHFD\n",
    "        print(\"4. TreeHFD Analysis...\")\n",
    "        treehfd_model = XGBTreeHFD(model)\n",
    "        treehfd_model.fit(X)\n",
    "        \n",
    "        # Prediction on the unique grid\n",
    "        TreeHFD_main, TreeHFD_order_2 = treehfd_model.predict(A.get_X_uniq().astype(float))\n",
    "        # Reconstruction of the matrix (col 0 is the intercept/bias, often ANOVA_matrix[:,0])\n",
    "        TreeHFD_matrix = np.c_[ANOVA_matrix[:, 0], TreeHFD_main, TreeHFD_order_2]\n",
    "\n",
    "        # TreeHFD Metrics (L2)\n",
    "        Err_L2_tree = ((np.sum(TreeHFD_matrix[:, :], axis=1) - y_tot)**2) @ P\n",
    "        # Protection against division by zero if y is null (unlikely with random floats)\n",
    "        denom = (y_tot**2 @ P)\n",
    "        tree_l2_rel = 100 * Err_L2_tree / denom if denom > 1e-9 else 0.0\n",
    "        \n",
    "        # TreeHFD Orthogonality\n",
    "        S_tree = [[]] + [[i+1] for i in range(self.d)] + (treehfd_model.interaction_list + 1).tolist()\n",
    "        L_S_tree = build_L(S_tree)\n",
    "        non_empty_indices_tree = [i + 1 for i, a in enumerate(L_S_tree) if len(a) != 0]\n",
    "        \n",
    "        if len(non_empty_indices_tree) > 0:\n",
    "            tree_ortho = np.max([\n",
    "                np.max(np.abs(TreeHFD_matrix[:, L_S_tree[i-1]].T * P @ TreeHFD_matrix[:, i])) \n",
    "                for i in non_empty_indices_tree\n",
    "            ])\n",
    "        else:\n",
    "            tree_ortho = 0.0\n",
    "\n",
    "        # TreeHFD Explainability\n",
    "        Main_effects_treeHFD = np.sum(np.abs(TreeHFD_matrix.T * P)[1 : self.d+1], axis=1)\n",
    "        Shap_treeHFD = batch_shapley_values(self.d, S_tree, TreeHFD_matrix)\n",
    "\n",
    "        # 5. Comparisons\n",
    "        diff_main = np.linalg.norm(Main_effects_ANOVA - Main_effects_treeHFD)\n",
    "        \n",
    "        # Diff Shap per feature (weighted sum of squared differences)\n",
    "        diff_shap_vec = np.sum(((Shap_ANOVA - Shap_treeHFD)**2).T * P, axis=1)\n",
    "        # We take the sum or norm of the vector for synthetic display\n",
    "        diff_shap_scalar = np.sum(diff_shap_vec) \n",
    "\n",
    "        # 6. Display\n",
    "        self.print_results(\n",
    "            global_r2, \n",
    "            anova_l2_err, anova_l2_rel, anova_ortho,\n",
    "            Err_L2_tree, tree_l2_rel, tree_ortho,\n",
    "            diff_main, diff_shap_scalar\n",
    "        )\n",
    "\n",
    "    def print_results(self, r2, anova_mse, anova_rel, anova_orth, tree_mse, tree_rel, tree_orth, d_main, d_shap):\n",
    "        print(\"\\n\" + \"=\"*80)\n",
    "        print(f\"{'BENCHMARK RESULTS':^80}\")\n",
    "        print(\"=\"*80)\n",
    "        print(f\"Global Model (XGBoost) Test R² : {r2:.4f}\")\n",
    "        print(\"-\" * 80)\n",
    "        \n",
    "        # Table Header\n",
    "        header = f\"| {'Metric':<25} | {'ANOVA':<20} | {'TreeHFD':<20} |\"\n",
    "        print(header)\n",
    "        print(\"|\" + \"-\"*27 + \"|\" + \"-\"*22 + \"|\" + \"-\"*22 + \"|\")\n",
    "        \n",
    "        # Table Rows\n",
    "        print(f\"| {'MSE (Reconstruction)':<25} | {anova_mse:.6f}{' '*12} | {tree_mse:.6f}{' '*12} |\")\n",
    "        print(f\"| {'Relative MSE (%)':<25} | {anova_rel:.4f}%{' '*11} | {tree_rel:.4f}%{' '*11} |\")\n",
    "        print(f\"| {'Orthogonality (Max)':<25} | {anova_orth:.6e}{' '*8} | {tree_orth:.6e}{' '*8} |\")\n",
    "        \n",
    "        print(\"-\" * 80)\n",
    "        print(f\"{'DIRECT COMPARISON':^80}\")\n",
    "        print(\"-\" * 80)\n",
    "        print(f\"Main Effects Difference (L2 Norm) : {d_main:.6e}\")\n",
    "        print(f\"SHAP Difference (Weighted SSD)    : {d_shap:.6e}\")\n",
    "        print(\"=\"*80 + \"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "becc5e2c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- Starting Benchmark (d=2, N=[3 3], n=10000) ---\n",
      "1. Data Generation...\n",
      "2. XGBoost Training...\n",
      "3. ANOVA Analysis (Functional ANOVA)...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Constructing Basis Matrix: 100%|\u001b[32m██████████\u001b[0m| 9/9 [00:00<00:00, 8730.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computations complete. Results ready.\n",
      "4. TreeHFD Analysis...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:00<00:00, 113.74it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 11041.13it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "                               BENCHMARK RESULTS                                \n",
      "================================================================================\n",
      "Global Model (XGBoost) Test R² : 0.9975\n",
      "--------------------------------------------------------------------------------\n",
      "| Metric                    | ANOVA                | TreeHFD              |\n",
      "|---------------------------|----------------------|----------------------|\n",
      "| MSE (Reconstruction)      | 0.000000             | 0.000000             |\n",
      "| Relative MSE (%)          | 0.0000%            | 0.0000%            |\n",
      "| Orthogonality (Max)       | 1.541620e-19         | 1.774456e-04         |\n",
      "--------------------------------------------------------------------------------\n",
      "                               DIRECT COMPARISON                                \n",
      "--------------------------------------------------------------------------------\n",
      "Main Effects Difference (L2 Norm) : 1.871161e-03\n",
      "SHAP Difference (Weighted SSD)    : 1.331728e-05\n",
      "================================================================================\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# ==========================================\n",
    "# RUN 1 : d=2\n",
    "# ==========================================\n",
    "\n",
    "d = 2\n",
    "N = 3*np.ones(d).astype(int)\n",
    "launcher = BenchmarkLauncher(N_val=N, d=d, n_samples=10000)\n",
    "launcher.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7d9b67c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- Starting Benchmark (d=4, N=[3 3 3 3], n=10000) ---\n",
      "1. Data Generation...\n",
      "2. XGBoost Training...\n",
      "3. ANOVA Analysis (Functional ANOVA)...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Constructing Basis Matrix: 100%|\u001b[32m██████████\u001b[0m| 73/73 [00:00<00:00, 22698.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computations complete. Results ready.\n",
      "4. TreeHFD Analysis...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 73.57it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 9009.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "                               BENCHMARK RESULTS                                \n",
      "================================================================================\n",
      "Global Model (XGBoost) Test R² : 0.9966\n",
      "--------------------------------------------------------------------------------\n",
      "| Metric                    | ANOVA                | TreeHFD              |\n",
      "|---------------------------|----------------------|----------------------|\n",
      "| MSE (Reconstruction)      | 0.000000             | 0.000000             |\n",
      "| Relative MSE (%)          | 0.0000%            | 0.0000%            |\n",
      "| Orthogonality (Max)       | 5.649304e-18         | 4.733991e-03         |\n",
      "--------------------------------------------------------------------------------\n",
      "                               DIRECT COMPARISON                                \n",
      "--------------------------------------------------------------------------------\n",
      "Main Effects Difference (L2 Norm) : 2.436838e-02\n",
      "SHAP Difference (Weighted SSD)    : 5.571920e-04\n",
      "================================================================================\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# ==========================================\n",
    "# RUN 2 : d=4\n",
    "# ==========================================\n",
    "\n",
    "d = 4\n",
    "N = 3*np.ones(d).astype(int)\n",
    "launcher = BenchmarkLauncher(N_val=N, d=d, n_samples=10000)\n",
    "launcher.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a6515480",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- Starting Benchmark (d=6, N=[3 3 3 3 3 3], n=10000) ---\n",
      "1. Data Generation...\n",
      "2. XGBoost Training...\n",
      "3. ANOVA Analysis (Functional ANOVA)...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Constructing Basis Matrix: 100%|\u001b[32m██████████\u001b[0m| 608/608 [00:00<00:00, 4092.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computations complete. Results ready.\n",
      "4. TreeHFD Analysis...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 79.54it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 3477.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "                               BENCHMARK RESULTS                                \n",
      "================================================================================\n",
      "Global Model (XGBoost) Test R² : 0.9966\n",
      "--------------------------------------------------------------------------------\n",
      "| Metric                    | ANOVA                | TreeHFD              |\n",
      "|---------------------------|----------------------|----------------------|\n",
      "| MSE (Reconstruction)      | 0.000000             | 0.000000             |\n",
      "| Relative MSE (%)          | 0.0000%            | 0.0000%            |\n",
      "| Orthogonality (Max)       | 1.419548e-16         | 8.313037e-03         |\n",
      "--------------------------------------------------------------------------------\n",
      "                               DIRECT COMPARISON                                \n",
      "--------------------------------------------------------------------------------\n",
      "Main Effects Difference (L2 Norm) : 2.016210e-02\n",
      "SHAP Difference (Weighted SSD)    : 3.811470e-04\n",
      "================================================================================\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# ==========================================\n",
    "# RUN 3 : d=6\n",
    "# ==========================================\n",
    "\n",
    "d = 6\n",
    "N = 3*np.ones(d).astype(int)\n",
    "launcher = BenchmarkLauncher(N_val=N, d=d, n_samples=10000)\n",
    "launcher.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6b404ed1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- Starting Benchmark (d=8, N=[3 3 3 3 3 3 3 3], n=10000) ---\n",
      "1. Data Generation...\n",
      "2. XGBoost Training...\n",
      "3. ANOVA Analysis (Functional ANOVA)...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Constructing Basis Matrix: 100%|\u001b[32m██████████\u001b[0m| 3334/3334 [00:31<00:00, 104.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computations complete. Results ready.\n",
      "4. TreeHFD Analysis...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 70.93it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 584.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "                               BENCHMARK RESULTS                                \n",
      "================================================================================\n",
      "Global Model (XGBoost) Test R² : 0.9899\n",
      "--------------------------------------------------------------------------------\n",
      "| Metric                    | ANOVA                | TreeHFD              |\n",
      "|---------------------------|----------------------|----------------------|\n",
      "| MSE (Reconstruction)      | 0.000000             | 0.000000             |\n",
      "| Relative MSE (%)          | 0.0000%            | 0.0000%            |\n",
      "| Orthogonality (Max)       | 3.572773e-16         | 8.594655e-03         |\n",
      "--------------------------------------------------------------------------------\n",
      "                               DIRECT COMPARISON                                \n",
      "--------------------------------------------------------------------------------\n",
      "Main Effects Difference (L2 Norm) : 7.881006e-03\n",
      "SHAP Difference (Weighted SSD)    : 4.892852e-05\n",
      "================================================================================\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# ==========================================\n",
    "# RUN 4 : d=8\n",
    "# ==========================================\n",
    "\n",
    "d = 8\n",
    "N = 3*np.ones(d).astype(int)\n",
    "launcher = BenchmarkLauncher(N_val=N, d=d, n_samples=10000)\n",
    "launcher.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6ebee8aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- Starting Benchmark (d=10, N=[3 3 3 3 3 3 3 3 3 3], n=10000) ---\n",
      "1. Data Generation...\n",
      "2. XGBoost Training...\n",
      "3. ANOVA Analysis (Functional ANOVA)...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Constructing Basis Matrix: 100%|\u001b[32m██████████\u001b[0m| 8032/8032 [09:19<00:00, 14.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computations complete. Results ready.\n",
      "4. TreeHFD Analysis...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 68.25it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 216.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "                               BENCHMARK RESULTS                                \n",
      "================================================================================\n",
      "Global Model (XGBoost) Test R² : 0.9790\n",
      "--------------------------------------------------------------------------------\n",
      "| Metric                    | ANOVA                | TreeHFD              |\n",
      "|---------------------------|----------------------|----------------------|\n",
      "| MSE (Reconstruction)      | 0.000000             | 0.000000             |\n",
      "| Relative MSE (%)          | 0.0000%            | 0.0000%            |\n",
      "| Orthogonality (Max)       | 2.723414e-16         | 6.649299e-04         |\n",
      "--------------------------------------------------------------------------------\n",
      "                               DIRECT COMPARISON                                \n",
      "--------------------------------------------------------------------------------\n",
      "Main Effects Difference (L2 Norm) : 1.609897e-03\n",
      "SHAP Difference (Weighted SSD)    : 2.263257e-06\n",
      "================================================================================\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# ==========================================\n",
    "# RUN 5 : d=10\n",
    "# ==========================================\n",
    "\n",
    "d = 10\n",
    "N = 3*np.ones(d).astype(int)\n",
    "launcher = BenchmarkLauncher(N_val=N, d=d, n_samples=10000)\n",
    "launcher.run()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "hfd_env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
