{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "from src.model import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\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": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "# Fixed hyperparameters of statistical model\n",
    "d, l = 300, 350\n",
    "sigma_sq_stat = 1.5\n",
    "sigma_sq = 1\n",
    "gen_conf_strength = .53\n",
    "r_sq_stat = 5\n",
    "eta = get_max_eta(gen_conf_strength, r_sq_stat)\n",
    "conf_strength, eta = get_params_from_generalized_conf(conf_eta=gen_conf_strength, r_sq_stat=r_sq_stat, eta=eta)\n",
    "\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,\n",
    "                                                                                sigma_sq=sigma_sq,\n",
    "                                                                                conf_strength=conf_strength,\n",
    "                                                                                eta=eta)\n",
    "ridge = 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",
    "lam_small, lam_large = 0, .5\n",
    "res_dict_small = ridge.compute_risks(lam=lam_small, gams=gams, include_finite=True)\n",
    "res_dict_large = ridge.compute_risks(lam=lam_large, gams=gams, include_finite=True)\n",
    "res_oracle = ridge.compute_oracle(gams, include_finite=True)"
   ],
   "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": [
    "colors = ['black', 'red']\n",
    "marker_size = 15\n",
    "res_dicts = [res_dict_small, res_dict_large]\n",
    "save_path = '../fig/figure4.pdf'\n",
    "steps_finite_samples = 3\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(.5*LINEWIDTH, .3*LINEWIDTH))\n",
    "\n",
    "# Orientation lines\n",
    "ax.axhline(y=ridge.r_sq, linestyle='--', color='gray', linewidth=1) # base risk of 0 classifier\n",
    "ax.axvline(x=1, linestyle='--', color='gray', linewidth=1) # base risk of 0 classifier) # interpolation threshold\n",
    "\n",
    "# Min-norm interpolator\n",
    "# Bias\n",
    "ax.plot(gams, res_dict_small['bias_caus'], color=colors[0], linestyle='--')\n",
    "# Variance\n",
    "ax.plot(gams, res_dict_small['var'], color=colors[0], linestyle='dotted')\n",
    "# Risk\n",
    "ax.plot(gams, res_dict_small['risk_caus'], color=colors[0], linestyle='-')\n",
    "ax.scatter(gams[::steps_finite_samples], res_dict_small['finite_loss_caus'][::steps_finite_samples], color=colors[0], marker='x', s=marker_size)\n",
    "\n",
    "# Optimal ridge regularization\n",
    "# Bias\n",
    "ax.plot(gams, res_oracle['bias_optim_caus'], color=colors[1], linestyle='--')\n",
    "# Variance\n",
    "ax.plot(gams, res_oracle['variance_optim_caus'], color=colors[1], linestyle='dotted')\n",
    "# Risk\n",
    "ax.plot(gams, res_oracle['risk_optim_caus'], color=colors[1], linestyle='-')\n",
    "ax.scatter(gams[::steps_finite_samples], res_oracle['finite_loss_optim_caus'][::steps_finite_samples], color=colors[1], marker='x', s=marker_size)\n",
    "\n",
    "# Legend and axes\n",
    "# ax.set_title('Causal bias-variance decomposition of the risk')\n",
    "ax.set_xlabel(r'Overparameterization ratio $\\gamma$')\n",
    "ax.set_xlim([0, max(gams)])\n",
    "ax.set_ylim([0, 6])\n",
    "\n",
    "handles = [Line2D([], [], label='Risk', color='k', linestyle='-'),\n",
    "           Line2D([], [], label='Bias', color='k', linestyle='--'),\n",
    "           Line2D([], [], label='Variance', color='k', linestyle='dotted')]\n",
    "\n",
    "plt.legend(handles=handles, framealpha=1, frameon=True, ncol=1)\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
}