{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy\n",
    "import numpy as np\n",
    "import networkx as nx\n",
    "import ot\n",
    "import time\n",
    "import multiprocessing as mp\n",
    "from tqdm import tqdm, trange\n",
    "import torch\n",
    "import cvxpy as cp\n",
    "import torch.nn as nn\n",
    "from torch.optim import Adam, SGD\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2., 4.])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a = torch.tensor([[0, 1, 1], [1, 2, 1]], dtype=torch.float32)\n",
    "torch.linalg.norm(a, dim=1, ord=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import h5py\n",
    "\n",
    "filename = '/data/sam/modelnet/data/modelnet40_ply_hdf5_2048/ply_data_train1.h5'\n",
    "dataset = None\n",
    "labels = None\n",
    "with h5py.File(filename,'r') as h5f: \n",
    "    dataset = h5f['data'][:]\n",
    "    labels = h5f['label'][:]\n",
    "    \n",
    "dataset = dataset - np.expand_dims(np.mean(dataset, axis=0), 0)  # center\n",
    "dist = np.max(np.sqrt(np.sum(dataset ** 2, axis=1)), 0)\n",
    "dataset = dataset / dist  # scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,\n",
       "       17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33,\n",
       "       34, 35, 36, 37, 38, 39], dtype=uint8)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x7fd7dc0d6040>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(projection='3d')\n",
    "ax.scatter(dataset[208][:, 0], dataset[208][:, 1], dataset[208][:, 2], s=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "class PointNetLearner(nn.Module):\n",
    "    def __init__(self, h_in, h_out, g_out, final_h_layers = 2, num_h_layers=10, num_g_layers=10, final_mlp = False, activation='relu', aggregation='sum'):\n",
    "        super(PointNetLearner, self).__init__()\n",
    "        # initial Siamese embedding part\n",
    "        self.h_out = h_out\n",
    "        self.g_out = g_out\n",
    "        self.h = []\n",
    "        self.h.append(nn.Linear(h_in, h_out))\n",
    "        for i in range(num_h_layers - 1):\n",
    "            self.h.append(nn.Linear(h_out, h_out))\n",
    "        self.h = nn.ModuleList(self.h)\n",
    "        \n",
    "        # final MLP\n",
    "        self.gamma = []\n",
    "        self.gamma.append(nn.Linear(h_out, g_out))\n",
    "        for i in range(num_g_layers - 2):\n",
    "            self.gamma.append(nn.Linear(g_out, g_out))\n",
    "        self.gamma.append(nn.Linear(g_out, 1))\n",
    "        self.gamma = nn.ModuleList(self.gamma)\n",
    "\n",
    "        self.finalMLP = final_mlp\n",
    "        if activation =='relu':\n",
    "            self.activation = torch.relu\n",
    "        elif activation == 'sigmoid':\n",
    "            self.activation = torch.sigmoid\n",
    "        else:\n",
    "            raise Exception(\"Activation function not implemented\")\n",
    "        \n",
    "        layers = []\n",
    "        for i in range(final_h_layers):\n",
    "            layers.append(nn.Linear(h_out, h_out))\n",
    "            layers.append(nn.ReLU())\n",
    "        self.final_h = nn.Sequential(*layers)\n",
    "        self.aggregation = aggregation\n",
    "\n",
    "    \n",
    "    def get_embedding(self, P):\n",
    "        out = P\n",
    "        for layer in self.h:\n",
    "            out = self.activation(layer(out))\n",
    "        out = self.final_h(torch.sum(out, axis=0))\n",
    "        return out \n",
    "    \n",
    "    def get_full_result(self, P, Q):\n",
    "        P_embd = P\n",
    "        Q_embd = Q\n",
    "        for layer in self.h:\n",
    "            P_embd = self.activation(layer(P_embd))\n",
    "            Q_embd = self.activation(layer(Q_embd))\n",
    "        P_embd = torch.sum(P_embd, axis=0)\n",
    "        Q_embd = torch.sum(Q_embd, axis=0)\n",
    "        result = P_embd + Q_embd\n",
    "        for layer in self.gamma:\n",
    "            result = self.activation(layer(result))\n",
    "        return result\n",
    "    \n",
    "    def reset_parameters(self):\n",
    "        for layer in self.h:\n",
    "            torch.nn.init.normal_(layer.weight)\n",
    "        for layer in self.gamma:\n",
    "            torch.nn.init.normal_(layer.weight)\n",
    "        return\n",
    "    \n",
    "    def forward(self, Pblock , Qblock, Pidx, Qidx, dists):\n",
    "        P_embd = Pblock\n",
    "        Q_embd = Qblock\n",
    "        for layer in self.h:\n",
    "            P_embd = self.activation(layer(P_embd))\n",
    "            Q_embd = self.activation(layer(Q_embd))\n",
    "            final_embeddings_P = []\n",
    "            final_embeddings_Q = []\n",
    "        for i in range(len(Pidx)):\n",
    "            P_start = Pidx[i][0]\n",
    "            P_end = Pidx[i][1]\n",
    "\n",
    "            Q_start = Qidx[i][0]\n",
    "            Q_end = Qidx[i][1]\n",
    "            outputP = torch.sum(P_embd[P_start:P_end], axis=0)\n",
    "            outputQ = torch.sum(Q_embd[Q_start:Q_end], axis=0)\n",
    "            final_embeddings_P.append(self.final_h(outputP))\n",
    "\n",
    "            final_embeddings_Q.append(self.final_h(outputQ))\n",
    "        final_embeddings_P = torch.vstack(final_embeddings_P)\n",
    "        final_embeddings_Q = torch.vstack(final_embeddings_Q)\n",
    "\n",
    "        if self.finalMLP:\n",
    "            if self.aggregation == 'max':\n",
    "                result = torch.maximum(final_embeddings_P, final_embeddings_Q)\n",
    "            else:\n",
    "                result = final_embeddings_P + final_embeddings_Q\n",
    "            for layer in self.gamma:\n",
    "                result = self.activation(layer(result))\n",
    "            \n",
    "            return torch.mean(torch.square((result-dists)/dists))\n",
    "        \n",
    "        #return final_embeddings_P, final_embeddings_Q\n",
    "        d_pred = torch.sum(torch.abs(final_embeddings_P - final_embeddings_Q), dim=1)\n",
    "        return torch.mean(torch.abs((d_pred - dists)/dists))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "class PointNetDataloader:\n",
    "    def __init__(self, Ps, Qs, dists, batch_size, shuffle=False):\n",
    "        self.Ps = Ps\n",
    "        self.Qs = Qs\n",
    "        self.total = len(Ps)\n",
    "        self.dists = torch.tensor(dists)\n",
    "        self.shuffle = shuffle\n",
    "        self.batch_size = batch_size\n",
    "\n",
    "        # Output tensors for each element\n",
    "        self.Pblock = torch.cat(self.Ps)\n",
    "        self.Qblock = torch.cat(self.Qs)\n",
    "        self.Pidx = []\n",
    "        pstart = 0\n",
    "        self.Qidx = []\n",
    "        qstart = 0\n",
    "        for i in range(self.total):\n",
    "            psz = len(self.Ps[i])\n",
    "            qsz = len(self.Qs[i])\n",
    "            pend = pstart + psz\n",
    "            qend = qstart + qsz\n",
    "            self.Pidx.append([pstart, pend])\n",
    "            self.Qidx.append([qstart, qend])\n",
    "            pstart = pend\n",
    "            qstart = qend\n",
    "        self.Pidx = torch.tensor(self.Pidx)\n",
    "        self.Qidx = torch.tensor(self.Qidx)\n",
    "        self.current_batch = 0\n",
    "    \n",
    "    def __iter__(self):\n",
    "        return self\n",
    "\n",
    "    def __next__(self):\n",
    "        batch_index = self.current_batch * self.batch_size\n",
    "        if batch_index >= self.total:\n",
    "            self.current_batch = 0\n",
    "            raise StopIteration\n",
    "        Pidx = self.Pidx[batch_index : batch_index + self.batch_size]\n",
    "        pblock_start = Pidx[0][0]\n",
    "        pblock_end = Pidx[-1][1]\n",
    "        Pblock = self.Pblock[pblock_start:pblock_end]\n",
    "\n",
    "        Qidx = self.Qidx[batch_index:batch_index + self.batch_size]\n",
    "        qblock_start = Qidx[0][0]\n",
    "        qblock_end = Qidx[-1][1]\n",
    "        Qblock = self.Qblock[qblock_start:qblock_end]\n",
    "        \n",
    "        self.current_batch += 1\n",
    "        return Pblock, Qblock, Pidx, Qidx, self.dists[batch_index:batch_index + self.batch_size]\n",
    "    \n",
    "     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 600/600 [00:00<00:00, 2753.21it/s]\n"
     ]
    }
   ],
   "source": [
    "# Get ModelNet data\n",
    "Ps = []\n",
    "Qs = []\n",
    "dists = []\n",
    "mean = np.zeros(3)\n",
    "cov = np.eye(3)\n",
    "for i in trange(600):\n",
    "    P = np.random.multivariate_normal(mean, cov, size=10)\n",
    "    Q = np.random.multivariate_normal(mean, cov, size=10)\n",
    "    mat = ot.dist(P, Q, metric='euclidean')\n",
    "    p = (1/len(P)) * np.ones(len(P))\n",
    "    q = (1/len(Q)) * np.ones(len(Q))\n",
    "\n",
    "    dist = ot.emd2(p, q, mat)\n",
    "    Ps.append(torch.tensor(P, dtype=torch.float32))\n",
    "    Qs.append( torch.tensor(Q, dtype=torch.float32))\n",
    "    dists.append(dist)\n",
    "    \n",
    "\n",
    "# nmin = 10\n",
    "# nmax = 100\n",
    "# szs = []\n",
    "# print(dataset.shape)\n",
    "# all_point_sets = []\n",
    "# ref_point_cloud = dataset[2047]\n",
    "# for i in trange(10):\n",
    "#     sz = np.random.randint(low=10, high=100)\n",
    "#     pcd = ref_point_cloud[np.random.randint(low=0, high=2048, size=sz)]\n",
    "#     all_point_sets.append(pcd)\n",
    "    \n",
    "# for i in trange(10):\n",
    "#     for j in range(i+1, 10):\n",
    "#         P = all_point_sets[i]\n",
    "#         Q = all_point_sets[j]\n",
    "#         mat = ot.dist(P, Q, metric='euclidean')\n",
    "#         p = (1/len(P)) * np.ones(len(P))\n",
    "#         q = (1/len(Q)) * np.ones(len(Q))\n",
    "        \n",
    "#         dist = ot.emd2(p, q, mat)\n",
    "#         Ps.append(torch.tensor(P, dtype=torch.float32))\n",
    "#         Qs.append( torch.tensor(Q, dtype=torch.float32))\n",
    "#         dists.append(dist)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load_data = np.load('/data/sam/modelnet/data/train-datasets/pairs-20.npz', allow_pickle=True)\n",
    "# Ps = load_data['P']\n",
    "# Ps = Ps[:10].tolist()\n",
    "# Qs = load_data['Q']\n",
    "# Qs = Qs[:10].tolist()\n",
    "# dists = load_data['dists'][:10]\n",
    "dataloader = PointNetDataloader(Ps, Qs, dists, batch_size = 32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [07:11<00:00,  4.31s/it]\n",
      "  0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "19.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [07:12<00:00,  4.32s/it]\n",
      "  0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "19.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [07:43<00:00,  4.63s/it]\n",
      "  0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "19.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  8%|▊         | 8/100 [00:38<07:09,  4.67s/it]"
     ]
    }
   ],
   "source": [
    "device='cuda:1'\n",
    "start = 0\n",
    "layers = 5\n",
    "h_output_dims = [50, 100, 150, 200]\n",
    "final_h_layers = [20]\n",
    "models = []\n",
    "for j in range(len(final_h_layers)):\n",
    "    final_h_layer = final_h_layers[j]\n",
    "    for i in range(len(h_output_dims)):\n",
    "        h_output_dim = h_output_dims[i]\n",
    "        model = PointNetLearner(3, h_output_dim, 10, num_h_layers=layers, \n",
    "                                num_g_layers=10, final_h_layers=final_h_layer, activation='sigmoid')\n",
    "        model.to(device)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "        losses = []\n",
    "        for i in trange(100):\n",
    "            optimizer.zero_grad()\n",
    "            counter = 0\n",
    "            total_loss = 0\n",
    "            for data in dataloader:\n",
    "                counter += 1\n",
    "                Pblock = data[0].to(device)\n",
    "                Qblock = data[1].to(device)\n",
    "                Pidx = data[2].to(device)\n",
    "                Qidx = data[3].to(device)\n",
    "                d = data[4].to(device)\n",
    "                loss = model(Pblock, Qblock, Pidx, Qidx, d)\n",
    "        #         d_pred = torch.sum(torch.abs(p_embedding - q_embedding), dim=1)\n",
    "        #         loss = torch.mean(torch.abs((d_pred - d)/d))\n",
    "                loss.backward()\n",
    "                #torch.nn.utils.clip_grad_norm_(model.parameters(), 1.0)\n",
    "                optimizer.step()\n",
    "                optimizer.zero_grad()\n",
    "                total_loss += loss.cpu().detach().numpy()\n",
    "\n",
    "            # Loss is average of (l_1 distance between vectors - truth)^2 i.e. relative mean squared error\n",
    "            losses.append(total_loss)\n",
    "\n",
    "        name = \"Width:\" + str(h_output_dim) + \", Depth:\" + str(layers)\n",
    "        plt.plot(np.arange(start, len(losses)), losses[start:], label=name)\n",
    "        plt.legend()\n",
    "        print(losses[-1])\n",
    "        models.append(model)\n",
    "        \n",
    "    # y = model(P, Q)\n",
    "    # loss = torch.square(y - dist)\n",
    "    # loss.backward()\n",
    "    # optimizer.step()\n",
    "    # print(loss)\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 2339.30it/s]\n"
     ]
    }
   ],
   "source": [
    "# Get ModelNet data\n",
    "Ps_test = []\n",
    "Qs_test = []\n",
    "dists_test = []\n",
    "\n",
    "mean = np.zeros(3)\n",
    "cov = np.eye(3)\n",
    "for i in trange(1000):\n",
    "    P = np.random.multivariate_normal(mean, cov, size=20)\n",
    "    Q = np.random.multivariate_normal(mean, cov, size=20)\n",
    "    mat = ot.dist(P, Q, metric='euclidean')\n",
    "    p = (1/len(P)) * np.ones(len(P))\n",
    "    q = (1/len(Q)) * np.ones(len(Q))\n",
    "\n",
    "    dist = ot.emd2(p, q, mat)\n",
    "    Ps_test.append(torch.tensor(P, dtype=torch.float32))\n",
    "    Qs_test.append( torch.tensor(Q, dtype=torch.float32))\n",
    "    dists_test.append(dist)\n",
    "# nmin = 10\n",
    "# nmax = 100\n",
    "# szs = []\n",
    "# print(dataset.shape)\n",
    "# all_point_sets_test = []\n",
    "# ref_point_cloud = dataset[2047]\n",
    "# for i in trange(5):\n",
    "#     sz = np.random.randint(low=10, high=100)\n",
    "#     pcd = ref_point_cloud[np.random.randint(low=0, high=2048, size=sz)]\n",
    "#     all_point_sets_test.append(pcd)\n",
    "    \n",
    "# for i in trange(5):\n",
    "#     for j in range(i+1, 5):\n",
    "#         P = all_point_sets[i]\n",
    "#         Q = all_point_sets[j]\n",
    "#         mat = ot.dist(P, Q, metric='euclidean')\n",
    "#         p = (1/len(P)) * np.ones(len(P))\n",
    "#         q = (1/len(Q)) * np.ones(len(Q))\n",
    "        \n",
    "#         dist = ot.emd2(p, q, mat)\n",
    "#         Ps_test.append(torch.tensor(P, dtype=torch.float32))\n",
    "#         Qs_test.append( torch.tensor(Q, dtype=torch.float32))\n",
    "#         dists_test.append(dist)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MEAN: 0.7282511312799229 R: 0.1882430136645806\n",
      "MEAN: 0.7575372454081016 R: 0.19121936376323934\n",
      "MEAN: 0.5122580180051631 R: -0.03387886548414315\n",
      "MEAN: 0.5777808356476073 R: 0.13051281629849845\n",
      "MEAN: 0.5513106595624794 R: 0.08528136260150539\n",
      "MEAN: 0.8823078945045274 R: 0.1889577202408165\n",
      "MEAN: 1.0915025488061387 R: 0.18761793111617572\n",
      "MEAN: 0.5852302077971823 R: 0.0542728801925069\n",
      "MEAN: 0.520809993513702 R: 0.051361309470088\n",
      "MEAN: 1.0111399535154193 R: 0.19117965637899995\n",
      "MEAN: 0.9926055053368834 R: 0.0014391339231677764\n",
      "MEAN: 0.9505932103429068 R: 0.12215279956866106\n",
      "MEAN: 0.5047073552674983 R: -0.014950647986096174\n",
      "MEAN: 0.5736484951445063 R: -0.15447695566862554\n",
      "MEAN: 0.9852408857008641 R: -0.028249706917039617\n",
      "MEAN: 1.0647164496015233 R: -0.010861026509547261\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": [
    "device='cuda:1'\n",
    "for i in range(len(models)):\n",
    "    model = models[i]\n",
    "    results = []\n",
    "    for i in range(1000):\n",
    "        P = Ps_test[i].to(device)\n",
    "        Q = Qs_test[i].to(device)\n",
    "        dist = dists_test[i]\n",
    "        pvec = model.get_embedding(P)\n",
    "        qvec = model.get_embedding(Q)\n",
    "        res = torch.sum(torch.abs(pvec- qvec)).detach().cpu().numpy()\n",
    "        results.append(abs(res - dist)/dist)\n",
    "        #print(torch.sum(torch.abs(pvec- qvec)), dist)\n",
    "    plt.scatter(dists_test, results)\n",
    "    r = np.corrcoef(dists_test,results)\n",
    "    print(\"MEAN:\", np.mean(results), \"R:\", r[0][1])\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [03:44<00:00,  2.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0014992126089055091\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [03:28<00:00,  2.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0014992013748269528\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [03:50<00:00,  2.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0014992151118349284\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "device='cuda:0'\n",
    "models = []\n",
    "start = 35\n",
    "layers = 10\n",
    "for embedding_size in range(900, 1200, 100):\n",
    "\n",
    "    model = PointNetLearner(2, embedding_size, 10, num_h_layers=layers, num_g_layers=10, activation='sigmoid', final_mlp=True)\n",
    "    model.to(device)\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "    losses = []\n",
    "    for i in trange(500):\n",
    "        optimizer.zero_grad()\n",
    "        counter = 0\n",
    "        total_loss = 0\n",
    "        for data in dataloader:\n",
    "            counter += 1\n",
    "            Pblock = data[0].to(device)\n",
    "            Qblock = data[1].to(device)\n",
    "            Pidx = data[2].to(device)\n",
    "            Qidx = data[3].to(device)\n",
    "            dists = data[4].to(device)\n",
    "            result = model(Pblock, Qblock, Pidx, Qidx, dists)\n",
    "            loss = torch.mean(torch.square(dists - result))\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            total_loss += loss.cpu().detach().numpy()\n",
    "        # Loss is average of (l_1 distance between vectors - truth)^2 i.e. mean squared error\n",
    "        losses.append(total_loss)\n",
    "    print(losses[-1])\n",
    "    \n",
    "    name = \"Width:\" + str(embedding_size) + \", Depth:\" + str(layers)\n",
    "    plt.plot(np.arange(start, len(losses)), losses[start:], label=name)\n",
    "    plt.legend()\n",
    "    models.append(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.13330154\n",
      "0.13330074\n",
      "0.1333017\n"
     ]
    }
   ],
   "source": [
    "P_test = []\n",
    "Q_test = []\n",
    "dists = []\n",
    "for i in range(50):\n",
    "    psz = np.random.randint(low=50, high=100)\n",
    "    qsz = np.random.randint(low=50, high=100)\n",
    "    P = np.random.uniform(size=(psz,  2))\n",
    "    Q = np.random.uniform(size=(qsz, 2))\n",
    "    mat = ot.dist(P, Q, metric='euclidean')\n",
    "    p = (1/psz) * np.ones(psz)\n",
    "    q = (1/qsz) * np.ones(qsz)\n",
    "\n",
    "    dist = ot.emd2(p, q, mat)\n",
    "\n",
    "    P_test.append(torch.tensor(P, dtype=torch.float32))\n",
    "    Q_test.append( torch.tensor(Q, dtype=torch.float32))\n",
    "    dists.append(dist)\n",
    "for model in models:\n",
    "    results = []\n",
    "    for i in range(len(P_test)):\n",
    "        P = P_test[i].to(device)\n",
    "        Q = Q_test[i].to(device)\n",
    "        emd = dists[i]\n",
    "        pred = model.get_full_result(P, Q).detach().cpu().numpy()\n",
    "        results.append(abs(emd - pred)/emd)\n",
    "    print(np.mean(results))\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "local-venv",
   "language": "python",
   "name": "local-venv"
  },
  "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.10"
  },
  "vscode": {
   "interpreter": {
    "hash": "e170b16b4be847ee4d90369ce69d204de6e4e423a0b7a92ee1ad685b3ece43c6"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
