{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"UFM-plots.ipynb","provenance":[],"collapsed_sections":[]},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"code","execution_count":null,"metadata":{"id":"seO5vGRV-PIE"},"outputs":[],"source":[""]},{"cell_type":"code","execution_count":null,"metadata":{"id":"cDQtWFZlWNaa"},"outputs":[],"source":["import numpy as np\n","from numpy.linalg import norm\n","import torch\n","import torch.nn.functional as F\n","\n","from torch import nn\n","from torch.utils.data import DataLoader, TensorDataset\n","\n","from sklearn.metrics.pairwise import cosine_similarity\n","import matplotlib.pyplot as plt\n","from numpy.linalg import svd\n","\n","\n","import cvxpy as cp\n","\n","import pickle\n"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":31,"status":"ok","timestamp":1652969708898,"user":{"displayName":"vala vakilian","userId":"01609867402239297181"},"user_tz":420},"id":"Yl03FV9bbdh8","outputId":"12983007-2394-4994-e569-874c3bee10b7"},"outputs":[{"output_type":"stream","name":"stdout","text":["cpu\n"]}],"source":["device = 'cuda' if torch.cuda.is_available() else 'cpu'\n","print(device)"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":21945,"status":"ok","timestamp":1652969730825,"user":{"displayName":"vala vakilian","userId":"01609867402239297181"},"user_tz":420},"id":"YRZPkFd4QZds","outputId":"ed1e4668-a775-472d-9fb0-5f06b35999d9"},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/drive\n","[Errno 2] No such file or directory: '/content/drive/My Drive/UFM-shared/plot/'\n","/content\n"]}],"source":["from google.colab import drive\n","drive.mount('/content/drive')\n","\n","path = '/content/drive/My Drive/UFM-shared/plot/'\n","%cd $path"]},{"cell_type":"code","source":["path"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":36},"id":"J9zvMjo-YhWd","executionInfo":{"status":"ok","timestamp":1652969730826,"user_tz":420,"elapsed":15,"user":{"displayName":"vala vakilian","userId":"01609867402239297181"}},"outputId":"ba5df968-ff3c-45c4-d44b-30305f39a3d8"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["'/content/drive/My Drive/UFM-shared/plot/'"],"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"}},"metadata":{},"execution_count":5}]},{"cell_type":"markdown","metadata":{"id":"-HC7EFVgWj3T"},"source":["## parameters"]},{"cell_type":"code","source":["# lr = 5e-1\n","\n","R_list = [1, 2, 10]\n","path_list = ['UFM_R1_k4_alpha100_d10_GD_BS32.pkl',\n","             'UFM_R2_k4_alpha68_d10_GD_BS32.pkl',\n","             'UFM_R10_k4_alpha18_d10_GD_BS32.pkl']\n"],"metadata":{"id":"fqEjThpupsDT"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["class NeuralNetwork(nn.Module):\n","    def __init__(self, n, d, k):\n","        super(NeuralNetwork, self).__init__()\n","        self.layer = nn.Sequential(\n","            nn.Linear(n, d, bias=False),\n","            nn.Linear(d, k, bias=False)\n","        )\n","\n","    def forward(self, x):\n","        logits = self.layer(x)\n","        return logits"],"metadata":{"id":"PVa5Izp1uDG_"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["epoch_list = np.hstack((np.arange(0, 20, 2, dtype=np.int32),\n","          np.arange(20, 200, 20, dtype=np.int32),\n","          np.arange(200, 1000, 50, dtype=np.int32),\n","          np.arange(1000,10000,1000, dtype=np.int32),\n","          np.arange(10000,100000,1000, dtype=np.int32)))\n"],"metadata":{"id":"F6RrQt5nubtA"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["def analysis(Z_hat, W_list, H_list, Z_list):\n","\n","  # svd\n","  u, s, vh = svd(Z_hat, full_matrices=False)\n","  s = s[:k-1]\n","  u = u[:,:k-1]\n","  vh = vh[:k-1,:]\n","\n","  wg_hat = vh.T @ np.diag(s) @ vh\n","  hg_hat = u @ np.diag(s) @ u.T\n","  wg_hat_norm = wg_hat / norm(wg_hat,'fro')\n","  hg_hat_norm = hg_hat / norm(hg_hat,'fro')\n","  Z_hat_norm = Z_hat / norm(Z_hat,'fro')\n","\n","  hg_diff = np.zeros((len(W_list),1))\n","  wg_diff = np.zeros((len(W_list),1))\n","  z_diff = np.zeros((len(W_list),1))\n","\n","  for j in range(len(W_list)):\n","    ww = W_list[j]\n","    hh = H_list[j]\n","    zz = Z_list[j]\n","    \n","    wg = ww @ ww.T\n","    hg = hh.T @ hh\n","    wg_norm = wg / norm(wg,'fro')\n","    hg_norm = hg / norm(hg,'fro')\n","    zz_norm = zz / norm(zz,'fro')\n","\n","    diff = wg_norm - wg_hat_norm\n","    wg_diff[j] = norm(diff, 'fro')\n","    \n","    diff = hg_norm - hg_hat_norm\n","    hg_diff[j] = norm(diff, 'fro')\n","\n","    \n","    diff = zz_norm - Z_hat_norm.T\n","    z_diff[j] = norm(diff, 'fro')\n","\n","  return z_diff, wg_diff, hg_diff\n","\n"],"metadata":{"id":"qkD3rs--un92"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# plots\n","from matplotlib.lines import Line2D\n","\n","leg_size = 20\n","label_size = 25\n","tick_size = 25\n","fig = plt.figure(figsize=(6,6))\n","colors = ['limegreen', 'red', 'dodgerblue']\n","\n","\n","for i in range(len(R_list)):\n","\n","  # load variables\n","  R = R_list[i]\n","  with open(path+path_list[i], 'rb') as f:\n","    loaded_dict = pickle.load(f)\n","\n","  # loading params\n","  R = loaded_dict['R']                      # imabalance ratio\n","  alpha = loaded_dict['alpha']              # n = alpha*(2*R+2)\n","  n = loaded_dict['n']                      # number of samples/dimension of input (basis vectors)\n","  d = loaded_dict['d']                      # dimension of hidden layer\n","  k = loaded_dict['k']                      # number of classes (1,2: maj - 3,4:min)\n","\n","  n_maj = loaded_dict['n_maj']\n","  n_min = loaded_dict['n_min']\n","\n","  x = torch.eye(n, device=device)            # set of basis vectors\n","\n","  y_list = loaded_dict['y_list']\n","  y_flatten = [ii for j in y_list for ii in j]\n","\n","  y = torch.tensor(y_flatten, device=device) \n","  y_oneHot = F.one_hot(y)\n","\n","  Z_hat = (y_oneHot - 1/k).cpu().detach().numpy()\n","  baseline_np = np.eye(k) - 1/k\n","\n","  # Z_hat balanced\n","  y_list_balanced = []\n","  for j in range(k):\n","    y_list_balanced.append([j]*(n//4))\n","  y_flatten_balanced = [ii for j in y_list_balanced for ii in j]\n","\n","  y_balanced = torch.tensor(y_flatten_balanced, device=device) \n","  y_oneHot_balanced = F.one_hot(y_balanced)\n","  # y.get_device()\n","\n","  Z_hat_balanced = (y_oneHot_balanced - 1/k).cpu().detach().numpy()\n","  print(Z_hat_balanced.shape)\n","  input()\n","\n","\n","  batch_size = loaded_dict['batch_size']\n","  lr = loaded_dict['lr']\n","  reg = loaded_dict['reg']\n","  epochs_old = loaded_dict['epochs']\n","  epochs = epochs_old\n","\n","  # define network\n","  model = NeuralNetwork(n,d,k).to(device)\n","  model.load_state_dict(loaded_dict['model'])\n","  Z_list = loaded_dict['Z_list']\n","  H_list = loaded_dict['H_list']\n","  W_list = loaded_dict['W_list']\n","  epoch_list = loaded_dict['epoch_list']\n","  loss_list = loaded_dict['loss_list']\n","\n","\n","  # metrics\n","  z_diff, wg_diff, hg_diff = analysis(Z_hat, \n","                                      W_list, \n","                                      H_list, \n","                                      Z_list)\n","\n","  z_diff_balanced, wg_diff_balanced, hg_diff_balanced = analysis(Z_hat_balanced, \n","                                                                 W_list, \n","                                                                 H_list, \n","                                                                 Z_list)\n","  \n","\n","  #############################################################################\n","  #---- [NEW] Comparison to Z^TZ\n","  wg_diff_2 = np.zeros((len(W_list),1))\n","\n","  for j in range(len(W_list)):\n","    ww = W_list[j]  \n","    wg = ww @ ww.T\n","    wg_norm = wg / norm(wg,'fro')\n","    \n","    wg_hat_balanced = np.eye(k) - 1/k * np.ones((k,k))\n","    wg_hat_norm_balanced = wg_hat_balanced / norm(wg_hat_balanced)\n","    diff = wg_norm - wg_hat_norm_balanced\n","    wg_diff_2[j] = norm(diff, 'fro')\n","\n","\n","  hg_diff_2 = np.zeros((len(H_list),1))\n","  hg_hat_balanced = Z_hat @ Z_hat.T\n","  hg_hat_norm_balnced = hg_hat_balanced / norm(hg_hat_balanced)\n","\n","  for j in range(len(H_list)):\n","    hh = H_list[j]\n","    \n","    hg = hh.T @ hh\n","    hg_norm = hg / norm(hg)\n","    diff = hg_norm - hg_hat_norm_balnced\n","    hg_diff_2[j] = norm(diff, 'fro')\n"," \n","\n","\n","  #############################################################################\n","  \n","  # # plot\n","  # # plt.subplot(2,3,1)\n","  # # plt.figure()\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff, \n","  #          label='R={}-$SELI$'.format(int(R)), linewidth=3, color=colors[i])\n","  # if R > 1:\n","  #   plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff_balanced, '--', \n","  #           label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff_balanced, '--', \n","  #   #          linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5,bbox_to_anchor=(0.99, 0.99))\n","  # # plt.ylim([0.0, 0.5])\n","  # # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Distance to $\\hat{Z}$', fontsize=label_size)\n","  # plt.xticks(fontsize=0.8*tick_size)\n","  # plt.yticks(fontsize=0.8*tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","\n","  # # plt.subplot(2,3,2)\n","  # # plt.figure()\n","  # # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff, \n","  # #          label='R={}-$SEL$'.format(int(R)), linewidth=3, color=colors[i])\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff, \n","  #          linewidth=3, color=colors[i])\n","  # if R > 1:\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_balanced, '--',\n","  #   #         label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_balanced, '--',\n","  #   #          linewidth=3, color=colors[i])\n","  #   plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_2, '--',\n","  #            linewidth=3, color=colors[i])\n","  # # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # # plt.ylim([0.0, 0.5])\n","  # # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Distance to $\\hat{W}^T\\hat{W}$', fontsize=label_size)\n","  # plt.xticks(fontsize=0.8*tick_size)\n","  # plt.yticks(fontsize=0.8*tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","  # plt.subplot(2,3,3)\n","  # plt.figure()\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff, \n","  #          label='R={}-$SEL$'.format(int(R)), linewidth=3, color=colors[i])\n","  plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff, \n","           linewidth=3, color=colors[i])\n","  if R > 1:\n","    # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_balanced, '--', \n","    #         label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","    # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_balanced, '--', \n","    #         linewidth=3, color=colors[i])\n","    plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_2, '--', \n","            linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # plt.ylim([0.0, 0.5])\n","  # plt.xlabel('epoch', fontsize=label_size)\n","  # plt.ylabel('Distance to $\\hat{H}^T\\hat{H}$', fontsize=label_size)\n","  plt.xticks(fontsize=0.8*tick_size)\n","  plt.yticks(fontsize=0.8*tick_size)\n","  plt.xscale('log')\n","  plt.yscale('log')\n","  plt.grid(True)\n","\n","\n","  # plt.subplot(2,2,4)\n","  # plt.plot(epoch_list[:len(Z_list)-1], loss_list,\n","  #          label='R={}'.format(int(R)), linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # # plt.ylim([0.0, 0.5])\n","  # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Loss', fontsize=label_size)\n","  # plt.xticks(fontsize=tick_size)\n","  # plt.yticks(fontsize=tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","\n","  \n","plt.savefig('UFM_H_hat.pdf',bbox_inches='tight')\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":283},"id":"B3ABtIotpr9n","executionInfo":{"status":"error","timestamp":1652969731666,"user_tz":420,"elapsed":849,"user":{"displayName":"vala vakilian","userId":"01609867402239297181"}},"outputId":"6f6a31d4-91c1-4628-ef35-5b9abba7c8b6"},"execution_count":null,"outputs":[{"output_type":"error","ename":"FileNotFoundError","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)","\u001b[0;32m<ipython-input-10-21e184954b88>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     13\u001b[0m   \u001b[0;31m# load variables\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     14\u001b[0m   \u001b[0mR\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mR_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 15\u001b[0;31m   \u001b[0;32mwith\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0mpath_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'rb'\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mf\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     16\u001b[0m     \u001b[0mloaded_dict\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     17\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: '/content/drive/My Drive/UFM-shared/plot/UFM_R1_k4_alpha100_d10_GD_BS32.pkl'"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 432x432 with 0 Axes>"]},"metadata":{}}]},{"cell_type":"code","source":["hh"],"metadata":{"id":"3TQ5oD9f_8i9","executionInfo":{"status":"ok","timestamp":1652970809896,"user_tz":420,"elapsed":179,"user":{"displayName":"Ganesh Kini","userId":"13270215654919527009"}},"colab":{"base_uri":"https://localhost:8080/"},"outputId":"8824cd58-b78e-4998-aa8e-ff6547608eef"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([[ 0.14331417,  0.13547483,  0.11017234, ...,  0.28813474,\n","         0.30302204,  0.26116346],\n","       [ 0.52132304,  0.52424106,  0.54422253, ..., -0.48959831,\n","        -0.44699058, -0.48772097],\n","       [ 0.23872175,  0.22488891,  0.23648003, ..., -0.15887412,\n","        -0.15949685, -0.11770742],\n","       ...,\n","       [ 0.1158968 ,  0.16476845,  0.10466966, ...,  0.88685498,\n","         0.88127923,  0.89480217],\n","       [-0.35638288, -0.33676614, -0.37010026, ...,  0.33004934,\n","         0.30601858,  0.26255611],\n","       [-0.07086668, -0.13261363, -0.12003812, ..., -0.05170349,\n","        -0.00243701,  0.01963834]])"]},"metadata":{},"execution_count":16}]},{"cell_type":"code","source":["# plots\n","from matplotlib.lines import Line2D\n","\n","leg_size = 20\n","label_size = 25\n","tick_size = 25\n","fig = plt.figure(figsize=(8,6))\n","colors = ['limegreen', 'red', 'dodgerblue']\n","\n","\n","for i in range(len(R_list)):\n","\n","  # load variables\n","  R = R_list[i]\n","  with open(path+path_list[i], 'rb') as f:\n","    loaded_dict = pickle.load(f)\n","\n","  # loading params\n","  R = loaded_dict['R']                      # imabalance ratio\n","  alpha = loaded_dict['alpha']              # n = alpha*(2*R+2)\n","  n = loaded_dict['n']                      # number of samples/dimension of input (basis vectors)\n","  d = loaded_dict['d']                      # dimension of hidden layer\n","  k = loaded_dict['k']                      # number of classes (1,2: maj - 3,4:min)\n","\n","  n_maj = loaded_dict['n_maj']\n","  n_min = loaded_dict['n_min']\n","\n","  x = torch.eye(n, device=device)            # set of basis vectors\n","\n","  y_list = loaded_dict['y_list']\n","  y_flatten = [ii for j in y_list for ii in j]\n","\n","  y = torch.tensor(y_flatten, device=device) \n","  y_oneHot = F.one_hot(y)\n","\n","  Z_hat = (y_oneHot - 1/k).cpu().detach().numpy()\n","  baseline_np = np.eye(k) - 1/k\n","\n","  # Z_hat balanced\n","  y_list_balanced = []\n","  for j in range(k):\n","    y_list_balanced.append([j]*(n//4))\n","  y_flatten_balanced = [ii for j in y_list_balanced for ii in j]\n","\n","  y_balanced = torch.tensor(y_flatten_balanced, device=device) \n","  y_oneHot_balanced = F.one_hot(y_balanced)\n","  # y.get_device()\n","\n","  Z_hat_balanced = (y_oneHot_balanced - 1/k).cpu().detach().numpy()\n","  print(Z_hat_balanced.shape)\n","  input()\n","\n","\n","  batch_size = loaded_dict['batch_size']\n","  lr = loaded_dict['lr']\n","  reg = loaded_dict['reg']\n","  epochs_old = loaded_dict['epochs']\n","  epochs = epochs_old\n","\n","  # define network\n","  model = NeuralNetwork(n,d,k).to(device)\n","  model.load_state_dict(loaded_dict['model'])\n","  Z_list = loaded_dict['Z_list']\n","  H_list = loaded_dict['H_list']\n","  W_list = loaded_dict['W_list']\n","  epoch_list = loaded_dict['epoch_list']\n","  loss_list = loaded_dict['loss_list']\n","\n","\n","  # metrics\n","  z_diff, wg_diff, hg_diff = analysis(Z_hat, \n","                                      W_list, \n","                                      H_list, \n","                                      Z_list)\n","\n","  z_diff_balanced, wg_diff_balanced, hg_diff_balanced = analysis(Z_hat_balanced, \n","                                                                 W_list, \n","                                                                 H_list, \n","                                                                 Z_list)\n","  \n","    # svd\n","  u, s, vh = svd(Z_hat, full_matrices=False)\n","  s = s[:k-1]\n","  u = u[:,:k-1]\n","  vh = vh[:k-1,:]\n","\n","  wg_hat = vh.T @ np.diag(s) @ vh\n","  hg_hat = u @ np.diag(s) @ u.T\n","  hg_hat_new = np.hstack([np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],0]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj+n_min]]).T,])\n","  hg_hat_new_norm = hg_hat_new / norm(hg_hat_new)\n","  #############################################################################\n","  #---- [NEW] Comparison with mean matrices\n","  wg_diff_2 = np.zeros((len(W_list),1))\n","\n","  for j in range(len(W_list)):\n","    ww = W_list[j]  \n","    wg = ww @ ww.T\n","    wg_norm = wg / norm(wg,'fro')\n","    \n","    wg_hat_balanced = np.eye(k) - 1/k * np.ones((k,k))\n","    wg_hat_norm_balanced = wg_hat_balanced / norm(wg_hat_balanced)\n","    diff = wg_norm - wg_hat_norm_balanced\n","    wg_diff_2[j] = norm(diff, 'fro')\n","\n","\n","  hg_diff_2 = np.zeros((len(H_list),1))\n","  # hg_hat_balanced = Z_hat @ Z_hat.T\n","  hg_hat_balanced = np.eye(k) - 1/k * np.ones((k,k))\n","  hg_hat_norm_balnced = hg_hat_balanced / norm(hg_hat_balanced)\n","\n","  for j in range(len(H_list)):\n","    hh = H_list[j]\n","    hhnew = np.hstack([np.array([np.mean(hh[:,0:n_maj],1)]).T, np.array([np.mean(hh[:,n_maj:2*n_maj],1)]).T, np.array([np.mean(hh[:,2*n_maj:2*n_maj+n_min],1)]).T, np.array([np.mean(hh[:,2*n_maj+n_min:2*n_maj+2*n_min],1)]).T])\n","    hg = hhnew.T @ hhnew\n","    hg_norm = hg / norm(hg)\n","    diff = hg_norm - hg_hat_norm_balnced\n","    hg_diff_2[j] = norm(diff, 'fro')\n","    diff1 = hg_norm - hg_hat_new_norm\n","    hg_diff[j] = norm(diff1, 'fro')\n"," \n","\n","\n","  #############################################################################\n","  \n","  # # plot\n","  # # plt.subplot(2,3,1)\n","  # # plt.figure()\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff, \n","  #          label='R={}'.format(int(R)), linewidth=3, color=colors[i])\n","  # # if R > 1:\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff_balanced, '--', \n","  #   #         label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), z_diff_balanced, '--', \n","  #   #          linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5,bbox_to_anchor=(0.99, 0.99))\n","  # # plt.ylim([0.0, 0.5])\n","  # # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Distance to $\\hat{Z}$', fontsize=label_size)\n","  # plt.xticks(fontsize=0.8*tick_size)\n","  # plt.yticks(fontsize=0.8*tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","\n","  # plt.subplot(2,3,2)\n","  # plt.figure()\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff, \n","  #          label='R={}-$SEL$'.format(int(R)), linewidth=3, color=colors[i])\n","  plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff, \n","           linewidth=3, color=colors[i])\n","  if R > 1:\n","    # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_balanced, '--',\n","    #         label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","    # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_balanced, '--',\n","    #          linewidth=3, color=colors[i])\n","    plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), wg_diff_2, '--',\n","             linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # plt.ylim([0.0, 0.5])\n","  # plt.xlabel('epoch', fontsize=label_size)\n","  # plt.ylabel('Distance to $\\hat{W}^T\\hat{W}$', fontsize=label_size)\n","  plt.xticks(fontsize=0.8*tick_size)\n","  plt.yticks(fontsize=0.8*tick_size)\n","  plt.xscale('log')\n","  plt.yscale('log')\n","  plt.grid(True)\n","\n","  # # plt.subplot(2,3,3)\n","  # # plt.figure()\n","  # # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff, \n","  # #          label='R={}-$SEL$'.format(int(R)), linewidth=3, color=colors[i])\n","  # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff, \n","  #          linewidth=3, color=colors[i])\n","  # if R > 1:\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_balanced, '--', \n","  #   #         label='R={}-$ETF$'.format(int(R)), linewidth=3, color=colors[i])\n","  #   # plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_balanced, '--', \n","  #   #         linewidth=3, color=colors[i])\n","  #   plt.plot(np.hstack(([0], epoch_list[:len(Z_list)-1])), hg_diff_2, '--', \n","  #           linewidth=3, color=colors[i])\n","  # # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # # plt.ylim([0.0, 0.5])\n","  # # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Distance to $\\hat{H}^T\\hat{H}$', fontsize=label_size)\n","  # plt.xticks(fontsize=0.8*tick_size)\n","  # plt.yticks(fontsize=0.8*tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","\n","  # plt.subplot(2,2,4)\n","  # plt.plot(epoch_list[:len(Z_list)-1], loss_list,\n","  #          label='R={}'.format(int(R)), linewidth=3, color=colors[i])\n","  # plt.legend(prop={'size': leg_size},handlelength=3.5)\n","  # # plt.ylim([0.0, 0.5])\n","  # plt.xlabel('epoch', fontsize=label_size)\n","  # # plt.ylabel('Loss', fontsize=label_size)\n","  # plt.xticks(fontsize=tick_size)\n","  # plt.yticks(fontsize=tick_size)\n","  # plt.xscale('log')\n","  # plt.yscale('log')\n","  # plt.grid(True)\n","\n","\n","  \n","plt.savefig('UFM_W_hat.pdf',bbox_inches='tight')\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":497},"id":"XG6ZsO-5vOgp","executionInfo":{"status":"ok","timestamp":1652976240275,"user_tz":420,"elapsed":6506,"user":{"displayName":"Ganesh Kini","userId":"13270215654919527009"}},"outputId":"c394a89d-80ac-43fd-b32a-fe25d0b76788"},"execution_count":null,"outputs":[{"name":"stdout","output_type":"stream","text":["(400, 4)\n","\n","(408, 4)\n","\n","(396, 4)\n","\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 576x432 with 1 Axes>"],"image/png":"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\n"},"metadata":{"needs_background":"light"}}]},{"cell_type":"code","source":["\n","\n","\n","hg_norm"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"2lN_NHJDvSvQ","executionInfo":{"status":"ok","timestamp":1652972681147,"user_tz":420,"elapsed":227,"user":{"displayName":"Ganesh Kini","userId":"13270215654919527009"}},"outputId":"acba9b66-0a3f-4e1f-9ac6-ebb193da70a1"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([[ 0.24998324, -0.10446987, -0.10456719, -0.10188682],\n","       [-0.10446987,  0.24967919, -0.09840093, -0.11789346],\n","       [-0.10456719, -0.09840093,  0.56692393, -0.2548714 ],\n","       [-0.10188682, -0.11789346, -0.2548714 ,  0.55877142]])"]},"metadata":{},"execution_count":55}]},{"cell_type":"code","source":["  # svd\n","  u, s, vh = svd(Z_hat, full_matrices=False)\n","  s = s[:k-1]\n","  u = u[:,:k-1]\n","  vh = vh[:k-1,:]\n","\n","  wg_hat = vh.T @ np.diag(s) @ vh\n","  hg_hat = u @ np.diag(s) @ u.T\n","  hg_hat_new = np.hstack([np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],0]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj+n_min]]).T,])"],"metadata":{"id":"KCQjLPl1yrg3"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["hg_hat[[0,180,360,360+18],360+18]"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"QT5IEJzB6f1E","executionInfo":{"status":"ok","timestamp":1652974534941,"user_tz":420,"elapsed":599,"user":{"displayName":"Ganesh Kini","userId":"13270215654919527009"}},"outputId":"bb19a118-1b06-47a5-99fe-a3971ca30d46"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([-0.02512594, -0.02512594, -0.09272519,  0.14297707], dtype=float32)"]},"metadata":{},"execution_count":82}]},{"cell_type":"code","source":["hg_hat_new = np.hstack([np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],0]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj]]).T, np.array([hg_hat[[0,n_maj,2*n_maj,2*n_maj+n_min],2*n_maj+n_min]]).T,])"],"metadata":{"id":"uxoOrbBI6iMq"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["hg_hat_new"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"73xWMwuX7dfZ","executionInfo":{"status":"ok","timestamp":1652974552058,"user_tz":420,"elapsed":321,"user":{"displayName":"Ganesh Kini","userId":"13270215654919527009"}},"outputId":"9f11e27b-475a-4baf-8bff-5920e79c1240"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["array([[ 0.06239374, -0.01214186, -0.02512594, -0.02512594],\n","       [-0.01214186,  0.06239374, -0.02512594, -0.02512594],\n","       [-0.02512594, -0.02512594,  0.14297707, -0.09272519],\n","       [-0.02512594, -0.02512594, -0.09272519,  0.14297707]],\n","      dtype=float32)"]},"metadata":{},"execution_count":84}]},{"cell_type":"code","source":[""],"metadata":{"id":"Ty3PRVKr8WSD"},"execution_count":null,"outputs":[]}]}