{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4eb9c85c",
   "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\n",
    "from dataset import *\n",
    "from models import *\n",
    "import h5py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4cdc8493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<mpl_toolkits.mplot3d.art3d.Path3DCollection at 0x7fb1ce111760>"
      ]
     },
     "execution_count": 3,
     "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": [
    "# Load testing data\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\n",
    "\n",
    "f = open('/data/sam/modelnet/data/shape_names.txt')\n",
    "lbl_names = f.readlines()\n",
    "\n",
    "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=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "270db5b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:01<00:00, 191.50it/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 272534.37it/s]\n",
      "/home/sam/siamese-metric-learning/dataset.py:121: FutureWarning: The input object of type 'Tensor' is an array-like implementing one of the corresponding protocols (`__array__`, `__array_interface__` or `__array_struct__`); but not a sequence (or 0-D). In the future, this object will be coerced as if it was first converted using `np.array(obj)`. To retain the old behaviour, you have to either modify the type 'Tensor', or assign to an empty array created with `np.empty(correct_shape, dtype=object)`.\n",
      "  Ps = np.array(Ps)[permutation]\n",
      "/home/sam/siamese-metric-learning/dataset.py:121: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray.\n",
      "  Ps = np.array(Ps)[permutation]\n",
      "/home/sam/siamese-metric-learning/dataset.py:122: FutureWarning: The input object of type 'Tensor' is an array-like implementing one of the corresponding protocols (`__array__`, `__array_interface__` or `__array_struct__`); but not a sequence (or 0-D). In the future, this object will be coerced as if it was first converted using `np.array(obj)`. To retain the old behaviour, you have to either modify the type 'Tensor', or assign to an empty array created with `np.empty(correct_shape, dtype=object)`.\n",
      "  Qs = np.array(Qs)[permutation]\n",
      "/home/sam/siamese-metric-learning/dataset.py:122: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray.\n",
      "  Qs = np.array(Qs)[permutation]\n"
     ]
    }
   ],
   "source": [
    "Ps, Qs, dists = build_multiple_item_dataset(dataset, items=[2047, 1040], max_pcd=200, train=False)\n",
    "Ps = Ps.tolist()\n",
    "Qs = Qs.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7c437f0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "P_test = Ps\n",
    "Q_test = Qs\n",
    "dists_test = dists"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2359387a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load non-final mlp models\n",
    "from train import *\n",
    "device = torch.device('cpu')\n",
    "in_dim = 3\n",
    "h_out = [200, 300]\n",
    "h_layers = [6, 8]\n",
    "g_out = [1]\n",
    "g_layers = [1]\n",
    "models = []\n",
    "# (h_out, h_layers, g_out, g_layers)\n",
    "model_params = []\n",
    "for h in h_out:\n",
    "    for hl in h_layers:\n",
    "        for g in g_out:\n",
    "            for gl in g_layers:\n",
    "                model_params.append((h, hl, g, gl))\n",
    "                model_name = generate_name(in_dim, h, g, hl, gl, False, 'sigmoid')\n",
    "                PATH = '/data/sam/modelnet/models/siamese/tr-{modelname}.pt'.format(modelname=model_name)\n",
    "                model = PointNetLearner(in_dim, h, g, num_h_layers=hl, \n",
    "                            num_g_layers=gl,final_h_layers = 10, final_mlp=False, activation='sigmoid')\n",
    "                model.load_state_dict(torch.load(PATH, map_location=device))\n",
    "                models.append(model)\n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5d985c13",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 25%|██▌       | 1/4 [00:04<00:14,  4.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 0 Model parameters: (200, 6, 1, 1) Average error: 0.8849279641788756 std. dev: 2.292551073950091\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 2/4 [00:09<00:09,  4.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 1 Model parameters: (200, 8, 1, 1) Average error: 1.7561552884113671 std. dev: 7.71077489660228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 75%|███████▌  | 3/4 [00:15<00:05,  5.48s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 2 Model parameters: (300, 6, 1, 1) Average error: 3.9710834106230117 std. dev: 17.3819469168155\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4/4 [00:23<00:00,  5.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 3 Model parameters: (300, 8, 1, 1) Average error: 7.425828756513349 std. dev: 31.454274031498272\n",
      "Lowest AVERAGE ERROR: 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "all_results = []\n",
    "average_errors = []\n",
    "for k in trange(len(models)):\n",
    "    model = models[k]\n",
    "    results = []\n",
    "    model.eval()\n",
    "    timing = []\n",
    "    for i in range(len(P_test)):\n",
    "        P = P_test[i].to(device)\n",
    "        Q = Q_test[i].to(device)\n",
    "        dist = dists_test[i]\n",
    "        pvec = model.get_embedding(P).detach().numpy()\n",
    "        qvec = model.get_embedding(Q).detach().numpy()\n",
    "        #print(np.linalg.norm(pvec - qvec, ord=1), dist)\n",
    "        results.append(abs(np.linalg.norm(pvec - qvec, ord=2)- dist)/dist)\n",
    "    all_results.append(results)\n",
    "    avg_error = np.average(results)\n",
    "    std = np.std(results)\n",
    "    average_errors.append(avg_error)\n",
    "    print(\"Model index:\", k ,\"Model parameters:\", model_params[k], \"Average error:\", avg_error, \"std. dev:\", std )\n",
    "print(\"Lowest AVERAGE ERROR:\", np.argmin(average_errors))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0ae22f10",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 1.         -0.11299448]\n",
      " [-0.11299448  1.        ]]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD4CAYAAAD1jb0+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAATCklEQVR4nO3db4xddZ3H8c9nprdhgF2nhJGUgVrCkhpcZBoniNt9oLjYLrhYlNVlWcIDNvWBJLCS2RRjYtlo7KYr+GRjUhciiYig1ApKtttAE6JRYEpbSild/wSkQ6XjwijSUabT7z6494537tz//38z71cymXvPPeee7z1z7+ee+Z3f7xxHhAAA6enrdgEAgMYQ4ACQKAIcABJFgANAoghwAEjUsk6u7Oyzz47Vq1d3cpUAkLy9e/f+JiKGiqd3NMBXr16t8fHxTq4SAJJn++VS02lCAYBEEeAAkCgCHAASRYADQKIIcABIVEd7oTRi574Jbdt1RK9OTevcwQGNrV+jjWuHu10WAHRdTwf4zn0TumPHQU3PzEqSJqamdceOg5JEiANY8nq6CWXbriNz4Z03PTOrbbuOdKkiAOgdPR3gr05N1zUdAJaSng7wcwcH6poOAEtJTwf42Po1Gsj0z5s2kOnX2Po1XaoIAHpHTx/EzB+opBcKACzU0wEuZUOcwAaAhXq6CQUAUB4BDgCJIsABIFEEOAAkigAHgEQR4ACQKAIcABJFgANAoqoGuO3TbD9t+4DtQ7bvzE2/wPZTtn9u+0Hby9tfLgAgr5Y98D9KuiIiLpU0ImmD7csl/bukuyPiLyS9IenmtlUJAFigaoBH1u9zdzO5n5B0haTv5qbfJ2ljOwoEAJRWUxu47X7b+yUdl7Rb0i8kTUXEydwsRyWVPGGJ7U22x22PT05OtqBkAIBUY4BHxGxEjEg6T9Jlkt5d6woiYntEjEbE6NDQUGNVAgAWqKsXSkRMSdoj6QOSBm3nz2Z4nqSJ1pYGAKikll4oQ7YHc7cHJF0p6bCyQX5dbrabJH2/TTUCAEqo5XzgKyXdZ7tf2cB/KCJ+YPsFSd+2/UVJ+yTd08Y6AQBFqgZ4RDwnaW2J6b9Utj0cANAFjMQEgEQR4ACQKAIcABJFgANAoghwAEgUAQ4AiSLAASBRBDgAJIoAB4BEEeAAkCgCHAASRYADQKIIcABIFAEOAIkiwAEgUQQ4ACSKAAeARBHgAJAoAhwAEkWAA0CiCHAASFTVALd9vu09tl+wfcj2rbnpW2xP2N6f+7mq/eUCAPKW1TDPSUm3R8Sztv9M0l7bu3OP3R0R/9G+8gAA5VQN8Ig4JulY7vabtg9LGm53YQCAyupqA7e9WtJaSU/lJt1i+znb99peUWaZTbbHbY9PTk42Vy0AYE7NAW77TEkPS7otIn4n6WuSLpQ0ouwe+ldKLRcR2yNiNCJGh4aGmq8YACCpxgC3nVE2vO+PiB2SFBGvRcRsRJyS9HVJl7WvTABAsVp6oVjSPZIOR8RdBdNXFsx2raTnW18eAKCcWnqhrJN0o6SDtvfnpn1O0vW2RySFpJckfboN9QEAyqilF8qPJLnEQ4+1vhwAQK0YiQkAiSLAASBRBDgAJIoAB4BEEeAAkCgCHAASRYADQKIIcABIFAEOAIkiwAEgUQQ4ACSKAAeARBHgAJAoAhwAEkWAA0CiCHAASBQBDgCJIsABIFEEOAAkigAHgEQR4ACQqKoBbvt823tsv2D7kO1bc9PPsr3b9s9yv1e0v1wAQF4te+AnJd0eERdLulzSZ2xfLGmzpMcj4iJJj+fuAwA6pGqAR8SxiHg2d/tNSYclDUv6mKT7crPdJ2ljm2oEAJRQVxu47dWS1kp6StI5EXEs99CvJZ1TZplNtsdtj09OTjZTKwCgQM0BbvtMSQ9Lui0iflf4WESEpCi1XERsj4jRiBgdGhpqqlgAwJ/UFOC2M8qG9/0RsSM3+TXbK3OPr5R0vD0lAgBKqaUXiiXdI+lwRNxV8NAjkm7K3b5J0vdbXx4AoJxlNcyzTtKNkg7a3p+b9jlJWyU9ZPtmSS9L+mRbKgQAlFQ1wCPiR5Jc5uEPt7YcAECtGIkJAIkiwAEgUQQ4ACSKAAeARBHgAJAoAhwAEkWAA0CiCHAASBQBDgCJIsABIFEEOAAkigAHgEQR4ACQKAIcABJFgANAoghwAEgUAQ4AiSLAASBRBDgAJIoAB4BEEeAAkCgCHAASVTXAbd9r+7jt5wumbbE9YXt/7ueq9pYJAChWyx74NyRtKDH97ogYyf081tqyAADVVA3wiHhS0usdqAUAUIdm2sBvsf1crollRbmZbG+yPW57fHJysonVAQAKNRrgX5N0oaQRScckfaXcjBGxPSJGI2J0aGiowdUBAIo1FOAR8VpEzEbEKUlfl3RZa8sCAFTTUIDbXllw91pJz5ebFwDQHsuqzWD7AUkflHS27aOSviDpg7ZHJIWklyR9un0lAgBKqRrgEXF9icn3tKEWAEAdGIkJAIkiwAEgUQQ4ACSKAAeARBHgAJAoAhwAEkWAA0CiCHAASBQBDgCJIsABIFEEOAAkigAHgEQR4ACQKAIcABJFgANAoghwAEgUAQ4AiSLAASBRBDgAJIoAB4BEEeAAkKiqAW77XtvHbT9fMO0s27tt/yz3e0V7ywQAFKtlD/wbkjYUTdss6fGIuEjS47n7AIAOqhrgEfGkpNeLJn9M0n252/dJ2tjasgAA1TTaBn5ORBzL3f61pHPKzWh7k+1x2+OTk5MNrg4AUKzpg5gREZKiwuPbI2I0IkaHhoaaXR0AIKfRAH/N9kpJyv0+3rqSAAC1aDTAH5F0U+72TZK+35pyAAC1qqUb4QOSfiJpje2jtm+WtFXSlbZ/JulvcvcBAB20rNoMEXF9mYc+3OJaAAB1YCQmACSKAAeARBHgAJAoAhwAEkWAA0CiCHAASBQBDgCJIsABIFEEOAAkigAHgEQR4ACQKAIcABJFgANAoghwAEgUAQ4AiSLAASBRBDgAJIoAB4BEEeAAkCgCHAASRYADQKKqXpW+EtsvSXpT0qykkxEx2oqiAADVNRXgOR+KiN+04HkAAHWgCQUAEtVsgIek/7G91/amVhQEAKhNs00ofx0RE7bfKWm37Rcj4snCGXLBvkmSVq1a1eTqAAB5Te2BR8RE7vdxSd+TdFmJebZHxGhEjA4NDTWzOgBAgYb3wG2fIakvIt7M3f6IpH9rWWVV7Nw3oW27jujVqWmdOzigsfVrtHHtcKdWDwBd10wTyjmSvmc7/zzfioj/bklVVezcN6E7dhzU9MysJGlialp37DgoSYQ4gCWj4QCPiF9KurSFtdRs264jc+GdNz0zq227jhDgAJaMJLsRvjo1Xdd0AFiMkgzwcwcH6poOAItRkgE+tn6NMv2eNy3Tb42tX9OligCg85IMcEnZIUSV7gPAIteKc6F03LZdRzRzan5iz5wK3fnoIboWAlgykgzwcgcr3zgxozdOzEiiayGAxS/JJpRaD1bmuxYCwGKUZICPrV+jgUx/TfPStRDAYpVkE0q+SaSwvfutP57U1PTMgnnfMZDpdHkA0BHJ7YHv3DehdVuf0L88uF+SdPenRvTjzVdoyzXvUabPC+Z/6+2T2rlvosNVAkD7JRXg+XOgTExNK/SnA5U7901o49phnXnawn8oZmaDdnAAi1JSTSjVzoEydWJhE4q0sB2cMxkCWAyS2gOvdg6UWobYV9qLB4CUJBXg1QK6VO+UgUz/vCH2lfbiASAlSQV4tYDeuHZYX/74JRoeHJAlDQ8O6Msfv2Re80i5vfiJqWmt2/qELtj8Q63b+gR75AB6niM6dxKR0dHRGB8fb+o5mm2/Xrf1CU3U2Dd8xekZfeHv3kP7OICusr03IkaLpyd1EFPK7mU3E6hj69fMu5pPJW+cmNHYdw/MrbfSl0fxYx9695D2vDipialp9duajVjwe7iGL6Cd+ya05ZFDc33cV5ye0dXvXakfHDg2N+2M5f3K9Pfpt9MzJeu689FDc6cYGBzIaMs187+UStVe+Pz55T566Uo9vPeopmdOLaiz8Muu8PkGT8/oDzOzc8vk55NU8xdxqe0+/vLreuCpV+a25/XvP19f3HhJ1eWqrbfc37jc3zf/GiNUcvtXe95Kf4P88/fCgfZS78N27Nwsxg4G7XxNye2BV1JrwL5jICNbmjqR/cBV2yM/Y3m/vnTtJfrsQ/tVeA6tPkt3fXJEkmr+Uig2kOlf0MxT+Ho+++B+LYzL5p2e6dP0zCmdlvvdKpk+qdmns7InlxzOBdmDT78y7+Rl+ceLXfTOM3Ti7VNzofr7P5yct1ymz5KzXUvzCrd/8aX68sssX9ant96u/W9rSTdcvmruC+XzOw/qmz/91bx5Mn3Wtr+/tOx6i1V6n5TTyBdYKTd8/Sf68S9eXzA9029tu+7SloVRqe1Q7XX3euA38ppKKbcHvmgCfOe+CY1998C8D2f+DSYtDNj8RpSk23KDghqV36Nu1PDggH68+QpJ89+QEmfJ7YT8f0K3P3Sgqb9jsa9+akRS+ffX4EBG+7/wkZqb9QrfJ9WU+zKq9AVWSqkvn0Zrqqbcdii3jlaFYzvV+5rKWTRNKOXc+eiheW9MKftGvfPRQzp9+bKSPU9a9YFt9jnyf+Ba9sTQevmupK0Mb0ka+85+vfPPy594Ld8cUev5eiampucGrVVTqrdV8SmYperXkn3gqVeq1tQq9V4qMYVr47b78o9J9UKp5I0yg3jeODFTdmO1+gPbqH5nTwFQ6g2J9uu327LdZ07VFnD1XAqw1jEL9QREpXmrfUby791WqPdSiSlcG7fdl39cNAFeSa9fKzP/IemlN95SMZDpb+sXeaWAW3F69kRrY+vXqNYYrHXMQj3v+UrzVgvoVm67WsZxFErh2rj1vqZ6NRXgtjfYPmL757Y3t6SiBg2WOevg4ECmrtPPdsPgQEbrtj5Be3cJpU5Q1qzicQLDbfzAz0YsuH6rlD0Anu+Ns3HtsG64fFXNIV7LF32p93ymzwtqqRYm17///IrraeW2q2UcR6F2h2Mr1Pua6tVwG7jtfkn/KelKSUclPWP7kYh4oSWV1WnLNe/R2HcOLOh1UNhlrtUHqVoh02e99XbpU+EuRn2WSjTFzlPYCyXfZbDSgbT8Mn914Vl66f+mKzZblDt4VOnYQ3E9kuZ1zawkv0y1rpxf3HiJRt911rweFSfePllyHbXsYZY65XIjvVDyPWnu/+mvFuxgtCMs6+kmXO419kr7d16zXZ8rabgXiu0PSNoSEetz9++QpIj4crllutmNUJIu2PzDntrLHa7wIe115bryVVvm7k+NlO07X+nD9/mdBxeESHGwFj5vcY8kaX7XvWKVupk22tWu2R4RvdbLote77C1mLe9GaPs6SRsi4p9z92+U9P6IuKVovk2SNknSqlWr3vfyyy83tL5WqGcUZie8tPXqtn2pNBKwtSyb7+Msqexe8boLz9Kzv/rtvOAp7hvdiHoCpJYBTK3WjoAjNCF1McALtXsPvJp2d9MrDLdS/3IWqtYHuJm+5QOZfn3ifcMLRlMunK9PJ0/Fgn7Bn3jfsB7eO7FgOxWPvivuI1wY0gQP0DrtCPCea0KpRT5YSoVmpVF3+bbbFUVDw/PTS/0bX2k9lUbhVQrRM5b361TEvKHpV793Zdlh14V1lBrCX+vQcQIY6J52BPgySf8r6cOSJiQ9I+kfI+JQuWV6IcALdSq86j0PBiEKoFBbhtLbvkrSVyX1S7o3Ir5Uaf5eC3AASEFbhtJHxGOSHmvmOQAAjVkSIzEBYDEiwAEgUQQ4ACSKAAeARHX0gg62JyXVOxTzbEm/aUM5KWEbsA0ktoG0dLfBuyJiqHhiRwO8EbbHS3WfWUrYBmwDiW0gsQ2K0YQCAIkiwAEgUSkE+PZuF9AD2AZsA4ltILEN5un5NnAAQGkp7IEDAEogwAEgUT0b4L10weRusX2v7eO2n+92Ld1g+3zbe2y/YPuQ7Vu7XVOn2T7N9tO2D+S2wZ3drqlbbPfb3mf7B92upVf0ZIAXXDD5byVdLOl62xd3t6qu+IakDd0uootOSro9Ii6WdLmkzyzB98EfJV0REZdKGpG0wfbl3S2pa26VdLjbRfSSngxwSZdJ+nlE/DIi3pb0bUkf63JNHRcRT0p6veqMi1REHIuIZ3O331T2w7ukrmgRWb/P3c3kfpZczwPb50m6WtJ/dbuWXtKrAT4s6ZWC+0e1xD64mM/2aklrJT3V5VI6Ltd0sF/ScUm7I2LJbQNlLxzzr5JOdbmOntKrAQ7MsX2mpIcl3RYRv+t2PZ0WEbMRMSLpPEmX2f7LLpfUUbY/Kul4ROztdi29plcDfELS+QX3z8tNwxJjO6NseN8fETu6XU83RcSUpD1aesdF1km6xvZLyjanXmH7m90tqTf0aoA/I+ki2xfYXi7pHyQ90uWa0GG2LekeSYcj4q5u19MNtodsD+ZuD0i6UtKLXS2qwyLijog4LyJWK5sFT0TEP3W5rJ7QkwEeEScl3SJpl7IHrh6qdLX7xcr2A5J+ImmN7aO2b+52TR22TtKNyu5x7c/9XNXtojpspaQ9tp9Tdsdmd0TQjQ6SGEoPAMnqyT1wAEB1BDgAJIoAB4BEEeAAkCgCHAASRYADQKIIcABI1P8DDx9kYZyzKhYAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "best_index = 0\n",
    "best_result = all_results[best_index]\n",
    "plt.scatter(dists_test, best_result)\n",
    "r = np.corrcoef(dists_test,best_result)\n",
    "print(r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f7718e89",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load final mlp models\n",
    "from train import *\n",
    "device = torch.device('cpu')\n",
    "in_dim = 3\n",
    "h_out = [60]\n",
    "h_layers = [6, 8, 10]\n",
    "g_out = [10, 20, 30]\n",
    "g_layers = [2, 3]\n",
    "models = []\n",
    "# (h_out, h_layers, g_out, g_layers)\n",
    "model_params = []\n",
    "for h in h_out:\n",
    "    for hl in h_layers:\n",
    "        for g in g_out:\n",
    "            for gl in g_layers:\n",
    "                model_params.append((h, hl, g, gl))\n",
    "                model_name = generate_name(in_dim, h, g, hl, gl, True, 'sigmoid')\n",
    "                PATH = '/data/sam/modelnet/models/mlp/{modelname}'.format(modelname=model_name)\n",
    "                model = PointNetLearner(in_dim, h, g, num_h_layers=hl, \n",
    "                            num_g_layers=gl, final_mlp=False, activation='sigmoid')\n",
    "                model.load_state_dict(torch.load(PATH, map_location=device))\n",
    "                models.append(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "5b27676c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 1/18 [00:09<02:43,  9.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 0 Model parameters: (60, 6, 10, 2) Avg. error: 0.6900224 std: 1.3571558\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 11%|█         | 2/18 [00:19<02:34,  9.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 1 Model parameters: (60, 6, 10, 3) Avg. error: 0.63765043 std: 0.5054855\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 17%|█▋        | 3/18 [00:27<02:17,  9.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 2 Model parameters: (60, 6, 20, 2) Avg. error: 0.63998914 std: 0.49725768\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 22%|██▏       | 4/18 [00:34<01:53,  8.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 3 Model parameters: (60, 6, 20, 3) Avg. error: 0.6231179 std: 0.5707178\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 28%|██▊       | 5/18 [00:42<01:44,  8.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 4 Model parameters: (60, 6, 30, 2) Avg. error: 0.62086695 std: 0.5867084\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 33%|███▎      | 6/18 [00:46<01:21,  6.82s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 5 Model parameters: (60, 6, 30, 3) Avg. error: 0.62463033 std: 0.5626735\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|███▉      | 7/18 [00:57<01:27,  7.95s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 6 Model parameters: (60, 8, 10, 2) Avg. error: 0.60873526 std: 0.9490615\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 44%|████▍     | 8/18 [01:07<01:27,  8.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 7 Model parameters: (60, 8, 10, 3) Avg. error: 0.6044754 std: 0.8002342\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|█████     | 9/18 [01:18<01:24,  9.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 8 Model parameters: (60, 8, 20, 2) Avg. error: 0.61210966 std: 0.9853138\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 56%|█████▌    | 10/18 [01:32<01:26, 10.81s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 9 Model parameters: (60, 8, 20, 3) Avg. error: 0.6210037 std: 0.5826899\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 61%|██████    | 11/18 [01:44<01:18, 11.22s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 10 Model parameters: (60, 8, 30, 2) Avg. error: 0.634832 std: 0.51654935\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 67%|██████▋   | 12/18 [01:55<01:06, 11.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 11 Model parameters: (60, 8, 30, 3) Avg. error: 0.6230186 std: 0.5706797\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 72%|███████▏  | 13/18 [02:09<01:00, 12.14s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 12 Model parameters: (60, 10, 10, 2) Avg. error: 0.61802286 std: 0.60364836\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 78%|███████▊  | 14/18 [02:26<00:53, 13.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 13 Model parameters: (60, 10, 10, 3) Avg. error: 0.6062986 std: 0.7291748\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 83%|████████▎ | 15/18 [02:37<00:38, 12.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 14 Model parameters: (60, 10, 20, 2) Avg. error: 0.6524127 std: 1.2086781\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 89%|████████▉ | 16/18 [02:46<00:23, 11.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 15 Model parameters: (60, 10, 20, 3) Avg. error: 0.6342294 std: 0.5190567\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 94%|█████████▍| 17/18 [03:02<00:12, 12.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 16 Model parameters: (60, 10, 30, 2) Avg. error: 0.6171936 std: 0.6100507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 18/18 [03:15<00:00, 10.87s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model index: 17 Model parameters: (60, 10, 30, 3) Avg. error: 0.61624074 std: 0.6163368\n",
      "Lowest AVERAGE ERROR: 7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "all_results = []\n",
    "average_errors = []\n",
    "result_dictionary = {}\n",
    "for params in model_params:\n",
    "    hwidth = params[0]\n",
    "    hdepth = params[1]\n",
    "    result_dictionary[(hwidth, hdepth)] = []\n",
    "for k in trange(len(models)):\n",
    "    model = models[k]\n",
    "    results = []\n",
    "    model.eval()\n",
    "    for i in range(len(P_test)):\n",
    "        P = P_test[i].to(device)\n",
    "        Q = Q_test[i].to(device)\n",
    "        dist = dists_test[i]\n",
    "        estimate = model.get_full_result(P, Q).detach().cpu().numpy()\n",
    "        results.append(abs((1-estimate)- dist)/dist)\n",
    "    all_results.append(results)\n",
    "    avg_error = np.average(results)\n",
    "    std = np.std(results)\n",
    "    average_errors.append(avg_error)\n",
    "    result_dictionary[(model_params[k][0], model_params[k][1])].append((model_params[k][2], model_params[k][3], avg_error, std))\n",
    "    print(\"Model index:\", k ,\"Model parameters:\", model_params[k], \"Avg. error:\", avg_error, \"std:\", std)\n",
    "print(\"Lowest AVERAGE ERROR:\", np.argmin(average_errors))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "46892dcd",
   "metadata": {},
   "outputs": [],
   "source": [
    "mlp_testerr = all_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45310e9b",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
