{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Code to generate the wavy-looking plots from Figure 2\n",
    "\n",
    "import pickle\n",
    "import autograd\n",
    "import itertools\n",
    "import scipy.optimize\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",
    "fs = 20\n",
    "tickFs = 16\n",
    "\n",
    "\n",
    "def oneTrial(U, S, Y, lams):\n",
    "  return expUtils.runTrialUOnlyNoisy(U, S, Y, lams)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "N = 3\n",
    "D = 2\n",
    "nYs = 200\n",
    "nUs = 100\n",
    "nCores = 11\n",
    "lams = np.logspace(-8, 3.0, 200) * N\n",
    "lams = np.append(0.0, lams)\n",
    "Us = np.empty((nUs,N,D))\n",
    "\n",
    "phis = np.linspace(0.0, 2*np.pi, nYs) # Spacing between the Ys on the unit circle\n",
    "psis = np.linspace(0,np.pi,nUs) # spacing between the Us on the unit circle\n",
    "np.random.seed(123456)\n",
    "\n",
    "Yog = expUtils.getUFast(N, D)\n",
    "Ys = np.empty((nYs,N))\n",
    "for yy in range(nYs):\n",
    "    coords = np.array([[np.cos(phis[yy]), -np.sin(phis[yy])],\n",
    "                    [np.sin(phis[yy]), np.cos(phis[yy])]]) @ np.array([1,0])\n",
    "    Ys[yy] = Yog @ coords\n",
    "\n",
    "Uog = expUtils.getUFast(N, D)\n",
    "\n",
    "\n",
    "for uu in range(nUs):\n",
    "  Ucoord1 = np.array([[np.cos(psis[uu]), -np.sin(psis[uu])],\n",
    "                    [np.sin(psis[uu]), np.cos(psis[uu])]]) @ np.array([1,0])\n",
    "  Ucoord2 = np.array([[np.cos(psis[uu]+np.pi/2), -np.sin(psis[uu]+np.pi/2)],\n",
    "                    [np.sin(psis[uu]+np.pi/2), np.cos(psis[uu]+np.pi/2)]]) @ np.array([1,0])\n",
    "  Us[uu,:,0] = Uog @ Ucoord1\n",
    "  Us[uu,:,1] = Uog @ Ucoord2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6.0\n",
      "[2.44826469 0.07745967]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:06<00:00, 15.36it/s]\n"
     ]
    }
   ],
   "source": [
    "S = np.ones(D)\n",
    "frac = 0.001\n",
    "S[0] = np.sqrt((1-frac) * N * D)\n",
    "S[1] = np.sqrt(frac * N * D)\n",
    "print((S**2).sum())\n",
    "print(S)\n",
    "\n",
    "nonQVX = np.empty((nUs,nYs), dtype=np.bool)\n",
    "losses = np.empty((nUs,nYs,lams.shape[0]))\n",
    "success = np.empty((nUs,nYs), dtype=np.bool)\n",
    "\n",
    "for uu in tqdm(range(nUs)):\n",
    "  results = ProcessingPool(nCores).map(oneTrial,\n",
    "                                       itertools.cycle([Us[uu],]),\n",
    "                                       itertools.cycle([S]),\n",
    "                                       Ys,\n",
    "                                       itertools.cycle([lams]))\n",
    "  \n",
    "  losses[uu] = np.array([r[0] for r in results]) \n",
    "  nonQVX[uu] = np.array([r[1] for r in results])\n",
    "  success[uu] = np.array([r[2] for r in results])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": [
    "plt.gca().imshow(nonQVX,\n",
    "                extent=[phis.min(), phis.max(), psis.min(), psis.max()],\n",
    "                aspect='auto')\n",
    "plt.xticks(fontsize=tickFs)\n",
    "plt.yticks(fontsize=tickFs)\n",
    "plt.title(f'$S_1$ = {S[0]:.4f}, $S_2$ = {S[1]:.4f}', fontsize=fs)\n",
    "plt.xlabel('$Y$ on unit circle', fontsize=fs)\n",
    "plt.ylabel('$U_{\\cdot 1}$ on unit circle', fontsize=fs)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:00<00:08, 11.16it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6.0\n",
      "[2.4494775  0.00774597]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:07<00:00, 12.62it/s]\n"
     ]
    }
   ],
   "source": [
    "S = np.ones(D)\n",
    "frac = 0.00001\n",
    "S[0] = np.sqrt((1-frac) * N * D)\n",
    "S[1] = np.sqrt(frac * N * D)\n",
    "print((S**2).sum())\n",
    "print(S)\n",
    "\n",
    "nonQVX = np.empty((nUs,nYs), dtype=np.bool)\n",
    "losses = np.empty((nUs,nYs,lams.shape[0]))\n",
    "success = np.empty((nUs,nYs), dtype=np.bool)\n",
    "for uu in tqdm(range(nUs)):\n",
    "  results = ProcessingPool(nCores).map(oneTrial,\n",
    "                                       itertools.cycle([Us[uu],]),\n",
    "                                       itertools.cycle([S]),\n",
    "                                       Ys,\n",
    "                                       itertools.cycle([lams]))\n",
    "  \n",
    "  losses[uu] = np.array([r[0] for r in results]) \n",
    "  nonQVX[uu] = np.array([r[1] for r in results])\n",
    "  success[uu] = np.array([r[2] for r in results])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": [
    "plt.gca().imshow(nonQVX,\n",
    "                extent=[phis.min(), phis.max(), psis.min(), psis.max()],\n",
    "                aspect='auto')\n",
    "plt.xticks(fontsize=tickFs)\n",
    "plt.yticks(fontsize=tickFs)\n",
    "plt.title(f'$S_1$ = {S[0]:.4f}, $S_2$ = {S[1]:.4f}', fontsize=fs)\n",
    "plt.xlabel('$Y$ on unit circle', fontsize=fs)\n",
    "plt.ylabel('$U_{\\cdot 1}$ on unit circle', fontsize=fs)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 2/100 [00:00<00:08, 11.41it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6.0\n",
      "[2.44378804 0.16703293]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:06<00:00, 16.21it/s]\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"
    }
   ],
   "source": [
    "S = np.ones(D)\n",
    "frac = 0.00465\n",
    "S[0] = np.sqrt((1-frac) * N * D)\n",
    "S[1] = np.sqrt(frac * N * D)\n",
    "print((S**2).sum())\n",
    "print(S)\n",
    "\n",
    "nonQVX = np.empty((nUs,nYs), dtype=np.bool)\n",
    "losses = np.empty((nUs,nYs,lams.shape[0]))\n",
    "success = np.empty((nUs,nYs), dtype=np.bool)\n",
    "\n",
    "for uu in tqdm(range(nUs)):\n",
    "  results = ProcessingPool(nCores).map(oneTrial,\n",
    "                                       itertools.cycle([Us[uu],]),\n",
    "                                       itertools.cycle([S]),\n",
    "                                       Ys,\n",
    "                                       itertools.cycle([lams]))\n",
    "  \n",
    "  losses[uu] = np.array([r[0] for r in results]) \n",
    "  nonQVX[uu] = np.array([r[1] for r in results])\n",
    "  success[uu] = np.array([r[2] for r in results])\n",
    "plt.gca().imshow(nonQVX,\n",
    "                extent=[phis.min(), phis.max(), psis.min(), psis.max()],\n",
    "                aspect='auto')\n",
    "plt.xticks(fontsize=tickFs)\n",
    "plt.yticks(fontsize=tickFs)\n",
    "plt.title(f'$S_1$ = {S[0]:.4f}, $S_2$ = {S[1]:.4f}', fontsize=fs)\n",
    "plt.xlabel('$Y$ on unit circle', fontsize=fs)\n",
    "plt.ylabel('$U_{\\cdot 1}$ on unit circle', fontsize=fs)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
