{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "from sklearn.datasets import fetch_rcv1\n",
    "from sklearn.linear_model import Ridge\n",
    "from sklearn.metrics import mean_squared_error\n",
    "from sklearn.model_selection import KFold\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "from gcv.ensemble import PreSketchedEnsembleRidge, EnsemblePreSketchTransform\n",
    "from gcv.sketches import CountSketchFactory, SketchSizeParams"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load dataset\n",
    "rcv1 = fetch_rcv1()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of words: 30617\n"
     ]
    }
   ],
   "source": [
    "# construct a binary classification task\n",
    "targets = ['GCAT', 'CCAT']\n",
    "target_idx = [np.where(rcv1.target_names == t)[0][0] for t in targets]\n",
    "\n",
    "# filter down to documents with only one of the two labels\n",
    "y_full = rcv1.target[:, target_idx]\n",
    "binary_idx = y_full.sum(axis=1).A1 == 1\n",
    "y_full = y_full[binary_idx][:, 0].toarray().ravel().astype(int) * 2 - 1\n",
    "X_full = rcv1.data[binary_idx, :]\n",
    "\n",
    "# split into train and test sets\n",
    "n_train = 20000\n",
    "n_test = 5000\n",
    "rng = np.random.default_rng(0)\n",
    "idx = rng.permutation(X_full.shape[0])\n",
    "train_idx = idx[:n_train]\n",
    "test_idx = idx[n_train:n_train + n_test]\n",
    "\n",
    "# filter words that appear in at least 1 document\n",
    "X_full = X_full[idx[:n_train + n_test], :]\n",
    "keep_idx = np.array(X_full.sum(axis=0) > 0).ravel()\n",
    "X_full = X_full[:, keep_idx]\n",
    "p = X_full.shape[1]\n",
    "print(f'Number of words: {p}')\n",
    "y_full = y_full[idx[:n_train + n_test]]\n",
    "\n",
    "# save data\n",
    "np.savez_compressed('data/rcv1.npz', X=X_full, y=y_full)\n",
    "\n",
    "# split into train and test sets\n",
    "X_train = X_full[:n_train, :]\n",
    "X_test = X_full[n_train:, :]\n",
    "y_train = y_full[:n_train]\n",
    "y_test = y_full[n_train:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(515, 30617)\n",
      "16.00338110812828\n"
     ]
    },
    {
     "data": {
      "image/png": "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iiuu0GOPPcacxMnOnTvV3d2tmTNnKikpSUlJSWpqatLvfvc7JSUlOf9emZf4GfHhY9y4cZo5c6YaGxsj+hsbG5Wbmxunqr7esrKy5PV6I+ZkYGBATU1NzpzMnDlTY8eOjRhz4MABvfXWW8zbEBljtHTpUm3cuFGvvPKKsrKyIvYzLyOHMUb9/f3MSZzcdNNNamtrU2trq9NmzZql+fPnq7W1Veeffz7zEm/xOc81OscutX366afNnj17TGlpqRk/frzZt29fvEsbtXp7e83u3bvN7t27jSRTXV1tdu/e7VzevGbNGpOenm42btxo2trazF133XXSy9QmT55sXn75ZbNr1y5z4403cpnaabj33ntNenq6ee2118yBAwecdujQIWcM82JfWVmZ2bZtm+no6DBvvvmmeeCBB8wZZ5xhGhoajDHMyUhx/NUuxjAv8ZYQ4cMYY37/+9+bqVOnmnHjxplvfetbzuWFGB6vvvqqkTSoLViwwBhz9FK1Bx980Hi9XuN2u831119v2traIo7R19dnli5daiZMmGCSk5PNd7/7XbN///44fJrR4WTzIcmsX7/eGcO82Ldw4ULn/00TJ040N910kxM8jGFORooTwwfzEl8uY4yJz5oLAAD4Ohrx53wAAIDRhfABAACsInwAAACrCB8AAMAqwgcAALCK8AEAAKwifAAAAKsIHwAAwCrCBwAAsIrwAQAArCJ8AAAAqwgfAADAqv8DV6zXQJRcCesAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sf = CountSketchFactory(p)\n",
    "# sf = SubsampledFourierSketchFactory(p)\n",
    "Sh = sf(SketchSizeParams(600))\n",
    "print(Sh.shape)\n",
    "\n",
    "# compute the sketch of the training data\n",
    "Xh_train = Sh @ X_train.T\n",
    "\n",
    "XX = Xh_train @ Xh_train.T\n",
    "w, v = np.linalg.eigh(XX)\n",
    "print(min(w))\n",
    "\n",
    "plt.hist(w, bins=100)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_norm = X_train.multiply(1 / np.sqrt(X_train.power(2).sum(axis=1).A)) * np.sqrt(p)\n",
    "X_test_norm = X_test.multiply(1 / np.sqrt(X_test.power(2).sum(axis=1).A)) * np.sqrt(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def classification_error(y_true, y_pred):\n",
    "    return np.mean(y_true != np.sign(y_pred))\n",
    "\n",
    "def gcv_error(estimator, y, y_hat, error_metric):\n",
    "\n",
    "    div = estimator.gcv_div()\n",
    "    z = (y_hat - div * y) / (1 - div)\n",
    "\n",
    "    return error_metric(y, z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "1/10: 100%|██████████| 2/2 [00:33<00:00, 16.76s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.38it/s]\n",
      "2/10: 100%|██████████| 2/2 [00:31<00:00, 15.67s/it]\n",
      "100%|██████████| 250/250 [00:32<00:00,  7.58it/s]\n",
      "3/10: 100%|██████████| 2/2 [00:30<00:00, 15.46s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.55it/s]\n",
      "4/10: 100%|██████████| 2/2 [00:30<00:00, 15.25s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.57it/s]\n",
      "5/10: 100%|██████████| 2/2 [00:29<00:00, 14.98s/it]\n",
      "100%|██████████| 250/250 [00:32<00:00,  7.60it/s]\n",
      "6/10: 100%|██████████| 2/2 [00:31<00:00, 15.53s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.45it/s]\n",
      "7/10: 100%|██████████| 2/2 [00:31<00:00, 15.67s/it]\n",
      "100%|██████████| 250/250 [00:34<00:00,  7.34it/s]\n",
      "8/10: 100%|██████████| 2/2 [00:34<00:00, 17.19s/it]\n",
      "100%|██████████| 250/250 [00:34<00:00,  7.19it/s]\n",
      "9/10: 100%|██████████| 2/2 [00:31<00:00, 15.62s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.47it/s]\n",
      "10/10: 100%|██████████| 2/2 [00:30<00:00, 15.50s/it]\n",
      "100%|██████████| 250/250 [00:33<00:00,  7.37it/s]\n"
     ]
    }
   ],
   "source": [
    "# sketches = ['gaussian', 'orthogonal', 'countsketch', 'dct']\n",
    "sketches = ['countsketch']\n",
    "q = 515\n",
    "n_ens = 5\n",
    "# Ks = [2, 5]\n",
    "Ks = [2]\n",
    "rng = np.random.default_rng(0)\n",
    "n_trials = 10\n",
    "\n",
    "lamdas = np.concatenate([-np.logspace(2, 1, 51), np.linspace(-10, 10, 101)[1:], np.logspace(1, 3, 101)[1:]])\n",
    "\n",
    "cv_reg_errs = np.zeros((n_trials, len(sketches), len(Ks), len(lamdas)))\n",
    "cv_cls_errs = np.zeros((n_trials, len(sketches), len(Ks), len(lamdas)))\n",
    "test_reg_errs = np.zeros((n_trials, len(sketches), len(lamdas)))\n",
    "test_cls_errs = np.zeros((n_trials, len(sketches), len(lamdas)))\n",
    "gcv_reg_errs = np.zeros((n_trials, len(sketches), len(lamdas)))\n",
    "gcv_cls_errs = np.zeros((n_trials, len(sketches), len(lamdas)))\n",
    "\n",
    "for t in range(n_trials):\n",
    "\n",
    "    for i, sketch in enumerate(sketches):\n",
    "        sketch_transform = EnsemblePreSketchTransform(n_ens=n_ens, q=q, sketch=sketch, rng=rng)\n",
    "        XS_train = sketch_transform.fit_transform(X_train_norm)\n",
    "        XS_test = sketch_transform.transform(X_test_norm)\n",
    "\n",
    "        # perform k-fold cross validation\n",
    "        for k, K in enumerate(Ks):\n",
    "\n",
    "            y_hat_cv = np.zeros((len(lamdas), n_train))\n",
    "\n",
    "            for train_idx, val_idx in tqdm(KFold(n_splits=K, shuffle=True, random_state=rng.integers(0, 1000)).split(XS_train), total=K, desc=f'{t + 1}/{n_trials}'):\n",
    "                XS_cv_train = XS_train[train_idx, :]\n",
    "                y_cv_train = y_train[train_idx]\n",
    "                XS_cv_val = XS_train[val_idx, :]\n",
    "                y_cv_val = y_train[val_idx]\n",
    "\n",
    "                ens = PreSketchedEnsembleRidge(n_ens=n_ens, lamda=lamdas[0], which_ridge='svd').fit(XS_cv_train, y_cv_train)\n",
    "                y_hat_cv[0, val_idx] = ens.predict(XS_cv_val)\n",
    "\n",
    "                for j, lamda in enumerate(lamdas[1:]):\n",
    "                    ens.refit(lamda)\n",
    "                    y_hat_cv[j + 1, val_idx] = ens.predict(XS_cv_val)\n",
    "                \n",
    "            # compute the CV error\n",
    "            for j in range(len(lamdas)):\n",
    "                cv_reg_errs[t, i, k, j] = mean_squared_error(y_train, y_hat_cv[j, :])\n",
    "                cv_cls_errs[t, i, k, j] = classification_error(y_train, y_hat_cv[j, :])\n",
    "        \n",
    "        # compute the test error and gcv error\n",
    "        ens = PreSketchedEnsembleRidge(n_ens=n_ens, lamda=lamdas[0], which_ridge='svd').fit(XS_train, y_train)\n",
    "        y_train_hat = ens.predict(XS_train)\n",
    "        y_test_hat = ens.predict(XS_test)\n",
    "        test_reg_errs[t, i, 0] = mean_squared_error(y_test, y_test_hat)\n",
    "        gcv_reg_errs[t, i, 0] = gcv_error(ens, y_train, y_train_hat, mean_squared_error)\n",
    "        test_cls_errs[t, i, 0] = classification_error(y_test, y_test_hat)\n",
    "        gcv_cls_errs[t, i, 0] = gcv_error(ens, y_train, y_train_hat, classification_error)\n",
    "\n",
    "        for j, lamda in enumerate(tqdm(lamdas[1:])):\n",
    "            ens.refit(lamda)\n",
    "            y_train_hat = ens.predict(XS_train)\n",
    "            y_test_hat = ens.predict(XS_test)\n",
    "            test_reg_errs[t, i, j + 1] = mean_squared_error(y_test, y_test_hat)\n",
    "            gcv_reg_errs[t, i, j + 1] = gcv_error(ens, y_train, y_train_hat, mean_squared_error)\n",
    "            test_cls_errs[t, i, j + 1] = classification_error(y_test, y_test_hat)\n",
    "            gcv_cls_errs[t, i, j + 1] = gcv_error(ens, y_train, y_train_hat, classification_error)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cv[0,0]: 32\n",
      "test[0]: 30\n",
      "gcv[0]: 30\n"
     ]
    }
   ],
   "source": [
    "# detect when lamda is too negative and set to nan\n",
    "lamda_0_i = np.argmin(np.abs(lamdas))\n",
    "BIG_VAL = 10\n",
    "\n",
    "for i in range(len(sketches)):\n",
    "    \n",
    "    for j in range(len(Ks)):\n",
    "        cv_idx = np.max(np.argwhere(np.mean(cv_reg_errs[:, i, j, :lamda_0_i], axis=0) > BIG_VAL))\n",
    "        print(f'cv[{i},{j}]: {cv_idx}')\n",
    "        cv_reg_errs[:, i, j, :cv_idx] = np.nan\n",
    "        cv_cls_errs[:, i, j, :cv_idx] = np.nan\n",
    "\n",
    "    test_idx = np.max(np.argwhere(np.mean(test_reg_errs[:, i, :lamda_0_i], axis=0) > BIG_VAL))\n",
    "    print(f'test[{i}]: {test_idx}')\n",
    "    test_reg_errs[:, i, :test_idx] = np.nan\n",
    "    test_cls_errs[:, i, :test_idx] = np.nan\n",
    "\n",
    "    gcv_idx = np.max(np.argwhere(np.mean(gcv_reg_errs[:, i, :lamda_0_i], axis=0) > BIG_VAL))\n",
    "    print(f'gcv[{i}]: {gcv_idx}')\n",
    "    gcv_reg_errs[:, i, :gcv_idx] = np.nan\n",
    "    gcv_cls_errs[:, i, :gcv_idx] = np.nan\n",
    "    \n",
    "to_save = {\n",
    "    'cv_reg_errs': cv_reg_errs,\n",
    "    'cv_cls_errs': cv_cls_errs,\n",
    "    'test_reg_errs': test_reg_errs,\n",
    "    'test_cls_errs': test_cls_errs,\n",
    "    'gcv_reg_errs': gcv_reg_errs,\n",
    "    'gcv_cls_errs': gcv_cls_errs,\n",
    "    'lamdas': lamdas,\n",
    "    'sketches': sketches,\n",
    "    'Ks': Ks,\n",
    "    'n_ens': n_ens,\n",
    "    'q': q,\n",
    "    'n_trials': n_trials,\n",
    "    'p': p,\n",
    "    'n_train': n_train,\n",
    "    'n_test': n_test\n",
    "}\n",
    "\n",
    "np.savez('results/rcv1.npz', **to_save)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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97//HbPZHHjstddeo1OnTowfP/7EBH+YjIwMoqOjA3/8jmTp0qVccskljBw5knfeeQefz8eTTz5ZL4nRdZ3Jkyezbt06HnroIc444wxWr17NhAkT6h1z69atjBo1itTUVP71r3+RmJjIV199xW233UZBQQGzZ89u9uvxer1kZWUFfi+1MV1yySWsXLmSu+++m1GjRrF3715mz57N2LFjWbduHXa7HYAbbriBBQsWcPfdd3PuueeydetWLrvsMsrKyho837Rp05g0aRJvvPEGlZWVmM1mHn/8cf76179yww038Ne//hW3281TTz3F2WefzZo1a+jXrx8AF110UeB9TE1NpaCggFWrVgU+dNTWxp999tnMnTuX6OhoDhw4wKJFi3C73TgcjgZj2rFjB6NGjaJjx448++yzxMXF8eabbzJ16lRyc3O5++67g/a/7777GD16NK+88gplZWXcc889TJ48mW3btmE0Gpv9OxBCtDwZc0I75nz99dcAXHrppc1/0TUyMzPp3bs3V111FbGxsWRnZ/PSSy8xbNgwtm7dSnx8PAB33nknb7zxBo899hiDBw+msrKSzZs3U1hYGDjW0caPumrfl8suu4zu3bsHEtWkpCSys7Pr7f/zzz9z1llnER8fzyOPPELPnj3Jzs7m008/xe12Y7VaKSoqAmD27NkkJiZSUVHBRx99xNixY1m6dCljx44lKSmJRYsWMWHCBKZPn87vf/97gEZ//0888QT33XcfV199NU888QSFhYU89NBDjBw5krVr19KzZ8/Avh6PhylTpjB9+nTuuusuVqxYwaOPPkpUVBQPPvhg835BovlCPXUm2qfaEo0ffvhBeTweVV5erhYtWqQSExPVOeecozwej1JKqXfeeUcB6uWXX272sT/88MPAts2bNytA3X///Ud83vGUaHg8HuXxeFR2drZ68MEHG4w5IyNDAeq1114LbBsxYoRKTk4OKuUoKytTsbGxQSUaX3zxhQLUSy+9FHTMJ554ol5ZwPjx41Xnzp1VaWlp0L5/+tOflM1mU0VFRY2+prS0NHXRRRcFXtPevXvVjTfeqMxms/r8888D+7399tsKUB988EHQ89euXasA9eKLLyqllNqyZYsC1D333BO0X+3zr7/++sC22t/dddddF7Tvvn37lMlkUrfeemvQ9vLycpWYmKiuvPJKpZRSBQUFClBPP/30EV/f+++/rwD1008/Nfo+1H1fr7rqKmW1WtW+ffuC9ps4caJyOByqpKREKXWobOWiiy4K2u/dd99VgFq9enWj5xVCtDwZc/za2phz0003KUBt3769Sa+/KWWBXq9XVVRUqLCwMPXMM88Etvfv319deumlR3xeU8YPpfy/gzFjxgRta6icvqH3/9xzz1XR0dEqLy+v0XPUfT0ej0edd9556rLLLgtsb6wssPbfZEZGhlLKX6Jqt9vrjUv79u1TVqtVXXPNNYFt119/vQLUu+++G7TvRRddpHr37t3kuMWxk7JAcVzOPPNMzGYzERERTJgwgZiYGD755BNMpmOfFL3yyiuJiIhg7ty5gW1z585F0zRuuOGGlgg7yJYtWzCbzZjNZpKSknjkkUeYNWsWf/zjHxt9XmVlJWvXruVXv/oVNpstsD0iIoLJkycH7VvbLenKK68M2n711VcH/VxdXc3SpUu57LLLcDgceL3ewNdFF11EdXU1P/zww1Ff08KFCwOvKS0tjf/7v//jueeeY9KkSYF9Pv/8c6Kjo5k8eXLQeQYNGkRiYmKgg9GRYr/iiiuO+Hu+/PLLg37+6quv8Hq9XHfddUHnstlsjBkzJnCu2NhYunfvzlNPPcWcOXPYuHEjuq4HHWvQoEFYLBb+8Ic/8L///Y/09PSjvh/gLyU877zzSElJCdo+depUnE4nq1evDto+ZcqUoJ8HDBgAUK9URQjRemTMaZtjzvGoqKjgnnvuoUePHphMJkwmE+Hh4VRWVgaVvA0fPpwvv/ySe++9l2+//Zaqqqqg4zRl/DgeTqeT5cuXc+WVVx51hvHll1/mjDPOwGazYTKZMJvNLF26tF4JX1OtXr2aqqqqoDJ8gJSUFM4991yWLl0atF3TtHr/JgYMGCDjVyuR5Eocl9dff521a9eybNky/vjHP7Jt27agP961dda1pRtN4XA4uOqqq1i0aBE5OTl4vV7efPNNxowZc0K69nTv3p21a9eyZs0a3nvvPQYOHMgTTzzBO++80+jziouL0XWdxMTEeo/V3VZYWIjJZCI2NjZoe0JCQr39vF4vzz33XGDwrf266KKLAH9npqM566yzWLt2LT/88ANvvPEGXbp04U9/+hPfffddYJ/c3FxKSkqwWCz1zpWTkxM4T23JRd1YTSYTcXFxDZ6/boej2pKVYcOG1TvXggULAufSNI2lS5cyfvx4nnzySc444ww6dOjAbbfdRnl5OeD/fS1ZsoSOHTtyyy230L17d7p3784zzzzT6HtSWFjYYOel5OTkoNdZq+5rs1qtAPUGdCFE65Exp22NOcfyftd1zTXX8Pzzz/P73/+er776ijVr1rB27Vo6dOgQ9Pf22Wef5Z577uHjjz9m3LhxxMbGcumllwZa8Tdl/DgexcXF+Hy+o3ahnTNnDjfffDMjRozggw8+4IcffmDt2rVMmDDhmMeP2vHpSGNY3fHL4XAEJeDgH8Oqq6uP6fyieeSeK3Fc+vbtG7iheNy4cfh8Pl555RXef/99rrjiCoYOHUpsbCyffPIJTzzxRJPX4Zg+fTr/93//x+uvv06vXr3Iy8vjX//61wl5DTabLfAahg0bxrhx4zjttNO44447uPjiiwkPD2/weTExMWiaRk5OTr3H6m6Li4vD6/VSVFQUNNjV3S8mJgaj0ci1117LLbfc0uB5u3btetTXFBUVFXhNI0aMYMSIEQwcOJAZM2bw008/YTAYiI+PJy4ujkWLFjV4jIiIiEDs4E+QOnXqFHjc6/XW+4Neq+7vubZm/v333yctLa3R2NPS0nj11VcB2LlzJ++++y4PPfQQbrc7sB7N2Wefzdlnn43P52PdunU899xz3HHHHSQkJHDVVVc1eNy4uLgGa+gPHjwYFKMQou2SMadtjTnjx4/nvvvu4+OPP27wfq6jKS0t5fPPP2f27Nnce++9ge0ulytw71KtsLAwHn74YR5++GFyc3MDs1iTJ09m+/btQNPGj2MVGxuL0Whk//79je735ptvMnbsWF566aWg7ceT4NWOw0caw2T8altk5kq0qCeffJKYmBgefPBBdF3HbDZzzz33sH37dh599NEGn5OXl8f3338ftG3EiBH079+f1157jddee42oqKh6pWYnSlxcHH//+9/Jzc3lueeeO+J+YWFhDB8+nA8//DDoalB5eXm9tU/GjBkD+LvlHa7ulUqHw8G4cePYuHEjAwYMYOjQofW+jjRb1JiePXty9913s2nTpkAMF198MYWFhfh8vgbP07t3bwDOOeecBmN///338Xq9TTr/+PHjMZlM7Nmzp8Fz1X7QqKtXr1789a9/5fTTT2fDhg31HjcajYwYMSLQ1aqhfWqdd955LFu2LJBM1Xr99ddxOByceeaZTXotQoi2Q8ac0I45Z5xxBhMnTuTVV19l2bJlDe6zbt069u3b1+BjmqahlApUBtR65ZVX8Pl8RzxvQkICU6dO5eqrr2bHjh1BnWJrHW38aC673c6YMWN47733Gp3N0zSt3uv55Zdf6pWeN6caYuTIkdjtdt58882g7fv37w+UvIu2Q2auRIuKiYlh1qxZ3H333bz11lv87ne/4y9/+Qvbtm1j9uzZrFmzhmuuuSawoOOKFSv473//y8MPP8zo0aODjjVt2jTuvPNOduzYwR//+MdA57rDOZ1OFi5cCBCoC1++fDkFBQWEhYUxceLEY3od1113HXPmzOGf//wnt9xyC5GRkQ3u9+ijjzJhwgQuuOAC7rrrLnw+H//4xz8ICwsLuuo2YcIERo8ezV133UVZWRlDhgxh9erVvP7660Bwe99nnnmGs846i7PPPpubb76ZLl26UF5ezu7du/nss8+OOIAdzZ///GdefvllHn74Ya688kquuuoq5s+fz0UXXcTtt9/O8OHDMZvN7N+/n2+++YZLLrmEyy67jNNOO42rr76af/3rXxiNRs4991y2bNnCv/71L6KioprUmrhLly488sgj3H///aSnpwfulcjNzWXNmjWBK5K//PILf/rTn/j1r39Nz549sVgsLFu2jF9++SVwVfPll19m2bJlTJo0idTUVKqrqwP3Spx//vlHjGH27Nl8/vnnjBs3jgcffJDY2Fjmz5/PF198wZNPPklUVNQxva9CiNCRMSf0Y87rr7/OhAkTmDhxItOmTWPixInExMSQnZ3NZ599xttvv8369esbbMceGRnJOeecw1NPPUV8fDxdunRh+fLlvPrqq0RHRwftO2LECC6++GIGDBhATEwM27Zt44033mDkyJE4HI4mjR/Ha86cOZx11lmMGDGCe++9lx49epCbm8unn37Kf/7zHyIiIrj44ot59NFHmT17NmPGjGHHjh088sgjdO3aNeiCZEREBGlpaYGFlmNjYwPvQV3R0dE88MAD3HfffVx33XVcffXVFBYW8vDDD2Oz2Y6pi7A4gULdUUO0T0da0FEppaqqqlRqaqrq2bOn8nq9ge2ffPKJmjRpkurQoYMymUwqJiZGjRs3Tr388svK5XLVO05+fr6yWCwKUGvWrGkwjtpuPg19paWlHfV1NLSgY63abku1C1E21DlIKaU+/fRTNWDAAGWxWFRqaqr6+9//3uCCjkVFReqGG25Q0dHRyuFwqAsuuED98MMPCgjqiFR7rmnTpqlOnTops9msOnTooEaNGqUee+yxo76mhroe1XrhhRcUoP73v/8ppfyLV/7zn/9UAwcOVDabTYWHh6s+ffqoP/7xj2rXrl2B51VXV6s777xTdezYUdlsNnXmmWeq1atXq6ioKDVz5szAfo39u1BKqY8//liNGzdORUZGKqvVqtLS0tQVV1yhlixZopRSKjc3V02dOlX16dNHhYWFqfDwcDVgwAD173//O/BvafXq1eqyyy5TaWlpymq1qri4ODVmzBj16aefBp2LBrowbdq0SU2ePFlFRUUpi8WiBg4cWO/3WdvN6r333gvafqTfvxDixJMx55C2NuYo5f8dPPvss2rkyJEqMjJSmUwmlZycrH71q1+pL774IrBfQ90C9+/fry6//HIVExOjIiIi1IQJE9TmzZtVWlpaUDfae++9Vw0dOlTFxMQoq9WqunXrpmbOnKkKCgqUUk0bP2p/B8faLVAppbZu3ap+/etfq7i4uMDvYOrUqaq6uloppZTL5VJ//vOfVadOnZTNZlNnnHGG+vjjj9X1119f79/IkiVL1ODBg5XVag3qvlu3W2CtV155JfC7j4qKUpdcconasmVL0D7XX3+9CgsLq/c7CuVC06caTSmlTnQCJ4Ro2FtvvcVvf/tbvv/+e0aNGhXqcJpl1apVjB49mvnz53PNNdeEOhwhhBBH0Z7HHCHaC0muhGglb7/9NgcOHOD000/HYDDwww8/8NRTTzF48OBA29y2avHixaxevZohQ4Zgt9v5+eef+fvf/05UVBS//PJLva5EQgghQqs9jzlCtGdyz5UQrSQiIoJ33nmHxx57jMrKSpKSkpg6dSqPPfZYqEM7qsjISL7++muefvppysvLiY+PZ+LEiTzxxBOSWAkhRBvUnsccIdozmbkSQgghhBBCiBYQ0lbsK1asYPLkySQnJ6NpGh9//PFRn7N8+XKGDBmCzWajW7dux71ugRBCiFPLiy++SNeuXbHZbAwZMoSVK1cecd/s7GyuueYaevfujcFg4I477mhwvw8++IB+/fphtVrp168fH3300QmKXgghRFsW0uSqsrKSgQMH8vzzzzdp/4yMDC666CLOPvtsNm7cyH333cdtt93GBx98cIIjFUIIcTJYsGABd9xx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yQElVyIiIiIiIjmg5EpERERERCQHlFyJiIiIiIjkgJIrERERERGRHFByJSIiIiIikgNKrkRERERERHJAyZWIiIiIiEgOKLkSERERERHJASVXIiIiIiIiOaDkSkREREREJAeUXImIiIiIiOSAkisREREREZEcUHIlIiIiIiKSA0quREREREREckDJlYiIiIiISA4ouRIREREREckBJVciIiIiIiI5oORKREREREQkB5RciYiIiIiI5ICSKxERERERkRxQciUiIiIiIpIDSq5ERERERERyQMmViIiIiIhIDii5EhERERERyQElVyIiIiIiIjmg5EpERERERCQHlFyJiIiIiIjkgJIrERERERGRHFByJSIiIiIikgNKrkRERERERHJAyZWIiIiIiEgOKLkSERERERHJASVXIiIiIiIiOaDkSkREREREJAeUXImIiIiIiOSAkisREREREZEcUHIlIiIiIiKSA0quREREREREckDJlYiIiIiISA4ouRIREREREckBJVciIiIiIiI5oORKREREREQkB/KeXM2dO5eRI0cSCASYNGkSixcv3uP+ixYtYtKkSQQCAY455hh+/etfH6RIRUTkSHAg2p0//vGPjB07Fr/fz9ixY3n22WcPVPgiInIIy2tyNW/ePG655Ra++93vsmLFCqZPn85FF11EbW1tr/vX1NRw8cUXM336dFasWMF//Md/cPPNN/PHP/7xIEcuIiKHowPR7ixdupSrr76aa6+9llWrVnHttdfyuc99jjfeeONgvSwRETlEGK7ruvl68ilTpjBx4kQeeOCBzLYxY8Zw+eWXM2fOnB77f+c73+Evf/kLa9euzWybOXMmq1atYunSpVk9Z2trK8XFxdRtrmXgoKH7/yJERCRrXe/BLS0tFBUVHfTnPxDtztVXX01rayvPPfdcZp8LL7yQ0tJSnnjiiaziyvd5ERE5WuX6/deTg5j2SSKRYNmyZdx2223dts+YMYMlS5b0+pilS5cyY8aMbtsuuOACHnnkEZLJJF6vt8dj4vE48Xg8c7ulpQWAtrY2gq2t+/syRERkL7R2vu/m43u9A9XuLF26lFtvvbXHPvfcc0+fsfTVNrWqXRIROahy3S7lLblqaGjAtm2qqqq6ba+qqqK+vr7Xx9TX1/e6fyqVoqGhgerq6h6PmTNnDrNnz+6x/bgTTtyP6EVEZH+0tbVRXFx8UJ/zQLU7fe3T1zGh77Zp6FCNqBARyYdctUt5S666GIbR7bbruj229bd/b9u73H777cyaNStz23EcmpqaKC8v3+PzHEytra0MHTqUTZs2aTjIftK5zA2dx+zoPGVn1/NUWFhIW1sbgwYNyls8B6Ld2dtjqm06eug85obOY3Z0nrJzINulvCVXFRUVWJbV45u9bdu29fgGsMvAgQN73d/j8VBeXt7rY/x+P36/v9u2kpKSfQ/8ACoqKtIfQo7oXOaGzmN2dJ6y03WeDnaPVZcD1e70tU9fxwS1TUcjncfc0HnMjs5Tdg5Eu5S3aoE+n49JkyaxcOHCbtsXLlzItGnTen3M1KlTe+y/YMECJk+e3Ot8KxERkS4Hqt3pa5++jikiIkeuvJZinzVrFv/93//Nb37zG9auXcutt95KbW0tM2fOBNLDJq677rrM/jNnzmTjxo3MmjWLtWvX8pvf/IZHHnmEb33rW/l6CSIichg5EO3ON77xDRYsWMBPfvIT3n//fX7yk5/w4osvcssttxzslyciInmW1zlXV199NY2Njdx1113U1dUxbtw45s+fz/DhwwGoq6vrtvbIyJEjmT9/Prfeeiv3338/gwYN4t577+XKK6/M10vICb/fzw9+8IMeQ0Rk7+lc5obOY3Z0nrJzKJ2nA9HuTJs2jT/84Q/ccccdfO9732PUqFHMmzePKVOmHPTXl0uH0r/b4UznMTd0HrOj85SdA3me8rrOlYiIiIiIyJEir8MCRUREREREjhRKrkRERERERHJAyZWIiIiIiEgOKLkSERERERHJASVXcsSYO3cuI0eOJBAIMGnSJBYvXpzvkERE5Cimdknk6KPk6jB2xRVXUFpaylVXXZXvUPJu3rx53HLLLXz3u99lxYoVTJ8+nYsuuqhbSWXJDV13/du0aROf+tSnGDt2LBMmTOCpp57Kd0iHpLa2Nk499VROPvlkxo8fz8MPP5zvkCQH9B6Rpnbp4NJ11z+1TdnZ37ZJpdgPYy+//DLt7e38z//8D08//XS+w8mrKVOmMHHiRB544IHMtjFjxnD55ZczZ86cPEZ25NF117+6ujq2bt3KySefzLZt25g4cSLr1q0jFArlO7RDim3bxONxgsEgkUiEcePG8dZbb1FeXp7v0GQ/6D0iTe3SwaXrrn9qm7Kzv22Teq4OY//0T/9EYWFhvsPIu0QiwbJly5gxY0a37TNmzGDJkiV5iurIpeuuf9XV1Zx88skADBgwgLKyMpqamvIb1CHIsiyCwSAAsVgM27bR932HP71HqF3KB113/VPblJ39bZuUXOXBq6++ymWXXcagQYMwDIM//elPve6nsdrZaWhowLZtqqqqum2vqqqivr4+T1EdmrK59nTd5fY8vf322ziOw9ChQw9w1AdfLs5Tc3MzJ510EkOGDOHf//3fqaioOEjRy+7UNuWO2qW9o7YpO2qbspPvtknJVR50dHRw0kkncd999/W5j8Zq7z3DMLrddl23x7ajXX/Xnq67tFydp8bGRq677joeeuihgxH2QZeL81RSUsKqVauoqanh8ccfZ+vWrQcrfNmN2qbcU7uUHbVN2VHblJ28t02u5BXgPvvssz22n3baae7MmTO7bTvhhBPc2267rdu2l19+2b3yyisPZIiHvHg87lqW5T7zzDPdtt98883uWWedlaeoDn29XXu67nra1/MUi8Xc6dOnu7/73e8ORph5tz/XU5eZM2e6Tz755IEKUfaC2qb9o3Zp36ltyo7apuzko21Sz9UhSGO1947P52PSpEksXLiw2/aFCxcybdq0PEV1+NF1l51szpPrunzlK1/hnHPO4dprr81HmHmXzXnaunUrra2tALS2tvLqq69y/PHHH/RYJTt6j8ie2qXc0XWXHbVN2TkYbZMnd+FKrmQ7VvuCCy5g+fLldHR0MGTIEJ599llOPfXUgx3uIWHWrFlce+21TJ48malTp/LQQw9RW1vLzJkz8x3aYUPXXXayOU+vvfYa8+bNY8KECZmx3r///e8ZP378wQ43b7I5T5988gnXX389ruviui433XQTEyZMyEe4kgW9R+wdtUu5oesuO2qbsnMw2iYlVzly5513Mnv27D3u89ZbbzF58uSsj9nfWO0XXnhh74I8gl199dU0NjZy1113UVdXx7hx45g/fz7Dhw/Pd2iHHV132dnTeTrzzDNxHCcfYR1y9nSeJk2axMqVK/MQ1dFDbVP+qF3KLV132VHblJ0D2TYpucqRm266ic9//vN73GfEiBFZHauiogLLsnpUFNq2bVuPTFt2uvHGG7nxxhvzHcZhS9dddnSesqPzdGhQ25Rfapf2n6677Og8ZedgnCfNucqRiooKTjjhhD3+BAKBrI6lsdqSD7rusqPzlB2dp0OD2iY53Om6y47OU3YOxnlSz1UetLe38+GHH2Zu19TUsHLlSsrKyhg2bBigsdpyYPR37em6S9N5yo7O05FFbZPki95LsqPzlJ28n6es6wpKzrz88ssu0OPny1/+crf97r//fnf48OGuz+dzJ06c6C5atCg/AcsRI5trT9edzlO2dJ6OLGqbJF/0XpIdnafs5Ps8Ga7rurlJ00RERERERI5emnMlIiIiIiKSA0quREREREREckDJlYiIiIiISA4ouRIREREREckBJVciIiIiIiI5oORKREREREQkB5RciYiIiIiI5ICSKxERERERkRxQciUiIiIiIpIDSq5EDiN33HEHfr+fL3zhC/kORUREBFDbJLIrw3VdN99BiEh2Wltb+f3vf89NN93EBx98wOjRo/MdkoiIHOXUNonspJ4rkcNIUVERX/3qVzFNk9WrV+c7HBEREbVNIrtQciVymEmlUgSDQd599918hyIiIgKobRLpouRK5DBzxx130N7ergZMREQOGWqbRNI050rkMLJs2TKmTZvG+eefT01NDWvWrMl3SCIicpRT2ySyk5IrkcOE4zicdtppnH322UyZMoUvfvGLdHR04PP58h2aiIgcpdQ2iXSnYYEih4n/+q//Yvv27dx1112MHz+eVCrFunXr8h2WiIgcxdQ2iXSn5ErkMLB582a+973vMXfuXEKhEMceeyx+v19j20VEJG/UNon0pORK5DBw8803c9FFF3HJJZcA4PF4GDNmjBowERHJG7VNIj158h2AiOzZ3/72N1566SXWrl3bbfv48ePVgImISF6obRLpnQpaiIiIiIiI5ICGBYqIiIiIiOSAkisREREREZEcUHIlIiIiIiKSA0quREREREREckDJlYiIiIiISA4ouRIREREREckBJVciIiIiIiI5oORKREREREQkB5RciYiIiIiI5ICSKxERERERkRxQciUiIiIiIpIDSq5ERERERERy4P8HKvVd7xJm3HMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "color_cycle = plt.rcParams['axes.prop_cycle'].by_key()['color']\n",
    "marker_cycle = ['o', 's', 'd', 'v', '^', '<', '>', 'p', 'h', '*']\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(10, 4))\n",
    "\n",
    "too_big_idx = np.max(np.where(np.mean(test_reg_errs[:, 0, :], axis=0) > 1)[0])\n",
    "# too_big_idx = 5\n",
    "\n",
    "for sketch_i, sketch in enumerate(sketches):\n",
    "\n",
    "    for k, K in enumerate(Ks):\n",
    "        markevery = (5, 20)\n",
    "        axes[0].plot(lamdas, np.mean(cv_reg_errs[:, sketch_i, k, :], axis=0), color=color_cycle[k])\n",
    "        axes[0].errorbar(lamdas, np.mean(cv_reg_errs[:, sketch_i, k, :], axis=0), yerr=np.std(cv_reg_errs[:, sketch_i, k, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[k], color=color_cycle[k], capsize=3, label=f'CV, K={K}')\n",
    "\n",
    "        axes[1].plot(lamdas, np.mean(cv_cls_errs[:, sketch_i, k, :], axis=0), color=color_cycle[k])\n",
    "        axes[1].errorbar(lamdas, np.mean(cv_cls_errs[:, sketch_i, k, :], axis=0), yerr=np.std(cv_cls_errs[:, sketch_i, k, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[k], color=color_cycle[k], capsize=3, label=f'CV, K={K}')\n",
    "\n",
    "    markevery = (5, 20)\n",
    "    axes[0].plot(lamdas, np.mean(test_reg_errs[:, sketch_i, :], axis=0), color=color_cycle[len(Ks)])\n",
    "    axes[0].errorbar(lamdas, np.mean(test_reg_errs[:, sketch_i, :], axis=0), yerr=np.std(test_reg_errs[:, sketch_i, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[len(Ks)], color=color_cycle[len(Ks)], capsize=3, label='Test')\n",
    "    axes[0].plot(lamdas, gcv_reg_errs[:, sketch_i, :].T, color=color_cycle[len(Ks) + 1], alpha=0.5, label=['GCV'] + [None] * (n_trials - 1))\n",
    "    # axes[0].plot(lamdas, np.mean(gcv_reg_errs[:, sketch_i, :], axis=0), color=color_cycle[len(Ks) + 1])\n",
    "    # axes[0].errorbar(lamdas, np.mean(gcv_reg_errs[:, sketch_i, :], axis=0), yerr=np.std(gcv_reg_errs[:, sketch_i, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[len(Ks) + 1], color=color_cycle[len(Ks) + 1], capsize=3, label='GCV')\n",
    "\n",
    "    axes[1].plot(lamdas, np.mean(test_cls_errs[:, sketch_i, :], axis=0), color=color_cycle[len(Ks)])\n",
    "    axes[1].errorbar(lamdas, np.mean(test_cls_errs[:, sketch_i, :], axis=0), yerr=np.std(test_cls_errs[:, sketch_i, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[len(Ks)], color=color_cycle[len(Ks)], capsize=3)\n",
    "    axes[1].plot(lamdas, gcv_cls_errs[:, sketch_i, :].T, color=color_cycle[len(Ks) + 1], alpha=0.5)\n",
    "    # axes[1].plot(lamdas, np.mean(gcv_cls_errs[:, sketch_i, :], axis=0), color=color_cycle[len(Ks) + 1])\n",
    "    # axes[1].errorbar(lamdas, np.mean(gcv_cls_errs[:, sketch_i, :], axis=0), yerr=np.std(gcv_cls_errs[:, sketch_i, :], axis=0), errorevery=markevery, markevery=markevery, marker=marker_cycle[len(Ks) + 1], color=color_cycle[len(Ks) + 1], capsize=3, label='GCV')\n",
    "\n",
    "axes[0].legend()\n",
    "axes[0].set_xlabel(r'$\\lambda$')\n",
    "axes[0].set_title('RCV1 Ridge Regression')\n",
    "axes[0].set_ylabel('MSE')\n",
    "axes[0].set_xscale('symlog', linthresh=10)\n",
    "axes[0].set_xlim(lamdas[too_big_idx - 5], 1.1e3)\n",
    "axes[0].set_ylim(0, 1)\n",
    "\n",
    "axes[1].set_title('RCV1 Ridge Classification')\n",
    "axes[1].set_xlabel(r'$\\lambda$')\n",
    "axes[1].set_ylabel('Classification Error')\n",
    "axes[1].set_xscale('symlog', linthresh=10)\n",
    "axes[1].set_xlim(lamdas[too_big_idx - 5], 1.1e3)\n",
    "axes[1].set_ylim(0, 0.1)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Clasification Test Error\n",
      "K=2: 0.03876 +- 0.00132605\n",
      "GCV: 0.03866 +- 0.00102\n",
      "Regression Test Error\n",
      "K=2: 0.215658 +- 0.00239273\n",
      "GCV: 0.213941 +- 0.00237626\n"
     ]
    }
   ],
   "source": [
    "print('Clasification Test Error')\n",
    "\n",
    "cv_min_idx = np.argmin(cv_cls_errs, axis=3)[:, sketch_i]\n",
    "gcv_min_idx = np.argmin(gcv_cls_errs, axis=2)[:, sketch_i]\n",
    "\n",
    "for k, K in enumerate(Ks):\n",
    "\n",
    "    test_mean = np.mean([test_cls_errs[i, sketch_i, cv_min_idx[i, k]] for i in range(n_trials)])\n",
    "    test_std = np.std([test_cls_errs[i, sketch_i, cv_min_idx[i, k]] for i in range(n_trials)])\n",
    "\n",
    "    print(f'K={K}: {test_mean:6g} +- {test_std:6g}')\n",
    "\n",
    "test_mean = np.mean([test_cls_errs[i, sketch_i, gcv_min_idx[i]] for i in range(n_trials)])\n",
    "test_std = np.std([test_cls_errs[i, sketch_i, gcv_min_idx[i]] for i in range(n_trials)])\n",
    "\n",
    "print(f'GCV: {test_mean:6g} +- {test_std:6g}')\n",
    "\n",
    "print('Regression Test Error')\n",
    "\n",
    "cv_min_idx = np.argmin(cv_reg_errs, axis=3)[:, sketch_i]\n",
    "gcv_min_idx = np.argmin(gcv_reg_errs, axis=2)[:, sketch_i]\n",
    "\n",
    "for k, K in enumerate(Ks):\n",
    "\n",
    "    test_mean = np.mean([test_reg_errs[:, sketch_i, cv_min_idx[i, k]] for i in range(n_trials)])\n",
    "    test_std = np.std([test_reg_errs[:, sketch_i, cv_min_idx[i, k]] for i in range(n_trials)])\n",
    "\n",
    "    print(f'K={K}: {test_mean:6g} +- {test_std:6g}')\n",
    "\n",
    "test_mean = np.mean([test_reg_errs[:, sketch_i, gcv_min_idx[i]] for i in range(n_trials)])\n",
    "test_std = np.std([test_reg_errs[:, sketch_i, gcv_min_idx[i]] for i in range(n_trials)])\n",
    "\n",
    "print(f'GCV: {test_mean:6g} +- {test_std:6g}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.17"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
