{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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\n",
    "\n",
    "import numpy as np\n",
    "#Xfull = np.genfromtxt('/home/will/projects/model_selection/data/bcTCGA/bcTCGA-X.txt', delimiter=',', skip_header=1)\n",
    "#Xfull = Xfull[:,1:]\n",
    "#Y = np.genfromtxt('/home/will/projects/model_selection/data/bcTCGA/bcTCGA-Y.txt', delimiter=',', skip_header=1)\n",
    "#Y = Y[:,1]\n",
    "Xfull = np.loadtxt('/home/will/projects/model_selection/data/lifeExpectency/X.txt')\n",
    "Y = np.loadtxt('/home/will/projects/model_selection/data/lifeExpectency/Y.txt')\n",
    "\n",
    "Y -= Y.mean()\n",
    "Ufull, Sfull, Vfull = np.linalg.svd(Xfull, full_matrices=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-175-677d7045b02d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     20\u001b[0m         \u001b[0mthetaHat\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlinalg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msolve\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m \u001b[0;34m@\u001b[0m \u001b[0mX\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mlam\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meye\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mD\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m \u001b[0;34m@\u001b[0m \u001b[0mY\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m         Qs = np.einsum('nd,nd->n',\n\u001b[0;32m---> 22\u001b[0;31m                        \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlinalg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msolve\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m \u001b[0;34m@\u001b[0m \u001b[0mX\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mlam\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meye\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mD\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mX\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     23\u001b[0m                        X)\n\u001b[1;32m     24\u001b[0m         \u001b[0mXtheta\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mX\u001b[0m \u001b[0;34m@\u001b[0m \u001b[0mthetaHat\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "nTrial = 500\n",
    "D = 15\n",
    "lams = np.logspace(-8,6,600)\n",
    "indsChosen = np.empty((nTrial,D), dtype=np.int)\n",
    "losses = np.empty((nTrial,lams.shape[0]))\n",
    "nonQVX = np.empty(nTrial, dtype=np.bool)\n",
    "N = Y.shape[0]\n",
    "\n",
    "for tt in range(nTrial):\n",
    "    Ds = np.random.choice(np.arange(D), replace=False, size=D).astype(np.int32)\n",
    "    indsChosen[tt] = Ds\n",
    "    #X = Ufull[:,Ds] @ np.diag(Sfull[Ds]) @ Vfull[Ds]\n",
    "    X = Xfull[:,Ds]\n",
    "    X -= np.mean(X, axis=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",
    "    losses[tt] = lossesLOO.mean(1)\n",
    "    nonQVX[tt] = expUtils.findNonQVXInds(lossesLOO.mean(1)).shape[0] > 0\n",
    "\n",
    "\n",
    "print(np.any(nonQVX))\n",
    "print(nonQVX)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "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": [
    "## Code for bcTCGA\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",
    "    #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",
    "    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": 181,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-181-a921d135c13c>: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": [
    "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.savefig('/home/will/projects/model_selection/neurips2021/figs/lifeExpectency_nonQVX_SVD_D=15.png')\n",
    "\n",
    "\n",
    "plt.show()\n",
    "#for dd in nonQVXDs:\n",
    "#    plt.plot(lams, losses[dd])\n",
    "#    plt.xscale('log')\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 w/ simulated responses\n",
    "np.random.seed(1621624513)\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.savefig('/home/will/projects/model_selection/neurips2021/figs/introExample_wine.png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": [
    "# Cartoon example 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, lossesLOO.mean(1), label='LOOCV loss')\n",
    "plt.title(f'Cartoon LOOCV', fontsize=24)\n",
    "plt.xlabel('$\\lambda$', fontsize=24)\n",
    "plt.ylabel('LOOCV($\\lambda$)', fontsize=24)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.xscale('log')\n",
    "plt.tight_layout()\n",
    "plt.savefig('/home/will/Dropbox/neurips2021/cartoonLOOCV.png')\n",
    "plt.show()"
   ]
  },
  {
   "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 with simulated responses\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",
    "#seed = int(time.time())\n",
    "#np.random.seed(seed)\n",
    "#print(seed)\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 = X @ theta + np.random.normal(size=N, scale=100*S[-1] / N)\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",
    "#ind = np.where(nonQVX)[0][1]\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.savefig('/home/will/projects/model_selection/neurips2021/figs/introExample_wine1.png')\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.savefig('/home/will/projects/model_selection/neurips2021/figs/introExample_wine2.png')\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.savefig('/home/will/projects/model_selection/neurips2021/figs/introExample_wine1.png')\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.savefig('/home/will/projects/model_selection/neurips2021/figs/introExample_wine2.png')\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
}
