{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "#import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn.datasets import fetch_openml\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from numpy.fft import fft2\n",
    "from scipy.stats import gamma\n",
    "from scipy.stats import ncx2,chi2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def nnd2(M,N, lam, sigma_prop = 1e0, iters = 6000, burnin = 1000, desired_ar = 0.574, gamma_exp = 1., sigma_min = 1e-4, verbose = True):\n",
    "    assert 0.5 < gamma_exp \n",
    "    assert gamma_exp <= 1\n",
    "\n",
    "    # Negative log prior density\n",
    "    def nlpri(X):\n",
    "        svd = np.linalg.svd(X)\n",
    "        return lam*np.sum(svd[1])\n",
    "\n",
    "    # Negative log post density\n",
    "    nlpost = nlpri\n",
    "    #nlpost = _nlpost\n",
    "\n",
    "    accepts = 0\n",
    "    rejects = 0\n",
    "\n",
    "    X_est = np.array(np.random.normal(size=[M,N]))\n",
    "    cur_ld = -nlpost(X_est)\n",
    "\n",
    "    X_samp = np.zeros([iters,M,N])\n",
    "\n",
    "    def _prox(U, delta, lam):\n",
    "        lam_tild = lam * delta / 2\n",
    "        svd = np.linalg.svd(U, full_matrices = False)\n",
    "        new_sv = np.maximum(0,svd[1] - lam_tild)\n",
    "        #svd[0] @ jnp.diag(svd[1]) @ svd[2] - center\n",
    "        return svd[0] @ np.diag(new_sv) @ svd[2]\n",
    "    prox=_prox\n",
    "\n",
    "    for it in range(iters):\n",
    "        delta = np.square(sigma_prop)\n",
    "        X_prop_prox = prox(X_est, delta, lam)\n",
    "        noise = sigma_prop*np.random.normal(size=[M,N])\n",
    "        X_prop = X_prop_prox + noise\n",
    "        prop_ld = -nlpost(X_prop)\n",
    "\n",
    "        log_post_ratio = prop_ld - cur_ld\n",
    "\n",
    "        lprob_prop = -np.sum(np.square(noise))/(2*delta)\n",
    "        backprox = prox(X_prop, delta, lam)\n",
    "        lprob_back = -np.sum(np.square(X_est - backprox))/(2*delta)\n",
    "\n",
    "        log_prop_ratio = lprob_back - lprob_prop\n",
    "\n",
    "        lu = np.log(np.random.uniform())\n",
    "        lalpha = log_post_ratio + log_prop_ratio\n",
    "        isaccept = lalpha > lu\n",
    "        if isaccept:\n",
    "            #print(\"Accept!\")\n",
    "            accepts += 1\n",
    "            X_est = X_prop\n",
    "            cur_ld = prop_ld\n",
    "        else:\n",
    "            #print(\"Reject!\")\n",
    "            rejects += 1\n",
    "\n",
    "        ## Adjust proposal var.\n",
    "        alpha = np.minimum(np.exp(lalpha),1.)\n",
    "        gamma_it = np.power(1./(it+1),gamma_exp)\n",
    "        #sigma_prop = np.minimum(2*sigma_prop, np.maximum(sigma_min, sigma_prop + gamma_it * (alpha - desired_ar)))\n",
    "        sigma_pre = sigma_prop + gamma_it * (alpha - desired_ar)\n",
    "        sigma_prop = np.minimum(2*sigma_prop, np.maximum(sigma_min, sigma_pre))\n",
    "        #print(sigma_prop)\n",
    "\n",
    "        X_samp[it,:,:] = X_est\n",
    "\n",
    "    if verbose:\n",
    "        print(f\"Accept prop: {accepts/(accepts+rejects)}\")\n",
    "\n",
    "    return X_samp[burnin:,:,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "ds_name='mnist_784'#'cifar_10'#'mnist_784' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "X, y = fetch_openml(ds_name, version=1, return_X_y=True, as_frame=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.int64(0), np.int64(255))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.min(),X.max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "X=X.reshape(-1,28,28)/255 if ds_name=='mnist_784' else X.reshape((-1,3,32,32)).mean(1)/255 #convert to grayscale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x1366d56a0>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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9VSntAWKnR4QAFEIIAC6RwAtXrw4XHbZZaGmpiaUlZWFV155pc3yJEnC3XffHQYOHBh69+4dxo4dGz799NOObDMApRhA27ZtCyNGjAizZs3a5/IHH3wwPProo+Hxxx8P7777bjjiiCPC+PHjw44dOzqivQCU6iCECRMmZGVf0t7PI488En71q1+FK664InvtmWeeye6CmfaUrr322oNvMQBFoUOvAa1evTqsX78+O+22W2VlZRg5cmRYsmTJPuvs3LkzNDc3tykAFL8ODaA0fFJpj2dP6fPdy76pvr4+C6ndpba2tiObBECBij4Krq6uLjQ1NbWWtWvXxm4SAN0tgKqrq7PHDRs2tHk9fb572TeVl5eHioqKNgWA4tehATRkyJAsaObPn9/6WnpNJx0NN2rUqI7cFAClNgpu69atoaGhoc3Ag+XLl2fTpQwePDjceuut4de//nU44YQTskC66667su8MTZw4saPbDkApBdD7778fLrzwwtbnM2bMyB4nTZoUZs+eHe64447su0I333xz2Lx5czjvvPPCvHnzwmGHHdaxLQegtAJozJgx2fd99iedHeG+++7LCnxT2iPOKz2muso3r18CRTwKDoDSJIAAiEIAARCFAAIgCgEEQBQCCIAoBBAAUQggAKIQQABEIYAAiEIAARCFAAIgCgEEQBRlyYGmto4gvYFdZWVl7GbQSVpaWnLXac8humnTptAep512Wu46GzdubNe2oNg1NTUd8C7XekAARCGAAIhCAAEQhQACIAoBBEAUAgiAKAQQAFEIIACiEEAARCGAAIhCAAEQhQACIIqecTZLMbjuuutCoVqwYEG76plYFLqOHhAAUQggAKIQQABEIYAAiEIAARCFAAIgCgEEQBQCCIAoBBAAUQggAKIQQABEIYAAiMJkpLRbdXV17CZ0Wz/84Q9z1znhhBNCV1m8eHHuOsuWLeuUtlC89IAAiEIAARCFAAIgCgEEQBQCCIAoBBAAUQggAKIQQABEIYAAiEIAARCFAAIgCgEEQBQmI6VLlZWVdcl2Tj/99HbVW7BgQe46F1xwQe46SZKEQrZt27bcdZ588sncdebMmZO7zvLly3PX+c9//pO7Dp1PDwiAKAQQAN0jgNL7hFx22WWhpqYmO53yyiuvtFl+ww03ZK/vWS6++OKObDMApRhA6bnhESNGhFmzZu13nTRw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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(X[126],cmap='gray')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "X=X-X.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=np.abs(fft2(X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "#data is constructed as 2d fourier transform of mnist images, with larger frequencies trimmed \n",
    "\n",
    "k=5 if ds_name=='mnist_784' else 4#dimension of data\n",
    "df=d[:,:k,:k]\n",
    "df=df-df.mean(0)[None,:,:] #mean-center by channel\n",
    "#df=df/df.std(0)[None,:,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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zjnnnJ36Wi960Yu2/vehhx4ahx12WDziEY/oVe1//dd/PeogoQcAYEEbHx+PsbGxWn6J9aCDDoq99torrr/+egk9AABla8dAbzVF+/69dJP5n0/od6Vbb7017rrrrth3332jLhJ6AADYThs3buxV22fdeOONce2118aKFSt66y1veUs873nP60256fbQv+51r4uDDz44TjjhhKiLhB4AALbTNddcE8cee+zW988444ze25NPPjk+8IEPxLe//e24+OKL45577ulNHDr++OPjvPPOq3UWvYQeAIAFPeVmRxxzzDEPefOuz372s5GtOU1MAADADpPQAwBAwbTcAACQohMDvdUUnQbtZS7641EAAMACJaEHAICCabkBACBFu2r1VlO0G7SXuVChBwCAgknoAQCgYFpuAABI0Q83lmoiFXoAACiYhB4AAAqm5QYAgBRVNRCdaqBR++kH/fEoAABggZLQAwBAwbTcAACQoh2t3mqKdoP2Mhcq9AAAUDAJPQAAFEzLDQAAKTpVs27m1KmiL6jQAwBAwST0AABQMC03AACk6DTsxlKdBu1lLvrjUQAAwAIloQcAgIJpuQEAIEUnWr3VFJ0G7WUuVOgBAKBgEnoAACiYlhsAAFK0q1ZvNUW7QXuZCxV6AAAomIQeAAAKpuUGAIAUbixVj/54FAAAsEBJ6AEAoGASegAAKJgeegAA8u4U26BRkR13igUAAOabhB4AAAqm5QYAgBRVt+WmQW0uVYP2Mhcq9AAAUDAJPQAAFEzLDQAAKboTbho15aZqzl7mQoUeAAAKJqEHAICCabkBACBFpxroraboNGgvc9EfjwIAABYoCT0AABRMyw0AAClMuamHCj0AABRMQg8AAAXTcgMAQIpOtHqrKToN2stcqNADAEDBJPQAAFAwLTcAAKQw5aYeKvQAAFAwCT0AABRMyw0AACm03NRDhR4AAPq9Qt/pdOK2226LZcuWRavVH89k2DWqqooNGzbE6tWrY2Cg3ueHziHzfQ6dQR6MayEL7RxSYELfvXCsXbu2/t1QrPHx8VizZk2tMZxD5vscOoM8HNdCFso53FlabuYxoe9WAbqe/shXxdDgSNTth69aGllWXzKYFmvdk/IOzZOP+l5KnOlN0/GJ3/zE1jNSp9kYN3/jgBhbWn/l4elvPTWyPObknL+vrjtOz7vI/9epS1LidCYm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",
      "text/plain": [
       "<Figure size 1000x1000 with 17 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#data samples\n",
    "fig, axes = plt.subplots(nrows=4, ncols=4,figsize=(10,10))\n",
    "for ax in axes.flat:\n",
    "    im=ax.imshow(df[np.random.choice(len(df))],vmin=np.percentile(df,5),vmax=np.percentile(df,95))\n",
    "    ax.set_xticks([],[])\n",
    "    ax.set_yticks([],[])\n",
    "fig.colorbar(im, ax=axes.ravel().tolist())\n",
    "plt.savefig('mnistfftsamples.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "sv=np.linalg.svd(df)[1]\n",
    "xs=np.linspace(min(sv.sum(1)),max(sv.sum(1)),100)\n",
    "n,m=df.shape[1],df.shape[2] #both =k in this case\n",
    "lam=sv.sum(1).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(sv.sum(1),density=True,bins=50,label='mnist')\n",
    "plt.plot(xs,gamma.pdf(xs,a=n*m,scale=lam/(n*m)),label='Nuclear Norm Distribution')\n",
    "plt.xlabel('nuclear norm')\n",
    "plt.ylabel('density')\n",
    "plt.legend()\n",
    "plt.ylim(0,.023)\n",
    "plt.xlim(xs.min(),xs.max())\n",
    "plt.savefig('mnistnucnorm.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(107.17741583236453), np.float64(107.17601002311042))"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#check that empirical/imputed distribution have the same mean\n",
    "sv.sum(1).mean(),(xs*gamma.pdf(xs,a=n*m,scale=lam/(n*m))).sum()*np.diff(xs).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accept prop: 0.5721875\n"
     ]
    }
   ],
   "source": [
    "nnd_samples=nnd2(k,k, 1,iters=len(sv)+10000, burnin = 10000)*lam/k**2 #rescale to match the empirical avg. nuclear norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "nnd_sv=np.linalg.svd(nnd_samples)[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(107.28519455738167)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(nnd_sv.sum(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jx49gr0aYUWvwTZ9+nTP7YiICFmyZEnAX6dDhw4ybNiwXF+3KF/LJvv27TP7UK+p5wTWnlARQCGsSije1+MSN460f/9+qVSpkl/L6gF38eLFfoXP9957T0qVKiWBtHr1anPtuN9++00qVqxYpK+F4CAIAUCIOXnypJQuXbpYXksvN5mZmSklSxbf4aBGjRpF8n5VrlxZiktxvhaKFl1jABxDuyseeugheeSRR8yBSg+4TzzxRJ5N+r///ruZp7/83bZv3y433HCDubDjueeeK1dddZXs3r3b52ueOXNGEhISzEUiy5YtK82aNZN33nnHc7+GjAEDBnjuv/jii+X555/32d329NNPS0xMjFnGF92W5s2byxtvvGG6ffQClHfccYccP37cs0xGRoZ5D6pVq2YuWnnllVfKl19+6blft1O3d9myZdKyZUuJioqSdevWmffuwQcfNN092lpTvXp1mTNnjqSnp0v//v3N+1CvXj3zuLwcPHhQunfvbrZVt/nNN9/MsYx315iGmCFDhkjNmjXN+l5wwQXm/VS6jermm282j3Hfdr8Pr7zySpaLc/rqrtL3plevXlK+fHmpVauWzJw50+/Pg96vrUFK3xOdr/vK12tpi1Hfvn3NcuXKlZPrr79efvzxR8/98+bNMy1KK1askEaNGsk555wj1113nWkdy40+Z+/evaVq1arm/axfv7689tprnvtHjRolDRo0MK930UUXyeOPPy6nTp3y3O9+n+bOnSu1a9c2r/nAAw+Yz+Szzz5rvh/VqlUzn7vs++ell14y26Cvq8/t/Zn25dtvvzXL62voZ6dPnz5y+PBhz/36+CZNmpjnO++886RTp07msxUKCEIAHOX11183B70vvvjC/LF/8sknJTEx0e/H//LLL/K3v/3NBIRPP/1UNm/eLHfffbecPn3a5/J60P7Xv/4ls2bNMgFq+PDh8n//93+yZs0aT1A6//zz5e2335bvvvtOxo4dK48++qgsWrQoy/OsXLlSdu7cadb1ww8/zHX9NJBpiNBldNLXeeaZZzz3awh89913zfuwZcsWE17i4uLk6NGjWZ5n9OjR5nHff/+9NG3a1PPeValSRTZu3GhC0f333y+33XabtGvXzjxXly5dzAHujz/+yHX9NCikpKTIqlWrzMHvxRdfNOEoN//85z/lgw8+MO+Hbr8GJ3fgcQc4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BCEAAGAtghAAALAWQQhAnu666y7p0aNHsb/uvHnzpGLFihKq6tSpI9OnTw/2agA4S4666CqAwNMLPXLeVQBORRACkKfo6GgJVydPnjQXJQaA3NA1BkDeeecdadKkiZQtW1bOO+886dSpk6Snp/vsGuvQoYM89NBD8sgjj0jlypWlRo0a8sQTT2R5vh07dsiVV14pZcqUkUsuuUQ++eQTiYiIkCVLlpj7V69ebW7//vvvnsfoFaZ13r59+3yu4+7du+Wmm26S6tWryznnnCOXX365ed7s3VUTJkyQvn37SoUKFWTQoEE5nmf27NkSExNjrubtTZ/77rvv9vu1vOk667rrNrjptuk83Va3b7/9Vq6//nrznPrcffr0kcOHD/u1HwAUDYIQYLn9+/dLr169TAj4/vvvzYH7lltuybM77PXXX5fy5cvLF198Ic8++6w8+eSTkpiYaO7LzMw0walcuXLmfg0eY8aMOev1PHHihHTt2lVWrlwpW7duleuuu066d+8uycnJWZabPHmyNGvWzCzz+OOP53ie2267TY4cOSKrVq3yzDt69KgsX75cevfuXaDXKggNRtdcc420aNFCNm3aZF4vNTVVbr/99kLvBwABUODLtAJwlM2bN5urme/bt8/n/Xq155tuuinLFaCvvPLKLMtcfvnlrlGjRpl/L1u2zFWyZEnX/v37PfcnJiaa11i8eLG5vWrVKnP7t99+8yyzdetWM2/v3r3mtl5dPTo6Os9116tNz5gxw3Nbr9jdo0ePfLdZt0ev8O328ssvu2JiYlyZmZkFeq1p06aZf+s667rrNrjptuk83VY1YcIEV5cuXbI8Z0pKillm586d+e4HAEWDFiHActp6cu2115ouGW0tmTNnjvz22295PqZp06ZZbtesWVMOHjxo/r1z506JjY01XWZurVu3Puv11FaakSNHSqNGjcxoMu1e0paT7K00rVq1yve5tOXn3XfflYyMDHP7zTfflDvuuENKlChRoNcqiK+++sq0QulzuaeGDRt6uuIKsx8AnD2CEGC5yMhI0621bNkyU88zY8YMufjii2Xv3r25PqZUqVJZbmstTPaam7y4A4d3t8+pU6fyfIwGk8WLF8vEiRPls88+M/U4Ghq0INqbdtnlR7u59LWXLl0qKSkp5vnc3WIFea2CbI+GK31dfS7v6ccff5S//e1vhdoPAM4eQQiACTLt27eX8ePHm5oYHWmlQaAw9OCt4ULrX9y+/PLLLMtUrVrVUxfj5l1o7Mvnn39uCrdvvvlmE0q0xSm3wur8aBG31t9oS9Bbb71l1vmyyy4r9Gv5sz36/Nu3bzcF3fXq1csyucNbIPcDAP8QhADLaUGztnxoAa92/bz33nty6NAh0y1UGJ07d5a6detKv3795Ouvvzah4rHHHvMc6JUe/LX7TEebaYuItsxMmTIlz+etX7++WTcNGNrNdOeddxaoFSo7bQHS1507d26W1qDCvJaO8rriiivkmWeeMV1oa9as8Wyz2+DBg01RthZEazDU7rAVK1ZI//79TYF5oPcDAP8QhADL6TDztWvXmlFSDRo0MAdwDSU6zLswtItHh8lrV5AOOx84cKBn1Ji2xLi71rQlRofZa73RpEmT5KmnnsrzeadOnSqVKlWSdu3amS6muLi4LK04BaUjuHT4v9Y0adA529fSQHX69Glp2bKlDBs2LMf26JB9DYUaerp06WJamnQ5rUHSrrVA7wcA/onQiulgrwQAZ9MAoOcV2rVrl2ktAoBQQRACEHBa16KjorSLScPP0KFDTQvLunXrgr1qAJAFl9gAEHDHjx+XUaNGmVqXKlWqmDMk51cDBADBQIsQAACwFsXSAADAWgQhAABgLYIQAACwFkEIAABYiyAEAACsRRACAADWIggBAABrEYQAAIC1CEIAAEBs9f9MF9kgKDDVBQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins=np.linspace(0,4,50)\n",
    "plt.hist(sv.ravel()/k**2,bins=bins,density=True,alpha=.5,label='mnist')\n",
    "plt.hist(nnd_sv.ravel()/k**2,bins=bins,density=True,alpha=.5,label='nuclear norm distribution samples')\n",
    "plt.legend()\n",
    "plt.xlabel('singular values')\n",
    "plt.ylabel('density')\n",
    "plt.ylim(0,1.6)\n",
    "plt.xlim(0,4)\n",
    "plt.savefig('mnistsingval.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([9.86833757e+00, 8.95390243e+00, 8.40496128e+00, 7.68237547e+00,\n",
       "        7.36449373e+00, 6.45706039e+00, 6.08456460e+00, 5.24294819e+00,\n",
       "        4.91666429e+00, 4.37192421e+00, 3.87619674e+00, 3.23763253e+00,\n",
       "        2.96176160e+00, 2.48563916e+00, 2.23497471e+00, 2.00251493e+00,\n",
       "        1.66642851e+00, 1.51378926e+00, 1.27012660e+00, 1.05167043e+00,\n",
       "        9.03232260e-01, 7.99605613e-01, 7.22585808e-01, 6.24560601e-01,\n",
       "        4.99928553e-01, 4.56517390e-01, 3.97702266e-01, 3.22082821e-01,\n",
       "        2.88474179e-01, 2.00251493e-01, 1.87648252e-01, 1.52639250e-01,\n",
       "        1.47037810e-01, 9.94255666e-02, 8.26212455e-02, 7.28187248e-02,\n",
       "        6.86176445e-02, 7.98205253e-02, 6.30162042e-02, 3.64093624e-02,\n",
       "        1.96050413e-02, 3.22082821e-02, 1.82046812e-02, 1.68043211e-02,\n",
       "        1.82046812e-02, 1.96050413e-02, 2.80072019e-03, 1.54039610e-02,\n",
       "        4.20108028e-03]),\n",
       " array([0.        , 0.01020408, 0.02040816, 0.03061224, 0.04081633,\n",
       "        0.05102041, 0.06122449, 0.07142857, 0.08163265, 0.09183673,\n",
       "        0.10204082, 0.1122449 , 0.12244898, 0.13265306, 0.14285714,\n",
       "        0.15306122, 0.16326531, 0.17346939, 0.18367347, 0.19387755,\n",
       "        0.20408163, 0.21428571, 0.2244898 , 0.23469388, 0.24489796,\n",
       "        0.25510204, 0.26530612, 0.2755102 , 0.28571429, 0.29591837,\n",
       "        0.30612245, 0.31632653, 0.32653061, 0.33673469, 0.34693878,\n",
       "        0.35714286, 0.36734694, 0.37755102, 0.3877551 , 0.39795918,\n",
       "        0.40816327, 0.41836735, 0.42857143, 0.43877551, 0.44897959,\n",
       "        0.45918367, 0.46938776, 0.47959184, 0.48979592, 0.5       ]),\n",
       " <BarContainer object of 49 artists>)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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w4YNFRnS4f9o5xjaOYZ2jqOtq7ud8x6PPHiMHTu2y7Klh4+3v/3tacCAAWnTpk2d7uevR48evVP5hoaG4trRHnvskSopb2zf2JWnnWNo5xjaOY62rt527qrHo2Lbq+++++7p8MMPT8uWLevUm5G/njJlStmPAwCqTEWGXfJhlJkzZ6Yjjjii2NsjX2q7ZcuWdPrp5U3yAQCqU0XCx6c+9an0t7/9LV188cXFJmPvfe9705IlS3aahBotH9655JJLdhrmoVzaOYZ2jqGd42jr+mnniuzzAQAQNucDAOC/ET4AgFDCBwAQSvgAAELVXPhYsGBB2meffdKgQYOKA+5WrVr1X8v/8Ic/TAceeGBRfuLEiennP/95WF3rpZ0fe+yx9PGPf7won+9amy+9pvx2XrhwYTr22GPT8OHDiys/T6mr73/efDvfddddxTYC+WaIQ4YMKVbzff/73w+tbz29R3dYvHhx8f5x6qmnVryO9dbOixYtKtp2xyv/vIrKasjixYuz3XffPbvpppuyxx57LPvCF76Q7bHHHtmmTZt2Wf7Xv/51NmDAgOyqq67Kfv/732cXXnhhtttuu2WPPvpoeN1ruZ1XrVqVnXfeedntt9+ejR49Orv66qvD61wP7fzpT386W7BgQfbwww9njz/+ePbZz342a2xszJ577rnwutdyOy9fvjy76667iveM9evXZ/PmzSveR5YsWRJe91pv6w7PPPNM9s53vjM79thjs2nTpoXVt17a+eabb86GDRuW/fWvf91+bdy4saJ1rKnwceSRR2azZs3a/nrr1q3Z2LFjs5aWll2W/+QnP5lNnTq1072jjjoqO/PMMyte13pq5x3tvffewkdAO+f+/e9/Z0OHDs1uueWWCtay+r3Vds5NmjSp+OWF8ts6/z4++uijs+9+97vZzJkzhY8KtHMePvJfVCLVzLDLq6++mtasWVN0NXfo379/8bq1tXWXn5Pf37F87qSTTnrD8vSsnemddn7llVfSa6+9lvbcc88K1rS+2zn/BS4/OmLdunXpuOOOq3Bt67Otv/GNb6SRI0emz3/+80E1rc92fvnll9Pee+9dHDg3bdq0Yri8kmomfLzwwgtp69atO+2imr/Od1ndlfz+mylPz9qZ3mnn888/vzhd8vUBm7fezm1tbeltb3tbcZbV1KlT0/z589OJJ54YUOP6ausHHngg3XjjjcV8JirXzu9+97vTTTfdlO655570gx/8oDiP7eijj07PPfdcqqrt1YHedcUVVxQT9FasWFH5iWN1aOjQoemRRx4pflvMez7y86ze9a53peOPP763q1Yz8qPZTzvttCJ45KelUzn5oa87HvyaB4+DDjooXX/99enSSy+tyDNrJnzk35wDBgxImzZt6nQ/fz169Ohdfk5+/82Up2ftTGw7z507twgfv/rVr9Khhx5a4ZrWZzvn3dj77bdf8e98tcvjjz+eWlpahI8S2/qpp55Kf/zjH9Mpp5yy/V7+G3lu4MCBxVDXvvvuG1Dz+nuP3m233dKkSZPS+vXrK1TLGhp2ybs/Dz/88OK3kB2/UfPXOya6HeX3dyyfW7p06RuWp2ftTFw7X3XVVcVvKvlBjvlyUGK+n/PPaW9vr1At67Ot8y0QHn300aKHqeP62Mc+lpqamop/53MTqMz3dD5sk7f9mDFjUsVkNba8qKGhIVu0aFGxDO6MM84olhd1LBk67bTTsgsuuKDTUtuBAwdmc+fOLZYmXnLJJZbaVqCd29vbi+Wf+TVmzJhi2W3+7yeffLIX/xe1185XXHFFsbzuRz/6Uaclcy+99FIv/i9qr50vv/zy7Je//GX21FNPFeXz94/8fWThwoW9+L+ozbZ+PatdKtPOc+bMye69997ie3rNmjXZ9OnTs0GDBhXLdCulpsJHbv78+dn48eOLN+F8udHKlSu3f+yDH/xg8c27ozvvvDM74IADivIHH3xw9rOf/awXal3b7Zyv0c9z7uuvvBzltXO+jHlX7ZyHaspr569//evZfvvtV7w5Dx8+PJsyZUrxZk9l3qN3JHxUpp1nz569veyoUaOyj3zkI9natWuzSuqX/1G5fhUAgBqd8wEAVAfhAwAIJXwAAKGEDwAglPABAIQSPgCAUMIHABBK+AAAQgkfAEAo4QMACCV8AAChhA8AIEX6X9BCnRuCc6MHAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins=np.linspace(0,.5,50)\n",
    "plt.hist(sv.min(1)/k**2,bins=bins,density=True,alpha=.5,label='mnist')\n",
    "plt.hist(nnd_sv.min(1)/k**2,bins=bins,density=True,alpha=.5,label='nuclear norm distribution samples')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "gaussian_samples=np.random.randn(len(sv),k,k)*np.std(df.ravel())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins=np.linspace(0,4,50)\n",
    "plt.hist(np.linalg.svd(gaussian_samples)[1].ravel()/k**2,density=True,label='iid gaussian', bins=bins)\n",
    "plt.hist(sv.ravel()/k**2,density=True,alpha=.5,label='mnist',bins=bins)\n",
    "plt.legend()\n",
    "plt.xlabel('singular values')\n",
    "plt.ylabel('density')\n",
    "plt.ylim(0,1.6)\n",
    "plt.xlim(0,4)\n",
    "plt.savefig('mnistsingvalvsgaussian.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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s2DBAhNsrDWeAumzkNrvbypIAICQpGv2aPVEq076ZajrBSkd5wPcDgEJABCytMtMx93oWCNdhFFnamlXEnA7BCQAQEjSwby6zhEyX+/evdO8InmgYZo/AACADQEJAADAhoAEAABgQ0ACAACwISABAADYEJAAACFJV7yuXbu2081AkGKaPwCEg7iJmfdYLaIlEOiZ6vVcYKkNU8uXL/d5IlqEJwISACAk3X333eYCpAddbAAAxzVv3txUe/T8XXom+2LFipmTw+r50/r06WNOVHr//ffLF198YfZfu3atOft8bGys1K9f35zkVE+4qqtmJ9fFpvfR047oSVD1DPAPPvig/PLLL+a8YXpy2R9//NEcUy+6DeGNgAQACAh6xnk9DcjGjRtNWHrxxRfl6aefNsFny5Yt0qZNG+nRo4dcvnzZfZ/XX3/dnHx206ZNki1bNnNmel9u3LghnTp1ksjISNm+fbvEx8dL//79TRjq0qWLDB06VKpVqyaJiYnmotsQ3uhiAwAEhFq1asmoUaPMz9HR0TJp0iQTmPr162e2jRkzRt555x0TcCxvvfWWCT3qtddekw4dOpgzufs6g7uesPbRRx+VChUqmG1VqlRx365dcRqwihcvninPFYGPChIAICDUrFnT/XPWrFmlcOHCUqNGDfc27XZTJ0+e9HmfEiVKJLndUqhQIXNusLZt28pjjz0ms2bNMpUiIDkEJABAQMiePbvXde3+8tym19WtW7d83sfX7Z7ef/9907WmXXZLliyRSpUqyfr16/3+PBAaCEgAgLBRp04d0323bt06qV69uixatMhsz5Ejh9y8edPp5iGAEJAAACHv0KFDJhhpBUlnrn311Veyb98+9zikcuXKmX10HaTffvtNrl696nST4TAGaQNBYEbM3iTbolpXcqQtQDDSZQB2795tZsqdPn3ajFd6+eWX5fnnnze3d+7cWZYtWyYtWrSQs2fPmu44HbOE8BXhcrlcTjdi7ty5MnXqVDl+/LiZxTB79myzVkVyli5dKqNHj5bDhw9LxYoVZfLkydK+fXtz2/Xr180siFWrVsnBgwclf/780qpVKzMbomTJku5jnDlzxkwj/de//iVZsmQxHw4dtJfaRcV0RoQeW2dF5MuXzw+vAkIpvGQGAhLsdPaWVkHKly+fZBYXEE6upPBZSO33t+MVJB0oN2TIEJk3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vfjii678+fOb30OJiYnuy+XLl9373O730I0bN1zVq1d3tWnTxrVt2zbX6tWrXffcc48rOjraoWcVeu/D/v37XePHjzevv34m9HfTfffd53r44Yfdx+B9cBYByc+6dOniKlGihCtHjhyuUqVKmev6QbDoF/JLL73kKliwoCt37tyuJ554wnxocGfi4uLMl7L9olPLran+o0ePdhUrVsxM72/ZsqVrz549Xsc4ffq0+TK+++67zTTaPn36mC923Pl7oF8K+ktef7nrFPOyZcu6+vXr5zV9WfEe3Dlf74Fe3n///TT9Hjp8+LDrkUceceXKlcv8kad//F2/ft2BZxSa70NCQoIJQ4UKFTK/k+6//37X8OHDXefOnfM6Du+DcyL0P05WsAAAAAINY5AAAABsCEgAAAA2BCQAAAAbAhIAAIANAQkAAMCGgAQAAGBDQAIAALAhIAEAANgQkACEhN69e0unTp2cbgaAEEFAAgAAsCEgAUAqXbt2LdMeS88CdePGjUx7PADeCEgAMlzz5s3llVdekVdffVUKFSokxYsXl3HjxrlvP3z4sERERMi2bdvc286ePWu2rV271r1t586d8uijj0q+fPkkb9688tBDD8mBAwd8PuatW7dk4sSJUr58ecmVK5fUqlVLPvnkE/ftN2/elL59+7pvf+CBB2TWrFk+u+3eeustKVmypNnHF30utWvXln/+859Srlw5yZ8/v3Tt2lUuXLjg3ufq1avmNShatKjcdddd0qxZM/nhhx/ct+vz1Of7xRdfSL169SRnzpzy3Xffmddu4MCBMnjwYClYsKAUK1ZM3n33Xbl06ZL06dPHvA7333+/uR8A/yEgAcgUH3zwgeTJk0c2bNggU6ZMkfHjx0tMTEyq7//rr7/Kww8/bILDmjVrZPPmzfKXv/wl2SqLhqMPP/xQ5s2bZ4JVVFSUPPfcc/LNN9+4A9S9994rS5culZ9//lnGjBkjI0eOlI8//tjrOLGxsbJnzx7T1pUrVybbPg1qy5cvN/voRR9n0qRJ7ts1HH766afmddiyZYsJNW3btpUzZ854Hee1114z99u1a5fUrFnT/doVKVJENm7caMLSiy++KE8//bQ0bdrUHKtNmzbSo0cPuXz5cqpfTwC34QKADBYZGelq1qyZ17YGDRq4RowYYX4+dOiQS38dbd261X3777//brbFxcWZ69HR0a7y5cu7rl275vMxevXq5erYsaP5+cqVK67cuXO71q1b57VP3759Xd26dUu2nS+//LKrc+fOXscsVqyY6+rVqyk+v7Fjx5rHO3/+vHvb8OHDXY0aNTI/X7x40ZU9e3bXwoUL3bfr8yhZsqRrypQp5ro+T32+y5cvT/G1u3HjhitPnjyuHj16uLclJiaa+8bHx6fYTgCpl+12AQoA/MGqhlhKlCghJ0+eTPX9tftNu9SyZ89+2333799vqimtW7dOMoaoTp067utz586V9957TxISEuSPP/4wt2tXmacaNWpIjhw5bvuY2rWm3V2+np9Wl65fvy4PPvig+3Z9Hg0bNjSVIk/169dP8bXLmjWrFC5c2LTLot1uKi2vJ4CUEZAAZAp7sNHxNtrNpbJkyeIemGzRQOFJxwml1sWLF82/n3/+uZQqVcrrNu2iU4sXL5Zhw4bJtGnTpEmTJibcTJ061XQBetJuwTt9fmnh6/F8Hdtzm15X6Xk8AL4RkAA47p577jH/JiYmuis8ngO2rSqKjsXR4HS7KlLVqlVNENLKUGRkpM99vv/+ezOG56WXXnJvS27A952qUKGCqULpY5YtW9Zs0+ehg7R18DWAwENAAuA4rQ41btzYDE7WWWXaVTRq1CivfQYMGCCzZ882s8Oio6PNTLH169ebbir77DKtBml1SAdma1VFZ4ydO3fOBBSdAderVy+pWLGiGcT95ZdfmsfUGWgaWPRnf9OqkA6sHj58uJnFV6ZMGTNQXbsBdSYdgMBDQAIQEHQskIYFneKugUcDhM7Osui4G529piFDq0I6FkfHC3mO6/H05ptvmsqUzmY7ePCgFChQQOrWrWtmqqnnn39etm7dKl26dDFdVN26dTPVpIyaLq/hT8OazjbT6f861kjDmU7dBxB4InSkttONAAAACCSsgwQAAGBDQAIAALAhIAEAANgQkAAAAGwISAAAADYEJAAAABsCEgAAgA0BCQAAwIaABAAAYENAAgAAsCEgAQAAiLf/D4Z8bqqC8YOlAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.linalg.svd(gaussian_samples)[1].sum(1),density=True,bins=xs,label='iid gaussian samples',alpha=.5)\n",
    "plt.hist(sv.sum(1),density=True,bins=xs,label='mnist',alpha=.5)\n",
    "plt.xlabel('nuclear norm')\n",
    "plt.ylabel('density')\n",
    "plt.legend()\n",
    "plt.ylim(0,.023)\n",
    "plt.xlim(xs.min(),xs.max())\n",
    "plt.savefig('nucnormvsgaussian.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(4,4))\n",
    "plt.hist(sv.sum(1),density=True,bins=50,label='mnist',color='blue')\n",
    "plt.hist(np.linalg.svd(gaussian_samples)[1].sum(1),density=True,bins=xs,label='iid gaussian',alpha=.5,color='orange')\n",
    "plt.plot(xs,gamma.pdf(xs,a=n*m,scale=lam/(n*m)),label='Gamma',color='green')\n",
    "plt.xlabel('nuclear norm')\n",
    "plt.ylabel('density')\n",
    "plt.legend()\n",
    "plt.ylim(0,.023)\n",
    "plt.xlim(xs.min(),xs.max())\n",
    "plt.savefig('mnistgaussianndnucnorm.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_hist(bins,X,**kwargs):\n",
    "    a,b,*_=np.histogram(X,bins=bins,density=True)\n",
    "    bin_centers = 0.5*(b[1:]+b[:-1])\n",
    "    plt.plot(bin_centers,a,**kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(4,4))\n",
    "bins=np.linspace(0,4,50)\n",
    "plot_hist(bins,sv.ravel()/k**2,label='mnist',color='blue')\n",
    "plot_hist(bins,np.linalg.svd(gaussian_samples)[1].ravel()/k**2,label='iid gaussian',color='orange')\n",
    "plot_hist(bins,nnd_sv.ravel()/k**2,label='nuclear norm distribution',color='green')\n",
    "plt.legend()\n",
    "plt.xlabel('singular values')\n",
    "plt.ylabel('density')\n",
    "plt.ylim(0,1.6)\n",
    "plt.xlim(0,4)\n",
    "plt.savefig('mnistgaussiannndsingvals.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
