{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "293692f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import csv\n",
    "\n",
    "import sys\n",
    "sys.path += ['utils/']  \n",
    "\n",
    "from EDRep import *\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b66c4124",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Normal(μ, σ2, t):\n",
    "    \n",
    "    return 1/np.sqrt(2*np.pi*σ2)*np.exp(-(t - μ)**2/(2*σ2))\n",
    "\n",
    "\n",
    "def RFM(X, D, indeces):\n",
    "\n",
    "    n, dim = X.shape\n",
    "\n",
    "    # create the random projection\n",
    "    W = np.random.normal(0, 1, (D, dim))\n",
    "    M = np.zeros((n, 2*D))\n",
    "\n",
    "    J = X@W.T\n",
    "    norms = np.sqrt(X**2@np.ones(dim))\n",
    "    Λ = diags(np.exp(norms**2/2))\n",
    "\n",
    "    # obtain the high dimensional vectors\n",
    "    M[:,:D] = Λ@np.sin(J)\n",
    "    M[:,D:] = Λ@np.cos(J)\n",
    "    M *= np.sqrt(1/D)\n",
    "\n",
    "    Z = M[indeces]@np.sum(M, axis = 0)\n",
    "\n",
    "    return Z\n",
    "\n",
    "\n",
    "def Performers(X, D, indeces):\n",
    "\n",
    "    n, dim = X.shape\n",
    "    W = np.random.normal(0, 1, size = (D, dim))\n",
    "    M = np.zeros((n, 2*D))\n",
    "\n",
    "    J = X@W.T\n",
    "    norms = np.sqrt(X**2@np.ones(dim))\n",
    "    Λ = diags(np.exp(-norms**2/2)/np.sqrt(2))\n",
    "\n",
    "    M[:,:D] = Λ@np.exp(J)\n",
    "    M[:,D:] = Λ@np.exp(-J)\n",
    "    M *= np.sqrt(1/D)\n",
    "\n",
    "    Z = M[indeces]@np.sum(M, axis = 0)\n",
    "\n",
    "    return Z\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fff6f927",
   "metadata": {},
   "outputs": [],
   "source": [
    "# file name\n",
    "f = 30\n",
    "\n",
    "# k-values\n",
    "kv = [1, 5, 15]\n",
    "\n",
    "# number of sampled indeces\n",
    "Nindeces = 1000\n",
    "\n",
    "# projection size for kernel methods\n",
    "D = 1000\n",
    "\n",
    "# read and pre-process the embedding\n",
    "X = pd.read_csv('Dataset/' + str(f) + '.txt', skiprows = 1, on_bad_lines='skip', sep = ' ', header = None, quoting=csv.QUOTE_NONE,\n",
    "                encoding='latin-1')\n",
    "X.set_index(0, inplace = True)\n",
    "X = X.dropna(axis = 1)\n",
    "X = X.values\n",
    "n, dim = np.shape(X)\n",
    "norms = np.sqrt(X**2@np.ones(dim))\n",
    "X = X/np.mean(norms)\n",
    "\n",
    "\n",
    "# select the random indeces\n",
    "indeces = np.random.choice(np.arange(n), Nindeces, replace = False)\n",
    "\n",
    "Z = computeZ(X, indeces)\n",
    "res = [computeZest(X, indeces, k = int(k)) for k in kv]\n",
    "ZPerformers = Performers(X, D, indeces)\n",
    "ZRFM = RFM(X, D, indeces)\n",
    "\n",
    "\n",
    "# compute the normalized version\n",
    "Y = normalize(X, norm = 'l2', axis = 1)\n",
    "Zn = computeZ(Y, indeces)\n",
    "resn = [computeZest(Y, indeces, k = int(k)) for k in kv]\n",
    "ZPerformersn = Performers(Y, D, indeces)\n",
    "ZRFMn = RFM(Y, D, indeces)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "520f59fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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hmnjxo164IEHdPfdd9t+GTdk2zLJ03XwySef6MYbb9Ty5cu1bt06DRs2TKNGjar2MNErr7zSth18+umnvijfKzxdB+ds3brVtoyxsbGu1wJ9O/jTn/5kW/Z9+/apffv21b4PvLodXPzxeP4jJSXFmjRpkmu+srLSSkhIsLKzs2vs//Of/9waOXKkrS01NdW65557LMuyLKfTacXHx1t//OMfXa8fP37cioiIsF5//XUfLEHjeboO3J09e9Zq3bq19eqrr7raxo8fb91yyy3eLtVnPF0Hf/3rX63o6Oha3y8Yt4Nnn33Wat26tXXixAlXm79tBxeSZL399tt19vnd735nXXnllba2MWPGWBkZGa75xq5Xk+qzDmrSu3dv69FHH3XNZ2VlWf369fNeYU2oPuvg448/tiRZx44dq7VPsG0Hb7/9tuVwOKzdu3e72ry9HQTMnpGKigqtW7dO6enprraQkBClp6crPz+/xjH5+fm2/pKUkZHh6r9r1y4VFBTY+kRHRys1NbXW9zSpIevA3cmTJ3XmzBm1b9/e1p6Xl6fY2Fj16NFD9913n7799luv1u4tDV0HJ06cUKdOnZSUlKRbbrlFX375peu1YNwOXnnlFd16661q1aqVrd1ftoOGuNj3gTfWq79xOp0qLS2t9n2wbds2JSQkqGvXrrr99tu1d+9eQxX6Tv/+/dWxY0fdeOONWrVqlas9GLeDV155Renp6erUqZOt3ZvbQcCEkaKiIlVWVrruBHtOXFxctWN95xQUFNTZ/9yfnrynSQ1ZB+4eeughJSQk2H7Qhg8frr/97W/Kzc3Vk08+qZUrV2rEiBGqrKz0av3e0JB10KNHD82bN0/vvPOO/vGPf8jpdGrw4MHav3+/pODbDtauXavNmzfr7rvvtrX703bQELV9H5SUlOjUqVNe+fnyN08//bROnDihn//856621NRUzZ8/XytWrNALL7ygXbt26brrrlNpaanBSr2nY8eOysnJ0ZIlS7RkyRIlJSVp6NChWr9+vSTvfM/6k4MHD+rdd9+t9n3g7e3A49vBI3DNnDlTCxcuVF5enu0EzltvvdX19759++qqq65St27dlJeXpxtuuMFEqV6VlpZme3Dj4MGD1atXL7344ot67LHHDFZmxiuvvKK+ffsqJSXF1h7o2wHsFixYoEcffVTvvPOO7XyJESNGuP5+1VVXKTU1VZ06ddLixYt11113mSjVq3r06KEePXq45gcPHqwdO3bo2Wef1d///neDlZnx6quvqm3btho9erSt3dvbQcDsGYmJiVFoaKgKCwtt7YWFhYqPj69xTHx8fJ39z/3pyXua1JB1cM7TTz+tmTNn6v3339dVV11VZ9+uXbsqJiZG27dvb3TN3taYdXBOWFiYrr76atfyBdN2UFZWpoULF9bry6Q5bwcNUdv3QZs2bRQVFeWVbctfLFy4UHfffbcWL15c7dCVu7Zt26p79+4Bsx3UJCUlxbV8wbQdWJalefPm6Y477lB4eHidfRu7HQRMGAkPD9fAgQOVm5vranM6ncrNzbX9r/dCaWlptv6S9MEHH7j6d+nSRfHx8bY+JSUlWrNmTa3vaVJD1oFUdaXIY489phUrVmjQoEEX/Zz9+/fr22+/VceOHb1Stzc1dB1cqLKyUps2bXItX7BsB1LVpe7l5eX6xS9+cdHPac7bQUNc7PvAG9uWP3j99dc1YcIEvf7667ZLu2tz4sQJ7dixI2C2g5ps3LjRtXzBsh1I0sqVK7V9+/Z6/eek0duB106FbQYWLlxoRUREWPPnz7e++uor61e/+pXVtm1bq6CgwLIsy7rjjjusqVOnuvqvWrXKatGihfX0009bW7ZssbKysqywsDBr06ZNrj4zZ8602rZta73zzjvWF198Yd1yyy1Wly5drFOnTjX58tWHp+tg5syZVnh4uPXmm29ahw4dck2lpaWWZVlWaWmp9dvf/tbKz8+3du3aZX344YfWgAEDrCuuuMI6ffq0kWW8GE/XwaOPPmq999571o4dO6x169ZZt956qxUZGWl9+eWXrj6Bvh2cc+2111pjxoyp1u6P20Fpaam1YcMGa8OGDZYka9asWdaGDRusPXv2WJZlWVOnTrXuuOMOV/+dO3daLVu2tB588EFry5Yt1pw5c6zQ0FBrxYoVrj4XW6/Njafr4LXXXrNatGhhzZkzx/Z9cPz4cVef3/zmN1ZeXp61a9cua9WqVVZ6eroVExNjHT58uMmXrz48XQfPPvustXTpUmvbtm3Wpk2brClTplghISHWhx9+6OoT6NvBOb/4xS+s1NTUGt/T29tBQIURy7Ksv/zlL9bll19uhYeHWykpKdZnn33mem3IkCHW+PHjbf0XL15sde/e3QoPD7euvPJKa9myZbbXnU6nNX36dCsuLs6KiIiwbrjhBmvr1q1NsSgN5sk66NSpkyWp2pSVlWVZlmWdPHnSuummm6xLL73UCgsLszp16mRNnDix2f7QnePJOnjggQdcfePi4qybb77ZWr9+ve39An07sCzL+vrrry1J1vvvv1/tvfxxOzh3iab7dG65x48fbw0ZMqTamP79+1vh4eFW165drb/+9a/V3reu9drceLoOhgwZUmd/y6q63Lljx45WeHi4lZiYaI0ZM8bavn170y6YBzxdB08++aTVrVs3KzIy0mrfvr01dOhQ66OPPqr2voG8HVhW1e0LoqKirJdeeqnG9/T2duCwLMtq2D4VAACAxguYc0YAAIB/IowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAw6v8DFan8n6h9t60AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "α = np.random.randint(n)\n",
    "plt.hist(X[α]@X.T, bins = 30, edgecolor = 'white', color = 'chartreuse', \n",
    "                density = True, label = 'Empirical', cumulative = True)\n",
    "\n",
    "m = np.mean(X[α]@X.T) \n",
    "s = np.sqrt(np.var(X[α]@X.T))\n",
    "\n",
    "t = np.linspace(1.03*np.min(X[α]@X.T), np.max(X[α]@X.T))\n",
    "k = 1\n",
    "π, μ, σ2 = res[k].π, res[k].μ, res[k].Ω\n",
    "\n",
    "y = np.sum(np.diag(π/n)@np.array([Normal(X[α]@μ[b].T, X[α]@σ2[b]@X[α], t) for b in range(len(μ))]), axis = 0)\n",
    "plt.plot(t, np.cumsum(y)*(max(t)-min(t))/len(t), color = 'k', linewidth = 3, linestyle = '-.', label = 'mvGaussian')\n",
    "plt.show();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5a1fe8d7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "eps = []\n",
    "\n",
    "for i in range(len(res)):\n",
    "    eps.append(np.log10(np.abs(Z - res[i].Zest)/Z))\n",
    "\n",
    "eps.append(np.log10(np.abs(Z - ZPerformers)/Z))\n",
    "eps.append(np.log10(np.abs(Z - ZRFM)/Z))\n",
    "    \n",
    "    \n",
    "tv = np.linspace(np.min(np.concatenate(eps)), np.max(np.concatenate(eps)))\n",
    "\n",
    "for i in range(len(eps)):\n",
    "    plt.plot(tv, [np.mean(eps[i] < t) for t in tv])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "232ca258",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "EDRep",
   "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
}
