{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75777eb9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import problems\n",
    "from experiments import *\n",
    "from fastridge import RidgeEM, RidgeLOOCV"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c19c79b",
   "metadata": {},
   "source": [
    "Figure 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59fbd001",
   "metadata": {},
   "outputs": [],
   "source": [
    "ridgeEM = RidgeEM(fit_intercept=False, normalize=False)\n",
    "ridgeCV_GLM = RidgeLOOCV(alphas=100, fit_intercept=False, normalize=False)\n",
    "ridgeCV_fixed = RidgeLOOCV(alphas=np.logspace(-10, 10, 100, endpoint=True, base=10), fit_intercept=False, normalize=False)\n",
    "\n",
    "estimators = [ridgeEM, ridgeCV_fixed]\n",
    "est_names = ['EM', 'CV_fix']\n",
    "# ns = [100, 500, 1000, 1500, 2000, 2500, 3000, 3500, 4000]\n",
    "ns = [100, 150, 200, 300, 400, 600, 800, 1200, 1600, 2400, 3200, 4800, 6400, 9600, 12800]\n",
    "sigmas = [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]\n",
    "probs = [problems.random_sparse_factor_problem(100, sigma_eps=sig) for sig in sigmas]\n",
    "r = 100\n",
    "\n",
    "exp = Experiment(probs, estimators, ns, r, est_names)\n",
    "exp.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6a9cc86",
   "metadata": {},
   "outputs": [],
   "source": [
    "from importlib import reload\n",
    "import plotting\n",
    "reload(plotting)\n",
    "from plotting import plot_metrics\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "sigmas_idx_plot = [1, 2, 3, 4, 5]\n",
    "fig, axs = plot_metrics(exp, [parameter_mean_squared_error, regularization_parameter, number_of_iterations, fitting_time], sigmas_idx_plot, figsize=(12, 6))\n",
    "axs[0, 0].set_xscale('log')\n",
    "for j in range(5):\n",
    "    axs[0, j].set_title(f'$\\sigma = {sigmas[sigmas_idx_plot[j]]}$')\n",
    "axs[0, 0].legend()\n",
    "plt.subplots_adjust(wspace=0, hspace=0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5b20bf0e",
   "metadata": {},
   "source": [
    "Figure 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f0ca372",
   "metadata": {},
   "outputs": [],
   "source": [
    "ps = [50, 100, 200, 400, 800]\n",
    "np.random.seed(123)\n",
    "probs = [problems.random_problem(p) for p in ps]\n",
    "ns = [50, 75, 100, 150, 200, 300, 400, 600, 800, 1200, 1600]\n",
    "\n",
    "ridgeEM = RidgeEM(fit_intercept=False)\n",
    "ridgeCV_GLM = RidgeLOOCV(alphas=100, fit_intercept=False)\n",
    "ridgeCV_fixed = RidgeLOOCV(alphas=np.logspace(-10, 10, 100, endpoint=True, base=10), fit_intercept=False)\n",
    "\n",
    "estimators = [ridgeEM, ridgeCV_fixed, ridgeCV_GLM]\n",
    "est_names = ['EM', 'CV_fix', 'CV_glm']\n",
    "\n",
    "exp1 = Experiment(probs, estimators, ns, 100, est_names, seed = 123)\n",
    "exp1.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0898a9a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from importlib import reload\n",
    "import plotting\n",
    "reload(plotting)\n",
    "from plotting import plot_metrics\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "prob_idx=[0, 1, 2, 3, 4]\n",
    "fig, axs = plot_metrics(exp1, [parameter_mean_squared_error, regularization_parameter, from matplotlib import pyplot as plt fitting_time], prob_idx=prob_idx, figsize=(12, 6))\n",
    "axs[0, 0].set_yscale('log')\n",
    "axs[1, 0].set_yscale('log')\n",
    "#axs[2, 0].set_ylabel('$k$ (or $T$)')\n",
    "for i in range(len(prob_idx)):\n",
    "    axs[0, i].set_title(f'$p={ps[prob_idx[i]]}$')\n",
    "axs[0, 0].legend()\n",
    "plt.savefig('growing_p_v2.pdf', dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
