{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Notebook to replicate the results from _Section 5: Understanding scaling laws for denoising theoretically_ from the paper **Scaling Laws For Deep Learning Based Image Reconstruction**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# PCA\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "# other\n",
    "import torch\n",
    "import numpy as np\n",
    "from scipy.linalg import orth\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Device\n",
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = '0'\n",
    "dtype = torch.cuda.FloatTensor"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-08-18T15:29:45.914666Z",
     "start_time": "2021-08-18T15:29:45.904139Z"
    }
   },
   "outputs": [],
   "source": [
    "class dataGen():\n",
    "    \n",
    "    def __init__(self,n,d):\n",
    "        # n: ambient dimension\n",
    "        # d: signal dimension\n",
    "        \n",
    "        # subspace model\n",
    "        self.U = torch.from_numpy( orth(np.random.normal(loc=0, scale=1, size=[n,d])) ) \n",
    "        \n",
    "    def create_train_data(self, n, d, N, sigma_z=0):\n",
    "        # n: ambient dimension\n",
    "        # d: signal dimension\n",
    "        # N: number of training samples\n",
    "        # sigma_z: noise standard deviation\n",
    "        \n",
    "        # train data\n",
    "        self.C = torch.from_numpy( np.random.normal(loc=0, scale=1.0, size=[d,N]) )\n",
    "        self.z = torch.from_numpy( np.random.normal(loc=0, scale=sigma_z, size=[n,N]) )\n",
    "        self.trX = self.U @ self.C\n",
    "        \n",
    "        self.trY = self.trX + self.z"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Estimators"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The estimator learned with gradient descent in the limit of infinite many iterations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-08-18T15:29:45.928623Z",
     "start_time": "2021-08-18T15:29:45.918962Z"
    }
   },
   "outputs": [],
   "source": [
    "class gradient_descent_converged():\n",
    "    '''\n",
    "    The estimator learned with gradient descent if we let the number of iterations go to infinity.\n",
    "    '''    \n",
    "    def test_risk(self, U, sigma_z):\n",
    "        '''\n",
    "        Compute the risk for a given estimator W subspace U and noise statistics sigma_z.\n",
    "        '''\n",
    "        n = U.shape[0]\n",
    "        d = U.shape[1]\n",
    "        risk = np.linalg.norm( (self.W - np.eye(n)) @ U ,'fro')**2 + sigma_z**2 * np.linalg.norm(self.W,'fro')**2\n",
    "        return risk/d\n",
    "    \n",
    "    def compute_GDconv_estimate(self, trX, trY, U, sigma_z):\n",
    "        '''\n",
    "        Compute the estimator from training data and return its risk.\n",
    "        '''\n",
    "        self.W = trX @ np.linalg.pinv(trY)\n",
    "        \n",
    "        teL = self.test_risk(U, sigma_z)\n",
    "        return teL.item()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The estimator learned with gradient descent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-08-18T15:29:45.952410Z",
     "start_time": "2021-08-18T15:29:45.929667Z"
    }
   },
   "outputs": [],
   "source": [
    "class GD_model():\n",
    "    '''\n",
    "    Learn an estimator bwith gradient descent form the data X,Y\n",
    "    '''\n",
    "    def __init__(self, n):\n",
    "        self.n = n\n",
    "        self.W = torch.zeros([n,n]).type(dtype)\n",
    "    \n",
    "    def test_risk(self, U, sigma_z):\n",
    "        '''\n",
    "        Compute the risk for a given estimator W subspace U and noise statistics sigma_z.\n",
    "        '''\n",
    "        n = U.shape[0]\n",
    "        d = U.shape[1]\n",
    "        risk = torch.linalg.norm( (self.W - torch.eye(n).type(dtype)) @ U ,'fro')**2 + sigma_z**2 * torch.linalg.norm(self.W,'fro')**2\n",
    "        return risk/d\n",
    "    \n",
    "    def train(self, trX, trY, U, sigma_z, num_iters=1000, lr = 1e-2):\n",
    "        trainL_emp = []\n",
    "        testL = []\n",
    "\n",
    "        N = trX.shape[-1]\n",
    "        d = U.shape[1]\n",
    "        early_stopping_counter = 0\n",
    "        early_stopping_loss = 10000\n",
    "        for i in range(num_iters):\n",
    "            if i % 100 == 0:\n",
    "                print('Iteration : {}/{}'.format(i,num_iters))\n",
    "            ### train\n",
    "            # compute the gradient\n",
    "            dW = self.W @ trY @ trY.T - trX @ trY.T\n",
    "            \n",
    "            # update the weights\n",
    "            self.W -= lr*dW\n",
    "            \n",
    "            # train loss\n",
    "            Xhat = self.W @ trY\n",
    "            trl =  ( (Xhat-trX)**2 ).sum()/(N*d)\n",
    "            trainL_emp.append(trl.item())\n",
    "            \n",
    "            ### test\n",
    "            tel = self.test_risk(U, sigma_z)\n",
    "            testL.append(tel.item())\n",
    "            \n",
    "            # Stop if train loss is not improving anymore\n",
    "            if i>100 and np.abs(trainL_emp[-1]-trainL_emp[-2]) < 1e-20:\n",
    "                print('Stopped at iteration {} due to convergence'.format(i))\n",
    "                break\n",
    "            \n",
    "            \n",
    "            # Early stopp 100 iterations after the test loss reached its minimum\n",
    "            if testL[-1] < early_stopping_loss:\n",
    "                early_stopping_loss = testL[-1]\n",
    "            else:\n",
    "                early_stopping_counter += 1\n",
    "            if early_stopping_counter == 100:\n",
    "                print('Stopped at iteration {} due to early stopping'.format(i))\n",
    "                break\n",
    "            \n",
    "        return testL, trainL_emp"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Subspace estimation with PCA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class PCA_based_reconstruction():\n",
    "    '''\n",
    "    Estimator based on estimating the subspace with PCA on the data in Y.\n",
    "    '''\n",
    "    def __init__(self):\n",
    "        self.pca = PCA()\n",
    "\n",
    "    def test_risk(self, U, sigma_z):\n",
    "        '''\n",
    "        Compute the risk for a given estimator W subspace U and noise statistics sigma_z.\n",
    "        '''\n",
    "        n = U.shape[0]\n",
    "        d = U.shape[1]\n",
    "        risk = np.linalg.norm( (self.W - np.eye(n)) @ U ,'fro')**2 + sigma_z**2 * np.linalg.norm(self.W,'fro')**2\n",
    "        return risk/d\n",
    "        \n",
    "    def compute_subspace_estimate(self, trY, U, sigma_z):\n",
    "        '''\n",
    "        Compute the estimator from training data and return its risk.\n",
    "        '''\n",
    "        d = U.shape[1]\n",
    "        U_,S,V = np.linalg.svd(trY @ trY.T)\n",
    "        self.Uhat = U_[:,:d]        \n",
    "        self.W = 1/(1+sigma_z**2)* self.Uhat @ self.Uhat.T \n",
    "        \n",
    "        teL = self.test_risk(U, sigma_z)\n",
    "        return teL.item()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Risk minimizing optimal solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-08-18T15:29:46.008751Z",
     "start_time": "2021-08-18T15:29:45.997592Z"
    }
   },
   "outputs": [],
   "source": [
    "class optimal_estimator():\n",
    "    '''\n",
    "    This method assumes knowledge of the subspace U.\n",
    "    '''     \n",
    "    def risk_emp(self, X, Xhat, d):       \n",
    "        '''\n",
    "        Compute the risk empirical based on the test set or the training set.\n",
    "        '''\n",
    "        r = ( (Xhat-X)**2 ).sum()/(X.shape[1]*d) #divide by N*d\n",
    "        return r\n",
    "    \n",
    "    def test_risk(self, U, sigma_z):\n",
    "        '''\n",
    "        Compute the risk for a given estimator W subspace U and noise statistics sigma_z.\n",
    "        '''\n",
    "        n = U.shape[0]\n",
    "        d = U.shape[1]\n",
    "        risk = np.linalg.norm( (self.W - np.eye(n)) @ U ,'fro')**2 + sigma_z**2 * np.linalg.norm(self.W,'fro')**2\n",
    "        return risk/d\n",
    "        \n",
    "    def compute_optimal_estimator(self, U, sigma_z):\n",
    "        '''\n",
    "        Compute the estimator from the known subspace and return its risk.\n",
    "        '''\n",
    "        self.W = 1/(1+sigma_z**2)* U @ U.T \n",
    "        \n",
    "        teL = self.test_risk(U, sigma_z)\n",
    "        return teL.item()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Simulations\n",
    "\n",
    "Replicate any of the 8 setups from Figures 3 and 5 from the paper corresponding to the following choices for signal dimension $d$, ambient dimension $n$ and noise level $\\sigma_z$\n",
    "- $d$=10,$n$=100,$\\sigma_z$=0.2\n",
    "- $d$=10,$n$=100,$\\sigma_z$=0.1\n",
    "- $d$=10,$n$=100,$\\sigma_z$=0.05\n",
    "- $d$=10,$n$=1000,$\\sigma_z$=0.1\n",
    "- $d$=10,$n$=10000,$\\sigma_z$=0.1\n",
    "- $d$=50,$n$=1000,$\\sigma_z$=0.1\n",
    "- $d$=100,$n$=1000,$\\sigma_z$=0.1\n",
    "- $d$=10,$n$=1000,$\\sigma_z$=0.05\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-08-18T15:29:47.584692Z",
     "start_time": "2021-08-18T15:29:46.010141Z"
    }
   },
   "outputs": [],
   "source": [
    "# signal dimension in {10, 50, 100}\n",
    "d = 10 \n",
    "\n",
    "# ambient dimension in {100, 1000, 10000}\n",
    "n = 100\n",
    "\n",
    "# noise level in {0.05, 0.1, 0.2}\n",
    "sigma_z = 0.05 \n",
    "\n",
    "key = 'sigz0' + str(sigma_z)[2:] + '_d' + str(d) + '_n' + str(n)\n",
    "\n",
    "if key not in ['sigz01_d10_n100', 'sigz02_d10_n100', 'sigz005_d10_n100', 'sigz01_d10_n1000', 'sigz01_d10_n10000', \n",
    "               'sigz01_d50_n1000', 'sigz01_d100_n1000','sigz005_d10_n1000']:\n",
    "    print('This setup was not considered in the paper.')\n",
    "\n",
    "# Simulate risk as a function of the number of training examples\n",
    "if d == 10:\n",
    "    train_size = [1,2,4,8,10,12,14,16,18,22,24,30,36,44,64,100,256,512,1024,2048,4096,8192,16384]\n",
    "elif d == 50:\n",
    "    train_size = [1,4,10,18,30,44,50,58,64,70,76,86,100,128,256,512,1024,2048,4096,8192,16384]\n",
    "elif d == 100:\n",
    "    train_size = [1,10,15,30,50,70,80,90,100,110,120,130,150,175,200,256,512,1024,2048,4096,8192,16384]\n",
    "else:\n",
    "    print('Simulations were run for signal dimension d in {10,50,100}. Please pick one of those values')\n",
    "\n",
    "\n",
    "precision = 8 # print results rounded on 8 digits\n",
    "runs = 5 # Compute error bars over 5 runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "start_time": "2021-08-18T15:29:44.717Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**********run 0**********\n",
      "*****training size (N) = 1*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.79615766\n",
      "Converged gradient descent: test risk: 0.90048339\n",
      "21.72625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 101 due to convergence\n",
      "Gradient descent: test risk last: 0.90048355; test risk early stopped: 0.90048331; train loss: 1.387778801460961e-18\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 2*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.73406326\n",
      "Converged gradient descent: test risk: 0.80136828\n",
      "15.362778786140536\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 145 due to early stopping\n",
      "Gradient descent: test risk last: 0.80136824; test risk early stopped: 0.80136824; train loss: 2.962799276751138e-15\n"
     ]
    },
    {
     "data": {
      "image/png": "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iO1LynYH7qtRfSRJUg8xYsSINqHtggsuYPz48ey1115teubOP/98JkyYwI477sjChQsZO3Ysl19+OUceeSTLly9vd/sXXngh++yzD0cffTTPPvsszz77LFtvvTVnnHEGP/zhD7n00ku5//77+frXv84Xv/hFbr75ZgDWrl3Lxz/+cT74wQ+ycOFC/vznP3PiiSfSt2/fdrfZ1bp9mDUi+uX77Qv0jYhBwNqU0sqIuA74bkQcS3Y368eBfbu7jpIk1Yvv3HQf9z/Tfsiphl3e3sC3J3TokvhWpWFu+fLlXHbZZcyePZulS5e2lj/88MPMmjWLOXPmANmdrAcccAC77747J598MhMnTuT666+v+Oqs4cOHM2DAAIYMGcKWW24JwMqVK5k6dSq//e1vGTt2LADbbLMNd999N5deeimHHHIIy5cv5+WXX2bChAlsu+22AOy0006t2y3fZjXU4pq5M4Bvl3z+PPAdYArwZeBHwBKyu12PTyl1ac9cREwAJmy33XZduVlJklRFjY2NrFixgnXr1jF9+nR23XVX9t13X2699dbWnrlp06bR1NTUGrwuvPDC1vWPOuoojjrqqE7t8/777+fVV1/l4IMPbhMAX3/9dcaMGQPAyJEjmTRpEgcddBAHHHAABxxwAJ/+9Ker0gPXnm4PcymlKWTBrdK8ZcAnqrz/m4CbmpqajqvmfiRJKoLO9pDVyogRIwB48cUXueiii1ofMdLQ0EBzczPLli1j5syZzJw5s8v2uX79egBuuukm3vnOd7aZ179//9a///jHP+akk05i9uzZ3HjjjXzzm9/khhtu4KCDDuqyumxIT7qbVZIkqaLGxkYApk+fzpAhQzj00EOBbHh05cqVXHLJJYwePZrDDjtsk/cxYMAA1q1b1/p5l112YeDAgTz++ON8+MMf3uC6u+++O7vvvjunn34648aN4/LLL+eggw560zarwTAnSZJ6vJaeualTp3LOOefQp092D2dDQ/YgjGnTpvHd736Xvn37bvI+xowZw913383ixYsZNmwYI0eO5LTTTuO0004jpcSHPvQhVqxYwV133UWfPn2YPHkyjz32GNOnT+fQQw9lq6224tFHH+Wee+5pffZdpW221L2r9KS7WSVJkipq6ZkbMGAAEydObC0fPnw4ABHBMcccs1n7OO200xgwYAC77LILb33rW3niiSc4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nDlzALjwwgs599xz2WKLLVi1ahUXXXRR63V3V155JRdeeCFr1qxh/fr1nHzyyRx77LGt+/vsZz/LY489xl133dUFR1xdnXqdV0RsUX4jREQMjohTya6Vm9qFdZMkSQKyYdYVK1awbt06pk+fzq677sq+++5LQ0ND6zVz06ZNo6mpibFjxwKwaNEizjnnHBYuXMiFF17IGWecAcCPf/xjZsyYwa9+9Svuvfdebr/9dvr27du6r0WLFvHII4/w97//vfsPdBN05A0QA4FzgX8GBgPNEfHNlNIPIuLzwH8Co4G/ABOrWVlJktS1OttDVisjRowA4MUXX+Siiy7i4osvBqChoYHm5maWLVvGzJkzmTlzZus69957L1/60pcA2HrrrVm7di0rVqxgypQp/OlPf2q9QWLkyJEcffTRreudeeaZnH322Zx00kk8+eSTbL311t10lJumI8Os3wK+AvweWABsA1wYEbsA/0J2M8TklNJNVaulJEmqa42NjQBMnz6dIUOGcOihhwIwfPhwVq5cySWXXMLo0aM57LDDAEgp8cADD7Djjjuyfv16LrnkEg455BB+9rOfsddee/H2t7+94n7mz5/PsmXLOPDAA9l555257777enyY68gw62eA/0opHZhS+lpK6TPAl8iC3O+A3QxykiSpmlp65qZOncqpp55Knz5ZhGloaACyIdaTTz65dbh08eLFvPrqq3zwgx9k7733prGxkW9961ssWrSI3Xbbrd39nHnmmZx11lkA7LLLLtx///3VPKwu0ZGeua2B68vKrgMuA6b6nlZJklRtLT1zAwYMYOLEN67qannUWERwzDHHtJYvWrSIcePGccMNbR97O3ToUNavX19xH3feeSe33npra4BbuXJlaw9gT9aRnrn+wCtlZS2fl3ZtdSRJkt5s2LBhpJR4/vnnGTRoUGv5wIEDSSmxbNkyhg4d2lp+7733svvuu79pO+PGjeOaa67hhRdeAOCVV17hiiuuAOCMM87gt7/9LYsXL2bx4sXMnj271/TMAWwVEe8u+dy3pLzNY5dTSo92Sc0kSZI20aJFizj88MPfVL7vvvvy1a9+lQ9/+MOklAA48cQTufXWW0kptd4JC7D99tsXIsxFy4G0u0DEeqDSQlGpPKXUt8KyPU5TU1OaN29erashSVK3eeCBB9h5551rXQ21Y0M/n4iYn1Jq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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 4*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.60046405\n",
      "Converged gradient descent: test risk: 0.60418439\n",
      "10.86312505754881\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 331 due to early stopping\n",
      "Gradient descent: test risk last: 0.60418445; test risk early stopped: 0.60418445; train loss: 3.5891747202348306e-14\n"
     ]
    },
    {
     "data": {
      "image/png": "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TU2puwVKkqRiueeee5g4cWK1y6iovjQytxYov1NePfBiFWqRJEn9wN13380BBxzA2rVrOfroo7n88surXVKP60thbikwMCL2LGmbCNxXpXokSVIfMX36dCZPntymbfHixUQEJ598cpv26667jmHDhrF8+XLuv/9+Ro4cyeGHH86JJ57Y6SHXQw45hFNOOaVH667EOsv1+mHWiBiYb7cOqIuIocCrKaV1EXEj8M2IOJHsatYPAQf3do2SJKlvGTVqFEuXLm3TduGFFzJkyBBWr17dpn3WrFlMmzaN+vp6nnzySY499liuueYa3vrWt/Zmyb2mGiNzZwMbgLOAT+X/fXY+7fNktytZDlwPnJxScmROkqQa19jYSHPza6fWP/7449xwww2cdNJJbdoXLFjAokWLOO2001iyZAkHHXQQAAMHdj5+NX36dH73u99x5ZVXEhFEBMuWLSOlxAUXXMAee+zBsGHD2H///bn22mvbLLtgwQIOOuggRo4cSUNDA+94xztYsmRJh+vsadW4NclMYGYH01YBH67k9iNiKjB1/PjxldyMJEnqQaNGjWoT2i655BKmTJnCgQceyKJFi1rbL7roIqZOncqECRP47ne/y6RJkzjyyCM57rjjWLBgQYcPsr/00ktZunQpe++9N9/+9rcB2HnnnTn77LP58Y9/zJVXXsmECRO44447OOmkk2hsbOTII4/k1Vdf5UMf+hCf/exn+eEPf8jGjRtZvHgxdXV1Ha6zp/Wlq1l7RUrpZuDmpqamk6pdiyRJ1fbPN9/H/U+v6dVt7vuGer4xtUt3HmtVGubWrFnD1Vdfzbx581ixYkVr+0MPPcTcuXOZP38+kF3JeuihhzJx4kROPfVUpk2bxk9+8pN2H53V0NDA4MGDGT58OLvssgsA69at4+KLL+bWW29l0qRJAOy2227cddddXHnllRx55JGsWbOG1atXM3XqVPbYYw8A9t5779b1lq+zEmouzEmSpOJpbGxk7dq1bNq0idmzZ7P//vtz8MEHc9ttt7WeMzdr1iyamppag9ell17auvzxxx/P8ccf361t3n///bz00kscccQRbQLgxo0bGTduHAA77LAD06dP5/DDD+fQQw/l0EMP5WMf+xi77rrrdn7irjPMSZJUw7o7QlYto0aNAmDlypVcdtllrbcYqa+vp7m5mVWrVjFnzhzmzJnT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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 8*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.29350524\n",
      "Converged gradient descent: test risk: 0.25155556\n",
      "7.681389393070268\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Stopped at iteration 1958 due to early stopping\n",
      "Gradient descent: test risk last: 0.25155911; test risk early stopped: 0.25155911; train loss: 1.540311801717653e-11\n"
     ]
    },
    {
     "data": {
      "image/png": "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AM5OKd1dsiglSdKgNmrUKACmTZtGS0sLJ510EgAjRoxgzZo1XH/99YwZM4aTTz4ZgJQSjz32GAcccABbtmzh+uuv533vex//8R//wZFHHsmrX/3qbvczd+5cli9fzvHHH89BBx3EI488MuCTud50s34U+H8ppeNTSl9KKX0U+AxZIvcz4DATOUmSVEodLXNTpkzhoosuoq4uS2FaW1uBrIv1ggsu6OwuXbhwIevXr+cd73gHb3vb2xg1ahRf+9rXWLBgAYcddliP+7n00kv5xje+AcDBBx/Mo48+WsrD6he9aZnbG7izqOxHwE3AFJ/TKkmSSq2jZa6pqYlJk165qqvjIQARwRlnnNFZvmDBAiZMmMBdd3W97e2wYcPYsmVLt/t44IEHuO+++zoTuDVr1nS2AA5kvWmZawRWFZV1vF/av+FIkiRtbfjw4aSUeOmllxgyZEhneXNzMyklli9fzrBhwzrLH374YQ4//PCttjNhwgRuv/12Xn75ZQBWrVrFLbfcAsAll1zCvffey8KFC1m4cCEzZ86smZY5gL0i4nUF7+sLyrvcdjml9Jd+iUySJGkHLViwgFNOOWWr8qOOOoovfOELvOtd7yKl7BkI559/Pvfddx8ppc6RsACvf/3rqyKZi44D6XGBiC1s/cQHyJ76sFV5Sqm+m2UHnHHjxqU5c+ZUOgxJksrmscce46CDDqp0GOrBtj6fiJibUhrX3bzetMydvv1FJEmSVAm9eTbrzeUIpFwiYiIwcf/99690KJIkSTutT0+AqAUppbtTSmd3jH6RJEmqZoMumZMkSaolJnOSJElVzGROkiSpipnMSZIkVTGTOUmSpCpmMidJkmrWXXfdxfHHH8/tt9/OzJkzec973sNNN91U6bD6lcmcJEka8CZPnsyECRO6lM2bN4+I4JxzzulSfttttzF06FCWLFnC7NmzmTlzJr/85S+57bbbuOeee/jLX/7C+vXryxl+SZnMSZKkAW/kyJG0tbV1Kbvyyitpbm5mxYouj4ln6tSpTJo0iT322IOmpibq6up43euyR8w3NjbS0tLC5s2byxZ7qZnMSZKkAW/UqFFdkrlFixZxxx13cNZZZ3Upnz17NnPnzuXCCy8EYP/99+e4445jy5YtHH/88YwfP5729naGDx9e9mMold48m1WSJKmiilvmrr76ak488USOPPJI5s6d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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 10*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.17816989\n",
      "Converged gradient descent: test risk: 0.12504601\n",
      "6.870443537820389\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Stopped at iteration 2043 due to early stopping\n",
      "Gradient descent: test risk last: 0.12504993; test risk early stopped: 0.12504993; train loss: 4.500530170759021e-09\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 12*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.08634896\n",
      "Converged gradient descent: test risk: 0.03503405\n",
      "6.271828176216375\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Stopped at iteration 2178 due to early stopping\n",
      "Gradient descent: test risk last: 0.03503481; test risk early stopped: 0.03503481; train loss: 8.56333670640197e-09\n"
     ]
    },
    {
     "data": {
      "image/png": "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GTNmxGydtbXed/iLL75Ir169GozLzMys//3xxx/nhz/8IXPmzOGFF17gJz/5Cc8//zwXXnhhzGppjsJcnJgZWelpOswqIiISAyUlJQBMmzaNvLw8Ro0aBXiHR6urq3nkkUcoLS1l9OjRh72OrKwsampq6l8PGDCA7OxsVq1axVe/+tVm5x00aBCDBg3i9ttvZ/jw4TzxxBNceOGFhywzHhTm4igz3RTmREREYqCuZ27SpEk88MADpKV5R8AKCwsB7xDrz372M9LT0w97Hb1792b+/PmsXLmSgoICOnfuzG233cZtt92Gc46zzz6bqqoq3nnnHdLS0rjuuuv44osvmDZtGqNGjaJHjx6sWLGCDz/8sP7ed40ts672WEm5q1kTKSsjjX1xTuMiIiKpoK5nLisrizFjxtS3192dwsy49tpr27WO2267jaysLAYMGMARRxzB6tWrue+++7j33nuZMGECJ510El//+teZNWsWxx57LAB5eXksW7aMb33rW5xwwglcffXVXHnlldx+++1NLjPWzDkX84UmMzMbCYzs27fv+M8++yyu6zrtF69wzglH8OA3O/Yz4UREJBw+/vhjTjzxxKDLkCY0t3/MbIFzrqyxcSnXM5eo+8yB3zOnw6wiIiISRykX5hIpKz2N/TWp1fMpIiIiiaUwF0dZGem6NYmIiIjElcJcHGVlpLH3gC6AEBERkfhRmIujvMx09uxXmBMREZH4UZiLo/zsdKr3KsyJiIhI/CjMxVFeVga71TMnIiIicaQwF0dez9yBoMsQERGRDizlwpyZjTSz6RUVFXFfV25mBrv2qWdORERE4iflwlwibxqcn51O9b4DpNpTNkRERCRxUi7MJVJeVgbOwZ79uteciIhIkHbt2sW2bduCLiMuFObiKD87HYDqfTpvTkREJEh///vfmTp1atBlxIXCXBzlZWUAsEu3JxEREWmXsWPHMnz48AZtCxcuxMy44YYbGrTPnDmT3NxcNm/ezM9//nMefPBB9u3bB8AzzzzD1VdfnbC6E0FhLo7ys7yeuSpd0SoiItIuxcXFRF+8OGHCBLKzs9mxY0eD9smTJzNmzBi6devGbbfdhnOOG2+8kUmTJjFv3jwmTpyYyNLjTmEujgpzMwGo2L0/4EpERETCraSkpEGYW716NbNmzWL8+PEN2ufNm8eCBQu45ZZbANixYwfL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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 14*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.05377673\n",
      "Converged gradient descent: test risk: 0.01860264\n",
      "5.806584587860943\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Stopped at iteration 694 due to early stopping\n",
      "Gradient descent: test risk last: 0.01836611; test risk early stopped: 0.01835049; train loss: 3.694593397085555e-05\n"
     ]
    },
    {
     "data": {
      "image/png": "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uQDs3buX2bNnN91iJDs7m/LyckpLS5k7dy5z584N2TYbGhoAmD9/Pscee2yzacnJyU2fP/nkk3znO99h4cKFvPTSS/zwhz/kxRdfZNy4cSGr5UgU5sIoNyNF58yJiIiEQF5eHgBz5swhIyODiRMnAt7h0aqqKh555BEKCgqYNGnSUW8jJSWF+vr6pvcnnXQSqampbN26lQsvvPCIy44aNYpRo0Zx1113MX78eJ566inGjRt32DrDQWEujPIyUqipa6D6UB0ZKepqERGRo9U4Mjdjxgzuv/9+EhK8azizs7MB7xDrz372MxITE496GwMHDuS9995jy5YtZGVlkZ+fz5133smdd96Jc45zzz2XyspK3nnnHRISErjxxhvZvHkzc+bMYeLEifTr149Nmzbx4YcfNt37rrV1NtYeKnF3NWsk9czyHum1t1KHWkVERLqicWQuJSWFyZMnN7U3PmvdzJg2bVqXtnHnnXeSkpLCSSedRO/evdm2bRv33nsv99xzD9OnT2fEiBF88Ytf5Pnnn2fQoEEAZGRksG7dOq666ipOOOEEpkyZwte+9jXuuuuuNtcZauacC/lKY0FRUZFbunRpWLfxz492859PLeXFb53NqQNyw7otERGR9nz00UeceOKJfpchbTjS18fMljnnilqbFncjc5G8z1zPrFQA9lbWhH1bIiIiEp/iLsw55+Y7525sHJYNp56ZgcOsVTrMKiIiIuERd2EuknTOnIiIiISbwlwYZaQkkZacQGmVDrOKiIhIeCjMhVnPzFSNzImIiEjYKMyFWa+sFPbonDkREREJE4W5MOuTnUbx/oN+lyEiIiLdlMJcmBVmp/FpucKciIiIhIfCXJgV5qRRfqCWg7XhfS6biIiIxCeFuTAryE4DYJdG50RERCQM4i7MRfIJEADH5HhhTodaRURE/FNdXU1paanfZYRF3IW5SD4BAj4bmdutiyBERER889prrzF79my/ywiLuAtzkVYYGJnbpTAnIiJy1KZOncr48eObtS1fvhwz46abbmrWPm/ePNLT0ykuLubnP/85DzzwAIcOebcJ+93vfseUKVMiVnckKMyFWVZqEj1Sk3TOnIiISBfk5ubS8hSp6dOnk5qaSllZWbP2mTNnMnnyZPr06cOdd96Jc46bb76ZGTNmsGTJEh588MFIlh52CnMRUJCTpjAnIiLSBXl5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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 16*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.04865481\n",
      "Converged gradient descent: test risk: 0.01437558\n",
      "5.431562528774405\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Stopped at iteration 611 due to early stopping\n",
      "Gradient descent: test risk last: 0.01421477; test risk early stopped: 0.0142072; train loss: 0.00010995087359333411\n"
     ]
    },
    {
     "data": {
      "image/png": "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74KIiIhIxIikCyB6AZXOuRW1xi0C+jVi2cuBk4CfmdlsM/tOQzOZ2bjAId7527dvb3nFIiIiIj6LpAsgMoCSeuNKgMwjLeicexp4uhHzTQGmABQWFrpm1CgiIiISUSKpZ64MyKo3LgvY7UMtIiIiIlEhksLcCiDBzHrWGjcQWOJTPSIiIiIRz49bkySYWQoQD8SbWYqZJTjnyoGXgPvMLN3MTsG7+e8RD5+KiIiIxCo/eubuBvYAdwFXBX6/OzDtJrzblWzDuzr1RudcUHvmzGyEmU0pKal/ep6IiIhI9DHnYvM6gMLCQjd//ny/yxARERE5IjNb4JwrbGhaJJ0zJyIiIiJNpDAnIiIiEsUU5kRERESimMKciIiISBRTmBMRERGJYjEX5nRrEhEREWlNYi7MOedec86Ny87O9rsUERERkRaLuTAnIiIi0poozImIiIhEMYU5ERERkSimMCciIiISxWIuzOlqVhEREWlNYi7M6WpWERERaU1iLsyJiIiItCYKcyIiIiJRTGFOREREJIopzImIiIhEMYU5ERERkSimMCciIiISxWIuzOk+cyIiItKaxFyY033mREREpDWJuTAnIiIi0poozImIiIhEMYU5ERERkSimMCciIiISxRTmRERERKKYwpyIiIhIFFOYExEREYliCnMiIiIiUSzmwpyeACEiIiKtScyFOT0BQkRERFqTmAtzIiIiIq2JwpyIiIhIFFOYExEREYliCnMiIiIiUUxhTkRERCSKKcyJiIiIRDGFOREREZEopjAnIiIiEsUU5kRERESiWMyFOT3OS0RERFqTmAtzepyXiIiItCYxF+ZEREREWhOFOREREZEopjAnIiIiEsUU5kRERESimMKciIiISBRTmBMRERGJYgpzIiIiIlFMYU5EREQkiinMiYiIiEQxhTkRERGRKKYwJyIiIhLFFOZEREREopjCnIiIiEgUi7kwZ2YjzGxKSUmJ36WIiIiItFjMhTnn3GvOuXHZ2dl+lyIiIiLSYjEX5kRERERaE4U5ERERkSimMCciIiISxRTmRERERKKYwpyIiIhIFFOYExEREYliCnMiIiIiUSzB7wJatX/eBVs+9bsKERERCaV2/WH4b3zbvHrmRERERKKYeuZCyceULiIiIrFBPXMiIiIiUUxhTkRERCSKKcyJiIiIRDGFOREREZEopjAnIiIi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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 18*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02368349\n",
      "Converged gradient descent: test risk: 0.00689835\n",
      "5.120926262046845\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Stopped at iteration 469 due to early stopping\n",
      "Gradient descent: test risk last: 0.00675104; test risk early stopped: 0.00674686; train loss: 0.00011812477896455675\n"
     ]
    },
    {
     "data": {
      "image/png": "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/MtRs3zdZaj+ud4y1fuiqnYwrlOPf3/VihBftXFcW51567TV3feNL193vvrz0lhNDdURQM3VUxqqo7GavbpY3KtA6eXV8d595tBv88rTTgn9RmtRmBORiGBmxMca8bGQjJ66ISJSTZe1iYiIiEQwhTkRERGRCKYwJyIiIhLBFOZEREREIljUhTkzG21mzxYXF3tdioiIiEiLRV2Yc87Nc85NzMjI8LoUERERkRaLujAnIiIi0pYozImIiIhEMIU5ERERkQimMCciIiISwRTmRERERCKYwpyIiIhIBFOYExEREYlgCnMiIiIiESzqwpyeACEiIiJtSdSFOT0BQkRERNqSqAtzIiIiIm2JwpyIiIhIBFOYExEREYlgCnMiIiIiEUxhTkRERCSCKcyJiIiIRDCFOREREZEIpjAnIiIiEsEU5kREREQimMKciIiISASLujCnZ7OKiIhIWxJ1YU7PZhUREZG2JOrCnIiIiEhbojAnIiIiEsEU5kREREQimMKciIiISARTmBMRERGJYApzIiIiIhFMYU5EREQkginMiYiIiEQwhTkRERGRCKYwJyIiIhLBFOZEREREIpjCnIiIiEgEU5gTERERiWBRF+bMbLSZPVtcXOx1KSIiIiItFnVhzjk3zzk3MSMjw+tSRERERFos6sKciIiISFuiMCciIiISwRTmRERERCKYwpyIiIhIBFOYExEREYlgCnMiIiIiEUxhTkRERCSCxXldQJv25wdg12deVyEiIiLBlD8IRv3Ss82rZ05EREQkgqlnLpg8TOkiIiISHdQzJyIiIhLBFOZEREREIpjCnIiIiEgEU5gTERERiWAKcyIiIiIRTGFOREREJIIpzImIiIhEMIU5ERERkQimMCciIiISwRTmRERERCJY1IU5MxttZs8WFxd7XYqIiIhIi0VdmHPOzXPOTczIyPC6FBEREZEWi7owJyIiItKWmHPO6xo8YWZ7gS0h2FQOsC8E25HWoeMVWXS8IouOV2TR8Qov3ZxzHRqaELVhLlTMbJlzbqjXdUhgdLwii45XZNHxiiw6XpFDw6wiIiIiEUxhTkRERCSCKcwF37NeFyBNouMVWXS8IouOV2TR8YoQOmdOREREJIKpZ05EREQkginMiYiIiEQwhbkgMbNsM3vDzMrMbIuZ3eh1TdHMzO4ys2VmdsTM5tSbdpmZrTWzcjNbaGbdak1LNLPfmlmJme0ys8khLz7K+Pf5c/5/NwfN7BMzG1Vruo5XGDKzl8xsp3/frzOz22tN0zELQ2bWx8wOm9lLtdpu9P/bKzOzN80su9Y0fa+FKYW54HkGqADygO8CvzKzgd6WFNV2AI8Bv63daGY5wOvAQ0A2sAz431qzPAz0AboBlwD/aWZXhqDeaBYHbAUuAjLwHZtXzKy7jldY+2+gu3MuHRgDPGZmZ+mYhbVngH9W/+L/jpoF3Izvu6sc+J968+t7LQzpAoggMLNU4ABwmnNunb/tRWC7c+4BT4uLcmb2GNDZOTfe//tEYLxzbrj/91R8dzw/wzm31sy2A7c65971T38U6OOcu96TDxClzOxT4GdAe3S8wp6Z9QMWAT8EMtExCztmdj0wFlgD9HbO3WRmv8AXyG/0z9ML+Bzfv7sq9L0WttQzFxx9gcrqP3i/lYD+Dyb8DMR3bABwzpUBXwIDzSwL6Fh7OjqOIWdmefj+Ta1Gxyusmdn/mFk5sBbYCbyDjlnYMbN04BHg3nqT6h+rL/H1xPVF32thTWEuONKA4nptxUA7D2qRxjV2rNJq/V5/moSAmcUDvweed86tRccrrDnn7sS3v0fgG1o9go5ZOHoUeM45t7Ve+8mOlb7XwpTCXHCUAun12tKBgx7UIo1r7FiV1vq9/jQJMjOLAV7E1zNwl79ZxyvMOecqnXMfAp2BSeiYhRUzGwJ8DZjewOSTHSt9r4UphbngWAfEmVmfWm2D8Q0TSXhZje/YADXn8/QCVjvnDuAbKhpca34dxxAwMwOew3ei9XXOuaP+STpekSMO/7FBxyycXAx0BwrMbBdwH3Cdma3g+GPVE0jE952m77UwpjAXBP5zQl4HHjGzVDM7H7gWXy+DeMDM4swsCYgFYs0syczigDeA08zsOv/0nwKf+of0AF4AHjSzLDPrD0wA5njwEaLNr4BTgdHOuUO12nW8wpCZ5ZrZ9WaWZmaxZjYSuAF4Dx2zcPMsvjA9xP/6NfA2MBLfKQ2jzWyEP3Q/ArzunDuo77Uw55zTKwgvfJfgvwmUAQXAjV7XFM0vfLc/cPVeD/unfQ3fCduH8F2B173Wcon4bmdSAuwGJnv9Wdr6C98tKhxwGN/QTvXruzpe4fkCOgDvA0X+ff8ZMKHWdB2zMH35/9v4Uq3fb/R/Z5UBfwKya03T91qYvnRrEhEREZEIpmFWERERkQimMCciIiISwRTmRERERCKYwpyIiIhIBFOYExEREYlgCnMiIiIiEUxhTiSIzGy8mTkz612r7W4zG+thTZlm9rCZndnAtEVmtsiDslqFmfU3s/fMrMS/37/udU0nUn9fm9nF/povDuI2x5vZbS1cx8Nm1ibuadXYv4UTzD/HzLYFuy6RporzugCRKHQ38CG+u6l7IRP4L2AbsKLetDtDX06rmgb0BL6N7wa2X3hbTpOsAM4D1gRxG+Px/Xf/t0HcRiRp7N+CSMRQmBNpA8ws0Tl3pKXrcc4FM0iEwqnAYufcgmBtwMzigWOule+47pwrAZa05jpFJDpomFUkhMxsM77HVX3XP6TmzGxOremDzewtMztgZofM7O9mNqLeOuaY2TYzO8/M/mFmh4An/NOu9w8z7jWzUjP7xMxuqbVsd2CT/9ff1KphvH/6ccOsZtbPzN4wsyJ/TUvM7Mp68zzsX08fM3vbv+0tZvZTM4upNV+amT1lZgVmdsTMdpvZX/3P5Gxsv8Wb2WNmttnMKvzvj/mDVc0QJb4HiN9c/blOss6v+ffPYTPbYGa3+/ft5tr7y7+uO83sCTPbARwBMs2sg5nNMrN1ZlZuZlvNbK6ZdWpgW9eb2Vr/Z15tZt9oYJ4Gh1nNbKx/n5f7j8EfzaxrvXk2m9lL/u18bmZlZrbMzC6oNc8i4CLg/FrHfdFJ9tEZZvaBfx9tN7OHAGtgvjgz+1Gtz7jDzKaa71msted51My+9K9vn5l9WLtG/3wTzGyF/2/tgJm9b2bDa01PMbPHzWyT/29hk5n9pN7fWfW+HGNmT/u3tde/jzL983SnkX8LgTKzW83sqJk90JTlRFqTeuZEQusbwDvASnzPRATYC2C+83Y+AD7B97DxcuB7wF/NbLhzbnmt9WQAfwCmAD/G98xL8A0xvgr8EqgCLgRmm1myc+7XwE5gLL4h3v8G3vIv92VDxZpZR3xDwgeBu4Bi4PvA22Z2jXPuz/UWeQP4HTAdGA38DNjqb8PfPsZf83qgPXA+vuGuxjyPb+j0F/56zgMe9H/eG/lqiPIt4J/Ao42tzMwG4Hu4+FLgeiABeAjffq1qYJGf+Nc7EYjF99zYrv73H+E7hh2Be4G/m1l/59xh/7a+Bsz1b+9efM8xnQHEc5JhYDP7HvArfPvvEaAdvr+b983sdOfcwVqzjwD6+T/HYf8+mG9m3Z1zRfiG0F/y13+Hf5mSRradA7wH7Pr/7Z17jB5VFcB/p7t9gjQ12EcIWmK1SnygKUITC4TUpBYiIERq66MoGjXyENJUkIYlWpMmQEMQk2rQxQgrEbXG8mhp4yrYYptU2wWspupWC33YFoFCW/o4/nHOdO/enfn2+9Z2t0vPL5l8mTP3u/fMnTuZ853HfMDnMSN2np93zk+x670IWI15SL+NGddXepv5wDewufwzcBowBfu/z2LMO7E5uh8Lfx4BzvcxV4tIM7AcONv77/DjC7yfmzO97gGWYWtkMvaj57CfT0P3Qhkicgu2xr+kqq31fi8IjjkD/eewscX2Zt6wHCUFJiWyTpI/tk7kq4C/AMMSWZPLliayVu/zsl7GHoL9YPshsCGRT/TvX1vynXagPdm/EziU6d+EGSHrE1mL93lN1l8HsCLZorh8AgAABzZJREFUfxa4u8E5fJ/33ZLJb3P5BxLZVqC1jj4fwgywUYlsAmYEdZbM1Xqw/7Ku0WcTcKa3vyKR/wHLgxuSyM7zdulcX+Syi3z/VMx4/lE2zkTgDeDGbE29BIxJZFO8v9mJrB14us55X+jjvD2RnQLsskfHUdk0H+dz2ffnuPwc318G/LLGeJMwQ6tyfQCf9T4vyOTfcl3HZnP5QNbue36Ni/8lL65vj3uhYvxWX2NDgHuxP5y/pJH1HFtsx2OLMGsQnACIyEgsBPZz4IiHpJqxkNZKzMOWcgh7OOb9vEtE2kTkBeCgb9diXom+cAHwjKpuLgSqehhoA84RkdOy9o9m+8/S3ZOzDpgrIreKyBQRaapTBzDvT0qxf2EdfeScDzymqq8XAlXdhnmVyliqqj3CtiLyVRHZICJ7sWvyLz802Y83AecCj6jqUY+fqv4RM8BqMRXzXj1YrAdfE1uBTfRcE2tU9aVkv8M/yzxp9TAVu/bFOaGqrwG/ydrNwAypX2R6rvDjhZ7rgJkislBEPioiw7J+pmNG0g9q6DQD2IJ76bKxhmLXNSVfjx3AcGBcjTF6oxnzis8GpqtqPkYQ9DthzAXBicFbMc/OArqMsGL7OjAmzQkCdrpRdRQRORV4Evgg8E3MY3IuVrk4/P/Qa1uJfDtmaI7J5Huy/QPAiGT/OmAJ8AXs4b5TRBaLyKhedKBEj+3Z8UaYAOwske+oaN9jDkTkOuD7mLH9SeAjdBkTxTmfjhkZZf1WjVUw1j9X0nNNvB8LUad0m3vtKogZQd+YUKFjLhuLhan3ZjoW81vo+V0sdPoJLJ1gt4j82MO5abtar/4Yi+Wc5vOxNuujoGw9Qt/nBMzAvgQz/Nf20jYI+oXImQuCE4P/YvlB9wE/KWuQenaw0FDOVOxBN01Vny6E7rnoK3uA8SXy8a5D/rCsiaruxXLMbhGRdwBXYfl9b2A5VVU6FGOm+UyFXrsb0cHZRpexlFLlsSmb71nAKlU9mqclImdlbXZhxkZZv+MwL1MVxXnNBZ4rOf5qiexYso1qvVN2Y6HLaSVtAV4EUNWDWE7dIhEZD1yKvUpmFHA1NlcAZ1CdS7gbK1r4VMXxzgr5sWQP8BnMM94mIrNV9VA/jBsElYQxFwT9zwFgZCpQ1ddE5CnMq7Y+M9zqpfBuHSwEIjIGuKxkfHIdKvgdcKMn0Xd6n03Yw/dP2j0BvyFUdQtwl4jMwfLiaukAZjwtTORz/PP3fRj+GSzkN6oItYrIBKwYo8wTWcYoehYQXJPuqOphEVkHXCUiLcV1FZHzsHytWsbcasxgm6SqD9SpU28cwIoo6mENME9EzlTVfwOIyClYoUPKE5ghPlpVV9XTsapuxwpzZtJ17VdiP2i+TM9ChnSsK4G9qrqpzvOoRSP3wlFUtV1EPo4VM/1MRGaFQRcMJGHMBUH/8zwwTUQuxUKFu9xQugkzTJaLyP2YUXE68GGgSVV7e/XBasy4uE9EbseS1W/DPB6jk3Y7MA/HLBHZiCVx/1NVyzxcizHP0JPe5ytYVeS7sVBTQ4jIGqxqsAMLy12IGbCVxoqqPicibUCLexlXY17IBUCbqm5sVA/gO5hXcLlXUA73/nZQXs1axhPAfBG5FQu3Xex95tyO5XQtFZElWDXrHXSFiUtR1VdEZB52Pd8GPI4VRJyBzVu7qj5Up64FzwNfE5GrMS/nq6pa5QVbjF3rFSLSQlc16760kRs2bcAjInI3NhdHMGN1JjBfVf8mIr/GqrjXY8UaH8Jy4JZ4P38XkcXATSLyFmydHMbC15tU9WHgQcxgXiUid3l/w4B3YuHby9M8yDpo5F7ohqo+JfaKnseBh92gO9jb94LguDDQFRixxfZm3iivZn0PljP0uh9rTY69F0uu3ok9PLdiD7WZSZtWYGvFeBdjrzbZhz2sr8crTbN2l2MP9oOuw1yXt5NUWLpsMrAUMyT2Y16tGVmbFu+nOZO30r06dJHr9zL24OwArq9jHodiBtgW13mL7w/N2tVVzeptP4a9IuMA8A/sdR2/wjyORZuJVFf+jsReG/IfzIO2DDiL8srbT2OhwwNYyPSKfK7JqlkT+Uzgt5ghvQ/YjOVBnp206aS8QrqbLlho+jHXt1s1bcUcFa/L2Q+8gBm8d5SspyHADZhxtd+v7wbsVSCjvc3NvnZ2+3n81ddNfg2/Amz0udrj8zQ1OT7Cv7cpabPOZc3ZXE6vuB8n9nYvVMxHK9m9h/2weBm7R4bVms/YYjteW1GeHQRBcFLjBSSbgUdV9YsDrU8QBEG9RJg1CIKTEhG5FwvZvoi98PcGrDr3noHUKwiCoFHCmAuC4GRlBBb2HYdV067FwnJ9ycELgiAYMCLMGgRBEARBMIiJlwYHQRAEQRAMYsKYC4IgCIIgGMSEMRcEQRAEQTCICWMuCIIgCIJgEBPGXBAEQRAEwSAmjLkgCIIgCIJBzP8A0SJ+F++HvPsAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 22*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02108437\n",
      "Converged gradient descent: test risk: 0.0060645\n",
      "4.632052088259977\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 295 due to early stopping\n",
      "Gradient descent: test risk last: 0.00552235; test risk early stopped: 0.00549298; train loss: 0.0004633409553207457\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 24*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02044583\n",
      "Converged gradient descent: test risk: 0.0069591\n",
      "4.434852233839456\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 330 due to early stopping\n",
      "Gradient descent: test risk last: 0.005871; test risk early stopped: 0.00583096; train loss: 0.000600963132455945\n"
     ]
    },
    {
     "data": {
      "image/png": "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tg14HbC/5sIwx10eEJj9O7M27psm4b2lfTd9H//6/fPb/mvdpvv2zwt4TUDdre278T9UmuzbWj5+a/umyXs+JTcdLynMiYgEkZn/tKpu4hWRMNFgUSIiIiJRTGFOREREJIopzImIiIhEMYU5ERERkSimMCciIiISxRTmRERERKJYzIU5M5toZgtKSkq8LkVERESkw2IuzDnnljrnZmRltfycSREREZFoEXNhTkRERKQzUZgTERERiWIKcyIiIiJRTGFOREREJIopzImIiIhEMYU5ERERkSimMCciIiISxRTmRERERKKYwpyIiIhIFFOYExEREYliMRfm9GxWERER6UxiLszp2awiIiLSmcRcmBMRERHpTBTmRERERKKYwpyIiIhIFFOYExEREYliCnMiIiIiUUxhTkRERCSKKcyJiIiIRDGFOREREZEopjAnIiIiEsUU5kRERESimMKciIiISBRTmBMRERGJYgpzIiIiIlEs5sKcmU00swUlJSVelyIiIiLSYTEX5pxzS51zM7KysrwuRURERKTDYi7MiYiIiHQmCnMiIiIiUUxhTkRERCSKKcyJiIiIRDGFOREREZEopjAnIiIiEsUU5kRERESiWILXBXRqf70T9q33ugoREREJpR4jYPzPPDu8euZEREREoph65kLJw5QuIiIisUE9cyIiIiJRTGFOREREJIopzImIiIhEMYU5ERERkSimMCciIiISxRTmRERERKKYwpyIiIhIFFOYExEREYliCnMiIiIiUUxhTkRERCSKxVyYM7OJZragpKTE61JEREREOizmwpxzbqlzbkZWVpbXpYiIiIh0WMyFOREREZHOxJxzXtfgCTMrBHaG4VC5wMEwHKezUHu1n9qs/dRm7ac2az+1WfupzVp2snMur7kFMRvmwsXM1jjnCryuI1qovdpPbdZ+arP2U5u1n9qs/dRmJ0anWUVERESimMKciIiISBRTmAu9BV4XEGXUXu2nNms/tVn7qc3aT23WfmqzE6Br5kRERESimHrmRERERKKYwpyIiIhIFFOYCxEz62pmfzSzMjPbaWbXel1TpDGzlWZWYWal/umjgGXX+tutzMxeMLOuXtbqBTO7yczWmFmlmS1qsmysmW02s3IzW2FmJwcsSzazX5vZETPbZ2a3hr14j7TUZmbWz8xcwGet1MzuCVgey22WbGa/8v99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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 30*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01153009\n",
      "Converged gradient descent: test risk: 0.00452758\n",
      "3.9666524260127263\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 219 due to early stopping\n",
      "Gradient descent: test risk last: 0.00363564; test risk early stopped: 0.00361065; train loss: 0.0009452577796764672\n"
     ]
    },
    {
     "data": {
      "image/png": "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xs+ZM4fp06eTmZnJjh07+OY3v8kvfvELpk6dGs6Swybmwlw49c5MVTeriIhIEOTk5DQKc9u2beO5557jhhtuaDR++fLlrFy5kttuu401a9Zw+umnA5CQ0PobTGfMmMGbb77J448/jplhZhQVFeGc48EHH2TYsGGkpqYybtw4nnnmmUbLLl++nNNPP52MjAyysrI47bTTWLNmTYvrDDaFuRDqm52iblYREZEgaNoy98gjjzB16lROOeWURi1zs2fPprCwkFGjRrF69WomT57Mk08+yZVXXklZWctPmJg7dy5nnHEG1113Hbt372b37t0MGDCAu+++m1/96lc8/vjjrFu3jh/+8Id85zvf4eWXXwagpqaGyy+/nLPOOovVq1fz/vvv84Mf/ID4+PgW1xlsrcdU6ZLeWSmUHjlGZXUNaUk61CIiEnn+66W1rNsV3sdojembyX8Wju3QMoFhrqysjIULF7J06VL279/fMH7Tpk0sWbKEZcuWAb47Wc8//3zGjx/PrbfeyvTp03nhhReafS9tVlYWSUlJpKWl0bt3b8D3LtuHH36YV199lcmTJwMwZMgQPvjgAx5//HEuvfRSysrKKCkpobCwkGHDhgEwevTohvU2XWcoKGGEUJ+sFAB2l1YxLD/D42pERESiV05ODuXl5dTW1jJ//nzGjRvHpEmTeOONNxpa5ubMmcPEiRMbgtfcuXMblr/22mu59tprO7TNdevWUVVVxSWXXNIoAB47dozBgwcDkJuby4wZM7j44os5//zzOf/88/n6178ekha4lijMhVAf/7PmdpcozImISGTqaAuZV7KzswE4ePAg8+bNa3jESGZmJqWlpRQXF7No0SIWLVoUtG3W1dUB8NJLLzFw4MBG0xITExs+f+KJJ7jllltYunQpL774Iv/xH//B4sWLufjii4NWS2sU5kLoi5Y53dEqIiLSFTk5OQDMnz+ftLQ0LrvsMsDXPVpRUcFjjz1GQUEB06ZN6/Q2kpKSqK2tbfh6zJgxJCcns3XrVs4777xWlx0/fjzjx4/nzjvvZMqUKTz55JNcfPHFx60zFBTmQqgg0xfmdEeriIhI19S3zD388MM88MADxMX57uHMzMwEfF2sP/7xj4mPj+/0NgYPHswHH3xAUVERGRkZ5Obmcscdd3DHHXfgnOPss8+mvLyc9957j7i4OG688Ua2bNnC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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 36*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01148678\n",
      "Converged gradient descent: test risk: 0.00471814\n",
      "3.6210416858496033\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 212 due to early stopping\n",
      "Gradient descent: test risk last: 0.0033526; test risk early stopped: 0.00333533; train loss: 0.001199841732159257\n"
     ]
    },
    {
     "data": {
      "image/png": "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5KcDsKvsqM+ViIiIJK5Vq1ZxxhlnUFFRwZQpU3j88cf9LinsEi7MRWucufSUZIpz0tUzJyIiEgbTpk1j4sSJzdpWrlyJmXHrrbc2a1+4cCGZmZns27ePdevWkZOTwxVXXMFNN93U7inXiy66iNtuuy2sdUdinS0lXJiL5jhzfQoy1DMnIiISBgUFBbTsiHnkkUdIT0+ntLS0WfusWbOYOnUqeXl57Nixg29+85v84he/YNKkSdEsOWoSLsxF00n5GewuU8+ciIhIVxUWFjYLc9u2beP555/n5ptvbta+dOlSVqxYwZ133snatWs599xzAUhJaf8JptOmTePNN9/kySefxMwwM7Zs2YJzjocffpghQ4aQmZnJ6NGj+c1vftNs2aVLl3LuueeSk5NDfn4+55xzDmvXrm1zneGmMBdBJ+Vnsrv0KM45v0sRERGJay175h577DEmTZrEuHHjmvXMPfroo0yePJnhw4ezatUqJkyYwNNPP80111xDeXl5m+ufPXs25513HjfccAO7d+9m9+7d9O/fn/vuu49f/epXPPnkk6xbt44f/ehHfOc73+GVV14BoK6uji996UtccMEFrFq1ivfee48f/OAHJCcnt7nOcGs/pkqX9CnIoLKmnvLqOvIzU/0uR0RE5Dj/8vKHrNvVdsiJhJF98vjnyaM6tExwmCsvL2f+/PksXryY/fv3N7Vv3LiRRYsWsWTJEsC7k/XSSy9lzJgx3HHHHUydOpUXX3yx1efS5ufnk5aWRlZWFr179wa8Z9nOnDmT1157jQkTJgAwaNAgli1bxpNPPslVV11FeXk5paWlTJ48mSFDhgAwYsSIpvW2XGckKMxF0EmNw5OUHVWYExER6YLCwkIqKiqor69n7ty5jB49mvHjx/PGG2809czNmjWLsWPHNgWv2bNnNy1//fXXc/3113dom+vWraO6uporr7yyWQCsra1l4MCBABQVFTFt2jSuuOIKLr30Ui699FK+/vWvR6QHri0KcxHUpyAD8MaaG9E7z+dqREREjtfRHjK/FBQUAHDw4EHmzJnTNMRIXl4eZWVlHDp0iAULFrBgwYKwbbOhoQGAl19+mQEDBjSblpr6WSfNU089xe23387ixYv585//zD/90z/x0ksvccUVV4StlvYozEVQY8+c7mgVERHpmsLCQgDmzp1LVlYWV199NeCdHq2srOSJJ56gpKSEKVOmdHobaWlp1NfXN30/cuRI0tPT2bp1K5dcckm7y44ZM4YxY8Zwzz33MHHiRJ5++mmuuOKK49YZCQpzEdQrN50k01MgREREuqqxZ27mzJk89NBDJCV593Dm5XlnvmbNmsVPf/pTkpOTO72NgQMHsmzZMrZs2UJOTg5FRUXcfffd3H333Tjn+PznP09FRQXvvvsuSUlJTJ8+nc2bNzN37lyuvvpq+vbty6effsrq1aubxr5rbZ2NtYeL7maNoJTkJEryMthVqp45ERGRrmjsmUtLS2Pq1KlN7Y3jxpoZN954Y5e2cffdd5OWlsbIkSPp2bMn27Zt44EHHmDGjBk88sgjjBo1issuu4znn3+eQYMGAZCVlcWGDRv4+te/zimnnML111/Ptddeyz333NPmOsPNEm3YDDObDEweOnTozZ988knEtzflP94mLSWJ308/L+LbEhERac9HH33Eqaee6ncZ0ob2jo+ZrXDOjW1tWsL1zEXzCRAAJxVkauBgERERiZiEC3PR1ifwFIhE6wEVERGR6FCYi7CT8jOpqWvgYGWN36WIiIhIN6QwF2F9CgIDB+uOVhEREYkAhbkIaxw4WGPNiYiISCQozEVY0yO9NDyJiIiIRIDCXIT1yE4jLTlJd7SKiIhIRCjMRVhSktE7P4Od6pkTERGRCFCYi4L+RZnsOKwwJyIiIuGnMBcF/Quz2H6oyu8yREREpBtSmIuC/kVZHKysofJYnd+liIiIJKSqqioOHTrkdxkRkXBhzswmm9m8srKyqG2zf1EWANsPq3dORETED6+//jpz5szxu4yISLgwF+1nswIMaAxzh3TdnIiISGdMmzaNiRMnNmtbuXIlZsatt97arH3hwoVkZmayb98+/vVf/5WHH36YmhrvSUy///3vuf7666NWdzQkXJjzQ/9Cb6y5bbpuTkREpFMKCgpoeVbtkUceIT09ndLS0mbts2bNYurUqfTq1Yu7774b5xzf/e53mTlzJkuXLuXRRx+NZukRpzAXBUXZaWSnJesmCBERkU4qLCxsFua2bdvG888/z80339ysfenSpaxYsYI777wTgNLSUjZs2EBWVhYFBQVs3LiRPXv2RL3+SFKYiwIzo3+R7mgVERHprJY9c4899hiTJk1i3LhxzXrmHn30USZPnszw4cMB+OMf/8ikSZOYM2cON954Iw8++CDPPPNM1OuPpBS/C0gU/Yuy2HKg0u8yREREmvvLvbBnTXS32Xs0TPx5hxYJDnPl5eXMnz+fxYsXs3///qb2jRs3smjRIpYsWdK03G233QbAokWLADj77LM5++yzw/AmYod65qJkQFEW2w9X4ZzzuxQREZG4U1hYSEVFBfX19cydO5fRo0czfvx48vLymnrmZs2axdixY5kwYcJxy3/xi19kxowZUa46OtQzFyX9CzOprm1gf8UxeuVm+F2OiIiIp4M9ZH4pKCgA4ODBg8yZM4fHH38cgLy8PMrKyjh06BALFixgwYIFPlbpD/XMRcmAHhqeREREpLMKCwsBmDt3LllZWVx99dUA5OfnU1lZyRNPPEFJSQlTpkzxs0xfKMxFSf/CxjCnmyBEREQ6qrFnbubMmdx1110kJXkRJi8vD/BOsd5xxx0kJyf7VqNfFOaipJ/CnIiISKc19sylpaUxderUpvbGhwCYGTfeeKMvtflN18xFSWZaMj1z0zVwsIiISCfk5OS0ehNhenp6wt9cqJ65KGq8o1VEREQkXBTmomhAUZZugBAREZGwUpiLov6FmewqO0pNXYPfpYiIiEg3kXBhzswmm9m8lg/rjYaTe2TjHDrVKiIiImGTcGHOOfeyc256490v0TSoZzYAm/frsV4iIiISHgkX5vw0uDgQ5vSMVhEREQkThbkoKshKozArlU8V5kRERCRMFOaibFBxNpsPVPhdhoiIiHQTCnNRNrA4my0HdAOEiIiIhIfCXJQNLs5mT3k1lcfq/C5FREREugGFuSgbVJwDwJaDum5OREREuk5hLsoG6Y5WERGRDps2bRoTJ05s1rZy5UrMjFtvvbVZ+8KFC8nMzGTfvn3RLNE3CnNRNrA4C9BYcyIiIh1RUFBAywH/H3nkEdLT0yktLW3WPmvWLKZOnUqvXr2iWaJvUvwuINFkpaXQOy+DzTrNKiIiErLCwsJmYW7btm08//zzTJ8+nU2bNjW1L126lBUrVvCb3/zGjzJ9oZ45H3jDkyjMiYiIhKplz9xjjz3GpEmTGDduXLOeuUcffZTJkyczfPhwP8r0hXrmfDCoZzavrtntdxkiIiI8tOwh1h9aH9VtjigawT1n39OhZYLDXHl5OfPnz2fx4sXs37+/qX3jxo0sWrSIJUuWADB79mwefvhhiouLqaqqYs6cOU3X3T377LPMnj2bY8eO0dDQwB133MFNN93UtL1vfetbbN68mXfffTcM7ziy1DPng8HF2ZRW1XK4ssbvUkREROJCYWEhFRUV1NfXM3fuXEaPHs348ePJy8tr6pmbNWsWY8eOZcKECQCsXbuWhx56iFWrVjF79mzuu+8+AJ566inmzZvHq6++ypo1a/jb3/5GcnJy07bWrl3Lpk2b+OSTT6L/RjtBPXM+aLyj9dMDlZyVneZzNSIiksg62kPml4KCAgAOHjzInDlzePzxxwHIy8ujrKyMQ4cOsWDBAhYsWNC0zJo1a7jlllsA6N+/P3V1dVRUVDBjxgzeeeedphskioqKuOGGG5qWu//++3nwwQe5/fbb2b59O/3794/Su+wc9cz5YKCGJxEREemQwsJCAObOnUtWVhZXX301APn5+VRWVvLEE09QUlLClClTAHDO8dFHHzF8+HAaGhp44oknuOqqq/jDH/7AuHHj6NOnT6vbWbFiBYcOHeLyyy/n1FNP5cMPP4zOG+wChTkfDCjKIiXJ2LRfz2gVEREJRWPP3MyZM7nrrrtISvIiTF5eHuCdYr3jjjuaTpdu2bKF6upqLrjgAs4991wKCwv5yU9+wtq1azn99NPb3M7999/PAw88AMDIkSNZt25dJN9WWOg0qw9Sk5MYVJzNxn0KcyIiIqFo7JlLS0tj6tSpTe35+fkAmBk33nhjU/vatWuZOHEiL730UrP1ZGdn09DQ0Oo2/v73v/PGG280BbjKysqmHsBYpp45nwztlaMwJyIiEqKcnBycc+zdu5eMjIym9vT0dJxzHDp0iOzs7Kb2NWvWMGbMmOPWM3HiRH73u99x4MABAI4cOcIzzzwDwH333cdrr73Gli1b2LJlC4sXL46LnjmFOZ8M65XD1oOVVNfW+12KiIhIt9PW6dTx48fzwx/+kEsuuaTpjtiamhreeOMNnHNNd8ICDBs2LC7CnE6z+mRoSS4NzrsJ4tST8vwuR0REpFtZuHBhm9NuuummZmPKNbr44oubfd94p2ysU8+cT4b1ygHQqVYRERHpkoQLc2Y22czm+Z20BxVnk2TwicKciIiIdEHChTnn3MvOuemNd7/4JSM1mQFFWWzcd8TXOkRERCS+JVyYiyVDe+XyyV71zImIiEjnKcz5aFhJDlsOVlJb3/p4NyIiIiInojDno2G9cqitd2w9WOV3KSIiIhKnFOZ8NLTpjlZdNyciIiKdozDnoyE9vTCn6+ZERESksxTmfJSdnkLfgkwNTyIiIhIhL730Epdffjm/+93vWLx4MZdddhnz58/3u6ywUpjz2bCSHIU5ERGRE5g2bRoTJ05s1rZy5UrMjFtvvbVZ+8KFC8nMzGTfvn0sXbqUxYsX8/rrr7Nw4UJeeeUVPv30U6qrq6NZfkQpzPlseEkum/ZV6I5WERGRdhQUFBz3aK1HHnmE9PR0SktLm7XPmjWLqVOn0qtXL9LS0khKSmLw4MEApKamkpWVRV1dXdRqjzSFOZ8N751LTX0DWw5U+l2KiIhIzCosLGwW5rZt28bzzz/PzTff3Kx96dKlrFixgjvvvBOAoUOHcumll9LQ0MDll1/OhAkTqK+vJycnJ+rvIVJS/C4g0Y3onQfAR3uOMKwk1+dqREREYlPLnrnHHnuMSZMmMW7cOFasWNHU/uijjzJ58mSGDx8OwE033cRNN93UNP3b3/529IqOEoU5nw3plU1ykvHxnnIY08fvckRERGJScJgrLy9n/vz5LF68mP379ze1b9y4kUWLFrFkyRIfK40+hTmfpackM7g4m4/3aKw5ERGJvj0/+xnHPlof1W2mnzqC3j/+cYeWKSwspKKigvr6eubOncvo0aMZP348b7zxRtM1c7NmzWLs2LFMmDAhEmXHLIW5GDDipDxWbj3sdxkiIiIxq6CgAICDBw8yZ84cHn/8cQDy8vIoKyvj0KFDLFiwgAULFvhYpT8U5mLAiN65vLxqF+XVteRlpPpdjoiIJJCO9pD5pbCwEIC5c+eSlZXF1VdfDUB+fj6VlZU88cQTlJSUMGXKFD/L9IXuZo0BI3p7Nz5s0KlWERGRVjX2zM2cOZO77rqLpCQvwuTleTcSzpo1izvuuIPk5GTfavSLwlwMGB4Ic+sV5kRERFrV2DOXlpbG1KlTm9rz8/MBMDNuvPFGX2rzm06zxoC+BZnkpqewfk+536WIiIjEpJycHJxzx7Wnp6e32p5I1DMXA8yM4b1zdUeriIiIdJjCXIwY3juX9XuOJPxfFyIiItIxCnMxYsRJeRyprmNXWfd58K+IiIhEnsJcjDg1cBPER7t03ZyIiIiETmEuRpx6Uh5m8KHCnIiIiHSAwlyMyE5PYVCPbD7cVXbimUVEREQCFOZiyKl98tQzJyIiEaUb7WJTV46LwlwMGdUnj52lRymrqvW7FBER6YZSU1M5evSo32VIK44ePUpqauce6akwF0NG9fFGsf5wt061iohI+PXq1YudO3dSVVWlHroY4ZyjqqqKnTt30qtXr06tQ0+AiCGj+njPl1u3q5zxQ4p9rkZERLqbxueY7tq1i9panQWKFampqZSUlDQdn45SmIshxTnplOSl67o5ERGJmLy8vE6HBolNOs0aY0b1ydcdrSIiIhKybhHmzCzfzJaZWYWZneZ3PV0xqk8em/ZXUl1b73cpIiIiEge6RZgDqoCrgOf8LqSrRvXJo77BsX7PEb9LERERkTjQLcKcc67WObff7zrCYeRJ3h2t63TdnIiIiIQg6mHOzG4zs+VmdszMFrSYVmRmL5pZpZltNbNrol2f3/oXZZKbkcJaXTcnIiIiIfDjbtZdwIPAFUBmi2lPAjVACXAG8IqZrXLOfWhmvWn9NOrXnHN7IllwNJkZo/vms3anwpyIiIicWNTDnHPuBQAzGwv0a2w3s2zgq8BpzrkK4C0z+zNwHXBvILBdEO16/TC6Xz6/fmszx+rqSU9J9rscERERiWGxdM3cKUC9c25DUNsqYFQoC5vZq8DlwH+a2bQ25pkeOMW7fP/+2L3E7vS+BdTWOzbsqfC7FBEREYlxsTRocA7Q8txiGZAbysLOuUkhzDMPmAcwduzYmH2Oyen9vJsgVu8sZXTg3yIiIiKtiaWeuQqg5ZDUeUDCjdHRrzCTwqxU1uzQdXMiIiLSvlgKcxuAFDMbFtQ2BvjQp3p8Y2aM7lfAKoU5EREROQE/hiZJMbMMIBlINrMMM0txzlUCLwA/NbNsMzsf+BLwbLRrjAWn981nw94jehKEiIiItMuPnrn7gKPAvcC3A/++LzDtu3jDlewDfgfc6pxLuJ458O5orW9wrNutwYNFRESkbX4MTTIDmNHGtEPAlyO5fTObDEweOnRoJDfTZY03QazZUcbnBhT6XI2IiIjEqli6Zi4qnHMvO+em5+fH9l2ivfMyKM5JZ7WumxMREZF2JFyYixdmxun98lmzs9TvUkRERCSGKczFsNP75fPJvgoqjtX5XYqIiIjEKIW5GDamfwHOweod6p0TERGR1inMxbAz+hUA8MF2hTkRERFpXcKFOTObbGbzyspi/8aCwuw0BhVn8/42hTkRERFpXcKFuXi5m7XRGf0L+GB7Kc7F7KNkRURExEcJF+bizZkDCth/5Bi7yqr9LkVERERikMJcjDujv3fd3PvbDvtciYiIiMQihbkYN6J3HukpSXyg6+ZERESkFQpzMS4tJYnT+ubzvu5oFRERkVYozMWBM/oXsHZnGbX1DX6XIiIiIjEm4cJcPA1N0ujMAQUcq2tg/e4jfpciIiIiMSbhwly8DU0Cn90EsVI3QYiIiEgLCRfm4lHfgkxK8tJZsVVhTkRERJpTmIsDZsbYk4sU5kREROQ4CnNx4qyTC9lZepQ9GjxYREREgijMxYmzTi4EUO+ciIiINKMwFydG9skjIzWJ5c4HskgAACAASURBVFsP+V2KiIiIxBCFuTiRmpzEmH4F6pkTERGRZhIuzMXjOHONxg4s5MNd5VTV1PldioiIiMSIhAtz8TjOXKOxJxdR3+BYtT3+gqiIiIhERsKFuXh25gANHiwiIiLNKczFkYKsNIb1ymH5Ft0EISIiIh6FuTgzdmARy7cepr7B+V2KiIiIxACFuThzzqAijlTX8fGeI36XIiIiIjFAYS7OnD2oCIBlmw/6XImIiIjEgk6HOTMrMrO+ZpYezoKkfX0KMulbkMkyXTcnIiIidCDMmVlvM7vXzJaYWRWwH9gGVJnZFjN7xswmmplFrFoBvFOtyzYfwjldNyciIpLoThjmzKyfmT0FbAXuBo4AjwC3A98BfgT8BTgNWARsMrNrI1axcPagIg5U1LD5QKXfpYiIiIjPUkKY52PgNeDLwGvOufq2ZjSzfsC1wMNm1sc59+/hKTN8zGwyMHno0KF+l9Jpn103d4jBPXN8rkZERET8FMpp1vOdc19xzv2lvSAH4Jzb4Zx7CBgM/DksFYZZPD8BotGg4myKc9JZtlnXzYmIiCS6E/bMOec+6OhKnXPH8Hr0JALMjLMHFfKewpyIiEjCC+WauYfN7Cozi9+urG7o7IFF7Cw9ys7So36XIiIiIj4K5TTrHXinTA+a2ftmNtvMpphZcYRrk3acM7gHAO9u0nhzIiIiiSyUMFcEXAX8O1CJdwfrc8BeM1tnZr8ws2+ZWd8I1iktDC/JpTArlXc+VZgTERFJZKFcM3cEWBx4YWYZwHnA5wOv64DpgWmbnXPxe5toHElKMs4d3IN31DMnIiKS0Dr8BAjnXLVz7g3n3L8AlwOTgJcDkweFszhp33lDerCz9CjbD1X5XYqIiIj4JJRx5poEeuXO5bNeuXOBDOAjYC7wt3AXKG07L3Dd3DubDtK/KMvnakRERMQPJwxzZnYln4W3cYADVgBvAY8BbzvnDkeySGnd0F45FOek886nB/mHcf39LkdERER8EErP3Kt4Nz7MB34MLHPOVUe0KgmJmXHu4CL+vukAzjn0WFwREZHEE8o1c/8F1AM/AP4DmBW4e1VdQTHgvCE92Ft+TM9pFRERSVAnDHPOuYl4w5OMxeudKwFmA1vMbIuZPWtm083s1MiWGh5mNtnM5pWVlfldSlg0XTenIUpEREQSUkh3szrnGpxzK51zjznnpjjnegGnAz8HkoH7gLVmti+CtYZFd3g2a7BBxdn0zsvg7xqiREREJCF1eGiSILuCXnsDbT26XJF0iJlx/tBi/r7xAA0Nzu9yREREJMpCDnNm1tvM/sHMnjCz1cB+4EXg/wJ1wCPA5MiUKe25YFgPDlfVsm53ud+liIiISJSFMjTJfLxhSYYABhwDlgE/A5YCf3fOadRaH50/xHtM7lsbD3Ba3+5x+lhERERCE8rQJN8A3gGeAd4E3nPO1US0KumQXnkZDC/J5e2NB7jlwiF+lyMiIiJRFEqYK3DO1Ue8EumS84cW89v3tlJdW09GarLf5YiIiEiUhDI0iYJcHLhgWA+O1TWwYqsexiEiIpJIThjmzOwDM/uKhfh4ATPrZ2ZzzOwfu16ehOqcQT1ISTLe2njA71JEREQkikK5m/VZ4D+BnWY2y8ymmNkQM8szs/TAXa7jzex2M/sfYAtwCvBSBOuWFrLTU/jcgELeVpgTERFJKKGcZn0U707WR4ErgOeADcBhoArYCbwF/BvecCWXOueudM5tiFTR0roLhhWzZmcZByuO+V2KiIiIREkoN0DgnCvDC3OPBp7Jeh7QB8gADgLrgWXOOaUIH100vCcz/7qBpZ/s5ytn9vO7HBEREYmCkMJcMOfcdmB7y/bAKdcfOOdmh6Uy6bDT+uRTnJPGko8V5kRERBJFhx7nZWbFLW+EMLNMM7sL71q5mWGsTTooKcn4/Ck9eXPDfur1aC8REZGEEMrdrOlmNtvMKvCewXrQzG4NTPs28Cnw78A24MpIFisndvHwXpRW1bJqR6nfpYiIiEgUhHKa9SfA94H/BlYCg4DZZjYS+B7ezRDTnXMvR6xKCdmEYcUkGSxZv4/PDSj0uxwRERGJsFBOs34D+A/n3OXOuXudc98AbsELcn8FTo+nIGdmk81sXllZmd+lRERBVhqfG1DIGx/v97sUERERiYJQwlx/4MUWbS8Evs6Mt+e0Oudeds5Nz8/vvg+kv2h4T9bsLGP/Ed1cLCIi0t2FEuZSgSMt2hq/V/dPDLpoeC8A3tygwyMiItLdhTo0SV8zGxz0fXJQe7Mr7Z1zn4alMum0UX3y6JWbzpKP9/G1szREiYiISHcWaph7ro321h7ZldxKm0SRmXHhKT35rw/3UFffQEpyh0agERERkTgSSpi7IeJVSNhdPKIXf1yxgw+2lzJ2YJHf5YiIiEiEnDDMOeeejkYhEl7nDy0mOcl44+N9CnMiIiLdmM6/dVP5mamcdXIhb6zXTRAiIiLdmcJcN3bR8J6s213O3vJqv0sRERGRCFGY68YubhyiRAMIi4iIdFsKc93YiN659M7L4I2P9/ldioiIiESIwlw3ZmZcPKIXSzfs51hdvd/liIiISAQozHVzl48qobKmnr9vOuh3KSIiIhIBCnPd3PghPchOS+av6/b6XYqIiIhEgMJcN5eeksyFw3vy13V7aWhwfpcjIiIiYaYwlwAuG1nC/iPHWLWj9MQzi4iISFxRmEsAlwwvITnJdKpVRESkG1KYSwD5WamcM6iI1xTmREREuh2FuQRx2cgSNu6r4NP9FX6XIiIiImGkMJcgrhjVG4C/rN3jcyUiIiISTgpzCaJPQSZj+hewWGFORESkW0m4MGdmk81sXllZmd+lRN2k03qzZmcZ2w9V+V2KiIiIhEnChTnn3MvOuen5+fl+lxJ1E087CYD/+lC9cyIiIt1FwoW5RDagRxYjT8rj1TW7/S5FREREwkRhLsFMPK03K7eVsqes2u9SREREJAwU5hLMxNE61SoiItKdKMwlmKG9cjilJIdXVutUq4iISHegMJeAJp/eh2VbDrG77KjfpYiIiEgXKcwloC+O6QOg3jkREZFuQGEuAQ0qzmZ033xeXrXL71JERESkixTmEtTkMSexakcZWw9W+l2KiIiIdIHCXIK66nTvVOsinWoVERGJawpzCapvQSZnnVyoU60iIiJxTmEugV09pg/r9xzho93lfpciIiIinaQwl8C+ePpJpCQZL72/0+9SREREpJMU5hJYj5x0LjylJ3/6YBf1Dc7vckRERKQTFOYS3Fc+15c95dW8++lBv0sRERGRTlCYS3BfOLWE3PQUXtSpVhERkbikMJfgMlKTmTi6N39Zs5ujNfV+lyMiIiIdpDAnfPnMvlTW1PPauj1+lyIiIiIdpDAnnDuoB30LMvnj8h1+lyIiIiIdpDAnJCUZXx/bj7c3HWD7oSq/yxEREZEOUJgTAL52Vj8Anl+p3jkREZF4ojAnAPQrzOL8IcU8t2IHDRpzTkREJG4ozEmTr4/tx47DRzXmnIiISBxRmJMmV4zqTW5GCr//3+1+lyIiIiIhUpiTJhmpyXzlzL4sXruHQ5U1fpcjIiIiIVCYk2auOWcANfUNPL9CN0KIiIjEA4U5aWZE7zzOOrmQhcu24ZxuhBAREYl1CnNynGvPGcDmA5W8s0k3QoiIiMS6FL8L6M4eWvYQ6w+t97uMDmtwjtxBpfzj2wsYtjHH73JERERi2oiiEdxz9j2+bV89c3KcJDN65qRzqKqG2voGv8sRERGRdqhnLoL8TOldtflAJRc/soSzhg7jjstO8bscERERaUO36Jkzs/PM7B0ze9PMfmdmqX7XFO8GFWdz8fCe/Pa9bRyrq/e7HBEREWlDtwhzwFbgEufchcCnwJd8rqdbmHb+IA5UHOPVNbv9LkVERETa0C3CnHNul3PuaODbOkAXeoXBhKHFDO6ZzVNvb9EwJSIiIjEq6mHOzG4zs+VmdszMFrSYVmRmL5pZpZltNbNrOrjuQcBEYFEYS05YSUnGDeMHsnpHGe9vL/W7HBEREWmFHz1zu4AHgV+3Mu1JoAYoAa4FfmFmowDMrLeZvdXKq3dgeh7wNHCdc07PogqTKZ/rR25GCr/622a/SxEREZFWRP1uVufcCwBmNhbo19huZtnAV4HTnHMVwFtm9mfgOuBe59we4ILW1mlmKcDvgBnOuY/b2raZTQemAwwYMCA8b6iby05P4dpzTmbe0k1sO1jFgB5ZfpckIiIiQWLpmrlTgHrn3IagtlXAqBCW/RZwDvATM1tiZt9obSbn3Dzn3Fjn3NiePXt2veIEccP5A0lOMua/9anfpYiIiEgLsRTmcoCyFm1lQO6JFnTOPeucK3bOXRR4/b+IVJigSvIy+PIZffnD8u0cqtQZbBERkVgSS2GuAshr0ZYHHPGhFmlh+ucHU13bwLPvbPW7FBEREQkSS2FuA5BiZsOC2sYAH/pUjwQZVpLLJSN68fQ7W6iqqfO7HBEREQnwY2iSFDPLAJKBZDPLMLMU51wl8ALwUzPLNrPz8Qb/fTbaNUrrvnfxUA5V1rDwvW1+lyIiIiIBfvTM3QccBe4Fvh34932Bad8FMoF9eHen3uqcC2vPnJlNNrN5ZWUtL8+TEznr5ELOH9qDX775KdW1esSXiIhILIh6mHPOzXDOWYvXjMC0Q865Lzvnsp1zA5xzCyOw/Zedc9Pz8/PDveqE8P1LhnGg4hi/X6beORERkVgQS9fMSRw4d3APzh5UxC/f/JRjdeqdExER8ZvCnHTY/71kGHvKq/n9su1+lyIiIpLwFOakw84f2oNzBhXx+OsbdWeriIiIzxTmpMPMjH+8cjgHKo6x4O9b/C5HREQkoSVcmNPdrOFx1slFXDqiF79csomyo7V+lyMiIpKwEi7M6W7W8Lnr8uGUV9cx981NfpciIiKSsBIuzEn4jOyTx5fO6MOv3trMztKjfpcjIiKSkBTmpEv+8coRADy8eL3PlYiIiCQmhTnpkr4Fmdw8YTB/+mAX72877Hc5IiIiCUdhTrrs1ouG0DM3nQcWrcM553c5IiIiCUVhTrosOz2FH14+nJXbSnlh5U6/yxEREUkoCnMSFl87qx9nDijgZ69+RFmVhioRERGJloQLcxpnLjKSkowHv3wah6tq+PfXdDOEiIhItCRcmNM4c5Ezqk8+08YP4rfvbeOD7aV+lyMiIpIQEi7MSWTdcdkweuWmc89zqzlWV+93OSIiIt2ewpyEVW5GKv82ZTQf7z3Ck69v9LscERGRbk9hTsLukhElTDmzL/+xZBNrd+raRBERkUhSmJOI+MnkkRRmp3H3H1dRXavTrSIiIpGiMCcRUZCVxs+njGb9niM8vPhjv8sRERHpthTmJGIuPbWE6887mV+/vZk3Pt7ndzkiIiLdUsKFOY0zF10/mnQqw0ty+eEfV7HvSLXf5YiIiHQ7CRfmNM5cdGWkJjPnW2dScayO2xa+T219g98liYiIdCsJF+Yk+ob3zuXfpoxm2eZD/PwvejqEiIhIOCnMSVR85cx+XH/eyfzqrc386YOdfpcjIiLSbSjMSdT801UjGTewkB8+t5oVWw/7XY6IiEi3oDAnUZOWksQvv30WJ+VnMP2Z5Ww7WOV3SSIiInFPYU6iqkdOOr+eNo66Bse0Bcs4VFnjd0kiIiJxTWFOom5IzxzmXXcWOw8f5fpfL6O8utbvkkREROKWwpz44pzBPfjlt8/io93l/J8F/0tVTZ3fJYmIiMQlhTnxzcUjejH7m2eyYuthbnjqf6k4pkAnIiLSUQkX5vQEiNhy1eknMesbZ7B862Gu+9V7lB3VKVcREZGOSLgwpydAxJ4vndGXJ6/5HGt3lvHNee+yp0yP/RIREQlVit8FdGd7fvYzjn2kJx6E4lTguaO1fLL0CO+8YIzonUdWWrLfZYmIiJxQ+qkj6P3jH/u2/YTrmZPYVZCZysg+eQB8uKuMw1UatkRERORE1DMXQX6m9HhWUHqU7zy7gjU7y/j+JUO5/QunkJxkfpclIiISk9QzJzGnT0Emf7zlPP5hbD8ef30jU3/9nq6jExERaYPCnMSkjNRkHvrq6Tz01dGs3FrKFY8t5ZXVu/0uS0REJOYozEnMMjO+MW4Ar/5gAgN7ZPG9hSuZ/sxy9dKJiIgEUZiTmDeoOJvnbh3PvRNHsPST/Xxh5pvM/9un1NQ1+F2aiIiI7xTmJC6kJidxy4VDeO32Cxk7sJAHX/mIy2e9yeK1u3HO+V2eiIiIbxTmJK4M6JHFghvOZsEN40hJTuKW36zki4+/xX+v20tDg0KdiIgkHg1NInHpouG9uGBoMS99sIs5//MJNz2znME9s5k2fiBTPtePnHT9aIuISGKwRDtFZWaTgclDhw69+ZNPPvG7HAmD2voGXlm9m6fe3syqHWXkpqfwtbH9mHreQAYVZ/tdnoiISJeZ2Qrn3NhWpyVamGs0duxYt3z5cr/LkDB7f9thFvx9C6+s3k1dg2NMv3y+eHofrjr9JPoUZPpdnoiISKcozLVCYa5721tezUvv72TR6t2s2VkGwNiTC7nytN5cMKyY4SW5mOmpEiIiEh8U5lqhMJc4thyoZNHqXSxavZv1e44A0DM3nQuGFnPB0GLOHlREv8JMhTsREYlZCnOtUJhLTLtKj/LWxgP87ZMDvL3xAIcqawDokZ3GmP4FnNG/gDH9Czi1dy49c9MV8EREJCYozLVCYU4aGhwf7Sln5bZSVm33Xhv3V9D4kcjPTGVYrxyGleQyrFcO/Yuy6FeYSb/CTHIzUv0tXkREEkp7YU7jN0jCSkoyRvXJZ1SffK4792QAyqtrWbuzjA17jrBhXwWf7D3Cq2t2U3a0ttmy+ZmpTcGub0EWPXPT6ZGTRnFOGsU56fTISadHdhoZqcl+vDUREUkgCnMiQfIyUhk/pJjxQ4qb2pxzHKysYefho+w4fJQdh6uavn66v5K/fXKAqpr6VteXk55CfmYquRkp5KSnkJuRQm5G4PuMFPIC/85OSyEjNZmM1KSmr+kpyc3a0lO8r6nJGutbREQ+ozAncgJmRnFOOsU56YzpX9DqPFU1dRysqOFAxTEOVtRwsPIYBwLflx+t40h1LUeq69hfcYzNByo5Ul3Hkeo6auo7/nzZ5CQjPSWJlCQjJdn7mpqcRHKSkZJsXntSEqnJFmj7bN7UJK8tNTmJpCQjySDJDGv8ivc1Kcl730lB7d73gbak4Daa2i1oXcHfe3ND4yWIjVciBl+S2HKe4P3f9jIt5mmx/uCZWy7fVk2tzUOLmtoUwlUrLpSZgFCugAllTaGt58QzhXpFTkizhbCycL03b77Qtxc862dtxy/ffD7X5rLB7cH7ubWSGrfTeg0hbi+oscPLtlErrrX5Ol9ry3WcaNnmdR1fK63NF+J7bnV7J/gZaG3ZS0/txZfO6ItfFOZEwiArLYWsohT6F2V1aLnq2nqOVNdReayO6rp6qmsbqK6t51id97W6tp5jtQ2Bad70Y3VeW12Do66hgbp65/27voHaBkd9faC9wVFX76itb6CmroHKmnrqA/PX1jfQ4Lz/oBocNDiHa/H1s+mf/Tt4WuO8jubfi4i/2vuDp3lb8HzHL9TuHzi09YeQHdfW+vqO/+OtvVqbz3uiGjpWa7NSrfnX4PW0Vmvjekb1yTtuXdGkMCfiI+80ajI9c9P9LiUsXFPAawx97ri/lNv/K9m1+L75DO39pd7mshz/F3fLeUJarzu+17A1odwBHWpHX0jbC2Ftoa0nBCEWHs2aQr3jPLR1Nc7bSrDpYkBqrcyuBKTPQofuuBeFOREJo8bTqgDJIUcWERHpCl1JLSIiIhLHFOZERERE4pjCnIiIiEgcS7gwZ2aTzWxeWVmZ36WIiIiIdFnChTnn3MvOuen5+fl+lyIiIiLSZQkX5kRERES6E4U5ERERkTimMCciIiISxxTmREREROKYwpyIiIhIHFOYExEREYljCnMiIiIicSzF7wK6tb/cC3vW+F2FiIiIRFLv0TDx575tXj1zIiIiInFMPXOR5GNKFxERkcSgnjkRERGROKYwJyIiIhLHFOZERERE4pjCnIiIiEgcU5gTERERiWMKcyIiIiJxTGFOREREJI4pzImIiIjEMYU5ERERkTimMCciIiISxxIuzJnZZDObV1ZW5ncpIiIiIl2WcGHOOfeyc256fn6+36WIiIiIdFnChTkRERGR7sScc37X4Asz2w9sjcKmioEDUdiORJ+Obfem49t96dh2b931+J7snOvZ2oSEDXPRYmbLnXNj/a5Dwk/HtnvT8e2+dGy7t0Q8vjrNKiIiIhLHFOZERERE4pjCXOTN87sAiRgd2+5Nx7f70rHt3hLu+OqaOREREZE4pp45ERERkTimMCciIiISxxTmIsTMiszsRTOrNLOtZnaN3zVJ55nZEjOrNrOKwOvjoGnXBI5xpZm9ZGZFftYq7TOz28xsuZkdM7MFLaZdambrzazKzN4ws5ODpqWb2a/NrNzM9pjZnVEvXtrV1rE1s4Fm5oI+vxVmdn/QdB3bOBA4Tr8K/H97xMzeN7OJQdMT9vOrMBc5TwI1QAlwLfALMxvlb0nSRbc553ICr+EAgWM6F7gO71hXAf/hY41yYruAB4FfBzeaWTHwAnA/UAQsB/5f0CwzgGHAycDFwD+a2ZVRqFdC1+qxDVIQ9Bl+IKh9Bjq28SAF2A5cCOTjfVb/EAjrCf351Q0QEWBm2cBh4DTn3IZA27PATufcvb4WJ51iZkuA3zjn5rdo/xkw0Dl3TeD7IcBHQA/n3JGoFyohM7MHgX7OuWmB76cD05xz4wPfZ+ONIn+mc269me0EbnDOvRaY/gAwzDn3TV/egLSplWM7ENgMpDrn6lqZX8c2TpnZauBfgB4k8OdXPXORcQpQ3xjkAlYB6pmLb/9mZgfM7G0zuyjQNgrv2ALgnNuE1yN7ig/1Sde0PJaVwCZglJkVAn2Cp6PPdDzaamY7zOypQE8OOrbxy8xK8P6v/ZAE//wqzEVGDlDWoq0MyPWhFgmPe4DBQF+8MYxeDvTC6Vh3H+0dy5yg71tOk9h3ABiHd4rtLLzj9tvANB3bOGRmqXjH8Gnn3HoS/POb4ncB3VQFkNeiLQ/Qabc45Zx7L+jbp83sW8AkdKy7k/aOZUXQ99UtpkmMc85V4F1DBbDXzG4DdptZHjq2ccfMkoBn8c6C3BZoTujPr3rmImMDkGJmw4LaxuB1BUv34ADDO6ZjGhvNbDCQjvczIPGl5bHMBoYAHzrnDgO7g6ejz3Q8a7xY3HRs44uZGfArvBvOvuqcqw1MSujPr8JcBATO1b8A/NTMss3sfOBLeH9JSJwxswIzu8LMMswsxcyuBT4P/BdeN/9kM5sQ+M/jp8ALuvkhdgWOYQaQDCQ3HlfgReA0M/tqYPpPgNWBUzgAzwD3mVmhmY0AbgYW+PAWpA1tHVszO8fMhptZkpn1AOYAS5xzjafddGzjxy+AU4HJzrmjQe2J/fl1zukVgRferdEvAZXANuAav2vSq9PHsifwv3hd8qXAu8BlQdOvCRzjSuBPQJHfNevV7vGcgdczE/yaEZj2BWA9cBRYgnencuNy6XhDXpQDe4E7/X4veoV2bIFv4d3NWonXQ/MM0FvHNr5eeNc8OrxTpRVBr2sD0xP286uhSURERETimE6zioiIiMQxhTkRERGROKYwJyIiIhLHFOZERERE4pjCnIiIiEgcU5gTERERiWMKcyIRZGbTzMyZ2dCgttvNbIqPNRWY2Qwz+1wr05aY2RIfygoLMxthZq+bWXlgv3/Z75ra0nJfm9lFgZoviuA2p5nZjV1cxwwz6xZjWrX3WWhj/gVmtiPSdYl0lJ7NKhJ9twNv4T0lxA8FwD8DO4CVLaZ9N/rlhNVMYDDwD3gDPH/sbzkdshI4D1gXwW1Mw/t//9cR3EY8ae+zIBI3FOZEugEzS3fOHevqepxzkQwS0XAqsNQ5tzhSGzCzVKDOhXnEdedcOd7TRUREOkSnWUWiyMy24D2S5trAKTVnZguCpo8xsz+b2WEzO2pmb5vZhBbrWGBmO8zsPDP7u5kdBR4OTPtm4DTjfjOrMLP3zez6oGUH4j3WCOA/g2qYFph+3GnWwDMtXzSz0kBN75rZlS3mmRFYzzAzeyWw7a1m9hMzSwqaL8fMHjezbWZ2zMz2mtl/B56V2N5+SzWzB81si5nVBL4+GAhWTacogYHAdY3v6wTr/EJg/1Sb2UYzuymwb7cE76/Aur5rZg+b2S7gGFBgZj3NbK6ZbTCzKjPbbmYLzaxvK9v6ppmtD7znD83sK63M0+ppVjObEtjnVYFj8EczG9Bini1m9pvAdj4ys0ozW25mFwTNswS4EDg/6LgvOcE+OtPM/hbYRzvN7H7AWpkvxcx+FPQed5nZo+Y9IzN4ngfMbFNgfQfM7K3gGgPz3WxmKwM/a4fN7E0zGx80PcvMHjKzzYGfhc1m9k8tfs4a9+XVZvZEYFv7A/uoIDDPQNr5LITKzG4ws1ozu7cjy4mEk3rmRKLrK8CrwCq8Z0YC7Acw77qdvwHv4z0Eugq4BfhvMxvvnFsRtJ584PfAI8CP8Z5FCN4pxueAnwMNwOeB+WaW6Zz7Jd5zKafgneL9N+DPgeU2tVasmfXBOyV8BLgNKAO+B7xiZl90zv2lxSIvAk8Bs4DJwL8A2wNtBNqvDtT8CdADOB/vdFd7nsY7dfqzQD3nAfcF3u81fHaK8s94z9F9oL2VmdlI4BVgGfBNIA24H2+/NrSyyD8F1jsd7yHu1cCAwNcf4R3DPsBdwNtmNsI5Vx3Y1heAhYHt3YX3rN/ZQConOA1sZrfgPVj8KeCnQC7ez82bZna6c+5I0OwTgOGB91Ed2AeL7P+3d+4xWl1FAP8Ny3NbSzDII02VRhRtfFRDbUmkbRpMkDa2tY1F8EG1PmMftiHYgEUWAwAACEtJREFUWtJtFBOStqSpNUFT3RratbEqRvqAgqKtUCFBYduKBhWUlodAWwoFymP8Y+ayZ8/e++33rcCyZX7JyZc799xz5jvn3Nz5Zs7cT2SMqr6ChdAXuP5f8Wt21+h7OPBbYCvwecyInenfO2cBNt9zgRWYh/Q7mHF9ldeZBXwTG8u/AGcA47H/sS76vAsbowew8OcR4ALvc4WI9AcWA+d4++1+fra3c0um173AImyNjMN+9Bz279PQvVCGiNyKrfEvqWprvdcFwTGnt/8cNkqUN3PB9igpMDaRbQQWlNRdBvwVGJjImly2MJG1epuXd9N3P+wH24+AtYl8jF9/Xck1y4HlyfFdwKFM/ybMCFmTyFq8zWuz9tqBJcnxc8A9DY7h+7ztlkx+u8s/kMg2A611tPkwZoA1J7LRmBG0sWSs1oD9l3WNNpuAs7z+lYn8j9g+uH6J7Hyvl471xS672I9Px4znH2f9jAHeAG7K1tTLwLBENt7bm5bN7zN1jvsc7+ftiew0YIc9Oo7KJno/n8uun+7yc/14EfDLGv2NxQytyvUBfNbbvDCTf9t1HZGN5YNZve/7HBf/S17Mb5d7oaL/Vl9j/YD7gL3ApY2s5yhRjkeJMGsQnASIyBAsBPZz4IiHpPpjIa2lmIct5RD2cMzbeZeItInIi8BBL9dhXomecCHwrKpuKASqehhoA84VkTOy+o9lx8/R2ZOzGpghIreJyHgRaapTBzDvT0pxfFEdbeRcADyuqq8XAlXdgnmVylioql3CtiLyNRFZKyJ7sDn5t58a5+ebgPOAR1X1qMdPVf+EGWC1mIB5rx4q1oOvic3AerquiZWq+nJy3O6fZZ60epiAzX3xnVDVvcBvsnqTMUPqF5meS/x8oedqYIqIzBGRj4rIwKydSZiR9MMaOk0GNuFeuqyvAdi8puTrsR0YBIys0Ud39Me84tOASaqa9xEEJ5ww5oLg5OCtmGdnNh1GWFG+AQxL9wQB292oOoqInA48BXwQ+BbmMTkPy1wc9H/otaVEvhUzNIdl8l3Z8QFgcHJ8PTAf+AL2cN8uIvNEpLkbHSjRY2t2vhFGA9tL5Nsq6ncZAxG5HvgBZmx/EvgIHcZE8Z2HY0ZGWbtVfRWM8M+ldF0T78dC1Cmdxl47EmIG0zNGV+iYy0ZgYeo9mY7F+BZ6fg8LnX4C206wU0R+4uHctF6tV3+MwPac5uOxKmujoGw9Qs/HBMzAvhQz/Fd1UzcITgixZy4ITg5ewfYH3Q/8tKxC6tnBQkM5E7AH3URVfaYQuueip+wCRpXIR7kO+cOyJqq6B9tjdquIvAO4Gtvf9wa2p6pKh6LPdD9TodfORnRwttBhLKVUeWzKxnsqsExVj+7TEpGzszo7MGOjrN2RmJepiuJ7zQCeLzn/WonsWLKFar1TdmKhy4kldQFeAlDVg9ieurkiMgq4DHuVTDNwDTZWAGdSvZdwJ5a08KmK8xsr5MeSXcBnMM94m4hMU9VDJ6DfIKgkjLkgOPEcAIakAlXdKyJPY161NZnhVi+Fd+tgIRCRYcDlJf2T61DB74GbfBP9Rm+zCXv4/lk7b8BvCFXdBNwtItOxfXG1dAAznuYk8un++YcedP8sFvJrLkKtIjIaS8Yo80SW0UzXBIJr0wNVPSwiq4GrRaSlmFcROR/br1XLmFuBGWxjVfXBOnXqjgNYEkU9rARmishZqvofABE5DUt0SHkSM8SHquqyehpW1a1YYs4UOuZ+KfaD5st0TWRI+7oK2KOq6+v8HrVo5F44iqouF5GPY8lMPxORqWHQBb1JGHNBcOJ5AZgoIpdhocIdbijdjBkmi0XkAcyoGA58GGhS1e5efbACMy7uF5E7sM3qt2Mej6FJvW2Yh2OqiKzDNnH/S1XLPFzzMM/QU97mbiwr8t1YqKkhRGQlljXYjoXlLsIM2EpjRVWfF5E2oMW9jCswL+RsoE1V1zWqB/BdzCu42DMoB3l72yjPZi3jSWCWiNyGhdsu8TZz7sD2dC0UkflYNuuddISJS1HV3SIyE5vPtwFPYAkRZ2LjtlxVH65T14IXgK+LyDWYl/M1Va3ygs3D5nqJiLTQkc26L63khk0b8KiI3IONxRHMWJ0CzFLVv4vIr7Es7jVYssaHsD1w872df4jIPOBmEXkLtk4OY+Hr9ar6CPAQZjAvE5G7vb2BwDux8O0V6T7IOmjkXuiEqj4t9oqeJ4BH3KA72N11QXBc6O0MjChR3syF8mzW92B7hl73c63Jufdim6u3Yw/PzdhDbUpSpxXYXNHfJdirTfZhD+sb8EzTrN4V2IP9oOsww+XLSTIsXTYOWIgZEvsxr9bkrE6Lt9M/k7fSOTt0ruv3KvbgbAduqGMcB2AG2CbXeZMfD8jq1ZXN6nU/hr0i4wDwT+x1Hb/CPI5FnTFUZ/4OwV4b8l/Mg7YIOJvyzNtPY6HDA1jI9Mp8rMmyWRP5FOB3mCG9D9iA7YM8J6mzkfIM6U66YKHpx13fTtm0FWNUvC5nP/AiZvDeWbKe+gE3YsbVfp/ftdirQIZ6nVt87ez07/E3Xzf5HH4VWOdjtcvHaUJyfrBftz6ps9pl/bOxnFRxP47p7l6oGI9WsnsP+2HxKnaPDKw1nlGiHK9SpGcHQRCc0ngCyQbgMVX9Ym/rEwRBUC8RZg2C4JRERO7DQrYvYS/8vRHLzr23N/UKgiBolDDmgiA4VRmMhX1HYtm0q7CwXE/24AVBEPQaEWYNgiAIgiDow8RLg4MgCIIgCPowYcwFQRAEQRD0YcKYC4IgCIIg6MOEMRcEQRAEQdCHCWMuCIIgCIKgDxPGXBAEQRAEQR/mfygMmLlLjD94AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 44*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0074892\n",
      "Converged gradient descent: test risk: 0.00503876\n",
      "3.2753554424179376\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 171 due to early stopping\n",
      "Gradient descent: test risk last: 0.00318203; test risk early stopped: 0.00315394; train loss: 0.001381871523335576\n"
     ]
    },
    {
     "data": {
      "image/png": "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pq9evZq1a9dy00038e6773LWWWcBkJradf/VvHnzePnll3nooYcwM8yM7du345zjnnvu4cQTTyQrK4tJkybx5JNPtll39erVnHXWWeTm5hIMBjnzzDN59913O91mpCnMRdGQgiydMyciIhIBBQUFbULb/fffz6WXXsq0adPa9Mzde++9zJo1i/Hjx7N+/XpmzJjBY489xpe//GWOHDnS6fYXLVrE2WefzZVXXsmePXvYs2cPw4cP57bbbuMnP/kJDz30EBs3buR73/seX//613nhhRcAaGho4DOf+Qznnnsu69ev589//jPf+ta3SElJ6XSbkZZ0w6xmNguYNWbMmKjva3Awk8raBo7W1JOXmRb1/YmIiPTUvy7fwMbdnYecaDh5SD7/Mmtij9ZpHeaOHDnCI488wsqVKzlw4EDL9C1btrBixQpeeuklwLuS9cILL2Ty5MnceOONzJ07l1/+8pcdPpc2GAySnp5OdnY2gwYNArxn2d5333389re/ZcaMGQCMGjWKN954g4ceeojLLruMI0eOUF5ezqxZszjxxBMBmDBhQst2228zGpIuzDnnlgPLp06dek209zW4IHR7kooahTkREZE+KCwspLKyksbGRpYsWcKkSZOYPn06q1ataumZW7hwIVOnTm0JXosWLWpZ/4orruCKK67o0T43btxITU0Nl1xySZsAWF9fz8iRIwEoKipi3rx5XHzxxVx44YVceOGFfOELX4hKD1xnki7MxdKQYCYAu8uPMa40z+dqREREjtfTHjK/FBQUAHDo0CEWL17ccouR/Px8KioqKCsrY+nSpSxdujRi+2xqagJg+fLljBgxos28tLS/dtI8+uijfPvb32blypU8//zz/OAHP+C5557j4osvjlgtXVGYi6JBoTCn8+ZERET6prCwEIAlS5aQnZ3N7NmzAW94tKqqigcffJDS0lLmzJnT632kp6fT2NjY8v3JJ59MRkYGH330ERdccEGX606ePJnJkydz6623MnPmTB577DEuvvji47YZDQpzUVSan4kZuqJVRESkj5p75u677z7uvvtuAgHvGs78/HzAG2L94Q9/SEpKSq/3MXLkSN544w22b99Obm4uRUVF3HLLLdxyyy045/jkJz9JZWUlr7/+OoFAgGuvvZZt27axZMkSZs+ezdChQ9m6dStvv/12y73vOtpmc+2RoqtZoygtJUBJXoZ65kRERPqouWcuPT2duXPntkwPBoMAmBlXXXVVn/Zxyy23kJ6ezsknn8zAgQPZsWMHd955J/Pnz2fBggVMnDiRT3/60zzzzDOMGjUKgOzsbDZv3swXvvAFxo0bxxVXXMFXvvIVbr311k63GWnmnIv4RhPB1KlT3Zo1a6K+n8sf+iO5Gak8efWZUd+XiIhIV9577z1OOukkv8uQTnT18zGztc65qR3NU89clA0pyGS3HuklIiIiUaIwF2WDg1nsKa8hWXtARUREJLoU5qJscDCTY/WNVByr97sUERER6YcU5qJscPCvNw4WERERiTSFuSgbXNB8rzmdNyciIiKRl3RhzsxmmdnDrR/WG01DQj1zu8vVMyciIiKRl3Rhzjm33Dl3bfN9aaJtYF4GqQFTz5yIiIhERdKFuVhLCRil+ZnsUc+ciIiIRIHCXAwMCmbqAggRERGJCoW5GBgczNQwq4iIiESFwlwMDCnIYk+FbhwsIiLil+rqasrKyvwuIyoU5mJgcDCT2oYmyqrq/C5FREQkKb344ossXrzY7zKiQmEuBnTjYBERkb6ZN28eM2fObDNt3bp1mBnXXXddm+nLli0jKyuL/fv382//9m/cc8891NV5HSr/+7//yxVXXBGzumNBYS4GhhV6YW7X4WqfKxEREUlMBQUFtL9H7IIFC8jIyKC8vLzN9IULFzJ37lxKSkq45ZZbcM5x/fXXc99997F69WruvffeWJYedQpzMTC8KBuAHWUKcyIiIr1RWFjYJszt2LGDZ555hmuuuabN9NWrV7N27VpuuukmAMrLy9m8eTPZ2dkUFBSwZcsW9u7dG/P6o0lhLgaCWWnkZ6ays0xXtIqIiPRG+565+++/n0svvZRp06a16Zm79957mTVrFuPHjwfgF7/4BZdeeimLFy/mqquu4q677uLxxx+Pef3RlOp3AclixIBsdmqYVURE4s1vvgt734ntPgdNgpn/3qNVWoe5I0eO8Mgjj7By5UoOHDjQMn3Lli2sWLGCl156qWW9G264AYAVK1YAcMYZZ3DGGWdE4E3ED/XMxcjwwmwNs4qIiPRSYWEhlZWVNDY2smTJEiZNmsT06dPJz89v6ZlbuHAhU6dOZcaMGcet/7d/+7fMnz8/xlXHhnrmYmREUTZ/2LSfpiZHIGB+lyMiIuLpYQ+ZXwoKCgA4dOgQixcv5oEHHgAgPz+fiooKysrKWLp0KUuXLvWxSn+oZy5GhhVlU9fQxP6jtX6XIiIiknAKCwsBWLJkCdnZ2cyePRuAYDBIVVUVDz74IKWlpcyZM8fPMn2hMBcjw0O3J9F5cyIiIj3X3DN33333cfPNNxMIeBEmPz8f8IZYb7zxRlJSUnyr0S9JF+bMbJaZPdz+XjXRNqL59iSHFOZERER6qrlnLj09nblz57ZMDwaDAJgZV111lS+1+S3pwpxzbrlz7trmH36sDC3Mwkw9cyIiIr2Rm5uLc459+/aRmZnZMj0jIwPnHGVlZeTk5PhYoX+SLsz5JSM1hUH5mbqiVURERCJKYS6Ghhdms0s3DhYREZEIUpiLoeFFuteciIiIRJbCXAwNL8pi39Eaauob/S5FRERE+gmFuRgaXpiNc/BxuYZaRUREJDIU5mJoxADv9iQ7NdQqIiIiEaIwF0PDC0Nh7rB65kRERCQyFOZiqCQvg/TUgHrmREREJGIU5mIoEDCGFWYpzImIiEjEKMzF2AjdnkREREQiSGEuxoYXZqtnTkRERCJGYS7GhhdlcaSmgYrqer9LERERSRjz5s1j5syZbaatW7cOM+O6665rM33ZsmVkZWWxf//+WJboG4W5GBtR5F3RqqFWERGR8BUUFFBRUdFm2oIFC8jIyKC8vLzN9IULFzJ37lxKSkpiWaJvFOZibGRxDgDbDlX5XImIiEjiKCwsbBPmduzYwTPPPMM111zTZvrq1atZu3YtN910kx9l+kJhLsZOKPLC3PaDCnMiIiLhat8zd//993PppZcybdq0Nj1z9957L7NmzWL8+PF+lOmLVL8LSDZZ6SkMDmayTWFORETiwN1v3M2msk0x3eeEogncesatPVqndZg7cuQIjzzyCCtXruTAgQMt07ds2cKKFSt46aWXAFi0aBH33HMPxcXFVFdXs3jx4pbz7p544gkWLVpEbW0tTU1N3HjjjVx99dUt+/vSl77Etm3beP311yPwjqNLPXM+GDkgR2FORESkBwoLC6msrKSxsZElS5YwadIkpk+fTn5+fkvP3MKFC5k6dSozZswA4N133+Xuu+9m/fr1LFq0iNtuuw2ARx99lIcffphf//rXvPPOO7zyyiukpKS07Ovdd9/lww8/5IMPPoj9G+0F9cz5YNTAHH79zh6/yxAREelxD5lfCgoKADh06BCLFy/mgQceACA/P5+KigrKyspYunQpS5cubVnnnXfe4Rvf+AYAw4cPp6GhgcrKSubPn89rr73WcoFEUVERV155Zct6t99+O3fddRff/va32blzJ8OHD4/Ru+wd9cz5YNSAHMqr6zlcVed3KSIiIgmhsLAQgCVLlpCdnc3s2bMBCAaDVFVV8eCDD1JaWsqcOXMAcM7x3nvvMX78eJqamnjwwQe57LLL+PnPf860adMYMmRIh/tZu3YtZWVlXHTRRZx00kls2LAhNm+wDxTmfKArWkVERHqmuWfuvvvu4+abbyYQ8CJMfn4+4A2x3njjjS3Dpdu3b6empoZzzz2Xs846i8LCQu644w7effddTj311E73c/vtt3PnnXcCcPLJJ7Nx48Zovq2ISLphVjObBcwaM2aMbzWMKv7rFa2fGFHoWx0iIiKJorlnLj09nblz57ZMDwaDAJgZV111Vcv0d999l5kzZ/Lcc8+12U5OTg5NTU0d7uNPf/oTq1ataglwVVVVLT2A8Szpeuacc8udc9c2//D9MKIom4Dp9iQiIiLhys3NxTnHvn37yMzMbJmekZGBc46ysjJycnJapr/zzjtMnjz5uO3MnDmTp556ioMHDwJw9OhRHn/8cQBuu+02fvvb37J9+3a2b9/OypUrE6JnLunCXDxITw0wtDCLrQpzIiIiUdHZcOr06dP5zne+wwUXXNByRWxdXR2rVq3COddyJSzA2LFjEyLMJd0wa7wYVZzLdp0zJyIiEhXLli3rdN7VV1/d5p5yzT71qU+1+b75Stl4p545n4wakM32g9U45/wuRURERBKYwpxPRhbnUFnbwIHKWr9LERERkQSmMOeTv17RWu1zJSIiIpLIFOZ80vr2JCIiIiK9pTDnk6EFWaQGTFe0ioiISJ8ozPkkNSXAiAHZ6pkTERGRPlGY89GoATm6PYmIiIj0icKcj0YWe2GuqUm3JxEREZHeUZjz0ajiHGrqm9h7pMbvUkRERPql5557josuuoinnnqKlStX8ulPf5pHHnnE77IiSmHOR6MHele0bj2goVYREZGuzJs3j5kzZ7aZtm7dOsyM6667rs30ZcuWkZWVxf79+1m9ejUrV67kxRdfZNmyZbzwwgts3bqVmpr+05GiMOejMQNzAdiy/6jPlYiIiMS3goKC4x6ttWDBAjIyMigvL28zfeHChcydO5eSkhLS09MJBAKMHj0agLS0NLKzs2loaIhZ7dGmMOejgXkZ5GWmsuVApd+liIiIxLXCwsI2YW7Hjh0888wzXHPNNW2mr169mrVr13LTTTcBMGbMGC688EKampq46KKLmDFjBo2NjeTm5sb8PURLqt8FJDMzY0xJLh/u1zCriIhIV9r3zN1///1ceumlTJs2jbVr17ZMv/fee5k1axbjx48H4Oqrr+bqq69umf/Vr341dkXHiMKcz04cmMvLmw/4XYaIiEhcax3mjhw5wiOPPMLKlSs5cOBAy/QtW7awYsUKXnrpJR8rjT2FOZ+NKcnl6bW7qDhWTzArze9yREQkyez90Y+ofW9TTPeZcdIEBn3/+z1ap7CwkMrKShobG1myZAmTJk1i+vTprFq1quWcuYULFzJ16lRmzJgRjbLjls6Z89mJoYsgPtR5cyIiIp0qKCgA4NChQyxevJjvfOc7AOTn51NRUUFZWRlLly7llltu8bNMX6hnzmdjSpqvaK3kEyMKfa5GRESSTU97yPxSWOh9Ri5ZsoTs7Gxmz54NQDAYpKqqigcffJDS0lLmzJnjZ5m+UM+cz4YXZpGeElDPnIiISBeae+buu+8+br75ZgIBL8Lk5+cD3hDrjTfeSEpKim81+kVhzmepKQFGFmfz4X6FORERkc4098ylp6czd+7clunBYBDw7hBx1VVX+VKb3zTMGgfGlOSycfcRv8sQERGJW7m5uTh3/LPMMzIyOpyeTNQzFwfGDMxlR1k1tQ2NfpciIiIiCUZhLg6cWJJLk4PtB6v9LkVEREQSjMJcHNDtSURERKS3FObiwOiBOYB3exIRERGRnlCYiwPZ6akMLchSmBMREZEeU5iLE2NKcjXMKiIiIj2mMBcnThzohbmmpuS+vFpERKIr2W/jEa/68nNRmIsTY0pyqalv4uPyY36XIiIi/VRaWhrHjulzJh4dO3aMtLS0Xq3bL8KcmQXN7A0zqzSzU/yupzfGlXpXtH6w/6jPlYiISH9VUlLCxx9/THV1tXro4oRzjurqaj7++GNKSkp6tY3+8gSIauAy4D/8LqS3xpbmAbB5XyUXTCj1uRoREemPmp9junv3burr632uRpqlpaVRWlra8vPpqX4R5pxz9cABM/O7lF4LZqUxKD+TzXvVMyciItGTn5/f69Ag8Snmw6xmdoOZrTGzWjNb2m5ekZn90syqzOwjM/tyrOvz09jSXN7fpzAnIiIi4fOjZ243cBdwMZDVbt5DQB1QCkwBXjCz9c65DWY2CHi6g+193jm3N5oFx8r40jyeeP0jGpscKYHE7WUUERGR2Il5mHPOPQtgZlOBYc3TzSwH+BxwinOuEnjVzJ4HvgZ8NxTYzo11vbE0rjSP2oYmdpRVM6o4x+9yREREJAHE09Ws44BG59zmVtPWAxPDWdnMfg1cBPzYzOZ1ssy1oSHeNQcOHOhrvRE3blDzRRAaahUREZHwxFOYywUq2k2rAPLCWdk5d6lzbohz7mzn3NJOlnnYOTfVOTd14MCBfas2CsaWeLcn0UUQIiIiEq54CnOVQPvLa/KBpEk2ORmpDCvMYrOe0SoiIiJhiqcwtxlINbOxraZNBjb4VI8vxpXmqWdOREREwubHrUlSzSwTSAFSzCzTzFKdc1XAs8APzSzHzM4BPgM8Eesa/TSuNI+tByupb2zyuxQRERFJAH70zN0GHAO+C3w19O/bQvOux7tdyX7gKeA651xEe+bMbJaZPVxR0f70vPgwrjSX+kbH9oNVfpciIiIiCSDmYc45N985Z+1e80PzypxzlzvncpxzI5xzy6Kw/+XOuWuDwWCkNx0R41o91ktERESkO/F0zpwAY0pyMUNPghAREZGwKMzFmcy0FE4oyuYDhTkREREJg8JcHBpXmqeeOREREQmLwlwcGleax0eHqqmpb/S7FBEREYlzCnNxaPygPBqbHB8e0EUQIiIi0rWkC3PxfmsSgJMGe1e0vrdHQ60iIiLStaQLc/F+axKAkQNySE8NsGnPEb9LERERkTiXdGEuEaSmBBhfmscmPdZLREREuqEwF6cmDMpj0171zImIiEjXFObi1ITB+RysrGP/0Rq/SxEREZE4pjAXp5ovgtikiyBERESkCwpzcWrCoHwADbWKiIhIl5IuzCXCrUkAinLSKc3PUM+ciIiIdCnpwlwi3Jqk2YRB+WzU7UlERESkC0kX5hLJSYPz+fBAJXUNTX6XIiIiInFKYS6OnTQ4j/pGx9aDeqyXiIiIdExhLo61XASh8+ZERESkEwpzcWz0wBzSUwK8p/PmREREpBMKc3EsLSXAmJJc3tNjvURERKQTCnNxbsLgPDapZ05EREQ6oTAX504alM/+o7UcrKz1uxQRERGJQ0kX5hLlpsHNJg7xLoLYuFu9cyIiInK8pAtziXTTYICTQ2Fug8KciIiIdCDpwlyiKchOZ2hBFht2J0ZPooiIiMSWwlwCmDgkX8OsIiIi0iGFuQQwcUiQbYeqqKpt8LsUERERiTMKcwlg4pB8nEM3DxYREZHjKMwlgIlDdRGEiIiIdExhLgEMys+kKCddF0GIiIjIcRTmEoCZMXFIvnrmRERE5DgKcwni5CH5bN53lLqGJr9LERERkTjS6zBnZkVmNtTMMiJZULQl2hMgmk0cEqS+0fHB/qN+lyIiIiJxJOwwZ2aDzOy7ZvaSmVUDB4AdQLWZbTezx81spplZ1Mt8lZoAACAASURBVKqNgER7AkSziXoShIiIiHQgtbsFzGwYcCfwZeAo8BqwAC/MHQOKgFHAmcAK4CMzu90599NoFZ2MRg3IITs9RTcPFhERkTa6DXPA+8BvgcuB3zrnGjtbMBT8vgLcY2ZDnHP/EZkyJRAwThqcrytaRUREpI1whlnPcc591jn3m66CHIBzbpdz7m5gNPB8RCqUFs2P9Wpqcn6XIiIiInGi2zDnnHurpxt1ztU6597vXUnSmVOGBKmqa2TboSq/SxEREZE40W2YM7N7zOwyM0usKwb6oUnDvB/BO7s01CoiIiKecIZZb8QbMj1kZm+a2SIzm2NmxVGuTdoZW5JLRmqAdz5WmBMRERFPOBdAFAHnAOcBM4CvA98EnJm9D7wMrAZWO+c+jlahAqkpASYOyVfPnIiIiLToNsw5544CK0MvzCwTOBv4ZOj1NeDa0LxtzrkxUatWOHVYAT9fs5PGJkdKIK5v6SciIiIx0OMnQDjnapxzq5xz/wpcBFwKLA/NHhXJ4uR4k4YGqa5rZOuBSr9LERERkTgQzjBri1Cv3Fn8tVfuLCATeA9YArwS6QKlrVNDF0G8vauCsaV5PlcjIiIifgvnCRCX8NfwNg1wwFrgVeB+4I/OucPRLDKSzGwWMGvMmMQcDR49MJfs9BTe+biCz50+zO9yRERExGfh9Mz9GqgCHgG+D7zhnKuJalVR5JxbDiyfOnXqNX7X0hspAeOUIUHe3lXudykiIiISB8I5Z+7/gEbgW8B/AgvN7EtmNjyqlUmnJg0LsmH3ERoam/wuRURERHwWzhMgZuLdnmQqXu9cKbAI2G5m283sCTO71sxOim6p0uzUYUFqG5r4YL8ughAREUl2YV3N6pxrcs6tc87d75yb45wrAU4F/h1IAW4D3jWz/VGsVUImDdWTIERERMTT41uTtLK71WtfaNqAPlck3Ro5IIfcjFQ9CUJERETCvzWJmQ3ir1e1fhI4GTC88+nWAgvwngYhURYIGKcMzedthTkREZGkF86tSR7BC28n4oW3WuAN4Ed4j/H6k3OuOppFyvFOHVbA0j9up66hifTUvnSwioiISCILp2fu74HXgMfxet7+7Jyri2pV0q3Jwwqoa2zivT1HmDy8wO9yRERExCfhhLkC51xj1CuRHpkywgtwb+0sV5gTERFJYuHcmkRBLg4NCWZSkpfBWzt182AREZFk1m2YM7O3zOyzZmbhbNDMhpnZYjP7576XJ50xM6YML1CYExERSXLhnDn/BPBj4GMzW2hmc8zsRDPLN7MMMxtkZtPN7Ntm9gdgOzAOeC6KdQveUOu2g1UcrtIpjCIiIsmq23PmnHP3hq5ovRr4B7zHerl2izVf5for4ELnnG5REgNTQufKvbWrnE+NL/G5GhEREfFDWPeZc85VAPcC94aeyXo2MATIBA4Bm4A3nHO10SpUjnfqsALM4K0dCnMiIiLJKuybBjdzzu0EdrafHhpy/ZZzblFEKpNu5WakMq4kT+fNiYiIJLEe3W3WzIrbXwhhZllmdjPeuXL3RbC2qDCzWWb2cEVF/3h6wpThBazfVY5z7Ue+RUREJBmEczVrhpktMrNKvGewHjKz60LzvgpsBf4D2AFcEs1iI8E5t9w5d20wGPS7lIiYMqKA8up6th/SQzhERESSUTjDrHcA3wR+D6wDRgGLzOxk4B+BzcC1zrnlUatSOnVay82DDzOqOMfnakRERCTWwn2c1386525onmBmVwGPAL8DZunxXv4ZW5JHTnoKb+0o57OnDfO7HBEREYmxcM6ZGw78st20Z0Nf71OQ81dKwJg0LMibughCREQkKYUT5tKAo+2mNX9/ILLlSG+cNqKQjbuPUFOvJ6+JiIgkm3CvZh1qZqObX8DojqaH5kmMnT6ikIYmx3r1zomIiCSdcO8z93Qn0zt6ZFdKL2uRXvrECYUArN1xmDNHD/C5GhEREYmlcMLclVGvQvqkKCed0QNzWLv9sN+liIiISIyF82zWx2JRiPTN1BMK+e3GfTQ1OQIB634FERER6Rd69AQIiV9TTyiivLqerQcr/S5FREREYkhhrp84fWTovLmPNNQqIiKSTBTm+onRxTkUZqexRufNiYiIJBWFuX7CzDj9hEL1zImIiCQZhbl+5PQTith6sIpDlbV+lyIiIiIxojDXj0wNnTe3boduHiwiIpIsFOb6kUlDg6SnBFjzUZnfpYiIiEiMKMz1I5lpKZwyNF83DxYREUkiCnP9zLSRRby9q4Ka+ka/SxEREZEYUJjrZ84YVURdYxNv6rw5ERGRpKAw189MHVmEGfx52yG/SxEREZEYUJjrZ4JZaZw8OJ8/b9VFECIiIskg6cKcmc0ys4crKir8LiVqzhw1gHU7DlPboPPmRERE+rukC3POueXOuWuDwaDfpUTNmaOLqG1o4u1d/TewioiIiCfpwlwyOGNkEQB/3qrz5kRERPo7hbl+qDAnnQmD8nhd582JiIj0ewpz/dRZowew9qPD1Dc2+V2KiIiIRJHCXD915qgijtU36rw5ERGRfk5hrp86Y1TovDndb05ERKRfU5jrpwbkZjC2JFf3mxMREennFOb6sbNGD+Av28uoa9B5cyIiIv2Vwlw/ds6YYqrrGlm/S89pFRER6a8U5vqxs0cPIGDwygcH/S5FREREokRhrh8LZqcxaVgBf9yiMCciItJfKcz1czPGFPPWznKO1tT7XYqIiIhEgcJcP3fOmGIam5yeBiEiItJPKcz1c584oYDMtICGWkVERPophbl+LiM1hTNGDeBVhTkREZF+SWEuCcwYU8yW/ZXsrajxuxQRERGJMIW5JHDOmGIA9c6JiIj0QwpzSWDCoDwG5KTrvDkREZF+SGEuCQQCxjljinnlg4M0NTm/yxEREZEIUphLEuePH8jBylo27D7idykiIiISQQpzSeK8cQMxgxc37fe7FBEREYkghbkkMSA3g8nDClj1vsKciIhIf6Iwl0Q+Nb6E9bvKOVRZ63cpIiIiEiEKc0nkUxMG4hy8vPmA36WIiIhIhCjMJZFThgQpzs1g1fsKcyIiIv2FwlwSCQSM88cP5OX399PQ2OR3OSIiIhIBCnNJ5lPjSzhS08CbO8v9LkVEREQiQGEuyZw7tpiUgLFKtygRERHpFxTmkkwwK42pJxTqfnMiIiL9hMJcEvr0yaVs2nuU7Qer/C5FRERE+khhLgldPHEQAP+3Ya/PlYiIiEhf9YswZ2Znm9lrZvaymT1lZml+1xTPhhdlM3FIvsKciIhIP9AvwhzwEXCBc+48YCvwGZ/riXuXTBzEuh3l7DtS43cpIiIi0gf9Isw553Y7546Fvm0AdBO1blxyijfU+lv1zomIiCS0mIc5M7vBzNaYWa2ZLW03r8jMfmlmVWb2kZl9uYfbHgXMBFZEsOR+aUxJLqMH5rBSYU5ERCShpfqwz93AXcDFQFa7eQ8BdUApMAV4wczWO+c2mNkg4OkOtvd559xeM8sHHgO+5pyri175/YOZccnEQSxZvZXy6joKstP9LklERER6IeY9c865Z51zzwGHWk83sxzgc8DtzrlK59yrwPPA10Lr7XXOndvBa6+ZpQJPAfOdc+/H+C0lrEtOGURjk+P37+mecyIiIokqns6ZGwc0Ouc2t5q2HpgYxrpfAs4E7jCzl8zs7ztayMyuDQ3xrjlwQA+bnzQ0yJBgJivf3eN3KSIiItJL8RTmcoGKdtMqgLzuVnTOPeGcK3bOnR96/ayT5R52zk11zk0dOHBgBEpObGbGzEmDWb35IBXV9X6XIyIiIr0QT2GuEshvNy0fOOpDLUnj8ilDqWts4tfqnRMREUlI8RTmNgOpZja21bTJwAaf6kkKpwzNZ/TAHJ5782O/SxEREZFe8OPWJKlmlgmkAClmlmlmqc65KuBZ4IdmlmNm5+Dd/PeJWNeYTMyMy6cM5c/bythdfqz7FURERCSu+NEzdxtwDPgu8NXQv28Lzbse73Yl+/GuTr3OOaeeuSibPXkIAM+v3+1zJSIiItJTftyaZL5zztq95ofmlTnnLnfO5TjnRjjnlkV6/2Y2y8werqhof61F8hpZnMOU4QUaahUREUlA8XTOXEw455Y7564NBoN+lxJXLp8yhE17j/L+Xl1vIiIikkiSLsxJx/528hBSAsZzb6l3TkREJJEozAkAxbkZzBhbzC/XfUxDY5Pf5YiIiEiYFOakxRenDWfvkRpe3qynY4iIiCQKhTlpceFJpRTnZvDUGzv8LkVERETClHRhTlezdi4tJcDfTR3Gi5v2s6dC95wTERFJBEkX5nQ1a9e+OG0ETQ5+/pddfpciIiIiYUi6MCddGzEgmxlji/nZX3bQ2OT8LkdERES6kep3Af3Z3W/czaayTX6X0WNHCuo4XHuUzz/3KAXZaX6XIyIiEtcmFE3g1jNu9W3/6pmT4xRmp5OWEmDf0Rq/SxEREZFuqGcuivxM6X1172/f58FVW3jy0vMYPTDX73JERESkE+qZkw7NPXskaYEAP3l1m9+liIiISBeSLszp1iThGZiXwWdPG8rTa3dRVlXndzkiIiLSiaQLc7o1SfiunjGK2oYmnnz9I79LERERkU4kXZiT8I0tzeNT4wfy+Gvbqalv9LscERER6YDCnHTpmhmjOVhZx3Nvfux3KSIiItIBhTnp0tknDuCUofn898sf0tDY5Hc5IiIi0o7CnHTJzPjWhePYfqiaZ9epd05ERCTeKMxJt/7mpBImDwuy6A8fUNeg3jkREZF4ojAn3TIzbrpoPB+XH+Nna3b6XY6IiIi0ojAnYfnk2GKmjSzkwRc/0JWtIiIicSTpwpxuGtw7ZsZNnx7PviO1uu+ciIhIHEm6MKebBvfe2ScOYMbYYhb/4QMOVdb6XY6IiIiQhGFO+uZfZp1MdV0j//F/7/tdioiIiKAwJz00piSPK88Zyc/W7OTtXeV+lyMiIpL0FOakx/7pwrEU52Zwx6820NTk/C5HREQkqSnMSY/lZabxvZkTeGtnOU+v3eV3OSIiIklNYU565bOnDeWMUUXc+cJG9lQc87scERGRpKUwJ71iZiz4/GQamxzf+cXbGm4VERHxSarfBfRne3/0I2rf2+R3GVG19Ggt2/5QyV+W5zAoP9PvckRERGIu46QJDPr+933bv3rmpE9K8jIoyE5nR1k1x/RkCBERkZhLup45M5sFzBozZkzU9+VnSo+lrCM1XHz/agYHs3j2uulkpaf4XZKIiEjSSLqeOT0BIvJK8zO5/++nsGnvEf75mbdxTufPiYiIxErShTmJjvPHl3DLReNZvn43P35lq9/liIiIJA2FOYmY688/kUsnDeLff7OJlzcf8LscERGRpKAwJxFjZvzH5yczrjSP655cy7odh/0uSUREpN9TmJOIyslI5fF/OIOBeRnM+583eG/PEb9LEhER6dcU5iTiSvIyefIfziQnI5Wv/eQNth6o9LskERGRfkthTqJieFE2T/zDmTjn+MJ/v8Y7uyr8LklERKRfUpiTqBlTkssvvnE2mWkpfPHh13j1g4N+lyQiItLvKMxJVI0emMuz109neFE2Vy59g5+v2el3SSIiIv2KwpxEXWl+Jj/7+tmcMaqIf376bW59+m1q9OgvERGRiFCYk5gIZqXx+FVn8s0LxvCzNTv57H/+iS37dWGEiIhIXyVdmDOzWWb2cEWFTsiPtZSAcfNF43l03jT2VBzj0sWv8NCqLdQ3NvldmoiISMKyZH2O5tSpU92aNWv8LiNp7T9aw78+v5EX3tnDSYPzuevyiZx+QpHfZYmIiMQlM1vrnJva0byk65mT+FCSl8lDX/kE//3V0ymrquVz//Ua33hire5JJyIi0kOpfhcgye2SUwbxyXHFPPLKNpa8/CG/f28fs6cM4Rvnnci40jy/yxMREYl7GmaVuHHgaC0PrdrCz/6yk2P1jVwwoYS5Z5/AjLEDSQmY3+WJiIj4pqthVoU5iTuHq+p4/LWPePy17RyqqmNIMJMvTB3O7ClDOHFgrt/liYiIxJzCXAcU5uJfXUMTv39vH//7l5288sEBnIMJg/K45JRBXDihlIlD8gmox05ERJKAwlwHFOYSy96KGn7z7h5+/c4e1nx0GOdgQE46544tZurIIk4bXsCEQXmkpuiaHhER6X8U5jqgMJe4Dhyt5dUtB1i9+SCvbjnIgaO1AGSlpTBpWJDTRhRw2vACxpbmMaIomzQFPBERSXAKcx1QmOsfnHPsOnyMN3eW8+aOw6zbUc7G3RXUN3rHdVqKccKAHMYMzGVMSS6jB+YwtCCLIQVZlOZnkp6qoCciIvGvqzCnW5NIQjMzhhdlM7wom9mThwBQU9/Ipr1H2bK/kg8PVLJlfyWb9x/ld+/to7HJtVoXSvIyGBzMYnAwk6KcdAbkpFOYk05RB6+M1BS/3qaIiEinFOak38lMS2HK8AKmDC9oM72uoYmdh6vZU17D7vJjfFx+jN3lx9hdcYzN+45SVlVH+bF6OuuszkpLITczldyMVHIyUshJb/53asv0rLQUMtNSyEgNkJEWICPV+3fLtNQAGa3+nZ4aIDUQICVgpAaMlBTva2ogQGrAdIGHiCSE5lG+5r+frv30lu+b57ddnm7muy62RRfrhFMDxy0fxrba1Z2XmUpBdjp+UZiTpJGeGuDEgbld3t6ksclRcayesqpayqr++vVwdR2Hq+qoqmugsraRqtoGKmsb2FNRQ1VdQ8v3NfWRfc6sGV7ICwW8lICRltL2+9SAYQYBa/3VMCAQAMMImLexgOFNDy3bspy13YZ1sax1kS+9JTp/L929195st5ezWrgOvnGtprb+o33ch0D7+R1Mo4NlW89ufapLR+t3tmzYNYVZM22mRa5m2n2QHr/s8R+OHbdpx//L6ur9dVcz3bRzb2vuaDtdhZS26/cwkLSv1fU8SLVvj56GIoFvnHci3505wbf9K8yJtJISsJZh1d5oanLUNTZRW99ETUMjtfVN1DY0UtsQ+tpqek1DI/WNjsYmR0OTo7GxiYbmfzc5GhodjU1NLd/Xt/v+r9ObWv4n2dQU+uq8P7zOQZPz/jS3ntZ+2cYmR5NzbZbFhbbTsmznH6jQ9R/21h+0PV+3q/W6qKfLHdIm6bUOfRZKlW2ntV7WjptGm2W7Wd/abuf47R8/saNt9abmjt5zS0C31jVZj2puX0dPam5TS5ttHr+vnvxMOqq5w/ffx5rpoI6O1jc7vk5rt5GO1mm93ePnt/0htF6+0221P1a63UfX8zHrQb3d191dDe2Pu/bvp7M26qju7t5nZ/Pa/zqZGeN9fmKRwpxIBAUCRmbAG2oNkuZ3OSIikgR0KZ+IiIhIAku6MGdms8zs4YqKCr9LEREREemzpAtzzrnlzrlrg8Gg36WIiIiI9FnShTkRERGR/kRhTkRERCSBKcyJiIiIJDCFOREREZEEpjAnIiIiksAU5kREREQSmMKciIiISALT47yi6Tffhb3v+F2FiIiIRNOgSTDz333bvXrmRERERBKYeuaiyceULiIiIslBPXMiIiIiCUxhTkRERCSBKcyJiIiIJDCFOREREZEEpjAnIiIiksAU5kREREQSmMKciIiISAJTmBMRERFJYApzIiIiIglMYU5EREQkgSVdmDOzWWb2cEVFhd+liIiIiPRZ0oU559xy59y1wWDQ71JERERE+izpwpyIiIhIf2LOOb9r8IWZHQA+isGuioGDMdhPolM7hUftFB61U3jUTuFRO4VH7RS+3rTVCc65gR3NSNowFytmtsY5N9XvOuKd2ik8aqfwqJ3Co3YKj9opPGqn8EW6rTTMKiIiIpLAFOZEREREEpjCXPQ97HcBCULtFB61U3jUTuFRO4VH7RQetVP4ItpWOmdOREREJIGpZ05EREQkgSnMiYiIiCQwhbkoMbMiM/ulmVWZ2Udm9mW/a/KbmWWY2U9C7XHUzN40s5mheSPNzJlZZavX7X7X7Bcze8nMalq1xfut5n051IZVZvacmRX5Watf2h0rlWbWaGYPhOYl9fFkZjeY2RozqzWzpe3mXWhmm8ys2sxWmdkJreZlmNn/mNkRM9trZjfFvPgY6qydzOwsM/udmZWZ2QEz+4WZDW41f76Z1bc7vkb78iZipIu26vJ3TcdUy/SvtGuj6lC7nR6a36djSmEueh4C6oBS4CvAf5nZRH9L8l0qsBM4DwgCtwM/N7ORrZYpcM7lhl53xr7EuHJDq7YYDxA6hpYAX8M7tqqB//SxRt+0aptcvLY4Bvyi3WLJejztBu4C/qf1RDMrBp7F+90rAtYAP2u1yHxgLHAC8Cngn83skhjU65cO2wkoxDtBfSReWxwFHm23zM9aH4POua3RLtZnnbVVs85+1+ajYwrn3E/b/c26HtgKrGu1WK+PqdRIVC5tmVkO8DngFOdcJfCqmT2P9wH8XV+L85FzrgrvF7vZCjPbBpwOrPWlqMTzFWC5c241QOh/wO+ZWZ5z7qi/pfnq88B+4BW/C4kHzrlnAcxsKjCs1aw5wAbn3C9C8+cDB81sgnNuEzAXuNI5dxg4bGY/BuYBK2NYfsx01k7Oud+0Xs7MHgRejm118aWLY6o7OqY6dgXwuIvQVajqmYuOcUCjc25zq2nrgWTvmWvDzErx2mpDq8kfmdkuM3s01IuQzP6fmR00sz+a2fmhaRPxjiUAnHMf4vUAj/OhvnjS2R9GHU9ttT9+qoAPgYlmVggMaT0f/d1q9kna/p0CmBUaht1gZtf5UVScOe53TcdUx0KnNnwSeLzdrF4fUwpz0ZELVLSbVgHk+VBLXDKzNOCnwGOhHoGDwDS8rvjT8drqp/5V6LtbgdHAULzhnuVmdiI6to5jZiPwhu4fazVZx1PHujp+clt9335e0jKzU4E7gO+0mvxz4CRgIHANcIeZfcmH8uJBV79rOqY6Nhd4xTm3rdW0Ph1TCnPRUQnkt5uWj3feRdIzswDwBF6P0g0AzrlK59wa51yDc25faPpFZta+HZOCc+7Pzrmjzrla59xjwB+BS9Gx1ZG5wKut/zDqeOpUV8dPZavv289LSmY2BvgN8C3nXMsQvnNuo3Nut3Ou0Tn3J2AR3lB/0unmd03HVMfm0vY/n30+phTmomMzkGpmY1tNm8zx3fRJx8wM+AneCeufc87Vd7Jo83CZxaSw+Ofw2mID3rEEQOhqpwy8Yy5ZHfeHsQM6njztj58c4ES88+gOA3tazyeJ/26FhsJ+D9zpnHuim8Wbfz+l1e+ajqnjmdk5eEPPT3ezaI+OKYW5KAidh/Is8EMzywn98D6D1xuV7P4Lryt5lnPuWPNEMzvTzMabWcDMBgCLgZecc+2HhPo9Mysws4vNLNPMUs3sK3jnV/wf3vDFLDObEfog/iHwbLJe/GBm0/GGon/RbnpSH0+h4yYTSAFSmo8l4JfAKWb2udD8O4C3Q6c6gHcOz21mVmhmE/CGe5b68BZiorN2MrOhwIvAQ865/+5gvc+E2sjM7Azgn4Bfxbb62Oqirbr7XdMx5f3uNbsCeKb93+w+H1POOb2i8MK77P85oArYAXzZ75r8fuGdU+GAGrzu9+bXV4AvAdtC7bUH7w/AIL9r9qmdBgJ/wRuKKAdeBz7dav6XQ8dUVeiXvcjvmn1sqyXAEx1MT+rjCe+qcdfuNT8072+ATXi3cnkJGNlqvQy8WyocAfYBN/n9XvxoJ+BfQv9u/XeqstV6TwGHQtM3Af/k93vxsa26/F3TMdXmdy8z9Df9wg7W69MxpWezioiIiCQwDbOKiIiIJDCFOREREZEEpjAnIiIiksAU5kREREQSmMKciIiISAJTmBMRERFJYApzIlFkZvPMzIUeC9Q87dtmNsfHmgrMbL6ZfaKDeS+Z2Us+lBURZjbBzF40syOhdr/c75o6076tzez8UM3nR3Gf88zsqj5uY76Z9Yt7WnX1u9DJ8kvNbFe06xLpqdTuFxGRCPs28CreU0L8UIB3U9RdwLp2866PfTkRdR8wGvg7vJtzvu9vOT2yDjgb2BjFfczD+7v/P1HcRyLp6ndBJGEozIn0A2aW4Zyr7et2nHPRDBKxcBKw2jm3Mlo7MLM0oMFF+I7rzrkjeE/7EBHpEQ2zisSQmW3He6zZV0JDas7MlraaP9nMnjezw2Z2zMz+aGYz2m1jqZntMrOzzexPZnYMuCc074uhYcYDZlZpZm+a2RWt1h2J9+gdgB+3qmFeaP5xw6yh5y7+0szKQzW9bmaXtFtmfmg7Y83shdC+PzKzO8ws0Gq5XDN7wMx2mFmtme0zs9+HntnYVbulmdldZrbdzOpCX+8KBauWIUpgJPC15vfVzTb/JtQ+NWa2xcyuDrXt9tbtFdrW9WZ2j5ntBmqBAjMbaGZLzGyzmVWb2U4zW2becz3b7+uLZrYp9J43mNlnO1imw2FWM5sTavPq0M/gF2Y2ot0y283sydB+3jOzKjNbY2bntlrmJeA84JxWP/eXummj08zslVAbfWxmt9PBw7/Nex7l91q9x91mdq95z6hsvcydZvZhaHsHzezV1jWGlrvGzNaFjrXDZvayec/gbZ6fbWZ3m9m20LGwzcx+0O44a27L2Wb2YGhfB0JtVBBaZiRd/C6Ey8yuNLN6M/tuT9YTiST1zInE1meBXwPr8Z7hB3AAwLzzdl4B3sR7GHU18A3g92Y23Tm3ttV2gsD/AguA7+M9ZxO8IcangX8HmoBPAo+YWZbzHhi+B5iDN8T7/4DnQ+t92FGxZjYEb0j4KHADUAH8I/CCmf2tc+437Vb5JfAosBCYBfwrsDM0jdD02aGaPwAGAOfgDXd15TG8odMfheo5G7gt9H6/zF+HKJ/He67tnV1tzMxOBl4A3gC+CKQDt+O1a1MHq/wgtN1r8R6gXQOMCH39Ht7PcAhwM/BHM5vgnKsJ7etvgGWh/d2M9+zdRUAa3QwDm9k3gP/C7LLq3gAACJlJREFUa78fAnl4x83LZnaqa/uw7hnA+ND7qAm1wQozG+mcK8cbQn8yVP/XQ+sc6WLfxXgPm9+L93DwWuA7offd3pN4P++7+f/tnXuMHlUVwH+n2zdIU4N9hKAlVqvEB5oiNLFASE1qIQJCpLZqiqJRIw8hpII0LNGakAANQUyqARcjrETUGsujpY2r4BbbpNouYDVVt1row7YIFNrSx/GPc2b37t2Zb79vbXe79PySyZc5c797z3fnTuZ85zED7ZiH9DuYcX25t1kIfBObyz8DpwDTsfdYF2Peic3R/Vj48whwro/ZLvbC8hXAmd5/hx9f5P3cmOl1D7AcWyPTsD89h/33NHQtlCEiN2Nr/Muq2lLv94LgqDPYL6WNLba38oblKCkwNZF1Aj8tabsa+AswMpE1uWxZImvxPi/pY+xh2B+2HwEbEvkU//7VJd9pA9qS/TuBQ5n+TZgRsj6RNXufV2X9dQArk/3ngLsbnMMPkLysOpHf6vIPJbKtQEsdfT6MGWBjE9lkzAjqLJmr9WDvsq7RZxNwure/LJH/AcuDG5bIzvF26Vxf4LILfP9kzHh+IBtnCvAmcH22pl4Gxiey6d7fvOz8PlPnvC/2cd6ZyE4Cdtmto0s208f5Qvb9+S4/y/eXA7+sMd5UzNCqXB/A573P8zL5t13XCdlcPpi1+76f4+K95MX57XUtVIzf4mtsGHAv9nL5ixpZz7HFdiy2CLMGwXGAiIzBQmA/B454SGo4FtJahXnYUg5hN8e8n/eISKuIvAgc9O1qzCvRH84DnlXVzYVAVQ8DrcBZInJK1v6xbP85enpy1gELROQWEZkuIk116gDm/Ukp9s+vo4+cc4HHVfWNQqCq2zCvUhnLVLVX2FZEviYiG0RkL3ZO/uWHpvnxJuBs4FFV7fL4qeofMQOsFjMw79VDxXrwNbEV2ETvNbFGVV9O9jv8s8yTVg8zsHNf/CZU9XXgN1m72Zgh9YtMz5V+vNBzHTBHRBaLyMdFZGTWzyzMSPphDZ1mA1twL1021gjsvKbk67EDGAVMrDFGXwzHvOLzgFmqmo8RBANOGHNBcHzwdsyzs4huI6zYvgGMT3OCgJ1uVHUhIicDTwEfBr6FeUzOxioXR/0fem0rkW/HDM3xmXxPtn8AGJ3sXwMsBb6I3dx3isgSERnbhw6U6LE9O94Ik4GdJfIdFe17zYGIXAP8ADO2Pw18jG5jovjNp2JGRlm/VWMVTPDPVfReEx/EQtQpPeZeuwtiRtM/JlfomMsmYGHqvZmOxfwWen4PC51+Cksn2C0iP/Zwbtqu1qM/JmA5p/l8rM36KChbj9D/OQEzsC/CDP+1fbQNggEhcuaC4Pjgv1h+0H3AT8oapJ4dLDSUMwO70c1U1WcKoXsu+sseYFKJfJLrkN8sa6Kqe7Ecs5tF5F3AFVh+35tYTlWVDsWYaT5TodfuRnRwttFtLKVUeWzK5nsusFpVu/K0ROSMrM0uzNgo63ci5mWqovhdC4DnS46/ViI7mmyjWu+U3VjocmZJW4CXAFT1IJZTd4eITAIuxh4lMxa4EpsrgNOoziXcjRUtfKbieGeF/GiyB/gc5hlvFZF5qnpoAMYNgkrCmAuCgecAMCYVqOrrIvI05lVbnxlu9VJ4tw4WAhEZD1xSMj65DhX8Drjek+g7vc8m7Ob7J+2ZgN8QqroFuEtE5mN5cbV0ADOeFify+f75+34M/ywW8htbhFpFZDJWjFHmiSxjLL0LCK5Kd1T1sIisA64QkebivIrIOVi+Vi1jrh0z2Kaq6oN16tQXB7AiinpYA9wkIqer6r8BROQkrNAh5UnMEB+nqqvr6VhVt2OFOXPoPversD80X6F3IUM61uXAXlXdVOfvqEUj10IXqtomIp/Eipl+JiJzw6ALBpMw5oJg4HkBmCkiF2Ohwl1uKN2AGSYrROR+zKg4Ffgo0KSqfT36oB0zLu4TkduwZPVbMY/HuKTdDszDMVdENmJJ3P9U1TIP1xLMM/SU9/kqVhX5XizU1BAisgarGuzAwnLnYwZspbGiqs+LSCvQ7F7GdswLuQhoVdWNjeoBfBfzCq7wCspR3t8OyqtZy3gSWCgit2Dhtgu9z5zbsJyuZSKyFKtmvZ3uMHEpqvqqiNyEnc93AE9gBRGnYfPWpqoP16lrwQvA10XkSszL+ZqqVnnBlmDneqWINNNdzbovbeSGTSvwqIjcjc3FEcxYnQMsVNW/icivsSru9VixxkewHLil3s/fRWQJcIOIvA1bJ4ex8PUmVX0EeAgzmFeLyF3e30jg3Vj49tI0D7IOGrkWeqCqT4s9oucJ4BE36A729b0gOCYMdgVGbLG9lTfKq1nfh+UMveHHWpJj78eSq3diN8+t2E1tTtKmBdhaMd6F2KNN9mE362vxStOs3aXYjf2g67DA5W0kFZYumwYswwyJ/ZhXa3bWptn7GZ7JW+hZHXqH6/cKduPsAK6tYx5HYAbYFtd5i++PyNrVVc3qbT+BPSLjAPAP7HEdv8I8jkWbKVRX/o7BHhvyH8yDthw4g/LK289iocMDWMj0snyuyapZE/kc4LeYIb0P2IzlQZ6ZtOmkvEK6hy5YaPpx17dHNW3FHBWPy9kPvIgZvLeXrKdhwHWYcbXfz+8G7FEg47zNjb52dvvv+Kuvm/wcfhXY6HO1x+dpRnJ8tH9vU9JmncuGZ3M5q+J6nNLXtVAxHy1k1x72x+IV7BoZWWs+Y4vtWG1FeXYQBMEJjReQbAYeU9UvDbY+QRAE9RJh1iAITkhE5F4sZPsS9sDf67Dq3HsGU68gCIJGCWMuCIITldFY2HciVk27FgvL9ScHLwiCYNCIMGsQBEEQBMEQJh4aHARBEARBMIQJYy4IgiAIgmAIE8ZcEARBEATBECaMuSAIgiAIgiFMGHNBEARBEARDmDDmgiAIgiAIhjD/A2L/EtoGBu34AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 64*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00640658\n",
      "Converged gradient descent: test risk: 0.00607476\n",
      "2.7157812643872026\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 163 due to early stopping\n",
      "Gradient descent: test risk last: 0.00309144; test risk early stopped: 0.00307362; train loss: 0.001402157242409885\n"
     ]
    },
    {
     "data": {
      "image/png": "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rV27FjPjqquu6lC+bNkyCgsL2bVrF6+99holJSWce+65XHHFFd12uZ5xxhlcffXVMY07HvuMpCdAxImZMbBfPnvUMiciItJnZWVlbNiwoUPZvHnzyM/Pp6ampkP5ggULmDVrFqWlpWzbto2LL76Y+++/nxNPPDGRISeMWubiqKIkXy1zIiIiMVBeXk74TBRbtmzh4Ycf5sorr+xQvmrVKtasWcN1113H+vXrOeWUUwDIyem+/Wr27Nk8++yz3HPPPZgZZsamTZtwznH77bczatQoCgsLmTBhAg8++GCHbVetWsUpp5xCSUkJoVCIj3zkI6xfv77Lfcaakrk4GtgvX/fMiYiIxEBZWVmHpO3OO+9kxowZTJkypUPL3B133MHMmTMZO3Ys69atY9q0adx3331ccskl7N/f9QwTCxcu5KMf/SiXXXYZO3bsYMeOHYwYMYKbbrqJn/3sZ9xzzz289tprfPe73+UrX/kKTz75JADNzc186lOf4rTTTmPdunX89a9/5Vvf+hbZ2dld7jPW1M0aRxUl+by0ZV/QYYiIiHTpX594lde2J3YarfFDS/mXmcf3aJvwZG7//v3ce++9rFixgt27d7eXb9y4keXLl7Ny5UrAG8l61llnMXHiRK699lpmzZrFo48+2ulzaUOhEHl5eRQVFTF48GDAe5bt/Pnz+cMf/sC0adMAOProo3nxxRe55557OP/889m/fz81NTXMnDmTUaNGATBu3Lj2/UbuMx6UzMXRwH757K1vormllZxsNYKKiIj0Vnl5OXV1dbS0tLB48WImTJjA1KlTeeaZZ9pb5hYsWMDkyZPbE6+FCxe2b3/ppZdy6aWX9uiYr732Go2NjZx33nkdEsDDhw9TVVUFQP/+/Zk9ezbnnnsuZ511FmeddRaf+9zn4tIC1xUlc3E0sF8+zkF1fRODSguCDkdEROQDetpCFpSysjIA9u7dy6JFi9qnGCktLaW2tpbq6mqWLl3K0qVLY3bM1tZWAJ544glGjhzZYVlubm779z//+c+55pprWLFiBY8//jjf//73eeyxxzj33HNjFkt3lMzF0cCSPAB21x1SMiciItIH5eXlACxevJiioiIuuOACwOsera+v5+6776ayspILL7yw18fIy8ujpaWl/efx48eTn5/P5s2bOfPMM7vdduLEiUycOJEbb7yR6dOnc99993Hu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aQCsX7+e2267jXXr1rFw4UJuuukmAH7+85+zZMkSnnrqKV555RWee+45srOz24+1fv163n77bd56663EV7QX1DKXQHk5WVSU5OueORERSRo9bSELSllZGQB79+5l0aJF3HXXXQCUlpZSW1tLdXU1S5cuZenSpe3bvPLKK3z1q18FYMSIETQ3N1NXV8fcuXP5y1/+0j5Aon///lx22WXt2918883ceuutXHPNNWzdupURI0YkqJa9o5a5BNNccyIiIj1XXl4OwOLFiykqKuKCCy4AIBQKUV9fz913301lZSUXXnghAM45Xn/9dcaOHUtrayt33303559/Pr/61a+YMmUKQ4cO7fQ4a9asobq6mnPOOYfjjjuOV199NTEV7AMlcwk2OFSgljkREZEeamuZmz9/Ptdffz1ZWV4KU1paCnhdrNdee217d+mmTZtobGzktNNO45RTTqG8vJwf/OAHrF+/nhNPPLHL49x8883ccsstAIwfP57XXnstntWKCXWzJtjQUAF/fWdv0GGIiIiklLaWuby8PGbNmtVe3jY7hZlx+eWXt5evX7+e6dOn89hjj3XYT3FxMa2trZ0e4/nnn+eZZ55pT+Dq6+vbWwCTmVrmEmxwqJD9jc3Ua+JgERGRqJWUlOCc4/3336egoKC9PD8/H+cc1dXVFBcXt5e/8sorTJw48QP7mT59Og899BB79uwB4MCBA9x///0A3HTTTfzhD39g06ZNbNq0iRUrVqREy5ySuQTTXHMiIiLx11V36tSpU/n2t7/NmWee2T4itqmpiWeeeQbnXPtIWIAxY8akRDKnbtYEGxxqm2uukdGDSgKORkREJD0tW7asy2VXXHFFhznl2nz84x/v8HPbSNlkp5a5BPtHy5wmDhYREZG+UzKXYJo4WERERGJJyVyCFeRmM7BfPtv2NQQdioiIiKQBJXMBGF5eyLZ96mYVERGRvlMyF4Dh5UVK5kRERCQmlMwFYER5IdtrDtLS6oIORURERFKckrkADC8vornVsXO/BkGIiIhI3yiZC8Dw8kIAtlVrEISIiIj0jZK5AIzoXwTAVt03JyIiElePPfYY55xzDg899BArVqzgE5/4BPfee2/QYcWUkrkADC0rwAxNTyIiIhKl2bNnM3369A5la9euxcy46qqrOpQvW7aMwsJCdu3axapVq1ixYgVPP/00y5Yt48kn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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 100*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00493552\n",
      "Converged gradient descent: test risk: 4.23803572\n",
      "2.172625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 148 due to early stopping\n",
      "Gradient descent: test risk last: 0.00283823; test risk early stopped: 0.00282525; train loss: 0.001873351284302771\n"
     ]
    },
    {
     "data": {
      "image/png": "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bdu2cfjw4aBDEV9+fj7du3enrKysQ/srmUuw3pXFbNt7kAOHG+iUnxt0OCIiksVqamrYunUrvXr1oqioCDMLOqSs55xj//79bNq0CaBDCZ26WRMsND3JRg2CEBGRgG3bto1evXpRXFysRC5FmBnFxcX06tWLbdu2degYSuYSrHdVEYBe6yUiIoE7fPgwRUVFQYchURQVFXW461vJXIKF5prT9CQiIpIK1CKXmo7m56JkLsG6dS6kMC9H05OIiIhIQmRdMpfM13n55+O4yiJ1s4qIiEhCZF0yl8zXeYX0qSpWN6uIiIgkRNYlc0HoXVWsblYREZEAzJs3jx/84AdBh5FQSuaSoHdlMTUH6qnepwkaRUREkun9999n+PDhQYeRUErmkqBpehJ1tYqIiCTV0qVLOfXUU6mtrWX8+PE89NBDQYcUd0rmkuC40PQk6moVERHpkIkTJzJmzJhmZUuWLMHMuP7665uVz507l6KiIrZt28YHH3xAaWkpF198Mddee22rXa7nn38+N954Y1zjTsQxI+l1XkkQeguEWuZEREQ6pqKiglWrVjUrmzJlCoWFhezZs6dZ+bRp05gwYQJlZWVs3LiRK664gscff5xTTjklmSEnjVrmkqC8KJ+yTnmankRERKSDKisrCZ9WbP369Tz11FNcd911zcoXLlzI4sWLueWWW1i+fDlnnXUWAHl5rbdfTZw4kddee41HHnkEM8PMWLduHc457r//fgYMGEBRURHDhg3jiSeeaLbvwoULOeussygtLaW8vJzPfe5zLF++vMVjxpuSuSTp06WY9epmFRER6ZCKiopmSduDDz7I2LFjGTlyZLOWuQceeIBx48YxaNAgli5dyujRo3nssce48sorqampafH406dP5+yzz+bqq69m8+bNbN68md69e3PnnXfy61//mkceeYQPPviAH//4x3zve9/jhRdeAKC+vp6vfOUrnHvuuSxdupS//e1v/PCHPyQ3N7fFY8abulmTpF+XEpZtSs5ExSIiIrH69+dX8MGnLSc5iTD02DL+bdxJ7donPJmrqalh9uzZzJ8/n+3btzeVr169mnnz5rFgwQLAG8l6wQUXMHz4cG6++WYmTJjAM888E/XVWeXl5RQUFFBcXEzPnj0BqKurY+rUqbz00kuMHj0agP79+/Puu+/yyCOPcOmll1JTU8OePXsYN24c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xpnZrMjhzUE6sWdnAP6prlYREZGoQi1zU6dO5dZbbyUnx0thysq817pPmzaNm2++uam7dN26dRw4cIBzzz2Xs846i8rKSu6++26WL1/OKaec0uJ57rrrLu655x4Ahg4dygcffJDIy4qLWFrmegPPRJQ9DcwGpiboPa0Jk2oDIABO8KcnWbV1L18aqhGtIiIikUItcwUFBUyY8NlTXaE3OpkZ11xzTVP58uXLGTNmDM8+23za25KSEhobo0/U/9Zbb/Hqq682JXB1dXVNLYCpLJaWuXwgssko9P32+IaTnTp3yqdXRZEGQYiIiLSgtFFEBaIAACAASURBVLQU5xxbt26lU6dOTeWFhYU459i1axclJZ/N17ps2TKGDx9+xHHGjBnDk08+yY4dOwDYu3cvjz/+OAB33nknL730EuvWrWPdunXMnz8/Y1rmAHqZ2fFh3+eGlTebdtk593FcIssyJ/Yo5Z9blMyJiIjEw/Lly7n88suPKB81ahQ/+tGP+OIXv4hz3jsQfvjDH/Lqq6/inGsaCQtwwgknZFQy98cWyqO9sis3Spm04cSenXlz9U7qGxrJy23XjDEiIiISYe7cll/vfu211zabUy7kC1/4QrPvQyNlU10sydzVbW8iR+vE7p051NDIup37GOg/QyciIiLSlljezfpYMgJJllR7nVfIIH9E66qte5XMiYiISMyyrj/POfe8c25SaPRLqhjYvRQzNAhCRERE2iXrkrlU1Sk/l75VxUrmREREpF2UzKWQE3t01ohWERERaRclcynkxB6dWbdzHwfrG4IORURERNKEkrkUcmLPzjQ0Oj7eXhd0KCIiIpImlMylkEE9PhvRKiIiIhKLrEvmzGycmc1KxUkA+3ctIS/HlMyJiIjEybPPPstFF13Ek08+yfz58/nSl77E7Nmzgw4rrrIumUvVqUkACvJy6N+1hH9uqQ06FBERkZQyceJExowZ06xsyZIlmBnXX399s/K5c+dSVFTEtm3bWLhwIfPnz+eVV15h7ty5vPDCC3z88cccOHAgmeEnVNYlc6nuxJ6d+WibWuZERETCVVRUHPFqrSlTplBYWMiePc1eE8+0adOYMGEC3bt3p6CggJycHI4/3nvFfH5+PsXFxdTX1yct9kRTMpdiBvXozCc791F3MHNuMhERkaNVWVnZLJlbv349Tz31FNddd12z8oULF7J48WJuueUWAAYOHMgFF1xAY2MjF110EaNHj6ahoYHS0sx521Is72aVJBpyTBkAH27Zyxl9KwOORkREJDVEtsw9+OCDjB07lpEjR7J48eKm8gceeIBx48YxaNAgAK699lquvfbapvXf+c53khd0kiiZSzFDj/WSuQ821yiZExER8YUnczU1NcyePZv58+ezffv2pvLVq1czb948FixYEGCkyadkLsUcW96Jsk55rNxcE3QoIiKSBbb84hccXPlhUs9ZOGQwPX/yk3btU1lZSW1tLQ0NDcycOZNhw4YxatQoXn311aZn5qZNm8aIESMYPXp0IsJOWUrmUoyZMeSYMiVzIiIiYSoqKgDYuXMnM2bM4KGHHgKgrKyM6upqdu3axZw5c5gzZ06AUQZDyVwKGnpsGb97dwMNjY7cHAs6HBERyWDtbSELSmWl9+jRzJkzKS4u5rLLLgOgvLycuro6Hn74YXr06MH48eODDDMQWTeaNZUnDQ4ZckwZ+w838MlOvdZLREQEPmuZmzp1Krfeeis5OV4KU1bmPWs+bdo0br75ZnJzcwOLMShZl8yl8qTBIUOP+WwQhIiIiHzWMldQUMCECROaykOf52bGNddcE0hsQVM3awo6oUcpeTnGys01fPmUY4MOR0REJHClpaU4544oLywsjFqeTbKuZS4dFOblMqBbKSs3600QIiIi0jolcylq6LFlfPCpullFRESkdUrmUtSQYzqzpeYAu+oOBR2KiIiIpDAlcykq9FovzTcnIiIirVEyl6KUzImIiEgslMylqK6lhXTvXKjpSUREJK6yfeRnqjqan4uSuRSmQRAiIhJP+fn57N+/P+gwJIr9+/eTn5/foX2VzKWwIceUsWZ7LYfqG4MORUREMkD37t3ZtGkT+/btUwtdinDOsW/fPjZt2kT37t07dAxNGpzChhxTxuEGx+pttQw9tizocEREJM2FXn316aefcvjw4YCjkZD8/Hx69OjR9PNpr6xL5sxsHDBu4MCBQYfSptBrvVZ8Wq1kTkRE4qKsrKzDSYOkpqzrZk2Hd7OG9O9aQnFBLiv03JyIiIi0IOuSuXSSm2OcfGw572/cE3QoIiIikqKUzKW4YceVs+LTGuobNAhCREREjqRkLsWdclw5B+sb+WhbbdChiIiISApSMpfihvXynu1btrE64EhEREQkFSmZS3H9upRQ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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 256*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00342292\n",
      "Converged gradient descent: test risk: 0.00397762\n",
      "1.3578906321936013\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 122 due to early stopping\n",
      "Gradient descent: test risk last: 0.00259424; test risk early stopped: 0.00258368; train loss: 0.0021245647221803665\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q8KhUgAadqmbVUREJCgvvvgixx13HM3NzUybNo3bbrst6JDSTslchtRW+smcWuZERET6bcaMGUyePLlL2Zo1azAzLrvssi7lS5cupbKykq1bt/Lqq69SXV3NWWedxSWXXNJjl+vpp5/O5Zdfnta4M3HMeJoBIkMqSoupKC2icZeSORERkf4Kh8OsW7euS9ns2bMpLy+noaGhS/m8efOYPn06NTU1bNq0ifPOO4+7776bY489NpshZ41a5jIoXFlGQ6u6WUVERPorEonQ2NjY+Xrjxo3cf//9XHrppV3KV61axerVq7nqqqtYu3YtJ510EgAlJT23X82YMYMnnniCO+64AzPDzNiwYQPOOW655RYOPfRQKisrOeaYY7j33nu77Ltq1SpOOukkqqurqa2t5eMf/zhr167t9pjppmQug8KhUnWzioiIpEE4HO6StN16661MmTKFE044oUvL3Jw5c5g6dSpjx47lxRdfZNKkSdx1112cf/75NDV1P8LE/PnzOfnkk7nooot4//33ef/99znwwAO5/vrrufPOO7njjjt49dVX+e53v8vXvvY1Hn30UQDa2tr43Oc+xymnnMKLL77I//7v//Ltb3+b4uLibo+ZbupmzaCaylJ1s4qISE77t0de4dX3sjuM1lEH1PCvU49OaZ/YZK6pqYnFixezfPlytm3b1lm+fv16li1bxsqVKwHvSdYzzzyT8ePHc+WVVzJ9+nQefPDBhPPS1tbWUlZWRigUYsSIEYA3l+3cuXN57LHHmDRpEgAHH3wwzz33HHfccQfnnHMOTU1NNDQ0MHXqVA499FAAxo0b13nc+GNmQsElc2Y2FZh62GGHZfxc4cpSNta3Zvw8IiIiA10kEqG5uZn29nYWLlzIMcccw8SJE1mxYkVny9y8efOYMGFCZ+I1f/78zv0vvPBCLrzwwpTO+eqrr7J7927OPvvsLgngvn37GDNmDAB1dXXMmDGDs846izPPPJMzzzyTL33pSxlpgetOwSVzzrlHgEcmTJhwaabPFQ6V8tImtcyJiEjuSrWFLCjhcBiA7du3s2DBgs4hRmpqamhsbKS+vp4lS5awZMmStJ2zo6MDgEceeYTRo0d3WVdaWtr575/97GdcccUVLF++nIcffpjvf//7PPTQQ5x11llpi6UnBZfMZVM4VKZx5kRERNIgEokAsHDhQkKhEOee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amo6W+bmzZvHhAkTmDRpEgBr167l5ptv5sUXX2T+/Plcf/31APzsZz9j0aJF/Pa3v+Xll1/mySefpLi4uPNca9eu5Y033uDvf/979i+0D9QylyW1laXs3tfB7n3tVJQW976DiIhIFqTaQhaUcDgMwPbt21mwYAG33XYbADU1NTQ2NlJfX8+SJUtYsmRJ5z4vv/wyX//61wE48MADaWtro7m5mVmzZvHMM890PiBRV1fHRRdd1LnfDTfcwE033cQVV1zBO++8w4EHHpilq+wbtcxlSXTg4CbdNyciIpKySCQCwMKFCwmFQpx77rkA1NbW0tLSwu23387w4cOZNm0aAM45XnvtNcaOHUtHRwe3334755xzDr/85S854YQTOOCAAxKeZ/Xq1dTX1/OZz3yGI488kldeeSU7F9gPSuay5MMpvZTMiYiIpCraMjd37lyuvvpqioq8FKampgbwulivvPLKzu7SDRs2sHv3bk455RROOukkIpEIP/jBD1i7di3HHntst+e54YYbuPHGGwE46qijePXVVzN5WWmhbtYsCVeWAZrSS0REpC+iLXNlZWVMnz69s7y2thYAM+Piiy/uLF+7di2TJ0/moYce6nKcqqoqOjo6Ep7j6aefZsWKFZ0JXEtLS2cLYC5Ty1yWdLbMteohCBERkVRVV1fjnGPLli1UVFR0lpeXl+Oco76+nqqqqs7yl19+mfHjx+93nMmTJ3PffffxwQcfALBz507uvvtuAK6//noee+wxNmzYwIYNG1i+fHletMwpmcuS6D1zapkTERHJvO66UydOnMh3vvMdzjjjjM4nYvfu3cuKFStwznU+CQtw+OGH50Uyp27WLPnwnjm1zImIiGTa0qVLu113ySWXdBlTLuqTn/xkl9fRJ2VznVrmsqS6vITSYmOHWuZEREQkjZTMZYmZEQ6VsaNFLXMiIiKSPkrmsqguVMYOPQAhIiIiaaRkLovCoVJ2tKibVURERNJHyVwW1VWpZU5ERETSS8lcFoXVzSoiIiJppmQui+qqStnRug/nXNChiIiIyAAxIJI5M6s1s+fMrNnMPhp0PN2JhMpo73A07W4LOhQREREZIAZEMge0AucAvw46kJ5EQt78rBqeREREJDseeughPvOZz3DfffexfPlyPv3pT7N48eKgw0qrAZHMOef2Oee2BR1HbyJV3iwQum9OREQk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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 512*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00297171\n",
      "Converged gradient descent: test risk: 0.00318793\n",
      "0.9601736741337835\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 114 due to early stopping\n",
      "Gradient descent: test risk last: 0.00254917; test risk early stopped: 0.00254105; train loss: 0.002365246880799532\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnMAAAGPCAYAAAA3CFbxAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAAgAElEQVR4nO3deZydZX3w/8939i2zIJtENCgIogg+DRbQiBUVgw1atC1uIfAAitUqiz9cUFNFnwcKhLV9QrEGtNCqKLJoXMFg1SJB2RERw74EQib7NnP9/rjvM0yGmcmZmbNN5vN+vc5rMte9fc917uR8c213pJSQJEnS5FRX7QAkSZI0fiZzkiRJk5jJnCRJ0iRmMidJkjSJmcxJkiRNYiZzkiRJk5jJnCRJ0iRmMidJkjSJmcxJ24mI2D0ivhMRvRGxKiK+GxEvLdWxEfHmiEjDvFaW5x2VR0S8JCIuiohfR8S6/D3MGGHfout0IvU/xvjfk8f88jKcuyx1U+S1T8ivtzoiWoZs2zXfdup4z7+Naxd1bxdbPxHx3oi4OiIeioj1EfGHiPg/ETGtHPFLJnPSdiAi2oCfA/sAxwAfAvYCboyI9hIf+4/AwYNeby3R26iUPYG/A54Dbh5pp7HUy0TqfxxmAs+llB4s8XmhDHUzBgcAG4EOXnhPvS7/+btxnrtY27q3i6of4DSgD/gs8A7gX4GTgJ9EhN+7KrmGagcgqSROAF4O7J1SegAgIu4A/gh8GDivhMfem1L6TWnDr6glKaVdACLieODtI+w3lnqZSP2P1UzgthKeb7By1E2xDgBuATqBdwPXD9pWSOZ+P47zjsW27u1i62dOSmn5oN9/ERErgMuBN5MlwlLJ+D8EaZwioj0izoqIByJi0zBdNGXpEhrBkcBvCl+sACmlPwP/DbyrjMdOSETcHRH/FhEfiojf5V1S90TEX5Xrmiml/iJ3HUu9lLwOI6IhIr4QEcvyevlRROwO/AVlSubKVDfbFBEBvJYsWbsGmDOkBesA4OGU0oqxnruUiq2fIYlcwW/zn9NLF5GUMZmTxiH/8vku8A/A14B3Al8E+oEHga8APyj2XPkX97Ze9aOc5tXAXcOU3w3su40Qxnrsf0REX0Q8GxFXjnecVD4uam+yrqz3AV8m68KqA64Y5bhS1FcxxlIvE6n/F8jvryuBTwALyO6vu4CfAT3A0uGOqVC9QInfL1kXbQdZN+r3gZ2BQwZtfx0jdLGW+H2X5N4ewaH5z3tLeE4JsJtVGq+TgLcBh6eUfpKX/SQiDgBmAZ9PKaUiz3UocGMR+/2CrItmODuQjeMZagXZl/9oij22Fzg3j2MV2RfsZ4FfR8TrUkpPb+M6Q+0H1ANLU0rvLRTmrU+XRERrSmn9MMeVor6KMZY6nUj9D+d/A+8FDhnU7ffziDiELPF5QTJH5eoFSv9+D8h//j6l9LuIeIisq/WX+aSBVwDfHOHYUrzvUt/bW4mI6cCXgJ+mlG6dyLmk4ZjMSeNzLPCTQYlcwX3AkWNI5CD7Yj6wiP1Wb2P7cNeMImPY5rEppd+xdevILyJiCdk4p38EzijyWgWFcVBfGFK+I7BqhEQOSldfxRhLnU6k/of6NPD9YcZv3UvW8vWnYY6pZL1Aad/v64DNZC17ANeSJXOnAfvn5x1pvNyE33cZ7u0BEdFB1tq4hezfDankTOakMYqIXcgGoZ88zOYXA0+O8ZRrKG5g92gJ4nNkrSVD9TB8C0pJjk0p3RYR91Pcl+lQBwCPppTuGVL+OuCOUY4rRX0VYyz1MpH630pE7EHWEjU0yYVsvNVtI/xnoVL1AiV8v7kDyCYfbMp/vwb4eETsx7ZnspblfU/w3gYGhhJcSzZZ5NCU0qPjPZc0GsfMSWP3svznE4ML8zE5s8n+F14ouyIifp+/lkXEmmHG7hxK1iqxrdfPRonpbrJxTEPtCwxNlkp5LGStJuNJEF7H8N2Fr2P0Af6lqK9ijKVeJlqHgxUGyG/1n4KI2BV4E8PXGVSuXqC07xeyZG5wsraELCl8N9n9sCKl9PAIx5bzfY/33iYiGoGrgdcDR6SU7hzPeaRi2DInjV1hIdF9hpSfTtYysbBQkFKaCxDZwqLfBz6cUuobclwpuseuBc6JiJcX1h/Lr/kGsi670Yz72IiYCbwS+Na2w9/quDqyMXM/HFLeQ5Ysj7aeWKW6E8dSLxOp/6GeyX++mq2XsJgPtDByolvJbtaSvd+8pXtXBrWupZS2RMQNZMncaF2sUKb3Pd57Oz+2DvgP4DDgnZN8KR9NBiklX758jeFF9uVyG1n3zkeBw4FLyGay/sMw+7+KbObfG8oYUzvwAHAn2dIQRwK3k82s7Ri036FkY3fmjuPY/wDOBI4C3gKcSpZ4PAzsOGi/GWStGfNHiXeffJ93Dil/S17+2jJ/hu/NX/+aX++k/PdDx1ovY6zDYuqmnqzlazkwj2y272XA2vzYvSdL3RT5ft+R7/PmYeJIZK1q55T5PRd1b4+hfgrbzgQOGvJ6STnfi6+p+ap6AL58TcYX8FKy1ok1wDqy1eDnDLPfX+RfzAdUKKaryWbjrSYbdzRjyD5vzr9k5o3j2M+QjWXrzb9gHwEuBV48ZL9X59f4yCixHp3vM/TYU4ENQEOZ6yqN8LpprPUyxjrcZt3k++1DNrNyHVl3/qXAOfl56yZL3RR5L3w636d7SHkHsD7f9sEyv+ei7u1i6wdYNsp+88v5XnxNzVekVIqxsJKGiohDgYuB96SU7q92PJUSESeSrbP3spTSumrHU0umWt1MtfcrVYtj5qTy+Q5ZK9O3sjVg6QMOSiltrmpU5XcosMAv72FNtbqZau9Xqgpb5iRJkiYxlyaRJEmaxEzmJEmSJjGTOUmSpElsyk6A2HHHHdOMGTOqHYYkSdI2LV269JmU0k7DbZuyydyMGTO49dZbqx2GJEnSNkXEQyNts5tVkiRpEjOZkyRJmsRM5iRJkiYxkzlJkqRJzGROkiRpEpuys1klSZpq+vv7eeaZZ1i5ciV9fX3VDke5+vp6uru72XHHHamrG3s7m8mcJElTxKOPPkpEMGPGDBobG4mIaoc05aWU2Lx5M0899RSPPvooL33pS8d8DrtZJUmaItauXcv06dNpamoykasREUFTUxPTp09n7dq14zqHyZwkSVPIeLrxVH4T+Vz8RCVJkiYxkzlJkqRJzGSuTFau28SN9z3Nc2s3VTsUSZK0HTOZK5M/PLmaYxf9lnueWFXtUCRJmrKuv/56Pv7xj1c7jLIymSuT9uZs1Zc1G7dUORJJkqauO+64g/3337/aYZSVyVyZFJK5tSZzkiRVze23384BBxzAmjVrOOqoo7jooouqHVLJmcyVSXtzPQBrN7nCtiRJEzVv3jxmz569Vdltt91GRHDSSSdtVX7llVfS2trK008/zT333ENHRweHH344xx9//Khdrm9+85v52Mc+VtK4y3HOoXwCRJl02DInSVLJdHd3c//9929Vds4559Dc3MzKlSu3Kl+wYAFz586ls7OTRx99lKOPPporrriC1772tZUMuWJsmSuT1sZ6IkzmJEkqhZ6eHnp7ewd+f/jhh7n66qs54YQTtipfsmQJS5cu5ZRTTuGuu+7ioIMOAqChYfT2q3nz5vGLX/yCSy65hIggIli2bBkpJc4++2xe8YpX0Nrayn777cc3v/nNrY5dsmQJBx10EB0dHXR1dfGXf/mX3HXXXSOes9RM5sokImhvanAChCRJJdDd3b1V0nb++edzxBFHcOCBB27VMnfuuecyZ84c9t57b26//XZmzZrF5Zdfzvvf/35WrRp5hYkLLriAgw8+mGOPPZYnnniCJ554gt13350zzjiDr33ta1xyySXcc889fOYzn+HDH/4wN9xwAwBbtmzhXe96F2984xu5/fbb+Z//+R8+8YlPUF9fP+I5S81u1jJqb65n3UbHzEmSatc/XXc39zxe2WW09t2tky/OefWYjhmczK1atYrLLruMxYsXs3z58oHyBx54gOuvv56bbroJyGayHnbYYey///6cfPLJzJ07l+9973vDPpe2q6uLpqYm2tra2HXXXYHsWbbnnXceP/7xj5k1axYAe+yxB7fccguXXHIJ73znO1m1ahUrV65kzpw5vOIVrwBgn332GTjv0HOWg8lcGbU3NbBmky1zkiRNVE9PD2vWrKGvr4+FCxey3377ccghh3DjjTcOtMwtWLCAmTNnDiReF1xwwcDxxxxzDMccc8yYrnnPPfewYcMG3vGOd2yVAG7evJkZM2YAsMMOOzBv3jwOP/xwDjvsMA477DD+9m//tiwtcCMxmSuj9uYGx8xJkmraWFvIqqW7uxuAZ599lgsvvHBgiZHOzk56e3tZsWIFixYtYtGiRSW7Zn9/PwDXXXcdL33pS7fa1tjYOPDnr3/963zyk59k8eLFXHvttXzuc5/jmmuu4fDDDy9ZLKOZcslcRMwB5uy5555lv5bdrJIklUZPTw8ACxcupK2tjSOPPBLIukfXrl3LxRdfzC677MJRRx017ms0NTXR1/f89/a+++5Lc3MzDz30EG95y1tGPXb//fdn//335/TTT2f27NlcfvnlHH744S84ZzlMuWQupXQdcN3MmTNPKPe1OpobeHzlhnJfRpKk7V6hZe68887jrLPOoq4um8PZ2dkJZF2sX/rSl6ivrx/3NWbMmMEtt9zCsmXL6OjoYIcdduC0007jtNNOI6XEm970JtasWcNvfvMb6urqOPHEE/nzn//MwoULOfLII5k+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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 1024*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00272239\n",
      "Converged gradient descent: test risk: 0.00275869\n",
      "0.6789453160968006\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 114 due to early stopping\n",
      "Gradient descent: test risk last: 0.0025205; test risk early stopped: 0.00251519; train loss: 0.0024542997125536203\n"
     ]
    },
    {
     "data": {
      "image/png": "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331MnTqVww47jBNOOGGrXa7vec97OOWUU0oadznOWcwnQJRJc57MrbNlTpKkMevo6ODBBx/couyiiy6iqamJVatWbVG+YMEC5s2bR1tbG08++SRHH3001157Lfvss08lQ64YW+bKpKWQ5ckmc5IkjV1nZyddXV393z/++OPceOONnHjiiVuUL1myhKVLl3L66adzzz33cMABBwDQ0LD19qv58+fz85//nKuuuoqIICJYvnw5KSUuvPBC3vSmN9Hc3Mzee+/Nddddt8WxS5Ys4YADDmDq1Km0t7fzjne8g3vuuWfIc5aayVyZNDVkVbvWblZJksaso6Nji6Tt0ksv5fDDD2f//fffomXu4osvZu7cueyxxx7cddddzJ49m29+85scc8wxrF499AoTl112GQceeCDHHXcczzzzDM888wy77rorZ599Nl/72te46qqruO+++/j85z/PX/zFX3DrrbcCsHnzZj70oQ/xrne9i7vuuov//M//5LOf/Sz19fVDnrPU7GYtk7q6YEpjHettmZMk1bC/vfle7nu6sstozdy5jb+Z+9YRHTMwmVu9ejXXXHMNixcvZsWKFf3lDz30ELfccgu33347kM1kPfTQQ9l333057bTTmDdvHt/73vcGfS5te3s7hUKBlpYWdtxxRyB7lu0ll1zCj370I2bPng3Abrvtxh133MFVV13FEUccwerVq1m1ahVz587lTW96EwB77rln/3mLz1kOJnNl1NxY79IkkiSVQGdnJ2vWrKGnp4eFCxey9957c9BBB3Hbbbf1t8wtWLCAWbNm9Sdel112Wf/xxx57LMcee+yIrnnfffexfv16PvCBD2yRAG7atIkZM2YAMG3aNObPn89hhx3GoYceyqGHHsqf/umflqUFbigmc2XUUmhwzJwkqaaNtIWsWjo6OgB48cUXufzyy/uXGGlra6Orq4uVK1eyaNEiFi1aVLJr9vb2AnDzzTfz+te/fottjY2N/f/+xje+wamnnsrixYv5wQ9+wBe/+EVuuukmDjvssJLFsjUmc2U0pbHOljlJkkqgs7MTgIULF9LS0sKRRx4JZN2j3d3dXHnllUyfPp2jjjpq1NcoFAr09LzyuT1z5kyampp47LHHOOSQQ7Z67L777su+++7LWWedxZw5c/jmN7/JYYcd9qpzloPJXBk1F+ptmZMkqQT6WuYuueQS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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 2048*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0025987\n",
      "Converged gradient descent: test risk: 0.00261817\n",
      "0.48008683706689176\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 109 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250639; test risk early stopped: 0.00250341; train loss: 0.0023755652364343405\n"
     ]
    },
    {
     "data": {
      "image/png": "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EUccwbp161izZg1z587lda97HQB77713736r91kPIynMTQLWVpWtBV4xkBenlHY4EJ5SugK4AmDWrFlpsBUcjN7VrN2GOUmShquzs5P169fT09PDwoUL2XfffTnooIO4+eabe+fMLViwgFmzZvUGr4svvrj39cceeyzHHnvsoI5577338uKLL/KBD3xgmwDY3d3NjBkzANhpp52YP38+hx12GIceeiiHHnoof/7nf87uu+8+zDMeuJEU5tYD1X2fk4EXmlCXYWtpCYqFFnvmJEkj2mB7yJpl6tSpAKxatYpLLrmk9xIjkydPZu3ataxevZpFixaxaNGimh1z69bsO/yGG2542YheW1tb739/4xvf4HOf+xyLFy/mhz/8IV/84he5/vrrOeyww2pWl+0ZSWHuAaA1IvZMKf1XXrYfcE8T6zQsxdYWe+YkSaqBzs5OABYuXEh7eztHHnkkkA2PdnV1cdlllzF9+nSOOuqoIR+jWCzS0/PSXPd99tmHUqnEo48+ynve857tvna//fZjv/3244wzzmDOnDl885vf5LDDDnvZPuuh4WEuIlrz4xaAQkRMALaklLoi4nvAlyPieLL5bx8CDmp0HWul1NriRYMlSaqBcs/chRdeyLnnnktLSzadqbygYcGCBXz5y1+mUCgM+RgzZszgtttuY8WKFUyaNImddtqJ008/ndNPP52UEu9+97tZv349v/nNb2hpaeHEE0/kkUceYeHChRx55JHstttuPPzww9x55529177ra5/lutdKMy5NciawEfg88In8v8/Mn/sMMBF4FrgWOCmlNGp75kqtLd7OS5KkGij3zBWLRebNm9dbPmXKFAAiguOOO25Yxzj99NMpFovss88+7Lzzzjz22GN85Stf4eyzz+b888/nTW96E+973/u47rrrmDlzJgDt7e088MAD/Pmf/zlveMMbOPbYY/n4xz/OGWec0e8+ay1Squs6gBFr1qxZ6fbbb6/rMQ75x5t5y2umcsnH3lrX40iSNBD33Xcfb3zjG5tdDfVje+9PRCxLKc3q67kxcTuvkarUWrBnTpIk1dW4C3MRMTcirqi+JUg9FJ0zJ0mS6mzchbmU0g0ppRPLY+z1lC2AsGdOkiTVz7gLc41UanMBhCRJqi/DXB0VC/bMSZKk+jLM1VGpteCcOUmSVFeGuToqep05SZJUZ4a5OnIBhCRJqjfDXB25AEKSJNWbYa6OioWCPXOSJKmuxl2Ya+RFg0ttXjRYkqSRYMOGDaxevbrZ1aiLcRfmGn3R4O6exNat4/P+t5IkjRS/+MUvuOSSS5pdjboYd2GukYqtWfNu7nGoVZKk4Zg/fz5z5szZpmz58uVEBCeddNI25ddccw0TJ07k2Wef5atf/SrnnXcemzdvBuBf//VfOfbYYxtW70YwzNVRqbUAwKZuw5wkScMxdepUqqdInX/++ZRKJdasWbNN+YIFC5g3bx677LILp59+OiklPvOZz3DhhReydOlSLrjggkZWve4Mc3VU7pnb1OO8OUmShqOzs3ObMPfYY49x3XXXccIJJ2xTvnTpUpYtW8app54KwJo1a3jggQdob29n6tSpPPjggzz99NMNr389GebqqFQOc/bMSZI0LNU9cxdddBGHH344BxxwwDY9cxdccAFz585lr732AuDf//3fOfzww7nkkks47rjjOOecc/jWt77V8PrXU2uzKzCWlZwzJ0ka6f7j8/D0XY095q77wpz/PaiXVIa5devWceWVV7J48WJWrlzZW/7ggw9y4403smTJkt7XnXzyyQDceOONALztbW/jbW97Ww1OYuQwzNWRPXOSJNVGZ2cn69evp6enh4ULF7Lvvvty0EEHcfPNN/f2zC1YsIBZs2Yxe/bsl73+gx/8IB/84AcbXe2GMMzVUe8CCK81J0kaqQbZQ9YsU6dOBWDVqlVccsklXHrppQBMnjyZtWvXsnr1ahYtWsSiRYuaWMvmcM5cHfUOs3oXCEmShqWzsxOAhQsX0t7ezpFHHgnAlClT6Orq4rLLLmP69OkcddRRzaxmUxjm6qh3NathTpKkYSn3zF144YWcdtpptLRk37GTJ08GsiHWU045hUKh0LQ6Nsu4C3MNvZ1XPsxqz5wkScNT7pkrFovMmzevt7x8R6eI4LjjjmtK3Zpt3IW5Rt7Oy545SZJqY9KkSaSUeOaZZ5gwYUJvealUIqXE6tWr6ejoaGINm2fchblG6l3N6gIISZJUJ4a5Oiq1uQBCkiTVl2GujooFh1klSVJ9GebqqNTmdeYkSVJ9GebqqNwz5zCrJEmqF8NcHbUVggiHWSVJUv0Y5uooIii1ttgzJ0mS6sYwV2fFQos9c5IkqW4Mc3VWaiu4AEKSJNWNYa7OSq32zEmSpPoZd2GukfdmheyWXoY5SZJUL+MuzDXy3qwApdYCm7oNc5IkDcf8+fOZM2fONmXLly8nIjjppJO2Kb/mmmuYOHEizz77bCOr2DTjLsw1WrG1hc09hjlJkoZj6tSpVI+qnX/++ZRKJdasWbNN+YIFC5g3bx677LJLI6vYNK3NrsBYV2ptYVO3CyAkSRqOzs7ObcLcY489xnXXXceJJ57IQw891Fu+dOlSli1bxtVXX92MajaFPXN1VrJnTpKkYavumbvooos4/PDDOeCAA7bpmbvggguYO3cue+21VzOq2RT2zNVZqbWFVesNc5Kkkenc287l/tX3N/SYe++0N2e87YxBvaYyzK1bt44rr7ySxYsXs3Llyt7yBx98kBtvvJElS5YAcPHFF3Peeecxbdo0NmzYwCWXXNI77+7b3/42F198MZs2bWLr1q2ccsopHH/88b3H+9jHPsYjjzzCb37zmxqccX3ZM1dnpVavMydJ0nB1dnayfv16enp6WLhwIfvuuy8HHXQQkydP7u2ZW7BgAbNmzWL27NkA3H333Zx77rnccccdXHzxxZx55pkAfOMb3+CKK67gxz/+MXfddRe/+tWvKBQKvce6++67eeihh/iv//qvxp/oENgzV2cugJAkjWSD7SFrlqlTpwKwatUqLrnkEi699FIAJk+ezNq1a1m9ejWLFi1i0aJFva+56667+PSnPw3A7rvvzpYtW1i/fj1nn302t956a+8CiZ122olPfepTva8766yzOOecc/jc5z7H448/zu67796gsxwae+bqLFsAYZiTJGk4Ojs7AVi4cCHt7e0ceeSRAEyZMoWuri4uu+wypk+fzlFHHQVASon77ruPvfbai61bt3LZZZdxxBFH8G//9m8ccMABvPrVr+7zOMuWLWP16tW8//3v541vfCP33HNPY05wGAxzdeYCCEmShq/cM3fhhRdy2mmn0dKSRZjJkycD2RDrKaec0jtcumLFCl588UXe9a53ceCBB9LZ2cmXvvQl7r77bt7ylrf0e5yzzjqLr3zlKwDss88+3HvvvfU8rZpwmLXOivbMSZI0bOWeuWKxyLx583rLyzcBiAiOO+643vK7776bOXPmcP3112+zn46ODrZu7ft7+ZZbbuHmm2/uDXBdXV29PYAjmT1zdeYCCEmShm/SpEmklHjmmWeYMGFCb3mpVCKlxOrVq+no6Ogtv+uu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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 4096*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00255328\n",
      "Converged gradient descent: test risk: 0.00255961\n",
      "0.3394726580484003\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 109 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250216; test risk early stopped: 0.0025002; train loss: 0.002458970993757248\n"
     ]
    },
    {
     "data": {
      "image/png": "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ueYaFixYwLPPPttd/uCDDzJ//nwWLlwIwKxZs7j44ovZaaedWLduHbNnz+6ed/eNb3yDWbNmsWHDBjo7OznjjDM4+eSTu4/3kY98hIcffphf//rXgzzj4tkzV6CuYdbNhjlJkgZlwoQJrFmzho6ODubMmcP+++/PYYcdxrhx47p75mbOnMnkyZOZMmUKAHfffTcXXXQRd9xxB7NmzeLcc88F4Otf/zpXX301P/zhD7nrrru47bbbKJVK3ce6++67eeihh/jjH/9Y/xMdAHvmCuR15iRJQ9lAesgaZfz48QAsX76c2bNnc8UVVwAwbtw4Vq1axYoVK5g7dy5z587tfs1dd93FJz/5SQB22203Nm/ezJo1azj//PP51a9+1b1AYscdd+TEE0/sft15553HhRdeyOmnn86jjz7KbrvtVqezHBh75grk7bwkSaqNCRMmADBnzhzGjBnDMcccA0B7eztr167lyiuvZOedd+bYY48FIKXEfffdxz777ENnZydXXnkl73nPe/iv//ovDj74YF796lf3eJzFixezYsUK3v3ud/P617+ee+65pz4nOAiGuQKVm1zNKklSLXT1zF122WWcddZZNOWfsePGjQOyIdYzzjije7h06dKlrF+/nre+9a0ccsghTJgwgS9/+cvcfffdHHDAAb0e57zzzuOCCy4AYL/99uPee+8t8rRqwmHWAjU1Bc1NYZiTJGmQunrmWlpamD59end516XGIoKTTjqpu/zuu+9m6tSp3HjjjVvsZ4cddqCzs+fP5V/+8pfceuut3QFu7dq13T2AQ5k9cwUrl5qcMydJ0iC1tbWRUuLpp59m1KhR3eWtra2klFixYgU77LBDd/ldd93FgQce+LL9TJ06leuvv57nnnsOgBdeeIHrrrsOgHPPPZdbbrmFpUuXsnTpUhYsWDAseuYMcwUrl4KNm+2ZkySpnnobTj3ssMP43Oc+x+GHH969Inbjxo3ceuutpJS6V8IC7L333sMizDnMWrCW5iaHWSVJqrN58+b1+tzJJ5+8xTXluvzFX/zFFl93rZQd6uyZK1g2zGqYkyRJxTDMFcw5c5IkqUiGuYKVS+F15iRJUmEMcwUrl5rY5AIISZJUEMNcwZwzJ0mSimSYK1i5FM6ZkyRJhTHMFaxcanLOnCRJKoxhrmBeZ06SJBXJMFcw58xJktQ4N954I+9+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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 8192*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00252079\n",
      "Converged gradient descent: test risk: 0.00252528\n",
      "0.24004341853344588\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 105 due to early stopping\n",
      "Gradient descent: test risk last: 0.0024979; test risk early stopped: 0.00249688; train loss: 0.0024731773883104324\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*****training size (N) = 16384*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00250841\n",
      "Converged gradient descent: test risk: 0.00251053\n",
      "0.16973632902420016\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 104 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249603; test risk early stopped: 0.00249543; train loss: 0.002505565993487835\n"
     ]
    },
    {
     "data": {
      "image/png": "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XsqRRx7JgQceuFHL3CWXXMLEiRPZc889W1HNlrBlrkDlzpY575mTJG19Lrz7Qh5Z8khT97nXdntx9rvO7vX7asPcsmXLuOqqq5g9ezaLFi3qLH/ssceYNWsWc+bMAWDatGlcdNFFbL/99qxcuZLp06d33nf3ve99j2nTprF69WrWr1/P6aefzoknnti5v09/+tP8+c9/5q677urjERfPlrkCtZWdmkSSpEZob29n+fLlrFu3jhkzZrDPPvtw8MEHM3LkyM6WualTp3LAAQcwfvx4AB544AEuvPBC7r33XqZNm8Y555wDwHe/+12uvPJKfvrTn3L//ffz61//mnK53LmvBx54gMcff5z//u//bv6BbgFb5gpULlW7WW2ZkyRtfbakhaxVRo8eDcDixYuZPn06l112GQAjR46ko6ODJUuWMHPmTGbOnNn5nvvvv58vfOELAOy8886sXbuW5cuXc95553HnnXd2DpDYbrvtOP744zvfd+6553LBBRdw2mmn8dRTT7Hzzjs36Si3jC1zBWpzAIQkSQ3R3t4OwIwZMxg+fDhHHXUUAKNGjWLFihVcfvnljBkzhqOPPhqAlBIPP/wwe+65J+vXr+fyyy/nIx/5CD/4wQ848MADectb3tLlfubNm8eSJUs4/PDDecc73sGDDz7YnAPsA8NcgRwAIUlSY1Rb5qZMmcKZZ55JKe/9GjlyJJB1sZ5++umd3aULFixg1apVvO997+M973kP7e3tfOMb3+CBBx5g33337XY/5557Lueffz4Ae++9Nw899FCRh9UQdrMWqOIACEmSGqLaMjdkyBAmTZrUWT5q1CgAIoITTjihs/yBBx5gwoQJ3HzzzRttZ9ttt2V9N7c//fa3v+WOO+7oDHArVqzobAHcmtkyVyAnDZYkqTFGjBhBSokXXniBbbbZprN86NChpJRYsmQJ2267bWf5/fffz3777fe67UyYMIHrr7+el156CYBXXnmFa665BoBzzjmH2267jQULFrBgwQJmz57dL1rmDHMFKnvPnCRJLdFdd+rBBx/M3//933PooYd2joh97bXXuOOOO0gpdY6EBdh99937RZizm7VAbfk9c2sdzSpJUlNdd9113b524oknbjSnXNVf/dVfbfRzdaTs1s6WuQJVW+acZ06SJBXFMFegtnykzVq7WSVJUkEMcwXaMADCblZJklQM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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "**********run 1**********\n",
      "*****training size (N) = 1*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.82524019\n",
      "Converged gradient descent: test risk: 0.90046526\n",
      "21.72625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 101 due to convergence\n",
      "Gradient descent: test risk last: 0.90046531; test risk early stopped: 0.90046531; train loss: 0.0\n",
      "\n",
      "\n",
      "*****training size (N) = 2*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.7264449\n",
      "Converged gradient descent: test risk: 0.80101234\n",
      "15.362778786140536\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 119 due to convergence\n",
      "Gradient descent: test risk last: 0.80101234; test risk early stopped: 0.80101234; train loss: 6.086087897721798e-16\n",
      "\n",
      "\n",
      "*****training size (N) = 4*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.5937092\n",
      "Converged gradient descent: test risk: 0.6057579\n",
      "10.86312505754881\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 365 due to early stopping\n",
      "Gradient descent: test risk last: 0.60575807; test risk early stopped: 0.60575789; train loss: 8.696898588659088e-14\n",
      "\n",
      "\n",
      "*****training size (N) = 8*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.27538985\n",
      "Converged gradient descent: test risk: 0.23095874\n",
      "7.681389393070268\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Stopped at iteration 1421 due to early stopping\n",
      "Gradient descent: test risk last: 0.23096009; test risk early stopped: 0.23096006; train loss: 4.561246779583028e-12\n",
      "\n",
      "\n",
      "*****training size (N) = 10*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.1363569\n",
      "Converged gradient descent: test risk: 0.09962164\n",
      "6.870443537820389\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Iteration : 2600/5000\n",
      "Iteration : 2700/5000\n",
      "Iteration : 2800/5000\n",
      "Stopped at iteration 2818 due to early stopping\n",
      "Gradient descent: test risk last: 0.09962326; test risk early stopped: 0.09962326; train loss: 1.9935539330440122e-11\n",
      "\n",
      "\n",
      "*****training size (N) = 12*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.13301206\n",
      "Converged gradient descent: test risk: 0.08230063\n",
      "6.271828176216375\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Iteration : 2600/5000\n",
      "Stopped at iteration 2667 due to early stopping\n",
      "Gradient descent: test risk last: 0.08230179; test risk early stopped: 0.08230179; train loss: 3.064737796876216e-08\n",
      "\n",
      "\n",
      "*****training size (N) = 14*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.05822665\n",
      "Converged gradient descent: test risk: 0.01849198\n",
      "5.806584587860943\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Stopped at iteration 2491 due to early stopping\n",
      "Gradient descent: test risk last: 0.0184933; test risk early stopped: 0.0184933; train loss: 6.575778854767123e-08\n",
      "\n",
      "\n",
      "*****training size (N) = 16*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.03752175\n",
      "Converged gradient descent: test risk: 0.00717543\n",
      "5.431562528774405\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Stopped at iteration 744 due to early stopping\n",
      "Gradient descent: test risk last: 0.00702757; test risk early stopped: 0.00701993; train loss: 5.986979158478789e-05\n",
      "\n",
      "\n",
      "*****training size (N) = 18*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02560568\n",
      "Converged gradient descent: test risk: 0.0071388\n",
      "5.120926262046845\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Stopped at iteration 474 due to early stopping\n",
      "Gradient descent: test risk last: 0.00691989; test risk early stopped: 0.00690853; train loss: 0.0002141539880540222\n",
      "\n",
      "\n",
      "*****training size (N) = 22*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02166587\n",
      "Converged gradient descent: test risk: 0.00580951\n",
      "4.632052088259977\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 285 due to early stopping\n",
      "Gradient descent: test risk last: 0.00514063; test risk early stopped: 0.00511703; train loss: 0.0006548386882059276\n",
      "\n",
      "\n",
      "*****training size (N) = 24*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02403619\n",
      "Converged gradient descent: test risk: 0.00713275\n",
      "4.434852233839456\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Stopped at iteration 476 due to early stopping\n",
      "Gradient descent: test risk last: 0.00660593; test risk early stopped: 0.00658365; train loss: 0.00033128622453659773\n",
      "\n",
      "\n",
      "*****training size (N) = 30*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01437503\n",
      "Converged gradient descent: test risk: 0.00525959\n",
      "3.9666524260127263\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 244 due to early stopping\n",
      "Gradient descent: test risk last: 0.00399878; test risk early stopped: 0.00397577; train loss: 0.0009437921107746661\n",
      "\n",
      "\n",
      "*****training size (N) = 36*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01204163\n",
      "Converged gradient descent: test risk: 0.00492298\n",
      "3.6210416858496033\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 215 due to early stopping\n",
      "Gradient descent: test risk last: 0.00374552; test risk early stopped: 0.00370949; train loss: 0.0009525125497020781\n",
      "\n",
      "\n",
      "*****training size (N) = 44*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01018365\n",
      "Converged gradient descent: test risk: 0.00550072\n",
      "3.2753554424179376\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 229 due to early stopping\n",
      "Gradient descent: test risk last: 0.00339895; test risk early stopped: 0.00338438; train loss: 0.001199729973450303\n",
      "\n",
      "\n",
      "*****training size (N) = 64*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00603267\n",
      "Converged gradient descent: test risk: 0.00699808\n",
      "2.7157812643872026\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 142 due to early stopping\n",
      "Gradient descent: test risk last: 0.00306259; test risk early stopped: 0.00303098; train loss: 0.0015774548519402742\n",
      "\n",
      "\n",
      "*****training size (N) = 100*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0053286\n",
      "Converged gradient descent: test risk: 8.31170911\n",
      "2.172625011509762\n",
      "Iteration : 0/5000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration : 100/5000\n",
      "Stopped at iteration 136 due to early stopping\n",
      "Gradient descent: test risk last: 0.00282746; test risk early stopped: 0.00280388; train loss: 0.0018327170982956886\n",
      "\n",
      "\n",
      "*****training size (N) = 256*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00337343\n",
      "Converged gradient descent: test risk: 0.00408258\n",
      "1.3578906321936013\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 122 due to early stopping\n",
      "Gradient descent: test risk last: 0.00260025; test risk early stopped: 0.00258919; train loss: 0.002142146462574601\n",
      "\n",
      "\n",
      "*****training size (N) = 512*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00291302\n",
      "Converged gradient descent: test risk: 0.00310608\n",
      "0.9601736741337835\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 118 due to early stopping\n",
      "Gradient descent: test risk last: 0.00255278; test risk early stopped: 0.00254416; train loss: 0.0023275278508663177\n",
      "\n",
      "\n",
      "*****training size (N) = 1024*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00270176\n",
      "Converged gradient descent: test risk: 0.00277145\n",
      "0.6789453160968006\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 109 due to early stopping\n",
      "Gradient descent: test risk last: 0.00252511; test risk early stopped: 0.00252004; train loss: 0.002398691140115261\n",
      "\n",
      "\n",
      "*****training size (N) = 2048*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00260623\n",
      "Converged gradient descent: test risk: 0.00262372\n",
      "0.48008683706689176\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 108 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250753; test risk early stopped: 0.00250454; train loss: 0.0024524580221623182\n",
      "\n",
      "\n",
      "*****training size (N) = 4096*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0025496\n",
      "Converged gradient descent: test risk: 0.00255357\n",
      "0.3394726580484003\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 106 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250025; test risk early stopped: 0.00249853; train loss: 0.0024805825669318438\n",
      "\n",
      "\n",
      "*****training size (N) = 8192*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00252232\n",
      "Converged gradient descent: test risk: 0.00252472\n",
      "0.24004341853344588\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 105 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249842; test risk early stopped: 0.00249746; train loss: 0.002492771251127124\n",
      "\n",
      "\n",
      "*****training size (N) = 16384*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00250723\n",
      "Converged gradient descent: test risk: 0.00250957\n",
      "0.16973632902420016\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 105 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249611; test risk early stopped: 0.00249556; train loss: 0.0024780717212706804\n",
      "\n",
      "\n",
      "**********run 2**********\n",
      "*****training size (N) = 1*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.82375524\n",
      "Converged gradient descent: test risk: 0.90033608\n",
      "21.72625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 101 due to convergence\n",
      "Gradient descent: test risk last: 0.90033609; test risk early stopped: 0.90033609; train loss: 0.0\n",
      "\n",
      "\n",
      "*****training size (N) = 2*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.75488966\n",
      "Converged gradient descent: test risk: 0.80205154\n",
      "15.362778786140536\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 186 due to early stopping\n",
      "Gradient descent: test risk last: 0.80205148; test risk early stopped: 0.80205148; train loss: 1.048434851034976e-14\n",
      "\n",
      "\n",
      "*****training size (N) = 4*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.57205274\n",
      "Converged gradient descent: test risk: 0.60326234\n",
      "10.86312505754881\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 239 due to early stopping\n",
      "Gradient descent: test risk last: 0.60326236; test risk early stopped: 0.60326236; train loss: 8.303259846993618e-15\n",
      "\n",
      "\n",
      "*****training size (N) = 8*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.28103332\n",
      "Converged gradient descent: test risk: 0.22640061\n",
      "7.681389393070268\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Stopped at iteration 1522 due to early stopping\n",
      "Gradient descent: test risk last: 0.22640224; test risk early stopped: 0.22640224; train loss: 8.789646961659958e-12\n",
      "\n",
      "\n",
      "*****training size (N) = 10*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.14121749\n",
      "Converged gradient descent: test risk: 0.0688715\n",
      "6.870443537820389\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Iteration : 2600/5000\n",
      "Iteration : 2700/5000\n",
      "Iteration : 2800/5000\n",
      "Stopped at iteration 2847 due to early stopping\n",
      "Gradient descent: test risk last: 0.0688731; test risk early stopped: 0.0688731; train loss: 2.6291590432547807e-12\n",
      "\n",
      "\n",
      "*****training size (N) = 12*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.09247388\n",
      "Converged gradient descent: test risk: 0.02796021\n",
      "6.271828176216375\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Stopped at iteration 1088 due to early stopping\n",
      "Gradient descent: test risk last: 0.02779783; test risk early stopped: 0.02779191; train loss: 7.866877240303438e-06\n",
      "\n",
      "\n",
      "*****training size (N) = 14*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.05531658\n",
      "Converged gradient descent: test risk: 0.0123936\n",
      "5.806584587860943\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Stopped at iteration 815 due to early stopping\n",
      "Gradient descent: test risk last: 0.0122901; test risk early stopped: 0.01228249; train loss: 2.0198393031023443e-05\n",
      "\n",
      "\n",
      "*****training size (N) = 16*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02117832\n",
      "Converged gradient descent: test risk: 0.00510384\n",
      "5.431562528774405\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 263 due to early stopping\n",
      "Gradient descent: test risk last: 0.00489565; test risk early stopped: 0.00488254; train loss: 0.0003502952167764306\n",
      "\n",
      "\n",
      "*****training size (N) = 18*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.03490302\n",
      "Converged gradient descent: test risk: 0.00740407\n",
      "5.120926262046845\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Stopped at iteration 512 due to early stopping\n",
      "Gradient descent: test risk last: 0.00691258; test risk early stopped: 0.00688266; train loss: 0.0001676071115070954\n",
      "\n",
      "\n",
      "*****training size (N) = 22*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02564901\n",
      "Converged gradient descent: test risk: 0.00804923\n",
      "4.632052088259977\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Stopped at iteration 500 due to early stopping\n",
      "Gradient descent: test risk last: 0.00713105; test risk early stopped: 0.00709355; train loss: 0.0004118114011362195\n",
      "\n",
      "\n",
      "*****training size (N) = 24*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01843648\n",
      "Converged gradient descent: test risk: 0.00510196\n",
      "4.434852233839456\n",
      "Iteration : 0/5000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 277 due to early stopping\n",
      "Gradient descent: test risk last: 0.00439218; test risk early stopped: 0.00434497; train loss: 0.0005835749907419086\n",
      "\n",
      "\n",
      "*****training size (N) = 30*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01450643\n",
      "Converged gradient descent: test risk: 0.00479063\n",
      "3.9666524260127263\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 232 due to early stopping\n",
      "Gradient descent: test risk last: 0.00396451; test risk early stopped: 0.00394901; train loss: 0.0008453420014120638\n",
      "\n",
      "\n",
      "*****training size (N) = 36*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01042821\n",
      "Converged gradient descent: test risk: 0.00561299\n",
      "3.6210416858496033\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 173 due to early stopping\n",
      "Gradient descent: test risk last: 0.00374699; test risk early stopped: 0.00369796; train loss: 0.0013319167774170637\n",
      "\n",
      "\n",
      "*****training size (N) = 44*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00843449\n",
      "Converged gradient descent: test risk: 0.00504514\n",
      "3.2753554424179376\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 188 due to early stopping\n",
      "Gradient descent: test risk last: 0.00345114; test risk early stopped: 0.00343964; train loss: 0.0012020489666610956\n",
      "\n",
      "\n",
      "*****training size (N) = 64*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00770646\n",
      "Converged gradient descent: test risk: 0.00831533\n",
      "2.7157812643872026\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 177 due to early stopping\n",
      "Gradient descent: test risk last: 0.00303143; test risk early stopped: 0.00300616; train loss: 0.001608353340998292\n",
      "\n",
      "\n",
      "*****training size (N) = 100*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00491669\n",
      "Converged gradient descent: test risk: 2.19983109\n",
      "2.172625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 141 due to early stopping\n",
      "Gradient descent: test risk last: 0.0027477; test risk early stopped: 0.00272563; train loss: 0.0018700115615502\n",
      "\n",
      "\n",
      "*****training size (N) = 256*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00335778\n",
      "Converged gradient descent: test risk: 0.00408579\n",
      "1.3578906321936013\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 123 due to early stopping\n",
      "Gradient descent: test risk last: 0.00258997; test risk early stopped: 0.00257818; train loss: 0.002214893000200391\n",
      "\n",
      "\n",
      "*****training size (N) = 512*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0029221\n",
      "Converged gradient descent: test risk: 0.00309349\n",
      "0.9601736741337835\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 117 due to early stopping\n",
      "Gradient descent: test risk last: 0.00255467; test risk early stopped: 0.00254618; train loss: 0.0023738618474453688\n",
      "\n",
      "\n",
      "*****training size (N) = 1024*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00272987\n",
      "Converged gradient descent: test risk: 0.0027611\n",
      "0.6789453160968006\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 110 due to early stopping\n",
      "Gradient descent: test risk last: 0.00252055; test risk early stopped: 0.00251575; train loss: 0.002363559789955616\n",
      "\n",
      "\n",
      "*****training size (N) = 2048*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00259425\n",
      "Converged gradient descent: test risk: 0.00261548\n",
      "0.48008683706689176\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250753; test risk early stopped: 0.00250455; train loss: 0.0024807718582451344\n",
      "\n",
      "\n",
      "*****training size (N) = 4096*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00254937\n",
      "Converged gradient descent: test risk: 0.00255701\n",
      "0.3394726580484003\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 106 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250181; test risk early stopped: 0.00250002; train loss: 0.0024768272414803505\n",
      "\n",
      "\n",
      "*****training size (N) = 8192*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00252117\n",
      "Converged gradient descent: test risk: 0.00252225\n",
      "0.24004341853344588\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249777; test risk early stopped: 0.00249687; train loss: 0.002477157860994339\n",
      "\n",
      "\n",
      "*****training size (N) = 16384*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00250829\n",
      "Converged gradient descent: test risk: 0.00250896\n",
      "0.16973632902420016\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 106 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249557; test risk early stopped: 0.00249501; train loss: 0.0024792233016341925\n",
      "\n",
      "\n",
      "**********run 3**********\n",
      "*****training size (N) = 1*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.81093514\n",
      "Converged gradient descent: test risk: 0.90055459\n",
      "21.72625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 101 due to convergence\n",
      "Gradient descent: test risk last: 0.90055448; test risk early stopped: 0.90055448; train loss: 0.0\n",
      "\n",
      "\n",
      "*****training size (N) = 2*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.74691684\n",
      "Converged gradient descent: test risk: 0.80132622\n",
      "15.362778786140536\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 191 due to early stopping\n",
      "Gradient descent: test risk last: 0.80132627; test risk early stopped: 0.80132627; train loss: 1.2636552503171583e-14\n",
      "\n",
      "\n",
      "*****training size (N) = 4*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.57031789\n",
      "Converged gradient descent: test risk: 0.60202427\n",
      "10.86312505754881\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 217 due to early stopping\n",
      "Gradient descent: test risk last: 0.60202438; test risk early stopped: 0.60202426; train loss: 2.6214892141275016e-14\n",
      "\n",
      "\n",
      "*****training size (N) = 8*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.23952537\n",
      "Converged gradient descent: test risk: 0.21100159\n",
      "7.681389393070268\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Stopped at iteration 674 due to early stopping\n",
      "Gradient descent: test risk last: 0.21100166; test risk early stopped: 0.21100166; train loss: 7.906029888919697e-13\n",
      "\n",
      "\n",
      "*****training size (N) = 10*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.19748678\n",
      "Converged gradient descent: test risk: 0.14304231\n",
      "6.870443537820389\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Stopped at iteration 2249 due to early stopping\n",
      "Gradient descent: test risk last: 0.14304647; test risk early stopped: 0.14304647; train loss: 3.401672055147742e-09\n",
      "\n",
      "\n",
      "*****training size (N) = 12*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.06634879\n",
      "Converged gradient descent: test risk: 0.02519546\n",
      "6.271828176216375\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Iteration : 2600/5000\n",
      "Iteration : 2700/5000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Stopped at iteration 2772 due to early stopping\n",
      "Gradient descent: test risk last: 0.02519603; test risk early stopped: 0.02519603; train loss: 1.2966526463653594e-10\n",
      "\n",
      "\n",
      "*****training size (N) = 14*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.07356577\n",
      "Converged gradient descent: test risk: 0.02801091\n",
      "5.806584587860943\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Iteration : 2600/5000\n",
      "Iteration : 2700/5000\n",
      "Iteration : 2800/5000\n",
      "Iteration : 2900/5000\n",
      "Iteration : 3000/5000\n",
      "Iteration : 3100/5000\n",
      "Iteration : 3200/5000\n",
      "Iteration : 3300/5000\n",
      "Iteration : 3400/5000\n",
      "Iteration : 3500/5000\n",
      "Stopped at iteration 3550 due to early stopping\n",
      "Gradient descent: test risk last: 0.02801265; test risk early stopped: 0.02801265; train loss: 2.0134958145234805e-09\n",
      "\n",
      "\n",
      "*****training size (N) = 16*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.05020701\n",
      "Converged gradient descent: test risk: 0.01204246\n",
      "5.431562528774405\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Stopped at iteration 812 due to early stopping\n",
      "Gradient descent: test risk last: 0.01185198; test risk early stopped: 0.01184303; train loss: 4.3363073928048834e-05\n",
      "\n",
      "\n",
      "*****training size (N) = 18*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.04333969\n",
      "Converged gradient descent: test risk: 0.01144177\n",
      "5.120926262046845\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Stopped at iteration 769 due to early stopping\n",
      "Gradient descent: test risk last: 0.01122707; test risk early stopped: 0.01121681; train loss: 5.2107006922597066e-05\n",
      "\n",
      "\n",
      "*****training size (N) = 22*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02345545\n",
      "Converged gradient descent: test risk: 0.00561739\n",
      "4.632052088259977\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 375 due to early stopping\n",
      "Gradient descent: test risk last: 0.00526745; test risk early stopped: 0.00525522; train loss: 0.00035619267146103084\n",
      "\n",
      "\n",
      "*****training size (N) = 24*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01920232\n",
      "Converged gradient descent: test risk: 0.00558201\n",
      "4.434852233839456\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 326 due to early stopping\n",
      "Gradient descent: test risk last: 0.00471866; test risk early stopped: 0.00470733; train loss: 0.0006362417479977012\n",
      "\n",
      "\n",
      "*****training size (N) = 30*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.018484\n",
      "Converged gradient descent: test risk: 0.00548667\n",
      "3.9666524260127263\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 309 due to early stopping\n",
      "Gradient descent: test risk last: 0.00433257; test risk early stopped: 0.00429433; train loss: 0.0007134252809919417\n",
      "\n",
      "\n",
      "*****training size (N) = 36*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01004759\n",
      "Converged gradient descent: test risk: 0.0047885\n",
      "3.6210416858496033\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 181 due to early stopping\n",
      "Gradient descent: test risk last: 0.00337965; test risk early stopped: 0.00335971; train loss: 0.0011188124772161245\n",
      "\n",
      "\n",
      "*****training size (N) = 44*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00912671\n",
      "Converged gradient descent: test risk: 0.00531495\n",
      "3.2753554424179376\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 184 due to early stopping\n",
      "Gradient descent: test risk last: 0.00343767; test risk early stopped: 0.00340392; train loss: 0.0013250255724415183\n",
      "\n",
      "\n",
      "*****training size (N) = 64*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00627754\n",
      "Converged gradient descent: test risk: 0.00717516\n",
      "2.7157812643872026\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 180 due to early stopping\n",
      "Gradient descent: test risk last: 0.00309833; test risk early stopped: 0.00308325; train loss: 0.0015319762751460075\n",
      "\n",
      "\n",
      "*****training size (N) = 100*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00499334\n",
      "Converged gradient descent: test risk: 0.27023129\n",
      "2.172625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 138 due to early stopping\n",
      "Gradient descent: test risk last: 0.00276667; test risk early stopped: 0.0027502; train loss: 0.002024407498538494\n",
      "\n",
      "\n",
      "*****training size (N) = 256*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00342064\n",
      "Converged gradient descent: test risk: 0.00431199\n",
      "1.3578906321936013\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 121 due to early stopping\n",
      "Gradient descent: test risk last: 0.00260612; test risk early stopped: 0.00259448; train loss: 0.0021839295513927937\n",
      "\n",
      "\n",
      "*****training size (N) = 512*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00295839\n",
      "Converged gradient descent: test risk: 0.00310512\n",
      "0.9601736741337835\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 111 due to early stopping\n",
      "Gradient descent: test risk last: 0.00254848; test risk early stopped: 0.00254087; train loss: 0.002290873322635889\n",
      "\n",
      "\n",
      "*****training size (N) = 1024*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00270522\n",
      "Converged gradient descent: test risk: 0.00277188\n",
      "0.6789453160968006\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 113 due to early stopping\n",
      "Gradient descent: test risk last: 0.00252379; test risk early stopped: 0.00251846; train loss: 0.0024158908054232597\n",
      "\n",
      "\n",
      "*****training size (N) = 2048*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00260478\n",
      "Converged gradient descent: test risk: 0.00262133\n",
      "0.48008683706689176\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 110 due to early stopping\n",
      "Gradient descent: test risk last: 0.00251118; test risk early stopped: 0.00250814; train loss: 0.002424784703180194\n",
      "\n",
      "\n",
      "*****training size (N) = 4096*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00254756\n",
      "Converged gradient descent: test risk: 0.00255525\n",
      "0.3394726580484003\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250183; test risk early stopped: 0.00250006; train loss: 0.002467478858307004\n",
      "\n",
      "\n",
      "*****training size (N) = 8192*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00252084\n",
      "Converged gradient descent: test risk: 0.00252641\n",
      "0.24004341853344588\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249813; test risk early stopped: 0.00249708; train loss: 0.00247595296241343\n",
      "\n",
      "\n",
      "*****training size (N) = 16384*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0025071\n",
      "Converged gradient descent: test risk: 0.0025088\n",
      "0.16973632902420016\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 104 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249571; test risk early stopped: 0.00249518; train loss: 0.0024767236318439245\n",
      "\n",
      "\n",
      "**********run 4**********\n",
      "*****training size (N) = 1*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.82864318\n",
      "Converged gradient descent: test risk: 0.90151357\n",
      "21.72625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 102 due to convergence\n",
      "Gradient descent: test risk last: 0.90151358; test risk early stopped: 0.90151358; train loss: 4.701924782954826e-15\n",
      "\n",
      "\n",
      "*****training size (N) = 2*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.72170273\n",
      "Converged gradient descent: test risk: 0.80079298\n",
      "15.362778786140536\n",
      "Iteration : 0/5000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration : 100/5000\n",
      "Stopped at iteration 136 due to early stopping\n",
      "Gradient descent: test risk last: 0.80079287; test risk early stopped: 0.80079287; train loss: 3.0984249217160757e-15\n",
      "\n",
      "\n",
      "*****training size (N) = 4*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.59051656\n",
      "Converged gradient descent: test risk: 0.60416276\n",
      "10.86312505754881\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 339 due to early stopping\n",
      "Gradient descent: test risk last: 0.60416287; test risk early stopped: 0.60416287; train loss: 3.6692969219683305e-14\n",
      "\n",
      "\n",
      "*****training size (N) = 8*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.25771311\n",
      "Converged gradient descent: test risk: 0.22622603\n",
      "7.681389393070268\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Stopped at iteration 1145 due to early stopping\n",
      "Gradient descent: test risk last: 0.22622691; test risk early stopped: 0.22622691; train loss: 1.4878413171631744e-12\n",
      "\n",
      "\n",
      "*****training size (N) = 10*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.17328757\n",
      "Converged gradient descent: test risk: 0.12955654\n",
      "6.870443537820389\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Stopped at iteration 1198 due to early stopping\n",
      "Gradient descent: test risk last: 0.12954552; test risk early stopped: 0.129545; train loss: 8.200722589890574e-08\n",
      "\n",
      "\n",
      "*****training size (N) = 12*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.10471483\n",
      "Converged gradient descent: test risk: 0.04906823\n",
      "6.271828176216375\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Iteration : 1000/5000\n",
      "Iteration : 1100/5000\n",
      "Iteration : 1200/5000\n",
      "Iteration : 1300/5000\n",
      "Iteration : 1400/5000\n",
      "Iteration : 1500/5000\n",
      "Iteration : 1600/5000\n",
      "Iteration : 1700/5000\n",
      "Iteration : 1800/5000\n",
      "Iteration : 1900/5000\n",
      "Iteration : 2000/5000\n",
      "Iteration : 2100/5000\n",
      "Iteration : 2200/5000\n",
      "Iteration : 2300/5000\n",
      "Iteration : 2400/5000\n",
      "Iteration : 2500/5000\n",
      "Stopped at iteration 2504 due to early stopping\n",
      "Gradient descent: test risk last: 0.04906965; test risk early stopped: 0.04906965; train loss: 8.404090756641835e-09\n",
      "\n",
      "\n",
      "*****training size (N) = 14*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.05761026\n",
      "Converged gradient descent: test risk: 0.01511397\n",
      "5.806584587860943\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Iteration : 900/5000\n",
      "Stopped at iteration 964 due to early stopping\n",
      "Gradient descent: test risk last: 0.01505968; test risk early stopped: 0.01505721; train loss: 1.9530414647306316e-05\n",
      "\n",
      "\n",
      "*****training size (N) = 16*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.04522455\n",
      "Converged gradient descent: test risk: 0.00948748\n",
      "5.431562528774405\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Stopped at iteration 453 due to early stopping\n",
      "Gradient descent: test risk last: 0.00919315; test risk early stopped: 0.0091657; train loss: 0.00012615449668373913\n",
      "\n",
      "\n",
      "*****training size (N) = 18*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.03555355\n",
      "Converged gradient descent: test risk: 0.00708451\n",
      "5.120926262046845\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Iteration : 400/5000\n",
      "Iteration : 500/5000\n",
      "Iteration : 600/5000\n",
      "Iteration : 700/5000\n",
      "Iteration : 800/5000\n",
      "Stopped at iteration 818 due to early stopping\n",
      "Gradient descent: test risk last: 0.00691729; test risk early stopped: 0.00691547; train loss: 0.00011307856038911268\n",
      "\n",
      "\n",
      "*****training size (N) = 22*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.02427767\n",
      "Converged gradient descent: test risk: 0.00665238\n",
      "4.632052088259977\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 343 due to early stopping\n",
      "Gradient descent: test risk last: 0.00623119; test risk early stopped: 0.00620972; train loss: 0.0004174385976511985\n",
      "\n",
      "\n",
      "*****training size (N) = 24*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01881767\n",
      "Converged gradient descent: test risk: 0.00591698\n",
      "4.434852233839456\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Iteration : 300/5000\n",
      "Stopped at iteration 351 due to early stopping\n",
      "Gradient descent: test risk last: 0.0051834; test risk early stopped: 0.00515222; train loss: 0.0005217625293880701\n",
      "\n",
      "\n",
      "*****training size (N) = 30*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01285879\n",
      "Converged gradient descent: test risk: 0.00508467\n",
      "3.9666524260127263\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Iteration : 200/5000\n",
      "Stopped at iteration 233 due to early stopping\n",
      "Gradient descent: test risk last: 0.00387025; test risk early stopped: 0.00384679; train loss: 0.0010711257345974445\n",
      "\n",
      "\n",
      "*****training size (N) = 36*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.01040644\n",
      "Converged gradient descent: test risk: 0.00466569\n",
      "3.6210416858496033\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 195 due to early stopping\n",
      "Gradient descent: test risk last: 0.00348477; test risk early stopped: 0.003462; train loss: 0.0009473699028603733\n",
      "\n",
      "\n",
      "*****training size (N) = 44*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0092798\n",
      "Converged gradient descent: test risk: 0.00521138\n",
      "3.2753554424179376\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 149 due to early stopping\n",
      "Gradient descent: test risk last: 0.00330461; test risk early stopped: 0.00326081; train loss: 0.0014428901486098766\n",
      "\n",
      "\n",
      "*****training size (N) = 64*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00696139\n",
      "Converged gradient descent: test risk: 0.00760156\n",
      "2.7157812643872026\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 177 due to early stopping\n",
      "Gradient descent: test risk last: 0.00316396; test risk early stopped: 0.00314469; train loss: 0.001536372466944158\n",
      "\n",
      "\n",
      "*****training size (N) = 100*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00484993\n",
      "Converged gradient descent: test risk: 6.08874006\n",
      "2.172625011509762\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 140 due to early stopping\n",
      "Gradient descent: test risk last: 0.00282314; test risk early stopped: 0.0028064; train loss: 0.0019769142381846905\n",
      "\n",
      "\n",
      "*****training size (N) = 256*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.0033471\n",
      "Converged gradient descent: test risk: 0.00401575\n",
      "1.3578906321936013\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 131 due to early stopping\n",
      "Gradient descent: test risk last: 0.00263127; test risk early stopped: 0.00262091; train loss: 0.0022130839060992002\n",
      "\n",
      "\n",
      "*****training size (N) = 512*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00291955\n",
      "Converged gradient descent: test risk: 0.00310481\n",
      "0.9601736741337835\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 116 due to early stopping\n",
      "Gradient descent: test risk last: 0.00255256; test risk early stopped: 0.00254494; train loss: 0.002365086693316698\n",
      "\n",
      "\n",
      "*****training size (N) = 1024*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00273286\n",
      "Converged gradient descent: test risk: 0.00274854\n",
      "0.6789453160968006\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 112 due to early stopping\n",
      "Gradient descent: test risk last: 0.00252261; test risk early stopped: 0.00251804; train loss: 0.002419580239802599\n",
      "\n",
      "\n",
      "*****training size (N) = 2048*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00261229\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Converged gradient descent: test risk: 0.00262781\n",
      "0.48008683706689176\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00251071; test risk early stopped: 0.00250736; train loss: 0.0024587332736700773\n",
      "\n",
      "\n",
      "*****training size (N) = 4096*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00255279\n",
      "Converged gradient descent: test risk: 0.00255655\n",
      "0.3394726580484003\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00250104; test risk early stopped: 0.00249925; train loss: 0.002436995506286621\n",
      "\n",
      "\n",
      "*****training size (N) = 8192*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00252168\n",
      "Converged gradient descent: test risk: 0.00252455\n",
      "0.24004341853344588\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249784; test risk early stopped: 0.00249682; train loss: 0.0024850356858223677\n",
      "\n",
      "\n",
      "*****training size (N) = 16384*****\n",
      "Optimal estimatior: test risk: 0.00249377\n",
      "PCA estimation: test risk: 0.00250773\n",
      "Converged gradient descent: test risk: 0.00250999\n",
      "0.16973632902420016\n",
      "Iteration : 0/5000\n",
      "Iteration : 100/5000\n",
      "Stopped at iteration 107 due to early stopping\n",
      "Gradient descent: test risk last: 0.00249616; test risk early stopped: 0.00249557; train loss: 0.0024864182341843843\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Store results\n",
    "PCA_est_results = {'test_l':np.zeros([runs,len(train_size)])}\n",
    "GDconv_results = {'test_l':np.zeros([runs,len(train_size)])}\n",
    "learn_results = {'test_l':{}, 'train_l_emp':{}}\n",
    "opt_est_results = {'test_l':np.zeros([runs,len(train_size)])}\n",
    "\n",
    "\n",
    "\n",
    "for r in range(runs):\n",
    "    print(\"**********run {}**********\".format(r))\n",
    "    for i,N in enumerate(train_size):\n",
    "        print(\"*****training size (N) = {}*****\".format(N))\n",
    "        data = dataGen(n, d)\n",
    "        data.create_train_data(n, d, N, sigma_z=sigma_z)\n",
    "        \n",
    "        ### optimal estimation\n",
    "        opt_est = optimal_estimator()\n",
    "        teL = opt_est.compute_optimal_estimator(U = data.U.numpy(), sigma_z = sigma_z)\n",
    "        opt_est_results['test_l'][r,i] = teL\n",
    "        print(\"Optimal estimatior: test risk: {}\".format(np.round(teL,precision)))\n",
    "\n",
    "\n",
    "        ### PCA estimator\n",
    "        PCA_est = PCA_based_reconstruction()\n",
    "        teL = PCA_est.compute_subspace_estimate(trY = data.trY.numpy(), U = data.U.numpy(), sigma_z = sigma_z)\n",
    "        PCA_est_results['test_l'][r,i] = teL\n",
    "        print(\"PCA estimation: test risk: {}\".format(np.round(teL,precision)))\n",
    "\n",
    "        \n",
    "        ### Estimator learned with gradient descent in the limit of infinite many iterations\n",
    "        GDconv_est = gradient_descent_converged()\n",
    "        teL = GDconv_est.compute_GDconv_estimate(data.trX.numpy(), data.trY.numpy(), data.U.numpy(), sigma_z)\n",
    "        GDconv_results['test_l'][r,i] = teL\n",
    "        print(\"Converged gradient descent: test risk: {}\".format(np.round(teL,precision)))\n",
    "        \n",
    "\n",
    "        ### Estimator learned with gradient descent\n",
    "        num_iters = 5000\n",
    "        epsilon = np.sqrt(10* (d+sigma_z**2*n) * np.log(n) / N)\n",
    "        print(epsilon)\n",
    "        lr = 1/(N * (1+epsilon) * (1+sigma_z**2))\n",
    "              \n",
    "        learn_rec = GD_model(n)\n",
    "        testL, trainL_emp = learn_rec.train(data.trX.type(dtype), data.trY.type(dtype), data.U.type(dtype), \n",
    "                                            sigma_z, num_iters, lr)\n",
    "        learn_results['test_l'][str(r)+str(i)] = testL\n",
    "        learn_results['train_l_emp'][str(r)+str(i)] = trainL_emp\n",
    "        risk_last = np.round(learn_results['test_l'][str(r)+str(i)][-1],precision)\n",
    "        risk_early_stopped = np.round(np.min(learn_results['test_l'][str(r)+str(i)]),precision)\n",
    "        train_loss = learn_results['train_l_emp'][str(r)+str(i)][-1]\n",
    "        print(\"Gradient descent: test risk last: {}; test risk early stopped: {}; train loss: {}\".format(risk_last,risk_early_stopped,train_loss))           \n",
    "\n",
    "\n",
    "\n",
    "        if r==0:\n",
    "            fontsize = 16\n",
    "            fig = plt.figure(figsize=(10,6))\n",
    "            alpha=0.8\n",
    "            ax = fig.add_subplot(111)\n",
    "            steps = len(learn_results['test_l'][str(r)+str(i)])\n",
    "            #ax.plot(range(steps), learn_results['train_l_emp'][str(r)+str(i)],label=r\"$W^{k}$ train\")\n",
    "            ax.plot(range(steps), learn_results['test_l'][str(r)+str(i)], label=r\"$W^{k}$ test\")\n",
    "            ax.plot(range(steps), [opt_est_results['test_l'][r,i]]*steps,label=r\"$W^{\\ast}$\")\n",
    "            ax.plot(range(steps), [PCA_est_results['test_l'][r,i]]*steps,label=r\"$W_{PCA}$\")\n",
    "            ax.plot(range(steps), [GDconv_results['test_l'][r,i]]*steps,label=r\"$W^{\\infty}$\")\n",
    "            ax.set_yscale('log')\n",
    "            ax.set_title('$\\sigma_z=${}, $n=${}, $d=${}, $N=${}'.format(sigma_z,n,d,N), fontsize=fontsize)\n",
    "            ax.tick_params(axis='x', labelsize=fontsize-4 ) \n",
    "            ax.tick_params(axis='y', labelsize=fontsize-4 ) \n",
    "            ax.set_xlabel('Iterations of gradient descent k', fontsize=fontsize)\n",
    "            ax.set_ylabel('R(W)', fontsize=fontsize)\n",
    "            ax.legend(fontsize=fontsize-2)\n",
    "            plt.show()\n",
    "\n",
    "        print(\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "start_time": "2021-08-18T15:29:44.723Z"
    }
   },
   "outputs": [],
   "source": [
    "#######\n",
    "# Compute mean and std for plot\n",
    "#######\n",
    "# test performance of early stopped gradient descent\n",
    "learn_results_ES = {'test_l':np.zeros([runs,len(train_size)])}\n",
    "for r in range(runs):\n",
    "    for i in range(len(train_size)):\n",
    "        learn_results_ES['test_l'][r,i] = np.min(learn_results['test_l'][str(r)+str(i)])\n",
    "\n",
    "PCA_est_M = PCA_est_results['test_l'].mean(0)\n",
    "PCA_est_S = PCA_est_results['test_l'].std(0)\n",
    "GDconv_est_M = GDconv_results['test_l'].mean(0)\n",
    "GDconv_est_S = GDconv_results['test_l'].std(0)\n",
    "learn_results_ES_M = learn_results_ES['test_l'].mean(0)\n",
    "learn_results_ES_S = learn_results_ES['test_l'].std(0)\n",
    "opt_est_M = opt_est_results['test_l'].mean(0)\n",
    "opt_est_S = opt_est_results['test_l'].std(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fit linear power laws to the power law regions of $W^{k_{opt}}$ and $W_{PCA}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Look up table that defines the start and end point of the power law regions for the estimators given a setup\n",
    "look_up_power_law_regions = {\n",
    "    'sigz01_d10_n100' : {\n",
    "        'start_x' : [8,10],\n",
    "        'end_x' : [24,44]\n",
    "    },\n",
    "    'sigz02_d10_n100' : {\n",
    "        'start_x' : [8,10],\n",
    "        'end_x' : [24,44]\n",
    "    },\n",
    "    'sigz005_d10_n100' : {\n",
    "        'start_x' : [8,10],\n",
    "        'end_x' : [24,44]\n",
    "    },\n",
    "    'sigz01_d10_n1000' : {\n",
    "        'start_x' : [18, 80],\n",
    "        'end_x' : [80, 256]\n",
    "    },\n",
    "    'sigz01_d10_n10000' : {\n",
    "        'start_x' : [100, 512],\n",
    "        'end_x' : [256, 2048]\n",
    "    },\n",
    "    'sigz01_d50_n1000' : {\n",
    "        'start_x' : [50, 50],\n",
    "        'end_x' : [100, 256]\n",
    "    },\n",
    "    'sigz01_d100_n1000' : {\n",
    "        'start_x' : [80, 80],\n",
    "        'end_x' : [175, 175]\n",
    "    },\n",
    "    'sigz005_d10_n1000' : {\n",
    "        'start_x' : [10, 10],\n",
    "        'end_x' : [44, 100]\n",
    "    }\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "390.29399688206 -3.657632648196683\n",
      "10.435659758809015 -1.9313628103834832\n"
     ]
    }
   ],
   "source": [
    "start_GD = look_up_power_law_regions[key]['start_x'][0]\n",
    "end_GD = look_up_power_law_regions[key]['end_x'][0]\n",
    "\n",
    "start_PCA = look_up_power_law_regions[key]['start_x'][1]\n",
    "end_PCA = look_up_power_law_regions[key]['end_x'][1]\n",
    "\n",
    "#####\n",
    "# Linear fit of learned estimator\n",
    "#####\n",
    "# train_size at which power-law regime begins\n",
    "start_ind = np.where(np.array(train_size)==start_GD)[0][0]\n",
    "# train_size at which power-law regime ends\n",
    "end_ind = np.where(np.array(train_size)==end_GD)[0][0]\n",
    "\n",
    "# find linear fit \n",
    "y = np.log10(learn_results_ES_M[start_ind:end_ind+1])\n",
    "x = np.vstack((np.log10(np.array(train_size)[start_ind:end_ind+1]),np.ones(y.shape))).T\n",
    "\n",
    "linfit_w = np.linalg.inv(x.T@x) @ x.T@y\n",
    "\n",
    "# power-law: R = beta * N**alpha\n",
    "beta = 10**linfit_w[1]\n",
    "alpha = linfit_w[0]\n",
    "print(beta,alpha)\n",
    "linfit = beta * np.array(train_size)**alpha\n",
    "\n",
    "#####\n",
    "# Linear fit of noisy subspace estimator\n",
    "#####\n",
    "# train_size at which power-law regime begins\n",
    "start_ind = np.where(np.array(train_size)==start_PCA)[0][0]\n",
    "# train_size at which power-law regime ends\n",
    "end_ind = np.where(np.array(train_size)==end_PCA)[0][0]\n",
    "\n",
    "# find linear fit \n",
    "y = np.log10(PCA_est_M[start_ind:end_ind+1])\n",
    "x = np.vstack((np.log10(np.array(train_size)[start_ind:end_ind+1]),np.ones(y.shape))).T\n",
    "\n",
    "linfit_w = np.linalg.inv(x.T@x) @ x.T@y\n",
    "\n",
    "# power-law: R = beta * N**alpha\n",
    "beta_2 = 10**linfit_w[1]\n",
    "alpha_2 = linfit_w[0]\n",
    "print(beta_2,alpha_2)\n",
    "linfit_2 = beta_2 * np.array(train_size)**alpha_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "ExecuteTime": {
     "start_time": "2021-08-18T15:29:44.725Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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njfPaH/2bDUvescdWoeFaZ2VZZfXYCt5/4iy9Pqol57689QK21XnPfTR7x/prvO66qSMJJvPIWqnv//+W2utdXJysosjqbl++uknnZqaWmL7X3/9pevXr68B/eGHHxZsT09P102aNNGAfuSRR3ROTk7Bvh9++EH7+flpQG/durXEOZcsWaIB3aBBAx0bG1uw/cyZM7p9+/Ya0DNmzHBo/IVdeeWVGii49rRp00pt1717dw3oDz74oMj2xMREvXfv3gofaWlpJc75+++/6y1btuh58+bppk2b6l69ehX5XZbnl19+KTWeyrD+nagMYIcuJR91eUJc1x+S8Ncdt7d/VR8Kctd7gj31rhBPneKOTvVAj2z/qNZa67w8rXv10rpbN60r+fe/dKtWGX81V660T+A2kvePKE1WTpbuOq+rfj/m/QrbVuc99POxn3XXeV31zlM7bT6HqJ0k4a+eiRMnakAPGzasYNunn36qAd2qVSudVUpn0osvvqgBfdNNN5XY17VrVw3ohQsXlti3cePGgg8Dubm5DovfKjc3t+DDyZdffqkBffXVV5d6nuDgYA3oP/74o8j2BQsWaKDCx7p168qNc8eOHRrQX331VaVe19ixY7W3t7dOSqp6J4Y9En4Zwy9EBd57z1jR99uTL/FwwIuc8fbFLzePPSF+HPHz4Ma0ZXSLPsn77xsjcX7+GWbMqMYFb7wRwsOlJr+okRIyEgAcOoYfjNKcgCzAJUQVubsbo7W9vf+torV9+3bAqC7j4eFR4pjrr78egHXr1hUpI3ny5EliYmLw9PRkyJAhJY7r0aMHjRs35syZM/z6668Oi99q3759pKWlERQUxODBg2nRogVbt27l9OnTRdodPnyYxMREvLy8SlTKGTFiRKU6bK2/k7J07twZk8nEwYMVFxfIycnhyy+/pF+/fgQGBlbY3hEk4ReiAqNHG2P6v/gC9nm+xNjgBIZEZnNXYCoP+c6lZWY8L3ldy/Db4xg+HPr3h+efh7//tvGCHh7Gil7r10NWll1fixDVFWeJA3BolR6Aer71CPAKkEo9QlTBkSNHePfddwHo169fwfbU1FQAwsNLXyzPuj07O5u//vqrYPvvv/8OwEUXXYSPj0+px1522WVF2lZHWfFbWcfvX3rppSilGDhwIFprvvnmm1LbderUqdQPOPawZcsW8vLyaNWqVYVt165dy/nz5xk+fLhDYqkMSfiFqKS+feGdd4zqmQkJRgnOcdPv56voVwk9dIr1N/ckOyOVefPA3x/uvRdybF0o9KWX4MgR8PS062sQorri0+MBx/fwK6WICo2ShF+IcixYsIARI0Zw11130aNHD9q0acPJkyd59tlnGThwYEG7iIgIwOj5Lk3h7UeOHCnx5/Iq0TTLr0dd+Dh7x29lTeStE3Fvu+02AL7++uty21VX7969eeONN1i9ejXr16/nzTffZPDgwVx88cUMGDCgoN3HH3+Mu7s7mzZtKnL8okWLCAsLo2/fvnaJxxZSpUeIKujb13gUduut45k+PJG+P0/j6xt7MWjdFubO9WTSJDh7Fho3tuFC+f84C1HTmC2OXWW3sMjQSFbFrkJrjar2UtZC1D1btmxh4cKFBT+7u7szadIkxo8fX6Tdtddey+TJk1m9ejUnT54sUSXG2qsOFBnSY/1mwM/Pr8wY/P2NVelTUlIcFr9V8UT+qquuokGDBmzatAmz2VxQGz8mJgaArl27Vjmm0vznP/9h0aJFBR9qWrRowZgxYxg/fjyehTrm8vLyyM3NNSbJ5ktNTWXFihXce++9Dvu2oTKkh1+IavLxgWe/msiv199P29i/WXjdjfTtk0NMjI3JvtXWrcbkgX/+sVusQlSXOd1I+B09pAeMhN+SbeF06umKG4sLS8+eJR9z5hj7LJbS93/0kbE/Lq70/V98Yew/caL0/StXGvv37y99//r1xv4//ii5z0Hmz5+P1hqLxcKePXt47LHHeOWVV7jiiis4depUQbtrr72W7t27k56ezo033sgPP/xASkoKsbGx/Pe//2X16tUFY+cLl8K0Jq6O+sBd2fitsfzxxx/Avwm/yWSif//+5OTksGLFioK21uFF9urhnzhxIrt27SIlJYWUlBR2797NK6+8UmI8vnV+QM9C99zf35+0tDTmWN+fLiIJvxB2YDLBmMVv83efwXQ9uJ33e/fHHJdHUpIxOicz04aThodDTAx8/rnd4xXCVmaLGX9PfzzdHD/cLDLUWMdEhvUIUT4fHx86dOjAm2++yeuvv86ff/7JuHHjirT56quv6NatG3v37uW6664jMDCQtm3bMn/+fB5++GEuuugiAEJD//32LiAgAPi3p7801n3Wto6K/9ChQyQlJeHr60vbtm0LtluH9SxduhSAEydO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2NixY1mzZg0zZ84kPj6erVu38swzz+Dm5latoULOUpkIk4FrgKVKqVil1FillK+D4xJCFNOvH4wYAa+/Dr/9BpfeOZ60Z8YT/tcRtq55j9xffoHff0cpiImBBg2Msf9paeDrC56e8Oabrn4VojayDp+pCWP4g72DCfcNlx5+cUEbNWoUb7zxBkOHDqV168qNmH799dcBmDp1KlFRUQXb69evz9y5cwGYMmWKzUN7XnrpJf7++2/effddKhrOnJeXx65duwB49dVXgbITfuuE2K5duxbZvmzZMtq3b1/mIzo6mvbt27N161abXk9x9957L+PHj2fChAmEhYXRq1cvHnzwQUJDQ2nYsKFdruFIlUn4G2NMuj0MRAJvAyeVUq8rpRo7MjghRFEzZsB//mMM0wG4/IGJJI67n4ij5/mpJeR98jEAR45AeDj4+UFeHiQkGEm/lO4UtrAO6Qn3DXdxJIao0CgOJkjCL0RlnTx5kpiYGDw9PRkyZEiJ/T169KBx48acOXOmYJhKVfz2229MmzaNO++8k379+lXYft++faSlpREUFMTgwYNp0aIFW7du5fTp00XaHT58mISEBLy8vEqU0RwxYgRa6zIfycnJaK25/vrrq/x6SqOUYtq0acTFxfHnn39y7tw5Ro0axfnz57nyyivtcg1HqjDh11qnaa1nAW2AAcBmIBh4CqPG/idKKdcOrBLiAhEUBFu2QOFvb6968m3M9wwhwuLG5m/fRWdn07IlWCzGcB53dzh/HlJSoEULl4UuajFzuhmTMhHsHezqUABjWM+RhCPk5lVvvLEQF4rff/8dgIsuuggfH59S21x22WVF2lZWRkYG9957L6GhocycObNSx1iH6Vx66aUopRg4cCBaa7755ptS23Xq1AkPD48qxeUoQUFBXHzxxQQFBTFr1iyCg4NL/RBV01R60JE2rNBa9wI6A58AecBdwHal1I9KqYo/1gkhqkUpyMqCl1+Gn34ytnV7dQHnrrmUiPhMfhrdmyefNNpkZxuVe3JyjKT/ySddG7uoneLT4wn2DsakasY41aiwKLJysziedNzVoQhRKxw5cgSA5s2bl9mmWbNmRdpW1vPPP8/+/fuZNWsW4eGV+xaw+Lj82267DTDmGZTXrrosFgtLlixhyZIlHDt2jOTk5CI/W3388ce4u7uzadOmgm3btm1j6tSpfP/9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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fontsize = 22\n",
    "\n",
    "fig = plt.figure(figsize=(12,6))\n",
    "al=0.8\n",
    "ax = fig.add_subplot(111)\n",
    "ax.errorbar(train_size, PCA_est_M, yerr=PCA_est_S, color='b', fmt=\"-o\",alpha=al,label=r\"$W_{PCA}$\", capsize=5)\n",
    "ax.errorbar(train_size, GDconv_est_M, yerr=GDconv_est_S, color='g', fmt=\"-o\",alpha=al,label=r\"$W^{\\infty}$\", capsize=5)\n",
    "ax.errorbar(train_size, learn_results_ES_M, yerr=learn_results_ES_S, color='r', fmt=\"-o\",alpha=al,label=r\"$W^{k_{opt}}$\", capsize=5)\n",
    "ax.plot(train_size, opt_est_M,color='m', label=r\"$W^{\\ast}$\")\n",
    "\n",
    "\n",
    "ax.plot(train_size[:linfit.shape[0]], linfit,linestyle='--', color='r',label=r\"${%.1f} N^{%.1f}$\"%(np.round(beta,1),np.round(alpha,1)))\n",
    "ax.plot(train_size[:linfit_2.shape[0]], linfit_2,linestyle='--',color='b',label=r\"${%.1f} N^{%.1f}$\"%(np.round(beta_2,1),np.round(alpha_2,1)))\n",
    "\n",
    "ax.set_xlabel(\"Number of samples in the training set $N$\", fontsize=fontsize)\n",
    "ax.set_ylabel(r\"Test risk $R(W)$\", fontsize=fontsize)\n",
    "ax.legend(fontsize=fontsize)\n",
    "ax.set_title('$\\sigma_z=${}, $n=${}, $d=${}'.format(sigma_z,n,d), fontsize=fontsize)\n",
    "ax.tick_params(axis='x', labelsize=fontsize-2 ) \n",
    "ax.tick_params(axis='y', labelsize=fontsize-2 ) \n",
    "base =10\n",
    "ax.set_yscale('log')\n",
    "ax.set_xscale('log')\n",
    "ax.set_ylim([opt_est_M[0]*0.9,2.04])\n",
    "\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
