{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.25813293 -0.74638073 -0.5693928   0.20302752  0.10418666]\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "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",
    "    #U = inputs[1]\n",
    "    #noise = inputs[0]\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": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "nCores = 11\n",
    "nUs = 500\n",
    "nNoises = 500\n",
    "nTrials = 5\n",
    "Ns = np.linspace(10,300,10).astype(np.int32)\n",
    "nonQVXGood = np.empty((nTrials,Ns.shape[0],nNoises,nUs), dtype=np.bool)\n",
    "nonQVXBad = np.empty((nTrials,Ns.shape[0],nNoises,nUs), dtype=np.bool)\n",
    "goodNorms = np.empty((nTrials,Ns.shape[0]))\n",
    "badNorms = np.empty((nTrials,Ns.shape[0]))\n",
    "\n",
    "       "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [22:55<00:00, 137.52s/it]\n",
      "100%|██████████| 10/10 [22:35<00:00, 135.54s/it]\n",
      "100%|██████████| 10/10 [22:35<00:00, 135.53s/it]\n",
      "100%|██████████| 10/10 [22:39<00:00, 135.95s/it]\n",
      "100%|██████████| 10/10 [22:41<00:00, 136.11s/it]\n"
     ]
    }
   ],
   "source": [
    "for tt in range(nTrials):\n",
    "    # Make the Us\n",
    "    UsGood = []\n",
    "    UsBad = []\n",
    "    Uog = expUtils.getUFast(8,D)\n",
    "    for nn, N in enumerate(Ns):\n",
    "        Ubad = np.vstack([Uog, np.zeros((N-Uog.shape[0],D))])\n",
    "        UsGood.append(np.empty((nUs,N,D)))\n",
    "        UsBad.append(np.tile(Ubad[None,:,:], (nUs,1,1)))\n",
    "        for uu in range(nUs):\n",
    "            if N == Ns.min():\n",
    "                UsBad[-1][uu] = expUtils.getUFast(N,D)\n",
    "            else:\n",
    "                UsBad[-1][uu] = np.vstack([UsBad[0][uu], np.zeros((N-Ns.min(),D))])\n",
    "            UsGood[-1][uu] = expUtils.getUFast(N,D)\n",
    "            \n",
    "        goodNorms[tt,nn] = (np.linalg.norm(UsGood[-1], axis=2)**2).max(1).max()\n",
    "        badNorms[tt,nn] = (np.linalg.norm(UsBad[-1], axis=2)**2).max(1).min()\n",
    "\n",
    "    for nn in tqdm(range(len(Ns))):\n",
    "        lams = np.logspace(-8, 3.0, 200) * N\n",
    "        lams = np.append(0.0, lams)\n",
    "        noises = np.random.normal(scale=0.5, size=(nNoises,Ns[nn]))\n",
    "        for ii in range(nNoises):\n",
    "            res = ProcessingPool(nCores).map(oneTrial,\n",
    "                                             itertools.cycle([noises[ii]]),\n",
    "                                             UsGood[nn],\n",
    "                                             itertools.cycle([np.ones(D),]),\n",
    "                                             itertools.cycle([thetaStar]),\n",
    "                                             itertools.cycle([lams]))\n",
    "            nonQVXGood[tt,nn,ii] = np.array([r[1] for r in res])\n",
    "            res = ProcessingPool(nCores).map(oneTrial,\n",
    "                                             itertools.cycle([noises[ii]]),\n",
    "                                             UsBad[nn],\n",
    "                                             itertools.cycle([np.ones(D)]),\n",
    "                                             itertools.cycle([thetaStar]),\n",
    "                                             itertools.cycle([lams]))\n",
    "            nonQVXBad[tt,nn,ii] = np.array([r[1] for r in res])    \n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [],
   "source": [
    "output = {'nonQVXBad':nonQVXBad,\n",
    "         'nonQVXGood':nonQVXGood,\n",
    "         'goodNorms':goodNorms,\n",
    "         'badNorms':badNorms}\n",
    "f = open('/home/will/projects/model_selection/code/experiments/output/UassumptionOutput_errorBars.pkl', 'wb')\n",
    "pickle.dump(output, f)\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7bffTp06dbjmmmt477332L17N4mJiflyV199NQkJCUycOJHatWuTmZnJrFmz8tOKDxs2jPfff5/Ro0fTunVrdu7cyVdffcWePXtKpde6desYMWIEDz30EHFxcdx///306tWLXr16kZubS0ZGBmvWrGHEiBHUrVuXp556qtR/g9zcXLKzs1m0aBHjxo3jtttuIz4+PqB8v379GDlyJG+++SZDhw7NL1+2bBlr1qzh8ccfD9j2pZdeYvDgwfTt25cxY8awZcsWHnzwQRYvXsw333xDXFyc33a7du0iOjqaMWPGUKdOHbZs2cIzzzxDly5dWLt2LdHR0fzlL39h+/btLFmyhPfffx9wszhwy5ldunTh8OHD/PWvf6V58+Z89NFHDBkyhCNHjnDXXS4pxJo1a+jZsydpaWlMnTqVI0eO8Ne//pUDBw4QERHhV7eQ4C9JlJ5I2PcILqHfbuBWP/W/xYUEysUZrNii+jtdrtImLFz1RBdd9USX4gWNCkVIExYuf1P1b/VUH6l54vpbPVdejowdO1YBXbDAJdCcPXu2Ajpx4sR8me3btyug06dPD9jPWWedpcOGDQtYn5dw8NVXXy1QPnfuXL8JC6tWrao//fRTftn06dMV0O7duxdo37t3b23WrFlJbtUvK1euVFxsTgW0f//+mpubW2y7Hj166AUXXFCg7J577tHExMT8hIe+95ybm6t169bVrl27Fmj3xRdfKFAgwWPTpk11wIABAcfPzc3VX375RQF977338ssDJVJ87LHHtFq1avrDDz8UKB80aJAmJSXlJ3y86aabNCkpSQ8cOJAv88svv2hkZGShhIr+KG3CwuKW+B4B5gIpqvqqH+P2Ac6B4h1cENXlpbaUhmG4mVPO4YJlOYddeTny2muv0bp16/wU5z169KBhw4YFlvmSkpJo0aIFDzzwAC+//DI//vhjoX46depERkYGo0ePZunSpRw7duyk9GrTpg0tWrTI/9yuXTsALr/88gJy7dq1Y/PmzXk/pIOmVatWLFmyhHnz5jF69GimTZtG//79i213yy23sGjRovy/RW5uLlOnTuX666/Pn7X48v333/Prr79y880FT+lceOGFNG3alPnz5xc55sSJE+nQoQNxcXFUrVqVJk2a5PdbHLNnz+b888+nefPm5Obm5l+XX345O3fuZPVqF4504cKF9OzZk+rV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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "errsGood = 2 * np.sqrt(nonQVXGood.mean((2,3)).var(0))\n",
    "errsBad = 2 * np.sqrt(nonQVXBad.mean((2,3)).var(0))\n",
    "plt.errorbar(x=Ns,\n",
    "            y=nonQVXGood.mean((0,2,3)),\n",
    "            yerr=errsGood)\n",
    "plt.errorbar(x=Ns,\n",
    "            y=nonQVXBad.mean((0,2,3)),\n",
    "            yerr=errsBad)\n",
    "\n",
    "plt.scatter(Ns, nonQVXGood.mean((0,2,3)), label='Assum. 3 holds')\n",
    "plt.scatter(Ns, nonQVXBad.mean((0,2,3)), label='Assum. 3 violated')\n",
    "plt.xlabel('N', fontsize=18)\n",
    "plt.ylabel('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/ordernuAssumption_errorBars.png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "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": [
    "errsGood = np.sqrt(goodNorms.var(0))\n",
    "errsBad = np.sqrt(badNorms.var(0))\n",
    "barsGood = np.empty((2,Ns.shape[0]))\n",
    "barsGood[0] = np.abs(np.log(goodNorms.mean(0)) - np.log(goodNorms.mean(0) - 2*errsGood))\n",
    "barsGood[1] = np.abs(np.log(goodNorms.mean(0)) - np.log(goodNorms.mean(0) + 2*errsGood))\n",
    "barsBad = np.empty((2,Ns.shape[0]))\n",
    "barsBad[0] = np.abs(np.log(badNorms.mean(0)) - np.log(badNorms.mean(0) - 2*errsBad))\n",
    "barsBad[1] = np.abs(np.log(badNorms.mean(0)) - np.log(badNorms.mean(0) + 2*errsBad))\n",
    "\n",
    "#barsGood= [barsGood[1], barsGood[0]]\n",
    "#barsGood = [0.1*np.ones(barsGood.shape[1]), 2*np.ones(barsGood.shape[1])]\n",
    "#barsGood = [barsGood]\n",
    "\n",
    "plt.scatter(np.log(Ns), np.log(goodNorms.mean(0)), label='Assum. 3 holds')\n",
    "plt.scatter(np.log(Ns), np.log(badNorms.mean(0)), label='Assum. 3 violated')\n",
    "plt.errorbar(x=np.log(Ns),\n",
    "            y=np.log(goodNorms.mean(0)),\n",
    "            yerr=barsGood,\n",
    "            fmt='none')\n",
    "plt.errorbar(x=np.log(Ns),\n",
    "            y=np.log(badNorms.mean(0)),\n",
    "            yerr=barsBad,\n",
    "            fmt='none')\n",
    "plt.xlabel('log(N)', fontsize=18)\n",
    "plt.ylabel('Extrema of $\\log(||u_{max}||^2)$', fontsize=18)\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "plt.legend(fontsize=16)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/home/will/projects/model_selection/neurips2021/figs/ordernuAssumption_nus_errorBars.png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.00422679,  0.02561649,  0.17974329,  0.0786747 ,  0.08874084,\n",
       "         0.16747442,  0.11179427,  0.06582306,  0.1508598 ,  0.11443255],\n",
       "       [-0.004209  , -0.02497664, -0.15230499, -0.0729339 , -0.08150377,\n",
       "        -0.14340898, -0.10054355, -0.06175667, -0.1310561 , -0.10267202]])"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "barsGood"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8991238050955774"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "for tt in range(nTrials):\n",
    "    # Make the Us\n",
    "    UsGood = []\n",
    "    UsBad = []\n",
    "    Uog = expUtils.getUFast(8,D)\n",
    "    for nn, N in enumerate(Ns):\n",
    "        Ubad = np.vstack([Uog, np.zeros((N-Uog.shape[0],D))])\n",
    "        UsGood.append(np.empty((nUs,N,D)))\n",
    "        UsBad.append(np.tile(Ubad[None,:,:], (nUs,1,1)))\n",
    "        for uu in range(nUs):\n",
    "            if N == Ns.min():\n",
    "                UsBad[-1][uu] = expUtils.getUFast(N,D)\n",
    "            else:\n",
    "                UsBad[-1][uu] = np.vstack([UsBad[0][uu], np.zeros((N-Ns.min(),D))])\n",
    "            UsGood[-1][uu] = expUtils.getUFast(N,D)\n",
    "            \n",
    "        goodNorms[tt,nn] = (np.linalg.norm(UsGood[-1], axis=2)**2).max(1).max()\n",
    "        badNorms[tt,nn] = (np.linalg.norm(UsBad[-1], axis=2)**2).max(1).min()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.60116215, 0.60116215, 0.60116215, 0.60116215, 0.60116215,\n",
       "        0.60116215, 0.60116215, 0.60116215, 0.60116215, 0.60116215],\n",
       "       [0.60351724, 0.60351724, 0.60351724, 0.60351724, 0.60351724,\n",
       "        0.60351724, 0.60351724, 0.60351724, 0.60351724, 0.60351724],\n",
       "       [0.60217862, 0.60217862, 0.60217862, 0.60217862, 0.60217862,\n",
       "        0.60217862, 0.60217862, 0.60217862, 0.60217862, 0.60217862],\n",
       "       [0.62005773, 0.62005773, 0.62005773, 0.62005773, 0.62005773,\n",
       "        0.62005773, 0.62005773, 0.62005773, 0.62005773, 0.62005773],\n",
       "       [0.59030079, 0.59030079, 0.59030079, 0.59030079, 0.59030079,\n",
       "        0.59030079, 0.59030079, 0.59030079, 0.59030079, 0.59030079]])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "badNorms"
   ]
  },
  {
   "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
}
