{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acd7e98d",
   "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",
    "\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",
    "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)/sqn   )\n",
    "            log_pi= result.pi_np\n",
    "            beta =   result.post_mean\n",
    "\n",
    "\n",
    "  \n",
    "    out=   ysd *betahat_arr/ csd\n",
    "    return out\n",
    " \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d580a463",
   "metadata": {},
   "outputs": [],
   "source": [
    " \n",
    "\n",
    " \n",
    "\n",
    "### === NASH main function === ###\n",
    "\n",
    "def nash_noinfo_dynamic_td(X, y, maxit=10,damping = 0.99):\n",
    "    X = X.astype(np.float32)\n",
    "    y = y.astype(np.float32).flatten()\n",
    "\n",
    "    # Standardize\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",
    "\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",
    "        r = y - X @ beta\n",
    "        beta_new = beta.copy()\n",
    "        betahat_list, sebetahat_list = [], []\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) / sqn, 1e-4)\n",
    "\n",
    "\n",
    "            if log_pi is None:\n",
    "                beta_k_new = betahat_k\n",
    "            else:\n",
    "                pm = posterior_mean_norm(\n",
    "                    betahat=np.array([betahat_k]),\n",
    "                    sebetahat=np.array([sigma_0]) ,  \n",
    "                    log_pi=log_pi,\n",
    "                    scale=scale,\n",
    "                    location=location\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",
    "\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k)\n",
    "\n",
    "       \n",
    "        # Fit ASH on current beta and extract posterior mean\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",
    "        denom = n + p * (1 - pi0)\n",
    "        if denom <= 1e-8:\n",
    "            denom = n + p * 1e-3  # avoid divide by 0 or small number\n",
    "        sigma_0 = np.sqrt(max((res_sq_final + sigma_0_term) / denom, 1e-8)) / sqn\n",
    "       # residual = y - X @ beta\n",
    "       # residual_variance = np.mean(residual ** 2)\n",
    "       # sigma_0 = np.sqrt(residual_variance)\n",
    "        #print(sigma_0)\n",
    "\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",
    "\n",
    "        # Update beta with ash\n",
    "        ash_input = drift_comp * betahat_arr + (1 - drift_comp) * beta\n",
    "        log_pi, scale, postmean = call_r_ash_fit_all_with_postmean(ash_input, sigma_0)\n",
    "        pi0 =np.exp(log_pi[0])\n",
    "        location = np.zeros_like(scale)\n",
    "         # Replace with posterior mean from ASH\n",
    "\n",
    "        td_beta.append(ysd * beta / csd)\n",
    "        print(f\"Iteration {o+1} complete\")\n",
    "    beta = postmean.copy() \n",
    "    final_beta = ysd * beta / csd\n",
    "    #print(\"Final residual variance:\", np.var(y - X @ beta))\n",
    "    return final_beta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae250fd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name=[\"Airpassenger\"]\n",
    "rmses, mads = [], []\n",
    "k =1\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 = [\"Airpassenger\"] \n",
    "dataset_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger\")\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",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e28bf7ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "lasso = LassoCV(cv=5, max_iter=5000)\n",
    "lasso.fit(X_train, y_test )\n",
    "betal = lasso.coef_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7996018b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df9509d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = X_train.shape[1]\n",
    "\n",
    "# Create side info: a (p, 1) column vector with values 1 to p\n",
    "sideinfo_array = np.arange(1, p + 1).reshape(-1, 1).astype(np.float32)\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=  np.eye(144) , y=y_train, sideinfo=sideinfo_array, maxit=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d533773a",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_test = pd.read_csv(dataset_path / f\"y_test{k}.csv\").values.astype(np.float32).flatten()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a38c0851",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred_test = X_test @ beta_est\n",
    "\n",
    "        # Metrics\n",
    "rmse = np.sqrt(mean_squared_error(y_test, y_pred_test))\n",
    "rmse"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0899e26",
   "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",
    "    \"\"\"Standardize columns of X (mean=0, std=1).\"\"\"\n",
    "    scaler = StandardScaler(with_mean=with_mean, with_std=with_std)\n",
    "    X_scaled = scaler.fit_transform(X)\n",
    "    return X_scaled.astype(np.float32), scaler.scale_\n",
    "\n",
    "def nash_with_sideinfo(X_train, y_train, sideinfo_array, maxit=10, damping=0.99):\n",
    "    \"\"\"\n",
    "    Run NASH regression with side information using an iterative Empirical Bayes approach.\n",
    "    \n",
    "    Parameters:\n",
    "    - X_train: ndarray (n x p) input features\n",
    "    - y_train: ndarray (n,) response\n",
    "    - sideinfo_array: ndarray (p x d) side info for the prior\n",
    "    - maxit: int, number of coordinate ascent iterations\n",
    "    - damping: float, update damping coefficient in [0, 1]\n",
    "\n",
    "    Returns:\n",
    "    - beta_final: ndarray (p,) posterior mean of beta (rescaled to original y)\n",
    "    \"\"\"\n",
    "    X = np.eye(144) if X_train is None else X_train.astype(np.float32)\n",
    "    y = y_train.astype(np.float32).flatten()\n",
    "    sideinfo = sideinfo_array\n",
    "\n",
    "    # Standardize\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",
    "\n",
    "    # Lasso initialization\n",
    "    lasso = LassoCV(cv=5, max_iter=5000)\n",
    "    lasso.fit(X, y)\n",
    "    beta = lasso.coef_\n",
    "\n",
    "    # Prior placeholders\n",
    "    log_pi, scale, location = None, None, None\n",
    "    pi0 = 0\n",
    "\n",
    "    for o in range(maxit):\n",
    "        betahat_list, sebetahat_list = [], []\n",
    "        beta_new = beta.copy()\n",
    "\n",
    "        for k in range(p):\n",
    "            r = y - X @ beta\n",
    "            xk = X[:, k]\n",
    "            r_k = r + xk * beta[k]\n",
    "            betahat_k = np.dot(xk, r_k) / n\n",
    "            sebetahat_k = max(np.std(r_k) / sqn, 1e-4)\n",
    "\n",
    "            if o == 0:\n",
    "                beta_k_new = damping * betahat_k + (1 - damping) * beta[k]\n",
    "            else:\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",
    "                beta_k_new = pm.post_mean[0]\n",
    "                beta_k_new = damping * beta_k_new + (1 - damping) * beta[k]\n",
    "\n",
    "            beta_new[k] = beta_k_new\n",
    "            betahat_list.append(betahat_k)\n",
    "            sebetahat_list.append(sebetahat_k)\n",
    "\n",
    "        betahat_arr = np.array(betahat_list)\n",
    "        sebetahat_arr = np.array(sebetahat_list)\n",
    "        beta = beta_new.copy()\n",
    "\n",
    "        # Noise and drift estimation\n",
    "        res_sq = np.sum((y - X @ beta) ** 2)\n",
    "        drift_term = np.dot(betahat_arr, betahat_arr) / np.sqrt(n + p)\n",
    "        sigma_0_term = np.dot(beta, beta - betahat_arr)\n",
    "        sigma_0 = np.sqrt(max((res_sq + sigma_0_term) / (n + p * (1 - pi0)), 1e-8)) / sqn\n",
    "        s = np.sqrt(res_sq + drift_term) / sqn\n",
    "        drift_comp = (1 / (n / s**2 + 1 / sigma_0**2)) * (n / s**2)\n",
    "\n",
    "        # Prior update using Cash\n",
    "        if o == 0:\n",
    "            ash_input = betahat_arr\n",
    "        else:\n",
    "            ash_input = drift_comp * betahat_arr + (1 - drift_comp) * result.post_mean\n",
    "\n",
    "        result = Cash_posterior_means(\n",
    "            X=sideinfo,\n",
    "            betahat=ash_input,\n",
    "            sebetahat=np.full_like(ash_input, sigma_0) / sqn,\n",
    "            n_epochs=50\n",
    "        )\n",
    "\n",
    "        log_pi = result.pi_np\n",
    "        beta = result.post_mean\n",
    "\n",
    "    return ysd.flatten() * result.post_mean\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac33cbf6",
   "metadata": {},
   "outputs": [],
   "source": [
    "sideinfo_array"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65ee24a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name=[\"Airpassenger\"]\n",
    "rmses, mads = [], []\n",
    "k =1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "a58959b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/50,   Variance Loss: -47.9593\n",
      "Epoch 20/50,   Variance Loss: -71.2640\n",
      "Epoch 30/50,   Variance Loss: -78.3029\n",
      "Epoch 40/50,   Variance Loss: -78.4325\n",
      "Epoch 50/50,   Variance Loss: -78.4341\n",
      "Epoch 10/200,   Variance Loss: -44.4184\n",
      "Epoch 20/200,   Variance Loss: -65.1672\n",
      "Epoch 30/200,   Variance Loss: -72.6428\n",
      "Epoch 40/200,   Variance Loss: -75.2193\n",
      "Epoch 50/200,   Variance Loss: -76.9144\n",
      "Epoch 60/200,   Variance Loss: -79.2865\n",
      "Epoch 70/200,   Variance Loss: -80.1250\n",
      "Epoch 80/200,   Variance Loss: -80.7606\n",
      "Epoch 90/200,   Variance Loss: -81.6864\n",
      "Epoch 100/200,   Variance Loss: -83.1148\n",
      "Epoch 110/200,   Variance Loss: -84.5385\n",
      "Epoch 120/200,   Variance Loss: -84.8833\n",
      "Epoch 130/200,   Variance Loss: -85.7442\n",
      "Epoch 140/200,   Variance Loss: -86.2326\n",
      "Epoch 150/200,   Variance Loss: -86.4014\n",
      "Epoch 160/200,   Variance Loss: -86.9001\n",
      "Epoch 170/200,   Variance Loss: -86.7551\n",
      "Epoch 180/200,   Variance Loss: -86.9546\n",
      "Epoch 190/200,   Variance Loss: -87.0935\n",
      "Epoch 200/200,   Variance Loss: -87.3222\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 24.1757\n",
      "Epoch 20/200,   Variance Loss: -48.4465\n",
      "Epoch 30/200,   Variance Loss: -71.1072\n",
      "Epoch 40/200,   Variance Loss: -72.9101\n",
      "Epoch 50/200,   Variance Loss: -73.5285\n",
      "Epoch 60/200,   Variance Loss: -73.9515\n",
      "Epoch 70/200,   Variance Loss: -74.8136\n",
      "Epoch 80/200,   Variance Loss: -75.7470\n",
      "Epoch 90/200,   Variance Loss: -77.1480\n",
      "Epoch 100/200,   Variance Loss: -79.3679\n",
      "Epoch 110/200,   Variance Loss: -83.1773\n",
      "Epoch 120/200,   Variance Loss: -85.2891\n",
      "Epoch 130/200,   Variance Loss: -86.4096\n",
      "Epoch 140/200,   Variance Loss: -87.0166\n",
      "Epoch 150/200,   Variance Loss: -87.5265\n",
      "Epoch 160/200,   Variance Loss: -87.7643\n",
      "Epoch 170/200,   Variance Loss: -87.9823\n",
      "Epoch 180/200,   Variance Loss: -88.1392\n",
      "Epoch 190/200,   Variance Loss: -88.3306\n",
      "Epoch 200/200,   Variance Loss: -88.4434\n",
      "Epoch 10/200,   Variance Loss: 8.5774\n",
      "Epoch 20/200,   Variance Loss: -66.4128\n",
      "Epoch 30/200,   Variance Loss: -71.5680\n",
      "Epoch 40/200,   Variance Loss: -73.6627\n",
      "Epoch 50/200,   Variance Loss: -74.4708\n",
      "Epoch 60/200,   Variance Loss: -75.1410\n",
      "Epoch 70/200,   Variance Loss: -76.0340\n",
      "Epoch 80/200,   Variance Loss: -77.7434\n",
      "Epoch 90/200,   Variance Loss: -81.0129\n",
      "Epoch 100/200,   Variance Loss: -83.7756\n",
      "Epoch 110/200,   Variance Loss: -84.7890\n",
      "Epoch 120/200,   Variance Loss: -85.6487\n",
      "Epoch 130/200,   Variance Loss: -86.5521\n",
      "Epoch 140/200,   Variance Loss: -87.1523\n",
      "Epoch 150/200,   Variance Loss: -87.3346\n",
      "Epoch 160/200,   Variance Loss: -87.6810\n",
      "Epoch 170/200,   Variance Loss: -87.7971\n",
      "Epoch 180/200,   Variance Loss: -88.1672\n",
      "Epoch 190/200,   Variance Loss: -88.4402\n",
      "Epoch 200/200,   Variance Loss: -88.4528\n",
      "Epoch 10/200,   Variance Loss: 22.7373\n",
      "Epoch 20/200,   Variance Loss: -51.4719\n",
      "Epoch 30/200,   Variance Loss: -70.5659\n",
      "Epoch 40/200,   Variance Loss: -73.2219\n",
      "Epoch 50/200,   Variance Loss: -74.4505\n",
      "Epoch 60/200,   Variance Loss: -75.3480\n",
      "Epoch 70/200,   Variance Loss: -76.8425\n",
      "Epoch 80/200,   Variance Loss: -79.8600\n",
      "Epoch 90/200,   Variance Loss: -83.5113\n",
      "Epoch 100/200,   Variance Loss: -85.4813\n",
      "Epoch 110/200,   Variance Loss: -86.4599\n",
      "Epoch 120/200,   Variance Loss: -86.9060\n",
      "Epoch 130/200,   Variance Loss: -87.3645\n",
      "Epoch 140/200,   Variance Loss: -87.5132\n",
      "Epoch 150/200,   Variance Loss: -87.7479\n",
      "Epoch 160/200,   Variance Loss: -87.7042\n",
      "Epoch 170/200,   Variance Loss: -88.0998\n",
      "Epoch 180/200,   Variance Loss: -88.2993\n",
      "Epoch 190/200,   Variance Loss: -88.3294\n",
      "Epoch 200/200,   Variance Loss: -88.5235\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 10.2188\n",
      "Epoch 20/200,   Variance Loss: -49.5220\n",
      "Epoch 30/200,   Variance Loss: -70.5323\n",
      "Epoch 40/200,   Variance Loss: -72.8917\n",
      "Epoch 50/200,   Variance Loss: -73.6561\n",
      "Epoch 60/200,   Variance Loss: -74.3674\n",
      "Epoch 70/200,   Variance Loss: -75.1030\n",
      "Epoch 80/200,   Variance Loss: -76.4861\n",
      "Epoch 90/200,   Variance Loss: -79.4892\n",
      "Epoch 100/200,   Variance Loss: -83.2961\n",
      "Epoch 110/200,   Variance Loss: -85.3294\n",
      "Epoch 120/200,   Variance Loss: -86.4032\n",
      "Epoch 130/200,   Variance Loss: -87.2278\n",
      "Epoch 140/200,   Variance Loss: -87.3688\n",
      "Epoch 150/200,   Variance Loss: -87.6821\n",
      "Epoch 160/200,   Variance Loss: -88.1746\n",
      "Epoch 170/200,   Variance Loss: -88.3625\n",
      "Epoch 180/200,   Variance Loss: -88.1319\n",
      "Epoch 190/200,   Variance Loss: -88.3528\n",
      "Epoch 200/200,   Variance Loss: -88.2847\n",
      "Epoch 10/200,   Variance Loss: 5.7197\n",
      "Epoch 20/200,   Variance Loss: -63.7725\n",
      "Epoch 30/200,   Variance Loss: -67.6717\n",
      "Epoch 40/200,   Variance Loss: -71.0708\n",
      "Epoch 50/200,   Variance Loss: -73.2204\n",
      "Epoch 60/200,   Variance Loss: -73.8309\n",
      "Epoch 70/200,   Variance Loss: -74.4827\n",
      "Epoch 80/200,   Variance Loss: -76.2138\n",
      "Epoch 90/200,   Variance Loss: -80.3068\n",
      "Epoch 100/200,   Variance Loss: -83.8934\n",
      "Epoch 110/200,   Variance Loss: -84.4288\n",
      "Epoch 120/200,   Variance Loss: -84.5459\n",
      "Epoch 130/200,   Variance Loss: -84.6911\n",
      "Epoch 140/200,   Variance Loss: -85.0838\n",
      "Epoch 150/200,   Variance Loss: -85.9680\n",
      "Epoch 160/200,   Variance Loss: -86.8429\n",
      "Epoch 170/200,   Variance Loss: -87.1495\n",
      "Epoch 180/200,   Variance Loss: -87.5207\n",
      "Epoch 190/200,   Variance Loss: -87.7494\n",
      "Epoch 200/200,   Variance Loss: -87.9983\n",
      "Epoch 10/200,   Variance Loss: 11.6332\n",
      "Epoch 20/200,   Variance Loss: -65.5922\n",
      "Epoch 30/200,   Variance Loss: -69.7017\n",
      "Epoch 40/200,   Variance Loss: -73.7996\n",
      "Epoch 50/200,   Variance Loss: -74.7625\n",
      "Epoch 60/200,   Variance Loss: -75.7492\n",
      "Epoch 70/200,   Variance Loss: -77.0538\n",
      "Epoch 80/200,   Variance Loss: -79.2791\n",
      "Epoch 90/200,   Variance Loss: -82.6052\n",
      "Epoch 100/200,   Variance Loss: -84.8745\n",
      "Epoch 110/200,   Variance Loss: -86.0567\n",
      "Epoch 120/200,   Variance Loss: -86.7856\n",
      "Epoch 130/200,   Variance Loss: -87.2780\n",
      "Epoch 140/200,   Variance Loss: -87.6192\n",
      "Epoch 150/200,   Variance Loss: -87.9365\n",
      "Epoch 160/200,   Variance Loss: -88.0152\n",
      "Epoch 170/200,   Variance Loss: -88.1641\n",
      "Epoch 180/200,   Variance Loss: -88.3337\n",
      "Epoch 190/200,   Variance Loss: -88.4564\n",
      "Epoch 200/200,   Variance Loss: -88.6427\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 16.3129\n",
      "Epoch 20/200,   Variance Loss: -59.4997\n",
      "Epoch 30/200,   Variance Loss: -71.7137\n",
      "Epoch 40/200,   Variance Loss: -73.9092\n",
      "Epoch 50/200,   Variance Loss: -74.2919\n",
      "Epoch 60/200,   Variance Loss: -74.9846\n",
      "Epoch 70/200,   Variance Loss: -76.0084\n",
      "Epoch 80/200,   Variance Loss: -77.6395\n",
      "Epoch 90/200,   Variance Loss: -80.7771\n",
      "Epoch 100/200,   Variance Loss: -83.5678\n",
      "Epoch 110/200,   Variance Loss: -84.4837\n",
      "Epoch 120/200,   Variance Loss: -84.9218\n",
      "Epoch 130/200,   Variance Loss: -85.7539\n",
      "Epoch 140/200,   Variance Loss: -86.6014\n",
      "Epoch 150/200,   Variance Loss: -87.0021\n",
      "Epoch 160/200,   Variance Loss: -87.0950\n",
      "Epoch 170/200,   Variance Loss: -87.5919\n",
      "Epoch 180/200,   Variance Loss: -87.8921\n",
      "Epoch 190/200,   Variance Loss: -88.2190\n",
      "Epoch 200/200,   Variance Loss: -88.2436\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 15.9499\n",
      "Epoch 20/200,   Variance Loss: -62.1604\n",
      "Epoch 30/200,   Variance Loss: -71.0156\n",
      "Epoch 40/200,   Variance Loss: -73.2374\n",
      "Epoch 50/200,   Variance Loss: -74.4083\n",
      "Epoch 60/200,   Variance Loss: -75.2637\n",
      "Epoch 70/200,   Variance Loss: -76.6052\n",
      "Epoch 80/200,   Variance Loss: -78.9584\n",
      "Epoch 90/200,   Variance Loss: -83.0351\n",
      "Epoch 100/200,   Variance Loss: -85.5541\n",
      "Epoch 110/200,   Variance Loss: -86.6826\n",
      "Epoch 120/200,   Variance Loss: -87.2271\n",
      "Epoch 130/200,   Variance Loss: -87.5552\n",
      "Epoch 140/200,   Variance Loss: -87.9502\n",
      "Epoch 150/200,   Variance Loss: -88.1898\n",
      "Epoch 160/200,   Variance Loss: -88.3219\n",
      "Epoch 170/200,   Variance Loss: -88.2252\n",
      "Epoch 180/200,   Variance Loss: -88.5643\n",
      "Epoch 190/200,   Variance Loss: -88.6447\n",
      "Epoch 200/200,   Variance Loss: -88.8771\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -41.1361\n",
      "Epoch 20/50,   Variance Loss: -61.5010\n",
      "Epoch 30/50,   Variance Loss: -76.0802\n",
      "Epoch 40/50,   Variance Loss: -78.3067\n",
      "Epoch 50/50,   Variance Loss: -78.3966\n",
      "Epoch 10/200,   Variance Loss: -41.1110\n",
      "Epoch 20/200,   Variance Loss: -68.2491\n",
      "Epoch 30/200,   Variance Loss: -73.0208\n",
      "Epoch 40/200,   Variance Loss: -75.6634\n",
      "Epoch 50/200,   Variance Loss: -76.3126\n",
      "Epoch 60/200,   Variance Loss: -77.1585\n",
      "Epoch 70/200,   Variance Loss: -77.7538\n",
      "Epoch 80/200,   Variance Loss: -78.5015\n",
      "Epoch 90/200,   Variance Loss: -78.9753\n",
      "Epoch 100/200,   Variance Loss: -80.0352\n",
      "Epoch 110/200,   Variance Loss: -81.2153\n",
      "Epoch 120/200,   Variance Loss: -82.5103\n",
      "Epoch 130/200,   Variance Loss: -83.5112\n",
      "Epoch 140/200,   Variance Loss: -84.2804\n",
      "Epoch 150/200,   Variance Loss: -84.8759\n",
      "Epoch 160/200,   Variance Loss: -84.8550\n",
      "Epoch 170/200,   Variance Loss: -85.4043\n",
      "Epoch 180/200,   Variance Loss: -85.5418\n",
      "Epoch 190/200,   Variance Loss: -85.2801\n",
      "Epoch 200/200,   Variance Loss: -85.7261\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 2.4612\n",
      "Epoch 20/200,   Variance Loss: -73.2373\n",
      "Epoch 30/200,   Variance Loss: -72.2043\n",
      "Epoch 40/200,   Variance Loss: -75.1349\n",
      "Epoch 50/200,   Variance Loss: -75.4257\n",
      "Epoch 60/200,   Variance Loss: -75.7284\n",
      "Epoch 70/200,   Variance Loss: -76.1746\n",
      "Epoch 80/200,   Variance Loss: -76.8141\n",
      "Epoch 90/200,   Variance Loss: -78.9288\n",
      "Epoch 100/200,   Variance Loss: -82.2846\n",
      "Epoch 110/200,   Variance Loss: -83.2915\n",
      "Epoch 120/200,   Variance Loss: -83.8262\n",
      "Epoch 130/200,   Variance Loss: -84.2218\n",
      "Epoch 140/200,   Variance Loss: -84.5921\n",
      "Epoch 150/200,   Variance Loss: -84.9156\n",
      "Epoch 160/200,   Variance Loss: -85.2417\n",
      "Epoch 170/200,   Variance Loss: -85.7610\n",
      "Epoch 180/200,   Variance Loss: -86.8653\n",
      "Epoch 190/200,   Variance Loss: -89.3345\n",
      "Epoch 200/200,   Variance Loss: -90.7988\n",
      "Epoch 10/200,   Variance Loss: 13.9619\n",
      "Epoch 20/200,   Variance Loss: -58.8270\n",
      "Epoch 30/200,   Variance Loss: -70.4402\n",
      "Epoch 40/200,   Variance Loss: -73.6033\n",
      "Epoch 50/200,   Variance Loss: -75.8106\n",
      "Epoch 60/200,   Variance Loss: -78.0352\n",
      "Epoch 70/200,   Variance Loss: -81.5432\n",
      "Epoch 80/200,   Variance Loss: -82.8999\n",
      "Epoch 90/200,   Variance Loss: -83.4942\n",
      "Epoch 100/200,   Variance Loss: -83.7930\n",
      "Epoch 110/200,   Variance Loss: -84.1671\n",
      "Epoch 120/200,   Variance Loss: -84.4301\n",
      "Epoch 130/200,   Variance Loss: -84.8573\n",
      "Epoch 140/200,   Variance Loss: -85.2065\n",
      "Epoch 150/200,   Variance Loss: -85.5807\n",
      "Epoch 160/200,   Variance Loss: -85.9097\n",
      "Epoch 170/200,   Variance Loss: -86.2493\n",
      "Epoch 180/200,   Variance Loss: -87.0856\n",
      "Epoch 190/200,   Variance Loss: -87.9201\n",
      "Epoch 200/200,   Variance Loss: -89.0316\n",
      "Epoch 10/200,   Variance Loss: 4.2776\n",
      "Epoch 20/200,   Variance Loss: -62.5411\n",
      "Epoch 30/200,   Variance Loss: -71.9443\n",
      "Epoch 40/200,   Variance Loss: -74.5010\n",
      "Epoch 50/200,   Variance Loss: -74.8231\n",
      "Epoch 60/200,   Variance Loss: -74.9607\n",
      "Epoch 70/200,   Variance Loss: -75.2500\n",
      "Epoch 80/200,   Variance Loss: -75.5849\n",
      "Epoch 90/200,   Variance Loss: -76.0967\n",
      "Epoch 100/200,   Variance Loss: -76.4479\n",
      "Epoch 110/200,   Variance Loss: -77.0005\n",
      "Epoch 120/200,   Variance Loss: -78.6565\n",
      "Epoch 130/200,   Variance Loss: -81.8919\n",
      "Epoch 140/200,   Variance Loss: -83.0793\n",
      "Epoch 150/200,   Variance Loss: -83.5143\n",
      "Epoch 160/200,   Variance Loss: -83.7491\n",
      "Epoch 170/200,   Variance Loss: -84.0842\n",
      "Epoch 180/200,   Variance Loss: -84.3896\n",
      "Epoch 190/200,   Variance Loss: -84.7620\n",
      "Epoch 200/200,   Variance Loss: -84.9240\n",
      "Epoch 10/200,   Variance Loss: 16.2337\n",
      "Epoch 20/200,   Variance Loss: -54.0747\n",
      "Epoch 30/200,   Variance Loss: -71.3711\n",
      "Epoch 40/200,   Variance Loss: -73.3456\n",
      "Epoch 50/200,   Variance Loss: -75.0579\n",
      "Epoch 60/200,   Variance Loss: -75.5986\n",
      "Epoch 70/200,   Variance Loss: -76.3749\n",
      "Epoch 80/200,   Variance Loss: -78.3046\n",
      "Epoch 90/200,   Variance Loss: -81.4500\n",
      "Epoch 100/200,   Variance Loss: -82.7254\n",
      "Epoch 110/200,   Variance Loss: -83.3031\n",
      "Epoch 120/200,   Variance Loss: -83.6294\n",
      "Epoch 130/200,   Variance Loss: -83.8711\n",
      "Epoch 140/200,   Variance Loss: -84.2384\n",
      "Epoch 150/200,   Variance Loss: -84.4521\n",
      "Epoch 160/200,   Variance Loss: -84.5486\n",
      "Epoch 170/200,   Variance Loss: -84.9686\n",
      "Epoch 180/200,   Variance Loss: -85.3000\n",
      "Epoch 190/200,   Variance Loss: -85.4994\n",
      "Epoch 200/200,   Variance Loss: -85.7419\n",
      "Epoch 10/200,   Variance Loss: 3.0203\n",
      "Epoch 20/200,   Variance Loss: -67.2381\n",
      "Epoch 30/200,   Variance Loss: -71.7529\n",
      "Epoch 40/200,   Variance Loss: -74.8677\n",
      "Epoch 50/200,   Variance Loss: -75.4076\n",
      "Epoch 60/200,   Variance Loss: -76.4350\n",
      "Epoch 70/200,   Variance Loss: -79.0146\n",
      "Epoch 80/200,   Variance Loss: -82.1709\n",
      "Epoch 90/200,   Variance Loss: -83.0523\n",
      "Epoch 100/200,   Variance Loss: -83.3758\n",
      "Epoch 110/200,   Variance Loss: -83.7055\n",
      "Epoch 120/200,   Variance Loss: -83.7642\n",
      "Epoch 130/200,   Variance Loss: -84.0449\n",
      "Epoch 140/200,   Variance Loss: -84.2995\n",
      "Epoch 150/200,   Variance Loss: -84.5954\n",
      "Epoch 160/200,   Variance Loss: -84.7868\n",
      "Epoch 170/200,   Variance Loss: -85.1841\n",
      "Epoch 180/200,   Variance Loss: -85.4570\n",
      "Epoch 190/200,   Variance Loss: -85.6981\n",
      "Epoch 200/200,   Variance Loss: -85.9650\n",
      "Epoch 10/200,   Variance Loss: 1.5145\n",
      "Epoch 20/200,   Variance Loss: -69.5251\n",
      "Epoch 30/200,   Variance Loss: -72.0547\n",
      "Epoch 40/200,   Variance Loss: -74.5715\n",
      "Epoch 50/200,   Variance Loss: -75.1437\n",
      "Epoch 60/200,   Variance Loss: -75.9133\n",
      "Epoch 70/200,   Variance Loss: -77.8700\n",
      "Epoch 80/200,   Variance Loss: -81.3295\n",
      "Epoch 90/200,   Variance Loss: -82.4166\n",
      "Epoch 100/200,   Variance Loss: -82.8993\n",
      "Epoch 110/200,   Variance Loss: -83.1145\n",
      "Epoch 120/200,   Variance Loss: -83.3222\n",
      "Epoch 130/200,   Variance Loss: -83.4183\n",
      "Epoch 140/200,   Variance Loss: -83.8122\n",
      "Epoch 150/200,   Variance Loss: -84.0976\n",
      "Epoch 160/200,   Variance Loss: -84.3647\n",
      "Epoch 170/200,   Variance Loss: -84.7264\n",
      "Epoch 180/200,   Variance Loss: -84.9943\n",
      "Epoch 190/200,   Variance Loss: -85.2618\n",
      "Epoch 200/200,   Variance Loss: -85.5338\n",
      "Epoch 10/200,   Variance Loss: 14.6620\n",
      "Epoch 20/200,   Variance Loss: -68.8814\n",
      "Epoch 30/200,   Variance Loss: -72.8011\n",
      "Epoch 40/200,   Variance Loss: -74.8283\n",
      "Epoch 50/200,   Variance Loss: -75.2492\n",
      "Epoch 60/200,   Variance Loss: -75.9258\n",
      "Epoch 70/200,   Variance Loss: -77.3751\n",
      "Epoch 80/200,   Variance Loss: -80.6649\n",
      "Epoch 90/200,   Variance Loss: -82.2281\n",
      "Epoch 100/200,   Variance Loss: -82.5500\n",
      "Epoch 110/200,   Variance Loss: -82.9102\n",
      "Epoch 120/200,   Variance Loss: -82.8863\n",
      "Epoch 130/200,   Variance Loss: -83.1106\n",
      "Epoch 140/200,   Variance Loss: -83.3233\n",
      "Epoch 150/200,   Variance Loss: -83.5821\n",
      "Epoch 160/200,   Variance Loss: -84.2761\n",
      "Epoch 170/200,   Variance Loss: -85.7214\n",
      "Epoch 180/200,   Variance Loss: -86.9117\n",
      "Epoch 190/200,   Variance Loss: -87.3776\n",
      "Epoch 200/200,   Variance Loss: -87.8601\n",
      "Epoch 10/200,   Variance Loss: -5.2104\n",
      "Epoch 20/200,   Variance Loss: -72.2126\n",
      "Epoch 30/200,   Variance Loss: -73.2017\n",
      "Epoch 40/200,   Variance Loss: -75.3139\n",
      "Epoch 50/200,   Variance Loss: -75.6819\n",
      "Epoch 60/200,   Variance Loss: -76.1278\n",
      "Epoch 70/200,   Variance Loss: -76.7554\n",
      "Epoch 80/200,   Variance Loss: -78.0752\n",
      "Epoch 90/200,   Variance Loss: -80.9145\n",
      "Epoch 100/200,   Variance Loss: -82.7513\n",
      "Epoch 110/200,   Variance Loss: -83.2125\n",
      "Epoch 120/200,   Variance Loss: -83.5051\n",
      "Epoch 130/200,   Variance Loss: -83.6382\n",
      "Epoch 140/200,   Variance Loss: -83.7959\n",
      "Epoch 150/200,   Variance Loss: -84.0271\n",
      "Epoch 160/200,   Variance Loss: -84.4455\n",
      "Epoch 170/200,   Variance Loss: -85.0187\n",
      "Epoch 180/200,   Variance Loss: -85.9278\n",
      "Epoch 190/200,   Variance Loss: -88.1883\n",
      "Epoch 200/200,   Variance Loss: -89.5445\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -49.9392\n",
      "Epoch 20/50,   Variance Loss: -73.5338\n",
      "Epoch 30/50,   Variance Loss: -78.3977\n",
      "Epoch 40/50,   Variance Loss: -78.4035\n",
      "Epoch 50/50,   Variance Loss: -78.4037\n",
      "Epoch 10/200,   Variance Loss: -44.6795\n",
      "Epoch 20/200,   Variance Loss: -65.9133\n",
      "Epoch 30/200,   Variance Loss: -74.2849\n",
      "Epoch 40/200,   Variance Loss: -76.6569\n",
      "Epoch 50/200,   Variance Loss: -78.0753\n",
      "Epoch 60/200,   Variance Loss: -80.3891\n",
      "Epoch 70/200,   Variance Loss: -84.6006\n",
      "Epoch 80/200,   Variance Loss: -86.1220\n",
      "Epoch 90/200,   Variance Loss: -86.6258\n",
      "Epoch 100/200,   Variance Loss: -87.1969\n",
      "Epoch 110/200,   Variance Loss: -87.7537\n",
      "Epoch 120/200,   Variance Loss: -88.4878\n",
      "Epoch 130/200,   Variance Loss: -88.7781\n",
      "Epoch 140/200,   Variance Loss: -89.0187\n",
      "Epoch 150/200,   Variance Loss: -89.1195\n",
      "Epoch 160/200,   Variance Loss: -89.0032\n",
      "Epoch 170/200,   Variance Loss: -89.1313\n",
      "Epoch 180/200,   Variance Loss: -89.2921\n",
      "Epoch 190/200,   Variance Loss: -89.4998\n",
      "Epoch 200/200,   Variance Loss: -89.4524\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -45.5581\n",
      "Epoch 20/200,   Variance Loss: -69.6197\n",
      "Epoch 30/200,   Variance Loss: -74.8885\n",
      "Epoch 40/200,   Variance Loss: -77.3380\n",
      "Epoch 50/200,   Variance Loss: -79.5061\n",
      "Epoch 60/200,   Variance Loss: -83.4088\n",
      "Epoch 70/200,   Variance Loss: -86.1984\n",
      "Epoch 80/200,   Variance Loss: -87.2463\n",
      "Epoch 90/200,   Variance Loss: -88.0863\n",
      "Epoch 100/200,   Variance Loss: -88.6079\n",
      "Epoch 110/200,   Variance Loss: -88.9280\n",
      "Epoch 120/200,   Variance Loss: -89.3827\n",
      "Epoch 130/200,   Variance Loss: -89.4371\n",
      "Epoch 140/200,   Variance Loss: -89.6391\n",
      "Epoch 150/200,   Variance Loss: -89.6640\n",
      "Epoch 160/200,   Variance Loss: -89.8098\n",
      "Epoch 170/200,   Variance Loss: -89.8669\n",
      "Epoch 180/200,   Variance Loss: -89.8184\n",
      "Epoch 190/200,   Variance Loss: -89.8685\n",
      "Epoch 200/200,   Variance Loss: -89.8752\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 20.9431\n",
      "Epoch 20/200,   Variance Loss: -58.7749\n",
      "Epoch 30/200,   Variance Loss: -71.5925\n",
      "Epoch 40/200,   Variance Loss: -73.8666\n",
      "Epoch 50/200,   Variance Loss: -75.1624\n",
      "Epoch 60/200,   Variance Loss: -75.8064\n",
      "Epoch 70/200,   Variance Loss: -76.5134\n",
      "Epoch 80/200,   Variance Loss: -77.4138\n",
      "Epoch 90/200,   Variance Loss: -78.2012\n",
      "Epoch 100/200,   Variance Loss: -79.7091\n",
      "Epoch 110/200,   Variance Loss: -81.6152\n",
      "Epoch 120/200,   Variance Loss: -83.9079\n",
      "Epoch 130/200,   Variance Loss: -85.8999\n",
      "Epoch 140/200,   Variance Loss: -86.9627\n",
      "Epoch 150/200,   Variance Loss: -87.9916\n",
      "Epoch 160/200,   Variance Loss: -88.6708\n",
      "Epoch 170/200,   Variance Loss: -88.8156\n",
      "Epoch 180/200,   Variance Loss: -89.2167\n",
      "Epoch 190/200,   Variance Loss: -89.5690\n",
      "Epoch 200/200,   Variance Loss: -89.9525\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 16.3323\n",
      "Epoch 20/200,   Variance Loss: -57.7219\n",
      "Epoch 30/200,   Variance Loss: -70.7716\n",
      "Epoch 40/200,   Variance Loss: -74.9696\n",
      "Epoch 50/200,   Variance Loss: -75.9074\n",
      "Epoch 60/200,   Variance Loss: -76.8941\n",
      "Epoch 70/200,   Variance Loss: -78.1491\n",
      "Epoch 80/200,   Variance Loss: -79.9276\n",
      "Epoch 90/200,   Variance Loss: -82.6493\n",
      "Epoch 100/200,   Variance Loss: -85.1735\n",
      "Epoch 110/200,   Variance Loss: -86.0690\n",
      "Epoch 120/200,   Variance Loss: -86.7214\n",
      "Epoch 130/200,   Variance Loss: -87.6502\n",
      "Epoch 140/200,   Variance Loss: -88.4352\n",
      "Epoch 150/200,   Variance Loss: -88.7833\n",
      "Epoch 160/200,   Variance Loss: -89.0158\n",
      "Epoch 170/200,   Variance Loss: -89.4432\n",
      "Epoch 180/200,   Variance Loss: -89.7348\n",
      "Epoch 190/200,   Variance Loss: -90.0274\n",
      "Epoch 200/200,   Variance Loss: -89.9660\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 22.3314\n",
      "Epoch 20/200,   Variance Loss: -46.3929\n",
      "Epoch 30/200,   Variance Loss: -62.0353\n",
      "Epoch 40/200,   Variance Loss: -69.0296\n",
      "Epoch 50/200,   Variance Loss: -73.4491\n",
      "Epoch 60/200,   Variance Loss: -74.1124\n",
      "Epoch 70/200,   Variance Loss: -74.3318\n",
      "Epoch 80/200,   Variance Loss: -74.6802\n",
      "Epoch 90/200,   Variance Loss: -75.2895\n",
      "Epoch 100/200,   Variance Loss: -76.0771\n",
      "Epoch 110/200,   Variance Loss: -77.7115\n",
      "Epoch 120/200,   Variance Loss: -80.7870\n",
      "Epoch 130/200,   Variance Loss: -84.9089\n",
      "Epoch 140/200,   Variance Loss: -86.8479\n",
      "Epoch 150/200,   Variance Loss: -88.1504\n",
      "Epoch 160/200,   Variance Loss: -88.8129\n",
      "Epoch 170/200,   Variance Loss: -89.1193\n",
      "Epoch 180/200,   Variance Loss: -89.4903\n",
      "Epoch 190/200,   Variance Loss: -89.8441\n",
      "Epoch 200/200,   Variance Loss: -90.0659\n",
      "Epoch 10/200,   Variance Loss: 11.7586\n",
      "Epoch 20/200,   Variance Loss: -70.4755\n",
      "Epoch 30/200,   Variance Loss: -73.6361\n",
      "Epoch 40/200,   Variance Loss: -75.4322\n",
      "Epoch 50/200,   Variance Loss: -76.3107\n",
      "Epoch 60/200,   Variance Loss: -77.1659\n",
      "Epoch 70/200,   Variance Loss: -78.1573\n",
      "Epoch 80/200,   Variance Loss: -79.6435\n",
      "Epoch 90/200,   Variance Loss: -81.7022\n",
      "Epoch 100/200,   Variance Loss: -84.4592\n",
      "Epoch 110/200,   Variance Loss: -86.0986\n",
      "Epoch 120/200,   Variance Loss: -87.2958\n",
      "Epoch 130/200,   Variance Loss: -87.9281\n",
      "Epoch 140/200,   Variance Loss: -88.7429\n",
      "Epoch 150/200,   Variance Loss: -88.7913\n",
      "Epoch 160/200,   Variance Loss: -89.4531\n",
      "Epoch 170/200,   Variance Loss: -89.7999\n",
      "Epoch 180/200,   Variance Loss: -90.0887\n",
      "Epoch 190/200,   Variance Loss: -90.4150\n",
      "Epoch 200/200,   Variance Loss: -90.1709\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 23.7227\n",
      "Epoch 20/200,   Variance Loss: -55.8697\n",
      "Epoch 30/200,   Variance Loss: -71.4826\n",
      "Epoch 40/200,   Variance Loss: -73.6503\n",
      "Epoch 50/200,   Variance Loss: -75.0208\n",
      "Epoch 60/200,   Variance Loss: -75.7655\n",
      "Epoch 70/200,   Variance Loss: -77.2458\n",
      "Epoch 80/200,   Variance Loss: -79.8711\n",
      "Epoch 90/200,   Variance Loss: -83.8997\n",
      "Epoch 100/200,   Variance Loss: -85.3044\n",
      "Epoch 110/200,   Variance Loss: -85.4972\n",
      "Epoch 120/200,   Variance Loss: -85.5705\n",
      "Epoch 130/200,   Variance Loss: -86.1134\n",
      "Epoch 140/200,   Variance Loss: -86.7691\n",
      "Epoch 150/200,   Variance Loss: -87.6138\n",
      "Epoch 160/200,   Variance Loss: -88.6057\n",
      "Epoch 170/200,   Variance Loss: -89.3328\n",
      "Epoch 180/200,   Variance Loss: -89.6162\n",
      "Epoch 190/200,   Variance Loss: -89.8787\n",
      "Epoch 200/200,   Variance Loss: -90.1025\n",
      "Epoch 10/200,   Variance Loss: 4.0956\n",
      "Epoch 20/200,   Variance Loss: -70.4038\n",
      "Epoch 30/200,   Variance Loss: -72.4051\n",
      "Epoch 40/200,   Variance Loss: -74.3880\n",
      "Epoch 50/200,   Variance Loss: -75.1338\n",
      "Epoch 60/200,   Variance Loss: -76.2097\n",
      "Epoch 70/200,   Variance Loss: -77.9829\n",
      "Epoch 80/200,   Variance Loss: -81.6109\n",
      "Epoch 90/200,   Variance Loss: -84.9111\n",
      "Epoch 100/200,   Variance Loss: -86.2828\n",
      "Epoch 110/200,   Variance Loss: -87.2865\n",
      "Epoch 120/200,   Variance Loss: -88.1553\n",
      "Epoch 130/200,   Variance Loss: -88.4660\n",
      "Epoch 140/200,   Variance Loss: -88.8811\n",
      "Epoch 150/200,   Variance Loss: -89.2995\n",
      "Epoch 160/200,   Variance Loss: -89.6779\n",
      "Epoch 170/200,   Variance Loss: -90.0468\n",
      "Epoch 180/200,   Variance Loss: -90.1050\n",
      "Epoch 190/200,   Variance Loss: -90.1688\n",
      "Epoch 200/200,   Variance Loss: -90.4011\n",
      "Epoch 10/200,   Variance Loss: 20.6067\n",
      "Epoch 20/200,   Variance Loss: -66.2958\n",
      "Epoch 30/200,   Variance Loss: -72.0978\n",
      "Epoch 40/200,   Variance Loss: -74.3871\n",
      "Epoch 50/200,   Variance Loss: -75.5312\n",
      "Epoch 60/200,   Variance Loss: -76.5519\n",
      "Epoch 70/200,   Variance Loss: -78.1552\n",
      "Epoch 80/200,   Variance Loss: -81.1663\n",
      "Epoch 90/200,   Variance Loss: -84.5058\n",
      "Epoch 100/200,   Variance Loss: -86.1928\n",
      "Epoch 110/200,   Variance Loss: -87.1621\n",
      "Epoch 120/200,   Variance Loss: -88.0015\n",
      "Epoch 130/200,   Variance Loss: -88.4944\n",
      "Epoch 140/200,   Variance Loss: -88.5371\n",
      "Epoch 150/200,   Variance Loss: -88.9928\n",
      "Epoch 160/200,   Variance Loss: -89.0433\n",
      "Epoch 170/200,   Variance Loss: -89.6272\n",
      "Epoch 180/200,   Variance Loss: -89.9937\n",
      "Epoch 190/200,   Variance Loss: -90.1777\n",
      "Epoch 200/200,   Variance Loss: -90.2326\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -48.3008\n",
      "Epoch 20/50,   Variance Loss: -75.8863\n",
      "Epoch 30/50,   Variance Loss: -77.9030\n",
      "Epoch 40/50,   Variance Loss: -78.3843\n",
      "Epoch 50/50,   Variance Loss: -78.3993\n",
      "Epoch 10/200,   Variance Loss: -50.8380\n",
      "Epoch 20/200,   Variance Loss: -73.3394\n",
      "Epoch 30/200,   Variance Loss: -75.4565\n",
      "Epoch 40/200,   Variance Loss: -76.3402\n",
      "Epoch 50/200,   Variance Loss: -77.3352\n",
      "Epoch 60/200,   Variance Loss: -79.5667\n",
      "Epoch 70/200,   Variance Loss: -81.0165\n",
      "Epoch 80/200,   Variance Loss: -81.7504\n",
      "Epoch 90/200,   Variance Loss: -83.2530\n",
      "Epoch 100/200,   Variance Loss: -84.9345\n",
      "Epoch 110/200,   Variance Loss: -85.5948\n",
      "Epoch 120/200,   Variance Loss: -85.7046\n",
      "Epoch 130/200,   Variance Loss: -85.6944\n",
      "Epoch 140/200,   Variance Loss: -85.8940\n",
      "Epoch 150/200,   Variance Loss: -85.9920\n",
      "Epoch 160/200,   Variance Loss: -85.9824\n",
      "Epoch 170/200,   Variance Loss: -85.9969\n",
      "Epoch 180/200,   Variance Loss: -86.1836\n",
      "Epoch 190/200,   Variance Loss: -86.1457\n",
      "Epoch 200/200,   Variance Loss: -86.2653\n",
      "Epoch 10/200,   Variance Loss: 18.7441\n",
      "Epoch 20/200,   Variance Loss: -64.3423\n",
      "Epoch 30/200,   Variance Loss: -70.7852\n",
      "Epoch 40/200,   Variance Loss: -72.6527\n",
      "Epoch 50/200,   Variance Loss: -73.7293\n",
      "Epoch 60/200,   Variance Loss: -75.4783\n",
      "Epoch 70/200,   Variance Loss: -78.2713\n",
      "Epoch 80/200,   Variance Loss: -80.3548\n",
      "Epoch 90/200,   Variance Loss: -82.4947\n",
      "Epoch 100/200,   Variance Loss: -83.9021\n",
      "Epoch 110/200,   Variance Loss: -85.2694\n",
      "Epoch 120/200,   Variance Loss: -86.4385\n",
      "Epoch 130/200,   Variance Loss: -87.0703\n",
      "Epoch 140/200,   Variance Loss: -87.4188\n",
      "Epoch 150/200,   Variance Loss: -87.5169\n",
      "Epoch 160/200,   Variance Loss: -87.6312\n",
      "Epoch 170/200,   Variance Loss: -87.7079\n",
      "Epoch 180/200,   Variance Loss: -87.9581\n",
      "Epoch 190/200,   Variance Loss: -88.1901\n",
      "Epoch 200/200,   Variance Loss: -88.2201\n",
      "Epoch 10/200,   Variance Loss: 9.0557\n",
      "Epoch 20/200,   Variance Loss: -66.6881\n",
      "Epoch 30/200,   Variance Loss: -71.2339\n",
      "Epoch 40/200,   Variance Loss: -72.5354\n",
      "Epoch 50/200,   Variance Loss: -73.1081\n",
      "Epoch 60/200,   Variance Loss: -73.5265\n",
      "Epoch 70/200,   Variance Loss: -74.7350\n",
      "Epoch 80/200,   Variance Loss: -77.9722\n",
      "Epoch 90/200,   Variance Loss: -80.4301\n",
      "Epoch 100/200,   Variance Loss: -80.7743\n",
      "Epoch 110/200,   Variance Loss: -80.8268\n",
      "Epoch 120/200,   Variance Loss: -80.7806\n",
      "Epoch 130/200,   Variance Loss: -80.8015\n",
      "Epoch 140/200,   Variance Loss: -80.6868\n",
      "Epoch 150/200,   Variance Loss: -80.9181\n",
      "Epoch 160/200,   Variance Loss: -80.9019\n",
      "Epoch 170/200,   Variance Loss: -80.8999\n",
      "Epoch 180/200,   Variance Loss: -81.1180\n",
      "Epoch 190/200,   Variance Loss: -81.2909\n",
      "Epoch 200/200,   Variance Loss: -81.4806\n",
      "Epoch 10/200,   Variance Loss: 12.9915\n",
      "Epoch 20/200,   Variance Loss: -56.8308\n",
      "Epoch 30/200,   Variance Loss: -70.1876\n",
      "Epoch 40/200,   Variance Loss: -72.3907\n",
      "Epoch 50/200,   Variance Loss: -73.0632\n",
      "Epoch 60/200,   Variance Loss: -73.5958\n",
      "Epoch 70/200,   Variance Loss: -75.1042\n",
      "Epoch 80/200,   Variance Loss: -78.9571\n",
      "Epoch 90/200,   Variance Loss: -80.7008\n",
      "Epoch 100/200,   Variance Loss: -80.9442\n",
      "Epoch 110/200,   Variance Loss: -80.9102\n",
      "Epoch 120/200,   Variance Loss: -80.9252\n",
      "Epoch 130/200,   Variance Loss: -80.9880\n",
      "Epoch 140/200,   Variance Loss: -80.7781\n",
      "Epoch 150/200,   Variance Loss: -80.9352\n",
      "Epoch 160/200,   Variance Loss: -80.8073\n",
      "Epoch 170/200,   Variance Loss: -81.0578\n",
      "Epoch 180/200,   Variance Loss: -81.0037\n",
      "Epoch 190/200,   Variance Loss: -81.0165\n",
      "Epoch 200/200,   Variance Loss: -81.0947\n",
      "Epoch 10/200,   Variance Loss: 6.2458\n",
      "Epoch 20/200,   Variance Loss: -65.2343\n",
      "Epoch 30/200,   Variance Loss: -71.3163\n",
      "Epoch 40/200,   Variance Loss: -72.8848\n",
      "Epoch 50/200,   Variance Loss: -73.9100\n",
      "Epoch 60/200,   Variance Loss: -74.6796\n",
      "Epoch 70/200,   Variance Loss: -75.7519\n",
      "Epoch 80/200,   Variance Loss: -77.4706\n",
      "Epoch 90/200,   Variance Loss: -79.5286\n",
      "Epoch 100/200,   Variance Loss: -81.0505\n",
      "Epoch 110/200,   Variance Loss: -81.7311\n",
      "Epoch 120/200,   Variance Loss: -82.8515\n",
      "Epoch 130/200,   Variance Loss: -86.1217\n",
      "Epoch 140/200,   Variance Loss: -87.1305\n",
      "Epoch 150/200,   Variance Loss: -87.2394\n",
      "Epoch 160/200,   Variance Loss: -87.5822\n",
      "Epoch 170/200,   Variance Loss: -87.4124\n",
      "Epoch 180/200,   Variance Loss: -87.8394\n",
      "Epoch 190/200,   Variance Loss: -88.0748\n",
      "Epoch 200/200,   Variance Loss: -88.2312\n",
      "Epoch 10/200,   Variance Loss: -1.4691\n",
      "Epoch 20/200,   Variance Loss: -67.5615\n",
      "Epoch 30/200,   Variance Loss: -71.2116\n",
      "Epoch 40/200,   Variance Loss: -73.1309\n",
      "Epoch 50/200,   Variance Loss: -73.7912\n",
      "Epoch 60/200,   Variance Loss: -75.2766\n",
      "Epoch 70/200,   Variance Loss: -78.6585\n",
      "Epoch 80/200,   Variance Loss: -80.6167\n",
      "Epoch 90/200,   Variance Loss: -82.4229\n",
      "Epoch 100/200,   Variance Loss: -83.5014\n",
      "Epoch 110/200,   Variance Loss: -83.7396\n",
      "Epoch 120/200,   Variance Loss: -83.7853\n",
      "Epoch 130/200,   Variance Loss: -83.8953\n",
      "Epoch 140/200,   Variance Loss: -83.9756\n",
      "Epoch 150/200,   Variance Loss: -83.9532\n",
      "Epoch 160/200,   Variance Loss: -83.9760\n",
      "Epoch 170/200,   Variance Loss: -84.0040\n",
      "Epoch 180/200,   Variance Loss: -84.1185\n",
      "Epoch 190/200,   Variance Loss: -84.1480\n",
      "Epoch 200/200,   Variance Loss: -84.2386\n",
      "Epoch 10/200,   Variance Loss: 11.1980\n",
      "Epoch 20/200,   Variance Loss: -64.5667\n",
      "Epoch 30/200,   Variance Loss: -71.4860\n",
      "Epoch 40/200,   Variance Loss: -72.9115\n",
      "Epoch 50/200,   Variance Loss: -73.7982\n",
      "Epoch 60/200,   Variance Loss: -74.4946\n",
      "Epoch 70/200,   Variance Loss: -75.8104\n",
      "Epoch 80/200,   Variance Loss: -78.4446\n",
      "Epoch 90/200,   Variance Loss: -82.1234\n",
      "Epoch 100/200,   Variance Loss: -83.6146\n",
      "Epoch 110/200,   Variance Loss: -84.2266\n",
      "Epoch 120/200,   Variance Loss: -84.7392\n",
      "Epoch 130/200,   Variance Loss: -85.1931\n",
      "Epoch 140/200,   Variance Loss: -85.6820\n",
      "Epoch 150/200,   Variance Loss: -86.6958\n",
      "Epoch 160/200,   Variance Loss: -87.1738\n",
      "Epoch 170/200,   Variance Loss: -87.4083\n",
      "Epoch 180/200,   Variance Loss: -87.5452\n",
      "Epoch 190/200,   Variance Loss: -87.7151\n",
      "Epoch 200/200,   Variance Loss: -87.7533\n",
      "Epoch 10/200,   Variance Loss: 20.7778\n",
      "Epoch 20/200,   Variance Loss: -60.6757\n",
      "Epoch 30/200,   Variance Loss: -68.7109\n",
      "Epoch 40/200,   Variance Loss: -72.5222\n",
      "Epoch 50/200,   Variance Loss: -73.3601\n",
      "Epoch 60/200,   Variance Loss: -73.9380\n",
      "Epoch 70/200,   Variance Loss: -74.5985\n",
      "Epoch 80/200,   Variance Loss: -76.1872\n",
      "Epoch 90/200,   Variance Loss: -78.4220\n",
      "Epoch 100/200,   Variance Loss: -81.8243\n",
      "Epoch 110/200,   Variance Loss: -84.4936\n",
      "Epoch 120/200,   Variance Loss: -86.0685\n",
      "Epoch 130/200,   Variance Loss: -86.9215\n",
      "Epoch 140/200,   Variance Loss: -87.3653\n",
      "Epoch 150/200,   Variance Loss: -87.5114\n",
      "Epoch 160/200,   Variance Loss: -87.7038\n",
      "Epoch 170/200,   Variance Loss: -87.7131\n",
      "Epoch 180/200,   Variance Loss: -87.6644\n",
      "Epoch 190/200,   Variance Loss: -87.9377\n",
      "Epoch 200/200,   Variance Loss: -88.0087\n",
      "Epoch 10/200,   Variance Loss: 12.4773\n",
      "Epoch 20/200,   Variance Loss: -69.1774\n",
      "Epoch 30/200,   Variance Loss: -70.9499\n",
      "Epoch 40/200,   Variance Loss: -73.2221\n",
      "Epoch 50/200,   Variance Loss: -73.7356\n",
      "Epoch 60/200,   Variance Loss: -74.5916\n",
      "Epoch 70/200,   Variance Loss: -76.2761\n",
      "Epoch 80/200,   Variance Loss: -79.1673\n",
      "Epoch 90/200,   Variance Loss: -80.5141\n",
      "Epoch 100/200,   Variance Loss: -80.8126\n",
      "Epoch 110/200,   Variance Loss: -80.8103\n",
      "Epoch 120/200,   Variance Loss: -80.9086\n",
      "Epoch 130/200,   Variance Loss: -80.8644\n",
      "Epoch 140/200,   Variance Loss: -80.8482\n",
      "Epoch 150/200,   Variance Loss: -80.9509\n",
      "Epoch 160/200,   Variance Loss: -80.9427\n",
      "Epoch 170/200,   Variance Loss: -81.0466\n",
      "Epoch 180/200,   Variance Loss: -80.8790\n",
      "Epoch 190/200,   Variance Loss: -81.0635\n",
      "Epoch 200/200,   Variance Loss: -80.8060\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -48.4032\n",
      "Epoch 20/50,   Variance Loss: -77.7763\n",
      "Epoch 30/50,   Variance Loss: -78.4457\n",
      "Epoch 40/50,   Variance Loss: -78.4467\n",
      "Epoch 50/50,   Variance Loss: -78.4469\n",
      "Epoch 10/200,   Variance Loss: -45.7464\n",
      "Epoch 20/200,   Variance Loss: -68.6845\n",
      "Epoch 30/200,   Variance Loss: -74.1628\n",
      "Epoch 40/200,   Variance Loss: -75.9264\n",
      "Epoch 50/200,   Variance Loss: -77.4878\n",
      "Epoch 60/200,   Variance Loss: -81.6424\n",
      "Epoch 70/200,   Variance Loss: -84.5482\n",
      "Epoch 80/200,   Variance Loss: -86.1831\n",
      "Epoch 90/200,   Variance Loss: -86.9250\n",
      "Epoch 100/200,   Variance Loss: -87.4588\n",
      "Epoch 110/200,   Variance Loss: -87.7614\n",
      "Epoch 120/200,   Variance Loss: -88.0486\n",
      "Epoch 130/200,   Variance Loss: -88.6272\n",
      "Epoch 140/200,   Variance Loss: -88.9416\n",
      "Epoch 150/200,   Variance Loss: -89.2047\n",
      "Epoch 160/200,   Variance Loss: -88.7040\n",
      "Epoch 170/200,   Variance Loss: -89.1598\n",
      "Epoch 180/200,   Variance Loss: -89.3886\n",
      "Epoch 190/200,   Variance Loss: -89.3845\n",
      "Epoch 200/200,   Variance Loss: -89.3382\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 15.3262\n",
      "Epoch 20/200,   Variance Loss: -50.3465\n",
      "Epoch 30/200,   Variance Loss: -65.3071\n",
      "Epoch 40/200,   Variance Loss: -69.6921\n",
      "Epoch 50/200,   Variance Loss: -72.6595\n",
      "Epoch 60/200,   Variance Loss: -73.3725\n",
      "Epoch 70/200,   Variance Loss: -73.8609\n",
      "Epoch 80/200,   Variance Loss: -74.7539\n",
      "Epoch 90/200,   Variance Loss: -77.1513\n",
      "Epoch 100/200,   Variance Loss: -79.6639\n",
      "Epoch 110/200,   Variance Loss: -79.9397\n",
      "Epoch 120/200,   Variance Loss: -80.2371\n",
      "Epoch 130/200,   Variance Loss: -80.1577\n",
      "Epoch 140/200,   Variance Loss: -80.2563\n",
      "Epoch 150/200,   Variance Loss: -80.2876\n",
      "Epoch 160/200,   Variance Loss: -80.3102\n",
      "Epoch 170/200,   Variance Loss: -80.2509\n",
      "Epoch 180/200,   Variance Loss: -80.1750\n",
      "Epoch 190/200,   Variance Loss: -80.3473\n",
      "Epoch 200/200,   Variance Loss: -80.3338\n",
      "Epoch 10/200,   Variance Loss: 13.2694\n",
      "Epoch 20/200,   Variance Loss: -60.3785\n",
      "Epoch 30/200,   Variance Loss: -71.5764\n",
      "Epoch 40/200,   Variance Loss: -73.7985\n",
      "Epoch 50/200,   Variance Loss: -74.8622\n",
      "Epoch 60/200,   Variance Loss: -76.0883\n",
      "Epoch 70/200,   Variance Loss: -78.4464\n",
      "Epoch 80/200,   Variance Loss: -81.4322\n",
      "Epoch 90/200,   Variance Loss: -83.7295\n",
      "Epoch 100/200,   Variance Loss: -85.1928\n",
      "Epoch 110/200,   Variance Loss: -86.3455\n",
      "Epoch 120/200,   Variance Loss: -87.1922\n",
      "Epoch 130/200,   Variance Loss: -87.4790\n",
      "Epoch 140/200,   Variance Loss: -87.9239\n",
      "Epoch 150/200,   Variance Loss: -88.1406\n",
      "Epoch 160/200,   Variance Loss: -88.2422\n",
      "Epoch 170/200,   Variance Loss: -88.3445\n",
      "Epoch 180/200,   Variance Loss: -88.4038\n",
      "Epoch 190/200,   Variance Loss: -88.5983\n",
      "Epoch 200/200,   Variance Loss: -88.5664\n",
      "Epoch 10/200,   Variance Loss: 9.1969\n",
      "Epoch 20/200,   Variance Loss: -66.9059\n",
      "Epoch 30/200,   Variance Loss: -71.4653\n",
      "Epoch 40/200,   Variance Loss: -73.0104\n",
      "Epoch 50/200,   Variance Loss: -73.4512\n",
      "Epoch 60/200,   Variance Loss: -73.6060\n",
      "Epoch 70/200,   Variance Loss: -74.1024\n",
      "Epoch 80/200,   Variance Loss: -74.7549\n",
      "Epoch 90/200,   Variance Loss: -76.1103\n",
      "Epoch 100/200,   Variance Loss: -79.8952\n",
      "Epoch 110/200,   Variance Loss: -83.9570\n",
      "Epoch 120/200,   Variance Loss: -85.3663\n",
      "Epoch 130/200,   Variance Loss: -86.7978\n",
      "Epoch 140/200,   Variance Loss: -87.6590\n",
      "Epoch 150/200,   Variance Loss: -87.8484\n",
      "Epoch 160/200,   Variance Loss: -87.9093\n",
      "Epoch 170/200,   Variance Loss: -88.2437\n",
      "Epoch 180/200,   Variance Loss: -88.3083\n",
      "Epoch 190/200,   Variance Loss: -88.3209\n",
      "Epoch 200/200,   Variance Loss: -88.5815\n",
      "Epoch 10/200,   Variance Loss: 23.1632\n",
      "Epoch 20/200,   Variance Loss: -31.4341\n",
      "Epoch 30/200,   Variance Loss: -67.6691\n",
      "Epoch 40/200,   Variance Loss: -71.8465\n",
      "Epoch 50/200,   Variance Loss: -74.2238\n",
      "Epoch 60/200,   Variance Loss: -75.0973\n",
      "Epoch 70/200,   Variance Loss: -75.8657\n",
      "Epoch 80/200,   Variance Loss: -76.9018\n",
      "Epoch 90/200,   Variance Loss: -77.9396\n",
      "Epoch 100/200,   Variance Loss: -79.5000\n",
      "Epoch 110/200,   Variance Loss: -81.8208\n",
      "Epoch 120/200,   Variance Loss: -84.5222\n",
      "Epoch 130/200,   Variance Loss: -85.8366\n",
      "Epoch 140/200,   Variance Loss: -86.6532\n",
      "Epoch 150/200,   Variance Loss: -87.2710\n",
      "Epoch 160/200,   Variance Loss: -87.2370\n",
      "Epoch 170/200,   Variance Loss: -87.8216\n",
      "Epoch 180/200,   Variance Loss: -88.1342\n",
      "Epoch 190/200,   Variance Loss: -88.2902\n",
      "Epoch 200/200,   Variance Loss: -88.3479\n",
      "Epoch 10/200,   Variance Loss: 5.1227\n",
      "Epoch 20/200,   Variance Loss: -67.2211\n",
      "Epoch 30/200,   Variance Loss: -71.5263\n",
      "Epoch 40/200,   Variance Loss: -73.0006\n",
      "Epoch 50/200,   Variance Loss: -73.3521\n",
      "Epoch 60/200,   Variance Loss: -73.8335\n",
      "Epoch 70/200,   Variance Loss: -74.5486\n",
      "Epoch 80/200,   Variance Loss: -76.2346\n",
      "Epoch 90/200,   Variance Loss: -79.2434\n",
      "Epoch 100/200,   Variance Loss: -83.3521\n",
      "Epoch 110/200,   Variance Loss: -84.1445\n",
      "Epoch 120/200,   Variance Loss: -84.2202\n",
      "Epoch 130/200,   Variance Loss: -84.3476\n",
      "Epoch 140/200,   Variance Loss: -84.3738\n",
      "Epoch 150/200,   Variance Loss: -84.3229\n",
      "Epoch 160/200,   Variance Loss: -84.5880\n",
      "Epoch 170/200,   Variance Loss: -84.5840\n",
      "Epoch 180/200,   Variance Loss: -84.6621\n",
      "Epoch 190/200,   Variance Loss: -84.7763\n",
      "Epoch 200/200,   Variance Loss: -84.7956\n",
      "Epoch 10/200,   Variance Loss: -4.9069\n",
      "Epoch 20/200,   Variance Loss: -67.3207\n",
      "Epoch 30/200,   Variance Loss: -71.2732\n",
      "Epoch 40/200,   Variance Loss: -73.7183\n",
      "Epoch 50/200,   Variance Loss: -76.0107\n",
      "Epoch 60/200,   Variance Loss: -79.3473\n",
      "Epoch 70/200,   Variance Loss: -80.1151\n",
      "Epoch 80/200,   Variance Loss: -80.1627\n",
      "Epoch 90/200,   Variance Loss: -80.2365\n",
      "Epoch 100/200,   Variance Loss: -80.2788\n",
      "Epoch 110/200,   Variance Loss: -80.2579\n",
      "Epoch 120/200,   Variance Loss: -80.1309\n",
      "Epoch 130/200,   Variance Loss: -80.2857\n",
      "Epoch 140/200,   Variance Loss: -80.3693\n",
      "Epoch 150/200,   Variance Loss: -80.2506\n",
      "Epoch 160/200,   Variance Loss: -80.3323\n",
      "Epoch 170/200,   Variance Loss: -80.3984\n",
      "Epoch 180/200,   Variance Loss: -80.3633\n",
      "Epoch 190/200,   Variance Loss: -80.2592\n",
      "Epoch 200/200,   Variance Loss: -80.2699\n",
      "Epoch 10/200,   Variance Loss: 11.2076\n",
      "Epoch 20/200,   Variance Loss: -55.7434\n",
      "Epoch 30/200,   Variance Loss: -67.7493\n",
      "Epoch 40/200,   Variance Loss: -72.2940\n",
      "Epoch 50/200,   Variance Loss: -73.0643\n",
      "Epoch 60/200,   Variance Loss: -73.3552\n",
      "Epoch 70/200,   Variance Loss: -73.5815\n",
      "Epoch 80/200,   Variance Loss: -74.0974\n",
      "Epoch 90/200,   Variance Loss: -75.3820\n",
      "Epoch 100/200,   Variance Loss: -79.4064\n",
      "Epoch 110/200,   Variance Loss: -83.7389\n",
      "Epoch 120/200,   Variance Loss: -85.4966\n",
      "Epoch 130/200,   Variance Loss: -87.0671\n",
      "Epoch 140/200,   Variance Loss: -87.6194\n",
      "Epoch 150/200,   Variance Loss: -87.9083\n",
      "Epoch 160/200,   Variance Loss: -88.1723\n",
      "Epoch 170/200,   Variance Loss: -88.4411\n",
      "Epoch 180/200,   Variance Loss: -88.6438\n",
      "Epoch 190/200,   Variance Loss: -88.4799\n",
      "Epoch 200/200,   Variance Loss: -88.8324\n",
      "Epoch 10/200,   Variance Loss: 13.4759\n",
      "Epoch 20/200,   Variance Loss: -62.8956\n",
      "Epoch 30/200,   Variance Loss: -70.8844\n",
      "Epoch 40/200,   Variance Loss: -72.9234\n",
      "Epoch 50/200,   Variance Loss: -73.8456\n",
      "Epoch 60/200,   Variance Loss: -74.7560\n",
      "Epoch 70/200,   Variance Loss: -76.3769\n",
      "Epoch 80/200,   Variance Loss: -79.2162\n",
      "Epoch 90/200,   Variance Loss: -80.1912\n",
      "Epoch 100/200,   Variance Loss: -80.2797\n",
      "Epoch 110/200,   Variance Loss: -80.2860\n",
      "Epoch 120/200,   Variance Loss: -80.4172\n",
      "Epoch 130/200,   Variance Loss: -80.5082\n",
      "Epoch 140/200,   Variance Loss: -80.4905\n",
      "Epoch 150/200,   Variance Loss: -81.2680\n",
      "Epoch 160/200,   Variance Loss: -82.5520\n",
      "Epoch 170/200,   Variance Loss: -83.4433\n",
      "Epoch 180/200,   Variance Loss: -83.7307\n",
      "Epoch 190/200,   Variance Loss: -83.7897\n",
      "Epoch 200/200,   Variance Loss: -84.2904\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -46.4068\n",
      "Epoch 20/50,   Variance Loss: -69.1435\n",
      "Epoch 30/50,   Variance Loss: -78.1487\n",
      "Epoch 40/50,   Variance Loss: -78.4282\n",
      "Epoch 50/50,   Variance Loss: -78.4351\n",
      "Epoch 10/200,   Variance Loss: -45.1166\n",
      "Epoch 20/200,   Variance Loss: -67.4311\n",
      "Epoch 30/200,   Variance Loss: -74.8043\n",
      "Epoch 40/200,   Variance Loss: -78.0344\n",
      "Epoch 50/200,   Variance Loss: -80.1853\n",
      "Epoch 60/200,   Variance Loss: -83.4137\n",
      "Epoch 70/200,   Variance Loss: -85.1407\n",
      "Epoch 80/200,   Variance Loss: -85.8018\n",
      "Epoch 90/200,   Variance Loss: -85.9855\n",
      "Epoch 100/200,   Variance Loss: -86.3059\n",
      "Epoch 110/200,   Variance Loss: -86.5709\n",
      "Epoch 120/200,   Variance Loss: -86.7500\n",
      "Epoch 130/200,   Variance Loss: -86.9616\n",
      "Epoch 140/200,   Variance Loss: -86.9695\n",
      "Epoch 150/200,   Variance Loss: -87.1974\n",
      "Epoch 160/200,   Variance Loss: -87.4242\n",
      "Epoch 170/200,   Variance Loss: -87.5757\n",
      "Epoch 180/200,   Variance Loss: -87.4124\n",
      "Epoch 190/200,   Variance Loss: -87.6039\n",
      "Epoch 200/200,   Variance Loss: -87.6741\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -46.8359\n",
      "Epoch 20/200,   Variance Loss: -73.2875\n",
      "Epoch 30/200,   Variance Loss: -75.4234\n",
      "Epoch 40/200,   Variance Loss: -77.6106\n",
      "Epoch 50/200,   Variance Loss: -78.7039\n",
      "Epoch 60/200,   Variance Loss: -80.0456\n",
      "Epoch 70/200,   Variance Loss: -81.9029\n",
      "Epoch 80/200,   Variance Loss: -84.9079\n",
      "Epoch 90/200,   Variance Loss: -86.4807\n",
      "Epoch 100/200,   Variance Loss: -86.8316\n",
      "Epoch 110/200,   Variance Loss: -87.0448\n",
      "Epoch 120/200,   Variance Loss: -87.3577\n",
      "Epoch 130/200,   Variance Loss: -87.5361\n",
      "Epoch 140/200,   Variance Loss: -87.5738\n",
      "Epoch 150/200,   Variance Loss: -87.7404\n",
      "Epoch 160/200,   Variance Loss: -87.7721\n",
      "Epoch 170/200,   Variance Loss: -87.8893\n",
      "Epoch 180/200,   Variance Loss: -87.6797\n",
      "Epoch 190/200,   Variance Loss: -88.1229\n",
      "Epoch 200/200,   Variance Loss: -88.2161\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -45.7763\n",
      "Epoch 20/200,   Variance Loss: -71.3794\n",
      "Epoch 30/200,   Variance Loss: -76.1009\n",
      "Epoch 40/200,   Variance Loss: -78.2836\n",
      "Epoch 50/200,   Variance Loss: -79.8204\n",
      "Epoch 60/200,   Variance Loss: -82.1881\n",
      "Epoch 70/200,   Variance Loss: -85.7444\n",
      "Epoch 80/200,   Variance Loss: -86.6920\n",
      "Epoch 90/200,   Variance Loss: -86.8865\n",
      "Epoch 100/200,   Variance Loss: -87.2106\n",
      "Epoch 110/200,   Variance Loss: -87.3781\n",
      "Epoch 120/200,   Variance Loss: -87.6297\n",
      "Epoch 130/200,   Variance Loss: -87.7722\n",
      "Epoch 140/200,   Variance Loss: -87.6737\n",
      "Epoch 150/200,   Variance Loss: -87.9515\n",
      "Epoch 160/200,   Variance Loss: -88.1403\n",
      "Epoch 170/200,   Variance Loss: -88.0945\n",
      "Epoch 180/200,   Variance Loss: -88.4429\n",
      "Epoch 190/200,   Variance Loss: -88.3685\n",
      "Epoch 200/200,   Variance Loss: -88.7561\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -46.0806\n",
      "Epoch 20/200,   Variance Loss: -71.6788\n",
      "Epoch 30/200,   Variance Loss: -75.1952\n",
      "Epoch 40/200,   Variance Loss: -77.0202\n",
      "Epoch 50/200,   Variance Loss: -77.8209\n",
      "Epoch 60/200,   Variance Loss: -79.6915\n",
      "Epoch 70/200,   Variance Loss: -82.2416\n",
      "Epoch 80/200,   Variance Loss: -83.3956\n",
      "Epoch 90/200,   Variance Loss: -86.1504\n",
      "Epoch 100/200,   Variance Loss: -86.9019\n",
      "Epoch 110/200,   Variance Loss: -87.1127\n",
      "Epoch 120/200,   Variance Loss: -87.4200\n",
      "Epoch 130/200,   Variance Loss: -87.6096\n",
      "Epoch 140/200,   Variance Loss: -87.8313\n",
      "Epoch 150/200,   Variance Loss: -87.8959\n",
      "Epoch 160/200,   Variance Loss: -88.0676\n",
      "Epoch 170/200,   Variance Loss: -88.2064\n",
      "Epoch 180/200,   Variance Loss: -88.2826\n",
      "Epoch 190/200,   Variance Loss: -88.5392\n",
      "Epoch 200/200,   Variance Loss: -88.6710\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 11.0305\n",
      "Epoch 20/200,   Variance Loss: -64.6200\n",
      "Epoch 30/200,   Variance Loss: -71.7840\n",
      "Epoch 40/200,   Variance Loss: -74.6799\n",
      "Epoch 50/200,   Variance Loss: -75.5866\n",
      "Epoch 60/200,   Variance Loss: -76.0980\n",
      "Epoch 70/200,   Variance Loss: -76.6970\n",
      "Epoch 80/200,   Variance Loss: -77.3517\n",
      "Epoch 90/200,   Variance Loss: -78.2813\n",
      "Epoch 100/200,   Variance Loss: -79.7064\n",
      "Epoch 110/200,   Variance Loss: -81.8400\n",
      "Epoch 120/200,   Variance Loss: -84.6704\n",
      "Epoch 130/200,   Variance Loss: -86.5635\n",
      "Epoch 140/200,   Variance Loss: -87.0769\n",
      "Epoch 150/200,   Variance Loss: -87.4242\n",
      "Epoch 160/200,   Variance Loss: -87.6172\n",
      "Epoch 170/200,   Variance Loss: -87.9739\n",
      "Epoch 180/200,   Variance Loss: -88.1315\n",
      "Epoch 190/200,   Variance Loss: -88.4298\n",
      "Epoch 200/200,   Variance Loss: -88.6613\n",
      "Epoch 10/200,   Variance Loss: 7.4713\n",
      "Epoch 20/200,   Variance Loss: -69.9967\n",
      "Epoch 30/200,   Variance Loss: -71.8916\n",
      "Epoch 40/200,   Variance Loss: -74.6511\n",
      "Epoch 50/200,   Variance Loss: -75.6497\n",
      "Epoch 60/200,   Variance Loss: -77.6368\n",
      "Epoch 70/200,   Variance Loss: -81.4708\n",
      "Epoch 80/200,   Variance Loss: -85.2785\n",
      "Epoch 90/200,   Variance Loss: -86.0506\n",
      "Epoch 100/200,   Variance Loss: -86.4193\n",
      "Epoch 110/200,   Variance Loss: -86.8925\n",
      "Epoch 120/200,   Variance Loss: -87.2776\n",
      "Epoch 130/200,   Variance Loss: -87.8492\n",
      "Epoch 140/200,   Variance Loss: -88.2177\n",
      "Epoch 150/200,   Variance Loss: -88.5384\n",
      "Epoch 160/200,   Variance Loss: -88.7316\n",
      "Epoch 170/200,   Variance Loss: -89.0689\n",
      "Epoch 180/200,   Variance Loss: -89.2547\n",
      "Epoch 190/200,   Variance Loss: -89.1334\n",
      "Epoch 200/200,   Variance Loss: -89.3986\n",
      "Epoch 10/200,   Variance Loss: -0.4970\n",
      "Epoch 20/200,   Variance Loss: -67.3740\n",
      "Epoch 30/200,   Variance Loss: -71.9686\n",
      "Epoch 40/200,   Variance Loss: -74.5018\n",
      "Epoch 50/200,   Variance Loss: -75.3945\n",
      "Epoch 60/200,   Variance Loss: -76.8547\n",
      "Epoch 70/200,   Variance Loss: -79.3729\n",
      "Epoch 80/200,   Variance Loss: -81.3793\n",
      "Epoch 90/200,   Variance Loss: -81.9086\n",
      "Epoch 100/200,   Variance Loss: -83.9673\n",
      "Epoch 110/200,   Variance Loss: -85.9583\n",
      "Epoch 120/200,   Variance Loss: -86.4371\n",
      "Epoch 130/200,   Variance Loss: -86.6805\n",
      "Epoch 140/200,   Variance Loss: -87.1051\n",
      "Epoch 150/200,   Variance Loss: -87.4381\n",
      "Epoch 160/200,   Variance Loss: -88.1420\n",
      "Epoch 170/200,   Variance Loss: -88.5326\n",
      "Epoch 180/200,   Variance Loss: -88.7326\n",
      "Epoch 190/200,   Variance Loss: -88.8211\n",
      "Epoch 200/200,   Variance Loss: -88.8856\n",
      "Epoch 10/200,   Variance Loss: 7.8598\n",
      "Epoch 20/200,   Variance Loss: -71.0033\n",
      "Epoch 30/200,   Variance Loss: -71.8070\n",
      "Epoch 40/200,   Variance Loss: -75.0158\n",
      "Epoch 50/200,   Variance Loss: -75.8580\n",
      "Epoch 60/200,   Variance Loss: -77.4237\n",
      "Epoch 70/200,   Variance Loss: -81.0660\n",
      "Epoch 80/200,   Variance Loss: -85.1892\n",
      "Epoch 90/200,   Variance Loss: -86.0514\n",
      "Epoch 100/200,   Variance Loss: -86.6340\n",
      "Epoch 110/200,   Variance Loss: -86.9860\n",
      "Epoch 120/200,   Variance Loss: -87.2848\n",
      "Epoch 130/200,   Variance Loss: -87.8469\n",
      "Epoch 140/200,   Variance Loss: -88.0441\n",
      "Epoch 150/200,   Variance Loss: -88.4619\n",
      "Epoch 160/200,   Variance Loss: -88.5808\n",
      "Epoch 170/200,   Variance Loss: -88.7884\n",
      "Epoch 180/200,   Variance Loss: -89.2297\n",
      "Epoch 190/200,   Variance Loss: -89.2384\n",
      "Epoch 200/200,   Variance Loss: -89.5474\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 14.9383\n",
      "Epoch 20/200,   Variance Loss: -55.5514\n",
      "Epoch 30/200,   Variance Loss: -71.8860\n",
      "Epoch 40/200,   Variance Loss: -74.7641\n",
      "Epoch 50/200,   Variance Loss: -76.1147\n",
      "Epoch 60/200,   Variance Loss: -77.0522\n",
      "Epoch 70/200,   Variance Loss: -78.4944\n",
      "Epoch 80/200,   Variance Loss: -81.1670\n",
      "Epoch 90/200,   Variance Loss: -84.6960\n",
      "Epoch 100/200,   Variance Loss: -85.8817\n",
      "Epoch 110/200,   Variance Loss: -86.3724\n",
      "Epoch 120/200,   Variance Loss: -86.6077\n",
      "Epoch 130/200,   Variance Loss: -87.0397\n",
      "Epoch 140/200,   Variance Loss: -87.4645\n",
      "Epoch 150/200,   Variance Loss: -87.7847\n",
      "Epoch 160/200,   Variance Loss: -88.1133\n",
      "Epoch 170/200,   Variance Loss: -88.0577\n",
      "Epoch 180/200,   Variance Loss: -88.5539\n",
      "Epoch 190/200,   Variance Loss: -88.8407\n",
      "Epoch 200/200,   Variance Loss: -88.6311\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -44.2917\n",
      "Epoch 20/50,   Variance Loss: -63.3705\n",
      "Epoch 30/50,   Variance Loss: -76.9553\n",
      "Epoch 40/50,   Variance Loss: -78.3295\n",
      "Epoch 50/50,   Variance Loss: -78.4220\n",
      "Epoch 10/200,   Variance Loss: -45.2220\n",
      "Epoch 20/200,   Variance Loss: -69.1288\n",
      "Epoch 30/200,   Variance Loss: -74.8053\n",
      "Epoch 40/200,   Variance Loss: -76.1866\n",
      "Epoch 50/200,   Variance Loss: -76.6165\n",
      "Epoch 60/200,   Variance Loss: -77.3445\n",
      "Epoch 70/200,   Variance Loss: -79.2067\n",
      "Epoch 80/200,   Variance Loss: -81.3729\n",
      "Epoch 90/200,   Variance Loss: -82.2241\n",
      "Epoch 100/200,   Variance Loss: -82.6213\n",
      "Epoch 110/200,   Variance Loss: -82.7325\n",
      "Epoch 120/200,   Variance Loss: -83.0115\n",
      "Epoch 130/200,   Variance Loss: -83.4122\n",
      "Epoch 140/200,   Variance Loss: -83.4219\n",
      "Epoch 150/200,   Variance Loss: -83.3272\n",
      "Epoch 160/200,   Variance Loss: -83.5783\n",
      "Epoch 170/200,   Variance Loss: -83.6181\n",
      "Epoch 180/200,   Variance Loss: -83.7206\n",
      "Epoch 190/200,   Variance Loss: -83.5520\n",
      "Epoch 200/200,   Variance Loss: -83.7243\n",
      "Epoch 10/200,   Variance Loss: -39.8293\n",
      "Epoch 20/200,   Variance Loss: -58.9803\n",
      "Epoch 30/200,   Variance Loss: -72.2503\n",
      "Epoch 40/200,   Variance Loss: -74.7023\n",
      "Epoch 50/200,   Variance Loss: -75.5402\n",
      "Epoch 60/200,   Variance Loss: -76.5225\n",
      "Epoch 70/200,   Variance Loss: -77.6471\n",
      "Epoch 80/200,   Variance Loss: -78.3815\n",
      "Epoch 90/200,   Variance Loss: -78.6133\n",
      "Epoch 100/200,   Variance Loss: -78.9250\n",
      "Epoch 110/200,   Variance Loss: -79.5357\n",
      "Epoch 120/200,   Variance Loss: -80.1210\n",
      "Epoch 130/200,   Variance Loss: -80.7432\n",
      "Epoch 140/200,   Variance Loss: -80.8078\n",
      "Epoch 150/200,   Variance Loss: -80.6943\n",
      "Epoch 160/200,   Variance Loss: -81.1385\n",
      "Epoch 170/200,   Variance Loss: -81.0580\n",
      "Epoch 180/200,   Variance Loss: -80.9361\n",
      "Epoch 190/200,   Variance Loss: -81.0892\n",
      "Epoch 200/200,   Variance Loss: -81.3178\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -42.1046\n",
      "Epoch 20/200,   Variance Loss: -71.0155\n",
      "Epoch 30/200,   Variance Loss: -73.9066\n",
      "Epoch 40/200,   Variance Loss: -75.4843\n",
      "Epoch 50/200,   Variance Loss: -76.2241\n",
      "Epoch 60/200,   Variance Loss: -77.4711\n",
      "Epoch 70/200,   Variance Loss: -78.5910\n",
      "Epoch 80/200,   Variance Loss: -79.4931\n",
      "Epoch 90/200,   Variance Loss: -80.3297\n",
      "Epoch 100/200,   Variance Loss: -80.7102\n",
      "Epoch 110/200,   Variance Loss: -80.8346\n",
      "Epoch 120/200,   Variance Loss: -80.8368\n",
      "Epoch 130/200,   Variance Loss: -80.7499\n",
      "Epoch 140/200,   Variance Loss: -80.7611\n",
      "Epoch 150/200,   Variance Loss: -80.7976\n",
      "Epoch 160/200,   Variance Loss: -80.7848\n",
      "Epoch 170/200,   Variance Loss: -80.9343\n",
      "Epoch 180/200,   Variance Loss: -80.8890\n",
      "Epoch 190/200,   Variance Loss: -80.8638\n",
      "Epoch 200/200,   Variance Loss: -80.6990\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -40.7617\n",
      "Epoch 20/200,   Variance Loss: -64.6304\n",
      "Epoch 30/200,   Variance Loss: -70.1117\n",
      "Epoch 40/200,   Variance Loss: -74.1156\n",
      "Epoch 50/200,   Variance Loss: -81.3770\n",
      "Epoch 60/200,   Variance Loss: -83.9624\n",
      "Epoch 70/200,   Variance Loss: -84.4277\n",
      "Epoch 80/200,   Variance Loss: -85.5832\n",
      "Epoch 90/200,   Variance Loss: -86.3583\n",
      "Epoch 100/200,   Variance Loss: -86.7130\n",
      "Epoch 110/200,   Variance Loss: -86.8028\n",
      "Epoch 120/200,   Variance Loss: -87.0445\n",
      "Epoch 130/200,   Variance Loss: -87.2041\n",
      "Epoch 140/200,   Variance Loss: -87.0073\n",
      "Epoch 150/200,   Variance Loss: -87.0672\n",
      "Epoch 160/200,   Variance Loss: -87.3484\n",
      "Epoch 170/200,   Variance Loss: -87.5131\n",
      "Epoch 180/200,   Variance Loss: -87.4538\n",
      "Epoch 190/200,   Variance Loss: -87.4420\n",
      "Epoch 200/200,   Variance Loss: -87.4821\n",
      "Epoch 10/200,   Variance Loss: -41.3162\n",
      "Epoch 20/200,   Variance Loss: -64.6523\n",
      "Epoch 30/200,   Variance Loss: -73.6596\n",
      "Epoch 40/200,   Variance Loss: -75.8950\n",
      "Epoch 50/200,   Variance Loss: -77.0247\n",
      "Epoch 60/200,   Variance Loss: -78.7214\n",
      "Epoch 70/200,   Variance Loss: -81.9316\n",
      "Epoch 80/200,   Variance Loss: -84.7299\n",
      "Epoch 90/200,   Variance Loss: -85.5748\n",
      "Epoch 100/200,   Variance Loss: -85.8181\n",
      "Epoch 110/200,   Variance Loss: -86.3171\n",
      "Epoch 120/200,   Variance Loss: -86.7413\n",
      "Epoch 130/200,   Variance Loss: -87.0057\n",
      "Epoch 140/200,   Variance Loss: -87.1566\n",
      "Epoch 150/200,   Variance Loss: -87.3161\n",
      "Epoch 160/200,   Variance Loss: -87.3276\n",
      "Epoch 170/200,   Variance Loss: -87.5105\n",
      "Epoch 180/200,   Variance Loss: -87.6116\n",
      "Epoch 190/200,   Variance Loss: -87.5488\n",
      "Epoch 200/200,   Variance Loss: -87.6175\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -44.0819\n",
      "Epoch 20/200,   Variance Loss: -69.6206\n",
      "Epoch 30/200,   Variance Loss: -73.7003\n",
      "Epoch 40/200,   Variance Loss: -76.1402\n",
      "Epoch 50/200,   Variance Loss: -78.2918\n",
      "Epoch 60/200,   Variance Loss: -80.2346\n",
      "Epoch 70/200,   Variance Loss: -80.6591\n",
      "Epoch 80/200,   Variance Loss: -80.6675\n",
      "Epoch 90/200,   Variance Loss: -81.0183\n",
      "Epoch 100/200,   Variance Loss: -80.9919\n",
      "Epoch 110/200,   Variance Loss: -80.9474\n",
      "Epoch 120/200,   Variance Loss: -81.1546\n",
      "Epoch 130/200,   Variance Loss: -80.7582\n",
      "Epoch 140/200,   Variance Loss: -81.1401\n",
      "Epoch 150/200,   Variance Loss: -81.1805\n",
      "Epoch 160/200,   Variance Loss: -81.2916\n",
      "Epoch 170/200,   Variance Loss: -80.8189\n",
      "Epoch 180/200,   Variance Loss: -81.2606\n",
      "Epoch 190/200,   Variance Loss: -81.4042\n",
      "Epoch 200/200,   Variance Loss: -81.1579\n",
      "Epoch 10/200,   Variance Loss: -44.3633\n",
      "Epoch 20/200,   Variance Loss: -70.9762\n",
      "Epoch 30/200,   Variance Loss: -73.6993\n",
      "Epoch 40/200,   Variance Loss: -75.4470\n",
      "Epoch 50/200,   Variance Loss: -77.0320\n",
      "Epoch 60/200,   Variance Loss: -78.0495\n",
      "Epoch 70/200,   Variance Loss: -78.4738\n",
      "Epoch 80/200,   Variance Loss: -79.0602\n",
      "Epoch 90/200,   Variance Loss: -79.6893\n",
      "Epoch 100/200,   Variance Loss: -78.7430\n",
      "Epoch 110/200,   Variance Loss: -80.7722\n",
      "Epoch 120/200,   Variance Loss: -80.8667\n",
      "Epoch 130/200,   Variance Loss: -80.9924\n",
      "Epoch 140/200,   Variance Loss: -81.1210\n",
      "Epoch 150/200,   Variance Loss: -81.1180\n",
      "Epoch 160/200,   Variance Loss: -81.0744\n",
      "Epoch 170/200,   Variance Loss: -81.0431\n",
      "Epoch 180/200,   Variance Loss: -81.0658\n",
      "Epoch 190/200,   Variance Loss: -81.0664\n",
      "Epoch 200/200,   Variance Loss: -81.2109\n",
      "Epoch 10/200,   Variance Loss: 10.8512\n",
      "Epoch 20/200,   Variance Loss: -65.8551\n",
      "Epoch 30/200,   Variance Loss: -71.7560\n",
      "Epoch 40/200,   Variance Loss: -73.4409\n",
      "Epoch 50/200,   Variance Loss: -74.2537\n",
      "Epoch 60/200,   Variance Loss: -75.6303\n",
      "Epoch 70/200,   Variance Loss: -77.6190\n",
      "Epoch 80/200,   Variance Loss: -79.5121\n",
      "Epoch 90/200,   Variance Loss: -80.6153\n",
      "Epoch 100/200,   Variance Loss: -81.1645\n",
      "Epoch 110/200,   Variance Loss: -81.4256\n",
      "Epoch 120/200,   Variance Loss: -81.6536\n",
      "Epoch 130/200,   Variance Loss: -81.8731\n",
      "Epoch 140/200,   Variance Loss: -82.0498\n",
      "Epoch 150/200,   Variance Loss: -82.2170\n",
      "Epoch 160/200,   Variance Loss: -82.3030\n",
      "Epoch 170/200,   Variance Loss: -82.5860\n",
      "Epoch 180/200,   Variance Loss: -83.2555\n",
      "Epoch 190/200,   Variance Loss: -86.8628\n",
      "Epoch 200/200,   Variance Loss: -87.3166\n",
      "Epoch 10/200,   Variance Loss: 14.5031\n",
      "Epoch 20/200,   Variance Loss: -59.9624\n",
      "Epoch 30/200,   Variance Loss: -70.6634\n",
      "Epoch 40/200,   Variance Loss: -73.1224\n",
      "Epoch 50/200,   Variance Loss: -73.7755\n",
      "Epoch 60/200,   Variance Loss: -74.3708\n",
      "Epoch 70/200,   Variance Loss: -75.1241\n",
      "Epoch 80/200,   Variance Loss: -76.6376\n",
      "Epoch 90/200,   Variance Loss: -78.7816\n",
      "Epoch 100/200,   Variance Loss: -81.5342\n",
      "Epoch 110/200,   Variance Loss: -84.3607\n",
      "Epoch 120/200,   Variance Loss: -85.7315\n",
      "Epoch 130/200,   Variance Loss: -86.5538\n",
      "Epoch 140/200,   Variance Loss: -87.0513\n",
      "Epoch 150/200,   Variance Loss: -87.4760\n",
      "Epoch 160/200,   Variance Loss: -87.8967\n",
      "Epoch 170/200,   Variance Loss: -88.1803\n",
      "Epoch 180/200,   Variance Loss: -88.8628\n",
      "Epoch 190/200,   Variance Loss: -89.0667\n",
      "Epoch 200/200,   Variance Loss: -89.3777\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -47.0342\n",
      "Epoch 20/50,   Variance Loss: -73.7846\n",
      "Epoch 30/50,   Variance Loss: -77.9037\n",
      "Epoch 40/50,   Variance Loss: -78.1273\n",
      "Epoch 50/50,   Variance Loss: -78.2755\n",
      "Epoch 10/200,   Variance Loss: -42.5650\n",
      "Epoch 20/200,   Variance Loss: -68.7507\n",
      "Epoch 30/200,   Variance Loss: -74.5118\n",
      "Epoch 40/200,   Variance Loss: -75.7923\n",
      "Epoch 50/200,   Variance Loss: -76.1242\n",
      "Epoch 60/200,   Variance Loss: -77.0282\n",
      "Epoch 70/200,   Variance Loss: -78.7677\n",
      "Epoch 80/200,   Variance Loss: -81.0446\n",
      "Epoch 90/200,   Variance Loss: -84.1006\n",
      "Epoch 100/200,   Variance Loss: -85.4086\n",
      "Epoch 110/200,   Variance Loss: -85.6202\n",
      "Epoch 120/200,   Variance Loss: -85.6222\n",
      "Epoch 130/200,   Variance Loss: -85.6250\n",
      "Epoch 140/200,   Variance Loss: -85.7097\n",
      "Epoch 150/200,   Variance Loss: -85.8546\n",
      "Epoch 160/200,   Variance Loss: -86.0023\n",
      "Epoch 170/200,   Variance Loss: -86.0492\n",
      "Epoch 180/200,   Variance Loss: -85.8545\n",
      "Epoch 190/200,   Variance Loss: -86.2652\n",
      "Epoch 200/200,   Variance Loss: -86.3322\n",
      "Epoch 10/200,   Variance Loss: 18.6731\n",
      "Epoch 20/200,   Variance Loss: -61.9586\n",
      "Epoch 30/200,   Variance Loss: -70.9703\n",
      "Epoch 40/200,   Variance Loss: -73.5713\n",
      "Epoch 50/200,   Variance Loss: -73.9800\n",
      "Epoch 60/200,   Variance Loss: -74.5175\n",
      "Epoch 70/200,   Variance Loss: -75.1128\n",
      "Epoch 80/200,   Variance Loss: -76.3336\n",
      "Epoch 90/200,   Variance Loss: -78.9184\n",
      "Epoch 100/200,   Variance Loss: -80.5905\n",
      "Epoch 110/200,   Variance Loss: -81.3413\n",
      "Epoch 120/200,   Variance Loss: -81.4427\n",
      "Epoch 130/200,   Variance Loss: -81.4389\n",
      "Epoch 140/200,   Variance Loss: -81.4758\n",
      "Epoch 150/200,   Variance Loss: -81.2827\n",
      "Epoch 160/200,   Variance Loss: -81.3736\n",
      "Epoch 170/200,   Variance Loss: -81.5294\n",
      "Epoch 180/200,   Variance Loss: -81.4635\n",
      "Epoch 190/200,   Variance Loss: -81.6231\n",
      "Epoch 200/200,   Variance Loss: -81.6465\n",
      "Epoch 10/200,   Variance Loss: 6.8529\n",
      "Epoch 20/200,   Variance Loss: -70.4839\n",
      "Epoch 30/200,   Variance Loss: -71.6511\n",
      "Epoch 40/200,   Variance Loss: -73.4211\n",
      "Epoch 50/200,   Variance Loss: -74.0259\n",
      "Epoch 60/200,   Variance Loss: -75.6010\n",
      "Epoch 70/200,   Variance Loss: -78.6805\n",
      "Epoch 80/200,   Variance Loss: -80.7948\n",
      "Epoch 90/200,   Variance Loss: -81.2342\n",
      "Epoch 100/200,   Variance Loss: -81.4474\n",
      "Epoch 110/200,   Variance Loss: -81.6014\n",
      "Epoch 120/200,   Variance Loss: -81.5309\n",
      "Epoch 130/200,   Variance Loss: -81.5323\n",
      "Epoch 140/200,   Variance Loss: -81.4394\n",
      "Epoch 150/200,   Variance Loss: -81.4615\n",
      "Epoch 160/200,   Variance Loss: -81.6347\n",
      "Epoch 170/200,   Variance Loss: -81.2891\n",
      "Epoch 180/200,   Variance Loss: -81.3669\n",
      "Epoch 190/200,   Variance Loss: -81.3751\n",
      "Epoch 200/200,   Variance Loss: -81.7856\n",
      "Epoch 10/200,   Variance Loss: 13.4713\n",
      "Epoch 20/200,   Variance Loss: -66.8344\n",
      "Epoch 30/200,   Variance Loss: -67.3801\n",
      "Epoch 40/200,   Variance Loss: -70.6106\n",
      "Epoch 50/200,   Variance Loss: -73.7146\n",
      "Epoch 60/200,   Variance Loss: -75.5375\n",
      "Epoch 70/200,   Variance Loss: -79.1881\n",
      "Epoch 80/200,   Variance Loss: -81.1757\n",
      "Epoch 90/200,   Variance Loss: -81.4049\n",
      "Epoch 100/200,   Variance Loss: -81.4416\n",
      "Epoch 110/200,   Variance Loss: -81.4813\n",
      "Epoch 120/200,   Variance Loss: -81.5839\n",
      "Epoch 130/200,   Variance Loss: -81.5005\n",
      "Epoch 140/200,   Variance Loss: -81.3529\n",
      "Epoch 150/200,   Variance Loss: -81.5096\n",
      "Epoch 160/200,   Variance Loss: -81.5562\n",
      "Epoch 170/200,   Variance Loss: -81.5891\n",
      "Epoch 180/200,   Variance Loss: -81.6139\n",
      "Epoch 190/200,   Variance Loss: -81.6731\n",
      "Epoch 200/200,   Variance Loss: -81.4080\n",
      "Epoch 10/200,   Variance Loss: 17.6088\n",
      "Epoch 20/200,   Variance Loss: -52.9380\n",
      "Epoch 30/200,   Variance Loss: -71.0539\n",
      "Epoch 40/200,   Variance Loss: -72.8059\n",
      "Epoch 50/200,   Variance Loss: -73.4196\n",
      "Epoch 60/200,   Variance Loss: -73.9066\n",
      "Epoch 70/200,   Variance Loss: -74.8672\n",
      "Epoch 80/200,   Variance Loss: -77.5364\n",
      "Epoch 90/200,   Variance Loss: -81.8050\n",
      "Epoch 100/200,   Variance Loss: -83.9125\n",
      "Epoch 110/200,   Variance Loss: -84.5753\n",
      "Epoch 120/200,   Variance Loss: -85.5235\n",
      "Epoch 130/200,   Variance Loss: -86.2179\n",
      "Epoch 140/200,   Variance Loss: -86.6528\n",
      "Epoch 150/200,   Variance Loss: -86.7612\n",
      "Epoch 160/200,   Variance Loss: -86.7004\n",
      "Epoch 170/200,   Variance Loss: -86.8762\n",
      "Epoch 180/200,   Variance Loss: -86.8185\n",
      "Epoch 190/200,   Variance Loss: -86.8537\n",
      "Epoch 200/200,   Variance Loss: -86.9259\n",
      "Epoch 10/200,   Variance Loss: 16.7085\n",
      "Epoch 20/200,   Variance Loss: -69.4014\n",
      "Epoch 30/200,   Variance Loss: -71.2189\n",
      "Epoch 40/200,   Variance Loss: -72.9912\n",
      "Epoch 50/200,   Variance Loss: -73.6080\n",
      "Epoch 60/200,   Variance Loss: -74.3149\n",
      "Epoch 70/200,   Variance Loss: -76.5460\n",
      "Epoch 80/200,   Variance Loss: -79.9432\n",
      "Epoch 90/200,   Variance Loss: -81.3701\n",
      "Epoch 100/200,   Variance Loss: -81.4203\n",
      "Epoch 110/200,   Variance Loss: -81.6863\n",
      "Epoch 120/200,   Variance Loss: -81.4338\n",
      "Epoch 130/200,   Variance Loss: -81.6217\n",
      "Epoch 140/200,   Variance Loss: -81.3912\n",
      "Epoch 150/200,   Variance Loss: -81.5585\n",
      "Epoch 160/200,   Variance Loss: -81.4015\n",
      "Epoch 170/200,   Variance Loss: -81.6965\n",
      "Epoch 180/200,   Variance Loss: -81.4814\n",
      "Epoch 190/200,   Variance Loss: -81.8619\n",
      "Epoch 200/200,   Variance Loss: -81.8972\n",
      "Epoch 10/200,   Variance Loss: 12.3793\n",
      "Epoch 20/200,   Variance Loss: -65.6183\n",
      "Epoch 30/200,   Variance Loss: -70.5574\n",
      "Epoch 40/200,   Variance Loss: -72.7515\n",
      "Epoch 50/200,   Variance Loss: -73.2606\n",
      "Epoch 60/200,   Variance Loss: -73.5268\n",
      "Epoch 70/200,   Variance Loss: -73.8118\n",
      "Epoch 80/200,   Variance Loss: -74.5011\n",
      "Epoch 90/200,   Variance Loss: -76.3535\n",
      "Epoch 100/200,   Variance Loss: -79.9734\n",
      "Epoch 110/200,   Variance Loss: -81.2770\n",
      "Epoch 120/200,   Variance Loss: -81.4271\n",
      "Epoch 130/200,   Variance Loss: -81.4899\n",
      "Epoch 140/200,   Variance Loss: -81.4669\n",
      "Epoch 150/200,   Variance Loss: -81.3580\n",
      "Epoch 160/200,   Variance Loss: -81.5133\n",
      "Epoch 170/200,   Variance Loss: -81.5543\n",
      "Epoch 180/200,   Variance Loss: -81.3963\n",
      "Epoch 190/200,   Variance Loss: -81.5811\n",
      "Epoch 200/200,   Variance Loss: -81.5555\n",
      "Epoch 10/200,   Variance Loss: 23.5973\n",
      "Epoch 20/200,   Variance Loss: -49.1484\n",
      "Epoch 30/200,   Variance Loss: -70.3930\n",
      "Epoch 40/200,   Variance Loss: -72.3039\n",
      "Epoch 50/200,   Variance Loss: -73.6053\n",
      "Epoch 60/200,   Variance Loss: -74.3526\n",
      "Epoch 70/200,   Variance Loss: -75.9320\n",
      "Epoch 80/200,   Variance Loss: -79.0169\n",
      "Epoch 90/200,   Variance Loss: -83.0031\n",
      "Epoch 100/200,   Variance Loss: -84.9329\n",
      "Epoch 110/200,   Variance Loss: -85.9946\n",
      "Epoch 120/200,   Variance Loss: -86.4254\n",
      "Epoch 130/200,   Variance Loss: -86.6561\n",
      "Epoch 140/200,   Variance Loss: -86.8811\n",
      "Epoch 150/200,   Variance Loss: -87.0193\n",
      "Epoch 160/200,   Variance Loss: -87.1124\n",
      "Epoch 170/200,   Variance Loss: -87.2590\n",
      "Epoch 180/200,   Variance Loss: -87.2422\n",
      "Epoch 190/200,   Variance Loss: -87.1865\n",
      "Epoch 200/200,   Variance Loss: -87.3866\n",
      "Epoch 10/200,   Variance Loss: 13.4228\n",
      "Epoch 20/200,   Variance Loss: -67.8151\n",
      "Epoch 30/200,   Variance Loss: -70.7477\n",
      "Epoch 40/200,   Variance Loss: -73.0190\n",
      "Epoch 50/200,   Variance Loss: -73.6181\n",
      "Epoch 60/200,   Variance Loss: -74.0810\n",
      "Epoch 70/200,   Variance Loss: -75.1697\n",
      "Epoch 80/200,   Variance Loss: -77.5814\n",
      "Epoch 90/200,   Variance Loss: -80.4756\n",
      "Epoch 100/200,   Variance Loss: -81.2664\n",
      "Epoch 110/200,   Variance Loss: -80.8658\n",
      "Epoch 120/200,   Variance Loss: -81.3322\n",
      "Epoch 130/200,   Variance Loss: -81.3789\n",
      "Epoch 140/200,   Variance Loss: -81.4697\n",
      "Epoch 150/200,   Variance Loss: -81.4079\n",
      "Epoch 160/200,   Variance Loss: -81.4764\n",
      "Epoch 170/200,   Variance Loss: -81.4852\n",
      "Epoch 180/200,   Variance Loss: -81.6542\n",
      "Epoch 190/200,   Variance Loss: -81.6798\n",
      "Epoch 200/200,   Variance Loss: -81.6522\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -49.0590\n",
      "Epoch 20/50,   Variance Loss: -75.4030\n",
      "Epoch 30/50,   Variance Loss: -78.4179\n",
      "Epoch 40/50,   Variance Loss: -78.4270\n",
      "Epoch 50/50,   Variance Loss: -78.4274\n",
      "Epoch 10/200,   Variance Loss: -44.0094\n",
      "Epoch 20/200,   Variance Loss: -67.2979\n",
      "Epoch 30/200,   Variance Loss: -74.4894\n",
      "Epoch 40/200,   Variance Loss: -77.1551\n",
      "Epoch 50/200,   Variance Loss: -79.1616\n",
      "Epoch 60/200,   Variance Loss: -82.7645\n",
      "Epoch 70/200,   Variance Loss: -85.6578\n",
      "Epoch 80/200,   Variance Loss: -86.2399\n",
      "Epoch 90/200,   Variance Loss: -86.8081\n",
      "Epoch 100/200,   Variance Loss: -87.1759\n",
      "Epoch 110/200,   Variance Loss: -87.5226\n",
      "Epoch 120/200,   Variance Loss: -87.6793\n",
      "Epoch 130/200,   Variance Loss: -87.9129\n",
      "Epoch 140/200,   Variance Loss: -88.0799\n",
      "Epoch 150/200,   Variance Loss: -88.0998\n",
      "Epoch 160/200,   Variance Loss: -88.1923\n",
      "Epoch 170/200,   Variance Loss: -88.2819\n",
      "Epoch 180/200,   Variance Loss: -87.9724\n",
      "Epoch 190/200,   Variance Loss: -88.2084\n",
      "Epoch 200/200,   Variance Loss: -88.3640\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 11.4888\n",
      "Epoch 20/200,   Variance Loss: -65.0493\n",
      "Epoch 30/200,   Variance Loss: -71.7055\n",
      "Epoch 40/200,   Variance Loss: -73.3176\n",
      "Epoch 50/200,   Variance Loss: -73.8937\n",
      "Epoch 60/200,   Variance Loss: -74.2416\n",
      "Epoch 70/200,   Variance Loss: -74.9946\n",
      "Epoch 80/200,   Variance Loss: -76.6809\n",
      "Epoch 90/200,   Variance Loss: -79.8877\n",
      "Epoch 100/200,   Variance Loss: -83.8068\n",
      "Epoch 110/200,   Variance Loss: -85.2465\n",
      "Epoch 120/200,   Variance Loss: -86.5413\n",
      "Epoch 130/200,   Variance Loss: -87.7088\n",
      "Epoch 140/200,   Variance Loss: -88.2744\n",
      "Epoch 150/200,   Variance Loss: -88.6595\n",
      "Epoch 160/200,   Variance Loss: -88.8546\n",
      "Epoch 170/200,   Variance Loss: -89.1070\n",
      "Epoch 180/200,   Variance Loss: -89.1987\n",
      "Epoch 190/200,   Variance Loss: -89.3336\n",
      "Epoch 200/200,   Variance Loss: -89.4679\n",
      "Epoch 10/200,   Variance Loss: 22.6081\n",
      "Epoch 20/200,   Variance Loss: -50.3937\n",
      "Epoch 30/200,   Variance Loss: -71.0026\n",
      "Epoch 40/200,   Variance Loss: -74.0060\n",
      "Epoch 50/200,   Variance Loss: -74.8685\n",
      "Epoch 60/200,   Variance Loss: -75.4399\n",
      "Epoch 70/200,   Variance Loss: -76.1804\n",
      "Epoch 80/200,   Variance Loss: -77.1579\n",
      "Epoch 90/200,   Variance Loss: -78.5013\n",
      "Epoch 100/200,   Variance Loss: -81.0841\n",
      "Epoch 110/200,   Variance Loss: -84.2292\n",
      "Epoch 120/200,   Variance Loss: -85.9020\n",
      "Epoch 130/200,   Variance Loss: -87.5734\n",
      "Epoch 140/200,   Variance Loss: -88.2774\n",
      "Epoch 150/200,   Variance Loss: -88.7028\n",
      "Epoch 160/200,   Variance Loss: -89.0079\n",
      "Epoch 170/200,   Variance Loss: -88.9765\n",
      "Epoch 180/200,   Variance Loss: -89.4590\n",
      "Epoch 190/200,   Variance Loss: -89.6129\n",
      "Epoch 200/200,   Variance Loss: -89.5275\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 23.0660\n",
      "Epoch 20/200,   Variance Loss: -45.0203\n",
      "Epoch 30/200,   Variance Loss: -72.5844\n",
      "Epoch 40/200,   Variance Loss: -74.3548\n",
      "Epoch 50/200,   Variance Loss: -75.7467\n",
      "Epoch 60/200,   Variance Loss: -77.0545\n",
      "Epoch 70/200,   Variance Loss: -79.0509\n",
      "Epoch 80/200,   Variance Loss: -82.2794\n",
      "Epoch 90/200,   Variance Loss: -84.1911\n",
      "Epoch 100/200,   Variance Loss: -84.5890\n",
      "Epoch 110/200,   Variance Loss: -84.8727\n",
      "Epoch 120/200,   Variance Loss: -84.9763\n",
      "Epoch 130/200,   Variance Loss: -85.0382\n",
      "Epoch 140/200,   Variance Loss: -85.0462\n",
      "Epoch 150/200,   Variance Loss: -85.1802\n",
      "Epoch 160/200,   Variance Loss: -85.1848\n",
      "Epoch 170/200,   Variance Loss: -85.2499\n",
      "Epoch 180/200,   Variance Loss: -85.2913\n",
      "Epoch 190/200,   Variance Loss: -85.4088\n",
      "Epoch 200/200,   Variance Loss: -85.4308\n",
      "Epoch 10/200,   Variance Loss: 12.5968\n",
      "Epoch 20/200,   Variance Loss: -66.3111\n",
      "Epoch 30/200,   Variance Loss: -72.0181\n",
      "Epoch 40/200,   Variance Loss: -73.8692\n",
      "Epoch 50/200,   Variance Loss: -74.5553\n",
      "Epoch 60/200,   Variance Loss: -75.2155\n",
      "Epoch 70/200,   Variance Loss: -76.3403\n",
      "Epoch 80/200,   Variance Loss: -77.9784\n",
      "Epoch 90/200,   Variance Loss: -80.9893\n",
      "Epoch 100/200,   Variance Loss: -83.8637\n",
      "Epoch 110/200,   Variance Loss: -84.6340\n",
      "Epoch 120/200,   Variance Loss: -84.9044\n",
      "Epoch 130/200,   Variance Loss: -85.1175\n",
      "Epoch 140/200,   Variance Loss: -85.6242\n",
      "Epoch 150/200,   Variance Loss: -86.8792\n",
      "Epoch 160/200,   Variance Loss: -88.0874\n",
      "Epoch 170/200,   Variance Loss: -88.6465\n",
      "Epoch 180/200,   Variance Loss: -88.8178\n",
      "Epoch 190/200,   Variance Loss: -89.0774\n",
      "Epoch 200/200,   Variance Loss: -89.1860\n",
      "Epoch 10/200,   Variance Loss: 12.4295\n",
      "Epoch 20/200,   Variance Loss: -64.4189\n",
      "Epoch 30/200,   Variance Loss: -71.6279\n",
      "Epoch 40/200,   Variance Loss: -73.5622\n",
      "Epoch 50/200,   Variance Loss: -74.6387\n",
      "Epoch 60/200,   Variance Loss: -75.7326\n",
      "Epoch 70/200,   Variance Loss: -77.7457\n",
      "Epoch 80/200,   Variance Loss: -79.6939\n",
      "Epoch 90/200,   Variance Loss: -82.6937\n",
      "Epoch 100/200,   Variance Loss: -84.3381\n",
      "Epoch 110/200,   Variance Loss: -84.7919\n",
      "Epoch 120/200,   Variance Loss: -85.0603\n",
      "Epoch 130/200,   Variance Loss: -85.1748\n",
      "Epoch 140/200,   Variance Loss: -85.3105\n",
      "Epoch 150/200,   Variance Loss: -85.9120\n",
      "Epoch 160/200,   Variance Loss: -87.4697\n",
      "Epoch 170/200,   Variance Loss: -88.2793\n",
      "Epoch 180/200,   Variance Loss: -88.7648\n",
      "Epoch 190/200,   Variance Loss: -88.9797\n",
      "Epoch 200/200,   Variance Loss: -89.0106\n",
      "Epoch 10/200,   Variance Loss: 7.7645\n",
      "Epoch 20/200,   Variance Loss: -64.3921\n",
      "Epoch 30/200,   Variance Loss: -71.6614\n",
      "Epoch 40/200,   Variance Loss: -73.5442\n",
      "Epoch 50/200,   Variance Loss: -74.0669\n",
      "Epoch 60/200,   Variance Loss: -74.6357\n",
      "Epoch 70/200,   Variance Loss: -75.3701\n",
      "Epoch 80/200,   Variance Loss: -77.1247\n",
      "Epoch 90/200,   Variance Loss: -80.9742\n",
      "Epoch 100/200,   Variance Loss: -84.4888\n",
      "Epoch 110/200,   Variance Loss: -86.0246\n",
      "Epoch 120/200,   Variance Loss: -87.4879\n",
      "Epoch 130/200,   Variance Loss: -88.2246\n",
      "Epoch 140/200,   Variance Loss: -88.6251\n",
      "Epoch 150/200,   Variance Loss: -88.9048\n",
      "Epoch 160/200,   Variance Loss: -89.0140\n",
      "Epoch 170/200,   Variance Loss: -89.1207\n",
      "Epoch 180/200,   Variance Loss: -89.2210\n",
      "Epoch 190/200,   Variance Loss: -89.5793\n",
      "Epoch 200/200,   Variance Loss: -89.6352\n",
      "Epoch 10/200,   Variance Loss: 11.6001\n",
      "Epoch 20/200,   Variance Loss: -67.4931\n",
      "Epoch 30/200,   Variance Loss: -71.5508\n",
      "Epoch 40/200,   Variance Loss: -73.7719\n",
      "Epoch 50/200,   Variance Loss: -74.4592\n",
      "Epoch 60/200,   Variance Loss: -75.0741\n",
      "Epoch 70/200,   Variance Loss: -76.1315\n",
      "Epoch 80/200,   Variance Loss: -78.6928\n",
      "Epoch 90/200,   Variance Loss: -83.1742\n",
      "Epoch 100/200,   Variance Loss: -85.1280\n",
      "Epoch 110/200,   Variance Loss: -86.2300\n",
      "Epoch 120/200,   Variance Loss: -87.6246\n",
      "Epoch 130/200,   Variance Loss: -88.2571\n",
      "Epoch 140/200,   Variance Loss: -88.6586\n",
      "Epoch 150/200,   Variance Loss: -88.9032\n",
      "Epoch 160/200,   Variance Loss: -89.1119\n",
      "Epoch 170/200,   Variance Loss: -89.3675\n",
      "Epoch 180/200,   Variance Loss: -89.3881\n",
      "Epoch 190/200,   Variance Loss: -89.5404\n",
      "Epoch 200/200,   Variance Loss: -89.6999\n",
      "Epoch 10/200,   Variance Loss: 4.2778\n",
      "Epoch 20/200,   Variance Loss: -64.6501\n",
      "Epoch 30/200,   Variance Loss: -67.7796\n",
      "Epoch 40/200,   Variance Loss: -71.3083\n",
      "Epoch 50/200,   Variance Loss: -73.1977\n",
      "Epoch 60/200,   Variance Loss: -74.1145\n",
      "Epoch 70/200,   Variance Loss: -74.8900\n",
      "Epoch 80/200,   Variance Loss: -76.0406\n",
      "Epoch 90/200,   Variance Loss: -77.4458\n",
      "Epoch 100/200,   Variance Loss: -79.4083\n",
      "Epoch 110/200,   Variance Loss: -80.2861\n",
      "Epoch 120/200,   Variance Loss: -80.2371\n",
      "Epoch 130/200,   Variance Loss: -80.3257\n",
      "Epoch 140/200,   Variance Loss: -80.2837\n",
      "Epoch 150/200,   Variance Loss: -80.4453\n",
      "Epoch 160/200,   Variance Loss: -80.4549\n",
      "Epoch 170/200,   Variance Loss: -80.1012\n",
      "Epoch 180/200,   Variance Loss: -80.3734\n",
      "Epoch 190/200,   Variance Loss: -80.4112\n",
      "Epoch 200/200,   Variance Loss: -80.1471\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n",
      "Epoch 10/50,   Variance Loss: -46.2085\n",
      "Epoch 20/50,   Variance Loss: -76.2153\n",
      "Epoch 30/50,   Variance Loss: -78.4105\n",
      "Epoch 40/50,   Variance Loss: -78.4216\n",
      "Epoch 50/50,   Variance Loss: -78.4224\n",
      "Epoch 10/200,   Variance Loss: -44.5639\n",
      "Epoch 20/200,   Variance Loss: -66.5824\n",
      "Epoch 30/200,   Variance Loss: -74.4465\n",
      "Epoch 40/200,   Variance Loss: -75.8533\n",
      "Epoch 50/200,   Variance Loss: -76.2522\n",
      "Epoch 60/200,   Variance Loss: -76.6267\n",
      "Epoch 70/200,   Variance Loss: -77.7408\n",
      "Epoch 80/200,   Variance Loss: -80.3141\n",
      "Epoch 90/200,   Variance Loss: -81.4066\n",
      "Epoch 100/200,   Variance Loss: -82.3210\n",
      "Epoch 110/200,   Variance Loss: -84.1004\n",
      "Epoch 120/200,   Variance Loss: -85.4574\n",
      "Epoch 130/200,   Variance Loss: -86.4095\n",
      "Epoch 140/200,   Variance Loss: -86.6540\n",
      "Epoch 150/200,   Variance Loss: -86.7164\n",
      "Epoch 160/200,   Variance Loss: -87.0021\n",
      "Epoch 170/200,   Variance Loss: -86.9907\n",
      "Epoch 180/200,   Variance Loss: -87.3654\n",
      "Epoch 190/200,   Variance Loss: -87.7508\n",
      "Epoch 200/200,   Variance Loss: -87.8718\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -42.3655\n",
      "Epoch 20/200,   Variance Loss: -65.4035\n",
      "Epoch 30/200,   Variance Loss: -73.7072\n",
      "Epoch 40/200,   Variance Loss: -76.2533\n",
      "Epoch 50/200,   Variance Loss: -77.2303\n",
      "Epoch 60/200,   Variance Loss: -78.3247\n",
      "Epoch 70/200,   Variance Loss: -80.5503\n",
      "Epoch 80/200,   Variance Loss: -84.1264\n",
      "Epoch 90/200,   Variance Loss: -86.4121\n",
      "Epoch 100/200,   Variance Loss: -86.7757\n",
      "Epoch 110/200,   Variance Loss: -87.3492\n",
      "Epoch 120/200,   Variance Loss: -87.3155\n",
      "Epoch 130/200,   Variance Loss: -87.8804\n",
      "Epoch 140/200,   Variance Loss: -88.0530\n",
      "Epoch 150/200,   Variance Loss: -88.1307\n",
      "Epoch 160/200,   Variance Loss: -88.5778\n",
      "Epoch 170/200,   Variance Loss: -88.7083\n",
      "Epoch 180/200,   Variance Loss: -88.7623\n",
      "Epoch 190/200,   Variance Loss: -88.8559\n",
      "Epoch 200/200,   Variance Loss: -89.0421\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -44.0617\n",
      "Epoch 20/200,   Variance Loss: -69.7272\n",
      "Epoch 30/200,   Variance Loss: -74.3314\n",
      "Epoch 40/200,   Variance Loss: -76.7500\n",
      "Epoch 50/200,   Variance Loss: -77.5513\n",
      "Epoch 60/200,   Variance Loss: -78.5216\n",
      "Epoch 70/200,   Variance Loss: -79.8005\n",
      "Epoch 80/200,   Variance Loss: -81.7632\n",
      "Epoch 90/200,   Variance Loss: -85.6455\n",
      "Epoch 100/200,   Variance Loss: -87.0989\n",
      "Epoch 110/200,   Variance Loss: -87.4126\n",
      "Epoch 120/200,   Variance Loss: -87.6051\n",
      "Epoch 130/200,   Variance Loss: -87.7952\n",
      "Epoch 140/200,   Variance Loss: -87.8175\n",
      "Epoch 150/200,   Variance Loss: -87.9079\n",
      "Epoch 160/200,   Variance Loss: -87.9228\n",
      "Epoch 170/200,   Variance Loss: -88.1054\n",
      "Epoch 180/200,   Variance Loss: -88.6134\n",
      "Epoch 190/200,   Variance Loss: -88.7365\n",
      "Epoch 200/200,   Variance Loss: -89.1618\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: -43.9064\n",
      "Epoch 20/200,   Variance Loss: -69.6474\n",
      "Epoch 30/200,   Variance Loss: -75.7816\n",
      "Epoch 40/200,   Variance Loss: -76.8529\n",
      "Epoch 50/200,   Variance Loss: -77.1658\n",
      "Epoch 60/200,   Variance Loss: -77.5374\n",
      "Epoch 70/200,   Variance Loss: -78.4615\n",
      "Epoch 80/200,   Variance Loss: -78.9196\n",
      "Epoch 90/200,   Variance Loss: -79.6207\n",
      "Epoch 100/200,   Variance Loss: -80.2960\n",
      "Epoch 110/200,   Variance Loss: -80.9235\n",
      "Epoch 120/200,   Variance Loss: -81.4309\n",
      "Epoch 130/200,   Variance Loss: -81.5858\n",
      "Epoch 140/200,   Variance Loss: -81.4709\n",
      "Epoch 150/200,   Variance Loss: -81.6604\n",
      "Epoch 160/200,   Variance Loss: -81.4492\n",
      "Epoch 170/200,   Variance Loss: -81.6539\n",
      "Epoch 180/200,   Variance Loss: -81.6165\n",
      "Epoch 190/200,   Variance Loss: -81.6888\n",
      "Epoch 200/200,   Variance Loss: -81.8150\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10/200,   Variance Loss: 14.5402\n",
      "Epoch 20/200,   Variance Loss: -64.1910\n",
      "Epoch 30/200,   Variance Loss: -67.9062\n",
      "Epoch 40/200,   Variance Loss: -72.5242\n",
      "Epoch 50/200,   Variance Loss: -74.4165\n",
      "Epoch 60/200,   Variance Loss: -75.2468\n",
      "Epoch 70/200,   Variance Loss: -76.6535\n",
      "Epoch 80/200,   Variance Loss: -79.8324\n",
      "Epoch 90/200,   Variance Loss: -84.0312\n",
      "Epoch 100/200,   Variance Loss: -85.4312\n",
      "Epoch 110/200,   Variance Loss: -86.6352\n",
      "Epoch 120/200,   Variance Loss: -87.8233\n",
      "Epoch 130/200,   Variance Loss: -88.4430\n",
      "Epoch 140/200,   Variance Loss: -88.8216\n",
      "Epoch 150/200,   Variance Loss: -89.0046\n",
      "Epoch 160/200,   Variance Loss: -89.1581\n",
      "Epoch 170/200,   Variance Loss: -89.5022\n",
      "Epoch 180/200,   Variance Loss: -89.6560\n",
      "Epoch 190/200,   Variance Loss: -89.7625\n",
      "Epoch 200/200,   Variance Loss: -89.8794\n",
      "Epoch 10/200,   Variance Loss: 0.3965\n",
      "Epoch 20/200,   Variance Loss: -64.5121\n",
      "Epoch 30/200,   Variance Loss: -71.8214\n",
      "Epoch 40/200,   Variance Loss: -74.2772\n",
      "Epoch 50/200,   Variance Loss: -74.8442\n",
      "Epoch 60/200,   Variance Loss: -75.4844\n",
      "Epoch 70/200,   Variance Loss: -76.4488\n",
      "Epoch 80/200,   Variance Loss: -78.6660\n",
      "Epoch 90/200,   Variance Loss: -82.2898\n",
      "Epoch 100/200,   Variance Loss: -85.1637\n",
      "Epoch 110/200,   Variance Loss: -85.9878\n",
      "Epoch 120/200,   Variance Loss: -86.5004\n",
      "Epoch 130/200,   Variance Loss: -87.0645\n",
      "Epoch 140/200,   Variance Loss: -87.8408\n",
      "Epoch 150/200,   Variance Loss: -88.2632\n",
      "Epoch 160/200,   Variance Loss: -88.8714\n",
      "Epoch 170/200,   Variance Loss: -89.2933\n",
      "Epoch 180/200,   Variance Loss: -89.6370\n",
      "Epoch 190/200,   Variance Loss: -89.6460\n",
      "Epoch 200/200,   Variance Loss: -90.1725\n",
      "Epoch 10/200,   Variance Loss: 17.0460\n",
      "Epoch 20/200,   Variance Loss: -56.5101\n",
      "Epoch 30/200,   Variance Loss: -71.6868\n",
      "Epoch 40/200,   Variance Loss: -74.1898\n",
      "Epoch 50/200,   Variance Loss: -75.2630\n",
      "Epoch 60/200,   Variance Loss: -75.8522\n",
      "Epoch 70/200,   Variance Loss: -76.6001\n",
      "Epoch 80/200,   Variance Loss: -77.7784\n",
      "Epoch 90/200,   Variance Loss: -79.9218\n",
      "Epoch 100/200,   Variance Loss: -83.4317\n",
      "Epoch 110/200,   Variance Loss: -85.0742\n",
      "Epoch 120/200,   Variance Loss: -85.7127\n",
      "Epoch 130/200,   Variance Loss: -86.5199\n",
      "Epoch 140/200,   Variance Loss: -87.4368\n",
      "Epoch 150/200,   Variance Loss: -87.9953\n",
      "Epoch 160/200,   Variance Loss: -88.4743\n",
      "Epoch 170/200,   Variance Loss: -88.7038\n",
      "Epoch 180/200,   Variance Loss: -89.0596\n",
      "Epoch 190/200,   Variance Loss: -89.2638\n",
      "Epoch 200/200,   Variance Loss: -89.6133\n",
      "Epoch 10/200,   Variance Loss: 8.8431\n",
      "Epoch 20/200,   Variance Loss: -68.8240\n",
      "Epoch 30/200,   Variance Loss: -72.2738\n",
      "Epoch 40/200,   Variance Loss: -75.2933\n",
      "Epoch 50/200,   Variance Loss: -76.3664\n",
      "Epoch 60/200,   Variance Loss: -77.9861\n",
      "Epoch 70/200,   Variance Loss: -80.9221\n",
      "Epoch 80/200,   Variance Loss: -84.4680\n",
      "Epoch 90/200,   Variance Loss: -85.3220\n",
      "Epoch 100/200,   Variance Loss: -85.7776\n",
      "Epoch 110/200,   Variance Loss: -86.2446\n",
      "Epoch 120/200,   Variance Loss: -87.4061\n",
      "Epoch 130/200,   Variance Loss: -87.8366\n",
      "Epoch 140/200,   Variance Loss: -88.5113\n",
      "Epoch 150/200,   Variance Loss: -88.7428\n",
      "Epoch 160/200,   Variance Loss: -89.1848\n",
      "Epoch 170/200,   Variance Loss: -89.3084\n",
      "Epoch 180/200,   Variance Loss: -89.5660\n",
      "Epoch 190/200,   Variance Loss: -89.7140\n",
      "Epoch 200/200,   Variance Loss: -89.7766\n",
      "Epoch 10/200,   Variance Loss: 8.0986\n",
      "Epoch 20/200,   Variance Loss: -67.2612\n",
      "Epoch 30/200,   Variance Loss: -71.8780\n",
      "Epoch 40/200,   Variance Loss: -74.9509\n",
      "Epoch 50/200,   Variance Loss: -75.6279\n",
      "Epoch 60/200,   Variance Loss: -77.1503\n",
      "Epoch 70/200,   Variance Loss: -81.2894\n",
      "Epoch 80/200,   Variance Loss: -84.6024\n",
      "Epoch 90/200,   Variance Loss: -85.2279\n",
      "Epoch 100/200,   Variance Loss: -85.4430\n",
      "Epoch 110/200,   Variance Loss: -85.5532\n",
      "Epoch 120/200,   Variance Loss: -85.6454\n",
      "Epoch 130/200,   Variance Loss: -85.7793\n",
      "Epoch 140/200,   Variance Loss: -86.3713\n",
      "Epoch 150/200,   Variance Loss: -87.5808\n",
      "Epoch 160/200,   Variance Loss: -88.3551\n",
      "Epoch 170/200,   Variance Loss: -88.8088\n",
      "Epoch 180/200,   Variance Loss: -89.2448\n",
      "Epoch 190/200,   Variance Loss: -89.4127\n",
      "Epoch 200/200,   Variance Loss: -89.5963\n",
      "Iteration 1 complete\n",
      "Iteration 2 complete\n",
      "Iteration 3 complete\n",
      "Iteration 4 complete\n",
      "Iteration 5 complete\n",
      "Iteration 6 complete\n",
      "Iteration 7 complete\n",
      "Iteration 8 complete\n",
      "Iteration 9 complete\n",
      "Iteration 10 complete\n"
     ]
    }
   ],
   "source": [
    "sideinfo_array = np.arange(1, p + 1).reshape(-1, 1).astype(np.float32)\n",
    "rmses  = []\n",
    "\n",
    "rmses_ash  = []\n",
    "for  k in  range(1, 11):\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",
    "    dataset_path = Path(\"C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger\")\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",
    "    X =  np.eye(144) #X_train.astype(np.float32)\n",
    "    y = y_train.astype(np.float32).flatten()\n",
    "    sideinfo= sideinfo_array\n",
    "    maxit=10\n",
    "    damping=0.99\n",
    "    # Standardize\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",
    "\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=50  ) \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=200  )\n",
    "            log_pi= result.pi_np\n",
    "            beta =   result.post_mean\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    est= np.sqrt(mean_squared_error(ysd* X@result.post_mean ,y_test))# np.sqrt(mean_squared_error(ysd* X@betahat_arr ,y_test))\n",
    "    rmses.append(est)\n",
    "    est_nash = nash_noinfo_dynamic_td(X=np.eye(144),y=y_train)\n",
    "\n",
    "    temp=np.sqrt(mean_squared_error(ysd* X@est_nash ,y_test))\n",
    "    rmses_ash.append(temp)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "167117ba",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "19.625836438695224"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(rmses) \n",
    "np.array(rmses).mean() "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "499e6e2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "2*np.array(rmses).std()/np.sqrt(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1214802b",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    " \n",
    "X =  np.eye(144) #X_train.astype(np.float32)\n",
    "y = y_train.astype(np.float32).flatten()\n",
    "sideinfo= sideinfo_array\n",
    "maxit=10\n",
    "damping=0.99\n",
    "    # Standardize\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",
    "\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=50  ) \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=50  )\n",
    "            log_pi= result.pi_np\n",
    "            beta =   result.post_mean\n",
    "\n",
    "  \n",
    "plt.plot(X@ result.post_mean)\n",
    "\n",
    "#plt.plot(X@ betahat_arr)\n",
    "#plt.plot(y)\n",
    "#print(drift_comp)\n",
    "print(np.sqrt(mean_squared_error(ysd* X@result.post_mean ,y_train)))\n",
    "#print(np.sqrt(mean_squared_error(ysd* X@betahat_arr ,y_test)))\n",
    " \n",
    "print(np.sqrt(mean_squared_error(ysd* X@betahat_arr ,y_test)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48a0b7f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(np.sqrt(mean_squared_error(ysd* X@result.post_mean ,y_test)))\n",
    "#print(np.sqrt(mean_squared_error(ysd* X@betahat_arr ,y_test)))\n",
    " \n",
    "print(np.sqrt(mean_squared_error(ysd* X@betahat_arr ,y_test)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8827da6",
   "metadata": {},
   "outputs": [],
   "source": [
    "result =emdn_posterior_means(X= sideinfo,\n",
    "                                          betahat=  ash_input, #ash_input ,\n",
    "                                          sebetahat= np.full_like(ash_input,sigma_0) /sqn ,\n",
    "                                          n_epochs=200  )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "c65dd53c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x16eb1e11f00>]"
      ]
     },
     "execution_count": 33,
     "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "bcce452e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x16eb1dda050>"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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0aNHD2Pfvn2d1awW+aLNr7zyihEZGen2Pm02W2c1qVWetrm8vNx4/PHHjT/84Q/Gtddea8yZM6dRmUB7z21pc6C95zlz5hjPPvussX//fuPjjz825s+fb4SFhRlFRUWuMv7+ng3DN+3uiHdN0OlGysrKDElu/2EXFhYakox//OMfrd5fXl7eZNA5e/asERYWZmzatMl17fjx40ZISIiRn5/fYfX3ljftdjqdhtVqNZYsWeK6Vl1dbVgsFmP16tWuazfccEOTf5B2tjFjxhizZs1yuzZ8+HDjySefbLL8z3/+c2P48OFu1x5++GEjNTXV9fX06dONyZMnu5WZNGmScffdd3dQrdvHF21+5ZVXDIvF0uF17Sietvlizf23Gmjv+WLNtTmQ33ODhIQEIycnx/W1v79nw/BNuzviXTN01Y0UFhbKYrFo7NixrmupqamyWCzau3ev1889cOCAzp8/r4yMDNe1AQMGKDExsV3P7SjetLu8vFx2u92tTREREbrhhhsa3fPaa68pOjpaV199tX72s5+5TrfvLLW1tTpw4IBbXSUpIyOj2fYVFhY2Kj9p0iS9//77On/+fItl/OGd+qrNkvTVV18pLi5OAwcO1NSpU1VcXNzxDfCCN21ui0B7z20VyO/Z6XSqqqpKUVFRrmv+/J4l37Vbav+7Juh0I3a7Xf379290vX///rLb7e16bnh4uC6//HK36zExMe16bkfxpt0N12NiYtyuX9qme++9Vxs3btTf/vY3Pf3009qyZYvuvPPODqx9606ePKm6urpW63oxu93eZPkLFy7o5MmTLZbxh3fqqzYPHz5ca9eu1Y4dO7Rx40aZzWalp6fryJEjvmmIB7xpc1sE2ntui0B/z88995zOnTun6dOnu67583uWfNfujnjXQXl6ub9ZtGiRcnJyWizz3nvvSZJMJlOj7xmG0eT19vLVcxt0Rrsv/f6l98ycOdP1z4mJiRo6dKhGjx6toqIiJScnt9qGjtRaXdtS/tLrnj6zs3V0m1NTU5Wamur6fnp6upKTk/XCCy9o2bJlHVXtdvHFOwm099yaQH7PGzdu1KJFi7R9+/ZGf8Hz9/csdXy7O+JdE3T8wOzZs1td6TN48GAdOnRIX3zxRaPvffnll41StCesVqtqa2t15swZt16diooKjRs3zuvntsaX7bZarZLq/xYUGxvrul5RUdHiv6vk5GSFhYXpyJEjnRZ0oqOjFRoa2uhvPS3V1Wq1Nlm+R48e6tu3b4tl2vPfSkfxVZsvFRISouuuu84v/qbvTZvbItDeszcC5T1v3rxZDz74oF5//XVNmDDB7Xv+/J4l37X7Ut68a4au/EB0dLSGDx/e4sdsNistLU2VlZXav3+/6953331XlZWV7QokKSkpCgsLU0FBgeuazWZTaWmpT4OOL9sdHx8vq9Xq1qba2lq9/fbbLbbp8OHDOn/+vFs48rXw8HClpKS41VWSCgoKmq1rWlpao/JvvvmmRo8erbCwsBbL+PKdtpWv2nwpwzBUUlLSqe+zOd60uS0C7T17IxDe88aNG/XAAw9ow4YNuvXWWxt935/fs+S7dl/Kq3fdrqnM6HSTJ082Ro0aZRQWFhqFhYXGyJEjGy2zHjZsmLF161bX16dOnTKKi4uNN954w5BkbNq0ySguLnZbojdr1ixj4MCBxq5du4yioiLj5ptv9rvl5Z62e8mSJYbFYjG2bt1qfPDBB8Y999zjtrz8n//8p5GTk2O89957Rnl5ufHGG28Yw4cPN5KSkjq93Q3LMl9++WWjrKzMyM7ONnr37m0cPXrUMAzDePLJJ42srCxX+Yal1nPnzjXKysqMl19+udFS67///e9GaGiosWTJEuPDDz80lixZ4lfLUX3R5kWLFhn5+fnGJ598YhQXFxs//vGPjR49ehjvvvtup7evKZ622TAMo7i42CguLjZSUlKMGTNmGMXFxcbhw4dd3w+092wYrbc50N7zhg0bjB49ehgrVqxodqsLf3/PhuGbdnfEuybodDOnTp0y7r33XqNPnz5Gnz59jHvvvdc4c+aMWxlJxiuvvOL6+pVXXjEkNfosXLjQVeabb74xZs+ebURFRRk9e/Y0pk6dahw7dqxzGtUG3rTb6XQaCxcuNKxWqxEREWFcf/31xgcffOD6/rFjx4zrr7/eiIqKMsLDw40hQ4YYjz/+uHHq1KlOapW7FStWGHFxcUZ4eLiRnJxsvP32267v3X///cYNN9zgVv5vf/ubkZSUZISHhxuDBw82Vq1a1eiZr7/+ujFs2DAjLCzMGD58uLFlyxZfN8MjHd3m7Oxs4z/+4z+M8PBwo1+/fkZGRoaxd+/ezmhKm3na5qb+342Li3MrE2jvubU2B9p7vuGGG5ps8/333+/2TH9/z4bR8e3uiHdtMoxvZ/MBAAAEGOboAACAgEXQAQAAAYugAwAAAhZBBwAABCyCDgAACFgEHQAAELAIOgAAIGARdAAAQMAi6AAAgIBF0AEAAAGLoAMAAAIWQQcAAASs/we9ZPRruGWnxwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter ( betahat_arr,result.post_mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00be493a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86854008",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot( ysd*betahat_arr/csd )\n",
    "plt.plot(y_test) \n",
    "np.sqrt(mean_squared_error( ysd*betahat_arr/csd ,y_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b67c4f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot( ysd*betahat_arr/csd )\n",
    "plt.plot(y_train)\n",
    "np.sqrt(mean_squared_error(2* ysd*result.post_mean/csd ,y_test))"
   ]
  }
 ],
 "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
}
