{
 "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": [
    "# import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\"\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=16 # This is the dimension of intermediate latent variable \n",
    "epochs = 10000\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=1000 \n",
    "nofprojections = 100"
   ]
  },
  {
   "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 0x7fadbd630160>"
      ]
     },
     "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": [],
   "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": [
      "WARNING: Logging before flag parsing goes to stderr.\n",
      "W0206 03:58:54.834708 140385778579264 deprecation.py:506] From /usr/local/lib64/python3.6/site-packages/tensorflow_core/python/ops/resource_variable_ops.py:1630: calling BaseResourceVariable.__init__ (from tensorflow.python.ops.resource_variable_ops) with constraint is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "If using Keras pass *_constraint arguments to layers.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model_1\"\n",
      "_________________________________________________________________\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, 16)                2064      \n",
      "=================================================================\n",
      "Total params: 235,920\n",
      "Trainable params: 235,920\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": [
      "Model: \"model_2\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         (None, 16)                0         \n",
      "_________________________________________________________________\n",
      "dense_4 (Dense)              (None, 128)               2176      \n",
      "_________________________________________________________________\n",
      "dense_5 (Dense)              (None, 256)               33024     \n",
      "_________________________________________________________________\n",
      "dense_6 (Dense)              (None, 784)               201488    \n",
      "=================================================================\n",
      "Total params: 236,688\n",
      "Trainable params: 236,688\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 = 'relu')(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": [
      "Model: \"model_3\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         (None, 16)                0         \n",
      "_________________________________________________________________\n",
      "dense_7 (Dense)              (None, 2)                 34        \n",
      "=================================================================\n",
      "Total params: 34\n",
      "Trainable params: 34\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": [],
   "source": [
    "lamda=10 # 10 is a good number\n",
    "\n",
    "discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "myLoss= discriminationLoss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "W0206 03:58:57.148687 140385778579264 module_wrapper.py:139] From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:422: The name tf.global_variables is deprecated. Please use tf.compat.v1.global_variables instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "params=encoderX.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=[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",
    "\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",
    " \n",
    "\n",
    "\n",
    "Classifiers = {}\n",
    "Classifiers[0] = classifier\n",
    "\n",
    "\n",
    "for ntask in range(numtasks):\n",
    "   \n",
    "  \n",
    "     \n",
    "    batchsize=400\n",
    "     \n",
    "    \n",
    "    seed=np.random.randint(0,high=100)\n",
    "    \n",
    "    classifier = classi(z,2*ntask+4)\n",
    "     \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",
    "\n",
    "\n",
    "    myLossT= discriminationLoss\n",
    "\n",
    "\n",
    "    params=encoderX.weights + classifier.weights\n",
    "\n",
    "    optT = Adam(lr=1e-4) # very important\n",
    "    updatesT = optT.get_updates(myLossT,params)\n",
    "    trainT = K.function(inputs=[ imgZ,labelZ],outputs=[ discriminationLoss],updates=updatesT)\n",
    "\n",
    "  \n",
    "    buffersize = 30000\n",
    "    for kk in range(ntask+1):\n",
    "        indCLt = []\n",
    "        labelY_current_temp = labelY_train[kk]\n",
    "        for iji in range(2*kk+4):\n",
    "            indCLt = np.concatenate([indCLt,np.where(np.argmax(labelY_current_temp,axis=1)==iji)[0]]) \n",
    "        indCLt = indCLt.astype(dtype=int)\n",
    "        dataY_train_current_temp = dataY_train1[kk]\n",
    "        if kk == 0:\n",
    "            \n",
    "            labelY_current = labelY_current_temp[indCLt[:int(buffersize/(ntask+1))],:2*ntask+4]         \n",
    "            dataY_train_current = dataY_train_current_temp[indCLt[:int(buffersize/(ntask+1))],:] \n",
    "        if kk > 0 and kk < ntask:\n",
    "            labelY_current =np.concatenate([labelY_current, labelY_current_temp[indCLt[:int(buffersize/(ntask+1))],:2*ntask+4]] ,axis=0 )        \n",
    "            dataY_train_current = np.concatenate([dataY_train_current, dataY_train_current_temp[indCLt[:int(buffersize/(ntask+1))],:]],axis=0 )\n",
    "        if kk == ntask:\n",
    "            labelY_current =np.concatenate([labelY_current, labelY_current_temp[indCLt,:2*ntask+4]] ,axis=0 )        \n",
    "            dataY_train_current = np.concatenate([dataY_train_current, dataY_train_current_temp[indCLt,:]],axis=0 )\n",
    "            \n",
    "\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",
    "    for iji in range(2):\n",
    "        indCLt = np.concatenate([indCLt,np.where(np.argmax(labelX_train,axis=1)==iji)[0]])\n",
    "    indCLt = indCLt.astype(dtype=int)\n",
    "    labelX_train_current = labelX_train[indCLt[:int(buffersize/(ntask+1))],:2*ntask+4] \n",
    "    dataX_train_current = dataX_train1[indCLt[:int(buffersize/(ntask+1))],:] \n",
    "    \n",
    "    labelY_current =np.concatenate([labelY_current,labelX_train_current] ,axis=0)\n",
    "    dataY_train_current = np.concatenate([dataY_train_current,dataX_train_current] ,axis=0 )\n",
    "\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",
    "\n",
    "        trainDataYtot =  trainDataY \n",
    "        trainLabelYtot = trainLabelY \n",
    "\n",
    "\n",
    "        \n",
    "          \n",
    "        loss.append(trainT(inputs=[trainDataYtot,trainLabelYtot]))\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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf[-1] = testXperf\n",
    "with open('Buffer.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('Buffer.json', 'r') as fp:\n",
    "    data = json.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Testing Accuracy')"
      ]
     },
     "execution_count": 33,
     "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"
   ]
  },
  {
   "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": [
    "indCL = np.concatenate([np.where(np.argmax(labelX_test,axis=1)==0)[0],np.where(np.argmax(labelX_test,axis=1)==1)[0]])\n",
    "temp1lab = labelX_test[indCL,:] \n",
    "temp1data = dataX_test1[indCL,:] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "TempLab = {}\n",
    "TempLab[0] = temp1lab\n",
    "TempData = {}\n",
    "TempData[0] = temp1data\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for ntask in range(numtasks):        \n",
    "    labelY_test_pre = labelY_test[ntask]    \n",
    "    indCLt = []\n",
    "    for iji in range(2*ntask+4):\n",
    "        indCLt = np.concatenate([indCLt,np.where(np.argmax(labelY_test_pre,axis=1)==iji)[0]]) \n",
    "    indCLt = indCLt.astype(int)\n",
    "    labelY_test_pre = labelY_test_pre[indCLt,:] \n",
    "    dataY_test_pre = dataY_test1[ntask]\n",
    "    dataY_test_pre = dataY_test_pre[indCLt,:]            \n",
    "    TempLab[ntask+1] = labelY_test_pre\n",
    "    TempData[ntask+1] = dataY_test_pre\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#plt.imshow(np.reshape(TempData[2][1,:],[28,28]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "temp1 = encoderX.predict(TempData[0])\n",
    "temp2 = encoderX.predict(TempData[1])\n",
    "temp3 = encoderX.predict(TempData[2])\n",
    "temp4 = encoderX.predict(TempData[3])\n",
    "temp5 = encoderX.predict(TempData[4])\n",
    " \n",
    "xtrainDataToT = np.concatenate((temp1,temp2,temp3,temp4,temp5 ), axis=0)\n",
    "xtrainlabelTot = np.argmax( np.concatenate((TempLab[0],TempLab[1],TempLab[2],TempLab[3],TempLab[4] ), axis=0),axis=1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "classifier = Classifiers[4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "labper1 = np.argmax(classifier.predict(temp1),axis=1)\n",
    "labper2 = np.argmax(classifier.predict(temp2),axis=1)\n",
    "labper3 = np.argmax(classifier.predict(temp3),axis=1)\n",
    "labper4 = np.argmax(classifier.predict(temp4),axis=1)\n",
    "labper5 = np.argmax(classifier.predict(temp5),axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(float((1*(labper1 == np.argmax(TempLab[0],axis=1))).sum())/labper1.shape[0])\n",
    "print(float((1*(labper2 == np.argmax(TempLab[1],axis=1))).sum())/labper2.shape[0])\n",
    "print(float((1*(labper3 == np.argmax(TempLab[2],axis=1))).sum())/labper3.shape[0])\n",
    "print(float((1*(labper4 == np.argmax(TempLab[3],axis=1))).sum())/labper4.shape[0])\n",
    "print(float((1*(labper5 == np.argmax(TempLab[4],axis=1))).sum())/labper5.shape[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "umapperT=umap.UMAP()\n",
    "xumapT=umapperT.fit_transform(xtrainDataToT)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(  figsize=(10, 10))\n",
    "plt.scatter(xumapT[:,0],xumapT[:,1],c=xtrainlabelTot,cmap='tab10',linewidth=1,s=.1)\n",
    "\n",
    "\n",
    "plt.grid()\n",
    "plt.tick_params(labelsize=20)\n",
    "\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(  figsize=(10, 10))\n",
    "\n",
    "plt.scatter(xumapT[:TempData[0].shape[0],0],xumapT[:TempData[0].shape[0],1],color = 'r',linewidth=1,s=1)\n",
    "plt.scatter(xumapT[TempData[0].shape[0]:TempData[0].shape[0]+TempData[1].shape[0],0],xumapT[TempData[0].shape[0]:TempData[0].shape[0]+TempData[1].shape[0],1],color = 'black',linewidth=2,s=2)\n",
    "plt.scatter(xumapT[TempData[1].shape[0]:TempData[1].shape[0]+TempData[2].shape[0],0],xumapT[TempData[1].shape[0]:TempData[1].shape[0]+TempData[2].shape[0],1],color = 'g',linewidth=1,s=1)\n",
    "plt.scatter(xumapT[TempData[2].shape[0]:TempData[2].shape[0]+TempData[3].shape[0],0],xumapT[TempData[2].shape[0]:TempData[2].shape[0]+TempData[3].shape[0],1],color = 'r',linewidth=1,s=1)\n",
    "plt.scatter(xumapT[TempData[3].shape[0]:TempData[3].shape[0]+TempData[4].shape[0],0],xumapT[TempData[3].shape[0]:TempData[3].shape[0]+TempData[4].shape[0],1],color = 'brown',linewidth=1,s=1)\n",
    "plt.scatter(xumapT[TempData[4].shape[0]:,0],xumapT[TempData[4].shape[0]:,1],color = 'orange',linewidth=1,s=1)\n",
    "\n",
    "\n",
    "plt.grid()\n",
    "plt.tick_params(labelsize=20)\n",
    "\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# save_model(classifier,filepath='classifierEXTNIPSfull.h5')\n",
    "# save_model(decoderX,filepath='decoderXEXTNIPSfull.h5')\n",
    "# save_model(encoderX,filepath='encoderXEXTNIPSfull.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": []
  }
 ],
 "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
}
