{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This notebook provides a step-by-step guide for reproducing the experimental results reported in our paper, *Graph-Guided Sparse Learning via Boolean Relaxation*.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from random_ensemble import RandomEnsembleCorrelation, RandomEnsembleCorrelationWeight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\n",
    "We import the classes `RandomEnsembleCorrelation` and `RandomEnsembleCorrelationWeight`, which correspond to **Random Ensemble I** and **Random Ensemble II** in the paper, respectively.\n",
    "\n",
    "Both classes require the following parameters:\n",
    "\n",
    "* `n`: number of samples\n",
    "* `d`: number of features\n",
    "* `k`: sparsity level (i.e., number of non-zero coefficients)\n",
    "* `p` *(optional, default = 0.95)*: probability of edges forming between two selected features or two non-selected features\n",
    "* `q` *(optional, default = 0.01)*: probability of edges forming between a selected feature and a non-selected feature\n",
    "* `gamma`: standard deviation of the noise added to the response\n",
    "* `correlated_ratio` *(optional, default = 0.3)*: fraction of selected features that are correlated with non-selected features\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here we create a random ensemble:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "demo = RandomEnsembleCorrelation(n=20, d=100, k=10, p=0.95, q=0.01, gamma=0.1, correlated_ratio=0.2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We use the `run` method to evaluate **support recovery accuracy**. This method accepts two optional parameters:\n",
    "\n",
    "* `num_replications`: number of repetitions for the experiment (default: 10)\n",
    "* `models`: list of models to evaluate (default: all models discussed in the paper — `gfl_pqn`, `gfl_proximal`, `lasso`, `adaptive_grace`, and `signal_family`)\n",
    "\n",
    "The `signal_family` includes the following algorithms: `gen-mp`, `dmo-acc-fw`, `graph-cosamp`, `cosamp`, and `graph-iht`. These methods originate from the study of compressed sensing signal sparse recovery."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Running gen-mp\n",
      "Running dmo-acc-fw\n",
      "Running graph-cosamp\n",
      "Running cosamp\n",
      "Running graph-iht\n",
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Running gen-mp\n",
      "Running dmo-acc-fw\n",
      "Running graph-cosamp\n",
      "Running cosamp\n",
      "Running graph-iht\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 0.9, Std. Accuracy: 0.09999999999999998\n",
      "Model: gen-mp, Avg. Accuracy: 0.35, Std. Accuracy: 0.15\n",
      "Model: dmo-acc-fw, Avg. Accuracy: 0.4, Std. Accuracy: 0.0\n",
      "Model: graph-cosamp, Avg. Accuracy: 0.4, Std. Accuracy: 0.0\n",
      "Model: cosamp, Avg. Accuracy: 0.3, Std. Accuracy: 0.0\n",
      "Model: graph-iht, Avg. Accuracy: 0.25, Std. Accuracy: 0.04999999999999999\n"
     ]
    }
   ],
   "source": [
    "accuracy = demo.run(num_replications=2, models=['gfl_pqn', 'gfl_proximal', 'signal_family'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To observe how support recovery accuracy varies with sample size, you can pass a list of sample sizes to the function `support_recovery_analysis`, which generates the plots shown in the paper.\n",
    "\n",
    "This function accepts the following parameters:\n",
    "\n",
    "* `accuracy`: list of support recovery accuracies\n",
    "* `sample_sizes`: list of corresponding sample sizes\n",
    "* `file_name` *(optional, default: None)*: name of the file to save the plot; if set to `None`, the plot will not be saved\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 0.8, Std. Accuracy: 0.0\n",
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Running gfl_pqn\n",
      "Running gfl_proximal\n",
      "Model: gfl_pqn, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n",
      "Model: gfl_proximal, Avg. Accuracy: 1.0, Std. Accuracy: 0.0\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "sample_sizes = np.arange(10, 100, 20)\n",
    "accuracy = []\n",
    "for sample_size in sample_sizes:\n",
    "    demo_sample = RandomEnsembleCorrelation(n=sample_size, d=100, k=10, p=0.95, q=0.01, gamma=0.1, correlated_ratio=0.2)\n",
    "    accuracy_sample = demo_sample.run(num_replications=1, models=['gfl_pqn', 'gfl_proximal'])\n",
    "    accuracy.append(accuracy_sample)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHACAYAAACMB0PKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABzdUlEQVR4nO3deVxUZfvH8c+wLwouKOAGaO77Lppmi5CZZmWplWZqj2alZquZuWSaVmZW8styz9Jc6qkeS7FcU7MULZcQ0zIVJC0FJWGA8/uDmBxBZXBwFr7v14uXM/fc55zr4lBcnHPf9zEZhmEgIiIi4oQ8HB2AiIiIyKWoUBERERGnpUJFREREnJYKFREREXFaKlRERETEaalQEREREaelQkVERESclgoVERERcVpejg7AVeXm5nL8+HHKli2LyWRydDgiIiIuwzAM0tPTqVKlCh4el79mokKlmI4fP0716tUdHYaIiIjL+v3336lWrdpl+6hQKaayZcsCed/koKAgu+zTbDazZs0aYmJi8Pb2tss+HU05uQbl5PzcLR9QTq6iJHJKS0ujevXqlt+ll6NCpZjyb/cEBQXZtVAJCAggKCjIrX7AlZPzU07Oz93yAeXkKkoyp6IMndBgWhEREXFaKlRERETEaalQEREREaelQkVERESclgoVERERcVoqVERERMRpqVARERERp6VCRURERJyWChURERFxWipUnEROrsF3h/9kx0kT3x3+k5xcw9EhSSFysrP5eduXZP22jZ+3fUlOdrajQ5JC6Dw5P50j1+AM58mhhcrGjRvp3r07VapUwWQy8emnn15xmw0bNtCyZUv8/PyoWbMm//d//1egz4oVK2jQoAG+vr40aNCATz75pECfWbNmERUVhZ+fHy1btmTTpk32SKlYvtqTzPVTv+GBuT+wMMmTB+b+wPVTv+GrPckOi0kKSli9gJOT6tD4637c8+csGn/dj5OT6pCweoGjQ5ML6Dw5P50j1+As58mhhcq5c+do2rQpb7/9dpH6Hz58mNtuu42OHTuSkJDA888/z/Dhw1mxYoWlz9atW+nduzf9+vVj9+7d9OvXj3vvvZfvvvvO0mfp0qWMHDmSMWPGkJCQQMeOHenatStHjhyxe45X8tWeZB75YCfJZ85btaecOc8jH+xUseIkElYvoOmW4VQyTlm1VzJO0XTLcP0P1kno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",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'gfl_pqn': [1.0, 1.0, 1.0, 1.0, 1.0],\n",
       " 'gfl_proximal': [0.8, 1.0, 1.0, 1.0, 1.0]}"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from utils.visualization import support_recovery_analysis\n",
    "support_recovery_analysis(accuracy, sample_sizes)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We can also evaluate out-of-sample mean squared error (MSE) to select the optimal sparsity level `k` using the `out_of_sample` method. This method accepts the following optional parameters:\n",
    "\n",
    "* `k_values`: list of `k` values to evaluate (default: the full set of `k` values considered in the paper)\n",
    "* `num_replications`: number of repetitions for the experiment (default: 10)\n",
    "* `model`: the model to evaluate (default: `'gfl_pqn'`, the proposed method in the paper)\n",
    "\n",
    "This analysis helps identify the `k` that yields the best predictive performance under different sample sizes and noise levels."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Replication 1/1 with model gfl_pqn, k=5, MSE=1.5803\n",
      "Replication 1/1 with model gfl_pqn, k=10, MSE=0.0038\n",
      "Replication 1/1 with model gfl_pqn, k=15, MSE=0.1506\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "k_values = np.arange(5, 20, 5)\n",
    "mse_results = demo.out_of_sample(k_values, num_replications=1, model='gfl_pqn')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "You can use the `plot_out_of_sample_mse` function to visualize the out-of-sample MSE results reported in the paper. It accepts the following parameters:\n",
    "\n",
    "- `mse_results`: the result returned by the `out_of_sample` method  \n",
    "- `true_k`: the ground-truth sparsity level  \n",
    "- `file_name` *(optional, default: None)*: the name of the file to save the plot; if set to `None`, the plot will not be saved"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/aolongli/Desktop/Research-GFL/Experiement/code/Graph-Guided-Sparse-Learning/utils/visualization.py:72: UserWarning: linestyle is redundantly defined by the 'linestyle' keyword argument and the fmt string \"o-\" (-> linestyle='-'). The keyword argument will take precedence.\n",
      "  plt.errorbar(k_vals, mse_means, yerr=mse_stds, fmt='o-', capsize=4, linestyle='--', color='r', label=\"Estimated MSE\")\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh0AAAHFCAYAAABW5Us4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABiUklEQVR4nO3deVxU1f/H8dewCKKCO4vivlam5pZbLikuZaYtliWaWvmzcqGsrL7uyjdNpTS3TEkrM3NroZJvqZhppUmbluUugkaZuCLL/P64MYqgDjBwh5n38/Hgwcyde2fecxzkw7nnnmOxWq1WRERERAqZh9kBRERExD2o6BAREZEioaJDREREioSKDhERESkSKjpERESkSKjoEBERkSKhokNERESKhIoOERERKRJeZgdwBpmZmRw7dowyZcpgsVjMjiMiIlJsWK1WTp8+TUhICB4e1+7LUNEBHDt2jNDQULNjiIiIFFtHjhyhatWq19xHRQdQpkwZwGgwf39/k9MUvbS0NDZs2EBYWBje3t5mxyn21J6O16BBAxITEwkODubXX381O06xp8+o47lzm6akpBAaGmr7XXotKjrAdkrF39/fbYsOPz8//P393e6HpTCoPR0vq8vWw8PDLX9GHU2fUcdTm2LX8AQNJBUREZEioaJDREREioSKDhERESkSGtMhIuICrFYr6enpZGRkXHfftLQ0vLy8uHDhgl37y/W5ept6e3vj6elZ4OdR0SEiUsxdvHiRxMREzp07Z9f+VquVoKAgjhw5ormJHMTV29RisVC1alVKly5doOdR0SEiUoxlZmZy4MABPD09CQkJoUSJEtf9pZeZmcmZM2coXbr0dSdzEvu4cptarVb+/PNPjh49St26dQvU4+F0RUdcXBwzZsxg586dJCYmsnbtWu6+++5rHpOamsqkSZN4++23SUpKomrVqrz44osMHjy4aEKLiJjk4sWLZGZmEhoaip+fn13HZGZmcvHiRXx9fV3uF6RZXL1NK1WqxMGDB0lLS3OtouPs2bM0btyYRx55hHvuuceuY+6//36OHz/Om2++SZ06dThx4gTp6emFnFRExHm44i86cR6OOmXkdEVHjx496NGjh937f/bZZ2zevJn9+/dTvnx5AGrUqFFI6URERCS/nK7oyKsPP/yQ5s2bM336dJYvX06pUqW46667mDx5MiVLlsz1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RERE7JDvouPll19m3LhxpKenZ1uK/oMPPmDixIlMmjSJ5557ziEhRa7q8oIjI8O4nFZERJxSvk6vLF26lLFjx1KxYkWmT5/O9u3bOXDgANu3b2f69OlUqFCBF154gejoaAfHFcmF1QqrVkH9+vDHH2anERGRq8hXT8fs2bMJDAxk165dVK5c2ba9evXqtGzZkgEDBtC4cWNmzZrFoEGDHJVV5OoWLzYuoX3qKYiJMcZ8iIiIU8lXT8fvv//O/fffn63guFxgYCD33Xcfv//+e4HCidjFYoE5c4xTLZ99BmvXmp1IRERyka+io1KlSnh7e19znxIlSlCpUqV8hRLJs3r1YMwY4/aoUXD2rKlxREQkp3wVHQ888ACrV6/m3LlzuT5+5swZVq9ezYMPPligcCJ58sILUL06HDkCU6aYnUZERK6Qr6Jj8uTJNGrUiFatWrFy5UoSEhJIS0sjISGB9957j9atW9O4ceN8r9kiki9+fvDaa8btmTPh11/NzSMiItnkayCpn58fAFarlf79++d43Gq1snv3btt+WSwWC+np6fl5SRH79OoFd9wBn3wC69bB88+bnUhERP6Vr6Kjffv2WHR1gDijrEGlo0ZBly5mpxERkcvkq+jYtGmTg2OIOFDNmloATkTECWntFXFtCQnw7rtmpxAREQq49oqIUztyBG64AS5cgMaN4cYbzU4kIuLW8l10HDp0iKioKH744Qfb1StXslgs7Nu3r0ABRfItNBS6djUmCxs+HDZt0kylIiImylfRsWHDBnr37k1qaire3t5UrlwZL6+cT2XVcuNittmzjVlK4+KM0ywPPWR2IhERt5WvomPMmDF4eHiwcuVK7rnnHjw8NDREnFT16vCf/xgThz39NNx5JwQEmJ1KRMQt5ata2Lt3L/379+e+++5TwSHO7+mnjRVojx+H8ePNTiMi4rbyVTEEBwfj6+vr6CwihaNECZg717g9Zw788IO5eURE3FS+Tq88/PDDvPvuu1y4cEHFhxQPXboY4zmqVIHatc1OIyLilvLV0zFu3DhuuOEGunXrxtatWzlz5oyjc4k43vLl8PLLULq02UlERNxSvooOLy8vnnzySX766Sduu+02AgIC8PT0zPGV2xUt9pg3bx41a9bE19eXZs2asWXLlmvu/84779C4cWP8/PwIDg7mkUce4a+//srXa4sLu/xy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Zk1KlixJrVq1mDRpkm3dELm+uLg4evXqRUhICBaLhXXr1mV73Gq1MmHCBEJCQihZsiQdO3bkl19+MSdsMXCt9kxLS+O5556jUaNGlCpVipCQEMLDwzl27Jh5gYuB631GL/f4449jsViIiooqsnzOTkWHmzp58iRt27bF29ubTz/9lN27dzNz5kzKli1rdrRi6+WXX2bBggXMnTuXPXv2MH36dGbMmMGcOXPMjlZsnD17lsaNGzN37txcH58+fTqzZs1i7ty5fPfddwQFBdG1a1fb+kmS3bXa89y5c3z//ff85z//4fvvv2fNmjXs3buXu+66y4Skxcf1PqNZ1q1bxzfffENISEgRJSsmrOKWnnvuOWu7du3MjuFS7rjjDuvgwYOzbevbt6/14YcfNilR8QZY165da7ufmZlpDQoKsv73v/+1bbtw4YI1ICDAumDBAhMSFi9Xtmduvv32WytgPXToUNGEKuau1qZHjx61VqlSxfrzzz9bq1evbp09e3aRZ3NW6ulwUx9++CHNmzfnvvvuo3LlyjRt2pQ33njD7FjFWrt27fjiiy/Yu3cvAD/88ANfffUVPXv2NDmZazhw4ABJSUmEhYXZtvn4+NChQwe+/vprE5O5jlOnTmGxWNTjWQCZmZkMGDCAMWPGcOONN5odx+lowTc3tX//fubPn09ERAQvvPAC3377LSNGjMDHx4fw8HCz4xVLzz33HKdOnaJBgwZ4enqSkZHB1KlTefDBB82O5hKSkpIACAwMzLY9MDCQQ4cOmRHJpVy4cIHnn3+e/v37u+WCZY7y8ssv4+XlxYgRI8yO4pRUdLipzMxMmjdvzrRp0wBo2rQpv/zyC/Pnz1fRkU8rV67k7bff5t133+XGG28kPj6eUaNGERISwsCBA82O5zIsFku2+1arNcc2yZu0tDQeeOABMjMzmTdvntlxiq2dO3fy6quv8v333+szeRU6veKmgoODueGGG7Jta9iwIYcPHzYpUfE3ZswYnn/+eR544AEaNWrEgAEDGD16NJGRkWZHcwlBQUHApR6PLCdOnMjR+yH2S0tL4/777+fAgQPExsaql6MAtmzZwokTJ6hWrRpeXl54eXlx6NAhnn76aWrUqGF2PKegosNNtW3blt9++y3btr1791K9enWTEhV/586dw8Mj+4+Up6enLpl1kJo1axIUFERsbKxt28WLF9m8eTNt2rQxMVnxlVVw/P777/zvf/+jQoUKZkcq1gYMGMCPP/5IfHy87SskJIQxY8bw+eefmx3PKej0ipsaPXo0bdq0Ydq0adx///18++23LFq0iEWLFpkdrdjq1asXU6dOpVq1atx4443s2rWLWbNmMXjwYLOjFRtnzpzhjz/+sN0/cOAA8fHxlC9fnmrVqjFq1CimTZtG3bp1qVu3LtOmTcPPz4/+/fubmNp5Xas9Q0JCuPfee/n+++/5+OOPycjIsPUilS9fnhIlSpgV26ld7zN6ZeHm7e1NUFAQ9evXL+qozsnsy2fEPB999JH1pptusvr4+FgbNGhgXbRokdmRirWUlBTryJEjrdWqVbP6+vpaa9WqZX3xxRetqampZkcrNjZu3GgFcnwNHDjQarUal82OHz/eGhQUZPXx8bHedttt1p9++snc0E7sWu154MCBXB8DrBs3bjQ7utO63mf0SrpkNjstbS8iIiJFQmM6REREpEio6BAREZEioaJDREREioSKDhERESkSKjpERESkSKjoEBERkSKhokNERESKhIoOEXFazz33HBaLhW+//dbsKCLiACo6RMRp7dq1C09PTxo1amR2FBFxAM1IKiJOq3LlygQGBvLTTz+ZHUVEHEA9HSLilI4ePcqff/5J06ZNzY4iIg6iokNEnNKuXbsAuOWWW7Jt//nnn6lfvz4BAQGsX7/ejGgikk8qOkTEKeVWdLzzzju0atUKT09Pvv32W3r37m1WPBHJBxUdIuKUdu3ahcVioUmTJly8eJEnnniChx9+mB49evDtt99Sv359syOKSB55mR1ARCQ3u3btonbt2pw6dYquXbuyc+dOIiMjef75582OJiL5pKtXRMTpnDx5kvLly1O7dm3++ecfAN577z26dOlibjARKRCdXhERp5M1nuPkyZP89ddfjBw5UgWHiAtQ0SEiTier6FiyZAktW7Zk4sSJfP755yanEpGCUtEhIk4nq+ho3bo169evp0qVKtx///38/PPPJicTkYLQmA4RcTo33ngjJ0+e5NixYwD8+OOPtG3blgoVKvDNN98QGBhockIRyQ/1dIiIUzl//jy//fYbjRs3tm27+eabWbFiBUeOHKF3795cuHDBxIQikl8qOkTEqfz4449kZGTQpEmTbNvvvPNOZs6cyTfffMPAgQNRJ61I8aPTKyIiIlIk1NMhIiIiRUJFh4iIiBQJFR0iIiJSJFR0iIiISJFQ0SEiIiJFQkWHiIiIFAkVHSIiIlIkVHSIiIhIkVDRISIiIkVCRYeIiIgUCRUdIiIiUiRUdIiIiEiRUNEhIiIiReL/ASr+kdGKIXJ7AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils.visualization import plot_out_of_sample_mse\n",
    "plot_out_of_sample_mse(mse_results, true_k=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from solver import Solver"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "You can also import the `Solver` class to obtain the selected features for a given model. It accepts the following parameters:\n",
    "\n",
    "- `models`: a list of models to evaluate  \n",
    "- `c` *(optional, default: 1)*: a parameter required by the signal family methods, representing an upper bound on the $\\ell_2$-norm of the estimated weight vector\n",
    "\n",
    "In experiments where the ground-truth weight vector is known, `c` is typically set to match the $\\ell_2$-norm of the true weights.  \n",
    "For inference tasks where the true weights are unknown, `c` is set to 1 by default.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "\n",
    "# generate the data\n",
    "X = np.random.randn(20, 50)\n",
    "y = np.random.randn(20)\n",
    "A = sp.csr_matrix(np.triu((np.random.rand(50,50) < 0.05).astype(int), k=1))\n",
    "A = A + A.T\n",
    "L = sp.csgraph.laplacian(A, normed=False).astype(np.float64) # make sure it is a float64 otherwise matlab doesn't like it\n",
    "\n",
    "models = [\"gfl_pqn\", \"signal_family\"]\n",
    "solver = Solver(models, c=1)\n",
    "res = solver.fit(X, y, L, A, k=2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "defaultdict(list,\n",
       "            {'gfl_pqn': array([2.80968663e-12, 3.20970828e-12, 4.10334832e-12, 4.93402688e-12,\n",
       "                    3.05912985e-12, 2.06479250e-01, 2.60457985e-12, 2.79175102e-12,\n",
       "                    4.88941052e-12, 2.73062099e-12, 4.33361135e-12, 1.07995328e-11,\n",
       "                    2.77997129e-12, 2.76390876e-12, 6.66357916e-11, 2.68743878e-01,\n",
       "                    7.53595781e-12, 5.45562058e-12, 3.37880794e-02, 1.66378896e-08,\n",
       "                    3.03445799e-12, 3.13694324e-12, 2.82451767e-12, 3.19875984e-12,\n",
       "                    4.00528061e-12, 3.14329087e-07, 3.46230432e-12, 3.52747063e-12,\n",
       "                    2.62385152e-12, 2.22677016e-01, 3.36893958e-12, 2.71545805e-12,\n",
       "                    2.88087819e-12, 6.18388381e-12, 3.31126680e-12, 3.20665178e-12,\n",
       "                    5.98928729e-12, 2.89308774e-11, 2.75070341e-12, 2.60373175e-12,\n",
       "                    2.99785098e-12, 2.92762529e-12, 2.68471048e-12, 3.44791192e-01,\n",
       "                    5.62668093e-01, 1.14382871e-01, 2.46469288e-01, 7.04169603e-12,\n",
       "                    3.21675141e-12, 2.83709748e-12]),\n",
       "             'gen-mp': array([ 0.        ,  0.        ,  0.        , -0.06841064,  0.        ,\n",
       "                    -0.23480336,  0.        ,  0.        , -0.03814759,  0.        ,\n",
       "                     0.        , -0.06045676,  0.        ,  0.        ,  0.        ,\n",
       "                    -0.18886253, -0.11768222,  0.        , -0.05811464, -0.25083951,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.05897697,  0.        ,  0.        ,  0.        , -0.10057202,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.1530084 ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        , -0.25089802,  0.31563872,\n",
       "                    -0.12487438,  0.16094206,  0.        ,  0.        ,  0.        ]),\n",
       "             'dmo-acc-fw': array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                    -0.11780663,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                    -0.155928  , -0.00449056,  0.        , -0.01177703, -0.03764706,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.03294118,  0.        ,  0.        ,  0.        , -0.08623059,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        , -0.23921569,  0.2447054 ,\n",
       "                    -0.05124124,  0.11420814,  0.        ,  0.        ,  0.        ]),\n",
       "             'graph-cosamp': array([0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.46875356,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ]),\n",
       "             'cosamp': array([ 0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "                     0.        ,  0.        ,  0.        , -0.57802328,  0.43253452,\n",
       "                     0.        ,  0.        ,  0.        ,  0.        ,  0.        ]),\n",
       "             'graph-iht': array([0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.45165447,\n",
       "                    0.        , 0.        , 0.        , 0.        , 0.        ])})"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.        ,  0.        ,  0.        , -0.06841064,  0.        ,\n",
       "       -0.23480336,  0.        ,  0.        , -0.03814759,  0.        ,\n",
       "        0.        , -0.06045676,  0.        ,  0.        ,  0.        ,\n",
       "       -0.18886253, -0.11768222,  0.        , -0.05811464, -0.25083951,\n",
       "        0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "        0.05897697,  0.        ,  0.        ,  0.        , -0.10057202,\n",
       "        0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
       "        0.        ,  0.        ,  0.1530084 ,  0.        ,  0.        ,\n",
       "        0.        ,  0.        ,  0.        , -0.25089802,  0.31563872,\n",
       "       -0.12487438,  0.16094206,  0.        ,  0.        ,  0.        ])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res['gen-mp']"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gfl",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
