{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Numerical Verification of CLT\n",
    "Here is the code that verifies the main theorem of our paper.\n",
    "\n",
    "**Main Theorem (CLT) ** For $\\mu>0$ and $p,\\alpha\\in[1,+\\infty)$, there is a sequence of positive numbers $\\{c_n\\}_{n\\geqslant 1}$ with $c_n\\to0$ as $n\\to\\infty$ such that with probability at least $1-c_n$ over the draw of $v\\sim S^{n-1}$,\n",
    "\t$$\n",
    "    \\|T(tX,tX+v)-G_\\mu\\|_\\infty\\leqslant c_n,\n",
    "    $$\n",
    "where $t=\\frac{1}{\\mu}\\cdot \\sqrt{\\|\\mathcal{I}_{\\varphi_n}\\|_2}$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "from numpy.linalg import norm\n",
    "import scipy\n",
    "from scipy import stats\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from matplotlib import rc\n",
    "rc('font',**{'family':'serif','serif':['Computer Modern']})\n",
    "rc('text', usetex=True)\n",
    "### Algorithm 2 ###\n",
    "def ell_p_ball_sampler(d,p):\n",
    "    if p==np.infty:\n",
    "        return np.random.uniform(-1,1,d)\n",
    "    else:\n",
    "        xi = scipy.stats.gamma.rvs(1/p, size=d)\n",
    "        xi = xi**(1/p)\n",
    "        xi = np.multiply(xi, scipy.stats.bernoulli.rvs(.5,size=d)*2-1)\n",
    "        w = scipy.stats.uniform.rvs(0,1)\n",
    "        return w**(1/d)*xi/norm(xi,p)\n",
    "def homo_logconcave_sampler(d,p,alpha):\n",
    "    return scipy.stats.gamma.rvs(d/alpha+1)**(1/alpha)*ell_p_ball_sampler(d,p)\n",
    "### Algorithm 2 ENDS ###\n",
    "### Computes Fisher Information ###\n",
    "def Fisher_asymp(n,p,alpha):\n",
    "    if p==np.infty:\n",
    "        return alpha**(2/alpha)*n**(1-2/alpha)*2/math.e\n",
    "    else:\n",
    "        return alpha**(2/alpha)*p**(2-2/p)*n**(2/p-2/alpha)*math.gamma(2-1/p)/math.gamma(1/p)\n",
    "### Implements Empirical ROC Function by Monte Carlo ###\n",
    "def empirical_ROC(d,p,alpha,v,scaling,N = 10000):\n",
    "    y = np.zeros(N)\n",
    "    z = np.zeros(N)\n",
    "    for i in range(N):\n",
    "        x = scaling*homo_logconcave_sampler(d,p,alpha)\n",
    "        y[i] = norm((x+v)/scaling,p)**alpha-norm(x/scaling,p)**alpha*(1+1e-13)\n",
    "        z[i] = norm((x-v)/scaling,p)**alpha*(1+1e-13)-norm(x/scaling,p)**alpha\n",
    "    \n",
    "    type1 = np.linspace(0,1,N)\n",
    "    type2 = np.zeros(N)\n",
    "    y.sort()\n",
    "    z.sort()\n",
    "\n",
    "    iz=0\n",
    "    iy=N-1\n",
    "    while iz<N:\n",
    "        while iy>0 and y[iy]>-z[iz]:\n",
    "            iy-=1\n",
    "        type2[iz]=iy/N\n",
    "        iz+=1\n",
    "    return type1, type2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate $v\\sim S^{n-1}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "d = 30\n",
    "v = np.random.normal(0, 1, d)\n",
    "v = v/norm(v)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Try it out!\n",
    "Pick your favorite $p,\\alpha\\in[1,+\\infty)$ and $\\mu>0$, but $\\mu>2$ is visually not recommended."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": [
    "p=1\n",
    "alpha=1\n",
    "mu=1\n",
    "t = np.sqrt(Fisher_asymp(d,p,alpha))/mu\n",
    "type1,type2 = empirical_ROC(d,p,alpha,v,t)\n",
    "plt.plot(type1,scipy.stats.norm.cdf(-scipy.stats.norm.ppf(type1)-mu),label=\"GDP\")\n",
    "plt.plot(type1,type2,label=\"Numerical\")\n",
    "plt.title(r'$d={%i}, p={%.2f}, \\alpha={%.2f}$' %(d,p,alpha),fontsize=15)\n",
    "plt.axis(\"scaled\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Robust to the distribution of $v$\n",
    "Although the theorem requires $v\\sim S^{n-1}$, it is mainly a normalization. For example, we can sample $v$ uniformly in the hypercube and then normalize it. Witness the numerical success!"
   ]
  },
  {
   "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": [
    "d = 30\n",
    "v = ell_p_ball_sampler(d,np.infty)\n",
    "v = v/norm(v)\n",
    "\n",
    "p=1\n",
    "alpha=1\n",
    "mu=1\n",
    "t = np.sqrt(Fisher_asymp(d,p,alpha))/mu\n",
    "type1,type2 = empirical_ROC(d,p,alpha,v,t)\n",
    "plt.plot(type1,scipy.stats.norm.cdf(-scipy.stats.norm.ppf(type1)-mu),label=\"GDP\")\n",
    "plt.plot(type1,type2,label=\"Numerical\")\n",
    "plt.title(r'$d={%i}, p={%.2f}, \\alpha={%.2f}$' %(d,p,alpha),fontsize=15)\n",
    "plt.axis(\"scaled\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Effect of Sample Size $N$ on Empirical ROC Functions\n",
    "We have been using $N=10000$. This is why."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = 30\n",
    "v = ell_p_ball_sampler(d,np.infty)\n",
    "v = v/norm(v)\n",
    "\n",
    "def config():\n",
    "    plt.axis(\"scaled\")\n",
    "    plt.xlabel(\"type I error\")\n",
    "    plt.ylabel(\"type II error\")\n",
    "\n",
    "fig = plt.figure(figsize = (9,3))\n",
    "plt.title('asdf')\n",
    "plt.subplot(131)\n",
    "p=np.infty\n",
    "p=2\n",
    "alpha=2\n",
    "t = math.sqrt(Fisher_asymp(d,p,alpha))\n",
    "type1,type2 = empirical_ROC(d,p,alpha,v,t,100)\n",
    "plt.plot(type1,scipy.stats.norm.cdf(-scipy.stats.norm.ppf(type1)-1),\"r--\",label=\"Exact\")\n",
    "plt.plot(type1,type2,label=\"Numerical\")\n",
    "plt.title(r'$N=100$')\n",
    "plt.legend(fontsize=12)\n",
    "config()\n",
    "\n",
    "plt.subplot(132)\n",
    "type1,type2 = empirical_trade_off(d,p,alpha,v,t,1000)\n",
    "plt.plot(type1,scipy.stats.norm.cdf(-scipy.stats.norm.ppf(type1)-1),\"r--\",label=\"Exact\")\n",
    "plt.plot(type1,type2,label=\"Numerical\")\n",
    "plt.title(r'$N=1000$')\n",
    "plt.legend(fontsize=12)\n",
    "config()\n",
    "\n",
    "plt.subplot(133)\n",
    "type1,type2 = empirical_trade_off(d,p,alpha,v,t,10000)\n",
    "plt.plot(type1,scipy.stats.norm.cdf(-scipy.stats.norm.ppf(type1)-1),\"r--\",label=\"Exact\")\n",
    "plt.plot(type1,type2,label=\"Numerical\")\n",
    "plt.title(r'$N=10000$')\n",
    "plt.legend(fontsize=12)\n",
    "# plt.title(r'$p$=%i, $\\alpha=$%i' %(p,alpha))\n",
    "# phi_title(15)\n",
    "config()\n",
    "plt.tight_layout(pad=0.5)\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": 2
}
