{
 "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "epochs = 5000\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=650 \n",
    "nofprojections = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "imgX = Input(shape=(4096,), 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",
    "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",
    "labelW = K.placeholder(shape=(None,nofclasses) ,dtype='float32') #labels of input images oneHot\n",
    "imgW = Input(shape=(4096,), name=\"input_img\", dtype='float32')  # adapt this if using `channels_first` image data format\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "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": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ReadData(sourceL,targetL,distL,lastL):  \n",
    "\n",
    "    curPath  = r'/nas/home/Seq_DA_ICML2021/Caltech/decaf6/'\n",
    "    folder =  sourceL\n",
    "    data = sio.loadmat(curPath+folder)\n",
    "    dataX_train = data['feas']\n",
    "    labelX_train = data['labels']-1\n",
    "\n",
    "    \n",
    "    dataX_test = dataX_train\n",
    "    labelX_train = keras.utils.to_categorical(labelX_train, nofclasses)\n",
    "    labelX_test = labelX_train\n",
    "\n",
    "\n",
    "\n",
    "    curPath  = r'/nas/home/Seq_DA_ICML2021/Caltech/decaf6/'\n",
    "    folder1 =  targetL\n",
    "    data = sio.loadmat(curPath+folder1)\n",
    "    dataY_train = data['feas']\n",
    "    labelY_train = data['labels']-1\n",
    "\n",
    "\n",
    "    dataY_test = dataY_train\n",
    "    labelY_train = keras.utils.to_categorical(labelY_train, nofclasses)\n",
    "    labelY_test = labelY_train\n",
    "\n",
    "    \n",
    "    curPath  = r'/nas/home/Seq_DA_ICML2021/Caltech/decaf6/'\n",
    "    folder2 =  distL\n",
    "    data = sio.loadmat(curPath+folder2)\n",
    "    dataZ_train = data['feas']\n",
    "    labelZ_train = data['labels']-1\n",
    "\n",
    "\n",
    "    dataZ_test = dataZ_train\n",
    "    labelZ_train = keras.utils.to_categorical(labelZ_train, nofclasses)\n",
    "    labelZ_test = labelZ_train\n",
    "    \n",
    "    \n",
    "    curPath  = r'/nas/home/Seq_DA_ICML2021/Caltech/decaf6/'\n",
    "    folder4 =  lastL\n",
    "    data = sio.loadmat(curPath+folder4)\n",
    "    dataW_train = data['feas']\n",
    "    labelW_train = data['labels']-1\n",
    "\n",
    "\n",
    "    dataW_test = dataW_train\n",
    "    labelW_train = keras.utils.to_categorical(labelW_train, nofclasses)\n",
    "    labelW_test = labelW_train\n",
    "    \n",
    "    \n",
    "    \n",
    "    task1 = 0\n",
    "    task2 = 1\n",
    "    task3 = 2\n",
    "    task4 = 3\n",
    "\n",
    "    DATAX_train = {}\n",
    "    DATAY_train = {}\n",
    "    DATAX_test = {}\n",
    "    DATAY_test = {}\n",
    "    \n",
    "    \n",
    "       \n",
    "     \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",
    "     \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",
    "     \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",
    "    DATAX_train[task4] = dataW_train\n",
    "    DATAY_train[task4] = labelW_train\n",
    "    DATAX_test[task4] = dataW_test\n",
    "    DATAY_test[task4] = labelW_test    \n",
    "    \n",
    "    \n",
    "    return  DATAX_train, DATAY_train, DATAX_test, DATAY_test  \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encoderNN(imgX = imgX, nofclasses=nofclasses):\n",
    "\n",
    "    \n",
    "     \n",
    "    \n",
    "    x = Dense(nofclasses, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(imgX)\n",
    " #   x = Dense(256, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(x)\n",
    "#    x = Dense(200, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(x)\n",
    "  #  x = Dense(nofclasses, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(x)\n",
    "    \n",
    "    encoderX = Model( imgX, x)\n",
    "    return encoderX\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def    classifierNN(nofclasses):\n",
    "    yin =  Input(shape=( nofclasses,) )\n",
    "\n",
    "    \n",
    "    probX = Dense(units=nofclasses, kernel_regularizer=regularizers.l2(0.01))(yin)\n",
    "    probX = Activation(softmax)(probX)\n",
    "\n",
    "\n",
    "    classifier=Model(inputs=[yin],outputs=[probX])\n",
    "    return classifier\n",
    "#    classifier.summary()\n",
    "\n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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=100,init_params='kmeans') \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",
    "        \n",
    "        a= gmmX[gmmY==i,:]\n",
    "        gmmModelSingle.fit(a)\n",
    "        gmmModel.weights_[i] = 1/nofclasses #gmmY[gmmY==i].shape[0]/gmmY.shape[0]\n",
    "        gmmModel.covariances_[i] = gmmModelSingle.covariances_[0]\n",
    "        gmmModel.means_[i] = gmmModelSingle.means_[0]\n",
    "\n",
    "        gmmModel.precisions_cholesky_[i] = gmmModelSingle.precisions_cholesky_[0]\n",
    "        gmmModel.precisions_[i] = gmmModelSingle.precisions_[0]\n",
    "\n",
    "\n",
    "    return gmmModel\n",
    "\n",
    "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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Losses(encoderX,classifier,labelX,imgX):\n",
    "\n",
    "    discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX)))) \n",
    "\n",
    "    params=encoderX.weights  + classifier.weights  \n",
    "\n",
    "    myLoss = discriminationLoss\n",
    "\n",
    "    opt = Adam(lr=1e-5)\n",
    "    updates = opt.get_updates(myLoss,params)\n",
    "    train = K.function(inputs=[imgX,labelX],outputs=[discriminationLoss],updates=updates)\n",
    "    return train\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Losses1(encoderX,classifier,labelX,imgX,imgY,labelY):\n",
    "\n",
    "    lamda2=1e-2\n",
    "    theta=tf.keras.backend.placeholder(shape = (nofprojections, nofclasses), dtype='float32')\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",
    "    return train\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "numtrial = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "def genresults(sourceL,targetL,distL,lastL):\n",
    "\n",
    "\n",
    "    DATAX_train, DATAY_train, DATAX_test, DATAY_test = ReadData(sourceL,targetL,distL,lastL)\n",
    "    \n",
    "    ntask = 0\n",
    "    epochs = 50000\n",
    "    epochstep = epochs/100\n",
    "    nofclasses=10\n",
    "    batchsize=650 \n",
    "    nofprojections = 100\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",
    "    Results1 = []\n",
    "    Results2 = []\n",
    "    Results3 = []\n",
    "    Results4 = []\n",
    "     \n",
    "    loss = []\n",
    "    imgX = Input(shape=(4096,), 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",
    "    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",
    "    labelW = K.placeholder(shape=(None,nofclasses) ,dtype='float32') #labels of input images oneHot\n",
    "    imgW = Input(shape=(4096,), name=\"input_img\", dtype='float32')  # adapt this if using `channels_first` image data format\n",
    "\n",
    "    \n",
    "    \n",
    "    for iop in range(numtrial): \n",
    "        \n",
    "        encoderX = encoderNN(imgX = imgX, nofclasses=nofclasses)\n",
    "        classifier = classifierNN(nofclasses)\n",
    "\n",
    "        train = Losses(encoderX,classifier,labelX,imgX)\n",
    "\n",
    "        loss = []\n",
    "\n",
    "        batchsize=20 \n",
    "        epochs = 50000\n",
    "        epochstep = epochs/100\n",
    "        sizeperCl = 8\n",
    "        for itr in range(epochs):\n",
    "            indTrainDataX,trainLabelX=batchGenerator(labelX_train,batchsize,nofclasses=nofclasses)\n",
    "            trainDataX=dataX_train[indTrainDataX,...]\n",
    "            loss.append(train(inputs=[trainDataX, trainLabelX ]))\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",
    "                perd_label_W = classifier.predict(encoderX.predict(DATAX_test[3]))\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",
    "                Results4.append(100*float(sum(1*(np.argmax(perd_label_W,axis=1)==np.argmax(np.squeeze(DATAY_test[3]),axis=1))))/DATAX_test[3].shape[0])\n",
    "\n",
    "\n",
    "            \n",
    "            \n",
    "           \n",
    "        gmmModel = myGMMfit(encoderX,classifier,dataX_train,labelX_train,nofclasses)\n",
    "        buffData, buffLab   = buffSelection(encoderX,gmmModel,dataX_train,labelX_train,sizeperCl)\n",
    "\n",
    "        \n",
    "        \n",
    "\n",
    "         \n",
    "        epochs2 = 15000\n",
    "        epochstep = epochs2/100\n",
    "        \n",
    "        for ntask in range(1,4):\n",
    "            \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",
    "        \n",
    "            train = Losses1(encoderX,classifier,labelX,imgX,imgY,labelY)\n",
    "            \n",
    "\n",
    "            for itr in range(epochs2):\n",
    "                indTrainDataY,trainLabelY=batchGenerator(labelY_train,batchsize,nofclasses=nofclasses)\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=200*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",
    "                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",
    "                    perd_label_W = classifier.predict(encoderX.predict(DATAX_test[3]))\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",
    "                    Results4.append(100*float(sum(1*(np.argmax(perd_label_W,axis=1)==np.argmax(np.squeeze(DATAY_test[3]),axis=1))))/DATAX_test[3].shape[0])\n",
    "\n",
    "\n",
    "\n",
    "            \n",
    "            if ntask == 3:\n",
    "                break\n",
    "                \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",
    "            \n",
    "    return Results1, Results2, Results3, Results4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "Results = np.zeros([12,numtrial])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "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/.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/.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"
     ]
    }
   ],
   "source": [
    "sourceL = 'amazon_decaf.mat'\n",
    "targetL = 'caltech_decaf.mat'\n",
    "distL = 'dslr_decaf.mat'\n",
    "lastL = 'webcam_decaf.mat'\n",
    "Results1, Results2, Results3, Results4 = genresults(sourceL,targetL,distL,lastL)\n",
    " \n",
    "    \n",
    "    \n",
    "sourceL = 'webcam_decaf.mat'\n",
    "targetL = 'dslr_decaf.mat'\n",
    "distL = 'caltech_decaf.mat'\n",
    "lastL = 'amazon_decaf.mat'\n",
    "Results11, Results21, Results31, Results41 = genresults(sourceL,targetL,distL,lastL)\n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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P1viG2+Y/eUvZn/+s9nLL/tr5tNP/Xsxa1bq/tXV/jN1/fX+9Vi6NHM+EuUvJpqYTjH0oCqui4LJ4otz+SNf9rVrzQ4+2P+HfvDBRpvbuvzLlvl/VC2VLfD68kuzzTfP/o+tJcsOO/j51hPnWrfObPHihkChf38/P3rC119nDiKSl402yr7twAPNLr/cbLvt/Ft0441mDz/csFRVZS7zggVmzz3n/2azaFH2c//whz7wOOiguTZmTEOZP/nE7K23/EemGL780gdmd91lts02LX9/OnUye+GFzMeePNkHRMkBvJnZPfc0cczNVqQGko++bFDfbD6OOKLx+Z97LjXAGj7cB8zp0n98FHJxzv+IMfOB2dixqdsvv7whH4nrfv/9C5+PDh3MvviicdkPPTQ13WGHNU6z5565n6dLFx90m5nV1PjrN337Mcdkfh8UTMZwUTBZfHEuf+TLftxxDd+uzvmf+EmiUP66OrPXXjObPdvsscfMystz/4eUaUm8RPX1Zkcf3fD8hAmpNXtmjYOIQi677da4rPX1ZsOG2frgaswYX5P0wQep6SZMyP+8m2xiNn68D3BHj/avayaTJpnttZdfjjoqtbYs4emn/Wu4446tfz369jWrrW18jqqqhqD+5z9P/Vz8/ve+Ni/jMY/4KjWY/N37OeVjzz0zvx533tmQ5m9/y5xm+fLmf4Dku2y5ZernYMGC1B9amYLJp54qTl5+9avGZU8PJjP8trWHH275ubbaquntG2/c+MdomMGkOuDE1Lx5furhp5/2912FNQaeSF569254bAa33x65D3FZGey6qx8U/bvfhfff94O4J4peUeHvY+vb13fOuesuWLAAevRIzFO5DD+rbBVbbunvsQR/L+gll6SeK3068f328wO3txXnfCcn8Pd/vv02/OtffpakhFWr/IQK+fryS9+BafJkP1lDtmN99RW89JJfHn7Yz8yUnI8f/xgOOsgPaP/OO/nnJ/l4mcb2ffXVhmGm/vlPf/+smX+thgzx9+JmNGp56voHPfPOm5kfReCaa/yEFqeckjldZSV8//t5nyarffbxIx+MGtXw3AYb+NEOmrL//q3rTLrrrn6M27//3Z/rj3/0Y8/+8pep6dauTZ0WdsgQOOKI1DRmforZlvr446a3f/UVHHssLF/edLo2ky3K1BLtmsknnkj9lTN+fNGz0+ai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rFgBtbWQNratSG5eecWPKykiJaXRsEAKJqWNKZiMkXHjoHt3f4tbly7w7rth50jajeuvhz33hJEj4fDD4e67/a8TEQld+uw3CialrakDToysWtXweM0a6Nw5vLxIO7JoEVx8sX/87bfw73/75Zln4IADws2bpPjvf//LhAkTGDx4MF27dmX48OFceOGFYWdLikwdcCRsCiZjRDPgSF7efRc6doS1axue23132Hff0LIkmc2fP58XX3xx/fquu+6qYDIGdM+khE3BZIxobm7Jy377wcKF8NRTcPvtsGABvPCChgQqQavTLnINWB4PCiYlbAomYyS5mRsUTEoLdO8Oxx7rFylZ6VMpKpiMB90zKWHTjRUxoppJkWhbm3wrAn5qRYk+jTMpYVPNZEyY+b4TyRRMSlaTJ/teWoccAp06hZ0bydGaNWtS1hVMxsPJ/fuzV8+erKyv54333uO7/fuHnSWJGQWTMZEeSHbpAs6FkxdpBy69FN55BzbcEE46CS64AAYODDtX0gwFk/E0oEsXBnTpAkAHYJsePcLNkMSOmrljQvdLSs7ef98HkuA72/zxj5DWjCalScGkiIRBwWRM6H5Jydltt6Wu778/bLJJOHmRFkkPJjvpFgURaQNq5o4JjTEpOTvxRF+Vfd99fpab004LO0eSI9VMikgYVDMZE2rmlpyNGQM33QTz58O998IRR4SdI8mRgkkRCYNqJmNCzdzSYt26wfe/H3YupAUUTIpIGFQzGRMKJkWiT8GkiIRBwWRM6J5JyerTTxt/QKRdUjApImFQMBkTumdSsjruOBg+HG65BdatCzs30goKJkUkDLpnMibUzC0Zff45TJvmH59xBlx/PUydqg9IO/WLX/yCbbbZhu233541a9YwUAPNi0gbUDAZEwomJaMnn0xd33BDfTjasX79+rHpppuy7bbbhp0VEYkRNXPHRHozt+6ZFMDXQib7znfCyYeIiLRbCiZjQjWTktFtt8HHH8O118L48XDooWHnSERE2hk1c8eEgknJyDnYcku/XHBB2LkREZF2SDWTMaFgUkRERIpBNZMxoXsmRaLvwQcfZMqUKXz44Yd07tyZgw8+mI033jjsbIlIxCmYjAnVTIpE38SJE3nuuefWrz/77LMKJkWk6NTMHRMKJkWiL33Q8k6dOoWUExGJE9VMxsR++0F5uQ8qV6+GUaPC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WH/3XY0zGWEKJkUkLLG4ZzLuVDMZPx2rq1MDyY4dYcstw8uQFN3atAtdwaSItBWFFTGgDjjx0/3zz1Of2Gor6NIlc2KJhD322IMLL7yQzz//nA033JDRo0eHnSURiQmFFTGgZu74qd10U7jrLnj/fb+MGBF2lqTIDjroIA466KDYz08sIm1PwWQMqJk7ftb27g1HHhl2NkREJAZ0z2QMqGZSREREikXBZAyoZlJERESKRcFkDKgDjoiIiBSLgskY0NzcIiIiUiwKJmNANZMx8/zz9Pj0U6ivDzsnIiISAwomY0AdcGLm3HMZc9ZZsOGG8L3vpQ5eLiIiUmAKJmOgrAwqKqBbN18rqZrJCPvyS/jkE/948WJ4+GHo1SvULImISLQprIiBH/zALxIDL7yQur7LLv6XhIiISJGoZlIkSgYNgiOOYF337n59v/3CzY+IiESeaiZFomT//WH//Xn1hRfYu6IC+vcPO0ciIhJxCiZFIsg6dICddw47GyIiEgNq5hYRERGRvCmYFBEREZG8qZk7Bu6/Hx591A8J1KkTHHUUHHZY2LkSERGRKFAwGQPvvQeTJjWsDx+uYFJEREQKQ83cMaDpFEVERKRYFEzGgKZTFBERkWJRHVUMnHyyHyVm3TpYu1YjxoiIiEjhKJiMgR128IuIiIhIoamZW0RERETypmBSRERERPKmYFJERERE8qZgUkRERETypg44MfDee7BkScMMOCNGQO/eYedKREREokDBZAz8+tfw+OMN648+CocfHlp2REREJELUzB0DGrRcREREikXBZAysXZu6rukURUREpFAUTMaAaiZFRESkWBRMxoBqJkVERKRYFEzGQHrNpIJJERERKRQFkzGgZm4REREpFgWTMaBmbhERESkWBZMxoJpJERERKRYFkzGgmkkREREpFgWTMaAOOCIiIlIsCiZjQM3cIiIiUiwKJmNAzdwiIiJSLAomY0A1kyIiIlIsCiZjQDWTIiIiUiwKJmNAHXBERESkWBRMxoCauUVERKRYFEzGgJq5RUREpFgUTEacGdTXpz7XoUM4eREREZHoUTAZcXV1qetlZeBcOHkRERGR6FEwGXHptZJlesdFRESkgBRaRFx6zaSauEVERKSQFExGnIJJERERKSYFkxGnYFJERESKScFkxCmYFBERkWLSiIMR17073HefDyrr6zXGpIiI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P//5zzjnWLt2Lffee2/IOWsdBZMRpZpJERGR0pJo4h40aBCnnnoqe+21V8rz7ZWCyYhSzaSIiEjpWL58OY899hgAJ5xwAmVlZfzgBz8AYNq0aXzwwQdhZq9VFExGlGomRURESsekSZNYvXo1ACeddBIAxxxzDF27dgXad+2kgsmIUs2kiIhI6UgEi9tuuy3bbrstAD179uSwww4D4J577qEu/Z93O6FgMqJUMykiIlIaPv30U1577TWA9U3bCYn1+fPn8+yzz7Z53gpBwWREadByERFpLeeKv5x1Vu7nz+ass6CysqLF524ribEky8rKOOGEE1K2HXTQQfTr1w9ov03dCiYjSs3cIiIi4TMz7rrrLgD22WcfBg4cmLK9U6dOHHfccQA89thjLF++vM3z2FoKJiNKzdwiIiLhq6qqYs6cOUDjJu6ExPOrV69m0qRJbZa3QlEwGVGqmRQREQlfoum6vLyco446KmOasWPHMnz48JT07YlCjIhSzaSIiLSWWfs4/8SJcN111VRUVBQ3Qy20cuVKHnroIQBqa2tzyt9rr73Gp59+uj64bA9UMxlRqpkUEREJ10MPPURNTU2L90t02GkvFGJElGomRUREwpVosu7Xrx833HBDs+mvvvpqpk2bxt13381vfvMbXFt2OW8FBZMRpZpJERGR8HzxxRdMmTIFgCOPPJLjjz++2X2++eYbpk2bxuzZs3nxxRcZN25ckXNZGGrmjijVTIqIiITnrrvuwoKbPo855pic9jn66KPX10a2p444CiYjSoOWi4iIhCdx32OfPn3YZ599ctpn4403ZuzYsQA8+OCDrFy5smj5KyQFkxGlZm4REZFwvP7668ycOROAww8/nI4t+CecqMWsqanh4YcfLkr+Ck3BZESpmVtERCQcyU3UuTZxZ0rfXpq6VV8VUaqZFBERCcdNN93ETTfdlNe+gwcPXn+vZXuhmsmIUs2kiIiItAXVV0XUuefCkCEfsuWWI1m3DnbdNewciYiISBQpmIyoMWOgpmYh7WSIKhEREWmn1MwtIiIiInlTMCkiIiIieVMwKSIiIiJ5UzApIiIiInlTB5yIeustePvt3tTX+zEmt9kGevcOO1ciIiISNQomI+qXv4QXXthu/fpzz8F++4WYIREREYkkNXNHlAYtFxERkbagYDKiNJ2iiIiItAWFGBE1ZgysWrWEioo+1NVBr15h50hERESiSMFkRP3xj1BV9T7jNAWOiIiIFJGauUVEREQkbwomRURERCRvCiZFREREJG8KJkVEREQkbwomRURERCRv6s0dUbvtBrNmjaVHDz9g+fPPw8Ybh50rERERiRoFkxH1xRcwf3639etmIWZGREREIkvBZERpBhwREZHSY2Y8/fTTPPHEE7zyyivMnz+fpUuX0r17dwYMGMCYMWM45JBDOOKII+jWrVvzBywBCjEiSnNzi4iIlJbXXnuNc889l2nTpjXatmzZMpYtW8aMGTO4++676dOnD5dccgnnnXceZWWl3cVFwWREqWZSRESkdNx1112cccYZrFmzBoAxY8Zw9NFHs+OOO9KvXz+qq6uZPXs2Tz/9NP/+979ZsmQJF1xwAaeffjq9SnxOZIUYEaWaSRERkdJQVVXFaaedRl1dHeXl5fzzn//k+9//fqN0e++9N6eccgrffPMNEyZM4Kabbgohty2nYDKiVDMpIiISvlWrVnHCCSdQV1dHWVkZjz/+OPvss0+T+/Tv358bb7yRfffdl06dOrVRTvOnECOiVDMpIiISvltvvZV58+YBcPbZZzcbSCY75phjipWtgirtOzolb+nBpGomRURE2t5tt90GgHOO8847L9zMFImCyQgyg/r61OdUMykiItK2VqxYwbvvvgvAFltsweabbx5uhopEwWQEpd8vWVYGzoWTFxERkbj64IMPqAv+KY8ePTrk3BSPgskIUucbEREpCOdSl2wmTkxNd9ZZ2dOOHp2adurUzOmmTk1N11QwdtZZVFRWNqSdODG3MhXZ4sWL1z/u379/0c8XFgWTEaTONyIiIuGrrq5e/7h79+4h5qS4FExGkGomRUREwldRUbH+8cqVK0PMSXEpmIwg1UyKiIiEr2/fvusff/PNNyHmpLhUZxVBqpkUEZGCMMst3VlnNX2fZLJs90imGz069/NPnEj1ddel1ARmlesxC2CbbbahQ4cO1NXVMTXXcrdDqpmMINVMioiIhK+yspLtt98egJkzZ/Lpp5+Gm6EiUTAZQRqwXEREpDScdtppAJgZf/7zn0POTXEomIyg9GZu1UyKiIiE4/TTT2ejjTYC4MYbb+T//u//ct73oYceahcddxRMRpBqJkVEREpDt27duOeee+jQoQP19fUcdthhTJo0qcl9Fi5cyE9+8hOOOeYY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EZH2bdGiResf9+nTJ8ScNE/BZASpZlJERArBzPJapk6dmvWYU6dOzfu42UycOJEVK1YU7Hil4J133ln/eMSIESHmpHkKJiNIQwOJiIi0b8ljS+65554h5qR5CiYjSIOWi4iItF8LFizgvvvuA3xHnP333z/kHDVNwWQEqWZSRESkfaqrq+OUU05h1apVAPzoRz/SPZPS9tQBR0REpP2ZNWsW+++/P08//TQAW2+9NZdddlnIuWqewowIUgccERGR0rNgwQKmT5++fr22tpalS5fy4YcfUlVVxVNPPUVdUCO09dZb88QTT5T8sECgYDKSVDMpIiJSem688UZuvPHGJtP06tWLs846iwkTJtCtW7c2ylnrKMyIINVMioiIlLaysjIqKiqorKxk4403ZvTo0ey2224cccQR7SaITFAwGUGqmRQRESkN48aNK/kxLVtLHXAiSDWTIiIi0lYUTEaQhgYSERGRtqIwI4ImT4bVq+HVV99gzJhdGDw47ByJiIhIVCmYjKABA/zf2bNXU+LTeYqIiEg7p2ZuEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERGRAquvr6d3794459h6662bTb/NNtvgnMM5x2WXXdZk2k8++WR92pNOOqlQWc6bgkkRERGRAisrK2OPPfYA4OOPP2bRokVZ0y5ZsoQPP/xw/fpLL73U5LGTt++1116tzGnrKZgUERERKYLkQK+pAPHll1/GzOjQoQMA//nPf1izZk3W9MnH2nvvvQuQ09ZRMCkiIiJSBMmBXnPBJMAhhxxCjx49WL16NW+++Waz6fv378+IESMKlNv8KZgUERERKYIdd9yRHj16AE0Hk4lt48ePZ5dddmky/ZdffsmcOXOA0mjiBgWTIiIiIkXRsWNHdt11VwDee+89VqxY0ShNTU0N06ZNA2DPPfdcf59ltmDyxRdfXP9YwaSIiIhIxCWauuvr63nllVcabX/ttddYt24dPXr0YIcddmDPPfdc/3xdXV2j9KV2vyQomBQREREpmuY64STuf9x1113p0KEDu+yyCx07dqS6unp9jWWm9H369GHUqFFFynXLKJgUERERKZKdd96Zrl27ApmDycRziRrJ8vJydtxxx4zpFy5cyIwZM9and84VLd8t0THsDIiIiEhpcVVVYWehTdm4cUU7dpcuXdh555156aWXePvtt1m1ahXdunUD4Ntvv13fazsRTCYev/nmm7z00kucf/75658vtfElE1QzKSIiIlJEiXsb165dy+uvv77++TfffJPVq1fTqVMnxo4du/75RCecV155BTNb/3wp3i8JCiZFREREiirbfZOJ+x/HjBmzvrYSGoLJxYsXp8yMk0hfWVnJ9ttvX8wst4iCSREREZEi2nXXXenUqROQGkym3y+Z0K9fP7bccsuUNCtWrOC9994DYPfdd18/W04p0D2TIiIikqKY9xAWS3V1NRUVFWFnI6Pu3bszevRo3njjDd544w3Wrl1LWVkZr732GtA4mEw8N2PGDF566SXOOeccXnnlFerr64HSul8SVDMpIiIiUnSJAHDVqlW89dZbTJs2jerqapxz7L777o3SJ5q6E03bpXq/JCiYFBERESm69PsmE0HiqFGj6N27d6P0idrKuXPn8tlnn61PX15ezpgxY9ogx7lTM7eIiIhIke2xxx6UlZVRX1/PSy+9RJcuXYDMTdwAQ4cOZdCgQXz99dc888wzvP3220Dq/ZelQjWTIiIiIkXWs2dPtttuOwBeffXV9VMrZgsmoaGp+/rrr2fNmjVA6d0vCQomRURERNpEIhBcsWIFixYtAnILJj///PP1z5Xa/ZKgYFJERESkTaTXKiaasrNJDzS7dOmSMrh5qVAwKSIiItIG9tprr5T5tBM1j9lss8029OzZc/36TjvttH6e71KiDjgiIiIibaBfv37rx4rMRVlZGcuWLStehgpENZMiIiIikjcFkyIiIiKSNwWTIiIiIpI3BZMiIiIikjcFkyIiIiKSNwWTIiIiIpI3BZMiIiIikjcFkyIiIiKSNwWTIiIiIpI3BZMiIiIikjcFkyIiIjFiZmFnQUJSrPdewaSIiEhMlJWVtWhuaImW+vp6ysoKH/opmBQREYmJbt26sXLlyrCzISFZuXIl3bp1K/hxFUyKiIjEREVFBdXV1WFnQ0JSXV1NRUVFwY+rYFJERCQmKisrqa2tZenSpWFnRdrY0qVLqa2tpbKysuDH7ljwI4qIiEhJ6tChA4MHD2bOnDnU1tZSUVFB9+7dKSsrwzkXdvakgMyM+vp6Vq5cSXV1NbW1tQwePJgOHToU/FwKJkVERGKkc+fODBs2jBUrVrBs2TLmzZsXiU45q1evpmvXrmFnIzSZyl9WVka3bt2oqKhgwIABRQkkQcGkiIhI7HTo0IHevXvTu3fvsLNSMFVVVeywww5hZyM0YZZf90yKiIiISN4UTIqIiIhI3hRMioiIiEjeFEy2kHOuwjk3wTn3gXOuxjm33Dn3lnPuAudc57DzJyIiItKW1AGnBZxzg4EqYEjwVC3QBRgTLCc65/Y1Mw3gJSIiIrGgmskcOec6Ao/jA8l5wP5m1h0oB44HqoEdgLvDyqOIiIhIW1MwmbtTgG2Cx0eb2fMAZlZvZpOAHwXbDnHO7RtGBkVERETamoLJ3J0S/J1iZq9n2H4/MCt4fHLbZElEREQkXAomc+CcKwd2D1YnZ0pjZgY8Hawe0Bb5EhEREQmbgsncbEXDazW9iXSJbQOcc32KmyURERGR8CmYzM3ApMdfN5EuedvArKlEREREIkLBZG4qkh7XNpEueVtF1lQiIiIiEaFxJtuQc+4s4KxgtcY590mRT9kPWFTkc5SyOJc/zmWHeJc/zmUHlT/O5Y9z2aH45R+cbYOCydxUJz0ubyJd8rbq9I1mNhGYWKhMNcc597aZjWmr85WaOJc/zmWHeJc/zmUHlT/O5Y9z2SHc8quZOzdzkx4PaiJd8ra5WVOJiIiIRISCydx8DNQHj0c1kS6xbb6ZLSlulkRERETCp2AyB2ZWC7warB6UKY1zzgEHBqvPtkW+ctBmTeolKs7lj3PZId7lj3PZQeWPc/njXHYIsfzOj7UtzXHO/RD4J2DArmb2n7Tt3wMmBav7mdkLbZxFERERkTanmsnc3QF8ADjgocT82865MufcscA/gnSTFUiKiIhIXKhmsgWcc0OAKcCQ4KlafEDeNVifBuxrZkvbPHMiIiIiIVDNZAuY2WxgW+A3+KkTDVgLTAUuBHYJO5B0zlU45yY45z5wztU455Y7595yzl3gnOscZt5awzl3qnPOclj2a+IYmznnbnbOzXLOrXbOLXTOPeOcO7oty5IhX+XOuYOdc5c65x52zs1JKs+EHI/R3zl3nXPuE+fcKufcEufcy865M4L7eZvbP7TXpjXlDz7ruXwuNm/mODs65+52zn3lnPvWOTfPOfeIc26fgha28Xn7OudOC879kXNuZXD+r5xzjzrnjszhGK265lv72WmN1pS/EN8JwXHC/Ozv6Jy73Dn3b+fcDOfcYufc2uDvq865S1wzU/O212u/NWVv79d9E/m5ODn/zaQtrevezLREZMEPKDoLH+QasBJYnbT+DtA77HzmWbZTgzLUAfObWPbMsv8hweuReC2WB8dKrN9KUFMfQtnGJeUjfZmQw/6j8QPVJvapxv/ISaw/DXRuYv9QX5vWlB+YEKRb08znYkgTxzgj7fVahh+9Ief3oBVlX5tW3lVATdpzTwHlWfZv1TXf2s9OmOWnld8JJfLZ/2uG8q9Ie24h/j79SF37rSk77fy6z5KfEcFrsL78TaQtueu+zV4oLcVd8APQvx98EObiOwGBr30+LukifTLsvOZZvlOD/M/OY9+hNPyDegXYIni+B3BF0gV0UUhlGwcsAZ4HrgaOB+bl8oUG9ExK+zEwJni+M/CT4MvWgL+X6mvTyvIn/qlU5XnuXYF1wTEeATYOnu8L3JRU/u8VqewG/Ac4GxiW9PwQGjr8GXBXhn1bdc239rNTAuXP+zuhhD77JxO0agG9kp7vEWxbEOThG6BnId+/sMvfyrJPoB1f9xnyU4YfMcaA1xLnz5K2JK/7or9IWtpmAX6YdAFk+iX3/aTt+4ad3zzKl/c/DuCuYN95yV9aSdtvpuFXeZvX3AIdMjw3m9yCqd8G6WqBoRm2/zLYvi7xz6LUXptWlr+1/1ReDvZ/H+iUYfvTwfZZmfJZgLKPb2Z78j+2TdK2teqab+1npwTKn/d3QrB/6J/9HPJ4QFL5Tyzk+1fq5W+m7O36us9wvp8F57s7qWyWJW1JXve6ZzI6Tgn+TjGz1zNsvx9/YYD/1RcLzrnuQOLenxvNbFmGZL8P/lYCR7RBtlKYWV0rdk+8l/eb2awM22/A1z50AE5M3lAqr00ry58359wwYI9g9VozW5shWaL8Q4C9Cp0HM5vSTJJbkh6nT5PW2ms+789OobSy/Hkrlc9+Dt5Ierxx2rZ2f+03o6my560Urvu0/AwFrgQWAz/PYZeSvO4VTEaAc64c2D1YnZwpjfmfHE8Hqwe0Rb5KxB5At+BxttdmNr66H9rRa+OcGwFsGqxmK1sN/lc4NC5bZF+bHO2f9PjpLGlewd9PBOGUf3XS4w6JB6295gvw2WkrGctfAO3ls79n0uP/Jh7E5NrPWPYCKLXr/h9Ad+B8M1vYVMJSvu4VTEbDVjS8l9ObSJfYNqC5HoIlbAPn3NSg99oq59znQW+8cVnSJ09/mctrM7IQmWwjLS3b1q3cv5Rfm5HOuenOudrgs/GJc+4fzrkdmtgnUf4FZrYgU4Kg1nRG4hyFzHCOxiU9/iDpcWuv+dZ+dtrKuKTHH2RJ09LvBCjhz75zrotzbohz7lx8UzTAZ8DjSckiee3nWPZk7fq6d86dCewLPG9md+awS8le9womo2Fg0uOvm0iXvG1g1lSlrRzYEX+TcBn+JvITgSnOuVudcx3T0ifKudTMVjVx3MRr055el5a+75XOuR4Z9o/Ca9MP/0W7CugCbIHvrTnVOfe7LPskytPUa5e8vU3L75zrhb9/CeBlM/skaXNrr/nWfnaKrpnyJ2vpdwKU4Gc/GJbH8LWxs/DNjb3xHTP2NbNvk5JH6tpvYdmTtdvr3jk3CLgGn/cf5bhbyV73CiajoSLpcW0T6ZK3VWRNVZrm4nsYbgd0NbM++H8iu+N7AQOcBvwxbb9EOZt6XZK3t6fXpbXvexRem0+Bi/DDanQ1s774JqMD8eO/OuAS59wFGfYt2fI758rwNTMb4f/BnpuWpFDvfb77F1UO5Yf8vxOgNN/7+fieyyuTnpsCnGdmX6Sljdq135KyQzSu+5vxPasnmNnnOe5Tste9gklpF8zsWTObYGbvJ36lmlmdmb2G/wJ5LEh6jnNueGgZlTZlZveY2TVmNjNxI72ZrTGzZ/H3hb0VJJ3gnOsZWkZb7s/AocHjn5jZ+2FmJgTNlj9q3wlmNsTMBphZD6A/ftic7YE3nXO/CTVzRdbSsrf36945dxLwHeBd4Ppwc1MYCiajoTrpcXkT6ZK3VWdN1c6YWT3+ywf8Z/qwpM2Jcjb1uiRvb0+vS2vf9yi/NpjZauBXwWoP/L1JyUqy/M65a2moifu5md2aIVmh3vt89y+aHMvfpGa+E6BE3/sEM1tgZtcBB+GHafm1c+7QpCSRvfZzKHtz+5f0de+c6w/8CT84/Jlmtq4Fu5fsda9gMhrmJj0e1ES65G1zs6Zqh8zsM/yI/gDDkjYlytnbOdeN7BKvTXt6XVr6vq8Ieuql7x/F1yYheeiMYWnbEuVp6rVL3l708jvnrgYSTXMXmtmfsiRt7TXf2s9OUbSg/M1q4jsB2sln38zexPcsBjgraVPkr/0myp6LUr7u/4AfHH0iMMM51yN5wQ8eDkDS84nnSva6VzAZDR/jp4GC1N5a6RLb5pvZkuJmqWQk91jL5bX5sIh5KbSWlu2jVu7fnl6bXCTKv6FzboNMCZxzHYAtg9Wilt85dw3wP8HqRUHtTDatveZb+9kpuBaWv7Xa02c/0RkieZ7puFz7mcreWmFf90ODv2fja/3Sl18mpU08d3WwXrLXvYLJCDCzWnyvN/BNA40EE7cfGKw+2xb5akvOuc3wPfugYcBW8L9sE70Vs702g/E9AqF9vTYzgcTN6dnK1p2G8drSyxbl1yZhl6TH6QP0Ppf0OGP58Z05EjegF638QdNuoln2IjO7pqn0BbjmW/vZKaiWlj/HY2b7ToD29dlP1KwlNzfG5drPVPZctIvrvqVK+rrPNjWOlva10DDFUj0wNsP279FOp1MEXHPbgYeDstUBI9K2J6YNm0vaHK/B9r8H21cQ0rRpGfI0m5ZNp7gSGJJh+0XkNqVaSb02uZQ/h89FF/wsGoaf0aFXhjSJadXeJfO0ak8F22dTpGnVgGuTrs0LWrBfq6751n52wix/a78TgjShfvbxg7A3V459g/fXgKsK+f6FWf7WlD0q130T+Z+QuB6ybC/J677NXiAtxV1Infz9q8SHCF/7fCx+flUDngo7r3mUbQjwJn4srmGJL5OgbLvQMI+qkWFyenyzQk2w/SVgePB8d+CypC+si0IsY298LUpi+SLI09Vpz/dI268nfm5dwzfHjA6e74xvRvk22+tSSq9NPuUH9sYPAfMDYOOk5zvh/xG9mfS5yJh/YLfgS9OAh4BBwfN9aPhnasD3ilTuq5PO8fMW7tuqa761n50wy08rvxNK4bMflOHd9DIE2zYBLk7K32JgQCHfvzDL35qyE4HrvpnXZkLi/Fm2l+R136YvkpbiLsEFOivpQliJb8pIrL9DidS85VEuS1pWAwuDv8nP3wp0zHKMQ4LXI5F2WdKXSWLfJn/xFrmMs9PKkm25PcO+o/EdDRJpVuAHcE6sPwN0aeLcob82+ZQfPztK8rba4HORXPY64Mpmzn0GsDZpn6U0/CM1mqkdbkWZN03L5/xmlguzXBt5X/Ot/eyEVX4K8J0Q9mc/Qxm+DcpQk/b858AOxXj/wip/a8pOO7/uc3htJiTy0MzrV1LXfZu/UFqKu+Dv87gCP/VYTfAheRvfQ7Jz2PnLs0zd8EOF3IP/JbUg+BKoxt+QfAuwew7H2Qzfg24WDf98ngWOLoEyzk77gsw5mAz2748fr2xm8KWyFN+UcwZQVuqvTT7lx/eIvAB4EPgEX4OxFv/L/F38LBrb5Hj+HYPP11f4f2zzgUeAfYpY5iE5lrnJf26tveZb+9kJo/wU6DshzM8+viboGOCv+HERvw4+e7XAHODf+CbNbsV8/8Iof2vK3t6v+xzyNCHxmW8mXUld94mmARERERGRFlNvbhERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkRERERyZuCSRERERHJm4JJEREREcmbgkkREcnKOVflnDPnXFXYeRGR0qRgUkQkjXNuXBBAtWR5NOx8i4iEQcGkiIiIiOStY9gZEBEpcTcCf88h3YpiZ0REpBQpmBQRadoCM5sediZEREqVmrlFREREJG8KJkVEisA5NzvomHN7sD7aOXe3c+4L59xq59xc59y9zrkdczzeLs65251znzvnap1zK5xz051z1zvnNs3xGH2cc79yzr3knPvGObc2OM47zrm/OOd2y+EYA51z1zrnZjrnVjnnljrn/s85d2wO+x7unHs46TVYGbxOrzvnrnHOjc+lHCJSWpyZhZ0HEZGS4pwbB0wJVq8wswl5HGM2MBi4A3gRuBnolCHpOuCnZnZTluM44HrgvCZOtxo408zubiI/xwC3AJVN5dvMXNp+VcDe+DL8CngU2CDL7teZ2YUZzt0BuAc4rqlzA9+Y2YBm0ohIidE9kyIixbU9cAKwBPg98AY+qNwPuBDoDvzdOTfHzCZn2P9KGgLJr4A/AG8BXYADgAuAbsCdzrmlZvZk+gGcc8cB9wEOWAPcCjwJzA323Ro4GDi0iXJsBDwWPL4EeAlYBewEXBZsv8A5N9nMXkjb98c0BJKvAf8E/ovvtNQHGBW8Hts3cX4RKVGqmRQRSZNWM5lrb+5ZZrYy6Riz8TWT4IPAXczs67Tz7AC8jA8o5wCbm9m6pO0jgffxtyR9CuxmZovSjrETUAWUA/OAoWb2bdL2DfGBWw9gMXCAmb2TpdybmNmXac9V4WsmAb4Eds+QZosgn12AR83syLTtLwF7Am8G+68jA+dcXzNbnGmbiJQu3TMpItK0s4EPclh2auIY56cHkgBmNg24OlgdDByWluQcGr6nf5QeSAbHeAtfWwm+dvCYtCT/Dx9IAvwkWyAZHOvLbNsCP82Uxsxm4pu/AfbKsF+i6frVbIFkcBwFkiLtkIJJEZHiWgo80sT2W5Me75+2LbH+uZlNIbt/NHGMRNP118ADTRyjOcuBx5vY/nbwt49zrlfatrnB38Occ/1akQcRKUEKJkVEmnaFmbkclqos+09rpjbuK3zzNMC2ieedc12A4cHqG01l0MzmA7OD1W2SjtExaf1VM6tv6jjNmNnM/kuSHlekbbs9+Ls58F/n3G3OuROdc4MRkXZPwaSISHEtyCHNN8HfvknP9W7hMeYHf/skPdeXhu/5ebRObTPbkwPNDskbzOx24DfAWnxv8lOBu4HZwdBAf3XOjWpl/kQkJAomRUSKqxC9HNt9T0kzuxzYDPgF8CxQE2waDPwEeN85NyGc3IlIayiYFBEprv4tSJPcAWVpC4+R6OSS3Ny8hIYaw41yOEZRmdmXZna1mR0I9ALGAlfhhwhywOXOue+GmEURyYOCSRGR4tohuHcxI+fcIBoCvQ8SzwfD+3warO7c1Amcc/2BIRmOsTZpfQ/nXMl855tZnZm9aWYXAwclbfpeWHkSkfyUzBeLiEhE9QYOb2L76UmPn0vblljf3DmXacidhDOaOEaiB/ZASjRQM7PXabgnU729RdoZBZMiIsV3vXOuUTOzc2474KJg9UsaD73zdxqaqW9yzvVO204wt/cvg9V5wINpSf5Kw/2Jfw0GSs/IObdJU4XIl3PuB865TFNJJrbvgR90HWBWMfIgIsWj6RRFRJq2YY49jdcEg3enew8/XeE7zrnEdIod8dMH/g9+QHEDzgmapdczsw+dc1fhg8WtgGnB+tukTqdYHhzjzOTZb4JjfOOc+xF+buy+wOvOufTpFLfET6d4ONA5h7K21J3Atc65R4FXgc/wUzFugB/k/CdBunXAxCKcX0SKSNMpioikSZtOMVdzzGxI0jFm43sq34GfMvEmMv+ArwN+ZmZ/y5IXB/wR+FkT516NDyTvzpbAOXcCPlDr3lQhzMyl7VeFn07xRTMb18TxTwVuC1aHmtnspG25/KNZhS/DPTmkFZESoppJEZEiM7NbnHMfAOfh56jeEN/T+kXgGjOb2sS+BpznnLsfP7XjXvie2+vw83k/C/zZzOY0k4d7nXPP42sBD8IPIN4T3wT+GfAScG8ritmUUcAhwB744YH643tzr8R3MnoeuNHMvijS+UWkiFQzKSJSBMk1k2Z2ari5EREpHnXAEREREZG8KZgUERERkbwpmBQRERGRvCmYFBEREZG8KZgUERERkbypN7eIiIiI5E01kyIiIiKSNwWTIiIiIpI3BZMiIiIikjcFkyIiIiKSNwWTIiIiIpI3BZMiIiIikrf/D7ECirnzQv9wAAAAAElFTkSuQmCC\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='A')\n",
    "\n",
    "plt.plot(list(range(100,400)),Results2[100:], ':r', linewidth=4.0, label='C')\n",
    "\n",
    "plt.plot(list(range(200,400)),Results3[200:], '--k', linewidth=4.0, label='D')\n",
    "\n",
    "plt.plot(list(range(300,400)),Results4[300:], 'c', linewidth=4.0, label='W')\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": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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mQwhtUyKiIhIrnQKOgBpfwMGwC67wJYtW+ncuStdugQdkYiIiISVkskQeuop77m8/HUmTpwYaCwiIiISbuoAFREREcmRBQsWYGb1j0ceeSTokNpMyaSIiIhIjtx9992Nlu+5556AImk/SiZFREREcqC2tpb77rsPgB49egDw1FNPsWbNmiDDajMlkyIiIiI58Oyzz7JixQoA/vjHP2JmbN++nfvvvz/gyNpGyaSIiIhIDsS6uMvKyrjgggs44ogjGq3vqJRMioiIiGTZpk2b+M9//gPAWWedRUFBAeeeey4A8+bNY/78+UGG1yZKJkVERESy7MEHH2TLli0AnHPOOQBMmTKFbt26AR27dVLJpIiIiEiWxZLFUaNGMWrUKABKS0v58pe/DMB9991HbW1tYPG1hZJJERERkSz6+OOPmTlzJkB913ZMbHnlypU8++yzOY+tPWgGHBEREWnEysuDDiGnXJZni4uNJVlQUMBZZ53VaNvxxx9Pv379WLt2LXfffTcnnHBCVmPJBrVMioiIiGSJc457770XgCOPPJJBgwY12t65c2fOOOMMAP7zn/+wadOmnMfYVkomRURERLKkvLycpUuXAk27uGNi67ds2cKDDz6Ys9jai5JJERERkSyJ3XhTVFTEV77ylaRlxo8fz+67796ofEeiayZFRESkkWxfQ5gNlZWVlJSUBB1GI5s3b+aRRx4BoLq6Oq34Zs6cyccff1yfXHYEapkUERERyYJHHnmEqqqqVu8Xu2Gno1DLpIiIiEgWxLqs+/Xrx0033dRi+RtvvJF58+Yxffp0rr/+esws2yG2CyWTIiIiIu1s2bJlzJgxA4DTTjuNM888s8V9Vq1axbx581iyZAkvvfQSEzvI5Qbq5hYRERFpZ/feey/OOcCbNjEdp59+en1rZEe6EUfJpIiIiEg7i1332KdPH4488si09tlll10YP348AA8//DCbN2/OWnztScmkiIiISDt6/fXX+eijjwA45ZRT6NQp/asKY62YVVVV/Otf/8pKfO1NyaSIiIhIO4rvok63iztZ+Y7S1a0bcERERETa0V//+lf++te/ZrTvkCFD6q+17CjUMikiIiIiGVMyKSIiIiIZUzIpIiIiIhlTMikiIiIiGVMyKSIiIiIZUzIpIiIiIhlTMikiIiIiGVMyKSIiIiIZUzIpIiIiIhlTMikiIiIi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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='W')\n",
    "\n",
    "plt.plot(list(range(100,400)),Results21[100:], ':r', linewidth=4.0, label='D')\n",
    "\n",
    "plt.plot(list(range(200,400)),Results31[200:], '--k', linewidth=4.0, label='C')\n",
    "\n",
    "plt.plot(list(range(300,400)),Results41[300:], 'c', linewidth=4.0, label='A')\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"
   ]
  }
 ],
 "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
}
