{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "import expUtils\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2938, 20) (2938,)\n",
      "True\n",
      "[False False False False False False  True  True  True  True  True  True\n",
      " False  True False False False False]\n"
     ]
    }
   ],
   "source": [
    "## Life expectancy experiment\n",
    "Xfull = LOAD COVARIATE MTX HERE\n",
    "Y = LOAD RESPONSES HERE\n",
    "\n",
    "Y -= Y.mean()\n",
    "Ufull, Sfull, Vfull = np.linalg.svd(Xfull, full_matrices=False)\n",
    "print(Xfull.shape, Y.shape)\n",
    "Ds = np.arange(2,20,1)\n",
    "lams = np.logspace(-8,6,600)\n",
    "losses = np.empty((Ds.shape[0],lams.shape[0]))\n",
    "nonQVX = np.empty(Ds.shape[0], dtype=np.bool)\n",
    "N = Y.shape[0]\n",
    "\n",
    "for dd, D in enumerate(Ds):\n",
    "    X = Ufull[:,:D] @ np.diag(Sfull[:D])\n",
    "    X -= np.mean(X, axis=0)\n",
    "    X /= np.sqrt(np.var(X, axis=0))\n",
    "    \n",
    "    lossesLOO = np.empty((lams.shape[0],N))\n",
    "    for ll, lam in enumerate(lams):\n",
    "        thetaHat = np.linalg.solve(X.T @ X + lam*np.eye(D), X.T @ Y)\n",
    "        Qs = np.einsum('nd,nd->n',\n",
    "                       np.linalg.solve(X.T @ X + lam*np.eye(D), X.T).T,\n",
    "                       X)\n",
    "        Xtheta = X @ thetaHat\n",
    "        predsLOO = Xtheta + Qs * (Xtheta - Y) / (1-Qs)\n",
    "        lossesLOO[ll] = (Y - predsLOO)**2\n",
    "    losses[dd] = lossesLOO.mean(1)\n",
    "    nonQVX[dd] = expUtils.findNonQVXInds(lossesLOO.mean(1)).shape[0] > 0\n",
    "\n",
    "\n",
    "print(np.any(nonQVX))\n",
    "print(nonQVX)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-4-6524e897fd34>:19: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Life expectancy plotting\n",
    "nonQVXDs = np.where(nonQVX)[0]\n",
    "ind = nonQVXDs[-1]\n",
    "fig, ax1 = plt.subplots()\n",
    "ax1.plot(lams, losses[ind])\n",
    "plt.xscale('log')\n",
    "plt.xlabel(r'$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.title(f'Life expectancy, $N={N}, D={Ds[ind]}$', fontsize=18)\n",
    "left, bottom, width, height = [0.32, 0.42, 0.45, 0.45]\n",
    "ax2 = fig.add_axes([left, bottom, width, height])\n",
    "upTo = 415\n",
    "ax2.plot(lams[:upTo], losses[ind,:upTo])\n",
    "plt.xlabel(r'$\\lambda$', fontsize=16)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=16)\n",
    "plt.xscale('log')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Wine dataset with synthetic responses; this actually didn't make it into the paper.\n",
    "np.random.seed(1621624513) # Some made up random seed so this is replicable\n",
    "Xfull = np.loadtxt('../../data/wine/X_redwine.txt')\n",
    "\n",
    "nTrial = 400\n",
    "M = 100\n",
    "lams = np.logspace(-8, 8.0, 200) * M\n",
    "lams = np.append(0.0, lams)\n",
    "subsetInds = np.empty((nTrial,M))\n",
    "nonQVX = np.empty(nTrial, dtype=np.bool)\n",
    "allLosses = np.empty((nTrial,lams.shape[0]))\n",
    "\n",
    "for tt in range(nTrial):\n",
    "  subInds = np.random.choice(np.arange(Xfull.shape[0]), replace=False, size=M)\n",
    "  X = Xfull[subInds]\n",
    "  (N,D) = X.shape\n",
    "  U, S, V = np.linalg.svd(X)\n",
    "  theta = V[-1]\n",
    "  Y = X @ theta + np.random.normal(size=N, scale=100*S[-1] / N)\n",
    "\n",
    "  X -= X.mean(0)\n",
    "  X /= np.sqrt(np.var(X, axis=0))\n",
    "  Y -= Y.mean()\n",
    "\n",
    "  lossesLOO = np.empty((lams.shape[0],N))\n",
    "  for ll, lam in enumerate(lams):\n",
    "    thetaHat = np.linalg.solve(X.T @ X + lam*np.eye(D), X.T @ Y)\n",
    "    Qs = np.einsum('nd,nd->n',\n",
    "                   np.linalg.solve(X.T @ X + lam*np.eye(D), X.T).T,\n",
    "                   X)\n",
    "    Xtheta = X @ thetaHat\n",
    "    predsLOO = Xtheta + Qs * (Xtheta - Y) / (1-Qs)\n",
    "    lossesLOO[ll] = (Y - predsLOO)**2\n",
    "  allLosses[tt] = lossesLOO.mean(1)\n",
    "  nonQVX[tt] = expUtils.findNonQVXInds(lossesLOO.mean(axis=1)).shape[0] > 0\n",
    "\n",
    "\n",
    "ind = np.where(nonQVX)[0][1]  \n",
    "plt.plot(lams, allLosses[ind])\n",
    "plt.title(f'Wine, $N=${M}, $D=${D}', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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06d57rnncpUdOHCA1157jfbt29s7SFStWhUfHx927NiRrW7Onm9gDf2fkpKSbV1AQACRkZHZFoAKFSrQvHlz/ve//2W7BHjo0CFWr15d4MjKDRo0yNZeZoLKqnbt2jz55JM0bdrUHntmIsr6LMqePXtYtWpVvvsqjq+++irbz1988QX+/v40adIkz/pt2rQhICCAffv25TpmkZGRhb6026FDB9auXZvtjDk9PZ0vv/ySZs2a5Up4IsKNN97IW2+9BZDrdw55H1dX8vf3x9/f3+X7KapffvmFcePGcdddd10RybSsKQ1nUEeA0cBerIQ5EJgjIs1VdRvwFtAJuA84ALQHPhSRU6o6000xl1odO3bkpZdeYty4cRw8eJABAwYQHBzM5s2befXVVwkKCmLmzL8Pm4jQr18/PvroI+rXr0+DBg344Ycf8rxH1rhxY37++WfmzZtHWFgYoaGhBXbIePnll+nRowc9e/bk0UcfJSkpifHjxxMUFMSTTz5Z6NcWFRVFTEwMTZs2xd/fnxUrVvDLL78wcOBAwLp05unpyYABA3jyySc5duwY48ePp1atWg51/y6sDz/8kIyMDFq0aMGiRYuYPn06EyZMyHeOnMDAQN544w2GDRvGyZMn6datG0FBQRw9epQVK1YQHR2drfPC5YwaNYq4uDg6d+7Miy++SGBgIO+//z579uyxf8DYtm0bI0aMoF+/ftStW5f09HTi4uLw9PS0n0Vf7ri6UuYDrm3atHH5voqiQoUKxMTEMHXqVDNArjuoaqlbgDPAI7bvdwAv5ihfAbzrSFvNmzfXgvz2228Fll+pFixYoF26dNGKFSuqt7e31q1bV5966ik9ffp0rrrx8fHav39/DQkJ0eDgYH3kkUd03rx5CuhPP/1kr7dz505t166d+vr6KqADBw50KI7WrVtr+fLlNTAwUGNiYnTXrl3Z6jz//PNq/SkW7JlnntEbb7xRAwMD1c/PT5s0aaKTJ0/OVufLL7/UBg0aqI+PjzZu3Fg///xzHThwoNauXdte58CBAwrohx9+mG3b8ePHK6CpqanZ1teuXVvvvffeXPW2b9+u0dHRWr58ea1ataqOHTtW09PT7fV++umnXMdQVfWHH37Q6OhoDQgI0PLly+u1116rgwcP1l9//bXA19+hQwft0KFDtnW7du3SXr16aWBgoPr4+GirVq10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ceNGfvvtNwYOHOhwG5ni4+NRVapVq5arLCwsjDNnzgBQt25dFi1aREZGBvfddx9hYWG0atXKnsBEhCVLlhAZGcmzzz5L/fr1iYiIYOrUqYWOySidvvzyS9q2bUuNGjXcHYqRD5OgrjIdO3bk+PHjbNiwIc/y9evXc+LECfvlrsjISAIDA/nuu+/ybfO7774jKCiIm266CYBOnTpx/Phx+zhrjhg4cCCHDx9m+fLlzJw5Ex8fH/r161eIV2YJDg5GRDh+/HiusuPHjxMSEmL/+ZZbbmHhwoWcPXuWpUuX4uXlRY8ePTh16hQAERERfMtE/loAACAASURBVPLJJ5w8eZItW7Zw66238uijj5r7FU7k5eWFl5dXie93586d7Nixo0h/Y0YJyqtrX1laTDfz7E6ePKnBwcEFdjOvVKlStm7mY8eOvWw383HjxtnXnT59WkNDQ/PtZp6cnKxLlizJtu78+fMaFBSk/fv318qVK+udd97p8GsmRzfzyMhIbdCggaalpdnXHTx4UL28vPSJJ57It525c+cqoOvXr8+zPCEhQQF9/fXXHY6tLLuSu5mnpaXpihUr8ny8wSh55NPN3NyDKqMWLlxIWFhYtnVBQUF07tyZzz//nNjYWKKiohg1apT9Qd23336bXbt2MXv27GxnGuPGjWPjxo307duXYcOG0a1bN/uDulOmTKFr166MHTvWXr9SpUp88803xMTEcNNNN/H444/bH9Rdv34906ZNo0+fPtkeBvb19eWuu+7io48+QlWLdHkv08svv0yPHj3o2bMnjz76KElJSYwfP56goCD7g6HTpk1j5cqVdO/enZo1a3Lq1CkmTpxI9erVadKkCdu2bWPEiBH069ePunXrkp6eTlxcHJ6enma06zLAw8OD9u3buzsM43Lyylplablaz6DyWq677jp7vd9++0379++v1apVUy8vLw0LC9N77rlHf/311zzbTU1N1XfffVcjIyPVz89P/fz8tHnz5jplyhRNTU3Nc5uDBw/qsGHDNCIiQr29vbVChQoaGRmpEydO1ISEhFz1f/75ZwW0cuXK+baZF/J4UHfBggXaunVrLV++vAYGBmpMTIzu2rXLXr569WqNiYnRGjVqqLe3t4aFhWmfPn3sdU6cOKEDBgzQevXqqa+vrwYHB2v79u114cKFDsdV1jnjDGrevHk6b948Z4Z1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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Cartoon example from introduction. \n",
    "# We actually made this w/ synthetic data\n",
    "np.random.seed(1621624513)\n",
    "N = 50\n",
    "D = 11\n",
    "noiseVar = 5.2\n",
    "lams = np.logspace(-8,6,600)\n",
    "theta = np.random.normal(size=D)\n",
    "X = np.random.normal(size=(N,D))\n",
    "Y = X @ theta + np.random.normal(size=N, scale=noiseVar)\n",
    "\n",
    "Ntest = 10000\n",
    "Xtest = np.random.normal(size=(Ntest,D))\n",
    "Ytest = Xtest @ theta + np.random.normal(size=Ntest, scale=noiseVar)\n",
    "\n",
    "\n",
    "lossesLOO = np.empty((lams.shape[0],N))\n",
    "lossesTest = np.empty(lams.shape[0])\n",
    "for ll, lam in enumerate(lams):\n",
    "    thetaHat = np.linalg.solve(X.T @ X + lam*np.eye(D), X.T @ Y)\n",
    "    Qs = np.einsum('nd,nd->n',\n",
    "                   np.linalg.solve(X.T @ X + lam*np.eye(D), X.T).T,\n",
    "                   X)\n",
    "    Xtheta = X @ thetaHat\n",
    "    predsLOO = Xtheta + Qs * (Xtheta - Y) / (1-Qs)\n",
    "    lossesLOO[ll] = (Y - predsLOO)**2\n",
    "    \n",
    "    lossesTest[ll] = ((Ytest - Xtest @ thetaHat)**2).mean()\n",
    "\n",
    "\n",
    "plt.plot(lams, lossesTest, c='k', linestyle='--', label='Out-of-sample loss')\n",
    "plt.plot(lams, lossesLOO.mean(1), label='LOOCV loss')\n",
    "plt.gca().axvline(lams[np.argmin(lossesLOO.mean(1))], alpha=0.6)\n",
    "plt.gca().axvline(lams[np.argmin(lossesTest)], c='k', linestyle='--', alpha=0.6)\n",
    "plt.title(f'Idealized illustration', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.legend(fontsize=16)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:14<00:00, 70.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Wine dataset example from introduction\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "import expUtils\n",
    "import time\n",
    "\n",
    "np.random.seed(1621624513)\n",
    "Xfull = np.loadtxt('../../data/wine/X_redwine.txt')\n",
    "Yfull = np.loadtxt('../../data/wine/Y_redwine.txt')\n",
    "\n",
    "nTrial = 1000\n",
    "M = 50\n",
    "lams = np.logspace(-8, 8.0, 200) * M\n",
    "lams = np.append(0.0, lams)\n",
    "subsetInds = np.empty((nTrial,M))\n",
    "nonQVX = np.empty(nTrial, dtype=np.bool)\n",
    "allLosses = np.empty((nTrial,lams.shape[0]))\n",
    "\n",
    "for tt in tqdm(range(nTrial)):\n",
    "  subInds = np.random.choice(np.arange(Xfull.shape[0]), replace=False, size=M)\n",
    "  X = Xfull[subInds]\n",
    "  (N,D) = X.shape\n",
    "  U, S, V = np.linalg.svd(X)\n",
    "  theta = V[-1]\n",
    "  Y = Yfull[subInds]\n",
    "\n",
    "  X -= X.mean(0)\n",
    "  X /= np.sqrt(np.var(X, axis=0))\n",
    "  Y -= Y.mean()\n",
    "\n",
    "  lossesLOO = np.empty((lams.shape[0],N))\n",
    "  for ll, lam in enumerate(lams):\n",
    "    thetaHat = np.linalg.solve(X.T @ X + lam*np.eye(D), X.T @ Y)\n",
    "    Qs = np.einsum('nd,nd->n',\n",
    "                   np.linalg.solve(X.T @ X + lam*np.eye(D), X.T).T,\n",
    "                   X)\n",
    "    Xtheta = X @ thetaHat\n",
    "    predsLOO = Xtheta + Qs * (Xtheta - Y) / (1-Qs)\n",
    "    lossesLOO[ll] = (Y - predsLOO)**2\n",
    "  allLosses[tt] = lossesLOO.mean(1)\n",
    "  nonQVX[tt] = expUtils.findNonQVXInds(lossesLOO.mean(axis=1)).shape[0] > 0\n",
    "print(nonQVX.sum())\n",
    "\n",
    "# Plot for two of the non-QVX losses. You can examine other losses if interested.\n",
    "ind = 173\n",
    "plt.plot(lams, allLosses[ind])\n",
    "plt.title(f'Wine dataset, $N=${M}, $D=${D}', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "ind = 129\n",
    "plt.plot(lams, allLosses[ind])\n",
    "plt.title(f'Wine dataset, $N=${M}, $D=${D}', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ind = 173\n",
    "plt.plot(lams, allLosses[ind])\n",
    "plt.title(f'Wine dataset, $N=${M}, $D=${D}', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "ind = 129\n",
    "plt.plot(lams, allLosses[ind])\n",
    "plt.title(f'Wine dataset, $N=${M}, $D=${D}', fontsize=18)\n",
    "plt.xlabel('$\\lambda$', fontsize=18)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "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.8.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
