{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using TensorFlow backend.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from utils import *\n",
    "\n",
    "import keras.utils\n",
    "from keras import backend as K\n",
    "from keras.datasets import mnist\n",
    "from keras.models import save_model,load_model,Model\n",
    "from keras.optimizers import Adam, RMSprop\n",
    "from keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from keras.models import save_model\n",
    "from tempfile import TemporaryFile\n",
    "import tensorflow as tf\n",
    "import pickle\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython import display\n",
    "import time\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import umap\n",
    "from copy import deepcopy\n",
    "\n",
    "import numpy as np\n",
    "from utils import *\n",
    "\n",
    "import keras.utils\n",
    "from keras import backend as K\n",
    "from keras.datasets import mnist\n",
    "from keras.models import save_model,load_model,Model\n",
    "from keras.optimizers import Adam, RMSprop\n",
    "from keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from keras.models import save_model\n",
    "from tempfile import TemporaryFile\n",
    "import tensorflow as tf\n",
    "import pickle\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython import display\n",
    "import time\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import umap\n",
    "import scipy.io as sio\n",
    "from copy import deepcopy\n",
    "from keras.datasets import fashion_mnist\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\"\n",
    "from keras import backend as K\n",
    "config = tf.ConfigProto()\n",
    "config.gpu_options.allow_growth = True\n",
    "K.tensorflow_backend.set_session(tf.Session(config=config))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ! pip install umap-learn\n",
    "# ! pip install  keras\n",
    "# ! pip install matplotlib\n",
    "# ! pip install np_utils\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=64 # This is the dimension of intermediate latent variable \n",
    "epochs = 50   * 100\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=100 \n",
    "nofprojections = 40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MgGMMfit(encoderX,dataX_train,labelX_train,nofclasses):\n",
    "    gmmX = encoderX.predict(dataX_train)\n",
    "    \n",
    "    gmmY = np.argmax(labelX_train,axis=1)\n",
    "    yper = classifier.predict(encoderX.predict(dataX_train))\n",
    "    yper = np.argmax(yper, axis=1)\n",
    "    gmmX = gmmX[gmmY==yper,:]\n",
    "    gmmY = gmmY[gmmY==yper]\n",
    "    gmmModel =  GaussianMixture(n_components=nofclasses,covariance_type='full', init_params='kmeans', tol=1e-04) \n",
    "    gmmModel.fit(gmmX,gmmY)\n",
    "    gmmModelSingle =  GaussianMixture(n_components=1,covariance_type='full') \n",
    "\n",
    "    for i in range(nofclasses):\n",
    "        a= gmmX[gmmY==i,:]\n",
    "        gmmModelSingle.fit(a)\n",
    "        gmmModel.weights_[i] = 1/float(nofclasses)#gmmY[gmmY==i].shape[0]/gmmY.shape[0]\n",
    "        gmmModel.covariances_[i] = gmmModelSingle.covariances_[0]\n",
    "        gmmModel.means_[i] = gmmModelSingle.means_[0]\n",
    "\n",
    "        gmmModel.precisions_cholesky_[i] = gmmModelSingle.precisions_cholesky_[0]\n",
    "        gmmModel.precisions_[i] = gmmModelSingle.precisions_[0]\n",
    "        \n",
    "    return gmmModel\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Read Fashion-MNIST\n",
    "(x_train, y_train), (x_test, y_test) = fashion_mnist.load_data()\n",
    "dataX_train=np.expand_dims(x_train.astype('float32')/255.,3)\n",
    "dataX_test=np.expand_dims(x_test.astype('float32')/255.,3)\n",
    "\n",
    "labelX_train = keras.utils.to_categorical(y_train, nofclasses)\n",
    "labelX_test = keras.utils.to_categorical(y_test, nofclasses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "numdataTrain = labelX_train.shape[0]\n",
    "numdataTest = labelX_test.shape[0]\n",
    "\n",
    "dataX_train1 = np.reshape(dataX_train,[numdataTrain,28*28]) \n",
    "dataX_test1 = np.reshape(dataX_test,[numdataTest,28*28]) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fc0582669b0>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAR9UlEQVR4nO3dbWyd5XkH8P//HB/HcRI3CXkhS0IJaaANaAvFSkdLGStqBdG0wF4Y+VClE5qrrWhF6odS1qnZpEls6ov6YUrljqhpRam6ASIfUNcs6hTY2gyHpXmlSwgBYvwCCSzOi+Pzcu2DHzoDfq77cJ7zZt//nxTZPpcfn9tP/Pfjc65z3zfNDCIy++VaPQARaQ6FXSQSCrtIJBR2kUgo7CKR6GjmnXVyjnVhXjPvcmYg3bL1zPUPL1Zqv+tQMybUrQmM3f3StR9aHWdsvDzhHmqlcr1H0xTjuIAJuzztN54p7CTvAPBtAHkA/2RmD3uf34V5+Bhvz3KX7SmX9+sV/weHhU63funWDW597uAF//69+y4GxhYIu2UJeyFw3jL+3Wn59C+Qf3HQPbZ85my2O2+RfbYntVbz6SSZB/CPAO4EsB7AFpLra/16ItJYWX53bgRwwsxOmtkEgB8B2FyfYYlIvWUJ+0oAr075+HRy2zuQ7CM5QHKgiMsZ7k5Esmj4s/Fm1m9mvWbWW8CcRt+diKTIEvZBAKunfLwquU1E2lCWsD8HYB3JNSQ7AdwLYFd9hiUi9VZz683MSiTvB/CvmGy97TCzI3Ub2QySm9vl1isX/NbYS9tucuu/+tPt/vHF86m1NYX57rEz2bGJi259aT69bfjE+XXusY9/ZFlNY2pnmfrsZvY0gKfrNBYRaSC9XFYkEgq7SCQUdpFIKOwikVDYRSKhsItEoqnz2WerUB89ZO3HX3brr5TS++gAcLy4KLV2suTPdS9bY3/fVzJcT8rwp8+Wrdutv1oqptY6WappTDOZruwikVDYRSKhsItEQmEXiYTCLhIJhV0kEmq9VYkd6afKStnaOH2r9rr14bK/wo/X3upEYElk+q25PPzVZSfMXyH2QiV97Ffk/ZZi6GvnA+tgny2nT+/9XM+oe+w/r7nZrZde8tul7UhXdpFIKOwikVDYRSKhsItEQmEXiYTCLhIJhV0kEuqzN8H472106x/v+g+3fmiix61359K31SoGetUF+n340PGdgeMLzlRSrwaEp7gGXgKAM06fHXjTPfZ432+49TVfUZ9dRNqUwi4SCYVdJBIKu0gkFHaRSCjsIpFQ2EUioT57lawSaOo6XvnDQC860E8umv/fFJpz7qkElpIOLjUdmg/v1LsCffbQ910MXKsW5C6l1kLLc5dWpr92YabKFHaSpwCMASgDKJlZbz0GJSL1V48r+++a2Rt1+Doi0kB6zC4SiaxhNwA/JbmfZN90n0Cyj+QAyYEiZt/jIJGZIuuf8beY2SDJZQB2k3zBzN6xeqKZ9QPoB4AeLq79mSQRySTTld3MBpO3owCeBOBP7xKRlqk57CTnkVzw9vsAPgPgcL0GJiL1leXP+OUAniT59tf5oZn9pC6jakeVwPrrjr+5+Sm3frbi96q9tdcBoJxL79MXMq4bH9xyOfDAzHsNQGi+ei4wttB9e3PtT5W8ue7A+quG3Hr6ZtDtq+awm9lJAL9Vx7GISAOp9SYSCYVdJBIKu0gkFHaRSCjsIpHQFNcmWNYx5taHy91uvSs34deZ3ggKTlFtMG9soem1ITkEWnOOi4F25nULRtz6THxBia7sIpFQ2EUiobCLREJhF4mEwi4SCYVdJBIKu0gk1Gevg9KnbnLr1xWedesnSx9w6+OVTre+sONiam3M5rrHhqaJhnrZ3lLRgD9NNTyF1d8uugi/Xs5wLQttVY0MPf5W0ZVdJBIKu0gkFHaRSCjsIpFQ2EUiobCLREJhF4mE+ux1MPg7/tzoxXm/Z3u0WHDrofns45Z+fJY530B4KenOwFLVobp734H57sFlsh3eds4AcGJsaeArvFbzfbeKruwikVDYRSKhsItEQmEXiYTCLhIJhV0kEgq7SCTUZ6+DBTe94daL1ti5z1nWhg/10b0ePgAszKXPpQeABc5rBC6Y/+PnrTlfjXWdw6m1jXP87+vYsVVu/drZ2GcnuYPkKMnDU25bTHI3yePJ20WNHaaIZFXNJeF7AO54120PAthjZusA7Ek+FpE2Fgy7me0FcPZdN28GsDN5fyeAu+o8LhGps1ofsy83s6Hk/WEAy9M+kWQfgD4A6IK/p5mINE7mZ+PNzOAsW2hm/WbWa2a9BfgTRkSkcWoN+wjJFQCQvB2t35BEpBFqDfsuAFuT97cCeKo+wxGRRgk+Zif5GIDbACwheRrA1wA8DODHJO8D8DKAexo5yHZ391W/dOsXzV+cfazsr+2+MO/3srOYCKyPXmDJrXcF6mUwtRaarx5aV76bl9369pFPpdZeX/Kce+yig6F142eeYNjNbEtK6fY6j0VEGkgvlxWJhMIuEgmFXSQSCrtIJBR2kUhoimsdbO454NYvVPzfqV05fypn1m2TPcWK/yPwya70aaIA0JPrcuuHJtK/N68tBwAItOZCxz/z7PWptb//k5+4xwb+S2YkXdlFIqGwi0RCYReJhMIuEgmFXSQSCrtIJBR2kUioz14H13f6U1T3X/a3XA5NI82iGFiueWnHObf+zPgSt37w0lVu/atLXkit/fulwLUmcF4K9Lds3v3HX0+tLcvPd49dcsA/L/6k5fakK7tIJBR2kUgo7CKRUNhFIqGwi0RCYReJhMIuEgn12avEjtpP1VjFn/NdgN8vDvG2bA5tuXz7HH+Z6lsP3unWR477ffiv/lF6n/2CdbrHLgz02S9W/B2GDpU+kFpbUwgsz334hF+fgXRlF4mEwi4SCYVdJBIKu0gkFHaRSCjsIpFQ2EUioT57lUqf/E2nOuAeG9oWObTue2hOujcf/lwp0OPnebc+8eQytz5vYWDtd0fo+woJrRvf6cx3L5r/2ga77G8HPRMFr+wkd5AcJXl4ym3bSA6SPJD829TYYYpIVtX8Gf89AHdMc/u3zGxD8u/p+g5LROotGHYz2wvgbBPGIiINlOUJuvtJHkz+zF+U9kkk+0gOkBwoYvY9DhKZKWoN+3YAawFsADAE4Btpn2hm/WbWa2a9BfgTF0SkcWoKu5mNmFnZzCoAvgtgY32HJSL1VlPYSa6Y8uHdAA6nfa6ItIdgo5PkYwBuA7CE5GkAXwNwG8kNmFw++xSAzzdwjG3hzPV+v9ozVvHXlb8i7/e6y4H92b357HlmW+F8Sf/P3fqZ+26u+Wt30d8EvZzxNV8LcpdSa/sjfPooGHYz2zLNzY80YCwi0kB6uaxIJBR2kUgo7CKRUNhFIqGwi0RCU1yrNLGg9mNDU1hDKoHfyRecJZVXdrzpHvuL8WzLWJe6a5/i2p3L1v/yWo4AsDg/nlr7u9dCEzXfqmFE7U1XdpFIKOwikVDYRSKhsItEQmEXiYTCLhIJhV0kEuqzV6ni7y6cSWhJZG+paAAoWndq7ba5fo//ukfud+tXw5/i2v167a8hyAem7ubhT88dgz/tuMt5fcO+Zz7iHntN4PueiXRlF4mEwi4SCYVdJBIKu0gkFHaRSCjsIpFQ2EUioT57tTKsyDxeKbj1hbmLbv2tSnofHQAW5v3jPVf/dbZ+cvfwhFu/bN5y0f5W1qHXH4T68EXn+Cv3ZVtjYCbSlV0kEgq7SCQUdpFIKOwikVDYRSKhsItEQmEXiYT67FVihuXVC4GDc4F15XOBed8fdNaG/4MTm91jgdcDdV/n8yfc+oli+lz8QmDJ+aL5ffjQls8ni4tTa/N3H3WPnY1d+OCVneRqkj8jeZTkEZJfTG5fTHI3yePJ20WNH66I1KqaP+NLAL5kZusB/DaAL5BcD+BBAHvMbB2APcnHItKmgmE3syEzez55fwzAMQArAWwGsDP5tJ0A7mrUIEUku/f1mJ3k1QBuBLAPwHIzG0pKwwCWpxzTB6APALrgv8ZbRBqn6mfjSc4H8DiAB8zs3NSamRlSpoqYWb+Z9ZpZbwHpGxCKSGNVFXaSBUwG/VEzeyK5eYTkiqS+AsBoY4YoIvUQ/DOeJAE8AuCYmX1zSmkXgK0AHk7ePtWQEbaJfIbdhUNLQQfvO9CayzN9qufQd9a6x/ZkbL2Vz51z69d3zk2tHZvwp+aOOFtRA+Etn2/oGEutVcbSa7NVNY/ZPwHgswAOkTyQ3PYQJkP+Y5L3AXgZwD2NGaKI1EMw7Gb2LJC6CsDt9R2OiDSKXi4rEgmFXSQSCrtIJBR2kUgo7CKR0BTXKvW8Uvukx3mBfnBIaKnpawvzUms9P/xFpvvO6sjEpdRad+D1AxOBKa6LA1OHHzu33q3HRld2kUgo7CKRUNhFIqGwi0RCYReJhMIuEgmFXSQS6rNXqXuo9l55cGvhQD95dcd5t37vS7/vVM+6xzbao29+LLX2wBJ/u+hK4FpUCCz4/PO3rnGq6ctvz1a6sotEQmEXiYTCLhIJhV0kEgq7SCQUdpFIKOwikVCfvUqF4f+t+djQlswTlYJbX5jzfycf+5cPp9auxH+6xyLn9/hRybBXNYC9Ix9KrT209L/cY0NbVXcFzut/v7YqtXZVqM/e4PPSCrqyi0RCYReJhMIuEgmFXSQSCrtIJBR2kUgo7CKRqGZ/9tUAvg9gOQAD0G9m3ya5DcCfAb/e4PshM3u6UQNttfKLL9d8bCf8nuw4/D77uPn95LG16V//SvfIMHb4PyJW8veeHz7bU/N9F+H3uvNpewsnLo9013zfCJzzmaiaF9WUAHzJzJ4nuQDAfpK7k9q3zOzrjRueiNRLNfuzDwEYSt4fI3kMwMpGD0xE6ut9PWYneTWAGwHsS266n+RBkjtILko5po/kAMmBIrJtgyQitas67CTnA3gcwANmdg7AdgBrAWzA5JX/G9MdZ2b9ZtZrZr0FzKnDkEWkFlWFnWQBk0F/1MyeAAAzGzGzsplVAHwXwMbGDVNEsgqGnSQBPALgmJl9c8rtK6Z82t0ADtd/eCJSL9U8G/8JAJ8FcIjkgeS2hwBsIbkBk+24UwA+35ARtosMUxpvnOO3cUbK/nTLFR3z3foPNm1Prf0tPuoeG2wx0W8LZjE/1+XW1xXOuPWrAucFC4rvd0j/j4HroM28Ka7VPBv/LIDpOpqztqcuMhvpFXQikVDYRSKhsItEQmEXiYTCLhIJhV0kElpKug7Wb/8Lt/7hTx936y+MLnfrdtifJnrNd150qiPuscz700itOOHWQ679y1dTax/68p+7xy69YdStDw8vdOvrv3I6teZPzAWY8+fPzsQZsLqyi0RCYReJhMIuEgmFXSQSCrtIJBR2kUgo7CKRoJk1787I1wFMXZN5CYA3mjaA96ddx9au4wI0tlrVc2wfNLOl0xWaGvb33Dk5YGa9LRuAo13H1q7jAjS2WjVrbPozXiQSCrtIJFod9v4W37+nXcfWruMCNLZaNWVsLX3MLiLN0+oru4g0icIuEomWhJ3kHSR/RfIEyQdbMYY0JE+RPETyAMmBFo9lB8lRkoen3LaY5G6Sx5O30+6x16KxbSM5mJy7AyQ3tWhsq0n+jORRkkdIfjG5vaXnzhlXU85b0x+zk8wD+B8AnwZwGsBzALaY2dGmDiQFyVMAes2s5S/AIHkrgPMAvm9mNyS3/QOAs2b2cPKLcpGZfblNxrYNwPlWb+Od7Fa0Yuo24wDuAvA5tPDcOeO6B004b624sm8EcMLMTprZBIAfAdjcgnG0PTPbC+Dsu27eDGBn8v5OTP6wNF3K2NqCmQ2Z2fPJ+2MA3t5mvKXnzhlXU7Qi7CsBTF2r6DTaa793A/BTkvtJ9rV6MNNYbmZDyfvDAPw1rZovuI13M71rm/G2OXe1bH+elZ6ge69bzOyjAO4E8IXkz9W2ZJOPwdqpd1rVNt7NMs0247/WynNX6/bnWbUi7IMAVk/5eFVyW1sws8Hk7SiAJ9F+W1GPvL2DbvLWX5WxidppG+/pthlHG5y7Vm5/3oqwPwdgHck1JDsB3AtgVwvG8R4k5yVPnIDkPACfQfttRb0LwNbk/a0AnmrhWN6hXbbxTttmHC0+dy3f/tzMmv4PwCZMPiP/IoC/asUYUsZ1DYBfJv+OtHpsAB7D5J91RUw+t3EfgCsA7AFwHMC/AVjcRmP7AYBDAA5iMlgrWjS2WzD5J/pBAAeSf5tafe6ccTXlvOnlsiKR0BN0IpFQ2EUiobCLREJhF4mEwi4SCYVdJBIKu0gk/g8VvWhx/BzQlgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "iii = 55110\n",
    "trainim = np.reshape(dataX_train1[iii,:],(28,28))\n",
    "plt.imshow(trainim)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "##  X is input and Z the embedding space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:508: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    " \n",
    "imgX = Input(shape=(28, 28, 1), name=\"input_img\")  # adapt this if using `channels_first` image data format\n",
    "labelX=K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Encoder, Decoder and Classifier NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encoderXNN(imgX,zdim):\n",
    "    x = Conv2D(64, (3, 3), activation='relu', padding='same', name='block1_conv1')(imgX)\n",
    "    x = Conv2D(64, (3, 3), activation='relu', padding='same', name='block1_conv2')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block1_pool')(x)\n",
    "\n",
    "    # Block 2\n",
    "    x = Conv2D(128, (3, 3), activation='relu', padding='same', name='block2_conv1')(x)\n",
    "    x = Conv2D(128, (3, 3), activation='relu', padding='same', name='block2_conv2')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block2_pool')(x)\n",
    "\n",
    "    # Block 3\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv1')(x)\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv2')(x)\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv3')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block3_pool')(x)\n",
    "    '''\n",
    "    # Block 4\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv1')(x)\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv2')(x)\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv3')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block4_pool')(x)\n",
    "    # Block 5\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='same', name='block5_conv1')(x)\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='same', name='block5_conv2')(x)\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='valid', name='block5_conv3')(x)\n",
    "    x = MaxPooling2D((2, 2), strides=(2, 2), name='block5_pool')(x)\n",
    "    '''\n",
    "    # Top layers\n",
    "    x = Flatten(name='flatten')(x)\n",
    "    x = Dense(1024, activation='relu')(x)\n",
    "    x = Dropout(0.5)(x)\n",
    "    x = Dense(1024, activation='relu')(x)\n",
    "    x = Dropout(0.5)(x)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    embed = Dense(zdim, activation='relu')(x)\n",
    "    encoderX = Model(imgX, embed)\n",
    "\n",
    "    return encoderX\n",
    "\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def decoderXNN(yin):\n",
    "\n",
    "    x = Reshape([1,1, 64])(yin)\n",
    "    xx = UpSampling2D((4, 4))(x)\n",
    "\n",
    "    xx = Conv2D(128, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    #encoded = UpSampling2D((2, 2))(yin)\n",
    "\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    #x = UpSampling2D((2, 2))(x)\n",
    "    xx = Conv2D(64, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(64, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    xx = Conv2D(32, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(32, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    xx = Conv2D(16, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(16, (3, 3), activation='relu')(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    decoded = Conv2D(1, (2, 2), activation='sigmoid', padding='same',name=\"decoded\")(xx)\n",
    "\n",
    "    decoderX = Model(yin, decoded)\n",
    "    \n",
    "    return decoderX\n",
    "\n",
    "    #decoderX.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def classifierNN(nofclasses,z):\n",
    "#     probX=Dense(nofclasses,activation='softmax')(z)\n",
    "#     classifier=Model(inputs=[z],outputs=[probX])\n",
    "#     return classifier\n",
    "\n",
    "\n",
    "def classifierNN(nofclasses,yin):\n",
    "    interdimX = 32\n",
    "    #y=Flatten()(yin)\n",
    "    #y=LeakyReLU(alpha=0.2)(yin)\n",
    "    #y=Dense(interdimX)(y)\n",
    "    #y=LeakyReLU(alpha=0.2)(y)\n",
    "    #y=BatchNormalization(momentum=0.8)(y)\n",
    "   # y=Dense(zdim)(y)\n",
    "    #y=LeakyReLU(alpha=0.2)(y)\n",
    "\n",
    "    probX=Dense(nofclasses,activation='softmax')(yin)\n",
    "    classifier=Model(inputs=[yin],outputs=[probX])\n",
    "    return classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "encoderX = encoderXNN(imgX,zdim)\n",
    "yin =  Input(shape=(zdim,) )\n",
    "\n",
    "decoderX = decoderXNN(yin)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "thres = .9\n",
    "lamda=1e1\n",
    "Classifier = []\n",
    "Encoder = []\n",
    "Decoder = []\n",
    "GMMs = []\n",
    "\n",
    "# reinitLayers(encoderX)\n",
    "# reinitLayers(encoderY)\n",
    "# reinitLayers(classifier)\n",
    "\n",
    "#seed=np.random.randint(0,high=100)\n",
    "loss = []\n",
    "testXperf = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training on Task 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig=plt.figure(figsize=(10,10))\n",
    "LR = 3e-5\n",
    "for cl in range(4):\n",
    "    # extract the dataset\n",
    "    #for jj in range(cl+1):\n",
    "    classifier = classifierNN(2*cl+2,yin)\n",
    "    if cl == 0:\n",
    "        indCL = np.concatenate([np.where(np.argmax(labelX_train,axis=1)==0)[0],np.where(np.argmax(labelX_train,axis=1)==1)[0]])\n",
    "        labelX_trainCL =  labelX_train[indCL,:2*cl+2] \n",
    "        dataX_train1CL =  dataX_train[indCL,:] \n",
    "    else:\n",
    "        indCL = np.concatenate([np.where(np.argmax(labelX_train,axis=1)==2*cl)[0],np.where(np.argmax(labelX_train,axis=1)==2*cl+1)[0]])\n",
    "         \n",
    "        \n",
    "        xreptrainlabelonehotExtended = labelX_train[indCL,:2*cl+2] \n",
    "        extended_memory_label = np.concatenate([xreptrainlabelonehot,np.zeros([xreptrainlabelonehot.shape[0],2])],axis=1)\n",
    "        labelX_trainCL = np.concatenate([xreptrainlabelonehotExtended,extended_memory_label],axis=0)\n",
    "        dataX_train1CL =np.concatenate([ dataX_train[indCL,:],xreptrainData ],axis=0)\n",
    "\n",
    "        \n",
    "\n",
    "    labelX=K.placeholder(shape=(None,2*cl+2),dtype='float32') #labels of input images oneHot\n",
    "    theta=K.variable(generateTheta(nofprojections,zdim),)#Define a Keras Variable for \\theta_ls\n",
    "    #swLoss=sWasserstein(encoderX(imgY),encoderX(imgZ),theta,Cp=labelX,Cq=labelZ)\n",
    "    \n",
    "\n",
    "    #autorec = K.mean(K.square(imgX-decoderX(encoderX(imgX))))\n",
    "    #autorec = K.mean(K.square((imgX-decoderX(encoderX(imgX)))))\n",
    "    autorec = K.mean(K.binary_crossentropy(imgX,decoderX(encoderX(imgX))))\n",
    "\n",
    "\n",
    "\n",
    "     \n",
    "    #discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "    discriminationLoss=K.mean(K.binary_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "    \n",
    "\n",
    "     \n",
    "    myLoss=  discriminationLoss+lamda*autorec\n",
    "    params=encoderX.weights + decoderX.weights + classifier.weights\n",
    "\n",
    "    \n",
    "    \n",
    "    #loss=[]\n",
    "    \n",
    "    \n",
    "    if cl == 0:\n",
    "        opt = Adam(lr=1e-4,decay = 1e-4)\n",
    "        updates = opt.get_updates(myLoss,params)\n",
    "        train = K.function(inputs=[imgX,labelX],outputs=[autorec],updates=updates)\n",
    "        \n",
    "    if cl >= 1:\n",
    "        LR = LR/3\n",
    "        if cl==3:\n",
    "            LR= 5e-7\n",
    "        opt = Adam(lr=LR,decay = 1e-5) # very important\n",
    "        updates = opt.get_updates(myLoss,params)\n",
    "        train = K.function(inputs=[imgX,labelX],outputs=[autorec],updates=updates)\n",
    "        #train = K.function(inputs=[imgX,imgY,imgZ,labelX,labelY,labelZ,theta],outputs=[lamda*autorec,discriminationLoss,swLoss],updates=updatesT)\n",
    "\n",
    "\n",
    "    for itr in range(epochs):\n",
    "        \n",
    "        indTrainDataX,trainLabelX=batchGenerator(labelX_trainCL,batchsize,nofclasses=2*cl+2)\n",
    "        trainDataX=dataX_train1CL[indTrainDataX,...]\n",
    "        \n",
    "        \n",
    "        loss.append(train(inputs=[trainDataX,trainLabelX]))\n",
    "      \n",
    "        if itr%epochstep==0: \n",
    "\n",
    "            for jj in range(2*cl+2):\n",
    "                if jj == 0:\n",
    "                    indCLtest = np.where(np.argmax(labelX_test,axis=1)==0)[0]\n",
    "                else:\n",
    "                    indCLtest = np.concatenate([indCLtest,np.where(np.argmax(labelX_test,axis=1)==jj)[0]])\n",
    "            labelX_testCL = labelX_test[indCLtest,:]\n",
    "            dataX_test1CL = dataX_test[indCLtest,:]   \n",
    "\n",
    "            perd_label_X = classifier.predict(encoderX.predict(dataX_test1CL))\n",
    "\n",
    "\n",
    "\n",
    "            \n",
    "            testXperf.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(labelX_testCL),axis=1))))/labelX_testCL.shape[0])\n",
    "            \n",
    "            plt.subplot(4, 1, 1)\n",
    "            plt.plot(np.asarray(loss))\n",
    "            \n",
    "            plt.subplot(4, 1, 2)\n",
    "            plt.plot(np.asarray(testXperf))\n",
    "            \n",
    "            imageind = np.random.randint(trainDataX.shape[0])\n",
    "            \n",
    "            plt.subplot(4, 1, 3)\n",
    "            plt.imshow(decoderX.predict(encoderX.predict(trainDataX[imageind:imageind+1,:,:,:]))[0,:,:,0])\n",
    "\n",
    "            plt.subplot(4, 1, 4)\n",
    "            plt.imshow(trainDataX[imageind,:,:,0])\n",
    "            \n",
    "            display.clear_output(wait=True)\n",
    "            display.display(plt.gcf()) \n",
    "            time.sleep(1e-3) \n",
    "    Classifier.append(classifier)  \n",
    "    Encoder.append(encoderX)  \n",
    "    Decoder.append(decoderX)  \n",
    "    \n",
    "        ### pseudo-datapoints\n",
    "    if cl<4:\n",
    "        labelX_train_EXP = np.argmax(np.squeeze(labelX_trainCL),axis=1)   \n",
    "        tempvar = labelX_trainCL\n",
    "        \n",
    "        \n",
    "        gmm = MgGMMfit(encoderX,dataX_train1CL,labelX_trainCL,2*cl+2)\n",
    "        \n",
    "\n",
    "        GMMs.append(gmm)\n",
    "\n",
    "  \n",
    "  \n",
    "        # GMM is used as a generative model so task 1 data is not saved\n",
    "        xnofsample = (2*cl+1)*4000\n",
    "        xreptrainDataencoded, xreptrainlabel = gmm.sample(xnofsample)\n",
    "\n",
    "\n",
    "\n",
    "        xtemper = np.zeros([xreptrainDataencoded.shape[0], xreptrainDataencoded.shape[1]])\n",
    "        xtemper  = xreptrainDataencoded\n",
    "\n",
    "\n",
    "        xreptrainData = decoderX.predict(xtemper)\n",
    "\n",
    "        xreptrainData = xreptrainData.clip(min=0)\n",
    "        xreptrainData = xreptrainData.clip(max=1)\n",
    "\n",
    " \n",
    "        xreptrainlabelonehot = keras.utils.to_categorical(xreptrainlabel)\n",
    "\n",
    "        xnofsampletest =  (2*cl+2)*1000\n",
    "        xreptestDataencoded, xreptestlabel = gmm.sample(xnofsampletest)\n",
    "\n",
    "        xtemper1 = np.zeros([xreptestDataencoded.shape[0],xreptestDataencoded.shape[1]])\n",
    "        xtemper1 = xreptestDataencoded\n",
    "\n",
    "        xreptestData = decoderX.predict(xtemper1)\n",
    "\n",
    "        xreptestData = xreptestData.clip(min=0)\n",
    "        xreptestData = xreptestData.clip(max=1)\n",
    "\n",
    "\n",
    "  \n",
    "        xreptestlabelonehot = keras.utils.to_categorical(xreptestlabel)\n",
    "\n",
    "        # model perforamnce on generated dataset\n",
    "        perd_label_Sample = classifier.predict(encoderX.predict(xreptestData))\n",
    "        print('model perforamnce on generated dataset')\n",
    "        print(100*float(sum(1*(np.argmax(perd_label_Sample,axis=1)==np.argmax(np.squeeze(xreptestlabelonehot),axis=1))))/perd_label_Sample.shape[0])\n",
    "\n",
    "\n",
    "\n",
    "                                              "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model perforamnce on generated dataset\n",
      "76.275\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf = testXperf \n",
    "with open('FMNIST-ICLA-CNN.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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": 2
}
