{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.stats import ortho_group\n",
    "import time\n",
    "import datetime\n",
    "\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "import scipy.linalg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 50\n",
    "niterX = 50 # 100\n",
    "niter = 50 # 100\n",
    "\n",
    "\n",
    "npoint = 40 # 40\n",
    "npoint_dense = 200\n",
    "xlogmax = 2\n",
    "EPS = 1e-12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  56,   63,   71,   80,   90,  102,  114,  129,  145,  163,  183,\n",
       "        206,  232,  261,  294,  331,  372,  419,  471,  530,  597,  672,\n",
       "        756,  851,  957, 1077, 1212, 1364, 1535, 1728, 1944, 2188, 2462,\n",
       "       2771, 3118, 3509, 3948, 4443, 5000])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "gamma = np.logspace(0,xlogmax,npoint)[1:]\n",
    "gamma = gamma + EPS*(gamma==1)\n",
    "# risk = (gamma<1)*(gamma/(1-gamma)) +(gamma>1)*(1-1/gamma+1/(gamma-1))\n",
    "ps = np.round(gamma*n).astype(int) #np.array([25,50,100]) #\n",
    "gamma = (ps/n)\n",
    "\n",
    "\n",
    "ps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  1.12,   1.26,   1.42,   1.6 ,   1.8 ,   2.04,   2.28,   2.58,\n",
       "         2.9 ,   3.26,   3.66,   4.12,   4.64,   5.22,   5.88,   6.62,\n",
       "         7.44,   8.38,   9.42,  10.6 ,  11.94,  13.44,  15.12,  17.02,\n",
       "        19.14,  21.54,  24.24,  27.28,  30.7 ,  34.56,  38.88,  43.76,\n",
       "        49.24,  55.42,  62.36,  70.18,  78.96,  88.86, 100.  ])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gamma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_symmetric(a, rtol=1e-05, atol=1e-08):\n",
    "    return np.allclose(a, a.T, rtol=rtol, atol=atol)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "49.99999999999999\n",
      "2rocess: 5000, 100.000\n",
      "99.99999999999997\n",
      "4rocess: 5000, 100.000\n",
      "199.99999999999997\n",
      "process: 5000, 100.000\r"
     ]
    }
   ],
   "source": [
    "total_list = []\n",
    "\n",
    "for multiple in [1,2,4]:\n",
    "    print(multiple)\n",
    "\n",
    "    nprocess = 0\n",
    "    U = ortho_group.rvs(dim=n)\n",
    "    UT = np.transpose(U)\n",
    "    D = np.diag(np.abs(np.random.randn(n)))\n",
    "\n",
    "    Omega = U@D@UT/D.sum()*n*multiple\n",
    "    ntotal = niter*niterX*len(ps)\n",
    "    tr_omega = np.trace(Omega)\n",
    "    print(tr_omega)\n",
    "\n",
    "    Rs = []\n",
    "    Vs = []\n",
    "    V2s = []\n",
    "    ts = []\n",
    "    t2s = []\n",
    "    t3s = []\n",
    "    ls = []\n",
    "    Bs = []\n",
    "    B2s = []\n",
    "    Zls =[]\n",
    "\n",
    "    for p in ps:\n",
    "        U = ortho_group.rvs(dim=p)\n",
    "        UT = np.transpose(U)\n",
    "        diag = np.abs(np.random.randn(p))\n",
    "        diag /= diag.sum()\n",
    "        D = np.diag(diag)\n",
    "        sqrt_D = np.diag(np.sqrt(diag))\n",
    "\n",
    "        Sigma = U@D@UT*p\n",
    "        sqrt_Sigma = U@sqrt_D@UT*np.sqrt(p)\n",
    "        \n",
    "        \n",
    "        l = 0.   \n",
    "        R = 0.\n",
    "        t = 0.\n",
    "        t2 = 0.\n",
    "        t3 = 0.\n",
    "        Z_l = 0.\n",
    "        l = 0.\n",
    "        V = 0.\n",
    "        V2 = 0.\n",
    "        Bias = 0.\n",
    "        for indX in range(niterX):\n",
    "            Z = np.random.multivariate_normal(np.zeros(p), np.eye(p), size=n)\n",
    "            ZT = np.transpose(Z)\n",
    "            ZZT = Z@ZT\n",
    "            # ZZTP = np.linalg.pinv(ZZT)\n",
    "\n",
    "            # Z_evals = np.linalg.eigvalsh(ZZT+EPS*np.eye(n))\n",
    "            # Z_evals = 1/Z_evals\n",
    "            # Z_evals_cut = Z_evals*(Z_evals<=100)\n",
    "            Z_l += 0 #(Z_evals_cut).sum()\n",
    "            # X = np.random.multivariate_normal(np.zeros(p), Sigma, size=n)\n",
    "            X = Z@sqrt_Sigma\n",
    "            \n",
    "            XT = np.transpose(X)\n",
    "            XXT = X@XT\n",
    "            XTX = XT@X\n",
    "            XTXP = np.linalg.pinv(XTX)\n",
    "            XP = np.linalg.pinv(X)\n",
    "            XTXPS = XTXP@Sigma\n",
    "\n",
    "            SXP = sqrt_Sigma@XP\n",
    "            SXPT = np.transpose(SXP)\n",
    "\n",
    "            # XXTP = np.linalg.pinv(XXT)\n",
    "            t += 0 # np.trace(XXTP@Omega)\n",
    "\n",
    "            # t2 = np.trace(XT@XXTP@Omega@XXTP@X@Sigma)\n",
    "            # t3 = np.trace(ZZTP@Omega)\n",
    "            # t3 = np.trace(XXTP@Omega)\n",
    "            beta = np.random.randn(p)\n",
    "            beta /= np.linalg.norm(beta)\n",
    "\n",
    "            evals = np.linalg.eigvalsh(SXP@SXPT+EPS*np.eye(p))\n",
    "\n",
    "            evals_cut = evals*(evals<=100) #(np.abs(np.real(evals))<=100)\n",
    "\n",
    "\n",
    "            l += (evals_cut).sum()\n",
    "            \n",
    "\n",
    "            BBT = np.zeros((p,p))\n",
    "            B = np.zeros(p).reshape(-1,1)\n",
    "            for _ in range(niter): \n",
    "                nprocess += 1\n",
    "                rate = nprocess / ntotal\n",
    "                print(\"process: %d, %.3f\"%(p,100*rate), end='\\r')\n",
    "                epsilon = np.random.multivariate_normal(np.zeros(n),Omega)\n",
    "                y = np.matmul(X,beta) + epsilon\n",
    "                betahat = scipy.linalg.lstsq(X, y, lapack_driver='gelsy')[0]\n",
    "                betahat = betahat.reshape(-1,1)                \n",
    "                betahatT = np.transpose(betahat)\n",
    "                BBT += betahat@betahatT\n",
    "                B += betahat\n",
    "                \n",
    "                # R += np.linalg.norm(beta-betahat.reshape(-1))**2\n",
    "            dbeta = B.reshape(-1,1)/niter-beta.reshape(-1,1)\n",
    "            Bias += np.linalg.norm(sqrt_Sigma@dbeta)**2\n",
    "            # Rs.append(R/niter)\n",
    "            Cov = BBT/niter-(B/niter)@np.transpose(B/niter)\n",
    "            CovS = Cov@Sigma\n",
    "            V += np.trace(CovS)\n",
    "\n",
    "        # Var2 = Cov@Sigma\n",
    "        # V2 = np.trace(Var2)\n",
    "\n",
    "            \n",
    "        # Bias2 = np.linalg.norm(sqrt_Sigma@dbeta)**2\n",
    "        Bs.append(Bias/niterX)\n",
    "        # B2s.append(Bias2)\n",
    "        Vs.append(V/niterX)\n",
    "        # V2s.append(V2/niterX)\n",
    "        ts.append(t/niterX)\n",
    "        # t2s.append(t2)\n",
    "        # t3s.append(t3)\n",
    "        ls.append(tr_omega/n*l/niterX)\n",
    "        # Zls.append(tr_omega/n*Z_l/niterX)\n",
    "        # print('del:',np.abs(Z_l-t3),t3,Z_l, end='\\r')\n",
    "    # double_Rs.append(Rs)\n",
    "\n",
    "\n",
    "    total_list.append([Vs,ts,ls,Zls,Bs])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "dense_gamma = np.logspace(-0.1,xlogmax,npoint_dense)\n",
    "dense_gamma = dense_gamma +EPS*(dense_gamma==1)\n",
    "bias = (dense_gamma<1)*(0) +(dense_gamma>1)*(1-1/dense_gamma)\n",
    "var = (dense_gamma<1)*(dense_gamma/(1-dense_gamma)) +(dense_gamma>1)*(1/(dense_gamma-1))\n",
    "risk = (dense_gamma<1)*(dense_gamma/(1-dense_gamma)) +(dense_gamma>1)*(1-1/dense_gamma+1/(dense_gamma-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "colors = ['k','b','r']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PR_asymptotic_20230924125827\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(12,4))\n",
    "\n",
    "\n",
    "# ax.plot(dense_gamma,risk,label='MSE',c='k',linewidth=2,alpha=0.5)\n",
    "ax.plot(dense_gamma,bias,label='bias',c='k',linestyle='--')\n",
    "\n",
    "ax.plot(dense_gamma,var,label=r'$s^\\ast_{iso}\\omega^2 $',c=colors[0],linestyle=':',alpha=1)\n",
    "ax.scatter(gamma,total_list[0][0],c=colors[0],marker='x',s=80,label=r'$E_X[Var_\\Sigma(\\hat\\beta|X)]$')\n",
    "ax.scatter(gamma,total_list[0][2],c=colors[0],marker='o',s=50,label=r'$\\frac{1}{n}Tr(\\Omega)E_X[Tr((X^\\top X)^\\dagger\\Sigma]$')\n",
    "# ax.plot(dense_gamma,2*var,label=r'$ s^\\ast_{iso}\\sigma^2 $',c=colors[1],linestyle=':',alpha=1)\n",
    "# ax.plot(dense_gamma,4*var,label=r'$ s^\\ast_{iso}\\sigma^2 $',c=colors[2],linestyle=':',alpha=1)\n",
    "\n",
    "for i in range(1,3):\n",
    "    ax.plot(dense_gamma,var*2**i,c=colors[i],linestyle=':',alpha=1)\n",
    "    ax.scatter(gamma,total_list[i][0],c=colors[i],marker='x',s=80)\n",
    "    ax.scatter(gamma,total_list[i][2],c=colors[i],marker='o',s=50)\n",
    "    # plt.scatter(gamma,total_list[i][3],c='purple',marker='o',s=5,label=r'$\\frac{1}{p}Tr(\\Lambda_{iso}^{-1})$')\n",
    "    # plt.scatter(gamma,V2s,c='r',marker='o',s=80,label=r'$Tr(Cov(\\hat\\beta)\\Sigma)$')\n",
    "    # plt.scatter(gamma,t2s,c='b',marker='o',s=30,label=r'$Tr(X^\\top(XX^\\top)^\\dagger \\Omega (XX^\\top)^\\dagger X\\Sigma)$')\n",
    "    # plt.scatter(gamma,t3s,c='orange',marker='x',s=30,label=r'$Tr((ZZ^\\top)^\\dagger \\Omega)$')\n",
    "    # plt.scatter(gamma,ls,c='g',marker='o',s=5,label=r'$\\sum_i 1/\\lambda_i(XX^\\top)$')\n",
    "    # plt.scatter(gamma,B2s,c='m',marker='v',s=5,label=r'$||\\mathbb{E}[\\hat\\beta]-\\beta||_\\Sigma^2$')\n",
    "ax.scatter(gamma,total_list[0][4],c='c',marker='v',s=5,label=r'$E_X[Bias_\\Sigma(\\hat\\beta|X)^2]$')#||\\mathbb{E}[\\hat\\beta]-\\beta||^2$')\n",
    "\n",
    "\n",
    "\n",
    "# plt.scatter(gamma,Rs,c='r',marker='o',s=1,label=r'$\\mathbb{E}[||\\hat\\beta-\\beta||^2]$')\n",
    "# plt.scatter(gamma,new_Rs2,c='r',marker='o',s=5)\n",
    "# plt.scatter(gamma,new_Rs5,c='b',marker='o',s=5)\n",
    "\n",
    "ax.axhline(1,c='k',alpha=0.1)\n",
    "# plt.axhline(1/2,linestyle=':',c='r')\n",
    "# plt.axhline(1/5,linestyle=':',c='b')\n",
    "# plt.axvline(1/2,linestyle=':',c='r')\n",
    "# plt.axvline(1/5,linestyle=':',c='b')\n",
    "# plt.axvline(1,linestyle=':',c='k')\n",
    "ax.set_xscale('log')\n",
    "# plt.yscale('log')\n",
    "ax.set_yscale('symlog', linthresh=10**(-xlogmax))\n",
    "ax.set_xlim(1,10**xlogmax)\n",
    "ax.set_ylim(10**(-xlogmax),100)\n",
    "\n",
    "ax.set_xlabel(r'$\\gamma=p/n$')\n",
    "# ax.set_ylabel('MSE')\n",
    "# plt.title('Isotropic features, but anisotropic noise')\n",
    "plt.tight_layout()\n",
    "ax.legend(bbox_to_anchor=(1., 1.0))\n",
    "\n",
    "ax.grid(True,axis='both')\n",
    "# ax.yaxis.grid(True)\n",
    "\n",
    "name = 'PR_asymptotic_'\n",
    "now = datetime.datetime.now()\n",
    "savename = now.strftime('%Y%m%d%H%M%S')\n",
    "print(name+savename)\n",
    "if 1:\n",
    "    plt.savefig('pdfs/'+name+savename+'.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ffcv",
   "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.9.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
