{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.sparse import csr_matrix\n",
    "import scipy.io as sio\n",
    "import scipy as sc\n",
    "from scipy.linalg import lu\n",
    "import cv2\n",
    "from mpl_toolkits.axes_grid1 import make_axes_locatable\n",
    "import time\n",
    "from sklearn.utils.extmath import randomized_svd"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Constructs a $n \\times n$ diagonal matrix of decaying singular values\n",
    "\n",
    "### The user can choose any decay rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 500  # matrix dimension\n",
    "\n",
    "f = 450  # matrix rank\n",
    "\n",
    "x = np.array([0]*n)\n",
    "x[:f] = np.array(list(range(1,f+1))[::-1])\n",
    "\n",
    "A = np.diag(x)  \n",
    "\n",
    "B = (A).astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sketchySVD(A, r):\n",
    "\n",
    "    ## Step 1\n",
    "\n",
    "    [m, n] = np.shape(A)\n",
    "    k = 4*r + 1\n",
    "    s = 2*k + 1\n",
    "\n",
    "    X = np.zeros((k, n))\n",
    "    Y = np.zeros((m, k))\n",
    "    Z = np.zeros((s, s))\n",
    "\n",
    "    Gamma = np.random.normal(0, 1, (k, m))\n",
    "    Omega = np.random.normal(0, 1, (k, n))\n",
    "    Phi = np.random.normal(0, 1, (s, m))\n",
    "    Psi = np.random.normal(0, 1, (s, n))\n",
    "\n",
    "    ## Step 2\n",
    "    \"\"\"\n",
    "    # uncomment part here to stream, but lets just go with full matrix for correctness check\n",
    "    for i in range(n):\n",
    "        H = csr_matrix((m, n), dtype=np.float).toarray()\n",
    "        H[:, i] = A[:, i]\n",
    "        X = X + Gamma @ H\n",
    "        Y = Y + H @ Omega.T\n",
    "        Z = Z + Phi @ H @ Psi.T\n",
    "    \"\"\"\n",
    "    X = np.matmul(Gamma, A)\n",
    "    Y = np.matmul(A, Omega.T)\n",
    "    Z = np.matmul(Phi, np.matmul(A, Psi.T))\n",
    "\n",
    "    ## Step 3\n",
    "\n",
    "    [Q, unused] = np.linalg.qr(Y)\n",
    "    [P, unused] = np.linalg.qr(X.T)\n",
    "    C = np.linalg.pinv(Phi @ Q) @ Z @ np.linalg.pinv(Psi @ P).T\n",
    "\n",
    "    ## Step 4\n",
    "\n",
    "    [U, Sigma, Vh] = np.linalg.svd(C)\n",
    "    U = Q @ U\n",
    "    V = P @ Vh.T\n",
    "    \n",
    "    U = U[:, :r]\n",
    "    Sigma = Sigma[:r]\n",
    "    V = V[:, :r]\n",
    "    \n",
    "    return (U,Sigma,V.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def BlockLanczos(A, r, q):\n",
    "    \n",
    "    [m, n] = np.shape(A)\n",
    "    s = 2*r\n",
    "    \n",
    "    Omega = np.random.normal(0, 1, (n, s))\n",
    "    \n",
    "    X = np.matmul(A, Omega)\n",
    "    Krylov = np.zeros((m, s*q))\n",
    "    Krylov[:, :s] = X\n",
    "    \n",
    "    for i in range(1,q):\n",
    "        X = np.matmul(A.T, X)\n",
    "        X = np.matmul(A, X)\n",
    "        [X, unused] = np.linalg.qr(X)\n",
    "        Krylov[:, (i-1)*s:i*s] = X\n",
    "    \n",
    "    [Q, unused] = np.linalg.qr(Krylov)\n",
    "    [Ub, Sigma, Vh] = np.linalg.svd(np.matmul(Q.T, A))\n",
    "    Ub = Ub[:, :r]\n",
    "    Sigma = Sigma[:r]\n",
    "    Vh = Vh[:r, :]\n",
    "    \n",
    "    U = np.matmul(Q, Ub)\n",
    "    \n",
    "    return (U, Sigma, Vh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def frPCA(A, k, q=3):\n",
    "    [m, n] = A.shape\n",
    "    s = 5\n",
    "    if m < n:\n",
    "        if q % 2 == 0:\n",
    "            Q = np.random.normal(0, 1, (n, k+s))\n",
    "            Q = np.matmul(A,Q)\n",
    "            if q == 2:\n",
    "                [Q, _, _] = np.linalg.svd(Q)\n",
    "            else:\n",
    "                [P, L, _] = lu(Q)\n",
    "                Q = np.matmul(P,L)\n",
    "        else:\n",
    "            Q = np.random.normal(0, 1, (m, k+s))\n",
    "\n",
    "        upper = int((q-1)/2)\n",
    "        for i in range(0,upper):\n",
    "            if i == upper-1:\n",
    "                [Q, _, _] = np.linalg.svd(np.matmul(A,np.matmul(A.T,Q)))\n",
    "            else:\n",
    "                [P, L, _] = lu(np.matmul(A,np.matmul(A.T,Q)))\n",
    "                Q = np.matmul(P,L)\n",
    "\n",
    "        [V,S,U] = np.linalg.svd(np.matmul(A.T,Q))\n",
    "        ind = list(range(s,k+s-1))\n",
    "        U = np.matmul(Q, U[:, :ind])\n",
    "        V = V[:, :ind]\n",
    "        S = S[ind]\n",
    "        pass\n",
    "    else:\n",
    "        if q % 2 == 0:\n",
    "            Q = np.random.normal(0, 1, (m, k+s))\n",
    "            Q = np.matmul(A.T,Q)\n",
    "            if q == 2:\n",
    "                [Q, _, _] = np.linalg.svd(Q)\n",
    "            else:\n",
    "                [P, L, _] = lu(Q)\n",
    "                Q = np.matmul(P,L)\n",
    "        else:\n",
    "            Q = np.random.normal(0, 1, (n, k+s))\n",
    "\n",
    "        upper = int((q-1)/2);\n",
    "        for i in range(0,upper):\n",
    "            if i == upper-1:\n",
    "                [Q, _, _] = np.linalg.svd(np.matmul(A.T,np.matmul(A,Q)))\n",
    "            else:\n",
    "                [P, L, _] = lu(np.matmul(A.T,np.matmul(A,Q)))\n",
    "                Q = np.matmul(P,L)\n",
    "        [U,S,V] = np.linalg.svd(np.matmul(A,Q))\n",
    "        ind = list(range(s,k+s))\n",
    "        U = U[:, ind]\n",
    "        V = np.matmul(Q, V[:, ind])\n",
    "        S = S[ind]\n",
    "    \n",
    "    return U, S , V.T"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Error Metric\n",
    "\n",
    "### Note that the conventional SVD is used to baseline any rank-$r$ approximation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def frob(A, Ak, Ares):\n",
    "    res_frob = np.abs(np.linalg.norm(A-Ak,'fro') - np.linalg.norm(A-Ares,'fro'))\n",
    "    return res_frob\n",
    "\n",
    "def spec(A, Ak, Ares):\n",
    "    res_spec = np.abs(np.linalg.norm(A-Ak,2) - np.linalg.norm(A-Ares,2))\n",
    "    return res_spec\n",
    "\n",
    "def chi(Vh,Vres):\n",
    "    corr = np.abs(np.matmul(Vh, Vres))\n",
    "    res_chi = np.abs(1. - np.sum(corr)/(1. * r))\n",
    "    return res_chi"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Conventional SVD and its rank-$r$ truncation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "[uu, ss, vv] = np.linalg.svd(B)\n",
    "total_energy = np.linalg.norm(B, 'fro')\n",
    "\n",
    "r = 20 # SET YOUR RANK HERE\n",
    "\n",
    "B_r = np.matmul(np.matmul(uu[:,:r], np.diag(ss[:r])), vv[:r,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Runs of different Randomized SVD solvers\n",
    "\n",
    "### Please note that as shown in the Theorem 2 in the main text, any randomized projection matrix $H \\neq V_rV_r^T$ where $V_r$ is the top rank-$r$ right singular matrix will always introduce errors in tail energy. \n",
    "\n",
    "### In the following, we show how large these errors are."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run: 1\n",
      "Run: 2\n",
      "Run: 3\n",
      "Run: 4\n",
      "Run: 5\n",
      "Run: 6\n",
      "Run: 7\n",
      "Run: 8\n",
      "Run: 9\n",
      "Run: 10\n"
     ]
    }
   ],
   "source": [
    "res = []\n",
    "res1 = []\n",
    "res2 = []\n",
    "res3 = []\n",
    "res4 = []\n",
    "\n",
    "num_runs = 10  # figures shown in the main text are for 1000 independent eveluations (runs)\n",
    "\n",
    "for run in range(num_runs):\n",
    "\n",
    "    print(f'Run: {run+1}')\n",
    "    \n",
    "    \"\"\"\n",
    "    SketchySVD: Joel A Tropp, Alp Yurtsever, Madeleine Udell, and Volkan Cevher.  \n",
    "    Streaming low-rank matrixapproximation with an application to scientific simulation.\n",
    "    SIAM Journal on Scientific Computing,41(4):A2430–A2463, 2019\n",
    "    \"\"\"\n",
    "    [U,S,V] = sketchySVD(B,r)\n",
    "    \n",
    "    \n",
    "    \"\"\"\n",
    "    BlockLanczos: Cameron Musco and Christopher Musco. \n",
    "    Stronger approximate singular value decomposition via theblock lanczos and power methods.\n",
    "    arXiv preprint arXiv:1504.05477, 16:27, 2015. Published in NIPS 2015.\n",
    "    \"\"\"\n",
    "    [U1, S1, V1] = BlockLanczos(B,r,5)\n",
    "    \n",
    "    \n",
    "    \"\"\"\n",
    "    RandSVD: Nathan Halko,  Per-Gunnar Martinsson,  and Joel A Tropp.   \n",
    "    Finding structure with randomness: Probabilistic algorithms for constructing approximate matrix decompositions.\n",
    "    SIAM review, 53(2):217–288, 2011.\n",
    "    \"\"\"\n",
    "    [U2, S2, V2] = randomized_svd(B, r, power_iteration_normalizer='none', n_iter=0)\n",
    "    \n",
    "    [U3, S3, V3] = randomized_svd(B, r, power_iteration_normalizer='auto', n_iter=5)\n",
    "    \n",
    "    \n",
    "    \"\"\"\n",
    "    frPCA: Feng, Xu, et al. \n",
    "    Fast randomized PCA for sparse data. \n",
    "    Asian conference on machine learning. PMLR, 2018.\n",
    "    \"\"\"\n",
    "    [U4, S4, V4] = frPCA(B, r)\n",
    "\n",
    "    B_res = np.matmul(np.matmul(U, np.diag(S)), V)\n",
    "    B1_res = np.matmul(np.matmul(U1, np.diag(S1)), V1)\n",
    "    B2_res = np.matmul(np.matmul(U2, np.diag(S2)), V2)\n",
    "    B3_res = np.matmul(np.matmul(U3, np.diag(S3)), V3)\n",
    "    B4_res = np.matmul(np.matmul(U4, np.diag(S4)), V4)\n",
    "    \n",
    "    err_fr = frob(B, B_r, B_res)\n",
    "    res.append(err_fr)\n",
    "    \n",
    "    err_fr1 = frob(B, B_r, B1_res)\n",
    "    res1.append(err_fr1)\n",
    "    \n",
    "    err_fr2 = frob(B, B_r, B2_res)\n",
    "    res2.append(err_fr2)\n",
    "    \n",
    "    err_fr3 = frob(B, B_r, B3_res)\n",
    "    res3.append(err_fr3)\n",
    "    \n",
    "    err_fr4 = frob(B, B_r, B4_res)\n",
    "    res4.append(err_fr4)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Absolute Tail Energy Errors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7X//+x/z5s1z1ZObTp06cdFFF/HRRx/lua8xxpzr/BkA6jPgBuDLwgklSD3wAGzYULTHvPhiGDfO591Lly7NtGnTGDx4MBMnTqRZs2Zcfvnl9O7dm1atWrntO3LkSCZMmMBXX31Fs2bNAHjzzTdp2rQpL774omu/d955hwoVKrB27VpatmxJREQEZcqUoWrVqq59pk+fzt69e1m5ciWVKlUCoF69em7HS0tLY9q0aWR2gx0yZAhTp051lQ8aNIjJkyfz8MOOyVUXLVrEvn37+Mc//gHAqFGj+PHHH6lXrx4JCQm0atWKTp06ccsttxAaGgo4LvznnXceU6ZM4fnnn3fFX7ZsWXr27OnTOWzUqBEbN270aV9jjDmX+dM4chHQQ0Q+FJEBItJFRK7LuhRWkCZvPXv25K+//mLu3Ll07tyZ7777jksvvdR1IQUYP348r732Gt9++60raQBYt24d33zzjevORXR0NLVq1QJg27ZtXo+5fv16mjRp4koaPKlduzZZx86oXr06+/btc63fcccd/PHHH3z33XeAo03DDTfcQMWKFQGoVq0aK1euZNOmTTzwwAOoKnfeeSctW7Z0tXMICQmhX79+TJ8+3dVOYerUqfTt25fw8HCfzp+qWp97Y4zxgT93HN51/uzhXLJTSuKjDD/+8i9u4eHhdOzYkY4dOzJy5EgGDRrE6NGjXV0wr7jiChYuXMisWbPcHilkZGTQpUsXxowZk6POuLg4r8dTH3oiZN4VyCQiZGRkuNYrV65Mt27dmDJlCg0aNOCzzz5j7ty5Oepp3LgxjRs35u677+bbb7/lyiuv5IMPPqBfv34ADBgwgGeffZZFixYRGxvLli1bmDlzZp7xZdq8eTN169b1eX9jjDlX+ZM41Cm0KIrAuTitdqNGjUhLS3O1e2jRogUPPvggHTt2RER48sknAWjevDkffPABtWvXznGhzxQWFpaj10Hz5s159913OXDgQK53HfIyePBgevXqRd26dYmLi6NDhw55fi6A48ePu7bVrl2bDh06MHnyZGJjY2nRogUXX3yxT8dftGgRP/30U5GOcWGMMWcrfx5VKPCXqu7MvgB7yGPmzOKmPg45fTY6ePAgV199Ne+++y4bN25k+/btzJkzh5deeon27du7TbBzySWXsHjxYsaOHcuzzz4LwN13383Ro0fp06cP33//PX/88QdffPEFQ4YM4dixY4BjAKmffvqJX3/9lQMHDpCamsqtt95KlSpVuOGGG1i+fDnbt2/ns88+4+uvv/Yr/o4dO1KxYkWeeuop+vfvT0jImX+Wd911F8888wwrVqxg586drFq1ittvv53IyEg6derkVs/AgQOZO3cus2fP9tooMjk5mb1797J7927WrFnDU089RY8ePejevburXYUxxhjv/EkctgPNvJQ1dZabYhAdHc2ll17K+PHjadu2LRdeeCEjRozg1ltvZfbs2Tn2b9myJYsXL2bMmDE8++yzVK9enRUrVhASEsK1117LhRdeyN13302ZMmUoU6YM4Lgr0LBhQxITE6lcuTIrVqwgKiqKZcuWUaNGDbp27cqFF17IqFGj/G4rICL079+f1NRU+vfv71bWsWNHvv/+e2666Sbq16/PjTfeCMCSJUuoX7++27433HADMTExZGRkcOutt3o81tSpU6lWrRp169ala9eurFy5krfeeotPPvmEUqVK3pM2Y4wJNPHlOTWAiGQAl6rqag9llwNLVDXo56NOTEzUtWvXeizbsmULDRs2LOKIDDjuLPz+++8BG+nSmGBh3ysmGIjIOlVNDERdubZxEJEmwMVZNl0nIhdk2y0cuAnYGoiAzLnl6NGjrFu3jnfeeYcPPviguMMxxhiTh7waR94IjHK+VmCkl/22A3cGKihz7ujevTurV69m4MCBdOnSpbjDMcYYk4e8EofngTGAAH/jmNBqTbZ9TqtqaiHEZs4BS5cuLe4QjDHG+CHXxMGZEGQmBf40pAw652J3TGOMMSbQfE4GRORKEemeZb2SiMwUkQ0iMlZEPA8AECRKcndMY4wxpqj4cxfhZaBxlvXxQHtgFdAPeCpwYRljjDEmGPmTONQH1gGISCSOhpP3q+pQ4GGgT+DDM8YYY0ww8SdxCAMy52y+HEf7iM+d61uBagGMyxhjjDFByJ/E4RfgWufrvsBKVT3mXK8OHApkYMYYY4wJPv5McvU0MEdEBgIxQPcsZdcC6wMZmDHGGGOCj893HFT1M6AhMBRorKoLshSvBJ4LcGzGmCIkInz44YdFcqzRo0czYMAA13q/fv24/vrri+TYgbBp0yZq1KjBiRMnijsUY4qcX2MzqOofqvqRqm7Ntn2iqq4KbGjGV2fbl24giIhrKVu2LImJiXz88cfFHVaeduzYgYiQOV9K9vWi4O3fS1JSEl27di304+/bt49XXnmFJ554wrVt/PjxvPvuu671du3acc899xR6LN7Ex8e7/RsTER599FFX+UUXXcSll17KK6+8UmwxGlNc/EocRCRcRDqJyAARGZZtuauwgjTGk7fffpukpCTWrFlD06ZN6d27NytXrizusABIS0vD1wnkAuX06dMFen/VqlVds6EWpkmTJtGyZUvq1q3r2hYTE0NsbGzAj1WQczJy5EiSkpJcS9ZEB6B///68+eabpKWlFTRMY84q/gwAdQXwJ7AQmAT8x8NigtArr7xCkyZNiIqKokaNGgwaNIgjR464yqdNm0Z0dDRffvkljRs3Jioqiquuuort291nSv/8889p1aoVERERVKxYka5du3Ly5EmmTZuW468zEaFfv36u906YMIGEhATCwsJISEjg7bffdqt7woQJ1K9fn/DwcCpXrsw111yT5xdybGwsVatW5YILLuCtt94iPDyczz77DHDcSu7QoQMRERFUqFCBfv36cfToUcAxW6GIsHfvXgCSk5MJCwujc+fOrrrffvttzj//fNf6nj17uPnmmylfvjzly5enS5cu/Pbbb67y0aNH07hxY6ZNm0a9evUoU6aMT7ex69SpA8All1yCiNCuXTtX2dSpU2nUqBHh4eHUr1+fV199lYyMDFe5iPD666/To0cPoqKiGDFiBOnp6QwcOJA6deoQERHB+eefz0svveR63+jRo5k+fTqff/656/eUOex39kcVuZ1DOHPnYvz48dSoUYPy5cvTv39/kpOTc/3MM2fOpFu3bm7bst4F6devH8uWLeP11193xbhjxw4ANm/eTJcuXShbtixVqlThlltucf0es9bz4osvUrNmTWrWrJnn78CbsmXLUrVqVdcSHR3tVt6pUycOHTpkw6abc44/jSNfA7YBHYHNZ9v8FPkdcvqBBx5gw4YNhRKTNxdffDHjxo0LWH0hISGMGzeOunXrsnPnTu69917uvfdeZsyY4drn1KlTvPDCC0yZMoXw8HDuuOMOhg4dyqJFiwBYuHAh3bt359FHH2Xq1KmkpaWxePFiMjIy6NOnD9dee62rro0bN9K1a1fatm0LwCeffMI999zDq6++SqdOnVi0aBHDhg2jatWqdO3albVr13L33Xczffp0rrjiCo4cOcJXX33l12cMDQ2ldOnSpKamkpyczLXXXssll1zC6tWrOXToEIMHD2bAgAF89NFHNGzYkLi4OJYuXcrNN9/MihUriImJ4dtvvyUtLY3SpUuzdOlS10U8OTmZq666itatW7Ns2TLCwsIYM2YMHTp0YMuWLURGOmaT3759OzNnzmTOnDmEhYURHh6eZ9yrV6+mZcuWLFy4kKZNmxIWFgY4EpeRI0fyf//3f7Ro0YKffvqJwYMHExoa6nYL/6mnnuL5559nzJgxiAgZGRnUqFGDDz74gMqVK7N69WqGDBlCxYoVGThwIMOHD2fLli0cOnTI9fuvUKFCjrjyOoeZli9fTrVq1fjiiy/YtWsXN910E/Xr1+exxx7z+HkPHTrE5s2bSUz0Prvv+PHj2bp1KxdccAHPP/88AJUrVyYpKYk2bdowcOBAxowZQ2pqKo8//jjdunVj1apVhIQ4/g5atmwZMTExLFy40HXXZ+jQoW6PQjzZvHkz5513nmt9zJgxvPDCC9SqVYvevXvz0EMPuX4/AGFhYVx88cUsW7aMDh065Fq3MSWJP4lDA6CHqv5YWMEUJlWdC8xNTEwcXNyxFLUHHnjA9To+Pp6XXnqJ7t27M336dNeXbVpaGq+//joNGjQAYPjw4fTv35+MjAxCQkJ45pln6NWrF88++6yrriZNmrheR0REALB//36GDBnCXXfdRf/+/QHHF/Btt93muuDVr1+fdevW8eKLL9K1a1f+/PNPoqKi6NatG2XLlqV27do0bdrU58936tQpXn75Zf7++2/at2/Pe++9x/Hjx5kxYwZly5YFYOLEiVx11VX8/vvvJCQk0LZtW77++mtuvvlmli5dSq9evViwYAFr1qzhsssuY9myZbz44osAvP/++6gqU6dORUQAxx2SKlWqMG/ePG666SbAcVt8xowZxMXF+Rx75cqVAahYsSJVq1Z1bX/mmWd46aWX6NWrF+C4M/Hoo4/yxhtvuCUOffr0YdCgQW51Pv30067X8fHx/PDDD8yaNYuBAwcSHR1NREQEZcqUcTtedr6cQ4By5crx5ptvUrp0aRo2bEjv3r358ssvvSYOf/75J6pKtWreh32JiYkhLCyMyMhItxjffPNNmjZt6vq9ALzzzjtUqFCBtWvX0rJlSwDCw8OZMmWK22OXp59+muHDh3s9JkD16tVdr++77z6aNWtGxYoVWb16NY8++ijbt29n0qRJOd6TeTfEmHOFP4nDRsD7N00JFci//IvLV199xQsvvMCWLVs4evQo6enpnD59mr1797q+LMuUKeNKGsDxhZiamsqRI0eoUKEC69evd3v04Mnp06e58cYbadiwIWPHjnVt37Jli1sLeoArrrjC9VihY8eO1K5dmzp16nDNNdfQqVMnevTo4bpgeXPbbbfRr18/UlJSiImJYcyYMXTu3JkHH3yQJk2auL2/devWhISEsHnzZhISEmjXrp3rd7t06VLuv/9+kpOTWbp0KZUqVWLPnj2uOw7r1q1j+/btOeJJTk5m27ZtrvWaNWv6lTR4s3//fnbt2sWdd97JXXedaTrkqd2Ep7/c33rrLSZNmsTOnTtJSUkhNTWV2rVr+xXDli1b8jyHAI0aNaJ06TNfI9WrV+f777/3Wm9KSgqAT3djslu3bh3ffPNNjkcGANu2bXMlDo0bN87RVqNKlSpUqVLF52M9+OCDrtdNmjShXLly9OnThxdffJGKFSu6yiIiIlyfyZhzhT+Jw13ANBHZoarLCisgE1g7d+6kS5cuDB48mKeffpqKFSvyww8/cMstt7g1HMv65Q+4/rLO+kw9L0OHDuXw4cPMnz+fUqVKeazP07ayZcvyww8/8M0337BkyRJeeOEFRowYwZo1a9z+Cszu5Zdf5tprr6VcuXJuFwVV9Xi8rMds164dw4YN47fffmPt2rW0a9eOEydOMGvWLCpVqkRCQgI1atRwnYOLL76Y999/P0d9WW/zR0VFeY3VH5nn/K233qJ169a57pv9mLNnz+aBBx5gzJgxtG7dmnLlyvH666/zySef+BWDL+cQHI+Ispfl9m+mUqVKABw+fDjXuw6eZGRk0KVLF8aMGZOjLGvC5un3kJ9HFVm1atUKgN9//90tcTh06BDx8fG+hG9MieFP4rAEiAS+EpFU4O/sO6iq7ym9KRJr167l9OnTvPrqq66L+bx58/yup1mzZnz55ZcMHuz5Sc+YMWOYO3cuq1evply5cm5lDRs25Ntvv3W76/Dtt9/SqFEj13rp0qW5+uqrufrqq3nqqadcjwGGDBniNaaqVaviqc1Ko0aNmDJlCseOHXP9xfzdd9+RkZFBw4YNXTHFxcXx3HPPkZCQQJUqVbjqqqu45557iI2NdWuk2Lx5c1dCEeiW/5nPzNPT013b4uLiqFGjBtu2beP222/3q75vv/2WVq1auT3OyHpXJPOYWY/niS/nMD/q1atHuXLl2Lx5s9vvPztPMTZv3pwPPviA2rVr50hY8uLvo4rsMts5ZU92fvrpJ3r06OFXLMac7fxJHF4HirZ/mfHZ33//naMRZ2xsLOeffz4ZGRmMGzeOHj16sGrVqnw9fnn88cfp2rUrCQkJ3Hrrragqixcv5s477+S7775jxIgRvPfee0RERLhauUdERBATE8NDDz1E7969adGiBZ06dWLhwoW89957rnEX5s2bx7Zt22jTpg0VKlTg66+/5tixY/m+QPXt25dRo0Zx++238/TTT3P48GHuvPNOevTo4ZZotG3blnfffZehQ4cCjvYAlStX5uOPP2b69Olu9Y0ZM4bu3bvz9NNPc95557Fr1y4+/fRThg4d6tb7wl9VqlQhIiKCRYsWER8fT3h4ODExMYwePZp7772X2NhYrrvuOlJTU/nhhx/Ys2eP1/YD4Gg/Mm3aNBYsWEBCQgLvv/8+y5Yto3z58q594uPjWbBgAb/++isVK1YkJiYmx4XY13Por5CQEDp06MC3337rar/hSXx8PKtXr2bHjh1ER0dToUIF7r77bt5++2369OnDI488QuXKlfnjjz/44IMPGDt2bK6Ptvx5VLFy5UpWrVrFVVddRUxMDGvWrOGf//wn3bp1c7sjsWPHDvbs2UOnTp18PwHGlASqek4tLVq0UG82b97stSyY3XHHHYojqXNbevbsqaqq48eP1+rVq2t4eLheffXVOnv2bAV0+/btqqo6depUjYqKcqvz66+/VkD379/v2vbpp59q8+bNNSwsTCtWrKhdu3bVlJQUHTVqlMfj33HHHa73vvnmm1qvXj0tXbq01qtXTydOnOgqW758ubZr104rVKig4eHheuGFF+qUKVNy/cyAzpkzx2v5xo0b9eqrr9bw8HCNjY3VO+64Q48cOeK2z5tvvpmjnsxzuXv3brd99+7dq/369dPKlStrWFiYxsfHa//+/V3nZ9SoUXrhhRfmGrOq6vbt2xXQNWvWuLa9/fbbWqtWLQ0JCdG2bdu6ts+cOVObNWumZcqU0djYWL388st11qxZuZ6DU6dO6YABAzQ2NlZjYmJ0wIAB+tRTT2nt2rVd++zbt087duyo0dHRCujXX3/tsb68zuEdd9yhXbp0cTu+L+dh4cKFWrVqVU1LS/Na16+//qqXXnqpRkREuP1b3bp1q/bs2VNjY2M1PDxc69evr/fcc4+eOnXKa0z+WrdunbZq1UpjYmI0PDxcGzRooKNGjdITJ0647ff888/rNddck2d9Z+v3iilZgLUaoOuoqJ+D1IhIGHARUAHHxFabVLVgI88UocTERPU2St+WLVsKdBvWGOObyy67jGHDhnHbbbcVdyj5curUKc4//3xmzZrF5Zdfnuu+9r1igoGIrFNV7/2g/eDvyJEPA/8DVgOLgDXA/0TkoUAEY4w5N0yYMMGvhrfBZufOnTz++ON5Jg3GlEQ+t3EQkQeAF4C3gNk4Eog4oA/wgoicUtXXCiNIY0zJ0qRJE7dxQM429evXp379+sUdhjHFwp/GkXcD/1bVx7Ns+xX4RkSOAPfhGF0yqP2anEy79Z5nAB8VEkJIHsPlGmOMP/aePs1dXr5zjPHm4uhoxhWg4XVh8udRRS3gay9lS4H8DwpvjDHGmLOCP3cc/gQ6AV94KOvoLC9yIvIm0A2orqqeR6zJokFkJEubNfNYtmXLFho45x0wxphAyAgLY6k1jjQliL+TXL0mIhWAD3G0cagC9Ab64XhUURxmAaOBvXnsZ4wxxpgC8vlRhar+B7gTuBaYD6wFFjjXh6rqG77WJSIJIjJBRH4UkXQRWeplv0Yi8qWIJIvIXyLytIi4jWWsqt+o6v98PbYxxhhj8s+fOw6o6tsiMglHe4ZqQBKwW/0dDAIuBK4DVgFhnnYQkfI4HotsBroD9YCxOJKdJ/w8njHGGGMCwK/EAcCZJOxyLvk1V1U/BRCRD4FKHvYZCkTgmMr7b2CJiJQDRovIS85txhhjjClCPj+qEJEpIjLbS9ks550In6iqLyO/dAYWZUsQ3seRTLT19VjGIT4+3uOsgpn69evH9ddfX4QRnV3uuecet4mvgslvv/1GXFwcR48eBRzThIsIBw4cKObIfNeyZUvX3CXGmODmT3fMjjgaRXryEY4eF4F0AfBL1g2q+ieQ7CwzTvv372fYsGHEx8dTpkwZ4uLiaN++PUuWLCnu0AJm9OjRiAgiQkhICNWrV6dv377s2lWQG1/5l9c5b9KkCYMGDfL43vnz5yMibN26lR07drg+l4gQHR1NgwYNGDRoEBs3bvQplhEjRjBs2DBiYmIAaN26NUlJSa7pn6dNm0Z0dHQAPnX+vfHGG9SpU4fw8HBatGjB8uXL3cqffPJJHnnkkbN6NEljzhX+JA6VccxN4clhHD0sAqk8cMTLsVxT/YnIJBHZ7Xy929OdDxEZIiJrRWTt/v37Axxm8evZsyerV69m8uTJbN26lXnz5tG5c2cOHjxY3KG5SUtLw//mMGc0aNCApKQkdu/ezezZs9m0aRM33XRTACP0XV7nfODAgcyePZsTJ07keO+UKVO48sor3UYeXLhwIUlJSWzatIlXX32Vffv20aJFC95///1c49i1axf//e9/6d+/v2tbWFgYVatWRSTP3sl+S01N9fs9s2fP5v7772fEiBGsX7+e1q1b07lzZ/7880wP7uuuu45jx46xYMGCQIZrjCkMvs6GhWOUyKe8lD0F/J6fWbZw3MVY6mF7KnC/h+17gOfyO6tXSZsd8/DhwwrokiVLct2vdu3a+vLLL7vWZ8yYoWXLltVPP/1UVXPOKpiRkaEvvvii1q1bV8PDw7Vx48Y6Y8YMtzofeeQRrV+/voaHh2vt2rX1oYce0pSUFFd55kyJU6dO1bp162pISIgeO3ZMAZ0wYYL26tVLIyMjtU6dOjnqzs7TrIuvvfaaAnr06FG/Y5o1a5bWrVtXo6OjtXv37m6zgKalpem//vUvjY2N1djYWL3//vt16NChrpkrfTnnBw8e1DJlyuSY5XPfvn0aGhqq06dPV1XPs2VmuuWWWzQmJkYPHz7s9Tgvv/yyNmvWzG1b1plNM19nXUaNGqWqjpk0H374Ya1Ro4ZGRkZqYmKiLly4MEc9n3/+uV5yySUaGhqqc+fO9RqLNy1bttRBgwa5bUtISNBHH33UbVv//v21b9++ftcf7M7G7xVT8hDA2TH9ueMwDXhERO4WkWgAEYkWkWHAw4DPbRx8dBiI9bA9Bs93IgpNu3Y5lzecnU+Tkz2XT5vmKD9wwHP5bGdrkV27cpb5Izo6mujoaD777DNOnjzp03tee+017r33XubNm0e3bt087vPEE08wefJkXn/9dTZv3sxjjz3GnXfeyeeff+7aJyoqiilTprBlyxbeeOMN3n//fZ577jm3erZv387MmTOZM2cOP/74I+Hh4QA8/fTTdO/enR9//JE+ffowYMAAdu7c6fPn3rt3Lx9//DGlSpWiVKkzPXR9iWnHjh3Mnj2bTz75hMWLF7N+/Xoef/zMSOpjx47l7bffZsKECaxcuZL09HTee+89V7kv57xChQrccMMNTJkyxW37jBkziIiIoFevXnl+xuHDh3P06FG++MLTmGsOy5cvJzHR+4R3rVu3Zty4cURGRpKUlERSUhLDhw8HoH///ixbtoyZM2eyadMm7rjjDrp27cqPP/7oVscjjzzCs88+yy+//EKrVq1Yvny56xx4W55//nkATp8+zbp16+jUyf1JZqdOnfjuu+/ctrVs2ZJly5bleV6MMcXLn14VL+LoEvl/OAaCOgFEAQJMdJYH0i9ka8sgIrWcx/zF4ztyISJdga4JCQmBiS5IlC5dmmnTpjF48GAmTpxIs2bNuPzyy+nduzetWrXKsf/IkSOZMGECX331Fc28jKB54sQJXnnlFRYvXsyVV14JQJ06dVi9ejWvv/46Xbp0ARzPpTPFx8czYsQIxowZwzPPPOPafvr0aWbMmEFcXJzbMW677Tb+8Y9/APDMM88wfvx4li9fTu3atb1+1i1bthAdHU1GRgYpKSkA3HfffURFRbn28SWmtLQ0pk2b5moTMGTIEKZOneoqHzduHA8//LDrMcj48eNZtGiRq9zXcz5o0CA6duzI1q1bXY8lpkyZwq233kqkDyOUNmrUCIA//vjD6z47d+7k4osv9loeFhZGTEwMIkLVqlVd27dt28asWbPYsWMH5513HuBoAPrFF18wYcIE3njjzLAso0ePdrvwR0dHs2HDhlxjr1ChAgAHDhwgPT09x+8/Li4uR0JUvXp19uzZQ1paGqVL+93hyxhTRHz+36mOnhCDRGQMcBVQATgIfKWqWwshtgXAQyJSVlWPObf1AVIAv/8sUdW5wNzExMTB/r536VLvZZGRuZdXqpR7ea1auZf7omfPnnTp0oXly5ezcuVKFi5cyNixY3nuuecYMWKEa7/x48dz7Ngx1qxZw/m5TJ6yefNmTp48ybXXXuv2nDw1NZX4+HjX+ocffsi4ceP4/fffOX78OOnp6aSnp7vVVbNmzRwXDcBtZsTSpUtTuXJl9u3bl+vnrFevHvPnz+fUqVN8+umnfPTRR66/bP2JqXbt2q6kARwXrMxjHz16lKSkJC677DJXeUhICK1atXJriOnLOW/fvj116tRhypQp/Pvf/+b777/n559/Zvr06bl+zkzqbA+SW1uFlJQU110cf/zwww+oqis5yXTq1Cmuvvpqt23Z72hERETgbwKe/TOoao5tERERqConT54s9sacxhjv/HlUAYCq/qKqb6rqc6r6Vn6SBhGJFJFeItILqAFUzlwXkcw/xd4CTgEfi0gHERmCY2jpV9TGcMghPDycjh07MnLkSL777jsGDhzI6NGjOX36tGufK664AhFh1qxZudaV2bJ97ty5bNiwwbX8/PPPLF68GIBVq1Zx8803c8011zB37lzWr1/Ps88+m6PxXNa7AVmFhoa6rYtIni3qw8LCSEhI4MILL2TEiBE0adKEu+++21Xua0z5ObYneZ1zEaF///688847pKenM3nyZJo2bUqLFi18qn/z5s0A1K1b1+s+lSpV4vDhw37HnpGRgYiwZs0at9/xli1bcjxeyf479OdRRaVKlShVqhR797qPCL9v374cCeWhQ4cIDw+3pMGYIOfX/UARqQL8C0jEMXpkD1X9WUTuB1ar6kofq6oCzMm2LXO9DrBDVQ+LSHvgP8BcHO0aXsWRPPitpD6q8KZRo0akpaVx8uRJwsIcg3O2aNGCBx98kI4dOyIibrf1s7+3TJky7Ny5M8dfn5lWrFhBjRo13Orwp41CIDz55JM0aNCAe++9lxYtWgQkppiYGKpVq8aqVatcn11VWb16NdWqVcv1vZ7Oef/+/Rk9ejRz5szh/fffz3GHJDdjxowhJiaGDh06eN2nWbNmrgTDm7CwsBx3XZo1a4aqsnfvXq666iqfYwLHHQhfH1WEhYXRokULlixZQu/evV3lS5YsoWfPnm7v+emnn2jevLlfsRhjip7PiYOItASWAPtxPCpoB5RxFlfDkVDk3eILUNUdONpG5LXfZsDzlctPBXlUEcwOHjxI7969GTBgAE2aNKFs2bKsXbuWl156ifbt21OuXDm3/S+55BIWL15Mp06dEBGeeCLn6N1ly5Zl+PDhDB8+HFWlTZs2HD9+nFWrVhESEsKQIUOoX78+e/bs4b333uOyyy5j0aJFed7JCLS6devSrVs3nnzySebPnx+wmO6//35eeOEF6tevz0UXXcQbb7xBUlKSK3Hw55zXrFmTa665hmHDhpGamkrfvn09HvPgwYPs3buXlJQUfvnlF958800WLFjAjBkz3B6rZHfNNdfQv3//XNsFxMfHc/LkSZYsWUKzZs2IjIykfv369O3bl379+jF27FiaN2/OoUOHWLp0KXXr1qVHjx5ej+nvo4oHH3yQ2267jZYtW3L55Zfz1ltv8ddffzF06FC3/ZYvX861117rc73GmGLia/cLYAXwXxyPN0oDGUBzZ1kP4M9AdfUozKWkdcc8efKkPvbYY5qYmKixsbEaERGhCQkJ+s9//lMPHjzo2i97d8zvv/9eY2Ji9JlnnlFVz90xX3vtNW3YsKGGhYVppUqVtEOHDrp48WLXPo8++qhWqlRJo6Ki9MYbb9Q33nhDHf+kHDx1oVRVBXTOnDlu27LHl523ulasWKGArlixIt8xTZ06VaOiolzrqamp+sADD2hMTIzGxMToPffc49Yd09dznumjjz5SQG+99dYcZZndMTOXiIgIPf/883XAgAG6YcMGr+cjU1pamtasWVPnzZvn2pa1O2amoUOHasWKFd26Y54+fVpHjRqlderU0dDQUI2Li9OuXbvq2rVrvdaTX6+//rrWrl1bw8LCtHnz5rps2TK38t27d2toaKju2rWrwMcKNmfj94opeQhgd0xR9W1AHhFJAbqr6mLnDJWpQKKq/iAibXEMD+1/K60ikuVRxeDffvvN4z5btmyhYcOGRRuYMQX01ltvMWfOHL788sviDiXfHnroIY4ePcrEiROLO5SAs+8VEwxEZJ2qeu+77Qd/GkcexTF6pCd1gaCe2lpV56rqkNxu+xpzNho8eDDt27d3zVVxNqpSpYpbl1ljTPDyp3Hkp8BTIrISyGxxpiJSCRgO2Aw1xhSDUqVKuXW7PRs99NBDxR2CMcZH/txxeBT4G9gMfOPc9haOoahTgJGBDc0YY4wxwcafAaAOi8ilwG1Ae+AEjkmvJgHvqOqpwgnRGGOMMcHCr3EcVPU0MNm5uIhDH1WdHcjgAulcG8fBGGOMKQw+P6oQkcqSbYxYEYkQkXuA34GZgQ4ukKxxpDHGGFNwuSYOzqGhJ4pIMrAXOCwiw51ldwI7gNdwJA7tCjdUY4wxxhS3vB5VjATuAKYAPwK1gRHOtg49gK+Ax1R1TaFGaYwxxpigkFfi0AN4WlWfy9wgIsuA+cAUVR1UmMEFkrVxMMYYYwourzYOtck5hXXmum9zAweJc72NQ3x8PGPGjPFa3q9fP66//voijOjscs8999CuXbviDsOj3377jbi4ONcAUEuXLkVEOHDgQDFH5ruWLVvy8cc2FIwxZ4O8EodQ4HS2bZnrJwIfjsmP/fv3M2zYMOLj4ylTpgxxcXG0b9+eJUuWFHdoATN69GhEBBEhJCSE6tWr07dvX3bt2lUs8eR1zps0acKgQZ5vyM2fPx8RYevWrezYscP1uUSE6OhoGjRowKBBg9i4caNPsYwYMYJhw4a5JsNq3bo1SUlJVKxYEYBp06YV61TVWX93mUvVqlXd9nnyySd55JFH8jW9uTGmaPnSq+JeEXkpcwH+7dx+f9btIvJiIcZpctGzZ09Wr17N5MmT2bp1K/PmzaNz584cPHiwuENzk5aWhq9zo3jSoEEDkpKS2L17N7Nnz2bTpk3cdNNNAYzQd3md84EDBzJ79mxOnMiZX0+ZMoUrr7yS+vXru7YtXLiQpKQkNm3axKuvvsq+ffto0aIF77//fq5x7Nq1i//+97/079/ftS0sLIyqVauSrRNUQKSmpubrfZm/u8xl06ZNbuXXXXcdx44dY8GCBYEI0xhTmHKbAQtHr4ntPi5/BGrmrcJcStrsmIcPH1ZAlyxZkut+2WefnDFjhpYtW1Y//fRTVfU8O+aLL76odevW1fDwcG3cuLHOmDHDrc5HHnlE69evr+Hh4Vq7dm196KGHNCUlxVWeORPl1KlTtW7duhoSEqLHjh1TQCdMmKC9evXSyMhIrVOnTo66s/M0q+Vrr72mgB49etTvmGbNmqV169bV6Oho7d69u9sMkGlpafqvf/1LY2NjNTY2Vu+//3632TF9OecHDx7UMmXK6JQpU9y279u3T0NDQ3X69OmqemZ2zDVr1uSo45ZbbtGYmBg9fPiw1+O8/PLL2qxZM7dtWWe1zHyddcmcHfPUqVP68MMPa40aNTQyMlITExN14cKFOer5/PPP9ZJLLtHQ0FCdO3eu11i88TazaXb9+/fXvn37+l1/sDsbv1dMyUMAZ8fMtXGkqsYHNEs5Cz3w229sOH68SI95cXQ0484/36d9o6OjiY6O5rPPPuOKK64gPDzvCUpfe+01Ro0axbx582jTpo3HfZ544gk+/PBDXn/9dRo0aMDKlSsZPHgw5cuXp0uXLgBERUUxZcoUatSowebNmxk6dChlypRxm6xo+/btzJw5kzlz5hAWFuaK7+mnn+bf//43L7zwApMnT2bAgAFceeWV1K5d26fPvXfvXj7++GNKlSpFqVKlXNt9iWnHjh3Mnj2bTz75hBMnTnDzzTfz+OOPM2HCBADGjh3L22+/zdtvv02TJk14/fXXee+992jevLnP57xChQrccMMNTJkyxe1uwIwZM4iIiKBXr155fsbhw4cza9YsvvjiC6/7L1++nMRE7xPetW7dmnHjxjFixAi2bdvmih+gf//+bNu2jZkzZ1KzZk3mz59P165dWbNmDU2bNnXV8cgjjzB27FgSEhIoW7Ysy5cvp3PnzrnGPmLECLf5M/744w9q1KhBWFgYrVq14vnnn6du3bpu72nZsiXPPfdc9qqMMUHGr5Ejz2YltVdF6dKlmTZtGoMHD2bixIk0a9aMyy+/nN69e9OqVasc+48cOZIJEybw1Vdf0axZM491njhxgldeeYXFixdz5ZVXAlCnTh1Wr17N66+/7kocnnzySdd74uPjGTFiBGPGjHG7SJ8+fZoZM2YQFxfndozbbruNf/zjHwA888wzjB8/nuXLl+eaOGzZsoXo6GgyMjJISUkB4L777iMqKsq1jy8xpaWlMW3aNFebgCFDhjB16lRX+bhx43j44Yddj0HGjx/PokWLXOW+nvNBgwbRsWNHtm7d6nosMWXKFG699VYiIyO9fs5MjRo1AhwXXW927tzJxRdf7LU8LCyMmJiYHO0Ktm3bxqxZs9ixYwfnnXce4GgA+sUXXzBhwgTeeOMN176jR4+mU6dOrvXo6Gg2bNiQa+wVKlRwvW7VqhXTpk3jggsuYN++fTz77LO0bt2an3/+2dUOA6B69ers2bOHtLQ0Spc+Z76ajDnrnDP/O1V1LjA3MTFxsD/v8/Uv/+LUs2dPunTpwvLly1m5ciULFy5k7NixPPfcc25/9Y0fP55jx46xZs0azs/lc23evJmTJ09y7bXXuj0nT01NJT4+3rX+4YcfMm7cOH7//XeOHz9Oeno66enpbnXVrFkzR9IAjsaDmUqXLk3lypXZt29frp+zXr16zJ8/n1OnTvHpp5/y0Ucf8fzzz7vt40tMtWvXJmvvmurVq7uOffToUZKSkrjssstc5SEhIbRq1cqtIaYv57x9+/bUqVOHKVOm8O9//5vvv/+en3/+menTfeuQpM72ILm1VUhJSfHpLlN2P/zwA6rqSk4ynTp1iquvvtptW/Y7GhEREfiTgGe/O3HppZdSt25dpk+fzoMPPuhWr6py8uTJYm3MaYzJnT+zY5ogFh4eTseOHRk5ciTfffcdAwcOZPTo0Zw+faZTzBVXXIGIMGvWrFzrymzZPnfuXDZs2OBafv75ZxYvXgzAqlWruPnmm7nmmmuYO3cu69ev59lnn83ReC7r3YCsQkND3dZFJM8W9WFhYSQkJHDhhRcyYsQImjRpwt133+0q9zWm/Bzbk7zOuYjQv39/3nnnHdLT05k8eTJNmzalRYsWPtW/efNmgBy39LOqVKkShw8f9jv2jIwMRIQ1a9a4/Y63bNnClClT3PbN/jtcvny563GNtyV7QpdVdHQ0F154Ib/99pvb9kOHDhEeHm5JgzFB7py543CuadSoEWlpaZw8eZKwsDAAWrRowYMPPkjHjh0REbfb+tnfW6ZMGXbu3Jnjr89MK1asoEaNGm517Ny5M/AfJBdPPvkkDRo04N5776VFixYBiSkmJoZq1aqxatUq12dXVVavXk21atVyfa+nc96/f39Gjx7NnDlzeP/993O9oGY3ZswYYmJi6NChg9d9mjVr5kowvAkLC8tx16VZs2aoKnv37uWqq67yOSZw3IHw51FFdidPnuSXX37JcdyffvrJ1Y7EGBO8LHE4yx08eJDevXszYMAAmjRpQtmyZVm7di0vvfQS7du3p1y5cm77X3LJJSxevJhOnTohIjzxxBM56ixbtizDhw9n+PDhqCpt2rTh+PHjrFq1ipCQEIYMGUL9+vXZs2cP7733HpdddhmLFi3K805GoNWtW5du3brx5JNPMn/+/IDFdP/99/PCCy9Qv359LrroIt544w2SkpJciYM/57xmzZpcc801DBs2jNTUVPr27evxmAcPHmTv3r2kpKTwyy+/8Oabb7JgwQJmzJhBboOWXXPNNfTv3z/XdgHx8fGcPHmSJUuW0KxZMyIjI6lfvz59+/alX79+jB07lubNm3Po0CGWLl1K3bp16dGjh9dj+vuoYvjw4XTt2pXzzjuPffv28cwzz3DixAnuuOMOt/2WL1/Otdde63O9xphikp+uGIAA1YHSgereUVRLSeuOefLkSX3sscc0MTFRY2NjNSIiQhMSEvSf//ynHjx40LVf9u6Y33//vcbExOgzzzyjqp67Y7722mvasGFDDQsL00qVKmmHDh108eLFrn0effRRrVSpkkZFRemNN96ob7zxhjr+STl464YH6Jw5c9y2ZY8vO291rVixQgFdsWJFvmOaOnWqRkVFudZTU1P1gQce0JiYGI2JidF77rnHrTumr+c800cffaSA3nrrrTnKMrtjZi4RERF6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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(8,4))\n",
    "ax = fig.add_subplot(111)\n",
    "l1, = ax.plot(res, 'r')\n",
    "l2, = ax.plot(res1,'k')\n",
    "l3, = ax.plot(res2,'b',linestyle='--')\n",
    "l4, = ax.plot(res3,'c')\n",
    "l5, = ax.plot(res4, 'y')\n",
    "\n",
    "plt.legend((l1,l2,l3,l4,l5), ('SketchySVD', 'Lanczos Power Iteration (iter=5)', 'Sklearn RandSVD (iter=0)', \\\n",
    "          'Sklearn RandSVD (iter=5)', 'frPCA'), prop={\"size\":14},markerscale=2.5, loc='best')\n",
    "ax.tick_params(axis='both', which='major', labelsize=15)\n",
    "ax.tick_params(axis='both', which='minor', labelsize=15)\n",
    "\n",
    "ax.set_xlabel('Run', fontsize=15)\n",
    "ax.set_ylabel('Absolute Reconstruction Error (Frob)', fontsize=15)\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "# plt.savefig('error_trends-synthetic.pdf',bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Relative Tail Energy Errors\n",
    "\n",
    "### Note that although the relative tail energies might look small, the absolute errors are large leading to larger errors in singular vectors and values.\n",
    "\n",
    "### The relative tail energy can be misleading since we already know that the Frobenius norm of the data matrix $\\|B\\|_F \\gg \\|B_r\\|$, where $B_r$ is the rank-$r$ approximation of $B$. If $B$ is a rank-$f$ matrix ($f \\gg r$), division by $\\|B\\|_F$ will always result in a small number.\n",
    "\n",
    "### For the synthetic case considered here, $\\|B\\|_F = 5.5 \\times 10^{3}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HDQINm7Mh4hycemlMH68z5uXKlWKGTNmcN999/Hmm2/SvHlzrrzySm699VZat27ttu3w4cOZPHky//3vf2nevDkAkyZNolmzZowZM8a13dtvv0358uVZt24drVq1IiIigrCwMKpWreraZubMmRw4cIDVq1dTsaIzVlq9evXcjpeamsqMGTOIiYkBoH///kyfPt1V3q9fP6ZOncoTTzwBwOeff87Bgwf5xz/+AcCIESPYtGkT9erVo379+rRu3ZrOnTtzxx13EBISAjjJwUUXXcS0adN48cUXXfGXLl2aHj16+HQOGzVqxObNm33a1hhjLmQ+tVyoajJwOxAeiIOq6h51nuDwtOzJst02Vb1GVSNUtZqqDlM/5hU5h7gWqGr/zItcSdOjRw/+97//sWDBArp06cI333zD5Zdf7rrYAkyYMIHXXnuNr7/+2pVYAKxfv56vvvrK1QISHR1NrVrOFC0///yz12Nu2LCBpk2buhILT2rXrk3Wc169enUOHvyrIeyee+7hl19+4ZtvnKedp02bxk033USFChUAqFatGqtXr2bLli0MGjQIVeX++++nVatWrn4XQUFB9OnTh5kzZ7r6TUyfPp3evXsTHu7br7Wq2rgExhjjA38G0fov0B5Ynj+hFGN+tCAUtvDwcDp16kSnTp0YPnw4/fr1Y+TIkQwZMgSAq666isWLFzNnzhy32xfp6enccMMNHh9VrVKlitfjqQ9PWGS2LmQSEdLT/xrEtVKlSnTr1o1p06bRoEEDPvnkExYsyDmGWpMmTWjSpAkPPvggX3/9NX//+9+ZN28effr0AaBv376MGjWKzz//nLJly7J9+3Zmz56dZ3yZtm3bRt26dX3e3hhjLlT+JBevA1NEJApYBPxOtvEmVHVbAGMzBaBRo0akpqa6+mG0bNmSwYMH06lTJ0SEYcOGAdCiRQvmzZtH7dq1cyQDmUJDQ3M8TdGiRQveeecdDh8+nGvrRV7uu+8+evbsSd26dalSpQodO3bM83MBnDhxwrWudu3adOzYkalTp1K2bFlatmzJpZde6tPxP//8c7Zu3epKwowxxnjnT4fOxTgThA3Gma10M7AlY9ma8bNYK8mPoh45coRrrrmGd955h82bN7N7927mz5/Pyy+/TIcOHShTpoxr28suu4wlS5Ywbtw4Ro0aBcCDDz5IUlISvXr14rvvvuOX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8uXLXRf6U6dO0b59e8LDw1mxYgWrV6+mWrVqdOzY0e1Cunv3bmbPns38+fPZtGkT4eHZR9PPac2aNa7zm5iY6Lq189ZbbzF06FCef/55tm/fzrhx4xgzZgwTJ0502/+5557j+uuvZ8uWLTz44IOkp6dTo0YN5s2bx/bt2xk9ejQvvvgi06dPB2DIkCHcdtttdOzY0fXv1aZNmxxx5XUOM61cuZKtW7eybNky5s6dy0cffcSECRO8ft6jR4+ybds24uO9T844YcIErrjiChISElwx1qpVi8TERK6++mqaNGnCmjVrWLZsGSdOnKBbt25uSdeKFSvYvHkzixcv5osvnK+zAQMGEB0dnevy66+/usUxduxYKlSowKWXXsro0aNztIKEhoZy6aWXsmLFCq+fxZiSyJ+JywAQkTigJs4jqG5UdVEggipuBg0axMaNGwv0mJdeeinjx48PWH2DBg1yvY6NjeXll1+me/fuzJw5k6AgJwdNTU3l9ddfp0GDBoBzEUpISCA9PZ2goCBeeOEFevbsyahRo1x1NW3a1PU6IiICgEOHDtG/f38eeOABEhISAOdL+q677nLdQ4+Li2P9+vWMGTOGrl278uuvvxIVFUW3bt0oXbo0tWvXplmzZj5/vjNnzvDKK6/w559/0qFDB959911OnDjBrFmzKF26NABvvvkm7du3Z9euXdSvX5+2bdvy5Zdfcvvtt7N8+XJ69uzJZ599xtq1a7niiitYsWIFY8aMAeC9995DVZk+fToizhx/kydPpnLlyixcuJDbbrsNcJrgZ82aRZUqVXyOvVKlSgBUqFCBqlWruta/8MILvPzyy/Ts2RNwWjieeuopJk6c6NYXoVevXvTr5z46//PPP+96HRsby/fff8+cOXO49957iY6OJiIigrCwMLfjZefLOQQoU6YMkyZNolSpUjRs2JBbb72VL774gqefftpjvb/++iuqSrVq1bweOyYmhtDQUCIjI91inDRpEs2aNXP9uwC8/fbblC9fnnXr1tGqVSsAwsPDmTZtmtstnueff54hQ4Z4PSZA9erVXa8feeQRmjdvToUKFVizZg1PPfUUu3fvZsqUKTn2yWxVMeZC4c+U642AuUAjPM+QqoBNuV5M/fe//+Wll15i+/btJCUlkZaWxtmzZzlw4IDrCzUsLMyVWIDzpZmSksIff/xB+fLl2bBhg9ttDk/Onj3LzTffTMOGDRk3bpxr/fbt23P8xXvVVVe5bmF06tSJ2rVrU6dOHa699lo6d+7MLbfc4rqoeXPXXXfRp08fTp8+TUxMDGPHjqVLly4MHjyYpk2buu3fpk0bgoKC2LZtG/Xr16ddu3auBG758uU8+uijnDp1iuXLl1OxYkX279/varlYv349u3fvzhHPqVOn+Pnnn13va9as6Vdi4c2hQ4f47bffuP/++3nggQdc6z314/DUAvDGG28wZcoU9u7dy+nTp0lJSaF2bf8e+Nq+fXue5xCgUaNGlCr111dN9erV+e6777zWe/r0aQCfWnWyW79+PV999VWO2xMAP//8syu5aNKkSY6+I5UrV6Zy5co+H2vw4MGu102bNqVMmTL06tWLMWPGUKFCBVdZRESE6zMZc6Hwp+ViMhAK3AJsw5lTxEBAWxAKw969e7nhhhu47777eP7556lQoQLff/89d9xxh1szb9YLBOD6Cz1rc3NeBgwYwLFjx1i0aBHBwe65aGZ9ntaVLl2a77//nq+++oqlS5fy0ksvMXToUNauXev212R2r7zyCtdddx1lypRxu3CoqsfjZT1mu3btGDhwIDt37mTdunW0a9eOkydPMmfOHCpWrEj9+vWpUaOG6xxceumlvPfeeznqK1++vOt1VFSU11j9kXnO33jjDY+3LLLKfsy5c+cyaNAgxo4dS5s2bShTpgyvv/46H330kV8x+HIOwbkdlb0st9+ZihUrAnDs2LFcWy88SU9P54YbbmDs2LE5yrImdZ7+HQYMGOD2NIon27Zt46KLLvJY1rp1awB27drlllwcPXqU2NhYX8I3psTwJ7loDtyuqgvzKxhTONatW8fZs2d59dVXXRf8hQv9/2du3rw5X3zxBffd53nG+rFjx7JgwQLWrFlDmTJl3MoaNmzI119/7dZ68fXXX9OoUSPX+1KlSnHNNddwzTXX8Nxzz7luOfTv399rTFWrVnX9BZ1Vo0aNmDZtGsePH3f95f3NN9+Qnp5Ow4YNXTFVqVKF0aNHU79+fSpXrkz79u156KGHKFu2rFvHyhYtWriSjkA/0RAaGgpAWlqaa12VKlWoUaMGP//8M3fffbdf9X399de0bt3a7dZJ1taVzGNmPZ4nvpzDc1GvXj3KlCnDtm3b3P79s/MUY4sWLZg3bx61a9fOkdTkxd/bItll3hrNnhBt3bqVW265xa9YjCnu/OnQ+TMe+lmY4uPPP/9k48aNbsuePXu4+OKLSU9PZ/z48ezevZs5c+acU2vMM888w/z583n22WfZtm0bP/zwA6+++iqnTp1i2bJlDB06lIkTJxIREcGBAwc4cOCA68mCxx9/nFmzZvH666+zc+dO/u///o93332XJ554AnCSnQkTJrBhwwb27t3L7NmzOX78+DlfxHr37k1UVBR33303W7Zs4auvvuL+++/nlltucUtG2rZtyzvvvEP79u0Bp39CpUqV+PDDD92Si969e1OlShW6d+/OihUr2L17N1999RWPPfaY2xMj56Jy5cpERETw+eef8/vvv7vO2ciRI3n55Zd59dVX2bFjB1u3buXtt9/mpZdeyrW+uLg4vv/+ez777DN27tzJCy+8kKPDYWxsLFu3bmXHjh0cPnyYlJSc8xX6eg79FRQURMeOHfn6669z3S42NpY1a9awZ88eDh8+THp6Og8++CBJSUn06tWL7777jl9++YVly5bRv39/jh/PfSieypUrU79+/VyXzNa71atX8+qrr7Jx40Z2797NvHnzGDhwIN26dXNr2dizZw/79++nc+fO53w+jCmWVNWnBecx1O+Bur7uU9wWnLlT3qxfv756s23bNq9lRdk999yjOP1i3JYePXqoquqECRO0evXqGh4ertdcc43OnTtXAd29e7eqqk6fPl2joqLc6vzyyy8V0EOHDrnWffzxx9qiRQsNDQ3VChUqaNeuXfX06dM6YsQIj8e/5557XPtOmjRJ69Wrp6VKldJ69erpm2++6SpbuXKltmvXTsuXL6/h4eHauHFjnTZtWq6fGdD58+d7Ld+8ebNec801Gh4ermXLltV77rlH//jjD7dtJk2alKOezHO5b98+t20PHDigffr00UqVKmloaKjGxsZqQkKC6/yMGDFCGzdunGvMqqq7d+9WQNeuXeta99Zbb2mtWrU0KChI27Zt61o/e/Zsbd68uYaFhWnZsmX1yiuv1Dlz5uR6Ds6cOaN9+/bVsmXLakxMjPbt21efe+45rV27tmubgwcPaqdOnTQ6OloB/fLLLz3Wl9c5vOeee/SGG25wO74v52Hx4sVatWpVTU1N9VrXjh079PLLL9eIiAi339WffvpJe/TooWXLltXw8HCNi4vThx56SM+cOeM1Jn+tX79eW7du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1Spq1KjhVoc/fSYCYdiwYTRo0ICHH36Yli1bBiSmmJgYqlWrxrfffuv67KrKmjVrqFatWq77ejrnCQkJjBw5kvnz5/Pee+/laGnJzdixY4mJiaFjx45et2nevLkrCfEmNDQ0R+tN8+bNUVUOHDhA+/btfY4JnJaMjRs35rpN+fLlXcdu2bIlS5cu5dZbb3WVL126lB49erjts3XrVlq0aOFXLMaYgudzcqGqyUBnEbkWp49FBeAI8IWqlpzBEkqgI0eOcOutt9K3b1+aNm1K6dKlWbduHS+//DIdOnSgTJkybttfdtllLFmyhM6dOyMiPPvssznqLF26NEOGDGHIkCGoKldffTUnTpzg22+/JSgoiP79+xMXF8f+/ft59913ueKKK/j888+ZM2dOQX1swPmLvlu3bgwbNoxFixYFLKZHH32Ul156ibi4OC655BImTpxIYmKiK7nw55zXrFmTa6+9loEDB5KSkkLv3r09HvPIkSMcOHCA06dP8+OPPzJp0iQ+++wzZs2aRW5js1x77bUkJCSQmppKqVKe/8vHxsaSnJzM0qVLad68OZGRkcTFxdG7d2/69OnDuHHjaNGiBUePHmX58uXUrVuXW265xesx/b0tMnjwYO666y5atWrFlVdeyRtvvMH//vc/Bgxwnydx5cqVXHfddT7Xa4wpJIHqvFGSlpL2KGpycrI+/fTTGh8fr2XLltWIiAitX7++/vOf/3R1qlPN+Sjqd999pzExMfrCCy+oqudHUV977TVt2LChhoaGasWKFbVjx466ZMkS1zZPPfWUVqxYUaOiovTmm2/WiRMnqvNr5/D0+Kiq06Fz/vz5buuyx5edt7pWrVqlgK5ateqcY8re4TElJUUHDRqkMTExGhMTow899JDbo6i+nvNMH3zwgQJ655135ijL7NCZuUREROjFF1+sffv21Y0bN3o9H5lSU1O1Zs2aunDhQte67B06VVUHDBigFSpUcHsU9ezZszpixAitU6eOhoSEaJUqVbRr1666bt06r/Wcq9dff11r166toaGh2qJFixwdPPft26chISH622+/nfexipLi+J1iSiYC2KFTVH0fsEhEwoC+OBOV1QQeUtWdItIL2Kyq2wOX9hSe+Ph4Xbduncey7du309CmRzbFzBtvvMH8+fP54osvCjuUc/b444+TlJTEm2+WrO5d9p1iigoR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fjyRkZGuVoPMCcISEhJYsWIFs2fPZsuWLdxzzz107dqVTZs2udXx5JNPMmrUKH788Udat27NypUrXefA2/Liiy+61fHLL79Qo0YN6tSpw+23384vv/ySI9ZWrVqxYkW+NV4aYwLEl6dFeohI1m+mIJy/bm4VkcuzrFdVnZRXZaq6B/dJz7xttw24xof4AkZVFwAL4uPj7/Nnv0E7d7LxxIl8isqzS6OjGX/xxT5tW6pUKWbMmMF9993Hm2++SfPmzbnyyiu59dZbad26dY7thw8fzuTJk/nvf/9L8+bNPdZ58uRJ/v3vf7NkyRL+/ve/A1CnTh3WrFnD66+/zg033AA498kzxcbGMnToUMaOHcsLL7zgWn/27FlmzZqVY1Kqu+66i3/84x8AvPDCC0yYMIGVK1dSu3Ztr591+/btREdHk56ezunTTh78yCOPEBUV5drGl5hSU1OZMWOGq49C//79mT59uqt8/PjxPPHEE65bLhMmTODzzz93lft6zvv160enTp346aefXLdApk2bxp133klkZKTXz5mpUaNGAB4vxJn27t3LpZde6rU8NDSUmJiYHP0cfv75Z+bMmcOePXtcj2c/9NBDLFu2jMmTJzNx4kTXtiNHjqRz586u99HR0WzcuDHX2MuXL+963bp1a2bMmMHf/vY3Dh48yKhRo2jTpg0//PCDq18IQPXq1dm/fz+pqamUKnXeD7sZY/KJL/87vc0i+mS29wrkmVyYwtGjRw9uuOEGVq5cyerVq1m8eDHjxo1j9OjRDB061LXdhAkTOH78OGvXruXiXJKXbdu2kZyczHXXXed23z4lJYXY2FjX+/fff5/x48eza9cuTpw4QVpaGmlpaW511axZ0+Nsl02bNnW9LlWqFJUqVeLgwYO5fs569eqxaNEizpw5w8cff8wHH3yQ4y9kX2KqXbu22wyi1atXdx07KSmJxMRErrjiCld5UFAQrVu3dus86ss579ChA3Xq1GHatGn861//4rvvvuOHH35g5syZuX7OTJrRPyW3vhOnT592tQb54/vvv0dVXQlMpjNnznDNNe55f/aWkYiICOrXr+/zsbp06eL2/vLLL6du3brMnDmTwYMHu9WrqiQnJxdqB1RjTO5yTS5U1Z+5R4o9EekKdPXnSxHwuQWhsIWHh9OpUyc6derE8OHD6devHyNHjmTIkCGEhjpzyF111VUsXryYOXPmMHz4cK91ZfbYX7BgQY5Bx0JCQgD49ttvuf322xkxYgSvvvoqZcuW5ZNPPnE1uWfK2qrgqZ5MIpLnkwKhoaGui1rjxo3ZuXMnDz74IDNmzPArpnM5tid5nXMRISEhgUmTJjF69GimTp1Ks2bNaNmypU/1b9u2DYC6det63aZixYocO3bM79jT09MREdauXZvjfEREuM9hmP3fcOXKlTkShuyGDh3qlthmFR0d7fr3y+ro0aOEh4dbYmFMEWftilmc622R4qpRo0akpqaSnJzsSi5atmzJ4MGD6dSpEyLidgsh+75hYWHs3bs3x1+xmVatWkWNGjXc6vCnz0QgDBs2jAYNGvDwww/TsmXLgMQUExNDtWrV+Pbbb12fXVVZs2YN1apVy3VfT+c8ISGBkSNHMn/+fN57770cLS25GTt2LDExMXTs2NHrNs2bN3clId6EhobmaL1p3rw5qsqBAwdo3769zzGB05Lhz22R7JKTk/nxxx9zHHfr1q20aNHCr1iMMQXPkosLwJEjR7j11lvp27cvTZs2pXTp0qxbt46XX36ZDh06UKZMGbftL7vsMpYsWULnzp0REZ59Nucs96VLl2bIkCEMGTIEVeXqq6/mxIkTfPvttwQFBdG/f3/i4uLYv38/7777LldccQWff/45c+bMKaiPDTh/0Xfr1o1hw4axaNGigMX06KOP8tJLLxEXF8cll1zCxIkTSUxMdCUX/pzzmjVrcu211zJw4EBSUlLo3bu3x2MeOXKEAwcOcPr0aX788UcmTZrEZ599xqxZs8jt8elrr72WhISEXPspxMbGkpyczNKlS2nevDmRkZHExcXRu3dv+vTpw7hx42jRogVHjx5l+fLl1K1bl1tu8T5Xob+3RYYMGULXrl256KKLOHjwIC+88AInT57knnvucdtu5cqVXHfddT7Xa4wpJIF67KQkLSXtUdTk5GR9+umnNT4+XsuWLasRERFav359/ec//6lHjhxxbZf9UdTvvvtOY2Ji9IUXXlBVz4+ivvbaa9qwYUMNDQ3VihUraseOHXXJkiWubZ566imtWLGiRkVF6c0336wTJ05U59fO4e0RREDnz5/vti57fNl5q2vVqlUK6KpVq845punTp2tUVJTrfUpKig4aNEhjYmI0JiZGH3roIbdHUX0955k++OADBfTOO+/MUZb5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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig1 = plt.figure(figsize=(8,4))\n",
    "ax1 = fig1.add_subplot(111)\n",
    "l1, = ax1.plot([x/total_energy for x in res], 'r')\n",
    "l2, = ax1.plot([x/total_energy for x in res1],'k')\n",
    "l3, = ax1.plot([x/total_energy for x in res2],'b',linestyle='--')\n",
    "l4, = ax1.plot([x/total_energy for x in res3],'c')\n",
    "l5, = ax1.plot([x/total_energy for x in res4], 'y')\n",
    "\n",
    "plt.legend((l1,l2,l3,l4,l5), ('SketchySVD', 'Lanczos Power Iteration (iter=5)', 'Sklearn RandSVD (iter=0)', \\\n",
    "          'Sklearn RandSVD (iter=5)', 'frPCA'), prop={\"size\":14},markerscale=2.5, loc='best')\n",
    "ax1.tick_params(axis='both', which='major', labelsize=15)\n",
    "ax1.tick_params(axis='both', which='minor', labelsize=15)\n",
    "\n",
    "ax1.set_xlabel('Run', fontsize=15)\n",
    "ax1.set_ylabel('Relative Reconstruction Error (Frob)', fontsize=15)\n",
    "ax1.set_xscale('log')\n",
    "ax1.set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Deviation in extracted right singular vectors\n",
    "\n",
    "### A correlation map between the extracted right singular vectors (randomized SVD methods) and the true right singular vectors from conventional SVD is shown.\n",
    "\n",
    "### Such a comparison is seldom shown in any Randomized SVD methods as pointed put by (Musco and Musco 2015)\n",
    "\n",
    "### For any rank-r SVD $V_r^TV_r=I_r$, we expect a correlation plot between the true SVD vector $V_{r,true}$ and the extracted SVD vector $V_{r,extracted}$ to be as close to Identity as possible."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$V_{extracted}$')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "subset_true = vv[:r,:]\n",
    "\"\"\"\n",
    "Replace the vector of subset pred with any other method\n",
    "V - Sketchy, V1 - Lanczos, V2 - RandSVD (iter=0), V3 - RandSVD (iter=5), V4 - frPCA\n",
    "\"\"\"\n",
    "subset_pred = V1.T  # Repalcing subset_pred by {V, V1, V2, V3, V4} shows the result for each of the four method\n",
    "\n",
    "corr = np.abs(np.matmul(subset_true,subset_pred))\n",
    "fig2 = plt.figure(figsize=(12,4))\n",
    "ax2 = fig2.add_subplot(121)\n",
    "qq = ax2.imshow(corr,cmap='jet')\n",
    "divider = make_axes_locatable(ax2)\n",
    "cax = divider.append_axes(\"right\", size=\"2%\", pad=0.08)\n",
    "cbar = plt.colorbar(qq,cax=cax)\n",
    "cbar.ax.tick_params(labelsize=17)\n",
    "ax2.set_title('Computed Correlation ($V_{r,extracted}^TV_{r,true}$)', fontsize=15)\n",
    "ax2.set_xlabel('$V_{true}$', fontsize=15)\n",
    "ax2.set_ylabel('$V_{extracted}$', fontsize=15)\n",
    "\n",
    "ax3 = fig2.add_subplot(122)\n",
    "qq1 = ax3.imshow(np.abs(np.matmul(subset_true,subset_true.T)),cmap='jet')\n",
    "divider = make_axes_locatable(ax3)\n",
    "cax1 = divider.append_axes(\"right\", size=\"2%\", pad=0.08)\n",
    "cbar1 = plt.colorbar(qq1,cax=cax1)\n",
    "cbar1.ax.tick_params(labelsize=17)\n",
    "ax3.set_title('Expected Correlation if the computations are correct', fontsize=15)\n",
    "ax3.set_xlabel('$V_{true}$', fontsize=15)\n",
    "ax3.set_ylabel('$V_{extracted}$', fontsize=15)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Deviation in extracted left singular vectors\n",
    "\n",
    "### For any rank-r SVD $U_r^TU_r=I_r$, we expect a correlation plot between the true SVD vector $U_{r,true}$ and the extracted SVD vector $U_{r,extracted}$ to be as close to Identity as possible."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$U_{extracted}$')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "subset_true = uu[:,:r].T\n",
    "\"\"\"\n",
    "Replace the vector of subset pred with any other method\n",
    "U - Sketchy, U1 - Lanczos, U2 - RandSVD (iter=0), U3 - RandSVD (iter=5), U4 - frPCA\n",
    "\"\"\"\n",
    "subset_pred = U  # Repalcing subset_pred by {U, U1, U2, U3, U4} shows the result for each of the four method\n",
    "\n",
    "corr = np.abs(np.matmul(subset_true,subset_pred))\n",
    "fig2 = plt.figure(figsize=(12,4))\n",
    "ax2 = fig2.add_subplot(121)\n",
    "qq = ax2.imshow(corr,cmap='jet')\n",
    "divider = make_axes_locatable(ax2)\n",
    "cax = divider.append_axes(\"right\", size=\"2%\", pad=0.08)\n",
    "cbar = plt.colorbar(qq,cax=cax)\n",
    "cbar.ax.tick_params(labelsize=17)\n",
    "ax2.set_title('Computed Correlation ($U_{r,extracted}^TU_{r,true}$)', fontsize=15)\n",
    "ax2.set_xlabel('$U_{true}$', fontsize=15)\n",
    "ax2.set_ylabel('$U_{extracted}$', fontsize=15)\n",
    "\n",
    "ax3 = fig2.add_subplot(122)\n",
    "qq1 = ax3.imshow(np.abs(np.matmul(subset_true,subset_true.T)),cmap='jet')\n",
    "divider = make_axes_locatable(ax3)\n",
    "cax1 = divider.append_axes(\"right\", size=\"2%\", pad=0.08)\n",
    "cbar1 = plt.colorbar(qq1,cax=cax1)\n",
    "cbar1.ax.tick_params(labelsize=17)\n",
    "ax3.set_title('Expected Correlation if the computations are correct', fontsize=15)\n",
    "ax3.set_xlabel('$U_{true}$', fontsize=15)\n",
    "ax3.set_ylabel('$U_{extracted}$', fontsize=15)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Deviation in Extracted Singular Values\n",
    "\n",
    "### Notice the scale of the deviation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(400.0, 1800.0)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "subset_true = ss[:r]\n",
    "\"\"\"\n",
    "Replace the vector of subset pred with any other method\n",
    "S - Sketchy, S1 - Lanczos, S2 - RandSVD (iter=0), S3 - RandSVD (iter=5), S4 - frPCA\n",
    "\"\"\"\n",
    "subset_pred = S[:r]  # Repalcing subset_pred by {S, S1, S2, S3, S4} shows the result for each of the four method\n",
    "\n",
    "fig3 = plt.figure(figsize=(8,4))\n",
    "ax4 = fig3.add_subplot(111)\n",
    "l1, = ax4.plot(subset_true, c='r')\n",
    "l2, = ax4.plot(subset_pred, c='g')\n",
    "ax4.set_title('Plot of Singular Values $\\Sigma$', fontsize=15)\n",
    "ax4.set_xlabel('Index', fontsize=15)\n",
    "ax4.set_ylabel('Value', fontsize=15)\n",
    "ax4.set_ylim([400, 1800])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The authors are concerned as to how the errror bounds (in different Randomized SVD methods) can be used to practically control the errors, given the aforementioned substantial deviations of the extracted singular factors (values and vectors) by such methods."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
