{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import tensorly as tl\n",
    "import tensorly.tenalg as tg\n",
    "import numpy as np\n",
    "from numpy.linalg import norm\n",
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#return matrix W with each column normalized\n",
    "def get_Wbar(W):\n",
    "    return W@np.diag(1/norm(W, axis = 0))\n",
    "    \n",
    "#return tensor T with components W, note we use two homogeneous parameterization\n",
    "def get_tensor(W):\n",
    "    Wbar = get_Wbar(W)\n",
    "    T = tl.cp_to_tensor((None, [W,W,Wbar,Wbar]))\n",
    "    return T\n",
    "\n",
    "#return the 1/2||T-T*||_F^2\n",
    "def get_loss(Tstar, W):\n",
    "    T = get_tensor(W)\n",
    "    loss = 0.5*(norm(Tstar - T))**2\n",
    "    return loss\n",
    "\n",
    "#return the gradient\n",
    "def get_gradient(Tstar, T, W, Wbar):\n",
    "    term1 = 4*tl.unfold(T-Tstar, 0)@(tl.kr([Wbar, Wbar, W]))\n",
    "    term2 = 2*W@tl.diag(tl.tensor_to_vec(T-Tstar)@(tl.kr([Wbar]*4)))\n",
    "    return (term1-term2)\n",
    "\n",
    "#return the correlation between the residual and the basis directions\n",
    "def get_correlation(Tstar, T):\n",
    "    return tl.tensor_to_vec(Tstar - T)@(tl.kr([np.eye(d)[:,:r]]*4))\n",
    "    \n",
    "#run gradient descent\n",
    "def vanilla_GD(Tstar, W, saddles, eta, num_iter, loss_list, correlation_list, distance_list, COMPUTE_DISTANCE):\n",
    "    for i in range(num_iter):\n",
    "        Wbar = W@np.diag(1/norm(W, axis = 0))\n",
    "        T = tl.cp_to_tensor((None, [W,W,Wbar,Wbar]))\n",
    "        loss = 0.5*(norm(Tstar - T))**2\n",
    "        correlation = get_correlation(Tstar, T)\n",
    "            \n",
    "        correlation_list.append(correlation)\n",
    "        loss_list.append(loss)\n",
    "        \n",
    "        if COMPUTE_DISTANCE:\n",
    "            distance = np.min([norm(T-saddles[i]) for i in range(len(saddles))])\n",
    "            distance_list.append(distance)\n",
    "            \n",
    "        \n",
    "        if i%100==0:\n",
    "            if orthogonal:\n",
    "                print(\"iter#{}, loss: {}, correlation: {}\".format(i, loss, correlation))\n",
    "            else:\n",
    "                print(\"iter#{}, loss: {}\".format(i, loss))\n",
    "        W_norm_list.append(norm(W,axis = 0))\n",
    "        W_list.append(W.copy())\n",
    "        gradient = get_gradient(Tstar, T, W, Wbar)\n",
    "        W -= eta*gradient\n",
    "            \n",
    "    return W, T\n",
    "\n",
    "#return the component that has best correlation with residual R\n",
    "def get_best_correlation(R, eta, num_iter):\n",
    "    V = np.random.randn(d,m)\n",
    "    Vbar = V@np.diag(1/norm(V, axis = 0))\n",
    "    for i in range(num_iter):\n",
    "        V = Vbar + eta*tl.unfold(R, 0)@(tl.kr([Vbar]*3))\n",
    "        Vbar = V@np.diag(1/norm(V, axis = 0))\n",
    "        \n",
    "    corr = tl.tensor_to_vec(R)@(tl.kr([Vbar]*4))\n",
    "    return Vbar[:, np.argmax(corr)].reshape((-1,1))\n",
    "\n",
    "#greedy low rank learning procedure\n",
    "def greedy_low_rank(Tstar, W, saddles, eta, num_iter, loss_list1, correlation_list, distance_list):\n",
    "    for s in range(r):\n",
    "        if s==0:\n",
    "            W = init*get_best_correlation(Tstar, eta, num_iter)\n",
    "        else:\n",
    "            W = np.hstack((W, init*get_best_correlation(Tstar - T, eta, num_iter*(s+1))))\n",
    "\n",
    "        W, T = vanilla_GD(Tstar, W, saddles, eta, (s+1)*num_iter, loss_list1, correlation_list, distance_list, COMPUTE_DISTANCE = False)\n",
    "        saddles.append(T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter#0, loss: 0.5\n",
      "iter#100, loss: 0.5\n",
      "iter#200, loss: 0.5\n",
      "iter#300, loss: 0.5\n",
      "iter#400, loss: 0.5\n",
      "iter#500, loss: 0.5\n",
      "iter#600, loss: 0.19241915667438822\n",
      "iter#700, loss: 0.1924189399003668\n",
      "iter#800, loss: 0.1924189399003668\n",
      "iter#900, loss: 0.1924189399003668\n",
      "iter#1000, loss: 0.1924189399003668\n",
      "iter#1100, loss: 0.1924189399003668\n",
      "iter#1200, loss: 0.1924189399003668\n",
      "iter#1300, loss: 0.1924189399003668\n",
      "iter#1400, loss: 0.1924189399003668\n",
      "iter#1500, loss: 0.1924189399003668\n",
      "iter#1600, loss: 0.1924189399003668\n",
      "iter#1700, loss: 0.1924189399003668\n",
      "iter#1800, loss: 0.1924189399003668\n",
      "iter#1900, loss: 0.1924189399003668\n",
      "iter#2000, loss: 0.1924189399003668\n",
      "iter#2100, loss: 0.1924189399003668\n",
      "iter#2200, loss: 0.1924189399003668\n",
      "iter#2300, loss: 0.1924189399003668\n",
      "iter#2400, loss: 0.1924189399003668\n",
      "iter#2500, loss: 0.1924189399003668\n",
      "iter#2600, loss: 0.1924189399003668\n",
      "iter#2700, loss: 0.1924189399003668\n",
      "iter#2800, loss: 0.1924189399003668\n",
      "iter#2900, loss: 0.1924189399003668\n",
      "iter#0, loss: 0.1924189399003668\n",
      "iter#100, loss: 0.1924189399003668\n",
      "iter#200, loss: 0.1924189399003668\n",
      "iter#300, loss: 0.1924189399003668\n",
      "iter#400, loss: 0.1924189399003668\n",
      "iter#500, loss: 0.1924189399003668\n",
      "iter#600, loss: 0.1924189399003668\n",
      "iter#700, loss: 0.1924189399003668\n",
      "iter#800, loss: 0.1924189399003668\n",
      "iter#900, loss: 0.1924189399003667\n",
      "iter#1000, loss: 0.09466981673258676\n",
      "iter#1100, loss: 0.09466981673258668\n",
      "iter#1200, loss: 0.09466981673258668\n",
      "iter#1300, loss: 0.09466981673258668\n",
      "iter#1400, loss: 0.09466981673258668\n",
      "iter#1500, loss: 0.09466981673258668\n",
      "iter#1600, loss: 0.09466981673258668\n",
      "iter#1700, loss: 0.09466981673258668\n",
      "iter#1800, loss: 0.09466981673258668\n",
      "iter#1900, loss: 0.09466981673258668\n",
      "iter#2000, loss: 0.09466981673258668\n",
      "iter#2100, loss: 0.09466981673258668\n",
      "iter#2200, loss: 0.09466981673258668\n",
      "iter#2300, loss: 0.09466981673258668\n",
      "iter#2400, loss: 0.09466981673258668\n",
      "iter#2500, loss: 0.09466981673258668\n",
      "iter#2600, loss: 0.09466981673258668\n",
      "iter#2700, loss: 0.09466981673258668\n",
      "iter#2800, loss: 0.09466981673258668\n",
      "iter#2900, loss: 0.09466981673258668\n",
      "iter#3000, loss: 0.09466981673258668\n",
      "iter#3100, loss: 0.09466981673258668\n",
      "iter#3200, loss: 0.09466981673258668\n",
      "iter#3300, loss: 0.09466981673258668\n",
      "iter#3400, loss: 0.09466981673258668\n",
      "iter#3500, loss: 0.09466981673258668\n",
      "iter#3600, loss: 0.09466981673258668\n",
      "iter#3700, loss: 0.09466981673258668\n",
      "iter#3800, loss: 0.09466981673258668\n",
      "iter#3900, loss: 0.09466981673258668\n",
      "iter#4000, loss: 0.09466981673258668\n",
      "iter#4100, loss: 0.09466981673258668\n",
      "iter#4200, loss: 0.09466981673258668\n",
      "iter#4300, loss: 0.09466981673258668\n",
      "iter#4400, loss: 0.09466981673258668\n",
      "iter#4500, loss: 0.09466981673258668\n",
      "iter#4600, loss: 0.09466981673258668\n",
      "iter#4700, loss: 0.09466981673258668\n",
      "iter#4800, loss: 0.09466981673258668\n",
      "iter#4900, loss: 0.09466981673258668\n",
      "iter#5000, loss: 0.09466981673258668\n",
      "iter#5100, loss: 0.09466981673258668\n",
      "iter#5200, loss: 0.09466981673258668\n",
      "iter#5300, loss: 0.09466981673258668\n",
      "iter#5400, loss: 0.09466981673258668\n",
      "iter#5500, loss: 0.09466981673258668\n",
      "iter#5600, loss: 0.09466981673258668\n",
      "iter#5700, loss: 0.09466981673258668\n",
      "iter#5800, loss: 0.09466981673258668\n",
      "iter#5900, loss: 0.09466981673258668\n",
      "iter#0, loss: 0.09466981673258668\n",
      "iter#100, loss: 0.09466981673258668\n",
      "iter#200, loss: 0.09466981673258668\n",
      "iter#300, loss: 0.09466981673258668\n",
      "iter#400, loss: 0.09466981673258668\n",
      "iter#500, loss: 0.09466981673258668\n",
      "iter#600, loss: 0.09466981673258668\n",
      "iter#700, loss: 0.09466981673258668\n",
      "iter#800, loss: 0.09466981673258668\n",
      "iter#900, loss: 0.09466981673258668\n",
      "iter#1000, loss: 0.09466981673258668\n",
      "iter#1100, loss: 0.09466981673258668\n",
      "iter#1200, loss: 0.09466981673209153\n",
      "iter#1300, loss: 0.040295337293756936\n",
      "iter#1400, loss: 0.04029533729370774\n",
      "iter#1500, loss: 0.04029533729370774\n",
      "iter#1600, loss: 0.04029533729370774\n",
      "iter#1700, loss: 0.04029533729370774\n",
      "iter#1800, loss: 0.04029533729370774\n",
      "iter#1900, loss: 0.04029533729370774\n",
      "iter#2000, loss: 0.04029533729370774\n",
      "iter#2100, loss: 0.04029533729370774\n",
      "iter#2200, loss: 0.04029533729370774\n",
      "iter#2300, loss: 0.04029533729370774\n",
      "iter#2400, loss: 0.04029533729370774\n",
      "iter#2500, loss: 0.04029533729370774\n",
      "iter#2600, loss: 0.04029533729370774\n",
      "iter#2700, loss: 0.04029533729370774\n",
      "iter#2800, loss: 0.04029533729370774\n",
      "iter#2900, loss: 0.04029533729370774\n",
      "iter#3000, loss: 0.04029533729370774\n",
      "iter#3100, loss: 0.04029533729370774\n",
      "iter#3200, loss: 0.04029533729370774\n",
      "iter#3300, loss: 0.04029533729370774\n",
      "iter#3400, loss: 0.04029533729370774\n",
      "iter#3500, loss: 0.04029533729370774\n",
      "iter#3600, loss: 0.04029533729370774\n",
      "iter#3700, loss: 0.04029533729370774\n",
      "iter#3800, loss: 0.04029533729370774\n",
      "iter#3900, loss: 0.04029533729370774\n",
      "iter#4000, loss: 0.04029533729370774\n",
      "iter#4100, loss: 0.04029533729370774\n",
      "iter#4200, loss: 0.04029533729370774\n",
      "iter#4300, loss: 0.04029533729370774\n",
      "iter#4400, loss: 0.04029533729370774\n",
      "iter#4500, loss: 0.04029533729370774\n",
      "iter#4600, loss: 0.04029533729370774\n",
      "iter#4700, loss: 0.04029533729370774\n",
      "iter#4800, loss: 0.04029533729370774\n",
      "iter#4900, loss: 0.04029533729370774\n",
      "iter#5000, loss: 0.04029533729370774\n",
      "iter#5100, loss: 0.04029533729370774\n",
      "iter#5200, loss: 0.04029533729370774\n",
      "iter#5300, loss: 0.04029533729370774\n",
      "iter#5400, loss: 0.04029533729370774\n",
      "iter#5500, loss: 0.04029533729370774\n",
      "iter#5600, loss: 0.04029533729370774\n",
      "iter#5700, loss: 0.04029533729370774\n",
      "iter#5800, loss: 0.04029533729370774\n",
      "iter#5900, loss: 0.04029533729370774\n",
      "iter#6000, loss: 0.04029533729370774\n",
      "iter#6100, loss: 0.04029533729370774\n",
      "iter#6200, loss: 0.04029533729370774\n",
      "iter#6300, loss: 0.04029533729370774\n",
      "iter#6400, loss: 0.04029533729370774\n",
      "iter#6500, loss: 0.04029533729370774\n",
      "iter#6600, loss: 0.04029533729370774\n",
      "iter#6700, loss: 0.04029533729370774\n",
      "iter#6800, loss: 0.04029533729370774\n",
      "iter#6900, loss: 0.04029533729370774\n",
      "iter#7000, loss: 0.04029533729370774\n",
      "iter#7100, loss: 0.04029533729370774\n",
      "iter#7200, loss: 0.04029533729370774\n",
      "iter#7300, loss: 0.04029533729370774\n",
      "iter#7400, loss: 0.04029533729370774\n",
      "iter#7500, loss: 0.04029533729370774\n",
      "iter#7600, loss: 0.04029533729370774\n",
      "iter#7700, loss: 0.04029533729370774\n",
      "iter#7800, loss: 0.04029533729370774\n",
      "iter#7900, loss: 0.04029533729370774\n",
      "iter#8000, loss: 0.04029533729370774\n",
      "iter#8100, loss: 0.04029533729370774\n",
      "iter#8200, loss: 0.04029533729370774\n",
      "iter#8300, loss: 0.04029533729370774\n",
      "iter#8400, loss: 0.04029533729370774\n",
      "iter#8500, loss: 0.04029533729370774\n",
      "iter#8600, loss: 0.04029533729370774\n",
      "iter#8700, loss: 0.04029533729370774\n",
      "iter#8800, loss: 0.04029533729370774\n",
      "iter#8900, loss: 0.04029533729370774\n",
      "iter#0, loss: 0.04029533729370774\n",
      "iter#100, loss: 0.04029533729370774\n",
      "iter#200, loss: 0.04029533729370774\n",
      "iter#300, loss: 0.04029533729370774\n",
      "iter#400, loss: 0.04029533729370774\n",
      "iter#500, loss: 0.04029533729370774\n",
      "iter#600, loss: 0.04029533729370774\n",
      "iter#700, loss: 0.04029533729370774\n",
      "iter#800, loss: 0.04029533729370774\n",
      "iter#900, loss: 0.04029533729370774\n",
      "iter#1000, loss: 0.04029533729370774\n",
      "iter#1100, loss: 0.04029533729370774\n",
      "iter#1200, loss: 0.04029533729370774\n",
      "iter#1300, loss: 0.04029533729370774\n",
      "iter#1400, loss: 0.04029533729370774\n",
      "iter#1500, loss: 0.04029533729370774\n",
      "iter#1600, loss: 0.04029533729370774\n",
      "iter#1700, loss: 0.040295337293707344\n",
      "iter#1800, loss: 0.04026447209896231\n",
      "iter#1900, loss: 0.005244913083819252\n",
      "iter#2000, loss: 0.0052447921665751945\n",
      "iter#2100, loss: 0.005244792166518939\n",
      "iter#2200, loss: 0.005244792166518937\n",
      "iter#2300, loss: 0.005244792166518937\n",
      "iter#2400, loss: 0.005244792166518937\n",
      "iter#2500, loss: 0.005244792166518937\n",
      "iter#2600, loss: 0.005244792166518937\n",
      "iter#2700, loss: 0.005244792166518937\n",
      "iter#2800, loss: 0.005244792166518937\n",
      "iter#2900, loss: 0.005244792166518937\n",
      "iter#3000, loss: 0.005244792166518937\n",
      "iter#3100, loss: 0.005244792166518937\n",
      "iter#3200, loss: 0.005244792166518937\n",
      "iter#3300, loss: 0.005244792166518937\n",
      "iter#3400, loss: 0.005244792166518937\n",
      "iter#3500, loss: 0.005244792166518937\n",
      "iter#3600, loss: 0.005244792166518937\n",
      "iter#3700, loss: 0.005244792166518937\n",
      "iter#3800, loss: 0.005244792166518937\n",
      "iter#3900, loss: 0.005244792166518937\n",
      "iter#4000, loss: 0.005244792166518937\n",
      "iter#4100, loss: 0.005244792166518937\n",
      "iter#4200, loss: 0.005244792166518937\n",
      "iter#4300, loss: 0.005244792166518937\n",
      "iter#4400, loss: 0.005244792166518937\n",
      "iter#4500, loss: 0.005244792166518937\n",
      "iter#4600, loss: 0.005244792166518937\n",
      "iter#4700, loss: 0.005244792166518937\n",
      "iter#4800, loss: 0.005244792166518937\n",
      "iter#4900, loss: 0.005244792166518937\n",
      "iter#5000, loss: 0.005244792166518937\n",
      "iter#5100, loss: 0.005244792166518937\n",
      "iter#5200, loss: 0.005244792166518937\n",
      "iter#5300, loss: 0.005244792166518937\n",
      "iter#5400, loss: 0.005244792166518937\n",
      "iter#5500, loss: 0.005244792166518937\n",
      "iter#5600, loss: 0.005244792166518937\n",
      "iter#5700, loss: 0.005244792166518937\n",
      "iter#5800, loss: 0.005244792166518937\n",
      "iter#5900, loss: 0.005244792166518937\n",
      "iter#6000, loss: 0.005244792166518937\n",
      "iter#6100, loss: 0.005244792166518937\n",
      "iter#6200, loss: 0.005244792166518937\n",
      "iter#6300, loss: 0.005244792166518937\n",
      "iter#6400, loss: 0.005244792166518937\n",
      "iter#6500, loss: 0.005244792166518937\n",
      "iter#6600, loss: 0.005244792166518937\n",
      "iter#6700, loss: 0.005244792166518937\n",
      "iter#6800, loss: 0.005244792166518937\n",
      "iter#6900, loss: 0.005244792166518937\n",
      "iter#7000, loss: 0.005244792166518937\n",
      "iter#7100, loss: 0.005244792166518937\n",
      "iter#7200, loss: 0.005244792166518937\n",
      "iter#7300, loss: 0.005244792166518937\n",
      "iter#7400, loss: 0.005244792166518937\n",
      "iter#7500, loss: 0.005244792166518937\n",
      "iter#7600, loss: 0.005244792166518937\n",
      "iter#7700, loss: 0.005244792166518937\n",
      "iter#7800, loss: 0.005244792166518937\n",
      "iter#7900, loss: 0.005244792166518937\n",
      "iter#8000, loss: 0.005244792166518937\n",
      "iter#8100, loss: 0.005244792166518937\n",
      "iter#8200, loss: 0.005244792166518937\n",
      "iter#8300, loss: 0.005244792166518937\n",
      "iter#8400, loss: 0.005244792166518937\n",
      "iter#8500, loss: 0.005244792166518937\n",
      "iter#8600, loss: 0.005244792166518937\n",
      "iter#8700, loss: 0.005244792166518937\n",
      "iter#8800, loss: 0.005244792166518937\n",
      "iter#8900, loss: 0.005244792166518937\n",
      "iter#9000, loss: 0.005244792166518937\n",
      "iter#9100, loss: 0.005244792166518937\n",
      "iter#9200, loss: 0.005244792166518937\n",
      "iter#9300, loss: 0.005244792166518937\n",
      "iter#9400, loss: 0.005244792166518937\n",
      "iter#9500, loss: 0.005244792166518937\n",
      "iter#9600, loss: 0.005244792166518937\n",
      "iter#9700, loss: 0.005244792166518937\n",
      "iter#9800, loss: 0.005244792166518937\n",
      "iter#9900, loss: 0.005244792166518937\n",
      "iter#10000, loss: 0.005244792166518937\n",
      "iter#10100, loss: 0.005244792166518937\n",
      "iter#10200, loss: 0.005244792166518937\n",
      "iter#10300, loss: 0.005244792166518937\n",
      "iter#10400, loss: 0.005244792166518937\n",
      "iter#10500, loss: 0.005244792166518937\n",
      "iter#10600, loss: 0.005244792166518937\n",
      "iter#10700, loss: 0.005244792166518937\n",
      "iter#10800, loss: 0.005244792166518937\n",
      "iter#10900, loss: 0.005244792166518937\n",
      "iter#11000, loss: 0.005244792166518937\n",
      "iter#11100, loss: 0.005244792166518937\n",
      "iter#11200, loss: 0.005244792166518937\n",
      "iter#11300, loss: 0.005244792166518937\n",
      "iter#11400, loss: 0.005244792166518937\n",
      "iter#11500, loss: 0.005244792166518937\n",
      "iter#11600, loss: 0.005244792166518937\n",
      "iter#11700, loss: 0.005244792166518937\n",
      "iter#11800, loss: 0.005244792166518937\n",
      "iter#11900, loss: 0.005244792166518937\n",
      "iter#0, loss: 0.005244792166518937\n",
      "iter#100, loss: 0.005244792166518937\n",
      "iter#200, loss: 0.005244792166518937\n",
      "iter#300, loss: 0.005244792166518937\n",
      "iter#400, loss: 0.005244792166518937\n",
      "iter#500, loss: 0.005244792166518937\n",
      "iter#600, loss: 0.005244792166518937\n",
      "iter#700, loss: 0.005244792166518937\n",
      "iter#800, loss: 0.005244792166518937\n",
      "iter#900, loss: 0.005244792166518937\n",
      "iter#1000, loss: 0.005244792166518937\n",
      "iter#1100, loss: 0.005244792166518937\n",
      "iter#1200, loss: 0.005244792166518937\n",
      "iter#1300, loss: 0.005244792166518937\n",
      "iter#1400, loss: 0.005244792166518937\n",
      "iter#1500, loss: 0.005244792166518937\n",
      "iter#1600, loss: 0.005244792166518937\n",
      "iter#1700, loss: 0.005244792166518937\n",
      "iter#1800, loss: 0.005244792166518937\n",
      "iter#1900, loss: 0.005244792166518937\n",
      "iter#2000, loss: 0.005244792166518937\n",
      "iter#2100, loss: 0.005244792166518937\n",
      "iter#2200, loss: 0.005244792166518937\n",
      "iter#2300, loss: 0.005244792166518937\n",
      "iter#2400, loss: 0.005244792166518937\n",
      "iter#2500, loss: 0.005244792166518937\n",
      "iter#2600, loss: 0.005244792166518937\n",
      "iter#2700, loss: 0.005244792166518937\n",
      "iter#2800, loss: 0.005244792166518937\n",
      "iter#2900, loss: 0.005244792166518937\n",
      "iter#3000, loss: 0.005244792166518937\n",
      "iter#3100, loss: 0.005244792166518937\n",
      "iter#3200, loss: 0.005244792166518937\n",
      "iter#3300, loss: 0.005244792166518937\n",
      "iter#3400, loss: 0.005244792166518937\n",
      "iter#3500, loss: 0.005244792166518937\n",
      "iter#3600, loss: 0.005244792166518937\n",
      "iter#3700, loss: 0.005244792166516923\n",
      "iter#3800, loss: 0.005244791947995202\n",
      "iter#3900, loss: 0.005221165749795255\n",
      "iter#4000, loss: 3.4469166698847464e-07\n",
      "iter#4100, loss: 9.254192348054198e-14\n",
      "iter#4200, loss: 2.6500827213359075e-20\n",
      "iter#4300, loss: 7.590168952494774e-27\n",
      "iter#4400, loss: 1.317799031111137e-31\n",
      "iter#4500, loss: 1.3135310407120419e-31\n",
      "iter#4600, loss: 1.3135310407120419e-31\n",
      "iter#4700, loss: 1.3135310407120419e-31\n",
      "iter#4800, loss: 1.3135310407120419e-31\n",
      "iter#4900, loss: 1.3135310407120419e-31\n",
      "iter#5000, loss: 1.3135310407120419e-31\n",
      "iter#5100, loss: 1.3135310407120419e-31\n",
      "iter#5200, loss: 1.3135310407120419e-31\n",
      "iter#5300, loss: 1.3135310407120419e-31\n",
      "iter#5400, loss: 1.3135310407120419e-31\n",
      "iter#5500, loss: 1.3135310407120419e-31\n",
      "iter#5600, loss: 1.3135310407120419e-31\n",
      "iter#5700, loss: 1.3135310407120419e-31\n",
      "iter#5800, loss: 1.3135310407120419e-31\n",
      "iter#5900, loss: 1.3135310407120419e-31\n",
      "iter#6000, loss: 1.3135310407120419e-31\n",
      "iter#6100, loss: 1.3135310407120419e-31\n",
      "iter#6200, loss: 1.3135310407120419e-31\n",
      "iter#6300, loss: 1.3135310407120419e-31\n",
      "iter#6400, loss: 1.3135310407120419e-31\n",
      "iter#6500, loss: 1.3135310407120419e-31\n",
      "iter#6600, loss: 1.3135310407120419e-31\n",
      "iter#6700, loss: 1.3135310407120419e-31\n",
      "iter#6800, loss: 1.3135310407120419e-31\n",
      "iter#6900, loss: 1.3135310407120419e-31\n",
      "iter#7000, loss: 1.3135310407120419e-31\n",
      "iter#7100, loss: 1.3135310407120419e-31\n",
      "iter#7200, loss: 1.3135310407120419e-31\n",
      "iter#7300, loss: 1.3135310407120419e-31\n",
      "iter#7400, loss: 1.3135310407120419e-31\n",
      "iter#7500, loss: 1.3135310407120419e-31\n",
      "iter#7600, loss: 1.3135310407120419e-31\n",
      "iter#7700, loss: 1.3135310407120419e-31\n",
      "iter#7800, loss: 1.3135310407120419e-31\n",
      "iter#7900, loss: 1.3135310407120419e-31\n",
      "iter#8000, loss: 1.3135310407120419e-31\n",
      "iter#8100, loss: 1.3135310407120419e-31\n",
      "iter#8200, loss: 1.3135310407120419e-31\n",
      "iter#8300, loss: 1.3135310407120419e-31\n",
      "iter#8400, loss: 1.3135310407120419e-31\n",
      "iter#8500, loss: 1.3135310407120419e-31\n",
      "iter#8600, loss: 1.3135310407120419e-31\n",
      "iter#8700, loss: 1.3135310407120419e-31\n",
      "iter#8800, loss: 1.3135310407120419e-31\n",
      "iter#8900, loss: 1.3135310407120419e-31\n",
      "iter#9000, loss: 1.3135310407120419e-31\n",
      "iter#9100, loss: 1.3135310407120419e-31\n",
      "iter#9200, loss: 1.3135310407120419e-31\n",
      "iter#9300, loss: 1.3135310407120419e-31\n",
      "iter#9400, loss: 1.3135310407120419e-31\n",
      "iter#9500, loss: 1.3135310407120419e-31\n",
      "iter#9600, loss: 1.3135310407120419e-31\n",
      "iter#9700, loss: 1.3135310407120419e-31\n",
      "iter#9800, loss: 1.3135310407120419e-31\n",
      "iter#9900, loss: 1.3135310407120419e-31\n",
      "iter#10000, loss: 1.3135310407120419e-31\n",
      "iter#10100, loss: 1.3135310407120419e-31\n",
      "iter#10200, loss: 1.3135310407120419e-31\n",
      "iter#10300, loss: 1.3135310407120419e-31\n",
      "iter#10400, loss: 1.3135310407120419e-31\n",
      "iter#10500, loss: 1.3135310407120419e-31\n",
      "iter#10600, loss: 1.3135310407120419e-31\n",
      "iter#10700, loss: 1.3135310407120419e-31\n",
      "iter#10800, loss: 1.3135310407120419e-31\n",
      "iter#10900, loss: 1.3135310407120419e-31\n",
      "iter#11000, loss: 1.3135310407120419e-31\n",
      "iter#11100, loss: 1.3135310407120419e-31\n",
      "iter#11200, loss: 1.3135310407120419e-31\n",
      "iter#11300, loss: 1.3135310407120419e-31\n",
      "iter#11400, loss: 1.3135310407120419e-31\n",
      "iter#11500, loss: 1.3135310407120419e-31\n",
      "iter#11600, loss: 1.3135310407120419e-31\n",
      "iter#11700, loss: 1.3135310407120419e-31\n",
      "iter#11800, loss: 1.3135310407120419e-31\n",
      "iter#11900, loss: 1.3135310407120419e-31\n",
      "iter#12000, loss: 1.3135310407120419e-31\n",
      "iter#12100, loss: 1.3135310407120419e-31\n",
      "iter#12200, loss: 1.3135310407120419e-31\n",
      "iter#12300, loss: 1.3135310407120419e-31\n",
      "iter#12400, loss: 1.3135310407120419e-31\n",
      "iter#12500, loss: 1.3135310407120419e-31\n",
      "iter#12600, loss: 1.3135310407120419e-31\n",
      "iter#12700, loss: 1.3135310407120419e-31\n",
      "iter#12800, loss: 1.3135310407120419e-31\n",
      "iter#12900, loss: 1.3135310407120419e-31\n",
      "iter#13000, loss: 1.3135310407120419e-31\n",
      "iter#13100, loss: 1.3135310407120419e-31\n",
      "iter#13200, loss: 1.3135310407120419e-31\n",
      "iter#13300, loss: 1.3135310407120419e-31\n",
      "iter#13400, loss: 1.3135310407120419e-31\n",
      "iter#13500, loss: 1.3135310407120419e-31\n",
      "iter#13600, loss: 1.3135310407120419e-31\n",
      "iter#13700, loss: 1.3135310407120419e-31\n",
      "iter#13800, loss: 1.3135310407120419e-31\n",
      "iter#13900, loss: 1.3135310407120419e-31\n",
      "iter#14000, loss: 1.3135310407120419e-31\n",
      "iter#14100, loss: 1.3135310407120419e-31\n",
      "iter#14200, loss: 1.3135310407120419e-31\n",
      "iter#14300, loss: 1.3135310407120419e-31\n",
      "iter#14400, loss: 1.3135310407120419e-31\n",
      "iter#14500, loss: 1.3135310407120419e-31\n",
      "iter#14600, loss: 1.3135310407120419e-31\n",
      "iter#14700, loss: 1.3135310407120419e-31\n",
      "iter#14800, loss: 1.3135310407120419e-31\n",
      "iter#14900, loss: 1.3135310407120419e-31\n",
      "iter#0, loss: 0.5\n",
      "iter#100, loss: 0.5\n",
      "iter#200, loss: 0.5\n",
      "iter#300, loss: 0.5\n",
      "iter#400, loss: 0.5\n",
      "iter#500, loss: 0.5\n",
      "iter#600, loss: 0.1924189399003668\n",
      "iter#700, loss: 0.1924112916035723\n",
      "iter#800, loss: 0.15729653318435413\n",
      "iter#900, loss: 0.059551076984035264\n",
      "iter#1000, loss: 0.00014256672454015867\n",
      "iter#1100, loss: 2.056252503721011e-05\n",
      "iter#1200, loss: 1.2113872213468384e-05\n",
      "iter#1300, loss: 8.481499446740535e-06\n",
      "iter#1400, loss: 6.393446666721993e-06\n",
      "iter#1500, loss: 5.029352008800633e-06\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-3-0e46b9a154a0>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     82\u001b[0m \u001b[0mW_list\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     83\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 84\u001b[0;31m \u001b[0mvanilla_GD\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mTstar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mW\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msaddles\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0meta\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnum_iter\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mloss_list2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcorrelation_list\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdistance_list\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mCOMPUTE_DISTANCE\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m<ipython-input-2-70e776b21b64>\u001b[0m in \u001b[0;36mvanilla_GD\u001b[0;34m(Tstar, W, saddles, eta, num_iter, loss_list, correlation_list, distance_list, COMPUTE_DISTANCE)\u001b[0m\n\u001b[1;32m     44\u001b[0m         \u001b[0mW_norm_list\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnorm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mW\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0maxis\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     45\u001b[0m         \u001b[0mW_list\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mW\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcopy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 46\u001b[0;31m         \u001b[0mgradient\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mget_gradient\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mTstar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mW\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mWbar\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     47\u001b[0m         \u001b[0mW\u001b[0m \u001b[0;34m-=\u001b[0m \u001b[0meta\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mgradient\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     48\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-2-70e776b21b64>\u001b[0m in \u001b[0;36mget_gradient\u001b[0;34m(Tstar, T, W, Wbar)\u001b[0m\n\u001b[1;32m     14\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mget_gradient\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mTstar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mW\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mWbar\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     15\u001b[0m     \u001b[0mterm1\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m4\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mtl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munfold\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mTstar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m@\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mWbar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mWbar\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mW\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 16\u001b[0;31m     \u001b[0mterm2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mW\u001b[0m\u001b[0;34m@\u001b[0m\u001b[0mtl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiag\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtensor_to_vec\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mTstar\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m@\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtl\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mWbar\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;36m4\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     17\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mterm1\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mterm2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     18\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "#gradient descent parameters\n",
    "d = 10\n",
    "r = 5\n",
    "m = 1000\n",
    "eta = 0.3\n",
    "init = 1e-100\n",
    "num_iter = 3000\n",
    "orthogonal = False\n",
    "\n",
    "#construct the ground truth tensor \n",
    "if orthogonal:\n",
    "    a = 1.2**np.array([1,2,3,4,5])\n",
    "    a = np.sort((a))[::-1]\n",
    "    Wstar = np.eye(d)[:,:r]@(np.diag(a))**0.25\n",
    "else:\n",
    "    Wstar = np.random.randn(d,r)\n",
    "    #Wstar = Wstar@np.diag(1/norm(Wstar, axis = 0))\n",
    "\n",
    "\n",
    "#ground truth tensor for non-orthogonal tensor decomposition\n",
    "Wstar = np.array([[-0.79037225,  0.07005099,  0.58095469, -0.52595503,  0.60099897],\n",
    "       [-1.52206411,  0.36191364,  1.34708127, -0.56571125, -0.29377751],\n",
    "       [-0.23031446, -1.41921319, -0.37373797, -1.02211438,  0.71801088],\n",
    "       [-0.93549671, -1.47881807, -1.19584746,  0.06290099, -0.81607334],\n",
    "       [-0.54248052, -1.30165582,  0.38818195,  0.46262811, -0.32395366],\n",
    "       [-0.74425509, -0.96664858,  1.89480584, -1.37132789, -1.6820107 ],\n",
    "       [ 0.46299708,  0.54387881, -0.03406488, -0.89315403, -0.18024349],\n",
    "       [-0.65469063,  0.03436177, -0.190509  , -0.30818727, -0.12000346],\n",
    "       [-2.22264477,  1.17140469, -0.63276744, -0.15521572, -1.45851107],\n",
    "       [ 1.28068789,  0.98506927,  0.5471856 , -0.20988675,  1.28894468]])\n",
    "\n",
    "#normalize the ground truth tensor\n",
    "Tstar = tl.cp_to_tensor((None, [Wstar]*4))\n",
    "Tstar = Tstar/norm(Tstar)\n",
    "\n",
    "#initialize our model\n",
    "W = np.random.randn(d,m)\n",
    "W = init*get_Wbar(W)\n",
    "\n",
    "'''\n",
    "big_loss = []\n",
    "big_correlation = []\n",
    "W_norm_list = []\n",
    "W_list = []\n",
    "\n",
    "for s in range(5):\n",
    "    W = np.random.randn(d,m)\n",
    "    Wbar = get_Wbar(W)\n",
    "    W = init*Wbar\n",
    "    \n",
    "    loss_list = []\n",
    "    reg_loss_list = []\n",
    "    correlation_list = []\n",
    "    reinit = np.array([0]*m) # 0 means reinitialized, 1 means passed the test\n",
    "    distance_list = []\n",
    "    saddles = [0*Tstar]\n",
    "\n",
    "    #run the algorithm\n",
    "    vanilla_GD(Tstar, W, saddles, eta, lmd, num_iter, loss_list, reg_loss_list, correlation_list, distance_list, COMPUTE_DISTANCE = False)\n",
    "    #our_algo(Tstar, W, eta, lmd, num_iter, delta1, gamma, phase2_over_phase1, epochs, loss_list, reg_loss_list, correlation_list)\n",
    "    \n",
    "    big_loss.append(loss_list)\n",
    "    big_correlation.append(correlation_list)\n",
    "'''\n",
    "\n",
    "loss_list = []\n",
    "correlation_list = []\n",
    "distance_list = []\n",
    "saddles = [0*Tstar]\n",
    "W_norm_list = []\n",
    "W_list = []\n",
    "    \n",
    "loss_list1 = []\n",
    "#run greedy low-rank learning to get the saddles\n",
    "greedy_low_rank(Tstar, W, saddles, eta, num_iter, loss_list1, correlation_list, distance_list)\n",
    "\n",
    "#run vanilla GD and compute the distance to saddles \n",
    "loss_list2 = []\n",
    "W = np.random.randn(d,m)\n",
    "W = init*get_Wbar(W)\n",
    "W_norm_list = []\n",
    "W_list = []\n",
    "\n",
    "vanilla_GD(Tstar, W, saddles, eta, num_iter, loss_list2, correlation_list, distance_list, COMPUTE_DISTANCE = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAEGCAYAAAB1iW6ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAfO0lEQVR4nO3de5xVdb3/8ddnBhQCb0eRUDQgrYlgGC4zgAISXqDsh5oYl5KoELUQDz2OZnk5Hn2YZWlK6kFJ0J9pamFeKVKLH6CkDAoICIgcL4OkAycUQXKY+fz+WGtv9szs2bOH5sJa6/18PObB3uv63V/gPd/9Xd+1vubuiIhI9BW0dQFERKR5KNBFRGJCgS4iEhMKdBGRmFCgi4jERLu2OvFRRx3lPXr0aKvTi4hE0ooVK7a5e5ds69os0Hv06EF5eXlbnV5EJJLM7K2G1qnLRUQkJhToIiIxoUAXEYmJNutDF8mmqqqKiooK9uzZ09ZFEWlTHTp0oHv37rRv3z7vfRTockCpqKjgkEMOoUePHphZWxdHpE24O9u3b6eiooKePXvmvV9eXS5mNsbMNpjZJjO7Isv6kWb2gZmtDH+uaULZRdL27NnDkUceqTCXRDMzjjzyyCZ/U220hW5mhcAdwOlABbDczJ5w93V1Nl3i7l9t0tlFslCYi+zf/4N8ulzKgE3uvjk8yUPAWUDdQG8VG/6+k6dXv0thQQHtCo3CAuPoQw7mnP7HKghEJNHy6XI5Fngn431FuKyuoWa2ysz+aGZfzHYgM5tmZuVmVl5ZWbkfxYVN73/ErL9s4pfPbuTnCzfw0z+u5wePrGLLjo/363gidXXu3LlVz1dZWcngwYPp378/S5YsadVzp4wcObJJN/r16NGDbdu2tWCJmmbRokV89au5Owjy2aY5TJ06lXXr2qS9m1cLPVuzt+6sGC8Dn3H3j8zsK8BjwIn1dnK/G7gbYNCgQfs1s8aZxd04s/hMamqcvTXOE6ve5T9+t4o9VTX7cziRNvfcc89RVFTEfffdt1/77927l3bt4jO+obq6msLCwrYuRoMaK9+vf/3rVixNbfm00CuA4zLedwfezdzA3T9094/C1wuA9mZ2VLOVMouCAuOgdgUc3C71ETTzkjQvd+eyyy6jT58+9O3bl4cffhiArVu3MmLECEpKSujTpw9LliyhurqaKVOmpLf95S9/We94b731FqeeeirFxcWceuqpvP3226xcuZLLL7+cBQsWUFJSwscf1/6muWDBAoqKihg2bBgzZsxItzCvvfZapk2bxhlnnMHkyZOprKzk3HPPpbS0lNLSUp5//nkAdu3axXe+8x1KS0vp378/jz/+OAAff/wxEyZMoLi4mPHjx6fPe8899zBz5sz0+efMmcMPfvCDnPV0yy230KdPH/r06cOtt94KwE033cSsWbMAmDlzJqNGjQKCX17f/OY36x2jR48eXHfddQwbNozf/e53zJkzh9LSUvr168e5557L7t27AZgyZQozZszgpJNOolevXvz+97+vd6zly5fTv39/Nm/e3GCZG6qXN998k+HDhzNgwAAGDBjACy+8AASt+y996UtMmjSJvn37smjRIkaOHMm4ceMoKiriG9/4BqnZ3zK/7XTu3Jkrr7ySfv36MWTIEN577z0A3njjDYYMGUJpaSnXXHNNs30rzOfX+nLgRDPrCWwBJgCTMjcws08D77m7m1kZwS+K7c1SQkms/3pyLeve/bBZj9n7mEP5z/+TtUewnkcffZSVK1eyatUqtm3bRmlpKSNGjODBBx9k9OjRXHnllVRXV7N7925WrlzJli1bWLNmDQA7duyod7zp06czefJkvvWtbzF37lxmzJjBY489xnXXXUd5eTm33357re337NnDhRdeyOLFi+nZsycTJ06stX7FihUsXbqUjh07MmnSJGbOnMmwYcN4++23GT16NK+99ho33HADo0aNYu7cuezYsYOysjJOO+007rrrLj71qU+xevVqVq9ezYABAwDSIX/TTTfRvn175s2bx1133dVgHa1YsYJ58+bx4osv4u4MHjyYU045hREjRnDzzTczY8YMysvL+ec//0lVVRVLly5l+PDhWY/VoUMHli5dCsD27du54IILALjqqqu45557uOSSS4DgF+rSpUtZv349Y8eOZdy4celjvPDCC1xyySU8/vjjHH/88Q2Wu6F6Ofroo3nmmWfo0KEDr7/+OhMnTkyH80svvcSaNWvo2bMnixYt4pVXXmHt2rUcc8wxnHzyyTz//PMMGzas1nl27drFkCFDuOGGG7j88suZM2cOV111FZdeeimXXnopEydOZPbs2Q2Ws6kabaG7+15gOrAQeA14xN3XmtlFZnZRuNk4YI2ZrQJmARNck5VKxC1dupSJEydSWFhI165dOeWUU1i+fDmlpaXMmzePa6+9lldffZVDDjmEXr16sXnzZi655BL+9Kc/ceihh9Y73rJly5g0KWgLnX/++enwasj69evp1atXehxy3UAfO3YsHTt2BODZZ59l+vTplJSUMHbsWD788EN27tzJn//8Z376059SUlLCyJEj2bNnD2+//TaLFy9Ot5SLi4spLi4GoFOnTowaNYqnnnqK9evXU1VVRd++fXPW0TnnnEOnTp3o3LkzX/va11iyZAkDBw5kxYoV7Ny5k4MPPpihQ4dSXl7OkiVLGgz08ePHp1+vWbOG4cOH07dvXx544AHWrl2bXnf22WdTUFBA79690y1egNdee41p06bx5JNP5gxzoMF6qaqq4oILLqBv376cd955tfrCy8rKao0JLysro3v37hQUFFBSUsKbb75Z7zwHHXRQ+lvVwIED09ssW7aM8847DyD9b6I55NXxFnajLKizbHbG69uB2+vu15r06yN+8m1Jt5SG2iQjRoxg8eLFPP3005x//vlcdtllTJ48mVWrVrFw4ULuuOMOHnnkEebOnZvz+I2NymqsTdSpU6f065qaGpYtW5YO+MxjzJ8/n89//vN5n3/q1Kn85Cc/oaioiG9/+9v7Vcb27dvTo0cP5s2bx0knnURxcTF//etfeeONN/jCF77Q6OeZMmUKjz32GP369ePee+9l0aJF6XUHH3xw1vN369aNPXv28Morr3DMMcc0Wu5s9XLttdfStWtXVq1aRU1NDR06dMhavrrlKCwsZO/evVnrIVXPDW3TnCL/LBeNVJSWMmLECB5++GGqq6uprKxk8eLFlJWV8dZbb3H00UdzwQUX8N3vfpeXX36Zbdu2UVNTw7nnnsv111/Pyy+/XO94J510Eg899BAADzzwQL2v53UVFRWxefPmdKsu1YefzRlnnFGry2blypUAjB49ml/96lfp4HvllVfSn+2BBx4Agtbw6tWr0/sOHjyYd955hwcffLDet4JsdfTYY4+xe/dudu3axR/+8Id0C3zEiBH84he/YMSIEQwfPpzZs2dTUlKS1/DinTt30q1bN6qqqtLlbMzhhx/O008/zY9//ONavwCyaahePvjgA7p160ZBQQH3338/1dXVeZ27qYYMGcL8+fMB0v8mmkPkA12kpZxzzjkUFxfTr18/Ro0axU033cSnP/1pFi1aRElJ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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_list1[:], label = \"loss of greedy low rank learning\")\n",
    "plt.legend()\n",
    "plt.xlabel('# steps')\n",
    "plt.savefig('greedy_loss.eps')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "end = 1500\n",
    "for i in range(10):\n",
    "    plt.plot(np.array(W_norm_list)[:end,i])\n",
    "plt.title('norm of components')\n",
    "plt.xlabel('# steps')\n",
    "plt.savefig('norm_growth.eps')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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F7nkkksoLS0FYMaMGYcsU15eTklJCV/5ylc4//zzueCC5k8EW7NmDd/5znfYt28fVVVVTJs2LT3v4osvJhQKMXz4cLZv3w7AX//6V6699tr0vvv06UNVVRWvvPIKV1xxRXrdurq6Nr+OV199lUWLFgFw9dVX841vfCOrr7+5upYuXcrSpUs56aSTAKiqqmLDhg2NAv21115j8uTJ6fOr+/Tpk3VNkyZNYtasWXz+85/n0ksvTe/z7bffTv+XsH//fjZs2MCECRO47rrriMViXHzxxYwZM6bVr+fYY4/l/fff5+abb+b8889n6tSpQMs/m5dffpk//OEP6Rq/+c1vAs5/LldddRXhcJijjz6as84665B9vfbaa7zzzjtMmjQJgPr6eiZOnNhqfdnI6sIitxvl6SbT5me8vh/w9kiGCb6SXs5zzb52r9paS9pLbZ1aFolEeOONN3juuedYuHAh999/f6MWc8qsWbNYvHgxo0eP5pFHHuGFF15IzysuLk6/TrWTVPWQfSeTSXr16tVs67M9sj1drqW6vvWtb/Gv//qvLa7XXO3Z1jR//nxef/11nnrqKcaMGcPKlStRVe67775GfwRTli1bxlNPPcXVV1/NnDlzuOaaa1rcR+/evVm1ahVLlizhgQce4He/+x0LFixo9WfT0tfR1tenqpxzzjn89re/zeKrz56N5WL8o8hpbRKrLmwdWZo8eTJPPPEENTU1HDhwgD/96U+HLFNVVcX+/fs577zz+PGPf5wO2x49enDgwIH0cgcOHOCoo44iFovx6KOPtrnvqVOnsmDBgnR/7p49eygvL2fo0KH8/ve/B5zQWLVq1SHrNt33qaeeysKFCwF49NFHOe2009pcpyXTpk1jwYIF6f7gbdu2HdKHPHHiRP7+97+zefPmdO1NtVTTpk2bOOWUU7jtttvo168fW7duZdq0afzsZz8jFosB8N5773Hw4EE++OAD+vfvz+zZs/nyl7/MW2+9BUA0Gk0vm2nXrl0kk0kuu+wybr/99vTyLf1sJk2a1KjGlMmTJ7Nw4UISiQQff/wxf/vb3w7Z12c/+1lefvllNm7cCEB1dTXvvfdem9/fttil/8Y/It2c53jnGJtl7NixXHnllYwZM4bBgwdz+umnH7LMgQMHuOiii6itrUVV0wfaZs6cyezZs/npT3/K448/zu23384pp5zC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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "end = 1500\n",
    "plt.plot(distance_list[:end], label = \"distance to the closest saddle\")\n",
    "plt.plot(loss_list2[:end], label = \"loss\")\n",
    "plt.xlabel('# steps')\n",
    "plt.legend()\n",
    "plt.savefig(\"saddle_distance.eps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for s in range(5):\n",
    "    if s<4:\n",
    "        plt.plot(big_loss[s][:1000], color = 'tab:blue')\n",
    "    else:\n",
    "        plt.plot(big_loss[s][:1000], label = \"loss\", color = 'tab:blue')\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel('# steps')\n",
    "plt.savefig(\"loss.eps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAEGCAYAAAB1iW6ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABF2ElEQVR4nO2deZxcVZn3v08tXdVrujv7RhIgLCGhQ9JJWJRFBAJEUEQFGSXDiyzDMr6OLL5xZFFhFNQxThRZJGNkQGEQEIOoSNiFBEkgJEACWegkkE4n3em9tvP+cW9V3a6u6q7ldne6+/nmU5/c5dxzz6lUfnXquef8HjHGoCiKogx+PAPdAEVRFMUdVNAVRVGGCCroiqIoQwQVdEVRlCGCCrqiKMoQwTdQNx41apSZOnXqQN1eURRlUPL666/vMcaMTnduwAR96tSprFmzZqBuryiKMigRkW2ZzmnIRVEUZYiggq4oijJEUEFXFEUZIgxYDF1RDnTC4TB1dXV0dHQMdFOUYUgwGGTSpEn4/f6sr1FBV5QM1NXVUV5eztSpUxGRgW6OMowwxtDQ0EBdXR3Tpk3L+joNuShKBjo6Ohg5cqSKudLviAgjR47M+ddhVoIuIgtF5F0R2SwiN2Yoc7KIrBWRt0XkuZxaoSgHKCrmykCRz2ev15CLiHiBZcBpQB2wWkSeMMZscJSpBH4OLDTGbBeRMTm3JEuuf3gdv1+7I3N7ndt5/mfsdpX0cr7HuqTHC3qqq7fmi/PqLNsYr9PrEcaPCPKleZP5yrEaUlCUoUA2MfT5wGZjzAcAIvIQcC6wwVHmy8CjxpjtAMaY3W43NM4rHzQQjmbr4a5e7z2xtzXMdx7fwHce38BVJx/CdQuPGOgmKYpSANkI+kTgQ8d+HbAgpcxhgF9EVgHlwE+NMb9OrUhELgMuAzjooIPyaS8v3PCpXsvEYjGi0ai9bb2MgRjWy9hlYiYGQNQYYsY6YcDaTtRliNkHosQS52IxiDmSg8SsqjAGIna9YIhG418rhhgGY6wyJmYdN/EzBqKxeElHfYBxXBe/ZyxmEt9XBkM0ftwuFydZZ7IfAB/t7+S5d3eztq6JmIFlq96nOODj6lMO7fX9VfoHr9fLrFmziEQiTJs2jRUrVlBZWZlTHWvWrOHXv/41S5cu7XYuvlp71KhRObft5ptvpqysjG9+85s5X+sWS5Ys4de//jX79u2jpaUlq2ucfT7++ON5+eWXC27H8uXLOf3005kwYQIAl156Kd/4xjeYMWNGwXXnSjaCnu63eOrQ1wfMBU4FioFXROTvxpj3ulxkzN3A3QC1tbV9Nnz2eDx4PPq8tzf+9dOHEY5Emfe9v9LYEeFHT7/L1z45jYDPO9BNU4Di4mLWrl0LwMUXX8yyZctYsmRJTnXU1tZSW1vbB60beD7zmc9w9dVXM3369LyuTyfm0WgUrze3z//y5cuZOXNmQtDvvffevNrjBtkIeh0w2bE/CdiZpsweY0wr0CoizwM1wHsoBzR+n5f7L5nP537+Mga4feU73HzOUQPdrAOOW/7wNht27ne1zhkTKrjpM9m918cddxxvvvkmAO+//z5XXXUV9fX1lJSUcM8993DEEUfw8MMPc8stt+D1ehkxYgTPP/88q1at4s477+TJJ5+koaGBCy+8kPr6eubPn088/eTWrVtZtGgR69evB+DOO++kpaWFm2++mXvuuYe7776bUCjEoYceyooVKygpKcnYzm3btnHJJZdQX1/P6NGjuf/++znooINYvHgxFRUVrFmzho8++ogf/vCHnH/++d2u/81vfsPSpUsJhUIsWLCAn//85xkF9thjj+31fcvUZ4CysjJaWlpYtWoVt9xyC+PHj2ft2rW89dZb3HjjjaxatYrOzk6uuuoqLr/8cgB++MMfsmLFCjweD2eeeSa1tbWsWbOGiy66iOLiYl555RXOPPNM7rzzTmpra3nwwQe57bbbMMZw9tln84Mf/CBx73/913/lySefpLi4mMcff5yxY8f22p/eyGYYuxqYLiLTRKQIuAB4IqXM48AnRcQnIiVYIZmNBbdO6ReOOaiKqhLru/3Rf9QNcGuUVKLRKM888wznnHMOAJdddhk/+9nPeP3117nzzjv5l3/5FwBuvfVWnn76adatW8cTT6T+F4VbbrmFT3ziE7zxxhucc845bN++vdd7n3feeaxevZp169Zx5JFHct999/VY/uqrr+arX/0qb775JhdddBHXXntt4tyuXbt48cUXefLJJ7nxxu6T5TZu3Mhvf/tbXnrpJdauXYvX6+WBBx7otY09kW2fX3vtNb7//e+zYcMG7rvvPkaMGMHq1atZvXo199xzD1u2bOGpp57iscce49VXX2XdunVcf/31nH/++dTW1vLAAw+w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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "color_list = {0: 'tab:blue', 1: 'tab:orange', 2:'tab:green', 3:'tab:red', 4:'tab:purple'}\n",
    "for i in range(r):\n",
    "    for s in range(5):\n",
    "        if s < 4:\n",
    "            plt.plot(np.array(big_correlation[s])[:1000,i], color = color_list[i])\n",
    "        else:\n",
    "            plt.plot(np.array(big_correlation[s])[:1000,i], label = \"Residual on e_{} direction\".format(i+1), color = color_list[i])\n",
    "    \n",
    "plt.legend()\n",
    "plt.xlabel('# steps')\n",
    "plt.savefig(\"corr.eps\")"
   ]
  }
 ],
 "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
