{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.16011283 0.37691284 0.90801587 0.08535304 0.02286128]\n"
     ]
    }
   ],
   "source": [
    "import itertools\n",
    "from tqdm import tqdm\n",
    "import autograd.numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from pathos.multiprocessing import ProcessingPool\n",
    "\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "import expUtils\n",
    "\n",
    "def oneTrial(noise, U, S, theta, lams):\n",
    "    X = U @ np.diag(S)\n",
    "    Y = X @ theta + noise\n",
    "    Y -= Y.mean()\n",
    "    return expUtils.runTrialUOnlyNoisy(U, S, Y, lams)\n",
    "D = 5\n",
    "thetaStar = np.random.normal(size=D); thetaStar /= np.linalg.norm(thetaStar)\n",
    "print(thetaStar)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  0%|          | 0/4000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:02<00:00, 63.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<01:01, 65.08it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:04<00:00, 62.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<01:03, 62.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:04<00:00, 62.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<01:02, 64.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:01<00:00, 65.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<00:59, 67.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:02<00:00, 64.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<00:57, 69.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:03<00:00, 62.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 6/4000 [00:00<01:19, 50.15it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:32<00:00, 43.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 5/4000 [00:00<01:38, 40.53it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:20<00:00, 49.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<01:02, 63.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:05<00:00, 61.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<00:59, 67.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:01<00:00, 65.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 6/4000 [00:00<01:08, 58.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:03<00:00, 62.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 6/4000 [00:00<01:09, 57.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:03<00:00, 63.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<00:59, 66.83it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:00<00:00, 65.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<01:04, 62.07it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:02<00:00, 63.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 7/4000 [00:00<00:57, 69.11it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done making data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4000/4000 [01:02<00:00, 63.90it/s]\n"
     ]
    }
   ],
   "source": [
    "Ns = [20,35,50,]\n",
    "\n",
    "nUs = 4000\n",
    "nSs = 25\n",
    "nCores = 10\n",
    "\n",
    "\n",
    "nTrials = 5\n",
    "nonQVX = np.empty((nTrials, len(Ns), nUs,nSs), dtype=np.bool)\n",
    "\n",
    "alphas = np.logspace(np.log10(1e-2),np.log10(10),nSs)\n",
    "Ss = np.empty((nSs,D))\n",
    "for ss in range(nSs):\n",
    "    Ss[ss] = np.exp(np.arange(D)*alphas[ss])\n",
    "    Ss[ss] /= Ss[ss].max()\n",
    "\n",
    "for tt in range(nTrials):\n",
    "    for nn, N in enumerate(Ns):\n",
    "        lams = np.logspace(-8, 3.0, 200) * N\n",
    "        lams = np.append(0.0, lams)\n",
    "\n",
    "        print('Making data')\n",
    "        Us = np.empty((nUs,N,D))\n",
    "        for uu in range(nUs):\n",
    "            Us[uu] = expUtils.getUFast(N, D)\n",
    "\n",
    "\n",
    "        noises = np.empty((nUs,N))\n",
    "        for uu in range(nUs):\n",
    "            E = np.random.normal(scale=5.0, size=N)\n",
    "            noises[uu] = np.random.normal(scale=0.5, size=N)\n",
    "\n",
    "\n",
    "\n",
    "        print('Done making data')\n",
    "\n",
    "        for uu in tqdm(range(nUs)):\n",
    "            res = ProcessingPool(nCores).map(oneTrial,\n",
    "                                             itertools.cycle([noises[uu]]),\n",
    "                                             itertools.cycle([Us[uu]]),\n",
    "                                             Ss,\n",
    "                                             itertools.cycle([thetaStar]),\n",
    "                                             itertools.cycle([lams]))\n",
    "            nonQVX[tt,nn,uu] = np.array([r[1] for r in res])\n",
    "            #losses[ss] = np.array([r[0] for r in res])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[[0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  [0.  0.  0.  ... 0.6 0.4 0.4]\n",
      "  [0.  0.  0.  ... 0.6 0.6 0.6]\n",
      "  ...\n",
      "  [0.  0.  0.  ... 0.4 0.4 0.4]\n",
      "  [0.  0.  0.  ... 0.4 0.2 0.2]\n",
      "  [0.  0.  0.  ... 0.4 0.4 0.2]]\n",
      "\n",
      " [[0.  0.  0.  ... 0.  0.  0. ]\n",
      "  [0.  0.  0.  ... 0.6 0.6 0.6]\n",
      "  [0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  ...\n",
      "  [0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  [0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  [0.  0.  0.  ... 0.4 0.2 0.2]]\n",
      "\n",
      " [[0.  0.  0.  ... 0.6 0.6 0.6]\n",
      "  [0.  0.  0.  ... 0.4 0.4 0.4]\n",
      "  [0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  ...\n",
      "  [0.  0.  0.  ... 0.4 0.4 0.4]\n",
      "  [0.  0.  0.  ... 0.2 0.2 0.2]\n",
      "  [0.  0.  0.  ... 0.4 0.4 0.4]]]\n"
     ]
    }
   ],
   "source": [
    "colors = ['b', 'r', 'y']\n",
    "for nn in range(len(Ns)):\n",
    "    errs = 2*np.sqrt(nonQVX[:,nn,:,:].mean(1).var(0))\n",
    "    plt.errorbar(x=np.log(np.abs((Ss - np.ones(D))).sum(1)),\n",
    "                 y=nonQVX[:,nn,:].mean((0,1)),\n",
    "                 yerr=errs,\n",
    "                 c=colors[nn],\n",
    "                fmt='none')\n",
    "    plt.scatter(np.log(np.abs((Ss - np.ones(D))).sum(1)), \n",
    "                nonQVX[:,nn,:].mean((0,1)), label=f'N={Ns[nn]}', c=colors[nn])\n",
    "    #try:\n",
    "    #    biggestInd = np.where(nonQVX[nn].mean(0) == 0)[0].max()\n",
    "    #    plt.gca().axvline(np.log(np.abs((Ss - np.ones(D))).sum(1))[biggestInd])\n",
    "    #except:\n",
    "    #    print(nn)\n",
    "#plt.xscale('log')\n",
    "plt.xlabel(r'$log || S - \\mathbf{1}||_1$', fontsize=18)\n",
    "plt.ylabel(r'Fraction non-QVX', fontsize=18)\n",
    "plt.legend(fontsize=16)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/home/will/projects/model_selection/neurips2021/figs/howCloseToUniform_errorBars.png')\n",
    "plt.show()\n",
    "print(nonQVX.mean(0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "errs"
   ]
  },
  {
   "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
}
