{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d7054c11",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import sys\n",
    "sys.path += ['utils/']  \n",
    "\n",
    "from node_embedding import *\n",
    "from dcsbm import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "645aa56b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def CreateEmbedding_exact(Pv, dim = 128, p0 = None, n_epochs = 30, sum_partials = False, η = .8, verbose = True):\n",
    "\n",
    "    # sample size\n",
    "    n = Pv[0].shape[0]\n",
    "\n",
    "    eps = η/n_epochs\n",
    "    \n",
    "    # initialize the weights\n",
    "    X = np.random.uniform(-1,1, (n, dim))\n",
    "    X = normalize(X, norm = 'l2', axis = 1)\n",
    "\n",
    "    for epoch in range(n_epochs):\n",
    "        \n",
    "        # print update\n",
    "        if verbose:\n",
    "            print(\"[%-25s] %d%%\" % ('='*(int((epoch+1)  /n_epochs*25)-1) + '>', (epoch+1)/(n_epochs)*100), end = '\\r')\n",
    "\n",
    "        # compute the gradient\n",
    "        GRAD = _computeGrad_exact(Pv, X, np.ones(n)/n, sum_partials)\n",
    "        \n",
    "        # update the weights\n",
    "        D = diags((GRAD * X).sum(axis = 1))\n",
    "        GRAD = GRAD - D@X\n",
    "        GRAD = normalize(GRAD, norm = 'l2', axis = 1)\n",
    "        X = np.sqrt(1-η**2)*X - η*GRAD\n",
    "\n",
    "        η = η - eps\n",
    "            \n",
    "    return X\n",
    "\n",
    "\n",
    "def _computeGrad_exact(Pv, X, p0, sum_partials):\n",
    "\n",
    "    n, dim = np.shape(X)\n",
    "\n",
    "    # \"energy\" part of the gradient\n",
    "    if sum_partials:\n",
    "        U, Ut = _computeUsum(Pv, X, X)\n",
    "\n",
    "    else:\n",
    "        U, Ut = _computeUprod(Pv, X, X)\n",
    "\n",
    "\n",
    "    M = np.exp(X@X.T)\n",
    "    z = M@np.ones(n)\n",
    "    Z_1 = np.diag(z**(-1))\n",
    "#     Zgrad = M@(Z_1@X) #+ Z_1@(M@X)\n",
    "    Zgrad = Z_1@(M@X)\n",
    "\n",
    "    P0 = np.reshape(p0, (n,1))\n",
    "    u = np.reshape(np.ones(n), (n,1))\n",
    "    E = np.sum(p0)\n",
    "\n",
    "    return -(U + Ut) + (u@(P0.T@X))/E + P0@(u.T@X)/E + Zgrad\n",
    "\n",
    "\n",
    "\n",
    "def _computeUsum(Pv, X, Y):\n",
    "    '''\n",
    "    This function computes the \"energetic\" contribution of the gradient in the case in which P is written as a sum of products of matrices\n",
    "\n",
    "    Use: U, Ut = _computeUsum(Pv, X, Y)\n",
    "\n",
    "    Inputs:\n",
    "        * Pv (list sparse array): The matrix P is given by a sum of the powers of the only elements contained in Pv.\n",
    "        * X (array): input weights with respect to which the gradient is computed\n",
    "        * Y (array): output weights with respect to which the gradient is computed\n",
    "       \n",
    "    Output:\n",
    "        * U (array): first contribution to the gradient\n",
    "        * Ut (array): second contribution to the gradient (coming from the transpose)\n",
    "\n",
    "    '''\n",
    "\n",
    "    # \"standard\" contribution U\n",
    "    U = [Pv[0]@Y]\n",
    "\n",
    "    for i in range(1, len(Pv)):\n",
    "        U.append(Pv[i]@U[-1])\n",
    "\n",
    "\n",
    "    # transpose contribution Ut\n",
    "    Pv = Pv[::-1]\n",
    "    Ut = [X.T@Pv[0]]\n",
    "\n",
    "    for i in range(1, len(Pv)):\n",
    "        Ut.append(Ut[-1]@Pv[i])\n",
    "\n",
    "    U = np.sum(U, axis = 0)/len(Pv)\n",
    "    Ut = np.sum(Ut, axis = 0)/len(Pv)\n",
    "\n",
    "    return U, Ut.T\n",
    "\n",
    "\n",
    "def _computeUprod(Pv, X, Y):\n",
    "    '''\n",
    "    This function computes the \"energetic\" contribution of the gradient in the case in which P is written as a product of matrices\n",
    "\n",
    "    Use: U, Ut = _computeUprod(Pv, X, Y)\n",
    "\n",
    "    Inputs:\n",
    "        * Pv (list sparse array): The matrix P is given by a sum of the powers of the only elements contained in Pv.\n",
    "        * X (array): input weights with respect to which the gradient is computed\n",
    "        * Y (array): output weights with respect to which the gradient is computed\n",
    "\n",
    "    Output:\n",
    "        * U (array): first contribution to the gradient\n",
    "        * Ut (array): second contribution to the gradient (coming from the transpose)\n",
    "\n",
    "    '''\n",
    "\n",
    "    # \"standard\" contribution U\n",
    "    U = Pv[0]@Y\n",
    "\n",
    "    for i in range(1, len(Pv)):\n",
    "        U = Pv[i]@U\n",
    "\n",
    "\n",
    "    # transpose contribution Ut\n",
    "    Pv = Pv[::-1]\n",
    "    Ut = X.T@Pv[0]\n",
    "\n",
    "    for i in range(1, len(Pv)):\n",
    "        Ut = Ut@Pv[i]\n",
    "\n",
    "    return U, Ut.T\n",
    "\n",
    "\n",
    "def NodeEmbedding_exact(A, dim, n_epochs = 30, walk_length = 5, verbose = True, η = 0.5):\n",
    "   \n",
    "    \n",
    "    # check that all entries of A are positive\n",
    "    if not (A[A.nonzero()] > 0).all():\n",
    "        raise DeprecationWarning(\"The weighted adjacency matrix has negative entries\")\n",
    "    \n",
    "    # create the probability matrix\n",
    "    n = A.shape[0]\n",
    "    d = A@np.ones(n)\n",
    "    D_1 = diags(d**(-1))\n",
    "    P = D_1.dot(A)\n",
    " \n",
    "    # Eder\n",
    "    embedding = CreateEmbedding_exact([P for i in range(walk_length)], dim = dim, n_epochs = n_epochs, \n",
    "                        sum_partials = True, verbose = verbose, η = η)\n",
    "    \n",
    "    return embedding\n",
    "\n",
    "\n",
    "def _computeGrad(Pv, X, Y, ℓ, p0, sum_partials, sym):\n",
    "    '''\n",
    "    This function computes the gradient of the loss function\n",
    "\n",
    "    Use: GRADX, GRADY = _computeGrad(Pv, X, Y, ℓ, p0, sum_partials)\n",
    "\n",
    "    Inputs:\n",
    "        * Pv (list sparse array): the P matrix is provided by the product of all the elements appearing in Pv. Note the use of the `walk_length` parameter in the case in which P is the sum of powers of a given matrix.\n",
    "        * X (array): input weights with respect to which the gradient is computed\n",
    "        * Y (array): output wieghts with respect to which the gradient is computed\n",
    "        * ℓ (array): label assignment to create the mixture of Gaussians\n",
    "        * p0 (array): array of size n that specifies the \"null model\" probability\n",
    "        * sum_partials (bool): if True, P is written as the sum of powers\n",
    "        \n",
    "    Output:\n",
    "        * GRADX, GRADY (array): gradient of the cost function computed in X and Y\n",
    "\n",
    "    '''\n",
    "\n",
    "    n, dim = np.shape(X)\n",
    "    m, _ = np.shape(Y)\n",
    "    k = len(np.unique(ℓ))\n",
    "\n",
    "    # compute the parameters\n",
    "    π = np.array([np.sum(ℓ == a)/n for a in range(k)])\n",
    "    μ = np.stack([np.mean(Y[ℓ == a], axis = 0) for a in range(k)])\n",
    "\n",
    "    # Z part of the gradient\n",
    "    Ω = [np.cov((Y[ℓ == a]).T) for a in range(k)]\n",
    "    Z = np.exp(np.array([X@μ[a] + 0.5*(X * X@Ω[a])@np.ones(dim) for a in range(k)]).T)@np.diag(π)\n",
    "    Zgrad = diags(1/(Z@np.ones(k)))@(Z@μ + np.sum([diags(Z[:,a])@X@Ω[a] for a in range(k)], axis = 0))\n",
    "\n",
    "\n",
    "    # \"energy\" part of the gradient\n",
    "    if sum_partials:\n",
    "        U, Ut = _computeUsum(Pv, X, Y)\n",
    "\n",
    "    else:\n",
    "        U, Ut = _computeUprod(Pv, X, Y)\n",
    "\n",
    "    P0 = np.reshape(p0, (m,1))\n",
    "    u = np.reshape(np.ones(n), (n,1))\n",
    "    E = np.sum(p0)\n",
    "\n",
    "    return -U + Zgrad + (u@(P0.T@Y))/E + u@(u.T@X)/n*(1-sym), -Ut + P0@(u.T@X)/E + P0@(P0.T@Y)/E*(1-sym)\n",
    "    \n",
    "\n",
    "def _Clustering(X, k):\n",
    "    '''This function generates the label assignment for the Gaussian approximation given the embedding\n",
    "\n",
    "    Use: ℓ = _Clustering(X, k)\n",
    "\n",
    "    Inputs:\n",
    "        * X (array): embedding matrix of size (n x dim)\n",
    "        * k (int): number of clusters to look for\n",
    "\n",
    "    Output:\n",
    "        * ℓ (array): entry-wise label assignment into one of the k clasess.\n",
    "\n",
    "    '''\n",
    "\n",
    "    n, dim = np.shape(X)\n",
    "\n",
    "    kmeans = faiss.Kmeans(dim, k, verbose = False, spherical = True)\n",
    "    kmeans.train(np.ascontiguousarray(X).astype('float32'))\n",
    "    _, ℓ = kmeans.assign(np.ascontiguousarray(X).astype('float32'))\n",
    "\n",
    "    return ℓ\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d3543d39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "i: 10/10; n: 10000\r"
     ]
    }
   ],
   "source": [
    "from time import time\n",
    "\n",
    "nv = np.linspace(500, 10000, 20).astype(int)\n",
    "n_epochs = 25\n",
    "n_iter = 10\n",
    "\n",
    "tv, tev = [[] for i in range(n_iter)], [[] for i in range(n_iter)]\n",
    "\n",
    "\n",
    "for i in range(n_iter):\n",
    "    for n in nv:\n",
    "        print(f'i: {i+1}/{n_iter}; n: {n}', end = '\\r')\n",
    "        \n",
    "#         θ = np.random.negative_binomial(2, 0.4, size = (n,1))\n",
    "        θ = np.random.negative_binomial(3, 0.3, size = (n,1))\n",
    "        P_ = np.minimum(θ@θ.T/n, 1)\n",
    "\n",
    "        dim = 32\n",
    "        A = np.random.binomial(1, P_)\n",
    "        A = np.triu(A)\n",
    "        A = A + A.T\n",
    "        A = csr_matrix(A)\n",
    "\n",
    "        t0 = time()\n",
    "        res = NodeEmbedding(A, dim, n_epochs = n_epochs, walk_length = 3, k = 1, verbose = False, η = 1., sym = True)\n",
    "        t = time() - t0\n",
    "\n",
    "        t0 = time()\n",
    "        res_exact = NodeEmbedding_exact(A, dim, n_epochs = n_epochs, walk_length = 3, verbose = False, η = 1.)\n",
    "        te = time() - t0\n",
    "\n",
    "        tv[i].append(t)\n",
    "        tev[i].append(te)\n",
    "        \n",
    "        del A\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6133cf82",
   "metadata": {},
   "outputs": [],
   "source": [
    "tv, tev, nv = np.array(tv), np.array(tev), np.array(nv)\n",
    "np.savetxt('saved_files/test_against_full/tv.dat', tv)\n",
    "np.savetxt('saved_files/test_against_full/tev.dat', tev)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "96c02023",
   "metadata": {},
   "outputs": [],
   "source": [
    "tv = np.loadtxt('saved_files/test_against_full/tv.dat')\n",
    "tev = np.loadtxt('saved_files/test_against_full/tev.dat')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "962fb44e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "\n",
    "n = 3000\n",
    "θ = np.random.negative_binomial(3, 0.3, size = (n,1))\n",
    "P_ = np.minimum(θ@θ.T/n, 1)\n",
    "A = np.random.binomial(1, P_)\n",
    "A = np.triu(A)\n",
    "A = (A + A.T)\n",
    "A = csr_matrix(A).sign()\n",
    "G = nx.from_scipy_sparse_matrix(A)\n",
    "\n",
    "\n",
    "d = A@np.ones(n)\n",
    "D_1 = diags(d**(-1))\n",
    "P = D_1@A"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "23153f67",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[========================>] 100%\r"
     ]
    }
   ],
   "source": [
    "# sample size\n",
    "\n",
    "dim = 32\n",
    "η0 = .7\n",
    "η = copy(η0)\n",
    "n_epochs = 150\n",
    "eps = η/n_epochs\n",
    "\n",
    "# initialize the weights\n",
    "X0 = np.random.uniform(-1,1, (n, dim))\n",
    "X0 = normalize(X0, norm = 'l2', axis = 1)\n",
    "\n",
    "X = copy(X0)\n",
    "X_exact = []\n",
    "\n",
    "for epoch in range(n_epochs):\n",
    "\n",
    "    # print update\n",
    "    print(\"[%-25s] %d%%\" % ('='*(int((epoch+1)  /n_epochs*25)-1) + '>', (epoch+1)/(n_epochs)*100), end = '\\r')\n",
    "\n",
    "    # compute the gradient\n",
    "    GRAD = _computeGrad_exact([P], X, np.ones(n)/n, False)\n",
    "\n",
    "    # update the weights\n",
    "    D = diags((GRAD * X).sum(axis = 1))\n",
    "    GRAD = GRAD - D@X\n",
    "    GRAD = normalize(GRAD, norm = 'l2', axis = 1)\n",
    "    X = np.sqrt(1-η**2)*X - η*GRAD\n",
    "\n",
    "    η = η - eps\n",
    "    \n",
    "    X_exact.append(X)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "028edfec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[========================>] 100%\r"
     ]
    }
   ],
   "source": [
    "X = copy(X0)\n",
    "η = copy(η0)\n",
    "\n",
    "for epoch in range(n_epochs):\n",
    "\n",
    "    # print update\n",
    "    print(\"[%-25s] %d%%\" % ('='*(int((epoch+1)  /n_epochs*25)-1) + '>', (epoch+1)/(n_epochs)*100), end = '\\r')\n",
    "\n",
    "    # compute the gradient\n",
    "    GRADX, GRADY = _computeGrad([P], X, X, np.zeros(n).astype(int), np.ones(n)/n, False, True)\n",
    "    GRAD = GRADX + GRADY\n",
    "    \n",
    "    # update the weights\n",
    "    D = diags((GRAD * X).sum(axis = 1))\n",
    "    GRAD = GRAD - D@X\n",
    "    GRAD = normalize(GRAD, norm = 'l2', axis = 1)\n",
    "    X = np.sqrt(1-η**2)*X - η*GRAD\n",
    "\n",
    "    η = η - eps\n",
    "    \n",
    "X_fin = copy(X)\n",
    "\n",
    "max_kappa = 9\n",
    "X_approx =  [[] for i in range(1,max_kappa)]\n",
    "    \n",
    "for k in range(1,max_kappa):\n",
    "    η = copy(η0)\n",
    "    ℓ = _Clustering(X_fin, k)\n",
    "    X = copy(X0)\n",
    "\n",
    "    for epoch in range(n_epochs):\n",
    "\n",
    "        # print update\n",
    "        print(\"[%-25s] %d%%\" % ('='*(int((epoch+1)  /n_epochs*25)-1) + '>', (epoch+1)/(n_epochs)*100), end = '\\r')\n",
    "\n",
    "        # compute the gradient\n",
    "        GRADX, GRADY = _computeGrad([P], X, X, ℓ, np.ones(n)/n, False, True)\n",
    "        GRAD = GRADX + GRADY\n",
    "\n",
    "        # update the weights\n",
    "        D = diags((GRAD * X).sum(axis = 1))\n",
    "        GRAD = GRAD - D@X\n",
    "        GRAD = normalize(GRAD, norm = 'l2', axis = 1)\n",
    "        X = np.sqrt(1-η**2)*X - η*GRAD\n",
    "\n",
    "        η = η - eps\n",
    "\n",
    "        X_approx[k-1].append(X)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0acd7af6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 3, figsize = (14, 4))\n",
    "\n",
    "\n",
    "nv = np.linspace(500, 10000, 20).astype(int)\n",
    "m = np.mean(tv, axis = 0)\n",
    "s = np.std(tv, axis = 0)\n",
    "\n",
    "α = np.mean(m*nv)/np.mean(nv**2)\n",
    "ax[1].plot(nv, α*nv, color = '#e63946', linewidth = 5, linestyle = '-', label = r'$y \\propto x$', alpha = 0.7)\n",
    "\n",
    "ax[1].plot(nv, m, color = '#264653', linewidth = 0, marker = 'o')\n",
    "ax[1].fill_between(nv, m-s, m+s, alpha = 0.3, color = '#2a9d8f')\n",
    "\n",
    "\n",
    "ax[1].tick_params(axis='both', which='major', labelsize = 16)\n",
    "ax[1].tick_params(axis = 'x', rotation = 30)\n",
    "ax[1].set_xlabel('n', fontsize = 24)\n",
    "ax[1].set_ylabel('comp. time (s)', fontsize = 24)\n",
    "ax[1].legend(fontsize = 20, loc = 2)\n",
    "ax[1].set_title('EDRep', fontsize = 26)\n",
    "\n",
    "###############################\n",
    "m = np.mean(tev, axis = 0)\n",
    "s = np.std(tev, axis = 0)\n",
    "\n",
    "α = np.mean(m*nv**2)/np.mean(nv**4)\n",
    "ax[0].plot(nv, α*nv**2, color = '#e63946', linewidth = 5, linestyle = '-', label = r'$y \\propto x^2$', alpha = 0.7)\n",
    "ax[0].plot(nv, m, color = '#264653', linewidth = 0, marker = 'o')\n",
    "ax[0].fill_between(nv, m-s, m+s, alpha = 0.3, color = '#2a9d8f')\n",
    "\n",
    "ax[0].tick_params(axis='both', which='major', labelsize = 16)\n",
    "ax[0].tick_params(axis = 'x', rotation = 30)\n",
    "ax[0].set_xlabel('n', fontsize = 24)\n",
    "ax[0].set_ylabel('comp. time (s)', fontsize = 24)\n",
    "ax[0].legend(fontsize = 20, loc = 2)\n",
    "ax[0].set_title('Full softmax', fontsize = 26)\n",
    "\n",
    "\n",
    "#################################\n",
    "cmap = plt.cm.get_cmap('rainbow', len(X_approx))\n",
    "\n",
    "for i in range(len(X_approx)):\n",
    "#     dist = np.array([(np.linalg.norm(K.T@K)**2 + np.linalg.norm(Q.T@Q)**2 - 2*np.linalg.norm(K.T@Q)**2) for K, Q in zip(X_exact, X_approx[i])])\n",
    "    dist = np.array([np.linalg.norm(np.abs(K - Q)) for K, Q in zip(X_exact, X_approx[i])])\n",
    "#     dist_rel = np.array([np.linalg.norm(K) for K in X_exact])\n",
    "    ax[2].plot(np.log10(dist/np.sqrt(n)), label = r'$\\kappa = $' + str(i+1), color = cmap(i))\n",
    "    \n",
    "# ax[2].legend(ncols = 2, fontsize = 12)\n",
    "ax[2].tick_params(axis='both', which='major', labelsize = 16)\n",
    "ax[2].tick_params(axis = 'x', rotation = 30)\n",
    "ax[2].set_xlabel('epoch', fontsize = 24)\n",
    "ax[2].set_ylabel(r'${\\rm log}_{10}(C_t)$', fontsize = 24)\n",
    "# ax[2].set_title('Embedding difference', fontsize = 26)\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig('../../paper/v6_NIPS_rebuttal/Figures/new.pdf', dpi = 400, bbox_inches = 'tight')\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1bd9d133",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.12135379,  0.31618733,  0.60007651,  1.43094766,  2.01860771,\n",
       "        3.67249351,  5.21826408,  6.78284695,  8.13547094,  9.23936315,\n",
       "       11.36215243, 13.26816249, 15.16753402, 17.8631747 , 22.52997992,\n",
       "       25.43393734, 25.31032104, 29.23176932, 32.61956761, 37.94481111])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(tev, axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b2cfd5e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.102266  , 0.16223524, 0.2078249 , 0.24746287, 0.31322761,\n",
       "       0.38385673, 0.43934555, 0.50462906, 0.55580013, 0.61813321,\n",
       "       0.69411914, 0.76600177, 0.82527821, 0.90136158, 0.96489785,\n",
       "       1.04344513, 1.0615016 , 1.1229104 , 1.21275012, 1.29365532])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(tv, axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "110c211e",
   "metadata": {},
   "outputs": [],
   "source": [
    "X =  X_approx[-1][-1]\n",
    "d = A@np.ones(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "496c56fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.026, 49.58506944444438)"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "θ = np.random.negative_binomial(3, 0.3, size = (n,1))\n",
    "P_ = np.minimum(θ@θ.T/n, 1)\n",
    "d = P_@np.ones(n)\n",
    "np.mean(d == 0), np.mean(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "27f113fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[-0.02696915, -0.0216431 , -0.08146465, ...,  0.10544149,\n",
       "        -0.08084426, -0.13540457],\n",
       "       [-0.13843913, -0.05072544, -0.18872852, ...,  0.08259439,\n",
       "         0.19926817,  0.07674501],\n",
       "       [-0.13253289,  0.06865681,  0.18012397, ...,  0.12422462,\n",
       "        -0.17671402, -0.04926537],\n",
       "       ...,\n",
       "       [ 0.24485395,  0.0179893 ,  0.09294438, ...,  0.50140216,\n",
       "         0.0380602 , -0.22205437],\n",
       "       [ 0.14087105, -0.07705725,  0.2024218 , ...,  0.06511348,\n",
       "         0.0236356 , -0.00841525],\n",
       "       [-0.26490694, -0.06473813,  0.35884704, ..., -0.15652091,\n",
       "        -0.04595899,  0.22315687]])"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dea7f358",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
