{
 "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",
    "import csv\n",
    "import keras.utils\n",
    "from tensorflow.keras import backend as K\n",
    "from tensorflow.keras.datasets import mnist\n",
    "from tensorflow.keras.models import save_model,load_model,Model\n",
    "from tensorflow.keras.optimizers import Adam, RMSprop, Adamax\n",
    "from tensorflow.keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from tensorflow.keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from tensorflow.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",
    "from PIL import Image\n",
    "from sklearn.cluster import KMeans\n",
    "from tensorflow.keras import regularizers\n",
    "from tensorflow.keras.applications.resnet50 import ResNet50\n",
    "from tensorflow.keras.preprocessing import image\n",
    "from tensorflow.keras.applications.resnet50 import preprocess_input, decode_predictions\n",
    "\n",
    "from tensorflow.keras.layers import Input, Conv2D, Activation, BatchNormalization, GlobalAveragePooling2D, Dense, Dropout\n",
    "from tensorflow.keras.activations import relu, softmax\n",
    "from tensorflow.keras.models import Model\n",
    "from tensorflow.keras import regularizers\n",
    "\n",
    "from tensorflow.keras.models import Sequential\n",
    "from tensorflow.keras.layers import Dense, Dropout, Flatten\n",
    "from tensorflow.keras.applications.resnet50 import ResNet50\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow.keras.layers as layers\n",
    "from tensorflow.keras.models import Model\n",
    "from tensorflow.keras.preprocessing import image\n",
    "from tensorflow.keras.initializers import glorot_uniform\n",
    "from tensorflow.keras.optimizers import SGD\n",
    "from array import array \n",
    "import json\n",
    "\n",
    "\n",
    "import os\n",
    "cwd = os.getcwd()\n",
    "\n",
    "from scipy.io import loadmat\n",
    "from PIL import Image\n",
    "from skimage.transform import rescale, resize\n",
    "from skimage.color import rgb2gray\n",
    "from sklearn.metrics import pairwise_distances_argmin_min"
   ]
  },
  {
   "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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/.local/lib/python3.7/site-packages/tensorflow/python/compat/v2_compat.py:96: disable_resource_variables (from tensorflow.python.ops.variable_scope) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "non-resource variables are not supported in the long term\n"
     ]
    }
   ],
   "source": [
    "import tensorflow.compat.v1 as tf\n",
    "tf.disable_v2_behavior()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ! pip install --user umap-learn\n",
    "# ##! pip uninstall --user keras\n",
    "# ! pip install --user keras==2.1.6\n",
    "# ! pip install --user matplotlib\n",
    "# ! pip install --user np_utils\n",
    "# ! pip install --user  Pillow"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "cwd = os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=10 # This is the dimension of intermediate latent variable \n",
    "epochs = 6000\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=200 \n",
    "nofprojections = 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def getData(nMNIST,nUSPS,nSVHN):\n",
    "    \n",
    "    \n",
    "    #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)\n",
    "\n",
    "\n",
    "    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]) \n",
    "\n",
    "\n",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/USPSDataset/Numerals'\n",
    "    savedImg = []\n",
    "\n",
    "    for j in range(0,10):\n",
    "        curFolderPath = curPath + '/' + str(j) \n",
    "        imgs =  os.listdir(curFolderPath)\n",
    "        for img in imgs:\n",
    "            curImg = curFolderPath + '/' + img\n",
    "            if curImg[-3:] == 'png':\n",
    "                img = Image.open(curImg,'r')\n",
    "                img = img.resize((28, 28))\n",
    "                savedImg = img\n",
    "                tempim = np.array(img.getdata())\n",
    "                tempim = np.reshape(tempim,[28,28])\n",
    "                imgdata = ((255-tempim).astype(float))/255\n",
    "                USPSMat.append(imgdata)\n",
    "                USPSTar.append(j)\n",
    "\n",
    "\n",
    "    dataY_train1 = np.array(USPSMat)\n",
    "    USPSTar = np.array(USPSTar)\n",
    "    labelY_train = keras.utils.to_categorical(USPSTar, nofclasses)\n",
    "\n",
    "    dataY_train = np.zeros([len(USPSMat),28,28,1])\n",
    "    for i in range(len(USPSMat)):\n",
    "        dataY_train[i,:,:,0] = USPSMat[i]   \n",
    "\n",
    "\n",
    "    USPSMattest  = []\n",
    "    USPSTartest  = []\n",
    "    curPathtest  = r'/nas/home/USPSDataset/Test'\n",
    "    savedImgtest = []\n",
    "\n",
    "    curFolderPathtest = curPathtest \n",
    "    imgs =  os.listdir(curFolderPathtest)\n",
    "    for img in imgs:\n",
    "        curImg = curFolderPathtest+'/'+img \n",
    "        if curImg[-3:] == 'png':\n",
    "            imgt = Image.open(curImg,'r')\n",
    "            imgt = imgt.resize((28, 28))\n",
    "            savedImg = imgt\n",
    "            lab =9- int(int(img[-8:-4])/150)        \n",
    "            tempim = np.array(imgt.getdata())\n",
    "            tempim = np.reshape(tempim,[28,28])\n",
    "            imgdata = ((255-tempim).astype(float))/255        \n",
    "            USPSMattest.append(imgdata)\n",
    "            USPSTartest.append(lab)\n",
    "\n",
    "\n",
    "    dataY_test1 = np.array(USPSMattest)\n",
    "    USPSTartest = np.array(USPSTartest)\n",
    "    labelY_test = keras.utils.to_categorical(USPSTartest, nofclasses)\n",
    "\n",
    "\n",
    "    dataY_test = np.zeros([len(USPSMattest),28,28,1])\n",
    "    for i in range(len(USPSMattest)):\n",
    "        dataY_test[i,:,:,0] = USPSMattest[i]\n",
    "\n",
    "\n",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/SVHNdataset/'\n",
    "    savedImg = []\n",
    "\n",
    "    train = loadmat(curPath+'train_32x32.mat')\n",
    "    test = loadmat(curPath+'test_32x32.mat')\n",
    "\n",
    "    # train and test are python dictionaries\n",
    "    # keys are ['__header__', '__version__', '__globals__', 'X', 'y']\n",
    "\n",
    "    zX_train = train['X']\n",
    "    zy_train = train['y']\n",
    "    zX_test = test['X']\n",
    "    zy_test = test['y']\n",
    "\n",
    "    zX_train = np.rollaxis(zX_train, 3)\n",
    "    zX_test = np.rollaxis(zX_test, 3)\n",
    "\n",
    "\n",
    "    zy_train1 = zy_train\n",
    "    zy_test1 = zy_test\n",
    "    zy_train = np.zeros(zy_train1.shape[0])\n",
    "    zy_test = np.zeros(zy_test.shape[0])\n",
    "\n",
    "    for i in range(zy_test.shape[0]):\n",
    "        zy_test[i] = zy_test1[i][0]\n",
    "        if zy_test[i]==10:\n",
    "            zy_test[i] = 0\n",
    "\n",
    "    for i in range(zy_train.shape[0]):\n",
    "        zy_train[i] = zy_train1[i][0]\n",
    "        if zy_train[i]==10:\n",
    "            zy_train[i] = 0\n",
    "\n",
    "    labelZ_train = keras.utils.to_categorical(zy_train, nofclasses)\n",
    "    labelZ_test = keras.utils.to_categorical(zy_test, nofclasses)\n",
    "\n",
    "    dataZ_train = np.zeros([zy_train1.shape[0],28,28,1])\n",
    "    dataZ_test = np.zeros([zy_test1.shape[0],28,28,1])\n",
    "\n",
    "\n",
    "    for i in range(zX_train.shape[0]):\n",
    "        dataZ_train[i,:,:,0] =  resize(rgb2gray(zX_train[i,:,:,0]),[28,28])\n",
    "\n",
    "    for i in range(zX_test.shape[0]):\n",
    "        dataZ_test[i,:,:,0] =  resize(rgb2gray(zX_test[i,:,:,0]),[28,28])\n",
    "\n",
    "\n",
    "    task1 = nMNIST\n",
    "    task2 = nUSPS\n",
    "    task3 = nSVHN\n",
    " \n",
    "    DATAX_train = {}\n",
    "    DATAY_train = {}\n",
    "    DATAX_test = {}\n",
    "    DATAY_test = {}\n",
    "    # MNIST\n",
    "    DATAX_train[task1] = dataX_train\n",
    "    DATAY_train[task1] = labelX_train\n",
    "    DATAX_test[task1] = dataX_test\n",
    "    DATAY_test[task1] = labelX_test\n",
    "    # USPS\n",
    "    DATAX_train[task2] = dataY_train\n",
    "    DATAY_train[task2] = labelY_train\n",
    "    DATAX_test[task2] = dataY_test\n",
    "    DATAY_test[task2] = labelY_test\n",
    "    # SVHN\n",
    "    DATAX_train[task3] = dataZ_train\n",
    "    DATAY_train[task3] = labelZ_train\n",
    "    DATAX_test[task3] = dataZ_test\n",
    "    DATAY_test[task3] = labelZ_test\n",
    "    \n",
    "    return DATAX_train, DATAY_train, DATAX_test, DATAY_test"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###  X is input and Z the embedding space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# classifier = load_model(filepath='classifierEXT.h5')\n",
    "# encoderX = load_model(filepath='encoderXEXT.h5')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Encoder, Decoder and Classifier NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ClassifierNN(imgX,nofclasses):\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(nofclasses, activation='relu')(x)\n",
    "    encoderX = Model(imgX, embed)\n",
    "\n",
    "    return encoderX\n",
    "\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def    classifierNN(nofclasses):\n",
    "    yin =  Input(shape=( nofclasses,) )\n",
    "\n",
    "    probX = Dense(nofclasses, activation='softmax')(yin)\n",
    "\n",
    "\n",
    "    classifier=Model(inputs=[yin],outputs=[probX])\n",
    "    return classifier\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def myGMMfit(encoderX,classifier,dataX_train,labelX_train,nofclasses):\n",
    "    gmmX = encoderX.predict(dataX_train)\n",
    "    gmmY = np.argmax(labelX_train,axis=1)\n",
    "\n",
    "\n",
    "    yper = classifier.predict(encoderX.predict(dataX_train))\n",
    "    yper = np.argmax(yper, axis=1)\n",
    "\n",
    "\n",
    "    gmmX = gmmX[gmmY==yper,:]\n",
    "    gmmY = gmmY[gmmY==yper]\n",
    "\n",
    "    gmmModel =  GaussianMixture(n_components=nofclasses,covariance_type='full', max_iter=300,init_params='kmeans', tol=1e-04) \n",
    "\n",
    "\n",
    "    gmmModel.fit(gmmX,gmmY)\n",
    "\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 #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",
    "\n",
    "    return gmmModel\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def buffSelection(encoderX,gmmModel,dataX_train,labelX_train,sizeperCl):\n",
    "    \n",
    "    gmmX = encoderX.predict(dataX_train)\n",
    "    gmmY = np.argmax(labelX_train,axis=1)\n",
    "\n",
    "    for i in range(nofclasses):\n",
    "        \n",
    "        ind = np.where(np.argmax(labelX_train,axis=1)==i)[0] \n",
    "        tempdataembed = gmmX[ind,:]\n",
    "        tempData = dataX_train[ind,:]\n",
    "        probabs = np.max(gmmModel.predict_proba(tempdataembed),axis=1) \n",
    "        if i == 0:\n",
    "            buffData = tempData[probabs.argsort()[-sizeperCl:][::-1],:] \n",
    "            buffLab = i*np.ones([sizeperCl,1])\n",
    "        else:\n",
    "            buffData = np.concatenate([buffData,tempData[probabs.argsort()[-sizeperCl:][::-1],:]],axis=0)\n",
    "            buffLab = np.concatenate([buffLab,i*np.ones([sizeperCl,1])])\n",
    "    buffLab = keras.utils.to_categorical(buffLab, labelX_train.shape[1])\n",
    "    return buffData, buffLab   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "def Learnseq(nMNIST,nUSPS,nSVHN):\n",
    "    \n",
    "    DATAX_train, DATAY_train, DATAX_test, DATAY_test = getData(nMNIST,nUSPS,nSVHN)\n",
    "    sizeperCl = 10\n",
    "    nofclasses = 10\n",
    "    Results1 = []\n",
    "    Results2 = []\n",
    "    Results3 = []\n",
    "    epochs = 6000\n",
    "    epochstep = epochs/100\n",
    "    for ntask in range(3):\n",
    "\n",
    "        if ntask == 0:\n",
    "            dataX_train = DATAX_train[ntask]\n",
    "            labelX_train = DATAY_train[ntask]\n",
    "            dataX_test = DATAX_test[ntask]\n",
    "            labelX_test = DATAY_test[ntask]\n",
    "\n",
    "\n",
    "            classifier = classifierNN(nofclasses)\n",
    "            encoderX = ClassifierNN(imgX,nofclasses)\n",
    "\n",
    "            discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX)))) \n",
    "            params=encoderX.weights  + classifier.weights  \n",
    "            myLoss = discriminationLoss\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)\n",
    "\n",
    "            loss = []\n",
    "            fig,ax=plt.subplots(1,figsize=(10,10))\n",
    "\n",
    "            for itr in range(epochs):\n",
    "\n",
    "                indTrainDataX,trainLabelX=batchGenerator(labelX_train,batchsize,nofclasses=10)\n",
    "                trainDataX=dataX_train[indTrainDataX,...]\n",
    "                loss.append(train(inputs=[trainDataX, trainLabelX ]))\n",
    "\n",
    "\n",
    "                if itr%epochstep==0:\n",
    "                    perd_label_X = classifier.predict(encoderX.predict(DATAX_test[0]))\n",
    "                    perd_label_Y = classifier.predict(encoderX.predict(DATAX_test[1]))\n",
    "                    perd_label_Z = classifier.predict(encoderX.predict(DATAX_test[2]))\n",
    "                    Results1.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(DATAY_test[0]),axis=1))))/DATAX_test[0].shape[0])\n",
    "                    Results2.append(100*float(sum(1*(np.argmax(perd_label_Y,axis=1)==np.argmax(np.squeeze(DATAY_test[1]),axis=1))))/DATAX_test[1].shape[0])\n",
    "                    Results3.append(100*float(sum(1*(np.argmax(perd_label_Z,axis=1)==np.argmax(np.squeeze(DATAY_test[2]),axis=1))))/DATAX_test[2].shape[0])\n",
    "\n",
    "\n",
    "            # GMM fiting and buffer      \n",
    "            gmmModel = myGMMfit(encoderX,classifier,dataX_train,labelX_train,nofclasses)\n",
    "            buffData, buffLab   = buffSelection(encoderX,gmmModel,dataX_train,labelX_train,sizeperCl)\n",
    "\n",
    "\n",
    "        else:\n",
    "\n",
    "            dataY_train = DATAX_train[ntask]\n",
    "            labelY_train = DATAY_train[ntask]\n",
    "            dataY_test = DATAX_test[ntask]\n",
    "            labelY_test = DATAY_test[ntask]\n",
    "\n",
    "            imgY = Input(shape=(nofclasses,) )  # adapt this if using `channels_first` image data format\n",
    "            labelY=K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "            lamda2=1e-2\n",
    "            theta=tf.keras.backend.placeholder(shape = (nofprojections, nofclasses), dtype='float32')\n",
    "            labelW =  K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "            imgW = Input(shape=(28, 28, 1) )  \n",
    "\n",
    "            discriminationLoss= K.mean(K.categorical_crossentropy(labelY,classifier(imgY)))   \\\n",
    "                                + K.mean(K.categorical_crossentropy(labelW,classifier(encoderX(imgW))))   \n",
    "            matchingLoss=sWasserstein(encoderX(imgX),imgY,theta,nclass=nofclasses,Cp=None,Cq=None,)+\\\n",
    "                            sWasserstein(encoderX(imgX),encoderX(imgW),theta,nclass=nofclasses,Cp=None,Cq=None,)+\\\n",
    "                            sWasserstein(encoderX(imgW),imgY,theta,nclass=nofclasses,Cp=None,Cq=None,)\n",
    "            myLoss=  lamda2*matchingLoss  + discriminationLoss  \n",
    "            params=encoderX.weights  + classifier.weights  \n",
    "            opt = Adam(lr=1e-4) # very important\n",
    "            updates = opt.get_updates(myLoss,params)\n",
    "            train = K.function(inputs=[imgX,imgY,labelY,theta,imgW, labelW],outputs=[lamda2*matchingLoss],updates=updates)\n",
    "\n",
    "\n",
    "\n",
    "            thres = .9\n",
    "            fig,ax=plt.subplots(1,figsize=(10,10))\n",
    "            epochs2 = 50 * 100\n",
    "            epochstep = epochs2/100\n",
    "\n",
    "            for itr in range(epochs2):\n",
    "                indTrainDataY,trainLabelY=batchGenerator(labelY_train,batchsize,nofclasses=10)\n",
    "                trainDataY=dataY_train[indTrainDataY,...]\n",
    "\n",
    "                indTrainDataX,trainLabelX=batchGenerator(buffLab,batchsize,nofclasses=nofclasses)\n",
    "                trainDataX=buffData[indTrainDataX,...]    \n",
    "\n",
    "                Yembed,Yembedlabel1  = gmmModel.sample(n_samples=20*batchsize)\n",
    "                Yembedlabel = keras.utils.to_categorical(Yembedlabel1)   \n",
    "\n",
    "\n",
    "                theta_=generateTheta(nofprojections,nofclasses)\n",
    "                loss.append(train(inputs=[trainDataY,Yembed,Yembedlabel,theta_ ,trainDataX, trainLabelX ]))\n",
    "\n",
    "\n",
    "\n",
    "                if itr%epochstep==0:\n",
    "                    perd_label_X = classifier.predict(encoderX.predict(DATAX_test[0]))\n",
    "                    perd_label_Y = classifier.predict(encoderX.predict(DATAX_test[1]))\n",
    "                    perd_label_Z = classifier.predict(encoderX.predict(DATAX_test[2]))\n",
    "                    Results1.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(DATAY_test[0]),axis=1))))/DATAY_test[0].shape[0])\n",
    "                    Results2.append(100*float(sum(1*(np.argmax(perd_label_Y,axis=1)==np.argmax(np.squeeze(DATAY_test[1]),axis=1))))/DATAY_test[1].shape[0])\n",
    "                    Results3.append(100*float(sum(1*(np.argmax(perd_label_Z,axis=1)==np.argmax(np.squeeze(DATAY_test[2]),axis=1))))/DATAY_test[2].shape[0])\n",
    "\n",
    "\n",
    "\n",
    "            if ntask == 2:\n",
    "                break\n",
    "\n",
    "\n",
    "            # GMM fiting and buffer  \n",
    "\n",
    "    #         dataX_temp =  np.concatenate([buffData,dataY_train],axis=0)\n",
    "    #         labelX_temp = np.concatenate([buffLab,labelY_train],axis=0)\n",
    "            gmmModel = myGMMfit(encoderX,classifier,dataY_train,labelY_train,nofclasses)\n",
    "            buffDatatemp, buffLabtemp   = buffSelection(encoderX,gmmModel,dataY_train,labelY_train,sizeperCl)\n",
    "\n",
    "            buffData = np.concatenate([buffData,buffDatatemp],axis=0)\n",
    "            buffLab = np.concatenate([buffLab,buffLabtemp],axis=0)\n",
    "\n",
    "    return Results1, Results2, Results3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/nas/home/anaconda3/envs/tf1/lib/python3.7/site-packages/ipykernel_launcher.py:125: FutureWarning: The behavior of rgb2gray will change in scikit-image 0.19. Currently, rgb2gray allows 2D grayscale image to be passed as inputs and leaves them unmodified as outputs. Starting from version 0.19, 2D arrays will be treated as 1D images with 3 channels.\n",
      "/nas/home/anaconda3/envs/tf1/lib/python3.7/site-packages/ipykernel_launcher.py:128: FutureWarning: The behavior of rgb2gray will change in scikit-image 0.19. Currently, rgb2gray allows 2D grayscale image to be passed as inputs and leaves them unmodified as outputs. Starting from version 0.19, 2D arrays will be treated as 1D images with 3 channels.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/.local/lib/python3.7/site-packages/tensorflow/python/keras/engine/training_v1.py:2070: Model.state_updates (from tensorflow.python.keras.engine.training) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "This property should not be used in TensorFlow 2.0, as updates are applied automatically.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/nas/home/.local/lib/python3.7/site-packages/tensorflow/python/framework/indexed_slices.py:432: UserWarning: Converting sparse IndexedSlices to a dense Tensor of unknown shape. This may consume a large amount of memory.\n",
      "  \"Converting sparse IndexedSlices to a dense Tensor of unknown shape. \"\n",
      "/nas/home/.local/lib/python3.7/site-packages/tensorflow/python/framework/indexed_slices.py:432: UserWarning: Converting sparse IndexedSlices to a dense Tensor of unknown shape. This may consume a large amount of memory.\n",
      "  \"Converting sparse IndexedSlices to a dense Tensor of unknown shape. \"\n",
      "/nas/home/anaconda3/envs/tf1/lib/python3.7/site-packages/ipykernel_launcher.py:125: FutureWarning: The behavior of rgb2gray will change in scikit-image 0.19. Currently, rgb2gray allows 2D grayscale image to be passed as inputs and leaves them unmodified as outputs. Starting from version 0.19, 2D arrays will be treated as 1D images with 3 channels.\n",
      "/nas/home/anaconda3/envs/tf1/lib/python3.7/site-packages/ipykernel_launcher.py:128: FutureWarning: The behavior of rgb2gray will change in scikit-image 0.19. Currently, rgb2gray allows 2D grayscale image to be passed as inputs and leaves them unmodified as outputs. Starting from version 0.19, 2D arrays will be treated as 1D images with 3 channels.\n",
      "/nas/home/.local/lib/python3.7/site-packages/tensorflow/python/framework/indexed_slices.py:432: UserWarning: Converting sparse IndexedSlices to a dense Tensor of unknown shape. This may consume a large amount of memory.\n",
      "  \"Converting sparse IndexedSlices to a dense Tensor of unknown shape. \"\n",
      "/nas/home/.local/lib/python3.7/site-packages/tensorflow/python/framework/indexed_slices.py:432: UserWarning: Converting sparse IndexedSlices to a dense Tensor of unknown shape. This may consume a large amount of memory.\n",
      "  \"Converting sparse IndexedSlices to a dense Tensor of unknown shape. \"\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlsAAAJDCAYAAAA8QNGHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAUgklEQVR4nO3dX4jld3nH8c9jYipotNBsQbKJCXRTTVWIHdIULwyYliQXmwtbSUCsEtybRmwVIaKoxCuVWhDiny2VVEHT6IUsuJKCjQTESFZsg0mILNGajUKixtwEjWmfXswo42R352Ryntk9yesFC/P7ne+c88CX2X3v75w5p7o7AADMeMGpHgAA4LlMbAEADBJbAACDxBYAwCCxBQAwSGwBAAzaNraq6nNV9UhVff8Et1dVfbKqjlbVPVX1uuWPCQCwmha5snVLkitPcvtVSfZt/DmQ5NPPfiwAgOeGbWOru+9M8ouTLLkmyed73V1J/rCqXr6sAQEAVtkyXrN1bpKHNh0f2zgHAPC8d+ZuPlhVHcj6U4158Ytf/OevfOUrd/PhAQB25Lvf/e7PunvPTr53GbH1cJLzNh3v3Tj3NN19MMnBJFlbW+sjR44s4eEBAGZV1f/s9HuX8TTioSRv3fitxMuSPN7dP13C/QIArLxtr2xV1ZeSXJ7knKo6luRDSV6YJN39mSSHk1yd5GiSJ5K8fWpYAIBVs21sdfd129zeSf5+aRMBADyHeAd5AIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAYtFFtVdWVVPVBVR6vqxuPcfn5V3VFV36uqe6rq6uWPCgCweraNrao6I8nNSa5KcnGS66rq4i3LPpDktu6+JMm1ST617EEBAFbRIle2Lk1ytLsf7O4nk9ya5JotazrJSze+flmSnyxvRACA1XXmAmvOTfLQpuNjSf5iy5oPJ/mPqnpnkhcnuWIp0wEArLhlvUD+uiS3dPfeJFcn+UJVPe2+q+pAVR2pqiOPPvrokh4aAOD0tUhsPZzkvE3HezfObXZ9ktuSpLu/neRFSc7ZekfdfbC717p7bc+ePTubGABghSwSW3cn2VdVF1bVWVl/AfyhLWt+nOSNSVJVr8p6bLl0BQA8720bW939VJIbktye5P6s/9bhvVV1U1Xt31j2niTvqKr/TvKlJG/r7p4aGgBgVSzyAvl09+Ekh7ec++Cmr+9L8vrljgYAsPq8gzwAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAgxaKraq6sqoeqKqjVXXjCda8uaruq6p7q+qLyx0TAGA1nbndgqo6I8nNSf4qybEkd1fVoe6+b9OafUnel+T13f1YVf3x1MAAAKtkkStblyY52t0PdveTSW5Ncs2WNe9IcnN3P5Yk3f3IcscEAFhNi8TWuUke2nR8bOPcZhcluaiqvlVVd1XVlcsaEABglW37NOIzuJ99SS5PsjfJnVX1mu7+5eZFVXUgyYEkOf/885f00AAAp69Frmw9nOS8Tcd7N85tdizJoe7+TXf/MMkPsh5fv6e7D3b3Wnev7dmzZ6czAwCsjEVi6+4k+6rqwqo6K8m1SQ5tWfPVrF/VSlWdk/WnFR9c3pgAAKtp29jq7qeS3JDk9iT3J7mtu++tqpuqav/GstuT/Lyq7ktyR5L3dvfPp4YGAFgV1d2n5IHX1tb6yJEjp+SxAQCeiar6bnev7eR7vYM8AMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMWii2qurKqnqgqo5W1Y0nWfemquqqWlveiAAAq2vb2KqqM5LcnOSqJBcnua6qLj7OurOTvCvJd5Y9JADAqlrkytalSY5294Pd/WSSW5Ncc5x1H0ny0SS/WuJ8AAArbZHYOjfJQ5uOj22c+52qel2S87r7a0ucDQBg5T3rF8hX1QuSfCLJexZYe6CqjlTVkUcfffTZPjQAwGlvkdh6OMl5m473bpz7rbOTvDrJN6vqR0kuS3LoeC+S7+6D3b3W3Wt79uzZ+dQAACtikdi6O8m+qrqwqs5Kcm2SQ7+9sbsf7+5zuvuC7r4gyV1J9nf3kZGJAQBWyLax1d1PJbkhye1J7k9yW3ffW1U3VdX+6QEBAFbZmYss6u7DSQ5vOffBE6y9/NmPBQDw3OAd5AEABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEFiCwBgkNgCABgktgAABoktAIBBYgsAYJDYAgAYtFBsVdWVVfVAVR2tqhuPc/u7q+q+qrqnqr5RVa9Y/qgAAKtn29iqqjOS3JzkqiQXJ7muqi7esux7Sda6+7VJvpLkY8seFABgFS1yZevSJEe7+8HufjLJrUmu2bygu+/o7ic2Du9Ksne5YwIArKZFYuvcJA9tOj62ce5Erk/y9WczFADAc8WZy7yzqnpLkrUkbzjB7QeSHEiS888/f5kPDQBwWlrkytbDSc7bdLx349zvqaorkrw/yf7u/vXx7qi7D3b3Wnev7dmzZyfzAgCslEVi6+4k+6rqwqo6K8m1SQ5tXlBVlyT5bNZD65HljwkAsJq2ja3ufirJDUluT3J/ktu6+96quqmq9m8s+3iSlyT5clX9V1UdOsHdAQA8ryz0mq3uPpzk8JZzH9z09RVLngsA4DnBO8gDAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMEhsAQAMElsAAIPEFgDAILEFADBIbAEADBJbAACDxBYAwCCxBQAwSGwBAAwSWwAAg8QWAMAgsQUAMGih2KqqK6vqgao6WlU3Huf2P6iqf9+4/TtVdcHSJwUAWEHbxlZVnZHk5iRXJbk4yXVVdfGWZdcneay7/yTJPyf56LIHBQBYRYtc2bo0ydHufrC7n0xya5Jrtqy5Jsm/bXz9lSRvrKpa3pgAAKtpkdg6N8lDm46PbZw77prufirJ40n+aBkDAgCssjN388Gq6kCSAxuHv66q7+/m47NU5yT52akegh2xd6vN/q0ue7fa/nSn37hIbD2c5LxNx3s3zh1vzbGqOjPJy5L8fOsddffBJAeTpKqOdPfaTobm1LN/q8verTb7t7rs3WqrqiM7/d5Fnka8O8m+qrqwqs5Kcm2SQ1vWHErydxtf/02S/+zu3ulQAADPFdte2erup6rqhiS3Jzkjyee6+96quinJke4+lORfk3yhqo4m+UXWgwwA4HlvoddsdffhJIe3nPvgpq9/leRvn+FjH3yG6zm92L/VZe9Wm/1bXfZute14/8qzfQAAc3xcDwDAoPHY8lE/q2uBvXt3Vd1XVfdU1Teq6hWnYk6Ob7v927TuTVXVVeW3pE4ji+xfVb1542fw3qr64m7PyPEt8Hfn+VV1R1V9b+Pvz6tPxZw8XVV9rqoeOdFbU9W6T27s7T1V9bpF7nc0tnzUz+pacO++l2Stu1+b9U8O+NjuTsmJLLh/qaqzk7wryXd2d0JOZpH9q6p9Sd6X5PXd/WdJ/mG35+TpFvzZ+0CS27r7kqz/QtmndndKTuKWJFee5Parkuzb+HMgyacXudPpK1s+6md1bbt33X1Hdz+xcXhX1t+DjdPDIj97SfKRrP8H51e7ORzbWmT/3pHk5u5+LEm6+5FdnpHjW2TvOslLN75+WZKf7OJ8nER335n1d1U4kWuSfL7X3ZXkD6vq5dvd73Rs+aif1bXI3m12fZKvj07EM7Ht/m1c/j6vu7+2m4OxkEV+/i5KclFVfauq7qqqk/1vnN2zyN59OMlbqupY1n/T/527MxpL8Ez/bUyyyx/Xw3NTVb0lyVqSN5zqWVhMVb0gySeSvO0Uj8LOnZn1pzIuz/pV5Tur6jXd/ctTORQLuS7JLd39T1X1l1l/n8pXd/f/nerBmDF9ZeuZfNRPTvZRP+y6RfYuVXVFkvcn2d/dv96l2djedvt3dpJXJ/lmVf0oyWVJDnmR/GljkZ+/Y0kOdfdvuvuHSX6Q9fji1Fpk765PcluSdPe3k7wo65+byOlvoX8bt5qOLR/1s7q23buquiTJZ7MeWl4vcno56f519+PdfU53X9DdF2T9NXf7u3vHn/3FUi3yd+dXs35VK1V1TtafVnxwF2fk+BbZux8neWOSVNWrsh5bj+7qlOzUoSRv3fitxMuSPN7dP93um0afRvRRP6trwb37eJKXJPnyxu80/Li795+yofmdBfeP09SC+3d7kr+uqvuS/G+S93a3ZwVOsQX37j1J/qWq/jHrL5Z/m4sMp4eq+lLW/xNzzsZr6j6U5IVJ0t2fyfpr7K5OcjTJE0nevtD92l8AgDneQR4AYJDYAgAYJLYAAAaJLQCAQWILAGCQ2AIAGCS2AAAGiS0AgEH/Dx30rkI5VNtIAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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": [
    "nMNIST = 2\n",
    "nUSPS = 1\n",
    "nSVHN = 0\n",
    "\n",
    "Results1, Results2, Results3 = Learnseq(nMNIST,nUSPS,nSVHN)\n",
    "\n",
    "nMNIST = 1\n",
    "nUSPS = 2\n",
    "nSVHN = 0\n",
    "\n",
    "Results11, Results21, Results31 = Learnseq(nMNIST,nUSPS,nSVHN)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApMAAAJxCAYAAAAemjl0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAACHs0lEQVR4nO3dd3hUVf7H8fdJqKH3ItJUBFEsoKiooCh2XbsrFtaCuta1rcqq6Ko/+9obNsS29rViJaLYAHsFFVApUoVAaEnO74/vDFMyk0wmM5nJzOf1PPfJ3HvPvffMYTJ8c6rz3iMiIiIikoyCTGdAREREROovBZMiIiIikjQFkyIiIiKSNAWTIiIiIpI0BZMiIiIikjQFkyIiIiKSNAWTIiIiIpK0ehNMOueKnHP7Ouf+5Zx73jk3xznnA9vYBO/RyTl3s3PuR+fcaufcUufc+865k51zLoHrN3HO3eecm+WcW+OcW+Sce8M5d1it36CIiIhIPeTqy6TlzrlhwKQ4p6/03o+t5vqBwBtAu8ChlUAToEFg/w3gIO/9ujjX7wc8AxQFDq0AmhMKyB8GTvL1pUBFREREUqDe1EwGLAPeAW4E/gosSOQi51wr4BUskPwB2N573wJoBpwJrAf2Bm6Nc30v4GkskJwCbO69bwW0Aq4KJPsbcGEyb0pERESkvqpPNZOF3vvyqGOzgR5UUzPpnPs38C9gNdDfez8r6vwlwLVAObCF935G1PkJwLFY8NrPe/9n1Pn7gNFYbWVP7/2y6t5P+/btfc+ePatLViurVq2iWbNmaX1GvlGZpp7KNPVUpqmnMk0tlWfqpbtMp0+fvth73yHWuQaxDmaj6ECyho4P/HwqOpAMuAO4FGu2HglcETzhnGsGBPtE3hMdSAb8HxZMtgT+gjV5V6lnz55MmzYtwewnp7i4mGHDhqX1GflGZZp6KtPUU5mmnso0tVSeqZfuMnXOzYl3rr41c9eYc25zoHtg9/VYabz3K4H3A7sjok7vAjSt5vrZwPdxrhcRERHJWTkfTAJbhr3+pop0wXNb1PL6/gnmS0RERKTey4dgsmvY67lVpAuea+mcax7j+mXe+9UJXN+1ijQiIiIiOSUfgskWYa9Lq0gXfq5FjNdVXRt+vkWVqURERERySL0ZgJMLnHOjsYE6dOrUieLi4rQ+b+XKlWl/Rr5RmaaeyjT1VKappzJNLZVn6mWyTPMhmCwJe12ETd8TS1HY65IYr8PPV3V9SbwE3vv7gfsBBg0a5NM9kk2j5VJPZZp6KtPUU5mmnso0tVSeqZfJMs2HZu55Ya83qiJd8NyKwOju6OvbOOeaEl/w+nlVpBERERHJKfkQTIaPwN4ybqrQue9qef23CeZLREREpN7Lh2ByBvBr4PU+sRIEJibfNbD7ZtTpD7CVc6q6vgfQL871IiIiIjkr54NJb+tFPhrYPdo51zNGsjOw1W/Kgcejrl8FPBfYPT2wzne0fwZ+lgAv1jLLIiIiIvVGvQomnXNtnHPtgxuh/BeFH4+aJxLgJmxd7SLgVefcwMD9GjnnTgf+HUh3f/S63AGXA6uALsDLzrnNAtc3c85dDpwWSHd1Iutyi4iIiOSK+jaa+3OgR4zjFwa2oPHAqOCO9365c+4A4A1shZtpzrkSoAnQMJDsTeAfsR7qvZ/lnDsSeAZrDp/hnFuO1WYWBpI9DNyY3NsSERERqZ/qVc1kbXjvp2NLHf4HmIkFkauwPpGnAPt679dWcf1rwABgHDAbC0SXAW8Bh3vvTww0qYuIiIjkjXpVM+m971nL6/8AzgtsyVz/M4FJx0VEREQkj2omRURERCT1FEyKiIiISNIUTIqIiIhI0hRMioiIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiKTJ6tWrGTt2LCNGjGDMmDH89NNPtb5naWkpt956K/vuuy8VFRUpyGXtNMh0BkRERERyyerVq3nttdf48ssveeCBB5g/fz4Ab731Ftdeey2DBw9m1KhRnHbaaZWuHT9+PN26dWPHHXdkypQprFmzhu22245u3boBMHfuXEaMGMF3330HwMSJE9lvv/3q7s3FoGBSREREcsbatWtZtWoVbdq0wTlXJ8/03vP666/z0ksvsXDhQiZPnsySJUvipv/kk09o3rx5zGDy0Ucf5d133610vHfv3gwYMICXX36Z8vLyDcdvueUWBZMiIiIitVVRUcHtt9/O5ZdfTklJCQ0bNmTnnXdm/Pjx9OjRY0O6uXPnMmnSJPr27csmm2zChx9+SGFhIbvssgvLly/n66+/Zs6cOTRp0oShQ4fSs2fPKp/rveeyyy7jmmuuqVF+Z82aFfN4v379YgaTv/zyC7/88kul4x988AHz5s2r0bNTTcGkiCSlogLGjoWnn4ZddoE77oCmTTOdKxGpz/744w/uvPNOLr30UpqGfaFMmzaNyy+/nNLSUrp3745zjhYtWnDIIYfw888/M2HCBKZNm8aaNWs2XLN+/Xree+89Dj30UD7++GMaNmwIwOzZsznuuOMSztOWW25Jnz59WL58OWVlZbzzzjsUFhZuOO+c488//0z4Xt988w0Av/76K+Xl5RH3Aujbt2/Cedt///158MEH6dSpEzNmzEj4ulRTMCmSJyoqoCCFQ+5uuw3+/W97/eOP0KAB3Htv/PS//ALnnw/vvw9/+Qvcf39q8yMi2c17z7fffsuvv/7Kl19+yVZbbcXvv//Oa6+9Rt++fSksLGTkyJGsXLmSdu3ace655264tnPnzvzyyy/8+OOPEfe86667qn3u999/z2effcbgwYMBGDJkCLvtthuTJ09OKN/ffPPNhgBw9913rxT8AUyaNKnSsRYtWrD33nvTvn17tttuO0488UQKCwuZMWMGb731FhUVFZSVlUXcr7y8nObNm1NYWEh5eTktW7akS5cuzJo1i3Xr1m1I55zj5JNP5u6776ZBg8yHcpnPgYik1bJlMHIkvP467LEHTJgAXbvW7p6//QaXXRZ57L774NhjrZYy2pNPwujRsHKl7W+yiQJJkfpm7ty53HzzzXz++ed06NCBQYMGceKJJ/L111/zwQcfsOOOO7LnnnvG7Kf43nvvcfbZZ/PVV19tOHbppZfGfdZ1113H6NGjKSoqAqBbt25MnjyZvfbaK+Ie1Rk8eDCPPvooffr0iTh+6aWXJhxMhtt3330rHfvjjz82DIYZOnQoRxxxBN26dWPo0KG0bt26Uvo+ffpUyk9QYWEho0aNYv/99+e3335jq622omHDhqxatYpJkybxyy+/0KlTJwYOHMimm25a4/ynjfdeWwa2gQMH+nSbNGlS2p+Rb+qyTL/+2vtjj/X+3HO9X7YsuXusXOn9Tjt5D6Gte3fvv/225vd6913vL7nE+/fe8/7AAyPvGdz69fN+7drI61591XvnQmmOPtr7iorQeX1OU09lmnr5Xqa33nqrLyoq8kCV29/+9rdK11ZUVPhNN9202mujt9tvv73SvaZOneqbNm0a95qCggJ/4IEH+s8//9xff/31fv369THz88knn/iWLVt6wHfq1Mm3b9/eA75Ro0Z+8ODB/qijjvK77LKLLywsjLj/119/Xel+q1ev9u+++66fNm2arwj/cqtj6f6MAtN8nJhGNZMiGfDnn9CqFSxfDldeCQsWQP/+cNBBMGAAfPst7LRTqCbv/fdtC3YhKi+HGTOgZ8/4/RTXrYPDDoOPPoo8/uuvsO22MHEi7L57/Dz++ivceKPlYc4cCLbi/N//xb/m++/h4Yfh1FNDx1q2hPbtYdEi299hB5g9G3r1in8fEakby5cvZ9myZTEHmVx77bWMGzeO2bNnJ3y/1atXVzrmnKNPnz41ml9xzJgxnHLKKRHH1qxZw5IlS7jjjjtYtmwZzzzzDJ9++ikAI0aM4PLLL2fLLbekVatWAGyzzTYx7+2cY4cddmDx4sWsW7eOZs2a4b3nzz//pKioiMaNG29Iu2DBAp544gnmzJlD165d6dixY6X7NWnShN2r+jLNAwomReqQ93D88fDYY9CjB5SWhoIssKbjww+HTz8NBZIAq1fDkiXQrRusWgX77AMffABt28Jrr8HLL1uwN3OmBaXjx8NFF8Ebb8TOx7p10Lx5aL+szILOzz6Dc86xQDNGa05CTjvNgtj27W1/l11g6lQLlL/5xoLfagZHikialJeX8/LLL7NixQpat27NySefzD777MOjjz5aKe2wYcMYM2ZMje4fPgAmXHiw2r9/f+bPn8/SpUtjpj3//PO5+uqrKx1v0qQJe++9d0S6r7/+GoCtttqqxtMANWzYcMOgHOccbdq0qZSmc+fOnHfeeTW6bz5SMClSh155xQJJsNq+WJ59tvKx556zQBLghhsskARYuhR23DEybXGxBarVadrUajhHjrTgcflyO37UUZGBZlVatYKXXoIRI2Dt2tDxDh3g5pvh9NPtOT16wJQp8N57sP/+id1bRFJj/fr1fPLJJ6xbt44xY8bw8ccfR5x/+eWXWb9+/YbAKminnXZiwIABEX0Ui4qKOOWUU3DOcdddd7F+/fqIa+IFk/369WPo0KFcdtllDB8+nHfeeYemTZtSUVFB3759Oe+885gyZQpHHHFEwlPsOOcYMGBAQmklvRRMitSQ9/DIIxYc9esHhx4av8l25crIwOzJJ2v+vBNPhM03t9dz58JVV9X8HpttZs3kb78NF14I8+dbkFdYaKOsg4EkwAknWNCXiMceg912g7//Hf7zn8hz559vQfCUKbbfvHn8QNJ7qKO5hUXywmeffUbbtm1p3Lgx++67L19++WXctH/++Sfvvfcee+65Z8TxxYsXc9BBB20IJhs3bsxrr73G0KFDATjttNN4+umn6d27N0ceeSQrV66MO1H3mWeeyZlnnrlhv7CwkJ133nnDfqyaUak/NJ5SpBq//ALXXWcjoS+8cAB77GEB3oMPwgUX2MjkWP0IFy2CgQOtJnHFCnjggZoHk8OHw913hwKt9u2tH2O4Lbao+h4tW8Jbb0GnTlYLOWMGPP44BLv+RC+c8OabkbWMAC1awJZb2ojtoUMtOJ0wAQ44wM5ffDE0a1b52WEze8Q0ezY88EAv+ve3pnwRqV5FRQUff/wxP//8c8zzixcv5uCDD6ZXr1507dq1ykAyaObMmZWONW/enJYtW7LVVlux9dZb8/rrr28IJAE233xzLrvsMkaOHEnDhg1p06ZNdo0wlroTb2SONo3mznfz5nl/0kneFxTEHrkcvjVo4P3ChaFrV6zwftCg6q8Lbief7P3Mmd5vv31oVPQDD3i/bl3svC1e7P0553g/bpztf/ll/Hv/9a9Vv8+PP7Z07dt7P3Kk98895/3bb3t/9dXef/WVpamoiByBHctzz3nfqZP3HTt6P2qU95MnV53++OMjR3k/8kjV6SVx+t1PvWwp0+XLl/vdd9/dA9455y+66CJfVla24Xx5ebnfZ599Eh4x3aRJE3/XXXfV+fvIlvLMJRrNLZJl5s2z0dS//ppY+rIya0Y+9FDbP+44mDbNXm+5pdVulpbGvnaTTazpuksX+OQTaxpv0aLq57VrB7feGtofMMAmDI+xzOuG2sN4Bg2y5w4caM3eQcOHh14n0gR96KGh95+ITp0sjAy6915rYheRSN57rr/+el555RWmBPuNBI6vX7+ejz/+mCFDhgDwzDPPMHHixLj3atu2LUcffTQ33HADc+bMoV27dnTq1Cnt70Fym5q5JeeVlsJDD1lzcawVrxYvjhw5DdavMNFAMih8/tt//AOCs0t8803sQPKRR+B//7NR1F262DHnqg8k49lrr9jH99mn6usKC226nhiLOqTV6NGR+x9/DF98Ubd5EKkP7rnnHi655JKIQDLo+++/Z4cddtiwf+SRR3LjjTdWGkxz6KGHsnbtWpYsWcJdd91Fs2bN2GKLLRRISkoomJScFaz1OussOOkkOOMMOPro0HHvbZBIhw42Uvq11+z4++/DE09YX8Og7t3hwAND+85Vnjrnttvgrrtg1izrV/j44/Fr9Pr2tdrLgw6y56dC796VjzVtatMHZaNNN4Wo/v5ce21m8iKSrcrKyrj++uvjnp84cSKnnnoqPvDF5pzjggsuYP78+Tz//PNMmDCBd955h2effZZGjRrVVbYlzyiYlJzjvQ2MadnS5lx86KHQuTfegGBf9AcfhFtusdfLl1ugOWuW1dD9/DMccYSd22wzW3v6pZfgpZc+YMIEmwcy1uDDM8+0AMl7m2vxgw/gvPNsVPO0adZ0vPfe8N//pmc5wdNPj9wfOzb1z0ilv/89cv+ZZ6xsRXLZunXrOP300yuNng5as2YNo0aNYsiQITRs2JBfYzSTbLbZZgwdOpTCwkLmzp1LSUlJxPl27dpxyCGHcOyxx7LHHnvUeA5GkZpQn0mp99atsyBwo41s+pkXX7Q5DgECy6VGePJJm9Lniisij++/v/VF7NXLmp4ffNCOP/ggNGlir1u0KIuooezf31arCbfffqEayZ13ti3o7beTfpsJufhie39//ml9MaODy2xz8MGw2WYlzJwZatv/5z/h3Xc1VZDkprKyMo455hiee+45ugUnj43SqFEjHn/8ccrKyiqd69ixIxMmTGD48OEU1nXfFJE4VDMp9doff9hAmb59bRDKTz9VvdwfwFNPQaNGofkPg666ymozy8pCQdhpp8Guu8a/V6xzmZyUu3t3+P13qxH97rvk+1/WlYICOPXUXyKOFRfHrvUVqe9KS0s3BJIAf/zxBxUVFZXSFRQUxO3LWFxczIgRIxRISlZRMCn1VkUFjBplSwCC1U5utZUt3VeV/fazJQl79oT16235wAcesOZssGDywgvh+eetD2RVdtqp8rGwadgyolkzGDLEAub6YODAZZUGD519Nvz2W+Sxt96Cv/3N1jKfP7/u8ieSCnPnzmXnnXfmmWee2XBs/fr1TJ48eUN/x3CdO3eudGy//fajX79+ac2nSDLUzC311kMP2TKA4eKs5LXBunUQPsixQYPIKXbAmrRHjkwsD/vtZ7WZK1bY/rHH2qAXqZk774RttglNXL5ihU0M/8YbUFJiAf/48aH0//d/Nnjqqqtij0L3WlFHskhZWRmHHXZYpcnDu3fvziabbBKzP+OVV17J3LlzmTRpEhMnTmSzzTbj3nvvrassi9SIaial3jr6aAs4EnXOOZGBZCq0b28jv3fd1QLJ6MBUEtOnj60yFO7tt21A0447RgaSYCv0XHutTb+0bl3kubvvtr6vPXuG1jAXyaQbbriBTz75JOJY//79KS4uZuONN455zf7778/o0aN58sknWbp0KZ9++mnctCKZpppJqbeaN7fBMf36WbN0VQoK4Pjj05OP/ffPbD/JXHHmmTZ4atKk0LF77qn6mvJyG3kfbPlbtQpuvx2WLbPtL3+Br78OzeMJVmtZUmI1yn/+abWh4eeD9/38c5tWKdaUSyJV+eabbxg1ahSLFy+moqKC36L6bOy11148//zzNG/ePKH7aSS2ZDvVTEq9MXdu5IopQRdcYGtGh0+1s9tuNgXQ+edbH8ZHHoHttquzrEoSCgqs60JNBw2FT3/UrJkFo3362P6SJXDTTaHPTWmp1WYPHWp/iHTsaHOMnn++9bl95BG4+mobzLX99jYXZrDfbEWFTVsU7KMrEsvq1avZd999mT59OnPmzKkUSLZr144JEyYkHEiK1AeqmZR6Yc0aGyDToQOMGGHboYeG+suNHm197mbNsmUBN93Ujt90U8ayLEno2RP+8x84+eTK5w4+2KY9WrTIVvuZMcOOP/ssfP99qHbyzTet5jHoyittUNWcOTb351df2fHwZ9xyS2jO0XDe22Cgvn3hhRdCgeU550R2aVizxlbw6dnTNskt3ns+/PBDXn/9dRYuXEjPnj254IILaNasGaWlpbz66qsccsghNGjQgDvuuIPff/897r3uvvturTojOUfBpGStH36wpsY997QAYPVqW+LwgQdsYMbhh0em32EH26R+O/FECxjHjbOaxQYNbAWja66x19272zygd95pA3VGjgwFkmB9V8eNsxHfp55q3SHA+lgGA8maqKiwP1yCg6xatoS//jV0vrTUJqP/+GMb9HPKKXDjjZErKP36q/3Bs369BacHH1zzfEjm3HjjjYwZMybi2P33388mm2zC+++/D9j8j2eccQZXXnllzHv06tWL6667jiOPPDLt+RWpawomJaMWLoR33oHOnW1y7+B61q+/bv3d1q2zc9HrS48YodG6uco5m3z94ovjp2nbFi6/PPa5wkKbp3LXXSNrH2+91eYWDdZo1kQwkASbVD181oBLLrFAEqwm8803rXY1XKtW9gcQ2ITs11xj1zln1/z6q82Zuummkctfrlxp3TU22kg1npmyYsUKrrnmmkrH582bx7x58zbsL1y4kCuuuILhw4dvmPIH4NZbb2XLLbdk2LBhmhtScpaCScmYpUthyy2tFgpsSp2RI63W5rDDQqN0FyywvmxNmoT+Ex8xIiNZlnqid2+rhQwPzFq2tGUtBw+22sRYunSxmvDu3W1gz1NPVU4zZoz9AQRWWx4+YAhs2qKioshjrVpZ38xg6+eYMfaZ3mUX64MZPmNMx462ClNpqTXfl5VZf9J//ctWbQr2DZ461Zre//lPu38s06bZ78yQIZX/+Fq50gLvVExltXp17k6J9dBDD7Ei/K+JKjRo0IBHHnmEjTbaiFdffZWlS5dyfLpG/olkE++9tgxsAwcO9Ok2adKktD+jNu65x3url6l+69zZ+5IS79980/vzz/d+8eLM5Dnby7Q+qusyffJJ7xs0sM9Vp07eT5ni/XXXef/EE96vWRNKV17u/UEHVf4s7rab9xUVoXSrV3t/5pmh8ytWVH5mRYX3W2yR+Oc93rbPPt7Pnev9p59636SJ9wUF3q9dW/l5kyZN8hdeGLruxhsj83LppXa8bVvvH364ZuW3bp33zzzj/X33ef/6697vskuoXJYurdm9sl1ZWZnv2bOnBxLabrjhhkxnud7Qd2nqpbtMgWk+TkyjmknJmJr0X3vjDev7ttdeVFotRaQmjj7aBtR88YXVQnbrFrl+elBBgTWXb789zJwZOj52bGQtX5MmcMcdcMghNjVRrNHowb6U//hH7fI+cSJssYXNb7pmjeU91kpHt9++KS+8AK1b2/ydp5wSOvfgg9Z/FKx14G9/g5dftgn4y8ttvfkdd7T3v3Jl5Pv55BPr+xnrd3fyZGvev+qqmr2ndetsJas33rBR+PvsY9ugQZUnpPfeVkbq3LluVniaPXt2xH7jxo154YUXOPLII1m5ciUAp59+OkcffTRdu3Zl0+DIP5F8Ey/K1KaayXTbbbfqa2IGDfK+rCzTOQ3J9jKtj7K9TH/6yT6rG2/s/X/+U7t7/fCD94cd5n3DhpU/6w0aeN+oUeK1lOD9kCHef/6598uXh56xbp33bdqs9V26WC3stGneL1hg55Yt836PPRK7t3P2c/PNvb/gAu8vv9z7wsLYaZs29f6mm7xfvz6Ujx9/9P6YY6pvRbjlltj33Ggj799/P5Ru9Wrv997bb6hRfvnl2Pdbs8ZaMaqzYoX3330XWcscS1lZmX/22Wd9//79/UknneS99/6nn37yd9xxh582bVr1D5KYsv33vj7KZM1kxoOqfN3yPZisqPC+XbvI/zwuv9z7nXf2vksXO3fggd4vXJjpnEbK5jKtr/KxTBcutEDvssvscz95sh0vK/N+5kzv33vP++nTvZ83z/vffrPfi3gB31FHVb5/z54rIwK9L78MnXvuufgBZLJb377ef/xx6BnffON9nz527ogjYpdBRYU10W+zTfz7dukSajq/+urK58eOjbznq69636aNNf+PGRM/UPzsM2viDwbkixZV/282adIkvya8H4TUSj7+3qebgsk83PI9mFywIPI/haZNrY9atsvmMq2vVKbVKyuzWtGiosjfm6Ii73/9NTLt+vXeN2hQviHN449Hni8p8b5x4+oDxES3Dh28f+SRUOB2772V7//KK5F5uPRS75s1S+z+Bxzg/bhxld87eH/ttZH3veCCyPPhfUWDysu933rryHQDBlgN7mGHWQD7j39Yma9c6f0JJ3jfsaP3I0bMj9k/VZKj3/vUy2QwqRVwJO1ee82maTnyyNBo1m+/jUzTr1/kCjYiElJYCOeea0tD7rGHHXPOlpuMXq65pASGDFnMvvvaJO/HHBN5vnlz65N4ww02CvuFF+C882ze1g4dqs9Lw4bw3/9aGLZqlf1On3BCqB9p48a2dnq4s86yUelBTZvatdG22qpyn+hXXrE+n7FG4A8ZErl/443WJ9Q561cKNldpuKeeihw9D9YHdNAgG+0/f36o7+exx9q68AsXwptvdubJJ2OXiUi+0wAcSYtly2xak7Zt4YgjQv8RFBXZlCjRwWT//nWeRZF6p3dvm5Zoxgyb6qhz58pp2rSBsWO/Y9iwjnHv8+yzNgE82Hyuf/mLva6osCUtn33WfidPPBGmT7eVpL7+2p730EOw776WPnoKJLDAcu1aePxxC1y33tqONQj732b0aPj3v0PTfwWdfTYcd5ytYhX9HRGtYUMbHBVuwQJbm917WLzY7tOuXej8vHk2xVIiYg0k+uADey8iEknBpKTcTz/ZXH5Ll1Y+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z690bbZRMCkiIiJSBwYMGLDh9fTp06tNv2DBAubNm1fp2myjYDKHlZfbJiIiIpk3dOhQGjSwHoZPPPFEtf0hJ0yYsOH1nnvumda81YaCyRz2wQcdaNAAmjSBtm3h5JMznSMREZH81alTJ4488kgAvvzyS66++uq4ab/44osN51u0aMGoUaPqIotJ0QCcHLZ2bUHgp21r1mQ4QyIiInnulltu4d1332XBggVcfvnlFBcXc9xxx9G3b18aN27MvHnzeOONN3jggQdYHZgk+p577qF169aZzXgVFEzmsDVrIiuetS63iIhIZnXq1InJkydz6KGH8s033/Duu+/y7rvvxkzbtGlT7r77bkaOHFnHuawZBZM5rKwsMpjUutwiIiKZt9lmm/HFF1/w7LPP8vzzzzN16lQWLlzIunXraNOmDX379mWvvfZi9OjRdOzYMdPZrZaCyRx26KFzue22zVizxpZTLCzMdI5EREQEoLCwkKOOOoqjjjoq01mpNQWTOc45q5FUraSIiIikg0Zzi4iIiEjSFEyKiIiISNIUTIqIiIhI0hRMioiIiEjSNAAnhz39dDeeeMLmlywqglGjoE+fTOdKREREcomCyRz28cft+Pzz0P7w4QomRUREJLXUzJ3DgsspBmkFHBEREUk1BZM5bM2ayFnKNdekiIiIpJqCyRymmkkRERFJNwWTOWzt2siaSQWTIiIikmoKJnNYdM2kmrlFREQk1RRM5rDoPpOqmRQREZFUUzCZoyoqYP36yH/eJk0ylBkRERHJWQomc9Tq1ZH7TZuCc5nJi4iIiOQuBZM5KjqYVBO3iIiIpIOCyRy1YkXkvoJJERERSQcFkznqt98i97t2zUw+REREJLcpmMxRv/4aud+jR2byISIiIrlNwWSOig4mu3fPTD5EREQktymYzFEKJkVERLJLcXExzrkNW9OmTVm+fHlC1/bp0yfi2nvvvTfNuU2cgskcNWdO5L6CSRERkeyyZs0ann322WrTffjhh8ycObMOcpQcBZM5SjWTIiIi2atJYCWRRx99tNq0wTRNs3RdZAWTOch7BZMiIiLZ7OCDDwbg/fffZ050c2KYtWvX8vTTT0dck20UTOagZctg1arQflERtG2bufyIiIhIpKFDh9K9e3e890yYMCFuupdeeolly5bRuHFjjjzyyDrMYeIUTOagWLWSWkpRREQk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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(1,figsize=(10,10))\n",
    "\n",
    "\n",
    "plt.plot(Results1, '-.b', linewidth=4.0, label='S')\n",
    "\n",
    "plt.plot(list(range(100,300)),Results2[100:], 'r', linewidth=4.0, label='U')\n",
    "\n",
    "plt.plot(list(range(200,300)),Results3[200:], '--k', linewidth=4.0, label='M')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='lower right', fontsize=28)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=28)\n",
    "plt.ylabel('Acc', fontsize=28)\n",
    "plt.xticks(fontsize=25)\n",
    "plt.yticks(fontsize=25)\n",
    "plt.ylim([0,101])\n",
    "plt.grid()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rVvDAQf45ylPPx169ID//hcefdSnHz4cHn/c9zoOV1QEN94IF17o1zff3Peajnb00T6QBBg6FL79lnffeINdgr21wV+7T5/QMT16+CVZzZsnblrfcku/RPvnP/3zobfd5stnq63gnnt8jWCnTj4IHDkSvv0Wtt3WP4O6ySbJ5Sk83Z57+mXePF/jueGGiY/t0sUvdVi8eDELFy5k4MCByeUpQxRMioiIpNNVV8E//uGbIMvKfIB1wAGw336+9mz0aN8EGx7QpcMFF/jgaMYM/7zjihV+6J2uXf2wNeE+/tgHiL17+6bW6PEdjzvOL0HnnANPPeVrwEaN8ueurva1iEG77+6H8wnvdDNgANxyS+S5i4upKS1NPH5jYxo2zNeqxtK/v2++XrTIl2MdeV64cCFHH300kydP5oQTTuCggw5i/PjxDBo0iCOOOIJm3bvXK2s1NTVceeWVPPDAA3Tu3JkpU6ZQFFZTed9993HVVVcxZ86cep033RRMioiIpMutt0bWkJWX+2fgnn3WByIlJX5cwmSMGeObje+5JxR4Fhf7GVBqauCEE0Jp//xn3xnHOV8jVlft2Xbb+SVZgwZFfq527WqnadbMdwx65x1YutQPRL7VVn57U9asme8hH8dPP/3ESy+9ROvWrRk7diwTA83NN998MzcHOkh17dqV7bbbjg022CDhpcyMH374gRUrVlBSUsIzzzzDtYFm+A022CAikKyqquKee+7hoIMOoksStZiZpGBSRETyX3W175Qyd65vft5001Az4sMP+2fu1l/fPwu3zTa+KXLaND8g97bb1n3+1av9bCy33ho/jVnygeSpp4ZqB//+dz/rycyZvnYzGCg2b+6fpxwxAk48MTdq+lq39nnMczU1Nbz22mvceeedvPrqqwnTrr/++rz55pu1Akkz45FHHqFFixaUl5czb948nnjiCX6OMyTS0KFDI9ZffPFFZs2axZgxYxr2YdJAwaSIiOSf33/3zyrOnesDsk8+iRzapbgYDj/cd3Q44wy/7auv4JVXap/rgQd8c2c8y5b5gC7RkC6xFBX5IHDLLX2gOH26b07dYYfIWsD27eHQQ2sff9RR9R/uR+pUXV1NswS1qTNnzmTUqFFMmjSpznMVFRXxn//8h/5R98/q1as55ZRTeCI4004SJk2axOrVqykJTJ3YoUMHjj/+eIZna9ab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u/HGGyPytPnmm6/bd9JJJzVqmeQrBZMFuCiYbJrilWlNje8DsdVWvnPsmjV+lJRBg5L/u77ddj7Ait5eVORrJIPOPrt2mugA9Kijaufv118z87dv+XKfp7328jWq9TnOrMDv048/9kFc9PhKQcuXh/4TSPcycqR/rqEu1dVm553nj9l448ibsRC89lrs8vs4d0chqK6utn//+982YsQIa9++fcIgL7i0adMmoqPJCy+8UOcxpaWl65qkZ8+enbAzzBdffBGRxzfffNPeeuste+2112xtU/+HI0comCzARcFk0xRdpuXlZrNm+Sbr+vwdf/55s759k0sb/U/7F19Etjxec43ffvvtflzIvfbyLY1NRcHdp9XVPqoP/w/AOf8g6bvv+jQvvZR8M3b//v65g+iHbDt08A/F7rKLb2pu394/WHv77Waffppavgux2/2qVbWfAQ0835erYnVuSWYZMmSILVmyxIYNGxazaTt8ad68uT388MMR1x0xYkTMtJ06dbLqqHun4H7vG0E2g0nNzS2SopdegkMOgerq+h3Xpo2flnfGjOTSXnNN5Latt4Z77oEHH4Rtt4VLL/XbzzvPL5KjzOD22+Gmm6CiApYti9z36qt+SaSoCLp0gfnzobgY/vQn+Pvf/Y3y7LPw4ovwwgtMa9uWjW66CVq2hMsvT0/+i4rSc56mpqQERo2Cxx7z6y1awLXXZjdPAd9++y3vvPMOe+yxBxtvvPG67SeffDKLFi3irrvuYvXq1Umdq127dpx77rm0b9+eHXbYgdtuu61WmjFjxtCxY0c+//xzDj30UAYNGhSx/7jjjuONN96oddxuu+1GUaHeP4UiXpSpRTWTUluwTCsqzDp2TK7iKHo59FBfMTVzptlTT/me0tFpunb1fRY++CC7n7cxFMR9umpV3eM81bVssol/vtHM94JO8NxiQZRpY5o/3+aOGOHnCo/qrJINy5Yts7POOmvd84/OObvttttqdUaZNWuWDRw40Nq1a2cjRoywG264wW6//XbbeOONrUePHvbkk0/aqFGjbJ999rFZs2atO+63336LmM4Q/FA9dXV2WbFihfXq1atWzeS4ceNqpdU9mn6qmRRpYkpKfM3kddfB//4XP91GG8G8eVBeHto2ciQ4B717++Xww31Fx3XXQb9+8K9/wfDhGf8Ikilz58IVV8CiRXDBBbDz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t9gC3n3XP/951lnwyy/w1luxB3S//XZf23nSSb5GtHdvP3TltGlldQa9a9bAgQf64HPnneH33yPzf999cPrpEKcSTVIwfvx4rrjiiohtf/jDH7j//vv54osvWG+99bKUM5EGijdpt5bMLoMHD04wnXp6ZHrS93xz0klm/s+oX665pnYalWn61VWm5eVmDz1k9sADZqtWxU9XWWk2bpzZHXeY3Xuv2WefmdXUmNl775n17Bn5wwUz58xuvtnszjutZvBgm7zRIbYes2sli7cUFZk99pi/9pIlZscdF7n/738P5e2XX8yaNQvta9PG7JVXQvtraszuvNOsuLj2dfr2Ndt//+TydOONZosWmZ122k8GZn/+c/zy+uc/I48988zQvttui9x3ySVma9cm/DHlvWR/96uqqmzx4sVWXV29blt1dbXdcccdVlpaasC6pbi42ObPn5+hHOc2fZemX6bLFPjc4sQ0WQ+qCnVRMJl7BgyI/AM6fnztNCrT9MtomY4bFztCa9HCbOzYdclmzzbr2DF2gHbPPWYPPuhjz+C24mKzp5+ufblnnjHr3dunGTkyct/335sdeaTft912gUDXzKqrza64wmzDDWNfP5mlWzezu+82GzUqcvtzz4WuE6683KxVq9rnef11s2nTzLp0qb3vpJOSL/bFi81eeMFsxozkj8l1ydynM2fOtIEDBxpgxx9/vC1dutTMzL7++msrKiqKCCQBO/LIIzOb6Rym79L0y2Ywqd7cIvjODNOmRW7bYYfs5EXSZN48PyBldFvvkCH+IcOw4VV69PAdYg48MDLpccf5pl7n/BiYF1/sh5O84w7Ye+/alxw1Cvbd158r+rIDBsB//gOXXeb3BXtjFxX5Zu/Zs5N7vKJ1a9/8XREY0ej11+Htt32z+qGHwnvvhWZ3nD8/dq/v++7zx0cLPscZy8MP++b0HXdMnL+ffoJdd4U5c3xZ3XyzL+5mzeCuu2Do0Lo/Y1N111138f333wMwYcIEFixYQPv27dl888257rrruOSSSwA/7/UJJ5zA9Zo6S/JFvChTi2omC8nnn0fWwmywQex0KtP0y0iZ1tSY7btv7eq1iy/27eFxXH11KOmQIWYrVqQ/a/FUVprttlviGkgwu+mmxOcZP96sefNqA7MLLqi9//fffU1mKjWgO+5Yu6YzfH3lSrNNN41//Hrrmb37rq/lLC9PvmyWLDG79Vaz2283q6iIn27FCrO//tXsjDPMfv45+fMnI5n7dK+99qpV+/jVV1+t2//RRx/ZK6+8YosXL05v5pogfZemn2omRbLs668j17fYIjv5kDS5914/lk64//s/+OtfEx521VV+Vpz5830tZWN2rG3eHJ55Bk47DT780I8pGW3wYN9jO5G994aHH/6M5s2Hsckmtff/5S/+86WiTx9fo9m6NUya5GcY6tPHj9/pnB9fc8st/SDxscyd62eVBHj/fXjqKd+p6tdffS/5M8/047qGd2gy89veeMOvjx7tB6Vv1873RDfz162shH328ecFePZZmDIFunZN7bOmYnqM8Z2eeeYZtgwMUbDddts1XmZEGpF6c4ugYDIvfPwxbLKJj2rOOity3447wqWXJnWanXbyzdXZGKGlY0cfUM6Z45fwqby33to3aScaED1o/fVXccQRte/j117zQxGF23573xwdy9FH+zEt99rLB49PPOF7f7/yin9a4Jtv/PtLL/VBnXPw4IPJfdYff4TttvPjc957L3zyiR8TtFcvuPvuULpPPw0FkgBffunLZfBgH9R26OBHYPjTn0KBJPgO/Oefn1xe0qGmpoaZM2dGbJs6dSr/+Mc/Gi8TIlmimkkRageTm2+enXxIit59F/bbr/ZI4uAfJnzssSY34vx66/ng8a67oGdP/7xmeHBZX19+CSecELlt4ED/vOXy5f6ZzW7d/NiVzz3ng9fbb/cBW6tWkcfdeWfk+o03+prcnXbyaYcN88FhXU491V/z4Yd94Pv117BoUeRwUPGmN//iC/+6Zg1Ejbazzn/+4+dhDx9rNFPmzp1LZWXluvWOHTuy6aabZv7CIjlANZNS8MxUM9lkmcG//+3bdmMFkgD/+pcfFbwJ2nZb36x77bUNCyQBNt44MigM1iKWlPim4K239h2RnnrKF+Wnn/oxNKMDSed8kNm8eWjbrrtGdsypq5MO+FrJm27yg61//LGvAQXffH3MMb7mcuRIn4+GOO443xcL/NieJ53ka2iT8fzz/rP98kvdaaObuPv27Vu/jIo0YQompeDNn+9rQ4JKS/18zpLj5szxXafPOSf+NC5HH127Oq5AtW4N//ufbx7u1ctX1sYL+upq4t9kE98cv+22PuB76qnIXuM77ZT4+AED4OWXfSDbo4d/7vLJJ/2+k07y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mpsLS1lZGeXl5Wk/r4LJPBddM6lgUkREglatWkXr1q2znQ1pJK1bt2ZVdGCQBgom85iZOuCIiEh8NTU1FBUpFCgURUVFGemprzsoj1VVOaqrQ+vFxdC8efbyIyIiuSeTvbYlt2TqZ61gMo+tWRP541WtpIiIiKSbgsk8tmZNZNd/PS8pIiIi6aZgMo+pZlJEREQyTcFkHlPNpIiIiGSagsk8Fl0zqWBSRERE0k3TKeax1avVzC0iIpJrKioqePLJJ3nhhReYPHkyixYtorq6mrZt29K7d28GDRrEsGHD2Guvvdh4442znd06KZjMY2rmFhERyS2ffPIJRx55JDNmzKi1b/HixSxevJgvv/ySxx9/HPADy5eUlDRyLutHwWQeUwccERGR3DFt2jT22muvdfNj77///hx22GEMGDCAkpISlixZwtdff82ECRN44403MjJbTSYomMxjqpkUERHJHX/961/XBZIPPvggJ598cq00u+++O+effz7Lly/n0UcfpVmzZrXS5BoFk3lMNZMiIiK5obq6mldeeQWAIUOGxAwkw7Vt25Zzzz23MbLWYOrNnceiO+CoZlJERCQ7Fi5cuK7ZesMNN8xybtJLwWQeq6xUM7eIiEguaNmy5br33333XRZzkn4KJvOYhgYSERHJDR06dKBv374AfP3111x77bXU1NRkN1NpomAyj6kDjoiISO4477zz1r3/61//Sr9+/fjTn/7Ef/7zH3766SfMLIu5S52CyTymDjgiIpIuzqVvadu2LOb2005L/vrxnHZaanlqDOeddx6nhX3IX3/9lbvuuoujjz6ajTbaiC5dujBq1CiefvppqqqqGidTaaBgMo9pOkUREZHc4Zzjvvvu46233uKAAw6gefPmEfsXL17Mc889xxFHHMHmm2/Ol19+maWc1o+GBspj0c3cqpkUERHJvt13353dd9+dFStW8NFHH/HZZ58xadIk3nnnHRYvXgzA999/z6677spHH33EoEGDspzjxBRM5rGLLvqBxx7ryqpVUFEBvXplO0ciIiIS1KZNG0aMGMGIESMAqKqq4qWXXuK8885j1qxZlJeXc/755/PGG29kOaeJKZjMY61aVdOzZ7ZzISIi+SCdfUPKy8spKyvLyPXvv98vTVFxcTGHHHIIG220EUOGDKGyspK3336bJUuW0LFjx2xnLy49MykiIiKS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uu59RUVFUsesXLkSgNatW2ckT+mgYFJERESkEXTs2HHd+3nz5iV1zNy5c2sdm2sUTIqIiIg0gi222GLd+0Q1tkHz5s1jzpw5tY7NNQomRURERBrBrrvuSnGx767y5JNP1tm8/thjj617v+eee2Y0bw2hYFJERESkEXTr1o3DDz8cgMmTJ/N///d/cdN+9dVX6/aXlZVx4oknNkYWU6Le3CIiIiKN5NZbb+Xtt99m3rx5/O1vf2PixIkcd9xxDBw4kJYtWzJnzhxee+01HnzwQVatWgXAPffcQ/v27bOb8QQUTIqIiIg0km7duvHuu+9yyCGHMGXKFN5++23efvvtmGlLS0u5++67OeaYYxo5l/WjYFJERESkEW200UZ89dVXPPPMMzz33HN89tlnLFiwgMrKSjp06MDAgQMZMWIEp512Gl27ds12duukYFJERESkkTVr1owjjjiCI444IttZaTB1wBERERGRlCmYFBEREZGUKZgUERERkZQpmBQRERGRlCmYFBEREZGUKZgUERERkZQpmBQRERGRlCmYFBEREZGUKZgUERERkZQpmBQRERGRlCmYFBERKWBmlu0sSCPJ1M9awaSIiEiBKioqoqamJtvZkEZSU1NDUVH6Qz8FkyIiIgWqtLSUlStXZjsb0khWrlxJaWlp2s+rYFJERKRAlZWVUV5enu1sSCMpLy+nrKws7edVMCkiIlKg2rZtS0VFBUuXLs12ViTDli5dSkVFBW3btk37uYvTfkYRERFpEpo1a0afPn2YOXMmFRUVlJWV0bp1a4qKinDOZTt70gBmRk1NDStXrqS8vJyKigr69OlDs2bN0n4tBZMiIiIFrEWLFmywwQYsX76c33//nblz52a8U87q1aspKSnJ6DUKTawyLSoqorS0lLKyMrp3756RQBIUTIqIiBS8Zs2a0aFDBzp06NAo15s4cSJbb711o1yrUGSzTPXMpIiIiIikTMGkiIiIiKRMwaSIiIiIpEzBZD0558qcc1c7575xzq1wzi1zzn3mnLvQOdci2/kTERERaUzqgFMPzrk+wESgb2BTBdASGBJYjnHO7WFmGrBLRERECoJqJpPknCsGXsYHknOBEWbWGmgFHAmUA1sDj2crjyIiIiKNTcFk8k4ANg+8H2VmbwKYWY2ZPQWcHti3n3Nuj2xkUERERKSxKZhM3gmB1wlm9lGM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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(1,figsize=(10,10))\n",
    "\n",
    "\n",
    "plt.plot(Results11, '-.b', linewidth=4.0, label='S')\n",
    "\n",
    "plt.plot(list(range(100,300)),Results21[100:], 'r', linewidth=4.0, label='M')\n",
    "\n",
    "plt.plot(list(range(200,300)),Results31[200:], '--k', linewidth=4.0, label='U')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='lower right', fontsize=28)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=28)\n",
    "plt.ylabel('Acc', fontsize=28)\n",
    "plt.xticks(fontsize=25)\n",
    "plt.yticks(fontsize=25)\n",
    "plt.ylim([0,101])\n",
    "plt.grid()\n",
    "plt.show()\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": []
  }
 ],
 "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
