{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.40665866  0.55520139 -0.58073065  0.42029145  0.11174596]\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",
    "    #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": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "nCores = 11\n",
    "nUs = 500\n",
    "nNoises = 500\n",
    "Ns = np.linspace(10,300,10).astype(np.int32)\n",
    "nonQVXGood = np.empty((Ns.shape[0],nNoises,nUs))\n",
    "nonQVXBad = np.empty((Ns.shape[0],nNoises,nUs))\n",
    "\n",
    "# Make the Us\n",
    "UsGood = []\n",
    "UsBad = []\n",
    "Uog = expUtils.getUFast(8,D)\n",
    "for N in 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",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [23:35<00:00, 141.55s/it]\n"
     ]
    }
   ],
   "source": [
    "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[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[nn,ii] = np.array([r[1] for r in res])    \n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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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023j4eFB586d6d+/P2fPns13nb9KW3am++uUL8UvAx7mk571ORMdS9fPN/DGf3dx6Ubq7M78zNosviNAowzOtwEirLy2usfdbD17ZfEtXryYS5cuMWnSJFq1apXqfP/+/Rk4cCBhYWF4e3szZMgQevbsSY0aNUhISGDWrFk4OTnRpk0bwPIDtUuXLtStWxcPDw/Cw8PZuXMnffpYHlmKCD179uTrr7+mZs2aBAYGsmTJkhTp5bZSo0YNqlSpwqpVq9Kts2vXLoYPH06PHj3w9/fn1q1brF27lilTptCxY8fkZ3I59c4777B48WLatm3L66+/jojw0UcfERMTw7vvvptuuz59+jB+/Hi6d+/O2LFj8fX15YsvvuDatWsp6r377rucP3+e1q1bU758eU6fPs3UqVNp0KABPj5Fb3uHgii70/0iQreGFQmt5cfUVYeYueE4y/acY3i7mvRqUgVHh7Sz/fJD1vBd1nZQPwLviMjPWLZ/h6SpPhEZBnQAhuQ8vIyJSGlgNPAoUAW4CCwG3jbGZPhroYg8CYzBkuhxBHjLGDMvdyO2TteGFez2DTJ79mxKlChBjx490jz/zDPP8NprrzF79mwmTJhA5cqVmTx5MqdPn8bV1ZW6deuyePFiGjWy/D7TsmVLfv75Z8aPH098fDz+/v588sknvPLKK8nXnDJlComJiYwaNYrExESefvpppk2bZvOXgrPyTMrPz48yZcowduxYzp07R/HixfH39+fjjz/mxRdftFks9erVIywsjLfeeos+ffpgjKFp06aEh4enm2IOlmdrv//+Oy+//DKDBg3C3d2dXr168dhjjzFgwIDkek2aNGHq1KkMHTqUy5cv4+vrS7t27RgzZozNPoPKXeU93YhMozPKbLq/hKszbz1Wm6eDK/Hewr28s2Av/7flFO8/UYfgqimnj+9OI94dqd2dRgTs8jPI2g0LiwErgJbAfiAI2A34AGWB34FOxphcndwWkQewJGzMwjJiqwB8DkQaY9pl0O5hLFmI7wFzge5YOrpmxpg/MrpnZhsW7tu3j1q1amXvgyhVhOj/I9a5v/MAy3T/uO51s9x5GGNYtuccHyyO4MzVOLo3rMAbHYPwTdpyvtn41Wl2ghU83djwRhvbfJA02HrL99si8igwGPg7EAfUBA4Bk4Epud05JcWxB0vnctdhERkBLBaRksaY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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": [
      "slope is -0.63370433892235\n"
     ]
    }
   ],
   "source": [
    "plt.scatter(Ns, nonQVXGood.mean((1,2)), label='Assum. 3 holds')\n",
    "plt.scatter(Ns, nonQVXBad.mean((1,2)), 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.png')\n",
    "plt.show()\n",
    "\n",
    "\n",
    "for nn in range(Ns.shape[0]):\n",
    "    normsGood[nn] = (np.linalg.norm(UsGood[nn], axis=2)**2).max(1).max()\n",
    "    normsBad[nn] = (np.linalg.norm(UsBad[nn], axis=2)**2).max(1).min()\n",
    "m, b = np.polyfit(np.log(Ns), np.log(normsGood), deg=1)    \n",
    "\n",
    "plt.scatter(np.log(Ns), np.log(normsGood), label='Assum. 3 holds')\n",
    "plt.scatter(np.log(Ns), np.log(normsBad), label='Assum. 3 violated')\n",
    "plt.plot(np.log(Ns), np.log(Ns)*m + b)\n",
    "#plt.yscale('log')\n",
    "#plt.xscale('log')\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.png')\n",
    "plt.show()\n",
    "print('slope is', m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[2.84010026e-05 1.61556406e-03 2.29492771e-04 8.03321264e-05\n",
      " 1.03272907e-04 2.61353586e-04 6.30989490e-05 2.98204586e-04\n",
      " 4.21141503e-05 4.82340058e-05]\n",
      "[0.88662158 0.51237047 0.32242846 0.23055034 0.19234934 0.15908099\n",
      " 0.13298219 0.12076903 0.1100207  0.09462514]\n"
     ]
    }
   ],
   "source": [
    "print(normsGood.var(0))\n",
    "print(normsGood.mean(0))"
   ]
  },
  {
   "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
}
