{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib64/python3.6/site-packages/h5py/__init__.py:36: FutureWarning: Conversion of the second argument of issubdtype from `float` to `np.floating` is deprecated. In future, it will be treated as `np.float64 == np.dtype(float).type`.\n",
      "  from ._conv import register_converters as _register_converters\n",
      "Using TensorFlow backend.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from utilsO 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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "#! pip install umap-learn\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=64 # This is the dimension of intermediate latent variable \n",
    "epochs = 10000\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=1000 \n",
    "nofprojections = 200"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Read MNIST\n",
    "\n",
    "(x_train,y_train),(x_test,y_test)=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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(60000, 784)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataX_train1.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(60000, 10)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labelX_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "numtasks =4\n",
    "\n",
    "\n",
    "dataY_train1 = {}\n",
    "dataY_test1 = {}\n",
    "labelY_train = {}\n",
    "labelY_test = {}\n",
    "indxtot = {}\n",
    "for numtask in range(numtasks):\n",
    "    \n",
    "\n",
    "\n",
    "    idx = list(range(28 * 28))\n",
    "    np.random.shuffle(idx)\n",
    "     \n",
    "    indxtot[numtask] = idx\n",
    "\n",
    "    dataY_train1[numtask]= np.zeros([numdataTrain,28*28])\n",
    "    temp3 = np.zeros([numdataTrain,28*28])\n",
    "\n",
    "    dataY_test1[numtask]= np.zeros([numdataTest,28*28])\n",
    "    temp4 = np.zeros([numdataTrain,28*28])\n",
    "\n",
    "    labelY_train[numtask] =labelX_train   \n",
    "\n",
    "    labelY_test[numtask] =  labelX_test  \n",
    "\n",
    "    for i in range(numdataTrain):    \n",
    "        temp = dataX_train1[i,:]    \n",
    "        temp2 = temp[idx]        \n",
    "        dataY_train1[numtask][i,:] = temp2\n",
    "    \n",
    "    for i in range(numdataTest):    \n",
    "        temp = dataX_test1[i,:]  \n",
    "        temp2 = temp[idx]        \n",
    "        dataY_test1[numtask][i,:] = temp2\n",
    "    \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f294404fc18>"
      ]
     },
     "execution_count": 10,
     "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": [
    "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": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING: Logging before flag parsing goes to stderr.\n",
      "W0414 18:24:13.497687 139823261714240 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:68: The name tf.get_default_graph is deprecated. Please use tf.compat.v1.get_default_graph instead.\n",
      "\n",
      "W0414 18:24:13.504868 139823261714240 module_wrapper.py:139] 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(((28*28),)) #Input image \n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Encoder, Decoder and Classifier NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "W0414 18:24:13.531924 139823261714240 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3837: The name tf.random_uniform is deprecated. Please use tf.random.uniform instead.\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_1 (InputLayer)         (None, 784)               0         \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              (None, 256)               200960    \n",
      "_________________________________________________________________\n",
      "dense_2 (Dense)              (None, 128)               32896     \n",
      "_________________________________________________________________\n",
      "dense_3 (Dense)              (None, 64)                8256      \n",
      "=================================================================\n",
      "Total params: 242,112\n",
      "Trainable params: 242,112\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "hidden_size = 256\n",
    "x=Dense(hidden_size,activation = 'relu')(imgX)\n",
    " \n",
    "x=Dense(int(hidden_size/2),activation = 'relu')(x)\n",
    "#x=Dense(hidden_size/32,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "encodedX=Dense(zdim)(x)\n",
    "\n",
    "encoderX=Model(inputs=[imgX],outputs=[encodedX])\n",
    "\n",
    "  \n",
    "encoderX.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         (None, 64)                0         \n",
      "_________________________________________________________________\n",
      "dense_4 (Dense)              (None, 128)               8320      \n",
      "_________________________________________________________________\n",
      "dense_5 (Dense)              (None, 256)               33024     \n",
      "_________________________________________________________________\n",
      "dense_6 (Dense)              (None, 784)               201488    \n",
      "=================================================================\n",
      "Total params: 242,832\n",
      "Trainable params: 242,832\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "z=Input((zdim,))\n",
    "\n",
    "x=Dense(int(hidden_size/2),activation = 'relu')(z)\n",
    "#x=Dense(hidden_size/2,activation = 'sigmoid')(x)\n",
    "x=Dense(hidden_size,activation = 'relu')(x)\n",
    "#x=Dense(hidden_size,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "decodedX=Dense(28*28,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "decoderX=Model(inputs=[z],outputs=[decodedX])\n",
    "\n",
    "  \n",
    "decoderX.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def classi(z,nofclasses):\n",
    "\n",
    "    probX=Dense(nofclasses,activation='softmax')(z)\n",
    "    classifier=Model(inputs=[z],outputs=[probX])\n",
    "    return classifier\n",
    "    classifier.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         (None, 64)                0         \n",
      "_________________________________________________________________\n",
      "dense_7 (Dense)              (None, 2)                 130       \n",
      "=================================================================\n",
      "Total params: 130\n",
      "Trainable params: 130\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "classifier = classi(z,2)\n",
    "classifier.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "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] \n",
    "dataX_train1CL =  dataX_train1[indCL,:] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "indCL = np.concatenate([np.where(np.argmax(labelX_test,axis=1)==0)[0],np.where(np.argmax(labelX_test,axis=1)==1)[0]])\n",
    "labelX_testCL =  labelX_test[indCL,:2] \n",
    "dataX_test1CL =  dataX_test1[indCL,:] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "labelX=K.placeholder(shape=(None,2),dtype='float32') #labels of input images oneHot\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training on Task 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "W0414 18:24:14.001061 139823261714240 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3014: The name tf.log is deprecated. Please use tf.math.log instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "lamda=10 # 10 is a good number\n",
    "\n",
    "discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "autorec = K.mean(K.square(imgX-decoderX(encoderX(imgX))))\n",
    "myLoss= discriminationLoss+lamda*autorec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "W0414 18:24:14.178406 139823261714240 deprecation.py:323] From /usr/local/lib64/python3.6/site-packages/tensorflow_core/python/ops/math_grad.py:1424: where (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Use tf.where in 2.0, which has the same broadcast rule as np.where\n",
      "W0414 18:24:14.303470 139823261714240 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:977: The name tf.assign_add is deprecated. Please use tf.compat.v1.assign_add instead.\n",
      "\n",
      "W0414 18:24:14.546321 139823261714240 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:964: The name tf.assign is deprecated. Please use tf.compat.v1.assign instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "params=encoderX.weights + decoderX.weights + classifier.weights\n",
    " \n",
    "    \n",
    "opt = Adam(lr=1e-4) # very important\n",
    "updates = opt.get_updates(myLoss,params)\n",
    "train = K.function(inputs=[imgX,labelX],outputs=[myLoss,lamda*autorec,discriminationLoss],updates=updates)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "loss=[]\n",
    "testXperf = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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": [
    "\n",
    "\n",
    "fig=plt.figure()\n",
    "# reinitLayers(encoderX)\n",
    "# reinitLayers(encoderY)\n",
    "# reinitLayers(classifier)\n",
    "\n",
    "#seed=np.random.randint(0,high=100)\n",
    "\n",
    "for itr in range(epochs):\n",
    "    indTrainDataX,trainLabelX=batchGenerator(labelX_trainCL,batchsize,nofclasses=2)\n",
    "    trainDataX=dataX_train1CL[indTrainDataX,...]\n",
    "    \n",
    "\n",
    "        \n",
    "    \n",
    "    loss.append(train(inputs=[trainDataX,trainLabelX]))\n",
    "     \n",
    "    if itr%epochstep==0:\n",
    "        perd_label_X = classifier.predict(encoderX.predict(dataX_test1CL))\n",
    "        testXperf.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(labelX_testCL),axis=1))))/perd_label_X.shape[0])\n",
    "        \n",
    "        plt.plot(np.asarray(loss))\n",
    "        display.clear_output(wait=True)\n",
    "        display.display(plt.gcf()) \n",
    "        time.sleep(1e-3) \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "plt.plot(testXperf,linewidth=4)\n",
    "plt.xlabel('Epochs/100',fontsize=14)\n",
    "plt.title('Task1 Testing ACC',fontsize=14)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "# save_model(classifier,filepath='classifier.h5')\n",
    "# save_model(decoderX,filepath='decoderX.h5')\n",
    "# save_model(encoderX,filepath='encoderX.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "21.14\n"
     ]
    }
   ],
   "source": [
    "perd_label_X = classifier.predict(encoderX.predict(dataX_test1))\n",
    "print(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(labelX_test),axis=1))))/perd_label_X.shape[0])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "# classifier = load_model(filepath='classifier.h5')\n",
    "# decoderX = load_model(filepath='decoderX.h5')\n",
    "# encoderX = load_model(filepath='encoderX.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Learning Next Tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 6 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "testpermutedperf = {}\n",
    "thres = .92\n",
    "\n",
    "for ntask in range(numtasks):\n",
    "    testpermutedperf[ntask] = []\n",
    "\n",
    "GMM = {}\n",
    "#fig=plt.figure()\n",
    "\n",
    "fig,ax=plt.subplots(6,figsize=(10,10))\n",
    "\n",
    "\n",
    "imgY=Input(((28*28),)) #Input image \n",
    "\n",
    "\n",
    "imgZ=Input(((28*28),)) #Input image \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "lamda2=1e-3\n",
    "theta=K.variable(generateTheta(nofprojections,zdim),)#Define a Keras Variable for \\theta_ls\n",
    "\n",
    "\n",
    "\n",
    "Classifiers = {}\n",
    "Classifiers[0] = classifier\n",
    "\n",
    "\n",
    "for ntask in range(numtasks):\n",
    "   \n",
    "    #Fit GMM to training data    \n",
    "    if ntask ==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_train_EXP = labelX_train[indCL,:2*ntask+2] \n",
    "        dataX_train1_EXP = dataX_train1[indCL,:] \n",
    "    else:        \n",
    "        labelY_train_pre = labelY_train[ntask-1]    \n",
    "        indCLt = []\n",
    "        for iji in range(2*ntask+2):\n",
    "            indCLt = np.concatenate([indCLt,np.where(np.argmax(labelY_train_pre,axis=1)==iji)[0]]) \n",
    "        indCLt = indCLt.astype(int)\n",
    "        labelY_train_pre = labelY_train_pre[indCLt,:2*ntask+2] \n",
    "        dataY_train_pre = dataY_train1[kk]\n",
    "        dataY_train_pre = dataY_train_pre[indCLt,:]            \n",
    "\n",
    "        labelX_train_EXP = np.concatenate((labelY_train_pre,xreptrainlabelonehot ),axis=0)\n",
    "        dataX_train1_EXP = np.concatenate((dataY_train_pre, xreptrainData),axis=0)        \n",
    "        \n",
    "   \n",
    "    tempvar = labelX_train_EXP\n",
    "    \n",
    "    num_det_clusters = 0\n",
    "\n",
    "    labeltrain_EXP = np.argmax(np.squeeze(labelX_train_EXP),axis=1)\n",
    "\n",
    "    # fitting GNN\n",
    "    print('ntask')\n",
    "    print(ntask)\n",
    "    \n",
    "    gmm = MgGMMfit(encoderX,dataX_train1_EXP,labelX_train_EXP,2*ntask+2)\n",
    "    \n",
    "    \n",
    " \n",
    "  \n",
    "    # GMM is used as a generative model so task 1 data is not saved\n",
    "    xnofsample = 60000\n",
    "    xreptrainDataencoded, xreptrainlabel = gmm.sample(xnofsample)\n",
    "    \n",
    "    \n",
    " \n",
    "    \n",
    "    xreptrainData = decoderX.predict(xreptrainDataencoded)\n",
    "    xreptrainData = xreptrainData.clip(min=0)\n",
    "    xreptrainData = xreptrainData.clip(max=1)\n",
    "\n",
    "    xreptrainlabelonehot = keras.utils.to_categorical(xreptrainlabel)\n",
    "\n",
    "    xnofsampletest = 10000\n",
    "    xreptestDataencoded, xreptestlabel = gmm.sample(xnofsampletest)\n",
    "    xreptestData = decoderX.predict(xreptestDataencoded)\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_X.shape[0])\n",
    "\n",
    "\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    batchsize=400\n",
    "    batchsize = batchsize/2\n",
    "    \n",
    "    \n",
    "    seed=np.random.randint(0,high=100)\n",
    "    \n",
    "    classifier = classi(z,2*ntask+4)\n",
    "    labelX=K.placeholder(shape=(None,2*ntask+2),dtype='float32') #labels of input images oneHot\n",
    "    \n",
    "    labelY=K.placeholder(shape=(None,2*ntask+2),dtype='float32') #labels of input images oneHot\n",
    "    labelZ=K.placeholder(shape=(None,2*ntask+4),dtype='float32') #labels of input images oneHot\n",
    "    \n",
    "\n",
    "    discriminationLoss=K.mean(K.categorical_crossentropy(labelZ,classifier(encoderX(imgZ))))\n",
    "    autorec = K.mean(K.square(imgZ-decoderX(encoderX(imgZ))))\n",
    "\n",
    "    swLoss=sWasserstein(encoderX(imgX),encoderX(imgY),theta,nclass = 2*ntask+2,Cp=labelX,Cq=labelY)\n",
    "\n",
    "\n",
    "    myLossT= discriminationLoss+lamda*autorec+lamda2*swLoss\n",
    "\n",
    "\n",
    "    params=encoderX.weights + decoderX.weights + classifier.weights\n",
    "\n",
    "    optT = Adam(lr=1e-4) # very important\n",
    "    updatesT = optT.get_updates(myLossT,params)\n",
    "    trainT = K.function(inputs=[imgX,imgY,imgZ,labelX,labelY,labelZ,theta],outputs=[lamda*autorec,discriminationLoss,swLoss],updates=updatesT)\n",
    "\n",
    "  \n",
    "\n",
    "    \n",
    "    indCLt = []\n",
    "    labelY_current = labelY_train[ntask]\n",
    "    for iji in range(2*ntask+4):\n",
    "        indCLt = np.concatenate([indCLt,np.where(np.argmax(labelY_current,axis=1)==iji)[0]]) \n",
    "    indCLt = indCLt.astype(dtype=int)\n",
    "    labelY_current = labelY_current[indCLt,:2*ntask+4] \n",
    "    dataY_train_current = dataY_train1[ntask]\n",
    "    dataY_train_current = dataY_train_current[indCLt,:] \n",
    "    \n",
    "\n",
    "\n",
    "    indCLt = []\n",
    "    for iji in range(2):\n",
    "        indCLt = np.concatenate([indCLt,np.where(np.argmax(labelX_test,axis=1)==iji)[0]])\n",
    "    indCLt = indCLt.astype(dtype=int)\n",
    "    labelX_test_current = labelX_test[indCLt,:2*ntask+4] \n",
    "    dataX_test_current = dataX_test1[indCLt,:] \n",
    "    \n",
    "    \n",
    "    \n",
    "    tempExplabel = np.zeros([xreptrainlabelonehot.shape[0],2*ntask+4])\n",
    "    tempExplabel[:,:2*ntask+2] = xreptrainlabelonehot\n",
    "    tempExplabel = tempExplabel.astype(dtype=int)\n",
    "    xreptrainlabelonehot = tempExplabel\n",
    "    \n",
    "\n",
    "\n",
    "   \n",
    "    for itr in range(epochs):\n",
    "        indTrainDataY,trainLabelY=batchGenerator(labelY_current,2*batchsize,nofclasses=2*ntask+4)\n",
    "        trainDataY=dataY_train_current[indTrainDataY,...]\n",
    "        \n",
    "        indCLt = []\n",
    "        for iji in range(2*ntask+2):\n",
    "            indCLt = np.concatenate([indCLt,np.where(np.argmax(trainLabelY,axis=1)==iji)[0]])\n",
    "        indCLt = indCLt.astype(dtype=int)\n",
    "        trainLabelYHistory = trainLabelY[indCLt,:2*ntask+4] \n",
    "        trainDataYHistory = trainDataY[indCLt,:]         \n",
    "\n",
    "        \n",
    "\n",
    "\n",
    "        indTrainDatasample,trainLabelsample=batchGenerator(tempExplabel,batchsize,nofclasses=2*ntask+2)\n",
    "        trainDatasample=xreptrainData[indTrainDatasample,...]\n",
    "\n",
    "\n",
    "        trainDataYtot = np.concatenate((trainDataY,trainDatasample), axis=0)\n",
    "        trainLabelYtot = np.concatenate((trainLabelY,trainLabelsample), axis=0)\n",
    "\n",
    "\n",
    "        theta_=generateTheta(nofprojections,zdim)\n",
    "        \n",
    "          \n",
    "        loss.append(trainT(inputs=[trainDataYHistory,trainDatasample,trainDataYtot,trainLabelYHistory[:,:2*ntask+2],trainLabelsample[:,:2*ntask+2],trainLabelYtot,theta_]))\n",
    "           \n",
    "            \n",
    "        if itr%epochstep==0:\n",
    "\n",
    "            perd_label_X = classifier.predict(encoderX.predict(dataX_test_current))\n",
    "            testXperf.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(labelX_test_current),axis=1))))/perd_label_X.shape[0])\n",
    "    \n",
    "\n",
    "            for kk in range(ntask+1):\n",
    "\n",
    "                indCLt = []\n",
    "                labelY_test_current = labelY_test[kk]    \n",
    "                for iji in range(2*kk+4):\n",
    "                    indCLt = np.concatenate([indCLt,np.where(np.argmax(labelY_test_current,axis=1)==iji)[0]]) \n",
    "                indCLt = indCLt.astype(int)\n",
    "                labelY_test_current = labelY_test_current[indCLt,:2*ntask+4] \n",
    "                dataY_test_current = dataY_test1[kk]\n",
    "                dataY_test_current = dataY_test_current[indCLt,:]     \n",
    "\n",
    "\n",
    "                perd_label_Y = classifier.predict(encoderX.predict(dataY_test_current))\n",
    "                testpermutedperf[kk].append(100*float(sum(1*(np.argmax(perd_label_Y,axis=1)==np.argmax(np.squeeze(labelY_test_current),axis=1))))/perd_label_Y.shape[0])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "            ax[0].plot(np.asarray(loss))\n",
    "            ax[1].plot(testXperf)\n",
    "            ax[2].plot(testpermutedperf[0])\n",
    "            ax[3].plot(testpermutedperf[1])\n",
    "            ax[4].plot(testpermutedperf[2])\n",
    "            ax[5].plot(testpermutedperf[3])\n",
    "            display.clear_output(wait=True)\n",
    "            display.display(plt.gcf()) \n",
    "            time.sleep(1e-3) \n",
    "    Classifiers[ntask+1] = classifier       \n",
    "    save_model(classifier,filepath='classifier'+str(ntask)+'.h5')\n",
    "    save_model(decoderX,filepath='decoderX'+str(ntask)+'.h5')\n",
    "    save_model(encoderX,filepath='encoderX'+str(ntask)+'.h5')\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf[-1] = testXperf\n",
    "with open('ICLAA.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('ICLAA.json', 'r') as fp:\n",
    "    data = json.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Testing Accuracy')"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "epochs1 = epochs/epochstep\n",
    "fig, ax=plt.subplots(1,1,figsize=(10,10))\n",
    "for task in range(numtasks+1):\n",
    "    if task == 0:\n",
    "        plt.plot(np.arange(epochs1*(task),epochs1*(numtasks+1)),testXperf,linewidth=4)\n",
    "    \n",
    "    if task >0:\n",
    "        plt.plot(np.arange(epochs1*(task),epochs1*(numtasks+1)),testpermutedperf[task-1],linewidth=4)\n",
    "plt.grid()\n",
    "plt.tick_params(labelsize=20)\n",
    "\n",
    "ax.set_xlabel('Epochs',fontsize=24)\n",
    "ax.set_ylabel('Testing Accuracy',fontsize=24)\n",
    "\n",
    "#ax.set_title('Training loss for the AE tasks',fontsize=14)\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": 2
}
