{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a33a92ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "os.environ[\"R_HOME\"] = r\"C:\\Program Files\\R\\R-4.4.2\"  # Use raw string for Windows paths\n",
    "sys.path.append(r\"c:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\")\n",
    "\n",
    "\n",
    "from utils import * \n",
    "# Core libraries\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    " \n",
    "\n",
    "# scikit-learn\n",
    "from sklearn.linear_model import LassoCV, RidgeCV\n",
    "from sklearn.metrics import mean_squared_error\n",
    "\n",
    "# rpy2 for R integration\n",
    "import rpy2.robjects as ro\n",
    "from rpy2.robjects import numpy2ri, r\n",
    "from rpy2.robjects.packages import importr\n",
    "\n",
    "# Activate NumPy-to-R conversion\n",
    "numpy2ri.activate()\n",
    "ashr = importr(\"ashr\")\n",
    "\n",
    "# torch (if used later in the project)\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    " \n",
    "# Local utilities (if you have a utils.py file)\n",
    "from utils_mix import *\n",
    "from empirical_mdn import emdn_posterior_means\n",
    "from utils_mix import *\n",
    "from numerical_routine import *\n",
    "from distribution_operation import *\n",
    "from posterior_computation import posterior_mean_norm\n",
    "from cash_solver import Cash_posterior_means\n",
    "from ash import call_r_ash_fit_all_with_postmean\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from sklearn.metrics import mean_squared_error, mean_absolute_error\n",
    "from sklearn.linear_model import LassoCV\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0dda98f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def col_scale(X, with_mean=True, with_std=True):\n",
    "    scaler = StandardScaler(with_mean=with_mean, with_std=with_std)\n",
    "    X_scaled = scaler.fit_transform(X)\n",
    "    return X_scaled, scaler.scale_\n",
    "\n",
    "\n",
    "def call_r_ash_fit_all_with_postmean(beta, sigma):\n",
    "    \"\"\"\n",
    "    Calls R's ash function and returns:\n",
    "    - log mixture weights\n",
    "    - mixture standard deviations\n",
    "    - posterior mean of beta\n",
    "    \"\"\"\n",
    "    from rpy2.rinterface_lib.sexp import NULLType\n",
    "\n",
    "    sebetahat = np.full_like(beta, sigma)\n",
    "    ash_obj = ashr.ash(betahat=beta, sebetahat=sebetahat, mixcompdist=\"normal\")\n",
    "\n",
    "    fitted_g = ash_obj.rx2(\"fitted_g\")\n",
    "    pi_r = np.array(fitted_g.rx2(\"pi\"), dtype=np.float32)\n",
    "    scale_r = np.array(fitted_g.rx2(\"sd\"), dtype=np.float32)\n",
    "\n",
    "    posterior_mean_r = ash_obj.rx2(\"result\").rx2(\"PosteriorMean\")\n",
    "    if isinstance(posterior_mean_r, NULLType):\n",
    "        raise RuntimeError(\"R ash() returned NULL for result$PosteriorMean\")\n",
    "    posterior_mean = np.array(posterior_mean_r, dtype=np.float32)\n",
    "\n",
    "    log_pi = np.log(np.clip(pi_r, 1e-12, 1.0))\n",
    "    return log_pi, scale_r, posterior_mean\n",
    "\n",
    "\n",
    "def get_data_loglik_normal(betahat, sebetahat, location, scale):\n",
    "    var = sebetahat[:, None] ** 2 + scale[None, :] ** 2\n",
    "    return -0.5 * (np.log(2 * np.pi * var) + (betahat[:, None] - location) ** 2 / var)\n",
    "\n",
    "\n",
    "def apply_log_sum_exp(data_loglik, log_pi):\n",
    "    combined_loglik = data_loglik + log_pi\n",
    "    return combined_loglik - logsumexp(combined_loglik, axis=1)[:, None]\n",
    "\n",
    "\n",
    "class PosteriorMeanNorm:\n",
    "    def __init__(self, post_mean, post_mean2, post_sd):\n",
    "        self.post_mean = post_mean\n",
    "        self.post_mean2 = post_mean2\n",
    "        self.post_sd = post_sd\n",
    "\n",
    "\n",
    "def posterior_mean_norm(betahat, sebetahat, log_pi, scale, location=None):\n",
    "    if location is None:\n",
    "        location = np.zeros_like(scale)\n",
    "\n",
    "    data_loglik = get_data_loglik_normal(betahat, sebetahat, location, scale)\n",
    "    log_post_assignment = apply_log_sum_exp(data_loglik, log_pi)\n",
    "\n",
    "    n, K = betahat.shape[0], scale.shape[0]\n",
    "    var = np.zeros((n, K))\n",
    "\n",
    "    if scale[0] == 0:\n",
    "        for i in range(n):\n",
    "            var[i, :] = np.concatenate(([0], 1 / ((1 / sebetahat[i]**2) + (1 / scale[1:]**2))))\n",
    "    else:\n",
    "        for i in range(n):\n",
    "            var[i, :] = 1 / ((1 / sebetahat[i]**2) + (1 / scale**2))\n",
    "\n",
    "    temp = np.zeros((n, K))\n",
    "    for i in range(n):\n",
    "        temp[i, :] = (var[i, :] / sebetahat[i]**2) * betahat[i] + location * (1 - var[i, :] / sebetahat[i]**2)\n",
    "\n",
    "    post_mean = np.sum(np.exp(log_post_assignment) * temp, axis=1)\n",
    "    post_mean2 = np.sum(np.exp(log_post_assignment) * (var + temp**2), axis=1)\n",
    "    post_sd = np.sqrt(post_mean2 - post_mean**2)\n",
    "    return PosteriorMeanNorm(post_mean, post_mean2, post_sd)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "53aaaa7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def nash_mdn(X, y, sideinfo=None, maxit=4, damping=0.99, eb_kwargs=None):\n",
    "    k=0 \n",
    "    X = X.astype(np.float32)\n",
    "    y = y.astype(np.float32).flatten()\n",
    "    X, csd = col_scale(X)\n",
    "    y, ysd = col_scale(y.reshape(-1, 1))\n",
    "    y = y.flatten()\n",
    "\n",
    "    n, p = X.shape\n",
    "    sqn = np.sqrt(n).astype(np.float32)\n",
    "    beta = LassoCV(cv=5, max_iter=5000).fit(X, y).coef_\n",
    "\n",
    "    log_pi, scale, location = None, None, None\n",
    "    td_beta = []\n",
    "    model_param = None\n",
    "    pi0=0\n",
    "    \n",
    "    for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        for k in range(p):\n",
    "            r = y - X @ beta\n",
    "            beta_new = beta.copy()\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta_new[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k) / sqn, 1e-4)\n",
    "            if 0<1: \n",
    "\n",
    "                beta_k_new = betahat_k\n",
    "                beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "             \n",
    "            else :\n",
    "                print(o)\n",
    "                pm = posterior_mean_norm(\n",
    "                    betahat=np.array([betahat_k]),\n",
    "                    sebetahat=np.array([sebetahat_k]),\n",
    "                    log_pi=np.log( np.clip( result.pi_np[k, :], 1e-12, 1.0)),\n",
    "                    location=result.location[k, :],\n",
    "                    scale=result.scale[k, :]\n",
    "                    )\n",
    "             \n",
    "                beta_k_new = pm.post_mean[0]\n",
    "\n",
    "            r += xk * (beta_new[k]  - beta_k_new)\n",
    "            beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "            beta_new[k]=beta_k_new\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k) \n",
    "\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        avg_se = np.mean(sebetahat_list)\n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ beta ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )   \n",
    " \n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ beta ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )\n",
    "        denom = n + p * (1 - pi0)\n",
    "        sigma_0 = np.sqrt(max((res_sq_final + sigma_0_term) / denom, 1e-8)) / sqn\n",
    "\n",
    "        res_sq = np.sum((y - X @ betahat_arr) ** 2)\n",
    "        drift_term = np.dot(betahat_arr,  betahat_arr) / np.sqrt(n + p)\n",
    "        s = np.sqrt((res_sq + drift_term)) / sqn\n",
    "\n",
    "        # Update drift_comp\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "        if o<1: \n",
    "            # Update beta with ash\n",
    "            ash_input = betahat_arr   \n",
    "            result =emdn_posterior_means(X= sideinfo,\n",
    "                                            betahat= ash_input,\n",
    "                                            sebetahat=np.array(sebetahat_list)   )\n",
    "            emdn_posterior_means(X= sideinfo,\n",
    "                                          betahat= ash_input,\n",
    "                                          sebetahat= np.full_like(ash_input,sigma_0), **(eb_kwargs or {}))\n",
    "        else :\n",
    "            ash_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "            result =emdn_posterior_means(X= sideinfo,\n",
    "                                          betahat= ash_input,\n",
    "                                          sebetahat=np.full_like(ash_input,sigma_0)   )\n",
    "            log_pi= result.pi_np\n",
    "            beta =   result.post_mean\n",
    "\n",
    "\n",
    "  \n",
    "    out=   ysd * result.post_mean/ csd\n",
    "    return out\n",
    " \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "fdf2943f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50, Loss: -0.6314\n",
      "Epoch 20/50, Loss: -1.7690\n",
      "Epoch 30/50, Loss: -3.1476\n",
      "Epoch 40/50, Loss: -4.0074\n",
      "Epoch 50/50, Loss: -0.6389\n",
      "Epoch 10/50, Loss: 1.2506\n",
      "Epoch 20/50, Loss: -3.6690\n",
      "Epoch 30/50, Loss: 1.0733\n",
      "Epoch 40/50, Loss: -0.4153\n",
      "Epoch 50/50, Loss: -1.5665\n",
      "Epoch 10/50, Loss: -0.4815\n",
      "Epoch 20/50, Loss: 2.0001\n",
      "Epoch 30/50, Loss: 2.3950\n",
      "Epoch 40/50, Loss: -0.1239\n",
      "Epoch 50/50, Loss: -3.0335\n",
      "  Fold 1: RMSE = 6.2169, MAD = 5.4324\n",
      "['TCGA']: mean RMSE = 6.2169, mean MAD = 5.4324\n",
      "\n",
      "Epoch 10/50, Loss: -0.6447\n",
      "Epoch 20/50, Loss: -2.5323\n",
      "Epoch 30/50, Loss: -1.8570\n",
      "Epoch 40/50, Loss: -1.7571\n",
      "Epoch 50/50, Loss: -3.7888\n",
      "Epoch 10/50, Loss: -1.1766\n",
      "Epoch 20/50, Loss: -2.5223\n",
      "Epoch 30/50, Loss: -0.9274\n",
      "Epoch 40/50, Loss: -0.8696\n",
      "Epoch 50/50, Loss: -2.9100\n",
      "Epoch 10/50, Loss: 0.9553\n",
      "Epoch 20/50, Loss: 1.0464\n",
      "Epoch 30/50, Loss: -1.1275\n",
      "Epoch 40/50, Loss: -3.0328\n",
      "Epoch 50/50, Loss: -0.0421\n",
      "  Fold 2: RMSE = 835.9014, MAD = 835.8764\n",
      "['TCGA']: mean RMSE = 421.0592, mean MAD = 420.6544\n",
      "\n",
      "Epoch 10/50, Loss: -2.2140\n",
      "Epoch 20/50, Loss: -3.0080\n",
      "Epoch 30/50, Loss: -3.4499\n",
      "Epoch 40/50, Loss: -3.9511\n",
      "Epoch 50/50, Loss: -3.8555\n",
      "Epoch 10/50, Loss: 3.2423\n",
      "Epoch 20/50, Loss: -0.4772\n",
      "Epoch 30/50, Loss: -1.6535\n",
      "Epoch 40/50, Loss: -3.6148\n",
      "Epoch 50/50, Loss: 1.7079\n",
      "Epoch 10/50, Loss: -2.3708\n",
      "Epoch 20/50, Loss: -0.2761\n",
      "Epoch 30/50, Loss: -1.3918\n",
      "Epoch 40/50, Loss: -0.9312\n",
      "Epoch 50/50, Loss: -0.3683\n",
      "  Fold 3: RMSE = 771.0442, MAD = 771.0238\n",
      "['TCGA']: mean RMSE = 537.7208, mean MAD = 537.4442\n",
      "\n",
      "Epoch 10/50, Loss: -2.1685\n",
      "Epoch 20/50, Loss: -1.1218\n",
      "Epoch 30/50, Loss: -2.6704\n",
      "Epoch 40/50, Loss: -3.0851\n",
      "Epoch 50/50, Loss: -0.6703\n",
      "Epoch 10/50, Loss: -0.2297\n",
      "Epoch 20/50, Loss: -1.1813\n",
      "Epoch 30/50, Loss: -2.8212\n",
      "Epoch 40/50, Loss: -1.6575\n",
      "Epoch 50/50, Loss: -2.3410\n",
      "Epoch 10/50, Loss: -0.8046\n",
      "Epoch 20/50, Loss: -2.0277\n",
      "Epoch 30/50, Loss: -2.2414\n",
      "Epoch 40/50, Loss: -1.1667\n",
      "Epoch 50/50, Loss: -1.7928\n",
      "  Fold 4: RMSE = 7.9050, MAD = 7.5916\n",
      "['TCGA']: mean RMSE = 405.2669, mean MAD = 404.9810\n",
      "\n",
      "Epoch 10/50, Loss: 0.1078\n",
      "Epoch 20/50, Loss: -0.3374\n",
      "Epoch 30/50, Loss: -1.8506\n",
      "Epoch 40/50, Loss: -3.2432\n",
      "Epoch 50/50, Loss: -3.7864\n",
      "Epoch 10/50, Loss: -0.1034\n",
      "Epoch 20/50, Loss: -2.2688\n",
      "Epoch 30/50, Loss: -2.2383\n",
      "Epoch 40/50, Loss: -0.4979\n",
      "Epoch 50/50, Loss: -3.7657\n",
      "Epoch 10/50, Loss: -0.0816\n",
      "Epoch 20/50, Loss: -1.7053\n",
      "Epoch 30/50, Loss: -0.9755\n",
      "Epoch 40/50, Loss: -0.7624\n",
      "Epoch 50/50, Loss: -2.1981\n",
      "  Fold 5: RMSE = 361.3753, MAD = 361.3643\n",
      "['TCGA']: mean RMSE = 396.4886, mean MAD = 396.2577\n",
      "\n",
      "Epoch 10/50, Loss: -0.3458\n",
      "Epoch 20/50, Loss: -1.2697\n",
      "Epoch 30/50, Loss: -2.5027\n",
      "Epoch 40/50, Loss: 2.2453\n",
      "Epoch 50/50, Loss: -2.9852\n",
      "Epoch 10/50, Loss: -0.5555\n",
      "Epoch 20/50, Loss: -0.4976\n",
      "Epoch 30/50, Loss: -0.4540\n",
      "Epoch 40/50, Loss: -1.1971\n",
      "Epoch 50/50, Loss: -0.4387\n",
      "Epoch 10/50, Loss: -1.7552\n",
      "Epoch 20/50, Loss: -2.0704\n",
      "Epoch 30/50, Loss: -1.3084\n",
      "Epoch 40/50, Loss: -0.8122\n",
      "Epoch 50/50, Loss: -3.3772\n",
      "  Fold 6: RMSE = 183.3416, MAD = 183.3150\n",
      "['TCGA']: mean RMSE = 360.9641, mean MAD = 360.7672\n",
      "\n",
      "Epoch 10/50, Loss: -2.1702\n",
      "Epoch 20/50, Loss: -2.0631\n",
      "Epoch 30/50, Loss: 0.7039\n",
      "Epoch 40/50, Loss: -1.3071\n",
      "Epoch 50/50, Loss: -3.7788\n",
      "Epoch 10/50, Loss: -1.2956\n",
      "Epoch 20/50, Loss: -2.0150\n",
      "Epoch 30/50, Loss: 0.7106\n",
      "Epoch 40/50, Loss: -1.2822\n",
      "Epoch 50/50, Loss: 0.3958\n",
      "Epoch 10/50, Loss: -1.3323\n",
      "Epoch 20/50, Loss: 0.1502\n",
      "Epoch 30/50, Loss: -0.5149\n",
      "Epoch 40/50, Loss: -3.6626\n",
      "Epoch 50/50, Loss: -1.4593\n",
      "  Fold 7: RMSE = 395.0608, MAD = 395.0515\n",
      "['TCGA']: mean RMSE = 365.8350, mean MAD = 365.6650\n",
      "\n",
      "  Fold 8: missing file — skipping.\n",
      "  Fold 9: missing file — skipping.\n",
      "  Fold 10: missing file — skipping.\n"
     ]
    }
   ],
   "source": [
    "dataset_name=[\"TCGA\"]\n",
    "rmses, mads = [], []\n",
    "for k in range(1, 11):\n",
    "        try:\n",
    "            base_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split\")\n",
    "            result_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/results_realdata\")\n",
    "            datasets = [\"TCGA\"] \n",
    "            dataset_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/TCGA\")\n",
    "            X_train = pd.read_csv(dataset_path / f\"X_train{k}.csv\").values.astype(np.float32)\n",
    "            y_train = pd.read_csv(dataset_path / f\"y_train{k}.csv\").values.astype(np.float32).flatten()\n",
    "            X_test = pd.read_csv(dataset_path / f\"X_test{k}.csv\").values.astype(np.float32)\n",
    "            y_test = pd.read_csv(dataset_path / f\"y_test{k}.csv\").values.astype(np.float32).flatten()\n",
    " \n",
    "            df = pd.read_csv(dataset_path / \"infocov.csv\")\n",
    "         \n",
    "\n",
    "# One-hot encode the only column\n",
    "            one_hot = pd.get_dummies(df[df.columns[0]])\n",
    "\n",
    "# Convert to NumPy\n",
    "            onehot_array = one_hot.to_numpy(dtype=np.float32)\n",
    "            sideinfo_array = onehot_array\n",
    "            mu= combined = np.concatenate([ y_test,y_train]).mean()\n",
    "            y_test=  y_test-mu\n",
    "            y_train=y_train-mu\n",
    "# Now pass sideinfo to your model:\n",
    "            beta_est = nash_mdn(X=X_train, y=y_train, sideinfo=sideinfo_array, maxit=2)\n",
    "\n",
    "            y_pred_test = X_test @ beta_est\n",
    "\n",
    "        # Metrics\n",
    "            rmse = np.sqrt(mean_squared_error(y_test, y_pred_test))\n",
    "            mad = mean_absolute_error(y_test, y_pred_test)\n",
    "            rmses.append(rmse)\n",
    "            mads.append(mad)\n",
    "            print(f\"  Fold {k}: RMSE = {rmse:.4f}, MAD = {mad:.4f}\")\n",
    "\n",
    "    # Save results\n",
    "            if rmses:\n",
    "                df = pd.DataFrame({'RMSE': rmses, 'MAD': mads})\n",
    "                df.to_csv(result_path / f\"{dataset_name}_nash_mdn.csv\", index=False)\n",
    "                print(f\"{dataset_name}: mean RMSE = {np.mean(rmses):.4f}, mean MAD = {np.mean(mads):.4f}\\n\")\n",
    "            else:\n",
    "                print(f\"{dataset_name}: no valid folds to evaluate.\\n\")\n",
    "\n",
    "# View result \n",
    "        except FileNotFoundError:\n",
    "            print(f\"  Fold {k}: missing file — skipping.\")\n",
    "            continue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "17d5b60e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     x\n",
      "0  309\n",
      "1  309\n",
      "2  266\n",
      "3  220\n",
      "4   32\n",
      "Columns: Index(['x'], dtype='object')\n"
     ]
    }
   ],
   "source": [
    "dataset_name=[\"TCGA\"]\n",
    "k=1\n",
    "\n",
    "\n",
    "base_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split\")\n",
    "result_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/results_realdata\")\n",
    "datasets = [\"TCGA\"]\n",
    "dataset_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/TCGA\")\n",
    "X_train = pd.read_csv(dataset_path / f\"X_train{k}.csv\").values.astype(np.float32)\n",
    "y_train = pd.read_csv(dataset_path / f\"y_train{k}.csv\").values.astype(np.float32).flatten()\n",
    "X_test = pd.read_csv(dataset_path / f\"X_test{k}.csv\").values.astype(np.float32)\n",
    "y_test = pd.read_csv(dataset_path / f\"y_test{k}.csv\").values.astype(np.float32).flatten()\n",
    "\n",
    "# ✅ FIXED: keep as DataFrame\n",
    "df = pd.read_csv(dataset_path / \"infocov.csv\")\n",
    "print(df.head())\n",
    "print(\"Columns:\", df.columns)\n",
    "\n",
    "# One-hot encode the only column\n",
    "one_hot = pd.get_dummies(df[df.columns[0]])\n",
    "\n",
    "# Convert to NumPy\n",
    "onehot_array = one_hot.to_numpy(dtype=np.float32)\n",
    "group_labels = one_hot.columns.to_list()\n",
    "\n",
    "onehot_array = one_hot.to_numpy(dtype=np.float32)\n",
    "sideinfo_array = onehot_array\n",
    " \n",
    "# Now pass sideinfo to your model:\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "# Initialize the scaler\n",
    "scaler = StandardScaler()\n",
    "X_train_scaled = scaler.fit_transform(X_train)\n",
    "\n",
    "# Use the same scaler to transform X_test\n",
    "X_test_scaled = scaler.transform(X_test)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4a12eecc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0., 0., 0., ..., 0., 0., 1.],\n",
       "       [0., 0., 0., ..., 0., 0., 1.],\n",
       "       [0., 0., 0., ..., 0., 0., 0.],\n",
       "       ...,\n",
       "       [0., 0., 0., ..., 0., 0., 1.],\n",
       "       [0., 0., 0., ..., 0., 0., 1.],\n",
       "       [0., 0., 0., ..., 0., 0., 1.]], dtype=float32)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "onehot_array"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "d30842ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/20,   Variance Loss: -524.0538\n",
      "Epoch 20/20,   Variance Loss: -524.0687\n",
      "Epoch 10/20,   Variance Loss: -1124.8631\n",
      "Epoch 20/20,   Variance Loss: -1125.0511\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[28], line 81\u001b[0m\n\u001b[0;32m     79\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m :\n\u001b[0;32m     80\u001b[0m     ash_input \u001b[38;5;241m=\u001b[39m drift_comp \u001b[38;5;241m*\u001b[39m betahat_arr \u001b[38;5;241m+\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m-\u001b[39m drift_comp) \u001b[38;5;241m*\u001b[39m result\u001b[38;5;241m.\u001b[39mpost_mean\n\u001b[1;32m---> 81\u001b[0m     result \u001b[38;5;241m=\u001b[39m\u001b[43mCash_posterior_means\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m \u001b[49m\u001b[43msideinfo\u001b[49m\u001b[43m \u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     82\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43mbetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m  \u001b[49m\u001b[43mash_input\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;66;43;03m#ash_input ,\u001b[39;49;00m\n\u001b[0;32m     83\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43msebetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfull_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mash_input\u001b[49m\u001b[43m,\u001b[49m\u001b[43msigma_0\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m/\u001b[39;49m\u001b[43msqn\u001b[49m\u001b[43m   \u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     84\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43mn_epochs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m20\u001b[39;49m\u001b[43m   \u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     85\u001b[0m     log_pi\u001b[38;5;241m=\u001b[39m result\u001b[38;5;241m.\u001b[39mpi_np\n",
      "File \u001b[1;32mc:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\\cash_solver.py:124\u001b[0m, in \u001b[0;36mCash_posterior_means\u001b[1;34m(X, betahat, sebetahat, n_epochs, n_layers, num_classes, hidden_dim, batch_size, lr, model_param, penalty)\u001b[0m\n\u001b[0;32m    121\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m inputs, targets, noise_std \u001b[38;5;129;01min\u001b[39;00m dataloader:\n\u001b[0;32m    123\u001b[0m     residuals \u001b[38;5;241m=\u001b[39mtargets\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mnumpy() \n\u001b[1;32m--> 124\u001b[0m     batch_loglik \u001b[38;5;241m=\u001b[39m \u001b[43mget_data_loglik_normal\u001b[49m\u001b[43m(\u001b[49m\u001b[43mbetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mresiduals\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    125\u001b[0m \u001b[43m                                      \u001b[49m\u001b[43msebetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mnoise_std\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    126\u001b[0m \u001b[43m                                      \u001b[49m\u001b[43mlocation\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mscale\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    127\u001b[0m \u001b[43m                                      \u001b[49m\u001b[43mscale\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mscale\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    128\u001b[0m     optimizer_cash\u001b[38;5;241m.\u001b[39mzero_grad()\n\u001b[0;32m    129\u001b[0m     outputs \u001b[38;5;241m=\u001b[39m model_cash(inputs)\n",
      "File \u001b[1;32mc:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\\distribution_operation.py:27\u001b[0m, in \u001b[0;36mget_data_loglik_normal\u001b[1;34m(betahat, sebetahat, location, scale)\u001b[0m\n\u001b[0;32m     25\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(location\u001b[38;5;241m.\u001b[39mshape)\u001b[38;5;241m==\u001b[39m\u001b[38;5;241m1\u001b[39m:\n\u001b[0;32m     26\u001b[0m   \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(betahat\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]):\n\u001b[1;32m---> 27\u001b[0m     out[i,] \u001b[38;5;241m=\u001b[39m\u001b[43mconvolved_logpdf_normal\u001b[49m\u001b[43m(\u001b[49m\u001b[43mbetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mbetahat\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     28\u001b[0m \u001b[43m                                     \u001b[49m\u001b[43msebetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43msebetahat\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[0;32m     29\u001b[0m \u001b[43m                                     \u001b[49m\u001b[43mlocation\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mlocation\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     30\u001b[0m \u001b[43m                                     \u001b[49m\u001b[43mscale\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mscale\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     31\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(location\u001b[38;5;241m.\u001b[39mshape)\u001b[38;5;241m==\u001b[39m\u001b[38;5;241m2\u001b[39m:\n\u001b[0;32m     32\u001b[0m   \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(betahat\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]):\n",
      "File \u001b[1;32mc:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\\distribution_operation.py:11\u001b[0m, in \u001b[0;36mconvolved_logpdf_normal\u001b[1;34m(betahat, sebetahat, location, scale)\u001b[0m\n\u001b[0;32m      8\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mconvolved_logpdf_normal\u001b[39m(  betahat,sebetahat, location, scale):\n\u001b[0;32m      9\u001b[0m   \u001b[38;5;66;03m# Calculate the standard deviation\u001b[39;00m\n\u001b[0;32m     10\u001b[0m   \u001b[38;5;66;03m#location ois wether a 1 d np with same length as scale \u001b[39;00m\n\u001b[1;32m---> 11\u001b[0m     sd \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39msqrt(\u001b[43msebetahat\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m2\u001b[39;49m \u001b[38;5;241m+\u001b[39m  scale\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m2\u001b[39m)\n\u001b[0;32m     13\u001b[0m     \u001b[38;5;66;03m# Calculate the log probability density\u001b[39;00m\n\u001b[0;32m     14\u001b[0m     logp \u001b[38;5;241m=\u001b[39m norm\u001b[38;5;241m.\u001b[39mlogpdf(betahat, loc\u001b[38;5;241m=\u001b[39m location, scale\u001b[38;5;241m=\u001b[39msd)\n",
      "File \u001b[1;32mc:\\Users\\willi\\anaconda3\\envs\\ml_env\\lib\\site-packages\\torch\\_tensor.py:39\u001b[0m, in \u001b[0;36m_handle_torch_function_and_wrap_type_error_to_not_implemented.<locals>.wrapped\u001b[1;34m(*args, **kwargs)\u001b[0m\n\u001b[0;32m     37\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m has_torch_function(args):\n\u001b[0;32m     38\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(wrapped, args, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)\n\u001b[1;32m---> 39\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m f(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)\n\u001b[0;32m     40\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[0;32m     41\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mNotImplemented\u001b[39m\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "y=y_train\n",
    "sideinfo= sideinfo_array\n",
    "maxit=10\n",
    "damping=0.99\n",
    "    # Standardize\n",
    "X=X_train_scaled\n",
    "y, ysd = col_scale(y.reshape(-1, 1))\n",
    "y = y.flatten()\n",
    "\n",
    "n, p = X.shape\n",
    "sqn = np.sqrt(n).astype(np.float32)\n",
    "\n",
    "    # Initialize via Lasso\n",
    "lasso = LassoCV(cv=5, max_iter=5000)\n",
    "lasso.fit(X, y)\n",
    "beta = lasso.coef_\n",
    "\n",
    "    # Initialize prior as None\n",
    "log_pi, scale, location = None, None, None\n",
    "td_beta = []\n",
    "pi0=0\n",
    "for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        for k in range(p):\n",
    "            r = y - X @ beta\n",
    "            beta_new = beta.copy()\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta_new[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k) / sqn, 1e-4)\n",
    "            if 0<1: \n",
    "\n",
    "                beta_k_new = betahat_k\n",
    "                beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "             \n",
    "            else :\n",
    "                print(o)\n",
    "                pm = posterior_mean_norm(\n",
    "                    betahat=np.array([betahat_k]),\n",
    "                    sebetahat=np.array([sebetahat_k]),\n",
    "                    log_pi=np.log( np.clip( result.pi_np[k, :], 1e-12, 1.0)),\n",
    "                    location=result.location[k, :],\n",
    "                    scale=result.scale[k, :]\n",
    "                    )\n",
    "             \n",
    "                beta_k_new = pm.post_mean[0]\n",
    "\n",
    "            r += xk * (beta_new[k]  - beta_k_new)\n",
    "            beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "            beta_new[k]=beta_k_new\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k) \n",
    "\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        avg_se = np.mean(sebetahat_list)\n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ betahat_arr ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )   \n",
    " \n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ beta ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )\n",
    "        denom = n + p * (1 - pi0)\n",
    "        sigma_0 = np.sqrt(max((res_sq_final + sigma_0_term) / denom, 1e-8)) / sqn\n",
    "\n",
    "        res_sq = np.sum((y - X @ betahat_arr) ** 2)\n",
    "        drift_term = np.dot(betahat_arr,  betahat_arr) / np.sqrt(n + p)\n",
    "        s = np.sqrt((res_sq + drift_term)) / sqn\n",
    "\n",
    "        # Update drift_comp\n",
    "        drift_comp =    (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "        if o<1: \n",
    "            # Update beta with ash\n",
    "            ash_input = betahat_arr   \n",
    "            result =Cash_posterior_means(X= sideinfo ,\n",
    "                                            betahat= betahat_arr ,\n",
    "                                            sebetahat=np.array(sebetahat_list) ,n_epochs=20  ) \n",
    "        else :\n",
    "            ash_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "            result =Cash_posterior_means(X= sideinfo ,\n",
    "                                          betahat=  ash_input, #ash_input ,\n",
    "                                          sebetahat= np.full_like(ash_input,sigma_0) /sqn   ,\n",
    "                                          n_epochs=20   )\n",
    "            log_pi= result.pi_np\n",
    "            #beta =   result.post_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "590aaae1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50,   Variance Loss: -524.0518\n",
      "Epoch 20/50,   Variance Loss: -524.0056\n",
      "Epoch 30/50,   Variance Loss: -524.1042\n",
      "Epoch 40/50,   Variance Loss: -524.1706\n",
      "Epoch 50/50,   Variance Loss: -524.1362\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\\cash_solver.py:159: RuntimeWarning: divide by zero encountered in log\n",
      "  log_pi=np.log(all_pi_values_np[i, :]),\n"
     ]
    }
   ],
   "source": [
    "result =Cash_posterior_means(X= sideinfo ,\n",
    "                                            betahat= betahat_arr ,\n",
    "                                            sebetahat=np.array(sebetahat_list) ,n_epochs=50  ) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "e763f2a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1c7e26cb700>]"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(betahat_arr )\n",
    "plt.plot(result.post_mean)\n",
    "plt.plot(lasso.coef_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "cfcfd121",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.2247384994149241\n",
      "0.16365185\n"
     ]
    },
    {
     "data": {
      "image/png": "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BHdCuru7+3NJWSmV39P27du54IILOPPMM3nkkUcwzaGzuXck/z4NdcOGDePMM89k9erVXH755aHHV69ezaWXXprBlUmusW2bm266iaeffpo//elPTJo0KdNLylkKRLJIY2MjjY2NzJo1i9GjR/POO+9w5513ctxxxw363ZBUNDc3c/755zN+/Hi+973v8f7774eeq6ioyODKss+2bdtob29n27Zt+P1+NmzYAMDxxx9PYWFhZheXIbfccgvz589n2rRpod20bdu2KccozL59+/jnP/8Z+n7Lli1s2LCB0tJSxo8fn8GVZY8bbriBxx57jGeffZZRo0aFdtmKi4sZPnx4hleXY2zJGn/961/tCy64wC4tLbXz8/PtiRMn2tddd539r3/9K9NLyyqPPPKIDTh+SaTPfOYzjr+nP/7xj5leWkb993//tz1hwgR72LBh9tSpU+0XXngh00vKKn/84x8d/735zGc+k+mlZY14/w165JFHMr20nKM+IiIiIpIxQ+dgXURERLKOAhERERHJGAUiIiIikjEKRERERCRjFIiIiIhIxigQERERkYxRICIiIiIZo0BEREREMkaBiIiIiGSMAhERERHJGAUiIiIikjEKRERERCRj/j9A8BgXddfReAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(X@result.post_mean, y)\n",
    "plt.scatter(X@lasso.coef_, y)\n",
    "print(np.sqrt(((X@result.post_mean - y )**2).mean()))\n",
    "print(np.sqrt(((X@lasso.coef_- y )**2).mean()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "84d9a9e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "tt ,oo= col_scale(y_test.reshape(-1, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "0868a941",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.28168141])"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "oo"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "034e5af9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0409785181536713"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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X31Vs2bN0ogRI+Tz+fTb3/621/cNw9CiRYs0YsQIDRw4UFdccYX++te/ujPYLBPrvXn22Wd19dVXq6ysTD6fT7W1ta6MM9uYvS8dHR268847dd5556moqEgjRozQl770Je3fv9+9AWeRWP/PLFq0SJ/85CdVVFSkoUOHavr06XrjjTfcGWwKEIjE8NWvflVr1qzRE088oe3bt+uqq67S9OnT9eGHH7o9tKzS1tam8ePHa/ny5RG//x//8R/6z//8Ty1fvlxbtmxRIBDQjBkzdPTo0RSPNPvEem/a2to0depU/ehHP0rxyLKb2fty/Phxbd26Vffcc4+2bt2qZ599Vu+++65mz57twkizT6z/Z8466ywtX75c27dv14YNG1RZWamrrrpK//jHP1I80hQxENXx48eN3Nxc46WXXur1/Pjx443vfve7Lo0Kkoznnnuu5+uuri4jEAgYP/rRj3qea29vN/x+v/Gzn/3MhRFmr77vTbj6+npDkrFt27aUjgnm70vI5s2bDUnG+++/n5pBwTAMa+9NS0uLIclYu3ZtagaVYqyImPjoo4/U2dmpwsLCXs8PHDhQGzZscGlU6Ku+vl6NjY266qqrep4rKCjQ5Zdfrtdff93FkQHpo6WlRT6fT0OGDHF7KAhz8uRJ/fznP5ff79f48ePdHo4jCERMFBcXa8qUKVqyZIn279+vzs5OrVq1Sm+88YYaGhrcHh5OaWxslCQNHz681/PDhw/v+R6A6Nrb23XXXXfppptuyohTXzPBSy+9pMGDB6uwsFDLli3TmjVrVFZW5vawHEEgEsMTTzwhwzB0+umnq6CgQP/1X/+lm266Sbm5uW4PDX34fL5eXxuG0e85AL11dHRo7ty56urq0kMPPeT2cHDKlVdeqdraWr3++uuaOXOmPv/5z+vgwYNuD8sRBCIxjBkzRq+88oqOHTumffv2afPmzero6NDo0aPdHhpOCQQCktRv9ePgwYP9VkkAfKyjo0Of//znVV9frzVr1rAa4iFFRUUaO3asJk+erMcee0wDBgzQY4895vawHEEgYlFRUZHKy8t1+PBh/f73v9ecOXPcHhJOGT16tAKBgNasWdPz3MmTJ/XKK6/okksucXFkgHeFgpD33ntPa9eu1bBhw9weEkwYhqFgMOj2MBwxwO0BeN3vf/97GYahs88+W7t27dK3vvUtnX322fryl7/s9tCyyrFjx7Rr166er+vr61VbW6vS0lKNHDlSd9xxh374wx9q3LhxGjdunH74wx9q0KBBuummm1wcdXaI9d40Nzdr7969PT0q3nnnHUndK1mh1Swkn9n7MmLECN1www3aunWrXnrpJXV2dvasKJaWlio/P9+tYWcFs/dm2LBhuvfeezV79myVl5fr0KFDeuihh/TBBx/oc5/7nIujdpC7RTve98wzzxhnnnmmkZ+fbwQCAeP22283jhw54vawss769esNSf0e//zP/2wYRncJ78KFC41AIGAUFBQYl112mbF9+3Z3B50lYr03K1eujPj9hQsXujruTGf2voRKqSM91q9f7/bQM57Ze3PixAnj+uuvN0aMGGHk5+cb5eXlxuzZs43Nmze7PWzH+AzDMFIQ7wAAAPRDjggAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHANgQgAAHDN/w/6vOGiVXaQkgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(  X_test@result.post_mean , tt)\n",
    "np.sqrt(((X_test_scaled@(result.post_mean )/oo  - tt /oo)**2).mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29d144b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.linear_model import LassoCV\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "def col_scale(X, with_mean=True, with_std=True):\n",
    "    \"\"\"Column-wise standardization.\"\"\"\n",
    "    scaler = StandardScaler(with_mean=with_mean, with_std=with_std)\n",
    "    X_scaled = scaler.fit_transform(X)\n",
    "    return X_scaled, scaler.scale_, scaler.mean_\n",
    "\n",
    "def nash_mdn(X, y, sideinfo, emdn_posterior_means, maxit=10, damping=0.99, eb_kwargs=None):\n",
    "    \"\"\"\n",
    "    Neural Adaptive Shrinkage with Mixture Density Network posterior.\n",
    "    \n",
    "    Args:\n",
    "        X: (n, p) design matrix\n",
    "        y: (n,) response vector\n",
    "        sideinfo: (p, d) side information for MDN prior\n",
    "        emdn_posterior_means: callable returning posterior means from MDN\n",
    "        maxit: maximum number of iterations\n",
    "        damping: damping factor for stability\n",
    "        eb_kwargs: additional args for emdn_posterior_means\n",
    "        \n",
    "    Returns:\n",
    "        Estimated beta (de-standardized)\n",
    "    \"\"\"\n",
    "    # Standardize X and y\n",
    "    X, csd, cmean = col_scale(X)\n",
    "    y, ysd, ymean = col_scale(y.reshape(-1, 1))\n",
    "    y = y.flatten()\n",
    "    n, p = X.shape\n",
    "    sqn = np.sqrt(n)\n",
    "\n",
    "    # Lasso initialization\n",
    "    lasso = LassoCV(cv=5, max_iter=5000).fit(X, y)\n",
    "    beta = lasso.coef_\n",
    "\n",
    "    # First iteration estimate\n",
    "    log_pi, scale, location = None, None, None\n",
    "    drift_comp = 0.5\n",
    "    sigma_0 = 1.0  # Will be updated\n",
    "    pi0 = 0.0\n",
    "\n",
    "    for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        r = y - X @ beta\n",
    "        beta_new = beta.copy()\n",
    "\n",
    "        for k in range(p):\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta_new[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k, ddof=1) / sqn, 1e-4)\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k)\n",
    "            r -= xk * (betahat_k - beta_new[k])\n",
    "            beta_new[k] = betahat_k\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        sebetahat_arr = np.array(sebetahat_list)\n",
    "\n",
    "        # Residual scale and drift update\n",
    "        res_sq = np.sum((y - X @ beta_new) ** 2)\n",
    "        drift_term = np.dot(betahat_arr, betahat_arr - beta_new) / np.sqrt(n + p)\n",
    "        s = np.sqrt((res_sq + drift_term)) / sqn\n",
    "        sigma_0 = np.sqrt((res_sq + np.sum((beta_new - betahat_arr) ** 2)) / (n + p * (1 - pi0))) / sqn\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "\n",
    "        # Drifted posterior input\n",
    "        if o == 0:\n",
    "            post_input = betahat_arr\n",
    "        else:\n",
    "            post_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "\n",
    "        # MDN posterior update\n",
    "        result = emdn_posterior_means(\n",
    "            X=sideinfo,\n",
    "            betahat=post_input,\n",
    "            sebetahat=np.full_like(post_input, sigma_0),\n",
    "            **(eb_kwargs or {})\n",
    "        )\n",
    "\n",
    "        # Posterior mean update with damping\n",
    "        beta = damping * result.post_mean + (1 - damping) * beta\n",
    "\n",
    "        # Optional: extract pi0 from MDN output\n",
    "        if hasattr(result, \"pi_np\"):\n",
    "            pi0 = result.pi_np[:, 0].mean() if result.pi_np.ndim == 2 else result.pi_np[0]\n",
    "\n",
    "    # Return de-standardized beta\n",
    "    return ysd * beta / csd\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "9b666aca",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.linear_model import LassoCV\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "def col_scale(X, with_mean=True, with_std=True):\n",
    "    \"\"\"Column-wise standardization.\"\"\"\n",
    "    scaler = StandardScaler(with_mean=with_mean, with_std=with_std)\n",
    "    X_scaled = scaler.fit_transform(X)\n",
    "    return X_scaled, scaler.scale_, scaler.mean_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dfe1e6d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def nash_noinfo_vectorized(X, y, maxit=100):\n",
    "    X, csd, cmean = col_scale(X)\n",
    "    y, ysd, ymean = col_scale(y.reshape(-1, 1))\n",
    "    y = y.flatten()\n",
    "\n",
    "    n, p = X.shape\n",
    "    sqn = np.sqrt(n)\n",
    "\n",
    "    # Initialize with Lasso\n",
    "    lasso = LassoCV(cv=10, max_iter=5000).fit(X, y)\n",
    "    beta = lasso.coef_\n",
    "\n",
    "    td_beta = []\n",
    "    drift_comp = 0.5\n",
    "\n",
    "    for o in range(maxit):\n",
    "        full_r = y - X @ beta\n",
    "        beta_matrix = np.tile(beta, (n, 1))\n",
    "        rj = full_r[:, None] + X * beta_matrix\n",
    "\n",
    "        beta_temp = np.sum(X * rj, axis=0) / n\n",
    "        centered_rj = rj - beta_temp\n",
    "        sd_temp = np.std(centered_rj, axis=0, ddof=1) / sqn\n",
    "\n",
    "        if o == 0:\n",
    "            beta = beta_temp.copy()\n",
    "            sigma_0 = np.mean(sd_temp)\n",
    "\n",
    "        b_post = drift_comp * beta_temp + (1 - drift_comp) * beta\n",
    "        resid = y - X @ b_post\n",
    "        s = np.sqrt((np.sum(resid**2) + np.sum((beta_temp - b_post) * b_post)) / np.sqrt(n + p)) / sqn\n",
    "\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "        ash_input = drift_comp * beta_temp + (1 - drift_comp) * beta\n",
    "\n",
    "        beta, beta2, pi0 = call_r_ash(ash_input, np.full(p, sd_temp ))\n",
    "\n",
    "        resid2 = y - X @ beta\n",
    "        sigma_0 = np.sqrt((np.sum(resid2**2) + np.sum((b_post - beta) * beta)) / (n + p * (1 - pi0))) / sqn\n",
    "\n",
    "        td_beta.append(ysd * beta / csd)\n",
    "\n",
    "    print(\"Final residual variance:\", np.var(y - X @ beta))\n",
    "    print({\"s\": s, \"mean_sd\": np.mean(sd_temp), \"sigma_0\": sigma_0, \"drift_comp\": drift_comp})\n",
    "    return ysd * beta / csd\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "265c2427",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50, Loss: 1.1956\n",
      "Epoch 20/50, Loss: -2.4792\n",
      "Epoch 30/50, Loss: -0.7214\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[51], line 51\u001b[0m\n\u001b[0;32m     48\u001b[0m     post_input \u001b[38;5;241m=\u001b[39m drift_comp \u001b[38;5;241m*\u001b[39m betahat_arr \u001b[38;5;241m+\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m-\u001b[39m drift_comp) \u001b[38;5;241m*\u001b[39m result\u001b[38;5;241m.\u001b[39mpost_mean\n\u001b[0;32m     50\u001b[0m \u001b[38;5;66;03m# MDN posterior update\u001b[39;00m\n\u001b[1;32m---> 51\u001b[0m result \u001b[38;5;241m=\u001b[39m \u001b[43memdn_posterior_means\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m     52\u001b[0m \u001b[43m    \u001b[49m\u001b[43mX\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43msideinfo\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     53\u001b[0m \u001b[43m    \u001b[49m\u001b[43mbetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mpost_input\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m     54\u001b[0m \u001b[43m    \u001b[49m\u001b[43msebetahat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfull_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpost_input\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msd_temp\u001b[49m\u001b[43m \u001b[49m\u001b[43m)\u001b[49m\u001b[43m  \u001b[49m\n\u001b[0;32m     55\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     57\u001b[0m \u001b[38;5;66;03m# Posterior mean update with damping\u001b[39;00m\n\u001b[0;32m     58\u001b[0m beta \u001b[38;5;241m=\u001b[39m damping \u001b[38;5;241m*\u001b[39m result\u001b[38;5;241m.\u001b[39mpost_mean \u001b[38;5;241m+\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m-\u001b[39m damping) \u001b[38;5;241m*\u001b[39m beta\n",
      "File \u001b[1;32mc:\\Document\\Serieux\\Travail\\python_work\\cEBNM_torch\\py\\empirical_mdn.py:103\u001b[0m, in \u001b[0;36memdn_posterior_means\u001b[1;34m(X, betahat, sebetahat, n_epochs, n_layers, n_gaussians, hidden_dim, batch_size, lr, model_param)\u001b[0m\n\u001b[0;32m    101\u001b[0m model\u001b[38;5;241m.\u001b[39mtrain()\n\u001b[0;32m    102\u001b[0m running_loss \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0.0\u001b[39m\n\u001b[1;32m--> 103\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m inputs, targets, noise_std \u001b[38;5;129;01min\u001b[39;00m dataloader:\n\u001b[0;32m    104\u001b[0m     optimizer\u001b[38;5;241m.\u001b[39mzero_grad()\n\u001b[0;32m    105\u001b[0m     pi, mu, log_sigma \u001b[38;5;241m=\u001b[39m model(inputs)\n",
      "File \u001b[1;32mc:\\Users\\willi\\anaconda3\\envs\\ml_env\\lib\\site-packages\\torch\\utils\\data\\dataloader.py:701\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    698\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[0;32m    699\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[0;32m    700\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[1;32m--> 701\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_next_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    702\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[0;32m    703\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m (\n\u001b[0;32m    704\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable\n\u001b[0;32m    705\u001b[0m     \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[0;32m    706\u001b[0m     \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called\n\u001b[0;32m    707\u001b[0m ):\n",
      "File \u001b[1;32mc:\\Users\\willi\\anaconda3\\envs\\ml_env\\lib\\site-packages\\torch\\utils\\data\\dataloader.py:757\u001b[0m, in \u001b[0;36m_SingleProcessDataLoaderIter._next_data\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    755\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_next_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[0;32m    756\u001b[0m     index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_index()  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[1;32m--> 757\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_dataset_fetcher\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfetch\u001b[49m\u001b[43m(\u001b[49m\u001b[43mindex\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[0;32m    758\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory:\n\u001b[0;32m    759\u001b[0m         data \u001b[38;5;241m=\u001b[39m _utils\u001b[38;5;241m.\u001b[39mpin_memory\u001b[38;5;241m.\u001b[39mpin_memory(data, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory_device)\n",
      "File \u001b[1;32mc:\\Users\\willi\\anaconda3\\envs\\ml_env\\lib\\site-packages\\torch\\utils\\data\\_utils\\fetch.py:52\u001b[0m, in \u001b[0;36m_MapDatasetFetcher.fetch\u001b[1;34m(self, possibly_batched_index)\u001b[0m\n\u001b[0;32m     50\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[0;32m     51\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m---> 52\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[0;32m     53\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m     54\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "File \u001b[1;32mc:\\Users\\willi\\anaconda3\\envs\\ml_env\\lib\\site-packages\\torch\\utils\\data\\_utils\\fetch.py:52\u001b[0m, in \u001b[0;36m<listcomp>\u001b[1;34m(.0)\u001b[0m\n\u001b[0;32m     50\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[0;32m     51\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m---> 52\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[0;32m     53\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m     54\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "maxit=2\n",
    "    # Standardize X and y\n",
    "X, csd, cmean = col_scale(X)\n",
    "y, ysd, ymean = col_scale(y.reshape(-1, 1))\n",
    "y = y.flatten()\n",
    "n, p = X.shape\n",
    "sqn = np.sqrt(n)\n",
    "\n",
    "    # Lasso initialization\n",
    "lasso = LassoCV(cv=5, max_iter=5000).fit(X, y)\n",
    "beta = lasso.coef_\n",
    "\n",
    "    # First iteration estimate\n",
    "log_pi, scale, location = None, None, None\n",
    "drift_comp = 0.5\n",
    "sigma_0 = 1.0  # Will be updated\n",
    "pi0 = 0.0\n",
    "\n",
    "for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        r = y - X @ beta\n",
    "        beta_new = beta.copy()\n",
    "\n",
    "        for k in range(p):\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta_new[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k, ddof=1) / sqn, 1e-4)\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k)\n",
    "            r -= xk * (betahat_k - beta_new[k])\n",
    "            beta_new[k] = betahat_k\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        sebetahat_arr = np.array(sebetahat_list)\n",
    "\n",
    "        # Residual scale and drift update\n",
    "        res_sq = np.sum((y - X @ beta_new) ** 2)\n",
    "        drift_term = np.dot(betahat_arr, betahat_arr - beta_new) / np.sqrt(n + p)\n",
    "        s = np.sqrt((res_sq + drift_term)) / sqn\n",
    "        sigma_0 = np.sqrt((res_sq + np.sum((beta_new - betahat_arr) ** 2)) / (n + p * (1 - pi0))) / sqn\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "        sd_temp = sebetahat_arr.mean() / sqn\n",
    "        # Drifted posterior input\n",
    "        if o == 0:\n",
    "            post_input = betahat_arr\n",
    "        else:\n",
    "            post_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "\n",
    "        # MDN posterior update\n",
    "        result = emdn_posterior_means(\n",
    "            X=sideinfo,\n",
    "            betahat=post_input,\n",
    "            sebetahat=np.full_like(post_input, sd_temp )  \n",
    "        )\n",
    "\n",
    "        # Posterior mean update with damping\n",
    "        beta = damping * result.post_mean + (1 - damping) * beta\n",
    "\n",
    "        # Optional: extract pi0 from MDN output\n",
    "        if hasattr(result, \"pi_np\"):\n",
    "            pi0 = result.pi_np[:, 0].mean() if result.pi_np.ndim == 2 else result.pi_np[0]\n",
    "\n",
    "    # Return de-standardized beta\n",
    " \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "fdb1e83d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50, Loss: -0.2138\n",
      "Epoch 20/50, Loss: 0.2851\n",
      "Epoch 30/50, Loss: -1.8157\n",
      "Epoch 40/50, Loss: -3.1090\n",
      "Epoch 50/50, Loss: -0.5162\n"
     ]
    }
   ],
   "source": [
    "result = emdn_posterior_means(\n",
    "            X=sideinfo,\n",
    "            betahat=post_input,\n",
    "            sebetahat=np.full_like(post_input, sd_temp )  \n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "0e462bf7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1c78bd40730>]"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot( result.location[:,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "f2edc2a7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1c78b815d80>]"
      ]
     },
     "execution_count": 109,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(result.post_mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "18ed259b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6.918259143829347"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(  (X_test@result.post_mean -(X_test@result.post_mean).mean()) , (y_test-y_test.mean()))\n",
    "np.sqrt(((  (X_test@result.post_mean -(X_test@result.post_mean).mean()) -y_test.mean())  )**2).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "e2c3f81a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def nash_mdn(X, y, sideinfo=None, maxit=4, damping=0.99, eb_kwargs=None):\n",
    "    k=0 \n",
    "    X = X.astype(np.float32)\n",
    "    y = y.astype(np.float32).flatten()\n",
    "    X, csd = col_scale(X)\n",
    "    y, ysd = col_scale(y.reshape(-1, 1))\n",
    "    y = y.flatten()\n",
    "\n",
    "    n, p = X.shape\n",
    "    sqn = np.sqrt(n).astype(np.float32)\n",
    "    beta = LassoCV(cv=5, max_iter=5000).fit(X, y).coef_\n",
    "\n",
    "    log_pi, scale, location = None, None, None\n",
    "    td_beta = []\n",
    "    model_param = None\n",
    "    pi0=0\n",
    "    \n",
    "    for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        for k in range(p):\n",
    "            r = y - X @ beta\n",
    "            beta_new = beta.copy()\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta_new[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k) / sqn, 1e-4)\n",
    "            if 0<1: \n",
    "\n",
    "                beta_k_new = betahat_k\n",
    "                beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "             \n",
    "            else :\n",
    "                print(o)\n",
    "                pm = posterior_mean_norm(\n",
    "                    betahat=np.array([betahat_k]),\n",
    "                    sebetahat=np.array([sebetahat_k]),\n",
    "                    log_pi=np.log( np.clip( result.pi_np[k, :], 1e-12, 1.0)),\n",
    "                    location=result.location[k, :],\n",
    "                    scale=result.scale[k, :]\n",
    "                    )\n",
    "             \n",
    "                beta_k_new = pm.post_mean[0]\n",
    "\n",
    "            r += xk * (beta_new[k]  - beta_k_new)\n",
    "            beta_k_new = damping * beta_k_new + (1 - damping) * beta_new[k]\n",
    "            beta_new[k]=beta_k_new\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k) \n",
    "\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        avg_se = np.mean(sebetahat_list)\n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ beta ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )   \n",
    " \n",
    "        beta = beta_new.copy()\n",
    "        res_sq_final = np.sum((y - X @ beta ) ** 2)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr )\n",
    "        denom = n + p * (1 - pi0)\n",
    "        sigma_0 = np.sqrt(max((res_sq_final + sigma_0_term) / denom, 1e-8)) / sqn\n",
    "\n",
    "        res_sq = np.sum((y - X @ betahat_arr) ** 2)\n",
    "        drift_term = np.dot(betahat_arr,  betahat_arr) / np.sqrt(n + p)\n",
    "        s = np.sqrt((res_sq + drift_term)) / sqn\n",
    "\n",
    "        # Update drift_comp\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "        if o<1: \n",
    "            # Update beta with ash\n",
    "            ash_input = betahat_arr   \n",
    "            result =emdn_posterior_means(X= sideinfo,\n",
    "                                            betahat= ash_input,\n",
    "                                            sebetahat=np.array(sebetahat_list)   )\n",
    "            emdn_posterior_means(X= sideinfo,\n",
    "                                          betahat= ash_input,\n",
    "                                          sebetahat= np.full_like(ash_input,sigma_0), **(eb_kwargs or {}))\n",
    "        else :\n",
    "            ash_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "            result =emdn_posterior_means(X= sideinfo,\n",
    "                                          betahat= ash_input,\n",
    "                                          sebetahat=np.full_like(ash_input,sigma_0)   )\n",
    "            log_pi= result.pi_np\n",
    "            beta =   result.post_mean\n",
    "\n",
    "\n",
    "  \n",
    "    out=   ysd * result.post_mean/ csd\n",
    "    return out\n",
    " \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "dabab76f",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def col_scale(X, with_mean=True, with_std=True):\n",
    "    scaler = StandardScaler(with_mean=with_mean, with_std=with_std)\n",
    "    X_scaled = scaler.fit_transform(X)\n",
    "    return X_scaled, scaler.scale_\n",
    "\n",
    "\n",
    "def call_r_ash_fit_all_with_postmean(beta, sigma):\n",
    "    \"\"\"\n",
    "    Calls R's ash function and returns:\n",
    "    - log mixture weights\n",
    "    - mixture standard deviations\n",
    "    - posterior mean of beta\n",
    "    \"\"\"\n",
    "    from rpy2.rinterface_lib.sexp import NULLType\n",
    "\n",
    "    sebetahat = np.full_like(beta, sigma)\n",
    "    ash_obj = ashr.ash(betahat=beta, sebetahat=sebetahat, mixcompdist=\"normal\")\n",
    "\n",
    "    fitted_g = ash_obj.rx2(\"fitted_g\")\n",
    "    pi_r = np.array(fitted_g.rx2(\"pi\"), dtype=np.float32)\n",
    "    scale_r = np.array(fitted_g.rx2(\"sd\"), dtype=np.float32)\n",
    "\n",
    "    posterior_mean_r = ash_obj.rx2(\"result\").rx2(\"PosteriorMean\")\n",
    "    if isinstance(posterior_mean_r, NULLType):\n",
    "        raise RuntimeError(\"R ash() returned NULL for result$PosteriorMean\")\n",
    "    posterior_mean = np.array(posterior_mean_r, dtype=np.float32)\n",
    "\n",
    "    log_pi = np.log(np.clip(pi_r, 1e-12, 1.0))\n",
    "    return log_pi, scale_r, posterior_mean\n",
    "\n",
    "\n",
    "def get_data_loglik_normal(betahat, sebetahat, location, scale):\n",
    "    var = sebetahat[:, None] ** 2 + scale[None, :] ** 2\n",
    "    return -0.5 * (np.log(2 * np.pi * var) + (betahat[:, None] - location) ** 2 / var)\n",
    "\n",
    "\n",
    "def apply_log_sum_exp(data_loglik, log_pi):\n",
    "    combined_loglik = data_loglik + log_pi\n",
    "    return combined_loglik - logsumexp(combined_loglik, axis=1)[:, None]\n",
    "\n",
    "\n",
    "class PosteriorMeanNorm:\n",
    "    def __init__(self, post_mean, post_mean2, post_sd):\n",
    "        self.post_mean = post_mean\n",
    "        self.post_mean2 = post_mean2\n",
    "        self.post_sd = post_sd\n",
    "\n",
    "\n",
    "def posterior_mean_norm(betahat, sebetahat, log_pi, scale, location=None):\n",
    "    if location is None:\n",
    "        location = np.zeros_like(scale)\n",
    "\n",
    "    data_loglik = get_data_loglik_normal(betahat, sebetahat, location, scale)\n",
    "    log_post_assignment = apply_log_sum_exp(data_loglik, log_pi)\n",
    "\n",
    "    n, K = betahat.shape[0], scale.shape[0]\n",
    "    var = np.zeros((n, K))\n",
    "\n",
    "    if scale[0] == 0:\n",
    "        for i in range(n):\n",
    "            var[i, :] = np.concatenate(([0], 1 / ((1 / sebetahat[i]**2) + (1 / scale[1:]**2))))\n",
    "    else:\n",
    "        for i in range(n):\n",
    "            var[i, :] = 1 / ((1 / sebetahat[i]**2) + (1 / scale**2))\n",
    "\n",
    "    temp = np.zeros((n, K))\n",
    "    for i in range(n):\n",
    "        temp[i, :] = (var[i, :] / sebetahat[i]**2) * betahat[i] + location * (1 - var[i, :] / sebetahat[i]**2)\n",
    "\n",
    "    post_mean = np.sum(np.exp(log_post_assignment) * temp, axis=1)\n",
    "    post_mean2 = np.sum(np.exp(log_post_assignment) * (var + temp**2), axis=1)\n",
    "    post_sd = np.sqrt(post_mean2 - post_mean**2)\n",
    "    return PosteriorMeanNorm(post_mean, post_mean2, post_sd)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "1fd6fd5e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50, Loss: -0.5917\n",
      "Epoch 20/50, Loss: -1.0131\n",
      "Epoch 30/50, Loss: -2.5789\n",
      "Epoch 40/50, Loss: -1.0748\n",
      "Epoch 50/50, Loss: -1.0967\n",
      "Epoch 10/50, Loss: 0.7220\n",
      "Epoch 20/50, Loss: -1.4069\n",
      "Epoch 30/50, Loss: -1.5993\n",
      "Epoch 40/50, Loss: -1.1915\n",
      "Epoch 50/50, Loss: -3.6560\n",
      "Epoch 10/50, Loss: -2.8376\n",
      "Epoch 20/50, Loss: -1.0421\n",
      "Epoch 30/50, Loss: -0.7526\n",
      "Epoch 40/50, Loss: -2.5841\n",
      "Epoch 50/50, Loss: -1.8400\n"
     ]
    }
   ],
   "source": [
    "beta_mdn =  nash_mdn(X=X_train,y=y_train, sideinfo=sideinfo_array,maxit=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "f2487c46",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_scaled = scaler.fit_transform(X_train)\n",
    " \n",
    "y, ysd = col_scale(y_train.reshape(-1, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "5494e0b2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.2893138])"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ysd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "08cccccb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.2512114872369255"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sqrt(np.mean( (X_scaled@beta_mdn/9- y)**2 ))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "25173a1b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.        , 0.83974611],\n",
       "       [0.83974611, 1.        ]])"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.corrcoef(X_test@beta_mdn, y_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "83f77ffc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.        , 0.84936762],\n",
       "       [0.84936762, 1.        ]])"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.corrcoef(X_test@lasso.coef_ , y_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "3810fd5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x1c78b8148e0>"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiIAAAGdCAYAAAAvwBgXAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAWmdJREFUeJzt3Xt4VOW5P/zvJEyOJJOEFCYomAjYEoMiKAdBKwgWRUXt9i2ednEr3Sj4U9y7RVQKlO1G33Zv6usBD9tiWwRtPaGieYWiIghFgYgxHiBy2pBgc2AGQjIJmfn9EVaYmazDs9asNWvNzPdzXVyXJDOzVjIj6173c9/34wqFQiEQERER2SDN7hMgIiKi1MVAhIiIiGzDQISIiIhsw0CEiIiIbMNAhIiIiGzDQISIiIhsw0CEiIiIbMNAhIiIiGzTy+4TUBMMBnH48GHk5eXB5XLZfTpEREQkIBQK4dixY+jfvz/S0tRzHo4ORA4fPowBAwbYfRpERERkwMGDB3HmmWeqPsbRgUheXh6Arh8kPz/f5rMhIiIiEX6/HwMGDOi+jqtxdCAiLcfk5+czECEiIkowImUVLFYlIiIi2zAQISIiItswECEiIiLbMBAhIiIi2zAQISIiItswECEiIiLbMBAhIiIi2zAQISIiIts4eqAZERERiesMhrBtbxO+P9aGvnlZGFVWhPQ0Z+/VxkCEiIgoCVRW12Hx2zWo87V1f63Ek4WF15RjSkWJjWemjkszRERECa6yug53rdwREYQAQL2vDXet3IHK6jqbzkwbAxEiIqIYdAZD2FLbiDVVh7ClthGdwVDcj7/47RrIHVX62uK3a+J+XqK4NENERGSQE5ZDtu1t6pEJCRcCUOdrw7a9TRg7qE9czkkPZkSIiIgMcMpyyPfHlIMQI4+LNwYiREREOjlpOaRvXpapj4s3BiJEREQ66VkOsYpUm1Lva0VRbgaUmnRd6FouGlVWZNm5xII1IkRERDrZvRwiV5siRwpOFl5T7th5IgxEiIgIQGIOw7KLncshUm2KyKKPNwHmiDAQISIiR3R/6GF30DSqrAglnizU+9pkAwIXuoIAs5dD1GpTJEW5biy4+lx48xMjmGQgQkSU4pTusKXuj+W3jnBUMOKEoCk9zYWF15TjrpU74AIifndWLodo1aYAQFNLB7z5WY5s1ZXDYlUiohTmpO4PEUots3W+NsxauQOPr9+N9pPBuAwYm1JRguW3joDXE7n84vVkmRa8RQ9Lq/e1Cj3Pqa26cpgRISJKYYk0DEtkWWLZ+m/x+/XfRjzGymzJlIoSTC73WrJMJJf5KcrNEHquU1t15TAQISJKYXZ3f+ghsiwBIO5LTOlpLtODNKXlsuaWdtXnWVWbYiUuzRARpbBEGoZlNBhy4hKTGpHlMjmJ0Korh4EIEVEKk7o/EmEYVizBUDwGjJlFNPNTlOuO+LuZtSnxxKUZIqIUZlf3hxFaLbMinLDEpEX0HKUW3USf+8KMCBFRirO6+yO688Po8ogUNMXCCUtMWkTPUWrRnTb8DIwd1CchgxCAGREiIoJ13R9mz/yQgqZFb9Wg3i+e3UikIk67hqXZhRkRIiICcLr7w6w7bKWZH1IXS2V1naHXnVJRgs0PTMTcSUOEHu+0JSYt4Zmf6LON/lnMyjbZyRUKhRx71n6/Hx6PBz6fD/n5+XafDhERCeoMhjD+sQ2KRZfSXf2meRNjCg7kMi5pLiD8euzkUfVqtLJJTpgwq0TP9ZuBCBERmSJ8/5eGYwEsWfuV5nNWzxxjaAZH+LGKe2cCIaChJYC+eVkYeVYhtu9vTvgiTkB5Tx2lOSPST2l394ye6zdrRIiIKGai29JHM9LFopYJkIKaWAaM2b2hXji5YWlac0Zc6JqZMrncmxABGAMRIiISJneRXldTL7wtfTS9XSxWb9Dn5OUOSSKN5RfBQISIiITIXaS9+VloO9mpOwgx0vlhdSYgUXYhTqSx/CLYNUNElASs7p5Q7IDxt+HoiQ5dr2W0i0VPJkCvRNqFOJHG8ouwNCOydOlSvP766/j666+RnZ2Niy++GI899hh++MMfWnlYIqKUYvVygsiut3p4DZ6blZmARFruSLY5I5ZmRD766CPMnj0bW7duxbp163Dy5ElcccUVaGlpsfKwREQpw6pZHeFE9z5Rs2DqUDw+fThWzxyDTfMmGgqQrMwEJNJyh545I4nA0oxIZWVlxN9XrFiBvn37Yvv27bj00kutPDQRUdKLV/dELBdf6e58xriymC+MVmYCEm25Q5ow26Nmx2GFtSLiWqzq8/kAAEVF8h+SQCCAQCDQ/Xe/3x+X8yIiSkTxWk4wevE1++5cbYM+idFjJeJyh1Vj+eMtbsWqoVAI999/P8aPH4+KigrZxyxduhQej6f7z4ABA+J1ekRECSdeywnSRVrp8uYCUJjjhjc/M+LrhbluPHXzBabenUuZAE+Ou8f35L4mKj3NhQVTyxWDEMCZyx1mj+W3Q9wCkTlz5mDXrl1YvXq14mPmz58Pn8/X/efgwYPxOj0iooQTr+UEkZqEpTcMw6+vPhdFuRnd32tq6cCStV9F1KmY1d0j16njO9FhuC6msroOS9bWyH7PrF2ISV5cRrzfc889ePPNN7Fx40aUlZUJP48j3omIusgNEgOA8Y9t0FxOiHU/F4ladw4AzZHjAGLu7rFiDxul+SGSp2++AFed11/otaiLY/aaCYVCuOeee/DGG2/gww8/xJAhYjslShiIEBGJBQBAZM2EVXuOqAVEasGBJ8cN34mOmPdG2VLbiJue36r5ONE9bOK1OV+q0XP9tnRpZvbs2Vi5ciVWrVqFvLw81NfXo76+Hq2trVYelogoaWi15wJdF3GvJ3L5xarlBLmaBJGi2aMyQYj0PUB8WJjZdTFWDkkjMZZ2zSxfvhwAcNlll0V8fcWKFZgxY4aVhyYiSnii7bmb5k20tXsi1mJYke4eKROz+8hxodcUrYtJpPkh4Zy0MV+sLA1E4lB+QkSUtPS259o18dOs2RpKF3s9O/vqbbNNtPkhQGJszKcHN70jInKoRLlb15rBIapvXlaPO/3mlnbMXiW+s28IwPSLBgofUzp3rRoRrcAmXhmKRNmYTw8GIkREDpUod+sig8bUSBf75pZAj8LRNJf+11u2/lu8/OkBoQxBepoL155fgmc37pX9fgjAVRVdy15KwUW8MhTxmqQbb9x9l4jIoUQGiZU4ZNqnNGgsumhWi/SzXXt+CWav2tkjM2F0s1vRvXYqq+vwnEIQInlh8z7c9PxWjH9sQ4/Xi8deP5JkLaxlIEJE5FCJtrnZlIoSbJo3EQumDhV+jteThaduHoG3Pq8zbXdfQKwbR++uwtHBhVaGQuv4eiXKUp1eDESIiBxMKdPg1Gmf6WkuzBhXhhKNzEhBthsv3Tkam+ZNRGFuRsy7+8rRyhDo3VU4OriId4YiUZbq9GKNCBGRwyXa5mZadRcA8LOLzsS4wcUArL+DV3p9I8cNDy5En1/vN+fnS8SN+UQwI0JElAASaXOzzmAIb32uXhvx1ud13UsWVt/BK71+LMeVAkIRS9750pRakURbqhPFQISIiEwlsuQRvmShVZQL9LzwitAq5hU5rhIpKyXy/KYW45vxRUu0pToRXJohIiJVemdk6C2qFGn/NdISDERmCOR+Dum4el5XWv7Q27ZsVmttoi3VaWEgQkREitRmZChdDItzM4VeO3xpQ7rTX/RWje6aimvO8+LTfc2o9we6v+aNmuOh9nP84tIyPP/xXs1WYbngRjrvB9+oRlNLu+JzRcbY6yEt1SUDBiJERCSbLVhXU684xXPWyh0oyHHj6ImO7q+XeLJw7fklWFOlvgShXlSpv9X1s/1HsfFXE7F9f7NshkBtGuksHdmQ6OBGMqWiBK3tnZj7l881XyPRWmvjgYEIEVGKk8sWePOz0HayU3WZJDwIAbru+NU6ZQDlokqlYEFEna8N2/c3y2YIRGZ9qJ1rUW4GHp46FF5Pturyh9eTLXSuidZaGw8sViUiSmGKk0H9bT0CDTN4snv1KKrUO1hMzvtfymdh9M4KCRcC0NjSDq8nW7NTKZGm4DoNAxEiohTVGQzhgde/MHWiqZajrSd7fC2WYEHy2o5DshNMzVgKEXmNZG2tjQcGIkREKerJDbstyXpoeeD1L7B5d0N34GBGsOBvO9ndDtwZDGFLbSPWVB1Cw7GAxjO1iS6nJFprbfjvaUtto2mj6PVijQgRkYPEazv5zmAIKzbvM/11RRw90YFbXvg7inLd+I9pFabVTayvqYevtb1HvUuay9jmeUYmlSZKa228dgwW4QqFQvaEQAL8fj88Hg98Ph/y8/PtPh0iIkvF8+KwpbYRNz2/1dTXNGrmJWV4Z1ddzMszuZnpOBGQL7CVEz77I3oOiBQ2KGUy4hUwWkGpMFjrZ9ZDz/WbGREiIgdQazG9a+UO3RcHrQulk9pIn/94L2Ze0jXLIxYtgU7V70dnRqR2XAA9u4ZUAkAnZRP00uoicsG8wWuiGIgQEdnM7IuDyIXSaW2kr3x6ELdffBb+uv1/cVwjoDAqGAIWTB2K4rzMHsGZ6HKK2QFjvOnZMTheA9NYrEpEZDMzt5NXbMc9daGU9juJZZ8VK/jbTmLFJ/txPNCJ3pm9kJORHvH9PrkZphynOC9TduNAkU0FO4MhLHpLfSbJ4rdrYi76tLKIVO/4/XhgRoSIyGZmXRz0ZlZE9kkR2UPFbC2BkwgBmDtpCEqLc9E3LwsjzyrEj3/7Qcx1JLFkgp7csFt1/LwZ2QSrl31Ef/54ZsyYESEiMpGRu1mzLg56MytK7aYlniw8c+sIPHPrCPTLj/2ClNlL36VGCppe/vQgrj6vP8YO6oOMXmlYeE05XFCe01GQ49Y9UEz0/aqsrsOy9buFzl8kYJQ7pmg2KxZOHLzGjAgRkUmM3s1KF4d6X5ts9kG0jdRIZkWr3TQv041bXvi70OvKnfdTN48AEMLdq3bqeq5cdkFpY7zwolO5DI/aWHmR90vKNIlSCxiVjrlg6lAsWfuV5UWkapkwuwavMSNCRGSCWO5mtaZyhgBcWdEVLLSfDCrewRvNrKjVRzS0GB8IFgJQmJuBq87rj3+9tMzQa8gHV5GXa2kKhZ6BYnreLz2TX9WyCWrHvHvVTqFs1tbaRqHzUOO0wWvMiBARxciMrhfp4hB9t+xyAaEQ8IfN+/CHzft6tKCG38FLmRWti2azzHb1Su2+sdYKbN7zD4wqK8L8q8px/pmFeHhNNZpkjq8k/PhKHStH/IGIjhWtDhi975eewk2lbEIsm++Fm71qBx796bCYgwUnDV7jQDMiohiJDgebM2Ewxg0uVv0HXwoI1tfU4wWByafSq9w36RyUFufgu3+04PG/qdcylHiysGnexO5zUFui+PE5fTH015Wa56F1PClYkn6+en8bHn7zC9XZH70z0/GbayvQfKIdBTkZeOTdGjS1yI+kl5avwn8uJZt3NwgtN62eOQZjB/URfvy9lw/B3MnnyH7PzAFyLpgzdMxKHGhGRBRHonfMT36wB09+sEe1biQ9zYVRZUW4/y9VQq8p3UkuW/+t4NlG1l5UVtdh1sodPR4jLVH8dMQZwq+rJHrGxqiyImz9rhFat8HHA524/6+fCx1DtGOlsroOD7z2hdBrdr+vgkkCtRoes9th4z10zEoMRIiIYqR3+UJr+JUZu9Fq+f5YW/fuu3KkJYp3v6iP+Vjhyx3BILBkbY1lP5/aBV9paUeJ9L42HBerk1F7nJntsHYMHbMSi1WJiGKkdziY1vCreAyT6puXhSc37FHdfTcE4ESHOVNOpYvn3at6FmuaSemCr1ajIaco1416fxu21DaiuHdmTMcGxNtmn755BAqy3ULHc9KY/lgwI0JEFCPR4WDh1O5qrRwmJdVSjDyrEHet3G7ZceJNrsW5ux7F14odB5p1BUBNLR2Y+0oVAMCbn4mCHDd8JzoMt1eLts1OqSiBJ8eNW/5HuybFaWP6jWIgQkRkAqWuFy1yd7Vac0ViEQJw7fkl2L6/GUdblbMhiSi8Y0WuANeoI/6A5i69IrM3lD4j0RvsjTm7j+b73yc3AyPPKjTy4zgOu2aIiEwk3YVv3vMPPPlBrebjpc6MaFI9A2D+iHUXgH8ZVyrUlZObma65q63dCrLdES2temtBRLgAeHLcyOqVHjFMzcj4da2dkQGx99/JO/7quX4zECEiskBnMITxj23QnJaq1m4qd1cfPUfEqLysdBxr0w4wppzbDx/vaXB0MDJ7wiCMH/yD7qWR8Y9tsKwO5aU7RiPt1GwRq2dvaGV1pKM6sZWXgQgRkQMo3dXquYCEz91oOh5AQbYbR1s7UJiTgQVvVccUIEjD0pJFiScL0y8aILwnjBGPTx+OacNjb2kW1X4yiDFL15syPyWeOEeEiJKGSBrbqZRqAvKyeuGGEWfAk52BzmBI9edJT3PB19qO/7fy6x4Dx24dPRDPbtxr+PycHITkZfXCsbaTup5T72uzNAgB4l8gun1/s2IQAiRHKy8DESJyLKu3RI+HKRUlCAYRMdrc33YSL36yHy9+sl/z51Gqd6j3teG5jXvxr5eWYU3VYdT7je8JE29qnUXSHf6/Tz4H//bqLl2vaySuum54f7xZdVjosfHelRYwtpFhouEcESJyJK1NyR5fv1tz63YnqKyuw+xVOxT3V6lT2RRPZH+Stz6vw8ZfTcTqmWPwL+NKkZfl/PtLtSAE6OpA6V+YY+k5SHM7bhw5QPg50y8aaN0JKTC6kWEicf4nlohSjsgFOHykuVOzJKJDtEKQH9mtNWFVSstv398MX2s7VmzeZ3qHTTx5o/aksaqFWbLwmnKMGaTdKitZtv5bvPzpgbh+1rRauUVmmDgdMyJE5Dh6R5zLbd3uBHp+DmmdP5xour3e16praqiTFOW6sexnw7F65hhsmjex+wIvDQAzau6kc1Dikc8SlIRtdx9+HJHKo3h/1tTOT88MEydjIEJEpukMhrCltjHmJRO9691aI9PtovfniH78voYTQs9ramm3fG8aqzS1dKDvqRHq7+w6HPG5kYp9C3PERp4Dp5dc5kwcjAVTy1GUmxHx/aJcNxZMHRqR0ZCO41UIXMIpfdbM+uzLUTo/b1hAlci4NENEpjCzsNTIercTuwf0/hzhj6+srsPvNXbUldLyhTkZqo9zutmrdkRMeS3IduP2cWWYM3EwplSU4ItDPjwlMBxOsvCacqyrqcfsVT2LfJtbOjB71U4sT3P1CEYml3tPDaNrwJMf7FF8/ejPWjyKqsPPLxE7yNRYmhHZuHEjrrnmGvTv3x8ulwtvvvmmlYcjIptoFZbqTWPr3UQunJO6B/T8HOEdGXpqSxZMHYqdB5sNn2O6A65j0aPmj7Z2YNn6bzHyP9ahsrpO+HOQm5GO5beOwORyr2aNUXhGQ8pmvLOrq3tm0A9yhY73/bE20z/7atLTXBg7qA+mDT8DYwf1SYogBLA4I9LS0oLzzz8ft99+O376059aeSgisolWYam0/Xt0IaYaI5vISZzUPRD+c6hxoasj451dh9E3LwvBUEhoqeXq80qwZO1XMS3LdDpnJauHoyc6MGvlDkwd5hV6/DO3jsQl5/wAW2obhYp8t+1tgq+1vUc2I3o5R0lxbib+/dXPTf3spyJLA5Err7wSV155pZWHICKbiXZ26F0y0buJnFO7B7R+jsIcN0KI7AIS3Qb+nV3OKs61ytov6jUfU5DjxsWDiwGIZ8XW1dTLdho1K7RaS6TPGlyw5LOfalgjQkQxsXLgUvS6+L6GFixbvzumHVDtEP5zSKPai3IzcKDphOwk0GTbFTcuQsCTG/agtDgHDcfEhru9WXVYdflGTvhnreG42HGctFzoRI4KRAKBAAKB02+s3++38WyISITVA5ekdXHJD715mtuo20VtHH30zyFtikfmkOpKJGqbA7oAFOa6FYfMhSvKdUeMWA//rG2pbRQ6NyctFzqRowKRpUuXYvHixXafBhHpEO+BS07tHlDrnJA7X72zUkgftSAEAK4ffgZe2LxP83UWXH0uvPlZsp+1VBg2Fg+OCkTmz5+P+++/v/vvfr8fAwaIj98lovhTKyy1askkOrtgN7X9YGat3IHemb1wPHB6A7cSTxaGluTF9yRTVHRmRMpoeLIzhAIRb36W4mfNjs9+MnJUIJKZmYnMzEy7T4OIdFIqyHTKkomVRMbRhwchQFcBI7Mh8REMdbU4F+dlRmQ0REbI98nNwMizClVfP5U/+2axNBA5fvw49uw5PRRm7969qKqqQlFREQYOjP/mQURkHacsmajVaViBSyzOV5yXiWnDz4j4mkiLeGNLO3782w80AwqnfPYTlSsUClnWRf7hhx9iwoQJPb7+85//HC+++KLm8/1+PzweD3w+H/Lz8y04QyJKJvGYcBltTdUh3PtylSWvTafpnScT7qU7RmPckGLZ78l9ZqKPCyApRqnHk57rt6WTVS+77DKEQqEef0SCECIiPeI54TIcOyLi497Lhxh/skpiYkpFCT765QQU5crPbnHqPkbJhJveEVHCE6nTULuQxLJhWSzj6EmbtIndPZcPwTO3jlDcUVeN1ryP7fubI1p0o4UPJiPzOapYlYjIiFimu8a6nBPLOHpSF915Ej0Ybsf+Jvx56wHN19HKWlk5lI+0MSNCRAnP6IXErOWcKRUl+MWlZXAxLWIquW3updbt6y84A4uurVDNRknZFK05HlYP5SN1zIgQUcIzciExc7O+yuo6PLdxL7MhJuiTm4GHpw6F15Ot2Xli1hwPDiazFzMiRJTwRpUVoSBHeaM4uTtjPcs5atpPBvHgG1+kbBCSk5Fu6us1trTD68kW3uZemuPhjaodkcumKJECGqBnXSsHk1mPGREiSnjraupx9IR6sWH0hcSMuoDK6jo8+Ea1aqFjsps76Rw88u5Xpr6m3loMM+Z4cDCZfRiIEFFCk5ZY1BTmuDHxR/2wpbax+0JV3FtsirPcsk9nMIQnN+yJ2GQt3kaVFuLLOj9aAp22nUNuZjpuHXMW/rB5r+qEUr1FvLuPHMeW2kZdwYQZY/85mMwelg40ixUHmhGRli21jbjp+a2ajyvMcaM5LGvizc9E28kgfCc6VOsCNs2bGHEhenfXYTz0ZnXEa6Wyolw3fjriTDz/8d4e35N+a7+4tMxQDU2JJwsLppajMDeDgUGC0XP9ZkaEiBLa+pp6ocdFBw5H/AHVO3gA3XUDUiZlfU093t4ldrxU0dTSgec/3ovMXmkInAxGfM+T48ajNwzDlIoSXDCwUHWCqZw6XxvuXrUj4mtWT8ql+GMgQkQJq7K6TmgHVTlqd+dSXQAAjH9sA/eSERAdhACALyz4C1/2eP7jWnzwzT9gJB8vtVZz5HryYNcMESUkkdoQI+ZOGoJN8yYCgOyMEdInfKJtepoLzS3t2PC1sSAE4Mj1ZMRAhIgSkhW73roAvPzpQdUZIyQuugX63V2HMWf1DvUnGXhdSmxcmiGihGTFuG3pAvfnLfuYCTHR98faUFldh7tX7TT9dSnxMRAhooTQGQxFtFWKtt8asb/phGWvnYqKe2fi3//6uemvy5HryYGBCBHZKjrAiG7PlGZ2rNi8F0dbI9tvczPS0dJu/hyNs4pyTH/NVCS1QCME0zNM3vxMjlxPEgxEiMg2cjvfFuW6cf3wMzCp3IvmlgAefLNadmpqvV99a3cjpAvnbWNL8T+b1Id0kbrwFuiGFvPfq5tGDeQ8kSTBQISIImhlKMwi7XwbfaFvaunAC5v3GW7LlURP8yzxZGH6RQPhb22Xfe3wC2dGrzTFzdSoJ092L7hcroiA0ZPjxu0Xl3W37JqttDjX9NckezAQIaJuchkKKwZIxaMrJQRgwdShKOqdiabjARTlZnTv6HpRWZHmniJTKkrwi0vL8PzHeyNaTdNcgMsFdPYcm5GS5k46B3MmDgYAPLlhN1Zs3oejrR04eqIDy9Z/i5c/PYAFU4eq7m5rhFQfEq/AmazDQISIAChnKKwYIGVF662cw0db8T+b9soGVpvmTZS9gEkXtvU19bKZk2AIKZUi8WT3wqSh/bD+q+/hC6vRiQ5QK6vr8Pv1u2U/P7NX7ewe825GhknaSTlegTNZi3vNEBE6gyHVCaJK+64YtabqEO59uSrm1zFCOnu5wEruwpbqZl5ShoemlqtmHkQ/PwumlmPJ2th+vy50vXcAZANntfeX4od7zRCRpvALS8OxgOrFIXyAVKw7nALxabtMc53KXkQJoetitfjtGkwu93ZfTJUyQqnutR3/iweuHKq6u61Whkv6/BTmZnRnoup9rViy9is0t7Qr7/njQsSymJTtmFzuxfjHNsg+T+n9JediIEKUgoze+Zs1QKq5pV0xUDCL2mtLF8at3zUizeXqvigyCOmpqaVDMwAV/Vx8f6wtIqDJzkiXLQiWQoenbroAhbmZPbIwW2ob4xo4k7UYiBClmFju/M3IZFRW12H2KmszD6NKC7FtX7Pm42a/tCNiNgnJiw40egyXyxUbLhf9+ZlSUYLlt47QLBzWOh/R8yZnYiBCFAdOqew32q0irfHHOkAqXnu4XCgYiDAIERMeQMhl07z5WSjIccN3okP2vVX7/ITvyiv6/4doQMzJq4mBgQiRxZxU2W+kWyV8vkaswVO8umVccKEo142mFgYasSoJCyCUsmlH/KfbcpWWWdQ+P2r1J3JGlRWptgObFThTfHD3XSILSf9wR198pZbYyuq6uJ6PkVS115OFp26+AJ7sDKypOoQttY2Gt1+PV6r8qQ9rGYSYwIXTAYRaNksqEC3McaNffuQyjdeTZXoHS3qaCwuvKe8+x+hzBswJnCk+mBEhsojIP9zxruwXTVUvmDoUxXmZ6JuXheaW9h4tl0YzOk5IlRfkuGVHxlOkolw3/vP6Yd3vsUhnTPOJDrx052ikuVyWL0MarS8h52EgQmQR0ZbGeFb2i6a0Z4wrQ3qaS7Gw1OiQM63jW8EFoCg3Aw9PHQqvJxvBYAi3vPD3OB09cf3mmoqI91Y0m9VwPIBpw8/o8XUr6qSM1JeQ83BphsgiTqzs15PS1sroAF0ZHT3LNFrHdwH410vLkJsh9k9T78x03P3jQaqPCQFobGmH15ONsYP6YMygPijx2J+ZcbpH3vsq4r2NpUC0sroO4x/bgJue34p7X67CTc9vxfjHNpiyNCnVl0wbfgbGDurDICQBMRAhsohTK/ullLY36mIcvZavJ6MjqjMYgic7A7ePK0Vhbobs8c8/swCtHWIbuXScDGLFJ3uFHisFfOlpLiyYOlT4nFNVna8NW2sbu/8uZbOULvMuRBa2SpxWJ0XOw6UZIos4ubJfJKVd7zc3oyPXPVSU68a08/vjzMIcFOVm4Jv641i2/lvhnyPQGQI6xTIy4QFfoeDci1Q3e9UOPPrTrjoRKZulNoAsukDUiXVS5DwMRIgsYuQf7nhSa5msrK7Dkne+FHodkYyOUttnU0sHVnyyX+g4RskFfBx0JeZoawdmrdyBZ05lyvQWiDqxToqch4EIkYUSsbJfdPKqaEYnXkPMlIQATL9oYMTX9jW02HMyCeqB17/ozlroKRDVUyfllKF/FH8MRIgslkiV/aJBg56MTryGmKlZtv5bvPzpge4N01ZvO2Dr+SSaoyc6MO/VXXjsn85DeppLeACZaP3TvoaWHrv32jX0j+LPFQqF7LpR0aRnG2Eiit2W2kbc9PxWzcf1yc3AI9dXCF0kfvP2l/jD5n0mnJ05/mnEGXh1xyG7TyMhefOzsOha8eCgMxjC+Mc2qNZJFeS40Swz10UKb80ehkbxoef6za4ZIuommkqfftEAtHYE8cLH3+GNHf+rOG21MxjCm1WHzT7NmDAIMa7er6/TRaRdXOlO2GiLOCUeLs0QUTfRVPpTH9b2+JpcKn3b3iY0tbSbdn7kDHo6XdTqpKZfNFC1S4rFrKmBgQgRdYtl8mmdzLRVdqckHyPBgVKd1Du7xLJl/BwlNy7NECWBzmAIW2obY96UTi2VLiKEyFS6E/aWIWvoDQ7kJqA6degfxRczIkQJTm5QmNwyiWh7pFIqXVT43fLIswqR5gK4xJ98Yg0OOoMhBEMhFGS7cbRVfhNCO4f+UfwwECFKYEozP6I3pZMLVrz5Wbhp1ECUFuf0CEyiU+m7jxzHkx/sET4v6W55+/5mBiFJxozgQO7zKHccwN6hfxQfDESIEpTo+OxgEPI76PrbIgoFo7Mo4bMittQ26gpEpLtlru3bI3qSr5lCiC04EB2Y5+Shf2SuuNSIPP300ygrK0NWVhZGjhyJjz/+OB6HJUpqouOzH15TLXRRqvO1YdbKHXh8/e4eNSZaG56FkzY+6wyG0HAsIPAMMkuWOw1/vn0UvvmPK/HSnaNRkO22+5QiiAzMK8hx46U7RmPTvIkMQlKE5YHIK6+8gvvuuw8PPfQQdu7ciUsuuQRXXnklDhzgZEOiWIhmG/S2zy5b/y3GPfq3iFkR4UWsalwAFkwtx5Mb9mDkknVYsvYrXcem2LR1BNGrVxoyeqUhzeVSrL2IhZRpM1IQLTJl9+iJDqSdmt5KqcHyQOS///u/cccdd+DOO+/E0KFD8fvf/x4DBgzA8uXLrT40UVKzspOg3h/AXaeyI1InzuRyL5bfOgIlHvnjlniy8ItLy/Dgm19g2fpvLbkIkjYpQLVqWSy8fVcvPXvPUOqwtEakvb0d27dvxwMPPBDx9SuuuAKffPKJlYcmSnpaMz9cAApz3WhqMRYQhADZGpJN8yZi294m1Pvb0HQ8gKLcDHg92WhuCeDuVTsNHYvMIwWoVre8GgkW2K5LciwNRBoaGtDZ2Yl+/fpFfL1fv36or6/v8fhAIIBA4PSast/vt/L0iBKatFxy18odPYoTpaT2f0yrwJK1X5my6Vx0J044aU8RsldRrhv1/jZsqW3EyLMKDQ+nE6EULKi1iYsEz2zXTT1x6ZpxuSLX+kKhUI+vAcDSpUuxePHieJwSUVJQG58tdRykpbkwa+WOmI8V3okTPd7bjh12czLS0dbRyfbgME0tHZj7ShWArgzWteeX4LmNe03tolELFrRm2ogEz2zXTT2W1ogUFxcjPT29R/bj+++/75ElAYD58+fD5/N1/zl48KCVp0eUFKZUlGDTvIlYPXMMHp8+HKtnjonoOJhSUYK5k84x5Vhy9QGdwRA272kw5fX1ONHeiT/OGIXrhveP+7ETQZ2vDc9u3Iup55WgX745Sx1qwYLUlhsdkEqZNKn4WQqevVG1Rl5PFnfaTVGWZkQyMjIwcuRIrFu3Dtdff33319etW4dp06b1eHxmZiYyMzOtPCWipBQ+80POnImDsXrbftT7zWmnleoDRAZTWWnd10cw7AyP43b4jYfCnF64bvgZWPN5nWpn1Du76tAvLwNzJw1BaXEuGo4FhLuZoqfiKs32EJ1pI2XSlPaeYSYkNVm+NHP//ffjtttuw4UXXoixY8fiueeew4EDBzBr1iyrD01Ep6SnubDo2nNx16klmljT9H3zsoQHU1npT1v223h0e2X26oWCnEyh9uwjx9rx+/W7sfzWEZgxrgz/s2mvau1IQbYbT90yAheVFmH7/mbNYEF0pk34RnlawTOlDssDkZ/97GdobGzEb37zG9TV1aGiogLvvvsuzjrrLKsPTURhYt1DBjhdHzDyrEL8+Lcf6ApCCnPcCKFrTgTF7kjUZFwRUlZCq07j0Z8Ow7jBxQAgFCywLZdiEZdi1bvvvht33313PA5FRCp67iFzDE9+UCv03PD6gO37m3UFM1efV4KbLhqIW174u4GzJjl6M1HhWQmRImc92JZLseBeM0QppuceMmKBSPhFak3VIeHjudC1+d3lP+pr5HTJZFJWwsw6DbblUiwYiBClsFFlRfDmZ6Her5zdKMhx46mbRmDMoD7dFyk9d7bSnbjeUfNkjfD3zqw6DbblUizisukdETnTupp6tJ3slP2e69SfR28YhnFDiiMuIno2wZMU9c7U/RwyjwunNyS0AttyyShmRIhSlFbXS0GOG0tvGCZ7AQm/Axblzc9SvGsma1mdlZCmqQZOBvG7G88HQkBDS4BtuSSEgQhRChLZjj2zVxoml3sVvy/dAS9660vV+STh9QHpaa6YO3dIP6NFqCLUpqmyPZdEuEKhkGNvTPx+PzweD3w+H/Lz8+0+HaKksaW2ETc9v1XzcatnjtG8mHQGQ3hywx7ZVlLpPvipm0egMDejuyhy+IAC/Oe7Nfjz1gNGTp9USL/z+yadg9LiHEuzEkpZNelIXJJJXXqu38yIEKUgs+Y+SCn50uIczJ00BKu3HYjIjnhP7XeyZG3kHbPLBTj3FiixWZn9CKd3miqREgYiRCkifFfUhmNio97VumPkUvLe/CzMDbsTb24JYPaqnT0uVgxC5MkNfSvKdaOpRXsI3JwJgzFucHHM2Q+13XPDGZmmSiSHgQhRCpALGqL3EQmnNfdBKSVff2ra59xJ5+CKci/GPfY3Q0WpJZ4sXH2eF89/vM/AsxNTUa4bW+dPQnqaKyIQkKbYas3omDv5nJgzD1q754bjNFUyC9t3iZKc0q6oakEIoNxhIVLoumz9txj660qhO/loC6YOxUe/nIC3P6/T/dxE1tTSge37m7tne0wbfgbGDuqDjF5pWHhNOQD0aH02sxtGdPdcCaepklkYiBAlsfaTQTz4RrVq0BB9/dKa+6CVko9VcV4mtu9vNm2n4ESilD0wMqOjMxjCltpGrKk6hC21jehUijyhXe8BdNV7hL+G1iwZq+eWUPLg0gxRkqqsrsODb3yhmZUIhrqyEMV5mUIdFlan2vvmZaVsOl8te6BnJLueJRbA+O65nKZKZmBGhCgJSWl20aWR4rzM7qUAtQtHZzCEj79tMOs0eyjIdmNUWRH2NZyw7BhOpJQ9iM5qAIhYtlEKQvQssQDG6z04TZXMwIwIkUVEuw+sOK5WDUc0kXX8yuo6PPD6FxEdHWa7fVwpAGD1tuSaL1KQ7cbRVvnfm1L2QG9WAzDeUhtLvYeZm+dRamIgQmQBIxcRs+ip4RDdFbWyug6zdIxzN6Iwx405E4dg294m1U34EtFlP/wBAKCt4yS27TsasQGg3NwPxa6kU1kNpWyD0ZbaWHfPNWvzPEpNDESITGb0IqKHWrZFb32F1jq+dJdttY7OIP5zbQ2yM5Lvn6U3qw53/3dBdi/MnTQEpcW5stmDWAaF6Vliif4MLZhajtmrWO9B8Zd8/8cT2SiWi4joUs67u+rw8JrqiLvqEk8WFkwdisLcTOw+clzoXPvkZuCR6ys0gyKru2QkxwOdeGHzPsuPY7ejrSexbP1uPHPrCNksQiyDwkSXWPY1nMD4xzb0yNj94tIyvPV5XeSQujhl8ih1MRAhMpHRi4joUs7Sd2vw7Ma9PV63zteGu1ftFD5PF4DF15wrdHFJ1Q4Wq81/fRdaO4Lw5hvLaMk9TmSJxZPjxu/XfyubsXtu4148dfMFKMzNZL0HxQ27ZohMZOQiItrl8O6uw7JBiBEhAHNe3onfvP2l5oyJfQ0tphyTIjWfOIm5r1Thpue3YvxjG7rf51gKR6WWWkB++Jn0LqvNC1my9iuMKisS6qIiMgMDESITiV5EintnYkttI97YeQgPvvGF5iCp9pNBPLym2rTzlPxh874eF8JwncFQ0nWwOFF40BnroDC1ltq5k4aodj2FZ+yI4oVLM0QmEkmNF+S48W9/qRKaHCpdGP68ZZ+hcemilAppuzpYUm/CabxJn5UH3/gCE3/UL+ZBYUotte/sOqz4nHBcjqN4YkaEyEQiqfHmEx26L+77m6wd8BWefdm8u6F7gFa9r9XS41KkppYOjFn6NwCIeVBY9J416Wku7g9DjsSMCJHJpNR4dPGp15OF1o5OQwPBzirKMfMUZUnZl1te+Hv313pn8p+IeGtqae/OTm2aN9HUQWGxzgshsgL/lSGygFxqPBgMRVzkRUgXhtvGluL5j7+L+zLJ8cDJuB6PTpPavM0cFMb9YciJuDRDpFP4/h+b9zRELGWEd59Ep8YbWvQFEeEXhoxeabhp1EATfwpyMiuLRrk/DDkNMyJEOsjN+winNsZd77p79CCp0uJc/SdMCc2qolHuD0NOwkCESJDS6PZwamPcRdbni3Iz8PDUofB6sntcGFhA6HwuF5DtTsOJ9mCPr4fC3vToZRElVr7n3B+GnIKBCJEA0R1t1ca4i6zPq41c1wpkyDpppwIJrd/7UzeNwE8qvNha24gt3zUA6LrYX1RahO37m7uzD8MHFGDcYxsixvSHY9EopRIGIkQC9Oy3Iq3vv7h5L4rzMiPS3kodNdnudFw1zIuJP+qn+LpqgUwsinIzEAwG4Ws9yQBHgVT6o/R7L8hx49EbhnUHkeOGFGPckOKIx0RnH/7z+grcdWpHYxaNUipzhUIhx/7b4/f74fF44PP5kJ+fb/fpUApbU3UI975cZfj50bUjncEQ7n15J9buqou4CKW5gJmXlGH+VeWKr6VVp6KXmUFNMpvwox/g67pjEb/3ghw3br+4DHMmDjYUNIjuMUSUaPRcvxmIEAnYUtuIm57favj50iVKqh1R2rxO8q+Xqgcj4Tv1fu8P4JF3vzJ8biQmP6sXPnt4csQSixkFnqK7LhMlEj3Xby7NEAmItT5Des4Dr32BbHc6ntPYvO75j/fi3674ETJ6yXfYhxcadgZD+MPmvabXjvTO7MU5ImH8bSexfX+z6QWeLBqlVMc5IkQC1Ea363G0tQM/X/GpZsAQDAF/3rIvrucWLRWCkKJct67H62mnDZ83o7XDMVEqYyBCKcnIRUJpEJRV9OwvE+9zU5KbmR6X4xTm6AsglEwbfoaux4u201ZW12H8Yxtw0/Nbce/LVao7HBOlOi7NUFJSW3ePpUAwfBDU+zX1ePGTfbCqykprf5non3Fyubf73NbV1OMPm/dZc2Iy0lzAJUOK8dTNIzF52UeWthjPnXQOfnHp2Th3YSViTTKsqRLbjRbo+oyItNMqzZtRmzFDlMoYiFDSUQs0AMR8kUhPc8HX2o4VFl7o01zAbWNLFb+vFUyNHdQH/tYOvLrjkGXnGC4YAj76tgHDFv3/qDgjH3W+NtO7ccJ/vi21jTEFIS4AhbluxTkecq49v0S1iLQzGMLW2kY88NoXsj+32owZolTGQISSitbdqCfHHfNFQhpuZqWZl5QpFqqK3nHn2LBzbgjAF4f8AHpOE435tU+9WGcwhM17/mH4daR3dnRZH7xXXS/8vOc27kVOhhulxTlCWTY54XvIsECVqAsDEUoaatNPpa8dPdGh+HzRi4Se4WZ6ac0RaT8ZxINvVAsFU1pLO6KMBhRm12Ye8Qcwa+UOFOS4Vd/HcPddPgR/2ro/IvNRcCoY1ROEAF2/32Xrv+3+u1aWTY1Ve8gQJSIGIpQ0zAoQtC4S9X7zLiIlniz8y7hSHGxuxVlFObhtbGmPTIhUC7K+ph5/2X4Qx9o6FV8vPJi6efRZWLLW+HwRF4B++Zn4fy4cgP9vwx7Dr2MWkWBS4kJXwPHypwcigpDczHQ0CwYxWup9bd2Bkd6Yi/sGEZ3GQISShll3mWoXicrqOix550tTjgNAs0DW6BTV74+1oergUcPnJdV3tJ0MOiII0UM6d7mAoyWgHMTppScwknAPGaKeGIhQ0oj1LlPrIiGy+64ecyedEzHyPbrLZ11NveHj9c3Liikwyz01zEzPRdYpPNlunAwGcdzEoMMM3EOGSB4DEXIsvaOvtaafSun65hMdirvfKl0kRHfflXiyesHXpjwQzJufiTkTBwOQz3p48zPRdjJoKAgpyHEjGAyhODfTwLO7JPIws6OtzgyevNxDhkiWpYHII488grVr16KqqgoZGRk4evSolYejJGJk1ofa7rRSaDHj4jL4W9vxRtUhNLWcvmBpXSRE60/65GbgkesrAEB1Z9VF156L9DSXcgeMP6B5LCVHT3Tglhf+Dm9+Fgpy3PCd6OCmdja77/IhuOfyIcyEEMmwdLJqe3s7brzxRtx1111WHoaSjHRxjr7wS+2patMplSaMFuS44clxY9n6b/HC5n1oaulAUW4G/mVcKVbPHINN8yaq3qmKLnNcOcwLT3YGJpd7Zc/D68nqbq/Vm2XR64i/DUcZhFjKBcCTrX0/98pnB60/GaIEZWlGZPHixQCAF1980crDkI3M3jlUqwVXZNbH5HIv8rLc2FLbCCCE9DQXHv9bz4LL5pauoWQi5yy6zLFy6wGs3HqgO3uzad5Exd+PlW3AwOnfV0GOG8FQCL7WxF1uscucCYPgTk/DsvW7FbNs/zKuDMvW71Z9Hc4OIVLmqBqRQCCAQOB0Strv99t4NqQlllHpSrQuzlqzPuTOSSnGEA1sKqvrsOgtfQPMpOzNUzdfgEKFICYesySk7pGHrhqKR9413sqbaqTC5bmTf4j0NBd+6M3rWcdz6rMeOBkUek3ODiGS56hAZOnSpd1ZFHI2q/bTEP3HWu5xSuekNlhLJLAx0rkiPX7O6p0Rxw8P1OI5S6K4d4ZqIa/T9cvLgMuVhiN+689frnA5fI+h6OxWV+ZNG2eHEMnTXSOyaNEiuFwu1T+fffaZoZOZP38+fD5f95+DB7mu6kQiE0wXv11jaNtz0X+sox8Xa72FXGBjRg1H9K8gvM5F6vKJhx0HmjHl3H4JGYQAQKAzhGnDuwJbM8s9C7J7wZsfmbEKr+MJl57mwthBfTBt+BkYO6hPd5AivY9K5+WC+IZ5RKlId0Zkzpw5mD59uupjSktLDZ1MZmYmMjONtxxSfMS6fKJGpAVXbtZHrPUWcgGQFTUc0ctBC68px6xT3TVW+vPWA5Yfw0pHT3Tg2Y178a+XluGtz+tMe19uH3c25kwcHFOdk0i3llpbuJk1VkSJSHcgUlxcjOLiYivOhRJELMsnWoz+o250/V1tiJlVa/rhgdqUihI8ffMFmL16p6kbxBnRO7MXHr2+Ao+897WlRbSxeOWz/8W2Byfh071NmL1qR8wzQ0qLc7ozHbGQurWU6kjklimtqLEiSkSW1ogcOHAATU1NOHDgADo7O1FVVQUAGDx4MHr37m3loclCRpdPRBn5R93IsbTuVq1e05cCnavO648Z+5uxYvM+S4+n5XjgJAp7Z3Z3+qyrqccfbD6naEdPdGD5h7W4d9IQPPrTYbKzWvQw8z1WqyOJZlWNFVEisjQQ+fWvf40//vGP3X+/4IILAAAffPABLrvsMisPTRYyunyih9Y/6tEp7ZFnFWoWY6a5Ims2tIaY6ZnUakT4RfCKcq/tgQgAbKltxLjBxRg7qA/GDuqDUWVFhva6UVPiycK155f0WGIR3VV3xSd7MWfiYMWAtcSThQVTy7FkbY2ln1E5ItkVM1rUiZKJpYHIiy++yBkiSSiWNXG9xxFt0ZUubs9t3Kt4Tk/eNAKFuRnC6/EiP+cj1w3Dg29+EfPGZ1LQY/+SSOTlUQoIn9ywW3NWhpY5EwZj3ODi7t/7r6YMjQgmt37XiMf/pn2Moyc6uuuP1ALWtDRY/hk1wsoaK6JEZOlkVUpeShNMlToOzKI2dfW5jXvxi0vLFM/pqvNKZLse1Gj9nIW5GbqDEKDnRVAKeuy+/x17tnz918ufxtbBluYC/s/lQyJ+7+FdKKPKivCKjmOE1+8odbPY9RnVYmWNFVEictQcEUosetbEzSCS0n7r8zp89MsJ2L6/2bRzUvs511Qd0vVaastBUypK8NTNIzBn9Q7V2SdWKchxY4zMHbgZ3UPBELB9f3PEHX748lrDsQDq/eLHEK3tiPdnVITVNVZEiYaBCMXEjI4DUaIp7egLnhmUfk7Ri8WcCYMwbvAPNC+ChbkZtgQhAPDoDcNkz82sO/Pw15FbXhOldyZHPD+jIuJRY0WUSLg0QwnDiSltrWFWQNeOvP/n8nOEloPW1dSbe4IGdAZD2FLbiDVVh7CltlF4nx0tUtCmtLwmqrWjU/fvKfpnMjJszyzSMhzQczib3fUrRHZgRoQShl0pbbWhU2oFrZLGlnb8+LcfRCzJyL2mne2yUqdGMBjCkrVfRbZN52ehIMcNn8pOvmkuIBRSbqMtyHEjGAyh/WQw5mm1vhMdulpcnTivw0iLOlGycoVCdo9RUub3++HxeODz+ZCfn2/36ZDNOoMhjH9sg2ZKe9O8iabdTYpexLSWGqSzWX7rCADoeQHKz0LbyU6hwtfMXi4ETtrzv61SB8ovLi3Dcxv3AlCf6VGU60ZTS2xDyKTjirzXSvM6wt8POy/6nKxKyUrP9ZuBCCUU6cICyF8Qzbyw6L2ItZ8MYszS9YoXWhcAj0ZmQURuRjpa2jtjeAXjx83L6oV6/+kdssODsljqPoxaPXOMYv2HFLiqBYdmB65E1EXP9ZtLM5RQ4pXSNjJ0avv+ZtW7/RCgq9VXiR1BiHTcmZecjdFn95G9g5c6VLZ+14jZL8U2fv264f3xZtVhzccpbVa4bW8TNu9p4LwOogTAQIQSTjxaMo0MnYpnkWxBthu+1tgyK0a8uGUf7rl8iOLvOj3NBYRgOAiRshQ3jhwgFIhE1wMZycpwXgeRvdg1QwlJaYiVWYx06MRz7sPt48oA9Oy6sJo01VRJZXUdZq8ytptweMfImEF9VLuRXOjZxmu0G4fzOojsxUCEUpJWO6eRDh2RVl4zFOW6MbBPDu6bNAR98zJMec3bLy5FQbZb6LFKQZoUCBjNhoRPPNXb4qq2lKZELpghovjj0gylHJFOGCNDp7T2pglBfGM3NU0tHZj7ShWArrZZM1xxrhcFOW6h/WTkgjQjgYBk9oRBGC8z7E1PPZDe6a+c10HkHMyIUEpR26vmrpU7UFldB8D40Cm1/U2euXUEHr1hmGk/C4CYp7CGZwXmTByCghzlrIhaBiGWMfAvbT0AX2u7bEAwpaIEm+ZNxOqZY/D49OF46Y7R+N2N5yNwMhiRydJb52H3fjNEdBozIpQy9HbCGO3Q0SqmvWNcKV7QObgso1ca2k8GdT1HVHhA9egNw2RbloGu35FSBiGWgs+jreoDyqR6oMrqOvz7q5/LZrLMHrVPRPHDQIRShpFOGL0dOtEDqq4+r3/EYzuDIfQvyNZ97lYEIX1yM/DI9RURF38p+Hrg9S96LCGpZUvMKPiMbocOpzTTRcpkPXXzCKGltLmTf8gAhMhhGIhQXFk5SVLrtY3uVSO6aZpW7UlldR0WvfVlxEAwuxTlurFl/uXI6CW/OuuTqWNRG62uVVOjRS4IlN7Pel8rlqz9SjWTtWRtDRZMHYrZq3bKjtoPAVgwlfUgRE7EQITixso9P0Reu7i32OZtoo+LPr7aHfsvLi3Ds6dGoDvBz8eWyV6UjQxyA07X1Mxaaax1VyIFgXrmgUhBTGFupuxSmmTJ2hqkpYF1IUQOw2JVigvRIlFLX1v0Vl3nLb3WxRtA9z4s8VKQ48a9lw+BN19+yWTZ+m8x7tG/9fi961m+ija53CvcAqykb16W4Xkg3x9rw5SKEiyYOlT2+2Z81ojIfAxEyHIiF+rFb9cY2ppdz2s3tIgtiaz/+oiucxC5eMdrAqrr1J9HbxiGuZPPweYHJmLupCGyj633BzAr6sJsdPkKAJ7csDumiaolniyMPKvQcBtw37wsdJ7aPVhOrJ81IrIGAxGyXCx32Wa+tmhB5YrN+7D03Rrhc7BzRHj06opcW+qKT/apvsYDr3/RfWE2MsgN6MpKicwgkRPeDr19f7PuTEh4W7GVnzUisgZrRMhysdxlm/naV5/XHyWeLKEL3bMb9+L8Mwtw1Xn9NR9r1ojwKef2w7Z9zWhqaVd9XFGuGwuuPhfe/K4Mwvb9zYoFultrGzUHqB090YFPdjegV6801PtaUZSbgeaWduFBblJWSlReVi8cazvZ/ffwdug1VYeEX0c6H+B0W7GVnzUisgYDEdIUa6eL0btss19bb0Hlw2uq8ZNT48bVxNoxIvn73iY0qwQN0ln85/XDIjIeah09W75rEDr2Xau243hAfVdfpUFueoeZLb7mXJQUZMt+nvR+BqJnulj5WSMiazAQIVVmdLoYGZcu0QqC9L72lIoSXFnhxXvV9Zrn3dTSIbRFvMho99yMdLS0q1/o1YIQQHuQmjyxgFErCFE7vt7sQklBtuLvVCSoC88Ixfp5ICL7MRAhRVotqaIjsrUu1ID8xE6RIMjIaw/6Qa7mOUtEL7JaU1gBGG5tLchx46mbRmCMzl2GO4MheGLsYom+6APAltrGiMBQT3ZBa5M5kfczOiOk9/ncX4bIWVyhUMix5eN+vx8ejwc+nw/5+fl2n05K6QyGMP6xDYopd+nOctO8icL/qOvJrigFQdKRooMgPa+9eXcDbnnh70LnvHrmGKFhZhK1DE7XQLMa1PtPn2NRboZmTYiR89Azh0P02Eq/46vPK8ELm/Zq7nvjQs/3TUmsmTgrZ9YQkTY9128GIiRrS20jbnp+q+bjzLxQhz/GSBCk9drdkzr9bXj4jS80l0pKNAItI7Uz0c+p97Vi7l8+V30OADw+fTimDT9D83GAchBn1OPThyOzV1pMr1mY48bSG5QzGXJirU2ycoovEanTc/3m0gzJsqr7QGRcupE9YbRe20iGQC2Fb/SOO/oct9Q2Cp2L6PKH2lwVo4p7Z+Lf//q5odd0Abj38sG45/JzdAcBoqP1rXo+EcUH54iQLDu7D8wOgvRO6izMceMZlSUEM6fESsWVSpfo8BkZIvR2sKiRjo0QDL9mCMDos4uZiSAiRcyIkCyzuw/0pMnNDIK0MgQuAIW5GZh+0ZlIc6Vh7KA+GHO2clGo0b1YlJhdXGnWfAzpaAumlmPLd2JZGyWc2UFEahiIkCwzL5B6lzHMDIJElnmaWtpxyZC+qml8KZDavKfB0LKRGq2OGz11FWZlqLyeLFx7fgmWrI294JUzO4hIDQMRUmTGBdJIC7CZQZAZyzxG6kveO7U8I1ogOaWiBJPLvTEXV5oxXG3B1KEo8WRh9qqdMdWacGYHEYlg1wxpil5W0RorHv68WFqAzWjBjLX7J9YOFDtaRqVzBuSHqymR3o+PfjkBP/7tBzFlQpTarIkoNbBrhkwV3n1QWV3X4yKldLE12v0iMSNLEOtU1wde/yKmrIDe4W9mUMtkXXt+CZ7buBeAcqZJz8ZzaS7g8qF9UX3IH/OyEhGlJgYiJEzvMosZyyJmtHAaXeZ5csNuzQ3jtBgpYDWDWhB3wcBC1eU2PRvPhULA+prv8dTNF6AwN5MzO4hINwYiJMRIt4hTNiAzUuvSGQxhxeZ9phzfSAGrGZSCOK1Mk573Q3rvl6z9SteUXSIiCQMREmJkmcVJG5DpXebZtrcJR1vFsiFXlPfF+zXfaz7OSW2sapkmvQWvdgVaRJQcONCMhBhZZpGWRYCee8CqLYt0BkPYUtuINVWHsKW2EZ1am5gIki6+04afgbEaG8iJ/rwFOW78/OIyocfa2caq53eq9r6pcVKgRUSJgxkREmJ0mUXvsohTNisT/Xlvv7gMY87u45jMjxwjv1Ol900N54UQkRFs3yUhUiuu1sVWqU5AZLKq3h13raT18wJd2ZDtD09GeppLtWUWsK+NNdbfaWcwhK21jZi9aofiUpWRnZiJKLnpuX5zaSbFGF32MLrMEv58tWURrWJYAFj01pfYvKfB9CUbpfPVWp549IZh3T+HlEHweiKzAl5Plm1BiMjvdPHbNZrLNOOGFOPRnw6DC8beeyIiNcyIpBAzlj2sWjoRHTwWLh5LNmo/r1zxKwDHbD0f6zC3aE5ZNiMi5+NAM+pBKUVf52vDrJU78PTNF+Cq8/prvo5Zo8ijGSl0NHtYmNzykdLPu66mvsfUWKddlM3exdiq956IUptlgci+ffuwZMkSbNiwAfX19ejfvz9uvfVWPPTQQ8jIyLDqsCRDawdaAJizeieehAtXnad9EY11yJgcI4WOZg4L07rbD/95jeyfYwcr5rhY8d4TUWqzrEbk66+/RjAYxLPPPosvv/wSy5YtwzPPPIMHH3zQqkOSAq0ZIAAQDAF3r9qBylObtWkxu8VWml2hN5QIn2FhlBRYRP+OpMAi/HdiRt1FvDS3BKAWm7nQFWxxUzoispNlGZEpU6ZgypQp3X8/++yz8c0332D58uX43e9+Z9VhKYy01PCeYHABiGUXrKgVUBvFLsLoDAu9E2Nj3T8nXiqr64R2z2WRKRHZLa5dMz6fD0VFyndfgUAAfr8/4g8ZU1ldh/GPbcBNz2/Fn7bsF36eVnZBT/ZAL6XOExFGZ1joCSwA8+surCCyFJfmAp662RlLSESU2uJWrFpbW4snnngC//Vf/6X4mKVLl2Lx4sXxOqWkFevW9UoXUSP7zegVXRBZnJuJf/vr5zjit2ZYmN7Awin756gRXYorzGWtFhHZT3dGZNGiRXC5XKp/Pvvss4jnHD58GFOmTMGNN96IO++8U/G158+fD5/P1/3n4MGD+n+iFCdyN6xF6SKqN3ugdH5atSXhM0fGDSnGomuNzy/Rojew0KplcULdRSJkbYiIJLozInPmzMH06dNVH1NaWtr934cPH8aECRMwduxYPPfcc6rPy8zMRGZmpt5TojBbaxuFR3JH08ouxHqBM1pbYmT3XFF6N+ZTq2VxynCvRMjaEBFJdAcixcXFKC4uFnrsoUOHMGHCBIwcORIrVqxAWhoHuVqpsroOD7z2haHnilxEY7nAxdryatUMCyOBhZWBkRmctOsxEZEWyyarHj58GD/+8Y8xcOBA/OlPf0J6enr397xer9BrcLKqOL11IUW5bjS1nN47RCQzYXS/Gel5SpkaJ+xVYiRbI7J/jl2cuvcNEaUGR0xWff/997Fnzx7s2bMHZ555ZsT3HDxVPiHpqQuRLvof/XICtu9v1nURNboskQgtr0YyLnYP91ILhJyetSEiklgWiMyYMQMzZsyw6uUpjEiXRLiF15Qjo1ea0EU0+mI3udyr+wKXKMWTdgcWeohkcDiSnYgSAfeaSQKiF/CCbDce/ekwUza42zRvovAFTrS2ZF/DCaHHpTo99TaJFFwRUWpi9WgSEL3QP3WLeF2A1uCydTX13S22Ywf1Ub3LHlVWBG++djfUy58ecMRodCdLpBHzREQiGIgkAdHZFmPOFrszNvtil57mwk2jBmo+LtY9Y1KBGbNciIichIFIEpCKSAFzhn5ZcbErLc4VepzddSJOlyj1NkREohiIJAmlfVq8nizdrZqiF7F6X6vwDrwcsmUO/h6JKNmwWDWJmNEl0RkMoeFYQOixS9Z+haaW9u6/q83d4JAtc/D3SETJhhmRJBO+T4tWEWk0acfeJWu/Enp8eBACqO/Aq7V8FAIw/aIBeGfX4R7ZFZH9aVKF2ctwRER2s2yyqhk4WTV+Yt2xV6I1JVWuJbh3ZjpCIaClvbP7a1J2BYCh/WmSndF9e4iI4kHP9ZuBCGmOYDdi9cwxivMrpCFp62rq8ZfP/hfHAyd7PCZ6cmv09wCOKXfyiHkiSm2OGPFOiUPvZFYRagWv6Wku+Frb8YfN+xQfoxYdh9AVjCx+uwaTy72WXHwT4SLPYWVElAwYiJAlrZ5qXRvSnJJYWLk/DZc9iIjih8WqSUpPgaeZrZ7S8DS1rg0zMzBmB1FaE2XlCnGJiMg4ZkSSkN47eq2WUFGiXRtmBg9mBlFaE2WtXg4iIkpFzIgkGSN39GotoXKkxxTkuCO+Ljo8zYzgQSTzohfHpxMRxR8zIkkkljt6aTJrdCZFCjaOnujo/pr3VHbF6PA0vRmY6A4aq+ZlcHw6EVH8MRBJInru6OUKPJUms0qvLRdwGCkUlTIwd63codimW5jjxtIbhgHoOUfEa1HhKMenExHFHwORBCHSTmrGHb1SS6howCHa9qqYgcl24/ZxpZgzcUj382IdWy+K49OJiOKPgUgCEC0+tfuOXm+RrOjeOPGal6GWqeH4dCIia7BY1eH0FJ9Kd/RKl0krCjyNnGe4WPbGsYKZuxgTEZE2ZkQcTG/xabzu6KOXX0aeVZhUba9m7GJMRERiGIg4mJHiU6XaC7MKPOWWX4pyM3rsxKt1nk4VHWRdfV5/BiBERBZiIOJgRotPrbqjV9qhVy0IUTtPp+FodyKi+GMg4mCxFJ+aXeCptkwkysltr0pBllTjolUfkgib5BEROREDEQdzUjtpLPvDOL3tNdbR7sykEBEZx64ZB1Mbva5VfKpn0zsRRpdVEqHtNZbR7twkj4goNsyIOJyR4lMz79ClJYfdR44LPb4o142mlp7j4J2cGTBai8NN8oiIYsdAJAHoKT6NtdYh+rWiAxol0vLLR7+cgO37mxOqVsJoLU6sI/WJiIiBSMIQKT418w5dKaCRE778ktErLeEuukZrcbhJHhFR7Fgj4hBm1HSYtY293g6ZRJ86arQWx+6R+kREyYAZEQcwq6bDrDt00Q6ZORMGYdzgHyTE8osWI7U4TupqIiJKVAxEbGZmTYdZd+iiAc2QfnkJtwyjRu8gOG6SR0QUOwYiNjK768LoHXr0MK7i3plC55+MSw56B8FZPVKfiCjZMRCxkdldF0bu0OWWhbz5mSjIccN3ooNLDgK4SR4RkXEMRGxkRdeFnjt0pWWhI/5A99e45CDG7JH6RESpgoGIjazquhC5QxdZFvLkuJHVKx31fi45EBGRNRiI2MisrgulDdfU7tBFloWOnujAS3eMQFqai0sORERkCQYiNjKj68Jo66/ock9DSwDThp8h9FgiIiK9ONDMZlJNh9cTufwiMiQslg3XOIyLiIicgBkRBzDSdRFr6++osiIU5Lhx9ERHj+9JCnLc7IwhIiJLMRBxCL1dF/HYcI2VIEREZDUuzSSoWFt/t+1tUs2GAEDziQ7NfWmIiIhiwUAkQcVa48GdY4mIyAksDUSuvfZaDBw4EFlZWSgpKcFtt92Gw4cPW3nIlCG1/iotn7jQ1T2jVOPBYlUiInICSwORCRMm4C9/+Qu++eYbvPbaa6itrcU//dM/WXnIlJGe5sKCqeWK80cA9dbfWAMZIiIiM7hCoZDctcwSb731Fq677joEAgG43W7Nx/v9fng8Hvh8PuTn58fhDBOH3PwQicgcEek17lq5A4D8DBM9O/8SERFJ9Fy/41Yj0tTUhJdeegkXX3yxYhASCATg9/sj/lBPSvNDJAumDhUKIGKZYUJERGQGy9t3582bhyeffBInTpzAmDFj8M477yg+dunSpVi8eLHVp5TQ1OaHAF3ZjCVrv8JPKkqERrFz51giIrKT7ozIokWL4HK5VP989tln3Y//5S9/iZ07d+L9999Heno6/vmf/xlKq0Hz58+Hz+fr/nPw4EHjP1mS0jM/RJQ0w2Ta8DMwdlAfBiFERBQ3ujMic+bMwfTp01UfU1pa2v3fxcXFKC4uxjnnnIOhQ4diwIAB2Lp1K8aOHdvjeZmZmcjMzNR7SimFbbdERJRMdAciUmBhhJQJCQQChp5PbLslIqLkYlmNyLZt27Bt2zaMHz8ehYWF+O677/DrX/8agwYNks2GkBip7bbe16bYuuu1qO22MxhiLQkREZnKskAkOzsbr7/+OhYuXIiWlhaUlJRgypQpePnll7n8EoP0NBcWXlOOu1bugAvybbdq80OMkmsXFm0TJiIiUhLXOSJ6cY6IsngGBlK7cPQHhfNGiIhIjp7rd0ruvpsMSwzxartVaxcOoSsYWfx2DSaXexPud0hERPZLuUAkmZYYpLZbK+lpF7b6XIiIKPmk1O67ShNJ631tuGvlDlRW19l0Zs7FdmEiIrJSygQiWksMQNcSQ2fQsSUztmC7MBERWSllAhErJpKmAu7SS0REVkqZQIRLDMZI7cIAegQjVrYLExFRakiZQIRLDMZxl14iIrJKynTN2DmRNBlwl14iIrJCygQidk0kTSbxaBcmIqLUkjJLMwCXGIiIiJwmZTIiEi4xEBEROUfKBSIAlxiIiIicIqWWZoiIiMhZGIgQERGRbRiIEBERkW1SskYkWmcwxOJVIiIiG6R8IFJZXYfFb9dE7ENT4snCwmvK2c5LRERksZRemqmsrsNdK3f02Ayv3teGu1buQGV1nU1nRkRElBpSNhDpDIaw+O0a2XHv0tcWv12DzqDcI4iIiMgMKRuIbNvb1CMTEi4EoM7Xhm17m+J3UkRERCkmZQOR748pByFGHkdERET6pWwg0jcvS/tBOh5HRERE+qVsIDKqrAglniwoNem60NU9M6qsKJ6nRURElFJSNhBJT3Nh4TXlANAjGJH+vvCacs4TISIislBKBiKdwRC21DYicDKI+yadg375kcsvXk8Wlt86gnNEiIiILJZyA83kBph58zMxd9IQlBbncrIqERFRHKVURkRpgNkRfwC/X78bmb3SMHZQHwYhREREcZIygQgHmBERETlPygQiHGBGRETkPCkTiHCAGRERkfOkTCDCAWZERETOkzJdM9IAs3pfm2ydiAtdbbscYJZ6OoMhbNvbhO+PtbFriogozlImEJEGmN21cgdcQEQwwgFmqUuunbvEk4WF15RzjgwRURykzNIMAEypKMHyW0fA6+EAM1Ju5673teGulTtQWV1n05kREaWOlMmISKZUlGByuTfpUvFcXtBHq53bha527snlXv4eiYgslHKBCNC1TDN2UB+7T8M0XF7QT087dzJ9VoiInCallmaSEZcXjGE7NxGRMzAQSWCcFmsc27mJiJyBgUgC47RY46R2bqXqDxe6lrfYzk1EZC0GIgmMywvGSe3cAHoEI2znJiKKHwYiCYzLC7FhOzcRkf1SsmsmWXBabOyStZ2biChRxCUjEggEMHz4cLhcLlRVVcXjkCmBywvmkNq5pw0/A2MH9eHvi4gojuISiPzqV79C//7943GolMPlBSIiSmSWL8289957eP/99/Haa6/hvffes/pwKYnLC0RElKgsDUSOHDmCmTNn4s0330ROTo7m4wOBAAKBQPff/X6/laeXVJJtWiwREaUGy5ZmQqEQZsyYgVmzZuHCCy8Ues7SpUvh8Xi6/wwYMMCq0yMiIiIH0B2ILFq0CC6XS/XPZ599hieeeAJ+vx/z588Xfu358+fD5/N1/zl48KDe0yMiIqIE4gqFQrrmfzc0NKChoUH1MaWlpZg+fTrefvttuFyn6xQ6OzuRnp6OW265BX/84x81j+X3++HxeODz+ZCfn6/nNImIiMgmeq7fugMRUQcOHIio8Th8+DB+8pOf4NVXX8Xo0aNx5plnar4GAxEiIqLEo+f6bVmx6sCBAyP+3rt3bwDAoEGDhIIQIiIiSn4c8U5ERES2iduI99LSUli0CkREREQJihkRIiIisg0DESIiIrKNo3fflZZyOGGViIgocUjXbZGSDEcHIseOHQMATlglIiJKQMeOHYPH41F9jGVzRMwQDAZx+PBh5OXlRQxGo9P8fj8GDBiAgwcPctaKw/G9Shx8rxIH3ytnCoVCOHbsGPr374+0NPUqEEdnRNLS0jhzRFB+fj7/J0wQfK8SB9+rxMH3ynm0MiESFqsSERGRbRiIEBERkW0YiCS4zMxMLFy4EJmZmXafCmnge5U4+F4lDr5Xic/RxapERESU3JgRISIiItswECEiIiLbMBAhIiIi2zAQISIiItswEElCgUAAw4cPh8vlQlVVld2nQ1H27duHO+64A2VlZcjOzsagQYOwcOFCtLe3231qdMrTTz+NsrIyZGVlYeTIkfj444/tPiWKsnTpUlx00UXIy8tD3759cd111+Gbb76x+7TIAAYiSehXv/oV+vfvb/dpkIKvv/4awWAQzz77LL788kssW7YMzzzzDB588EG7T40AvPLKK7jvvvvw0EMPYefOnbjkkktw5ZVX4sCBA3afGoX56KOPMHv2bGzduhXr1q3DyZMnccUVV6ClpcXuUyOd2L6bZN577z3cf//9eO2113Duuedi586dGD58uN2nRRp++9vfYvny5fjuu+/sPpWUN3r0aIwYMQLLly/v/trQoUNx3XXXYenSpTaeGan5xz/+gb59++Kjjz7CpZdeavfpkA7MiCSRI0eOYObMmfjzn/+MnJwcu0+HdPD5fCgqKrL7NFJee3s7tm/fjiuuuCLi61dccQU++eQTm86KRPh8PgDg/0cJiIFIkgiFQpgxYwZmzZqFCy+80O7TIR1qa2vxxBNPYNasWXafSspraGhAZ2cn+vXrF/H1fv36ob6+3qazIi2hUAj3338/xo8fj4qKCrtPh3RiIOJwixYtgsvlUv3z2Wef4YknnoDf78f8+fPtPuWUJfpehTt8+DCmTJmCG2+8EXfeeadNZ07RXC5XxN9DoVCPr5FzzJkzB7t27cLq1avtPhUygDUiDtfQ0ICGhgbVx5SWlmL69Ol4++23I/6x7OzsRHp6Om655Rb88Y9/tPpUU57oe5WVlQWgKwiZMGECRo8ejRdffBFpabwvsFt7eztycnLw17/+Fddff3331++9915UVVXho48+svHsSM4999yDN998Exs3bkRZWZndp0MGMBBJEgcOHIDf7+/+++HDh/GTn/wEr776KkaPHo0zzzzTxrOjaIcOHcKECRMwcuRIrFy5Eunp6XafEp0yevRojBw5Ek8//XT318rLyzFt2jQWqzpIKBTCPffcgzfeeAMffvghhgwZYvcpkUG97D4BMsfAgQMj/t67d28AwKBBgxiEOMzhw4dx2WWXYeDAgfjd736Hf/zjH93f83q9Np4ZAcD999+P2267DRdeeCHGjh2L5557DgcOHGANj8PMnj0bq1atwpo1a5CXl9ddw+PxeJCdnW3z2ZEeDESI4uz999/Hnj17sGfPnh5BIhOU9vvZz36GxsZG/OY3v0FdXR0qKirw7rvv4qyzzrL71CiM1F592WWXRXx9xYoVmDFjRvxPiAzj0gwRERHZhtVxREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkm/8LdoheHsFAnrMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(X_scaled@beta_mdn/5, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "5545e938",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x1c78b7fea40>"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGdCAYAAADaPpOnAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAMftJREFUeJzt3X98VPWd7/H3JCQZSJMpIZIEhZBSF4yBYkKBgFTrQ2IUqdbuo6AF225rRaUKdO8Wro9uAHcFt93V7VZQ8XdZEbfqLdxyU7H+qEqQCklLDGsRg1CdiASdidgESL73D5xZJpmZzEzmzMyZvJ6PRx7rnPnOnO/pODtvvz8+x2GMMQIAALCJjGR3AAAAIBqEFwAAYCuEFwAAYCuEFwAAYCuEFwAAYCuEFwAAYCuEFwAAYCuEFwAAYCtDkt2BeOvp6dH777+vvLw8ORyOZHcHAABEwBijjo4OjRo1ShkZ4cdW0i68vP/++xo9enSyuwEAAGJw+PBhnXPOOWHbpF14ycvLk3T64vPz85PcGwAAEAmv16vRo0f7f8fDSbvw4psqys/PJ7wAAGAzkSz5YMEuAACwFcILAACwFcILAACwFcILAACwFcILAACwFcILAACwFcILAACwFcILAACwlbQrUgcAAKzR3WO0q/WYjnR0amSeU1PLCpSZkfj7CBJeAABAv+qb3Vq1tUVuT6f/WInLqbq55aqtKEloX5g2AgAAYdU3u3XTxj0BwUWS2jydumnjHtU3uxPaH8ILAAAIqbvHaNXWFpkgz/mOrdraou6eYC2sQXgBAAAh7Wo91mfE5UxGktvTqV2txxLWJ8ILAAAI6UhH6OASS7t4ILwAAICQRuY549ouHggvAAAgpKllBSpxORVqQ7RDp3cdTS0rSFifCC8AACCkzAyH6uaWS1KfAON7XDe3PKH1XggvAAAgrNqKEq1fUKliV+DUULHLqfULKhNe54UidQAAoF+1FSWaXV5MhV0AAGAfmRkOVY8bkexuMG0EAADshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABsJSHhZd26dSorK5PT6VRVVZVeeeWVkG1fffVVzZw5UyNGjNDQoUM1YcIE3X333YnoJgAAsIEhVp9g8+bNWrJkidatW6eZM2fq/vvv1+WXX66WlhaNGTOmT/vc3FwtXrxYkyZNUm5url599VXdeOONys3N1Q9+8AOruwsAAFKcwxhjrDzBtGnTVFlZqfXr1/uPnXfeebr66qu1Zs2aiN7jmmuuUW5urn75y1/229br9crlcsnj8Sg/Pz/mfgMAgMSJ5vfb0mmjEydOaPfu3aqpqQk4XlNTox07dkT0Ho2NjdqxY4cuuuiioM93dXXJ6/UG/AEAgPRlaXg5evSouru7VVRUFHC8qKhIbW1tYV97zjnnKCcnR1OmTNEtt9yi73//+0HbrVmzRi6Xy/83evTouPUfAACknoQs2HU4HAGPjTF9jvX2yiuv6I033tB9992ne+65R5s2bQrabsWKFfJ4PP6/w4cPx63fAAAg9Vi6YLewsFCZmZl9RlmOHDnSZzSmt7KyMknSxIkT9cEHH2jlypW69tpr+7TLyclRTk5O/DoNAABSmqUjL9nZ2aqqqtL27dsDjm/fvl0zZsyI+H2MMerq6op39wAAgA1ZvlV62bJlWrhwoaZMmaLq6mo98MADOnTokBYtWiTp9LTPe++9p8cff1ySdO+992rMmDGaMGGCpNN1X372s5/phz/8odVdBQAANmB5eJk3b57a29u1evVqud1uVVRUaNu2bSotLZUkud1uHTp0yN++p6dHK1asUGtrq4YMGaJx48Zp7dq1uvHGG63uKgAAsAHL67wkGnVeAACwn5Sp8wIAABBvhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArhBcAAGArQ5LdAQBAeuru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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter( lasso.coef_,beta_mdn)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ml_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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
