{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "from src.model import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "plt.style.use('seaborn-whitegrid')\n",
    "\n",
    "# PLOT PREAMBLE: LIKE LATEX\n",
    "LINEWIDTH = 6.00117\n",
    "\n",
    "SCRIPT_SIZE = 8\n",
    "SMALL = 10\n",
    "NORMAL_SIZE = 10.95\n",
    "LARGE = 12\n",
    "Huge = 24.88\n",
    "\n",
    "#Direct input\n",
    "plt.rcParams['text.latex.preamble']=r\"\\usepackage{lmodern}\"\n",
    "#Options\n",
    "params = {'text.usetex' : True,\n",
    "          'font.size' : NORMAL_SIZE,\n",
    "          'axes.labelsize' : NORMAL_SIZE,\n",
    "          'xtick.labelsize' : NORMAL_SIZE,\n",
    "          'ytick.labelsize' : NORMAL_SIZE,\n",
    "          'legend.fontsize' : NORMAL_SIZE,\n",
    "          'figure.titlesize' : LARGE,\n",
    "          'font.family' : 'serif',\n",
    "          'font.serif': ['Computer Modern Roman'],\n",
    "          'lines.linewidth': 1.5\n",
    "          }\n",
    "plt.rcParams.update(params)\n",
    "\n",
    "# For the warning when hiding yticklabels\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "#### Risks across different $S=(1-2\\zeta)\\text{SNR}_S=\\frac{r^2-\\omega^2}{\\tilde{\\sigma}^2}$ for the min-norm estimator.\n",
    "- The different regimes are $\\kappa_C<0$ (no learning), $\\kappa_C\\in[0, 1]$ (learning in the underparameterized regime), and $\\kappa_C>1$ (learning everywhere)\n",
    "- Here, we don't fix the statistical model, but instead fix $r^2$ and vary $\\omega^2$. The reason is that we want to keep the Bayes risk $r^2$ fixed across different SNRs"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "# Fixed omega_sq and varying r_sq\n",
    "d, l = 100, 150\n",
    "sigma_sq = .7\n",
    "sigma_sq_stat = 1\n",
    "omega_sq = 2\n",
    "SNR_min_norm_list = [3, .5, -1]\n",
    "all_ridge_models = []\n",
    "for SNR in SNR_min_norm_list:\n",
    "    r_sq = sigma_sq_stat * SNR + omega_sq\n",
    "    conf_strength = omega_sq / (r_sq + omega_sq)\n",
    "    r_sq_stat = r_sq + omega_sq\n",
    "    M, alpha, beta, sigma_sq = generate_causal_params_for_fixed_statistical(d=d, l=l, r_sq_stat=r_sq_stat,\n",
    "                                                                            sigma_sq_stat=sigma_sq_stat, sigma_sq=sigma_sq,\n",
    "                                                                            conf_strength=conf_strength,\n",
    "                                                                            eta=0)\n",
    "    all_ridge_models.append(RidgeLimit(alpha=alpha, beta=beta, sigma_sq=sigma_sq, M=M))"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [],
   "source": [
    "gams = np.linspace(0.1, 5, 80)\n",
    "all_risks_min_norm = [model.compute_risks(lam=0, gams=gams)['risk_caus'] for model in all_ridge_models]"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 300.058x180.035 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "save_path = '../fig/figure3.pdf'\n",
    "\n",
    "colors = discretize_cmap(plt.cm.gist_heat, num_colors=len(SNR_min_norm_list), margin=30)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(.5*LINEWIDTH, .3*LINEWIDTH))\n",
    "\n",
    "# Orientation lines\n",
    "ax.axvline(x=1, linestyle='--', color='gray', linewidth=1) # interpolation threshold\n",
    "\n",
    "# Loop over different models\n",
    "for i, risk in enumerate(all_risks_min_norm):\n",
    "    # SNR = np.round(all_ridge_models[i].SNR, 2)\n",
    "    SNR = SNR_min_norm_list[i]\n",
    "    conf_strength = np.round(all_ridge_models[i].conf_strength, 2)\n",
    "    ax.plot(gams, risk, color=colors[i], linestyle='-',\n",
    "            label=rf'$S={SNR}$')\n",
    "            # label=rf'SNR$={SNR}$ /$\\zeta={conf_strength}$')\n",
    "\n",
    "    ax.axhline(y=all_ridge_models[i].r_sq, linestyle='--', color=colors[i]) # base risk of 0 classifier\n",
    "\n",
    "\n",
    "# Legend and axes\n",
    "ax.set_xlabel(r'Overparameterization ratio $\\gamma$')\n",
    "ax.set_ylabel(r'Causal risk $\\mathcal{R}^C_0$')\n",
    "ax.set_xlim([0, max(gams)])\n",
    "ax.set_ylim([0, 12])\n",
    "\n",
    "\n",
    "# plt.legend(framealpha=1, frameon=True, bbox_to_anchor=(.45, .45))\n",
    "plt.legend(framealpha=1, frameon=True)\n",
    "\n",
    "if save_path is not None:\n",
    "    plt.savefig(fname=save_path, bbox_inches='tight', dpi=300)\n",
    "\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}