{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning: To use the exr data format, please install the OpenEXR package following the instructions detailed in the README at github.com/tensorflow/graphics.\n",
      "Warning: To use the threejs_vizualization, please install the colabtools package following the instructions detailed in the README at github.com/tensorflow/graphics.\n"
     ]
    }
   ],
   "source": [
    "# System imports\n",
    "import sys\n",
    "import os\n",
    "sys.path.append(\"../\")\n",
    "DIR_PATH = os.getcwd()  \n",
    "PROJECT_PATH = os.path.dirname(DIR_PATH)  \n",
    "sys.path.append(PROJECT_PATH)\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.linalg\n",
    "import numpy as np\n",
    "import tensorflow as tf\n",
    "\n",
    "from modules.utils import plotting\n",
    "from data import data_loader\n",
    "from modules.utils.experiment_control.experiment import Experiment\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Re-load previously trained model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\t----- TIMESTAMP NUMBER 0 : 2021-02-02-04-13-47_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 1 : 2021-02-02-04-43-33_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 2 : 2021-02-02-05-13-27_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 3 : 2021-02-02-05-43-22_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 4 : 2021-02-02-06-13-21_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 5 : 2021-02-03-08-05-26_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 6 : 2021-02-03-08-32-54_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 7 : 2021-02-03-09-05-51_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 8 : 2021-02-03-09-40-37_ -----\n",
      "\n",
      "\n",
      "\t----- TIMESTAMP NUMBER 9 : 2021-02-03-10-15-29_ -----\n",
      "\n",
      "    data arrow_size n_hues n_rotations n_labels dist_weight separate_encoders  \\\n",
      "0  arrow         64     64          64        0         100             False   \n",
      "1  arrow         64     64          64        0         100             False   \n",
      "2  arrow         64     64          64        0         100             False   \n",
      "3  arrow         64     64          64        0         100             False   \n",
      "4  arrow         64     64          64        0         100             False   \n",
      "5  arrow         64     64          64        0         100             False   \n",
      "6  arrow         64     64          64        0         100             False   \n",
      "7  arrow         64     64          64        0         100             False   \n",
      "8  arrow         64     64          64        0         100             False   \n",
      "9  arrow         64     64          64        0         100             False   \n",
      "\n",
      "  stop_gradient    log_t_limit architectures epochs batch_size  \\\n",
      "0         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "1         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "2         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "3         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "4         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "5         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "6         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "7         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "8         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "9         False  (-10.0, -9.0)       dis_lib   1500        128   \n",
      "\n",
      "              timestamp  \n",
      "0  2021-02-02-04-13-47_  \n",
      "1  2021-02-02-04-43-33_  \n",
      "2  2021-02-02-05-13-27_  \n",
      "3  2021-02-02-05-43-22_  \n",
      "4  2021-02-02-06-13-21_  \n",
      "5  2021-02-03-08-05-26_  \n",
      "6  2021-02-03-08-32-54_  \n",
      "7  2021-02-03-09-05-51_  \n",
      "8  2021-02-03-09-40-37_  \n",
      "9  2021-02-03-10-15-29_  \n",
      "\n",
      " Selected experiment number 0\n",
      "Min log t limit -10.0 Max log t limit -9.0\n",
      "Min log t limit -10.0 Max log t limit -9.0\n",
      "Model: \"functional_23\"\n",
      "__________________________________________________________________________________________________\n",
      "Layer (type)                    Output Shape         Param #     Connected to                     \n",
      "==================================================================================================\n",
      "input_10 (InputLayer)           [(None, 1, 64, 64, 3 0                                            \n",
      "__________________________________________________________________________________________________\n",
      "h_enc_1way_circle0 (TimeDistrib (None, 1, 256)       378816      input_10[0][0]                   \n",
      "__________________________________________________________________________________________________\n",
      "h_enc_1way_circle1 (TimeDistrib (None, 1, 256)       378816      input_10[0][0]                   \n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_mu_euclidean_cir (None, 1, 2)         514         h_enc_1way_circle0[0][0]         \n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_mu_euclidean_cir (None, 1, 2)         514         h_enc_1way_circle1[0][0]         \n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_mu_circle0 (Lamb (None, 1, 2)         0           hyperspherical_mu_euclidean_circl\n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_log_t_circle0 (D (None, 1, 1)         257         h_enc_1way_circle0[0][0]         \n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_mu_circle1 (Lamb (None, 1, 2)         0           hyperspherical_mu_euclidean_circl\n",
      "__________________________________________________________________________________________________\n",
      "hyperspherical_log_t_circle1 (D (None, 1, 1)         257         h_enc_1way_circle1[0][0]         \n",
      "__________________________________________________________________________________________________\n",
      "sample_circle0 (Lambda)         (None, 1, 2)         0           hyperspherical_mu_euclidean_circl\n",
      "                                                                 hyperspherical_mu_circle0[0][0]  \n",
      "                                                                 hyperspherical_log_t_circle0[0][0\n",
      "__________________________________________________________________________________________________\n",
      "sample_circle1 (Lambda)         (None, 1, 2)         0           hyperspherical_mu_euclidean_circl\n",
      "                                                                 hyperspherical_mu_circle1[0][0]  \n",
      "                                                                 hyperspherical_log_t_circle1[0][0\n",
      "__________________________________________________________________________________________________\n",
      "functional_21 (Functional)      (None, 1, 64, 64, 3) 380803      sample_circle0[0][0]             \n",
      "                                                                 sample_circle1[0][0]             \n",
      "==================================================================================================\n",
      "Total params: 761,161\n",
      "Trainable params: 761,161\n",
      "Non-trainable params: 0\n",
      "__________________________________________________________________________________________________\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<tensorflow.python.keras.engine.functional.Functional at 0x247034793c8>,\n",
       " <tensorflow.python.keras.engine.functional.Functional at 0x24703002648>,\n",
       " <tensorflow.python.keras.engine.functional.Functional at 0x247030a8ec8>,\n",
       " <tensorflow.python.keras.engine.functional.Functional at 0x247030b1a08>]"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "path = \"C:\\\\Users\\\\s161416\\\\OneDrive - TU Eindhoven\\\\dis_e_results\\\\lsbd\"\n",
    "n_labels_list = [0, 512, 768, 1024, 1280, 1536, 2048]\n",
    "dataset = \"arrow\"\n",
    "selected_labels = 0\n",
    "repetition = 0\n",
    "# Name of saved experiment\n",
    "experiment_name = dataset+\"_dis_lib_\"+str(selected_labels)\n",
    "# Create experiment\n",
    "exp = Experiment(path, experiment_name)\n",
    "# Select repetition from experiment and load\n",
    "exp.select_target_previous_experiment(repetition)\n",
    "exp.load_parameters_name()\n",
    "# Quick fix\n",
    "exp.model_parameters[list(exp.model_parameters.keys())[0]].update({\"input_shape\":(64 ,64 , 3), \"num_circles\":2})\\\n",
    "# Re-create model\n",
    "model_class = exp.recreate_model() \n",
    "model_u = model_class.setup_model(1)\n",
    "[exp.load_weights(model_u[key], key) for key in model_u.keys()]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "if dataset == \"arrow\":\n",
    "    dataset_params = {\n",
    "        \"data\": \"arrow\",\n",
    "        \"arrow_size\": 64,\n",
    "        \"n_hues\": 64,\n",
    "        \"n_rotations\": 64,\n",
    "    }\n",
    "elif dataset == \"pixel4\":\n",
    "    dataset_params = {\n",
    "        \"data\": \"pixel\",\n",
    "        \"height\": 64,\n",
    "        \"width\": 64,\n",
    "        \"step_size_vert\": 1,\n",
    "        \"step_size_hor\": 1,\n",
    "        \"square_size\": 4\n",
    "    }\n",
    "elif dataset == \"modelnet\":\n",
    "    dataset_params = {\n",
    "        \"dataset_filename\": \"modelnet_color_single_64_64.h5\",\n",
    "        \"data\": \"modelnet_colors\"\n",
    "    }\n",
    "else:\n",
    "    dataset_params = None\n",
    "dataset_class = data_loader.load_factor_data(root_path=PROJECT_PATH, **dataset_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "reconstructions = model_u['full_model'].predict(np.expand_dims(dataset_class.images[:,0], 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x247062db0c8>"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_image = 0\n",
    "fig, axes = plt.subplots(1,2)\n",
    "axes[0].set_title(\"Original\")\n",
    "axes[0].imshow(dataset_class.images[num_image, 0])\n",
    "axes[1].set_title(\"Reconstruction\")\n",
    "axes[1].imshow(reconstructions[num_image, 0])\n"
   ]
  }
 ],
 "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
