{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"3\"\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=64 # This is the dimension of intermediate latent variable \n",
    "epochs = 50* 50\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize= 200 \n",
    "nofprojections = 40"
   ]
  },
  {
   "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": 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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f4f341644a8>"
      ]
     },
     "execution_count": 7,
     "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": 8,
   "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": 9,
   "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": 10,
   "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": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "encoderX = encoderXNN(imgX,zdim)\n",
    "yin =  Input(shape=(zdim,) )\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training on Task 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 720x720 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "lamda2=1e-3\n",
    "\n",
    "thres = .95\n",
    "lamda=4e0\n",
    "Classifier = []\n",
    "Encoder = []\n",
    "Decoder = []\n",
    "GMMs = []\n",
    "\n",
    "fig=plt.figure(figsize=(10,10))\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": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5977"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "for cl in range(9):\n",
    "    # extract the dataset\n",
    "    #for jj in range(cl+1):\n",
    "    classifier = classifierNN(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,:cl+2] \n",
    "        dataX_train1CL =  dataX_train[indCL,:] \n",
    "        indCLtot = indCL\n",
    "    else:        \n",
    "        tempind = np.where(np.argmax(labelX_train,axis=1)==cl+1)[0]\n",
    "        indCLtot = np.concatenate([indCLtot,tempind])\n",
    "        indCLtot = np.random.permutation(indCLtot)\n",
    "        \n",
    "        buffersize = 50\n",
    "        indCL = np.concatenate([indCLtot[:buffersize],tempind])\n",
    "        \n",
    "        xreptrainlabelonehotExtended = labelX_train[indCL,:cl+2] \n",
    "        labelX_trainCL =  labelX_train[indCL,:cl+2] \n",
    "        dataX_train1CL =  dataX_train[indCL,:] \n",
    "        \n",
    "\n",
    "    labelX=K.placeholder(shape=(None,cl+2),dtype='float32') #labels of input images oneHot\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",
    "    myLoss=  discriminationLoss\n",
    "     \n",
    "  \n",
    "    params=encoderX.weights   + classifier.weights\n",
    "\n",
    "    \n",
    "    \n",
    "    #loss=[]\n",
    "    \n",
    "    \n",
    "    \n",
    "    opt = Adam(lr=1e-4)\n",
    "    updates = opt.get_updates(myLoss,params)\n",
    "    train = K.function(inputs=[imgX,labelX],outputs=[discriminationLoss],updates=updates)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    for itr in range(epochs):\n",
    "        \n",
    "        indTrainDataX,trainLabelX=batchGenerator(labelX_trainCL,batchsize,nofclasses=cl+2)\n",
    "        trainDataX=dataX_train1CL[indTrainDataX,...]\n",
    "        \n",
    "        \n",
    "  \n",
    "        loss.append(train(inputs=[trainDataX,trainLabelX]))\n",
    "  \n",
    "        if itr%epochstep==0: \n",
    "\n",
    "            for jj in range(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(2, 1, 1)\n",
    "            plt.plot(np.asarray(loss))\n",
    "            \n",
    "            plt.subplot(2, 1, 2)\n",
    "            plt.plot(np.asarray(testXperf))\n",
    "            \n",
    "            display.clear_output(wait=True)\n",
    "            display.display(plt.gcf()) \n",
    "            time.sleep(1e-3) \n",
    "    Classifier.append(classifier)  \n",
    "      \n",
    "    \n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf = testXperf \n",
    "with open('MNIST-MB-50.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  }
 ],
 "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
}
