{
 "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\"] = \"3\"\n",
    "# from keras import backend as K\n",
    "# config = tf.ConfigProto()\n",
    "# config.gpu_options.allow_growth = True\n",
    "# K.tensorflow_backend.set_session(tf.Session(config=config))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "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": 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": [
    "epochs = 5000\n",
    "epochstep = epochs/100\n",
    "nofclasses=65\n",
    "batchsize=650 \n",
    "nofprojections = 100\n",
    "wd = 224\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "imgX = Input(shape=(2048,), name=\"input_img\")   \n",
    "labelX=K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "\n",
    "imgY = Input(shape=(nofclasses,) )   \n",
    "labelY=K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "\n",
    "\n",
    "labelW =  K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "imgW = Input(shape=(2048,), name=\"input_img1\")   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encoderNN(imgX = imgX, nofclasses=nofclasses):\n",
    "\n",
    "    \n",
    "     \n",
    "    \n",
    "    x = Dense(1000, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(imgX)\n",
    "    x = Dense(500, activation='relu', use_bias=True, kernel_initializer='glorot_uniform')(x)\n",
    "    #x = Dense(100, 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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ReadData(sourceL,targetL,distL,lastL):  \n",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/officehome_resnet50/'\n",
    "    savedImg = []\n",
    "    folder =  sourceL # e.g,'webcam_webcam.csv'\n",
    "\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            USPSMat.append(row)\n",
    "\n",
    "\n",
    "    dataX_train = np.zeros([len(USPSMat),2048])\n",
    "    labelX_train = np.zeros([len(USPSMat)])\n",
    "\n",
    "    i = 0\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            temp = np.array([float(i) if '.' in i else int(i) for i in row])\n",
    "            dataX_train[i,:] = temp[:2048]\n",
    "            labelX_train[i] = int(temp[2048])\n",
    "            i = i + 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",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/officehome_resnet50/'\n",
    "    savedImg = []\n",
    "    folder =  targetL # e.g'webcam_amazon.csv'\n",
    "\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            USPSMat.append(row)\n",
    "\n",
    "\n",
    "    dataY_train = np.zeros([len(USPSMat),2048])\n",
    "    labelY_train = np.zeros([len(USPSMat)])\n",
    "\n",
    "    i = 0\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            temp = np.array([float(i) if '.' in i else int(i) for i in row])\n",
    "            dataY_train[i,:] = temp[:2048]\n",
    "            labelY_train[i] = int(temp[2048])\n",
    "            i = i + 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",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/officehome_resnet50/'\n",
    "    savedImg = []\n",
    "    folder =  distL # e.g'webcam_amazon.csv'\n",
    "\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            USPSMat.append(row)\n",
    "\n",
    "\n",
    "    dataZ_train = np.zeros([len(USPSMat),2048])\n",
    "    labelZ_train = np.zeros([len(USPSMat)])\n",
    "\n",
    "    i = 0\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            temp = np.array([float(i) if '.' in i else int(i) for i in row])\n",
    "            dataZ_train[i,:] = temp[:2048]\n",
    "            labelZ_train[i] = int(temp[2048])\n",
    "            i = i + 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",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/officehome_resnet50/'\n",
    "    savedImg = []\n",
    "    folder =  lastL # e.g'webcam_amazon.csv'\n",
    "\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            USPSMat.append(row)\n",
    "\n",
    "\n",
    "    dataW_train = np.zeros([len(USPSMat),2048])\n",
    "    labelW_train = np.zeros([len(USPSMat)])\n",
    "\n",
    "    i = 0\n",
    "    with open(curPath +folder, newline='') as csvfile:\n",
    "        readCSV = csv.reader(csvfile, delimiter=',')\n",
    "        for row in readCSV:\n",
    "            temp = np.array([float(i) if '.' in i else int(i) for i in row])\n",
    "            dataW_train[i,:] = temp[:2048]\n",
    "            labelW_train[i] = int(temp[2048])\n",
    "            i = i + 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",
    "    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": 10,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.1.6\n"
     ]
    }
   ],
   "source": [
    "print(keras.__version__) #2.1.6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.3.0\n"
     ]
    }
   ],
   "source": [
    "print(tf.__version__) #1.15.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "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": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "numtrial = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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",
    "    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",
    "    epochs = 5000\n",
    "    epochstep = epochs/100\n",
    "    nofclasses=65\n",
    "    batchsize=650 \n",
    "    nofprojections = 100\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=650 \n",
    "        epochs = 5000\n",
    "        sizeperCl = 10\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",
    "\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",
    "        batchsize = 650\n",
    "        epochs2 = 500\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",
    "            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=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",
    "                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": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "Results = np.zeros([12,numtrial])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sourceL = 'Art_Art.csv'\n",
    "targetL = 'Art_Clipart.csv'\n",
    "distL = 'Art_Product.csv'\n",
    "lastL = 'Art_RealWorld.csv'\n",
    "Results1, Results2, Results3, Results4 = genresults(sourceL,targetL,distL,lastL)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "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"
     ]
    }
   ],
   "source": [
    "sourceL = 'RealWorld_RealWorld.csv'\n",
    "targetL = 'RealWorld_Product.csv'\n",
    "distL = 'RealWorld_Clipart.csv'\n",
    "lastL = 'RealWorld_Art.csv'\n",
    "Results11, Results21, Results31, Results41 = genresults(sourceL,targetL,distL,lastL)\n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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++67L0888QTWWhYuXMiBBx5Io0aNADjem4+g/MQjBZNJRjWTIiLiz1rLK+vWcd1vv7Fixw6387ffaj0fKUBJmGP7Z2ezuaiIX4JrRICbOnbkmGbNmLlqFbl77834NWv499KlpKWk8Mzuu3OEJ4D0l56aivfPX1FREUcccQRffvll6fHGjRtz0003cf3115NTrx53dejA8OHDmTJlikvQsiVkZ8O6dW5alKVL4Y8/AJg2bRpXXHEFLVq0YNiwYVxzzTWl1x04cCBvvPEG2dnZZfLUsWPHyrxMcUnBZJJRzaSISHKx1vL6+vUs89QmfL55M5uKithYVMQWz2NrOaux1LS2aWkc2qgRQ5s3p3t6Or2zsvhr506a1a9PRmoqs7ds4bMtWxjUpAmFJSWUWMshntq6Bfn51DOGK5Ys4bu8PEa1bcsxzZoFXP/c1q05p1UrjDHl5sNay48//shTTz0VEEgCbN68ma1bt1JcXExqairXX3+9L5AE+Osv9wD49NPS3T179uTcc88t3b7yyivZvn07r776Koceeij33HMPmZmZkbxscU3BZJJRzaSISHK5eelS7vHUmtW0esaQmZLCFr9g1ABHNG7M7C1b2GEt9Y3h5BYt6JaezmVt29K6QYMy1+ngV7NxUKNGHOQJHoPtnZUFwEe9e2OtDRswVhRITpkyhdGjR7PAbwohf1deeSVjxowBYMuWLbz33nvlXg+gW7dufP311wG1jikpKdx4443ceOONFZ5flymYTDKqmRQRSR7TNmyoViDZLi2NTUVFFJQENkBnp6ZyXuvW3NmlC9me6WpW79jBG+vXs29WFoc0asRfO3fy1datHJCTQ6swK8xUR3DAuH37dnbs2MH27dt56aWXMMYwbNgwmgXVXALMnz8/bCAJMG7cOKy1/O9//+PMM8/kt6Bm/912240WLVrwzTffsGvXLtq1a8err74asvk6GSiYTDKqmRQRSWyfbNrE+l27OLRRI85btKhS52SkpJDbuDF3d+1Kr8xMFuTn0zYtjRZpaRRby86SEtJTUykqKWFzURFN69cnJSiYa9OgAZe2a1e63TItjaFRHDzywQcf8OKLL/L999+zfPlytoSYxPyaa67h//7v/zj//POrdO3s7Gxuv/12UlJS2G+//UprJhs0aMDnn3/OfvvtB7im8pUrV9KsWTPSk/gPqoLJJKOa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KioqKnfbWsvJJ5/MRRddxGmnnca//vUv1q9fzwsvvED37t2ZOHEiBQUFlJSU8O233zJ//nxKSkqw1rJ8+XIWLlzI22+/zVVXXcWtt97Kxo0b+eKLLzj33HNL7/Hee++RlZVFixYtOProozn22GPJzc1lzZo1lJSUcP3119OsWTOuvvpqVqxYEZC/iy++mOeee47vv/+eiy66iK+++qr02EknncQ777zDqlWruOmmm/jiiy/48MMPaagvf6lp1lo9YvDo16+fjbYZM2YEbD/0kLVuqnL3uOKKqGchpoLLn0ySuezWJnf5k7ns1oYu/4IFC+zzzz9v//zzz4D9N998s01PT7d77rmnXbJkiT3ttNNs/fr17d/+9je7bds2a621s2fPtkC5j6ysrIDtjIyMCs8B7PTp021eXp5t0qRJpdIDNjMz027ZssVaa+3XX38dMs0+++xjb731Vjt//vyov97xRO/9GVG9PvCdDRPTqM9kEjn+eOjSBXbscA9NGSYidc327dvZtm0bjRo14vnnn+ePP/7gvPPOo2vXriHTP/3001x88cWUlJTQunVrvvzyS7p06cLHH3/MXXfdBcDPP/9Mjx49Ss/56KOPuPfeexkzZgwvvvhihXnatm0bPXr0YOvWraxdu5aCgoIKz+nYsSN77bUXaWlp/O9//2PMmDH89ttvFZ532GGHlQ6W6d27N506dWL58uUBaebNm8e8efMoLCzk/vvvr/CaItWlZu4k0rUrDB0Kp5wCZ50F++0X6xyJiFTOtm3bOO6448jIyKBFixakpaUxcuRI7rzzTg499FDWrVvHX3/9xZVXXknz5s25/fbbmTx5MqNGjaKkpASANWvWcNlll2GtpVGjRuXe75577sFay+WXX16p/E2ePJkffviBI488slLply5dSvv27UlLS2O//farcPoer/POO6/0eVpaGi+88ELYtCeccEKlrilSXQomRUQk7t155528++67uNa2QKtXr+aWW27h+uuvZ968eWzYsIHRo0dz1llnlUk/bdo0Fi9eTP/+/dl///3D3q+4uJivvvqKHj168OOPP5abtyOPPJL+/fuzfv36MgN0Qq1zfd999wWM0N5zzz159tlnqVfP11i4zz77cPrpp5OdnR1w7tChQwO2e/fuTWpqapl7tGjRgoMOOqjcfIvUFDVzi4hIrSgpKWH69OmsW7eOk08+mbVr19KiRQuys7P5+OOP+eSTTxg0aBBHHHFEmXM/+uijcq89duzYSudj6NChzJ8/n1GjRvHNN9+ETTdgwAD++usv9t57b3r27MnChQtLj40ePZqSkhJSU1O59NJLMcbQq1cvPv74Y7788kv++OMPBg4cSLt27fjjjz847rjjmD9/Prm5uSHXxD7jjDPYZ599mD9/PscccwyNGzcG3FraixYtol+/ftSvX7/MeRkZGey5557Mnz8/YP+ZZ54ZMsgUiYpwnSn1SLwBOMkmmcufzGW3NrnLH89lz8vLs507dw4YLNKwYUPbpUuX0m1jjH355Zft5s2bbUlJSem5RUVF9v3336/0QJXyHg888IC11tpt27bZxo0bh02XlpZmV6xYYa21dtq0abZhw4YWsOecc05A3iqjuLjYrlu3rsrnVcZJJ51UJu+//vprjd8n3sXze782xHIAjpq5RUSkxq1du5Y33ngjYF9WVhbjxo0L2Ld9+3aWLl1aum2t5bTTTmOvvfaisLCwdH9qaiqDBg3in//8Z9h7du7cucy+1NRUnn/+eX7++WfuuOMO3nzzTa699loAMjMzGT9+PM2bNw95vWuuuYZ27doBcMwxx7BixQp+//13nn/++SqvWZ2SkkLz5s2jstb14MGDA7ZPOOEEunXrVuP3EQlHwWQSmTPHTVr+4Yfw2Wewbl2scyQiddHGjRu54447uPzyy5k5cybFxcW8/fbbHHXUUbRu3RpjDK1bt2bYsGG8//77pedt3bqVPn36cMkll1R4j5UrV5Y2M/s744wzyqS98sormTVrFkuXLuX1118v3d+1a1dmzJjBueeeS8+ePbn11lvLDEoZOnQoa9asYe3ateTn57Ny5Uruvfdexo8fXzra26tZs2Z06dIlKgFhdQwfPpyePXsCkJOTw3333RfjHEmyUZ/JJPLgg+A/y8WkSTB8eOzyIyJ1z2effcZpp53GmjVrAHjsscfCprXWMnz4cObOnUuHDh2oV68eRxxxBIsXL67Uvb755hsOPPBAvv/++9I+hPvssw9Dhw7l7bffBuCKK64IWNGlSZMmlJSUsHr1alq3bl2ppQhTU1Np2bIl4Pogllf7GY/S09OZN28ec+bMYf369ey2226xzpIkGdVMJpEdOwK3QwwyFJEktmvXLl577TWefPJJZs+eXWYktHcgiTeQ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yY2T5kcNwBERERGpZRMnTsR6On2efPLJlTpn2LBhpbWR8TQQR8GkiIiISC3zTlTetGlTjjzyyEqd0759ew444AAAXnvtNfLz86OWv6pQMJnA/vgjnddfh7ffhnffhcWLY50jERERmT17Nr/88gsAJ5xwAvWqMBG0txZz27ZtvP7661HJX1UpmExgn3/egmHD4IQT4Ljj4LnnYp0jERER8W+irmwTd6j08dLUrQE4CaykRCvgiIiIxJsnn3ySJ598MqJzO3XqVNrXMl6oZjKBaTlFERERiTYFkwlMyymKiIhItCmYTGCqmRQREZFoUzCZwEpKArcVTIqIiEhNUzCZwNTMLSIiItGmYDKBqZlbREREok3BZAJTMCkiIiLRpmAygSmYFBERkWhTMJnA1GdSREREok3BZAJTzaSIiIhEm4LJBKblFEVERCTaFEwmMDVzi4iISLQpmExgauYWERGRaFMwmcDUzC0iIiLRpmAygalmUkRERKJNwWQCU59JERERiTYFkwlMNZMiIiISbQomE1hJSeC2gkkRERGpaQomE5iauUVERCTaFEwmMDVzi4iISLQpvEhgmhpIRESkbrHWMn36dN555x2++OIL1qxZw6ZNm8jMzKR169b079+fwYMHc+KJJ5Kenh7r7AIKJhOaaiZFRETqji+//JLLL7+cuXPnljm2efNmNm/ezKJFi5g0aRJNmzbl5ptv5qqrriIlJbYNzQovEpj6TIqIiNQNEydO5MILL2Tnzp0A9O/fn2HDhtG3b1+aN29OXl4ey5YtY/r06bz99tts3LiRa6+9lvPPP5/GjRvHNO8KJhPY1Vf/QrdufSkuhqIi6Nw51jkSERGRYDNnzuS8886juLiYjIwMnnnmGc4444wy6Y444gjOPfdc1q5dy+jRo3nyySdjkNuyFEwmsF69tpKbG+tciIiISDiFhYWceeaZFBcXk5KSwtSpUznyyCPLPadVq1Y88cQTDBw4kPr169dSTsNTMCkiIiISI88++yyrV68G4JJLLqkwkPR38sknRytbVaKpgURERERi5LnnngPAGMNVV10V28xESMGkiIiISAxs3bqVH374AYDddtuN7t27xzZDEVIwKSIiIhID8+fPp7i4GIB+/frFODeRUzCZwL74ohlvvAFvvw3vvQee2QZERERqhjGBj3DGjg1MN3Jk+LT9+gWmnTMn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RESqIT09nbvuuoujjjoKgGnTpsVVMKlmbhEREZE4d+CBB5Y+X758eQxzUpaCSREREZE4V79+/dLnxcEDI2JMwaSIiIhInJs3b17p87Zt28YwJ2UpmBQRERGJc3fffXfp8wEDBsQwJ2UpmBQREZGIhJtsu6JHv379wl6zX79+EV0zJycn7DVHjhwZ0TVjrbCwkNmzZzN06FDefPNNAHJychg1alRsMxZEwWSCuuUWGDr0EFq2hLZt4cknY50jERERKc/tt98eEMxmZGRw8MEHM3XqVMAFklOmTKFFixYxzmkgTQ2UoLZtg7y8+uTlue04XYFJREREKtChQwdOPPFErrvuOjp27Bjr7JShYDJBaTlFERGRuuWSSy7h0ksvLd1u2LAhzZo1o0mTJjHMVcUUYiQoBZMiIhJt1toav+acOXMiOi/P2xQXwtixYxk7dmykWao1oVbAqQsUYiSo//4XBg/+ggMOOJSiImjUKNY5EhERkUSkYDJBZWRATk4RrVrFOiciIiKSyDSaW0REREQipmBSRERERCKmYFJEREREIqZgUkREREQipgE4CWrcOPjkky58/LGbFmj4cOjePda5EhERkUSjYDJBvfwyfPhhp9Ltgw5SMCkiIhJvcnNzozJfZ21SM3eC0qTlIiIiUhsUTCYoBZMiIiJSGxRMJigFkyIiIlIbFEwmKAWTIiIiUhsUTCaoXbsCtxVMioiISDQomExQwTWT9evHJh8iIiKS2BRMJig1c4uIiEhtUDCZoBRMioiISG1QMJmgFEyKiIhIbVAwmaAUTIqIiEhtUDCZoBRMioiISG1QMJmggqcG0mhuERERiQYFkwlKNZMiIiJSGxRMJigFkyIiIlIbFEwmKAWTIiIiUhsUTCYoBZMiIiJSGxRMJiBrobg4cF9qamzyIiIiIolNwWQCCg4k69UDY2KTFxEREUlsCiYTUPC0QGriFhERkWhRMJmA1F9SREREaouCyQSkYFJERKRumDlzJsaYkI/09HTat2/Psccey+OPP862bdtind2QFEwmIAWTIiIidd/27dtZuXIl06dP57LLLqNXr178+OOPsc5WGQomE1BwMKmlFEVEROLfJZdcwvz580sfM2bM4Mknn2S33XYDYPny5Rx77LHk5eXFOKeBFEwmINVMioiI1D0tW7akV69epY/c3FxGjRrF/PnzOfLIIwFY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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='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='P')\n",
    "\n",
    "plt.plot(list(range(300,400)),Results4[300:], 'c', linewidth=4.0, label='R')\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": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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hg8fzh577MFLL71EaWkpzZo1q4XcSqKrkWDSGJMNnImrhezv3e35aYH/AW97HlKL1GdSRKTmffbZZ1x++eUYYxgzZgyDBg0KmW7nzp08++yzrF27lgsvvBBjDM2aNaNJkyaV3sNau2sanqysLI444ggOPvhgvv/+e6688kp27tzJV199RUpKCk888QTvv/8+V199Nbm5uSGvt//++7P33nsDhHV/kXBFHEwaNzRsMC6APBGo7z2ECyBnAy8Dk6y1q6qZT4mQmrlFpCb98ssv/POf/6RRo0bceeedtGwZahKPusd/xHNltm/fzjnnnMNff/0FwBFHHMGFF17IYYcdxtlnn01GRsautNdffz1PP/00APfffz8AzZo1Y/z48QFN0QUFBVx55ZXMnj2bffbZhx49evDGG2+wYMGCXWnefPPNgHxkZmZSWFjIuHHjGDduXIV5zsnJ4cUXXwyrfCJVVeXQwhizFy6AHA608u72/FyCbx3uB6y1byIxpWZuEamO0tJSvvjiCwoLC+nXrx+DBg1i/fr1AKxfv5633nqL+fPn07x5c1q1alXJ1cryD+KstcybN4927drRtGnTGi2HV0lJCfPmzSM7O5upU6cyd+5c3nvvPVJSUhgzZgxDhw4lJSUlZGA5d+5c7rvvPgYMGLArkPR66aWXeOmll7j77rv5+OOP6d69O3/88ceuQNLfxo0bGTp0KCtWrKB9+/YA3H777YwfPx6AefPmhVWWwsLCsNI1a9aMiRMn0qtXr7DSi1SZtbbSB9AMuBo3Z2SJ51HqefwFPAUc4Elb6jl+RjjXTtZH3759bbRNnz7dbtli7V9/Wbt6tbUrV1pbVBT128aN6dOnxzoLMZPMZbc2uctfk2X/6aef7GGHHWZxrU1lHvXq1bOFhYX2tNNOsxkZGfaZZ56xI0aMsD179rTXXnutzc3NtZ9++qkdP368nTt3bsh7PP744/boo4+2X375pT366KN3XfeLL74IK48bN260o0aNsvXr17ctWrSwPXv2tEcddZR9++23rbXWLlu2zM6ZM8dOnjzZXnTRRbZ58+bllsf7eOWVV8rcp7S01B5++OGVngvYU0891f7www+VpisoKNh1/fz8fHvHHXfY+vXrh3WPcB+333673bRpUwS//bonmT/31ka//MCPtrw4sbwD7jxOxq2nXRQUQBYCE3HzS6YFnaNgMo6CyWSWzOVP5rJbm9zlj6TsxcXFAdtbt261w4YNCytYmTFjhu3atWtYaW+99daA+5SWltq99tqr3PTt2rWz3bp1s2PGjCk37z169KjR4Auwn3zySZn7vPnmm2Gd+/zzz9udO3fagw46qNK0L7/8csA91q1bZ2+55ZYaK0dmZqbdsGFDld8PdVUyf+6tjW0wWdlyipOAE4B0z/YXwCVAK2vtmdbaD6xbXlFEROqAVatWMW3aNJYsWcLy5cs544wz6NatG6WlpbvSPP/887z//vthXe/VV1/l999/Dyvtfffdx1133bXrXt9//z2//PJLuen//PNPfvvtN26++WZWr15d5nhhYeGuJveaFKof6BtvvFHpeR988AGXXHIJaWlpPPXUU5X2wfzuu+8CtnNycujUqRMjRoxgwIABNGrUiHr16nH33Xczfvx46td3QxPGjx/Pjh07yu0KcMABB9ClSxdefPFFjdaW2lFelGkDaxm3ABdUlDbEOaqZVM1kTCVz+ZO57NYmZ/kLCgrsnDlz7F133WX/9a9/2alTp5ZJ8/3339sGDRqErMX64YcfdqUrLS21t99+e6U1X5E0yWZlZdmlS5daa6299957wz5vyJAhtrS0NKA8Y8aMqXbt3R577FFm33PPPVfmXiUlJfbyyy8vk3bYsGF29OjR9o8//ijzev/73/+2mZmZAembNWtmZ86cadetW1fp77SkpMQWFhYG/F78a5HHjx9vjTFl8hTOtRNRMn7u/cVzM7e3WdvbT3I5cD/Qq5JzFEwqmIy5ZC5/Mpfd2uQs/yOPPBIQUIwcOXLXsdzcXPv2229XGFSNHj26zDXHjRtnu3btavv16xeQdvfdd7fffPON3b59u50/f37YgVu9evXsu+++G3CPd999N6ym6rZt29olS5YEnPvss8+G1QcSsF26dAnYTklJsXfccYctLS21b731lk1JSbGA7dSpk12xYkXI17i0tNQ+//zz9pxzzrE33XST/frrryv9vezcudMWFxfbX3/91b744ot22bJlYfw2w7dhwwbbuXPngLJ99NFHNXqPuiIZP/f+4jmY3At4CFgVIrCcDVyHa/JWMKlgMu4kc/mTuezWJmf5J0+eXCaAOuOMM2xBQYHNysqqNNgaPHhwyOuWlJTY0tJS++yzz9pLL73Ufvnll2XSjB492gLWGGNvv/12W1JSYmfOnGnnzJljS0tL7Z9//mlfeuklO2/evHLzn5uba9evX28bN24ckK+XX37ZrlixwpaUlIQ8b+fOnbuOFxcX288//9x+99139rrrrrNnnXVWQPDYrl07e+KJJ9onn3zSrly5MuA6P/30k33jjTcCBsXUFXvuuWfAazZq1KhYZykmkvFz7y+WwWSFUwNZa38BbjTG3EzZOSX3BR4GHjTGfA6Mxw3WkTjy0EOwZYubEig1Fa6+GjRXrUji6datW5l9/fr1IzMzkwEDBvDxxx+HPM8Yw3XXXcdDDz0U8nhKiutaf/nll5d77zvvvJNzzjkHay277747AP379991vG3btlxwwQUV5t+7gsszzzzDxRdfTFFREY8//jgjRoyo8Ly0tLRd0+t4y3PAAQdwwAEHAHD11Vdz5JFHUlRURElJCePHjycnJ6fMdXr37k3v3r0rvFe8uuGGG7j44ot3badqDjipZWHNM2mtLQWmAlONMTkErnaTChzleYQ36ZXUmn//G5Yv922PGKFgUiQRdenSBWOMt4UIgFGjRjFr1iyOPfbYMsHk2WefzfXXX0/jxo1DBqJV1b1798oTheHss89m6NChpKam0rBhw2pfr3///sybN4+ff/6Zo48+OmQgWdedddZZPProo/zyyy80adKEUaNGxTpLkmSqPGm5tXYr8DzwvDGmGy6oPBfoCDTEVbMDPGWMOQK3hOLnnoBUapkmLRdJDvXr16ddu3asXLly176GDRsyaNAg/v3vf5dJf8IJJ9CvX7/azGLYajrg69atW40EzPEqMzOTn376iXnz5rFmzZpdtcMitaWyqYEqZK39zVp7u7W2M3AEbvnEAtyKOLsBlwIfA+uMMS8YY46tboalarScokjyCBUwDRgwgD322CPgWP369Rk8eHBtZk2iLD09nb59+5KVlRXrrEgSqrHQwlo7A5hhjBkFnAaMAAbhAstmwIXABTV5T6ncLbdAXp6roSwpgezsWOdIRKKlW7duTJ8+PWBf//79Mcbw3HPPMXz4cAoLC3nkkUeitlyhiCSfGg/srLWFuME4440x7XFB5XmA6t1j4JprYp0DEaktu+22W5l9Bx98MABHHnkkq1atori4mIyMjNrOmogksGo1c1fGWrvSWnuftXYPYAAwNpr3ExFJZnvssUeZfd5R0uBG+SqQFJGaVmtNztbab4Fv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Hva5kyZNiouBOwoxRERERGKkQYMGTJgwgdTUVEpLSxk2bBgTJ06s8Jz169czatQoTjvtNHbu3FlLOS2fRnOLiIiIxNCgQYN48cUXufTSSyksLOSss87ikUce4bTTTqN37940a9aM/Px8li9fzscff8zkyZPJz8+PdbZ3UTApIiIiEmMjRoyga9euXH311cyePZsffviBH374odz0zZs3584776xw5Z/aomBSREREJA4MGDCAWbNmMWXKFD744ANmzpzJmjVryM3NpWHDhrRp04Z+/foxdOhQTjrpJDIyMmKdZUDBZEIqKYF//ANWrerMp59CejrccUescyUiIiKVMcYwZMgQhgwZEuushE3BZALauRMeegigI6BgUkRERKJHo7kTkCYsFxERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGpm+bPn48xZtdj0qRJsc5SpRRMJiAFkyIiInXTyy+/HLA9fvz4GOUkfAomE5CCSRERkbqnpKSECRMmAJCVlQXAlClTWL9+fSyzVSkFkwlIwaSIiEjdM23aNNasWQPAE088gTGGnTt38tprr8U4ZxVTMJmAFEyKiIjUPd4m7rZt23LBBRdw2GGHBeyPVwomE9DQoZCbC++99zXr1sG4cbHOkYiIiFRky5YtTJ48GYBzzjmHlJQUzjvvPABmz57NvHnzYpm9CimYTED16kHjxtCoUTEtWkCTJrHOkYiIiFRk4sSJFBUVAXDuuecCcNppp1G/fn0gvmsnFUyKiIiIxJg3WNxnn33YZ599AGjUqBHDhg0DYMKECZQE92OLEwomRURERGJoyZIlfPPNNwC7mra9vNtr165l2rRptZ63cKTFOgMiIiJSt5gZM2KdhVplBw6M6vW9c0mmpKRwzjnnBBw79thjad68ORs2bODll1/muOOOi2peIqGaSREREZEYsdbyyiuvAHDEEUfQpk2bgOP16tXjzDPPBGDy5Mls2bKl1vNYGQWTCei77+Dmm+H55ztz++3w3//GOkciIiISyowZM1i+fDlQtonby7u/qKiIiRMn1lrewqVgMgHNng0PPgivvdaRe++FDz+MdY5EREQkFO/Am8zMTE455ZSQaQ488EC6d+8ekD6eqM9kAtKk5SIiEk3R7kMYiby8PLKzs2OdjSopKChg0qRJABQWFoaV/2+++YYlS5bsCi7jgWomE5CCSRERkfg3adIk8vPzq3yed8BOvFDNZALq3x/uvx9+++0POnTowv77xzpHIiIiEszbZN28eXOeeuqpStM/+OCDzJ49m1dffZW7774bY0y0sxgWBZMJqF8/95gxYwUDB3aJdXZEREQkyIoVK5g+fToAJ598MmeddVal56xbt47Zs2ezbNkyvvjiCwbGSXcDNXOLiIiI1LJXXnkFay3glk0Mx6mnnrqrNjKeBuIomBQRERGpZd5+j02bNuWII44I65x27dpx4IEHAvD2229TUFAQtfxVhYJJERERkVr07bffsnjxYgBOPPFE0tLC73XorcXMz8/nnXfeiUr+qkrBpIiIiEgt8m+iDreJO1T6eGnq1gCcBLRxI2zeDGvX1mflSmjcGOrY1FsiIiIJ67nnnuO5556L6NyOHTvu6msZL1QzmYAeeQS6dYOzzz6IDh3gySdjnSMRERFJVAomE5AmLRcREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQREZHaomAyASmYFBERkdqiYDIBKZgUERGR2qJgMgEpmBQRkUjF21J9UnOi9btVMJmAFEyKiEgkUlJSKC0tjXU2JEpKS0tJSan50E/BZAJSMCkiIpFo0KABBQUFsc6GRElBQQENGjSo8esqmExACiZFRCQS2dnZ5OXlxTobEiV5eXlkZ2fX+HUVTCYgBZMiIhKJnJwcCgsLyc3NjXVWpIbl5uZSWFhITk5OjV87rcavKDGnYFJERCKRmppKx44dWb58OYWFhWRnZ9OwYUNSUlIwxsQ6e1IF1lpKS0spKCggLy+PwsJCOnbsSGoUggIFkwlIwaSIiEQqPT2dLl26sHXrVjZv3syaNWvqxKCcoqIi6tevH+tsxEyo8qekpNCgQQOys7Np1apVVAJJUDCZkBRMiohIdaSmptKkSROaNGkS66yEbcaMGfTu3TvW2YiZWJZffSYTkIJJERERqS0KJhOQgkkRERGpLQomE5CCSREREaktCiaryBiTbYwZbYyZZ4zJN8ZsMcb8YIy5wRiTHuv8gYJJERERqT0agFMFxpiOwAygk2dXIZAB9PM8hhtjjrTWxnSCLgWTIiIiUltUMxkmY0wa8D4ukFwDHG2tbQhkAmcBeUBv4NVY5dFLwaSIiIjUFgWT4Tsf2Nvz/FRr7acA1tpSa+1EYKTn2BBjzJGxyKCXgkkRERGpLWrmDt/5np/TrbXfhjj+BnAf0BkYAXxWWxkLds01sGYN/PbbH3To0IU2bWKVExEREUl0CibDYIzJBAZ4NqeESmOttcaYqcAVwODaylso53vC3hkzVjBwYJdYZkVEREQSnJq5w9MT32s1v4J03mOtjDFNo5slERERkdhTMBke/4biVRWk8z+mxmURERFJeAomw5Pt97ywgnT+x7LLTSUiIiKSINRnshYZYy4DLvNs5htjFkX5ls2BDVG+RzxL5vInc9khucufzGUHlT+Zy5/MZYfol79jeQcUTIYnz+95ZgXp/I/lBR+01o4FxtZUpipjjPnRWtuvtu4Xb5K5/Mlcdkju8idz2UHlT+byJ3PZIbblVzN3eFb7PW9bQTr/Y6vLTSUiIiKSIBRMhmchUOp53quCdN5ja621m6KbJREREZHYUzAZBmttITDTs3lsqDTGGAMc49mcVhv5CkOtNanHqWQufzKXHZK7/MlcdlD5k7n8yVx2iGH5jbU2VveuU4wxFwMvABY42Fr7XdDxM4CJns2jrLUxWwFHREREpLaoZjJ8LwPzAANM8q6/bYxJMcacDjzvSTdFgaSIiIgkC9VMVoExphMwHejk2VWIC8jre7ZnA0daa3NrPXMiIiIiMaCaySqw1i4D9gHuxi2daIGdwCzg78BBsQ4kjTHZxpjRxph5xph8Y8wWY8wPxpgbjDHpscxbdRhjLjDG2DAeR1Vwja7GmDHGmKXGmCJjzHpjzMfGmFNrsywh8pVpjDnOGHObMeYdY8xyv/KMDvMaLY0xjxhjFhljthljNhljvjLGXOLpz1vZ+TF7bapTfs97PZz3RbdKrtPHGPOqMeZPY8x2Y8waY8y7xpgjarSwZe/bzBhzoefeC4wxBZ77/2mMec8Yc3IY16jWZ766753qqE75a+I7wXOdWL73+xhj7jTG/NcY86sxZqMxZqfn50xjzK2mkqV56+pnvzplr+uf+wryc4t//itJG1+fe2utHgnywE0ouhQX5FqgACjy2/4JaBLrfEZYtgs8ZSgB1lbwOLSc84d4Xg/va7HFcy3v9ot4aupjULaBfvkIfowO4/y+uIlqvefk4f7J8W5PBdIrOD+mr011yg+M9qTbUcn7olMF17gk6PXajJu9IezfQTXKvjOovNuA/KB9HwGZ5Zxfrc98dd87sSw/1fxOiJP3/tMhyr81aN96XD/9hPrsV6fs1PHPfTn56eF5DXaVv4K0cfe5r7UXSo/oPnAT0M/1vBFW4wYBgat9PtPvQ/phrPMaYfku8OR/WQTndsb3B+prYHfP/izgLr8P0E0xKttAYBPwKfAgcBawJpwvNKCRX9qFQD/P/nRglOfL1gLPxOtrU83ye/+ozIjw3gcDxZ5rvAu08+xvBjznV/4zolR2C3wHXAF08dvfCd+APwu8EuLcan3mq/veiYPyR/ydEEfv/RF4WrWAxn77szzH/vLkYR3QqCZ/f7EufzXLPpo6/LkPkZ8U3IwxFvjGe/9y0sbl5z7qL5IetfMALvb7AIT6T+5sv+NHxjq/EZQv4j8cwCuec9f4f2n5HR+D77/yWq+5BVJD7FtGeMHUPZ50hUDnEMf/4Tle7P1jEW+vTTXLX90/Kl95zp8L1AtxfKrn+NJQ+ayBsg+q5Lj/H7b2Qceq9Zmv7nsnDsof8XeC5/yYv/fDyONgv/IPr8nfX7yXv5Ky1+nPfYj7XeO536t+ZbPlpI3Lz736TCaO8z0/p1trvw1x/A3cBwPcf31JwRjTEPD2/XnWWrs5RLL7PT9zgJNqIVsBrLUl1Tjd+7t8w1q7NMTxp3C1D6nAcP8D8fLaVLP8ETPGdAEO8Ww+bK3dGSKZt/ydgMNqOg/W2umVJPmP3/PgZdKq+5mP+L1TU6pZ/ojFy3s/DP/ze94u6Fid/+xXoqKyRywePvdB+ekM3AdsBK4L45S4/NwrmEwAxphMYIBnc0qoNNb9yzHVszm4NvIVJw4BGniel/faLMNV90Mdem2MMT2ADp7N8sqWj/svHMqWLWFfmzAd7fd8ajlpvsb1J4LYlL/I73mq90l1P/M18N6pLSHLXwPqynv/UL/nv3ufJMlnP2TZa0C8fe6fBxoC11tr11eUMJ4/9womE0NPfL/L+RWk8x5rVdkIwTi2mzFmlmf02jZjzB+e0XgDy0nvv/xlOK/NXjWRyVpS1bLtWc3z4/m12csYM98YU+h5bywyxjxvjOldwTne8v9lrf0rVAJPremv3nvUZIbDNNDv+Ty/59X9zFf3vVNbBvo9n1dOmqp+J0Acv/eNMRnGmE7GmKtwTdEAvwHv+yVLyM9+mGX3V6c/98aYS4EjgU+ttePDOCVuP/cKJhNDG7/nqypI53+sTbmp4lsm0AfXSTgF14l8ODDdGPOiMSYtKL23nLnW2m0VXNf72tSl16Wqv/ccY0xWiPMT4bVpjvui3QZkALvjRmvOMsbcW8453vJU9Nr5H6/V8htjGuP6LwF8Za1d5He4up/56r53oq6S8vur6ncCxOF73zMtj8XVxi7FNTc2wQ3MONJau90veUJ99qtYdn919nNvjGkLPITL+8gwT4vbz72CycSQ7fe8sIJ0/seyy00Vn1bjRhjuC9S31jbF/REZgBsFDHAh8FjQed5yVvS6+B+vS69LdX/vifDaLAFuwk2rUd9a2wzXZHQMbv5XA9xqjLkhxLlxW35jTAquZqY17g/sVUFJaup3H+n5URVG+SHy7wSIz9/9WtzI5QK/fdOBa621K4LSJtpnvyplh8T43I/Bjaweba39I8xz4vZzr2BS6gRr7TRr7Whr7Vzvf6nW2hJr7Te4L5DJnqRXGmO6xyyjUqustROstQ9Zaxd7O9Jba3dYa6fh+oX94Ek62hjTKGYZrbongOM9z0dZa+fGMjMxUGn5E+07wVrbyVrbylqbBbTETZuzH/C9MebumGYuyqpa9rr+uTfGnAsMBX4GHo1tbmqGgsnEkOf3PLOCdP7H8spNVcdYa0txXz7g3tPD/A57y1nR6+J/vC69LtX9vSfya4O1tgj4P89mFq5vkr+4LL8x5mF8NXHXWWtfDJGspn73kZ4fNWGWv0KVfCdAnP7uvay1f1lrHwGOxU3Tcrsx5ni/JAn72Q+j7JWdH9efe2NMS+Bx3OTwl1pri6twetx+7hVMJobVfs/bVpDO/9jqclPVQdba33Az+gN08TvkLWcTY0wDyud9berS61LV3/tWz0i94PMT8bXx8p86o0vQMW95Knrt/I9HvfzGmAcBb9Pc3621j5eTtLqf+eq+d6KiCuWvVAXfCVBH3vvW2u9xI4sBLvM7lPCf/QrKHo54/tz/Czc5+ljgV2NMlv8DN3k4AH77vfvi9nOvYDIxLMQtAwWBo7WCeY+ttdZuim6W4ob/iLVwXptfopiXmlbVsi2o5vl16bUJh7f8LYwxu4VKYIxJBfbwbEa1/MaYh4AbPZs3eWpnylPdz3x13zs1rorlr6669N73DobwX2c6WT77ocpeXbH+3Hf2/LwCV+sX/PiHX1rvvgc923H7uVcwmQCstYW4UW/gmgbK8Czcfoxnc1pt5Ks2GWO64kb2gW/CVnD/2XpHK5b32nTEjQiEuvXaLAa8ndPLK1tDfPO1BZctkV8br4P8ngdP0PuJ3/OQ5ccN5vB2QI9a+T1Nu95m2ZustQ9VlL4GPvPVfe/UqKqWP8xrlvedAHXrve+tWfNvbkyWz36osoejTnzuqyquP/flLY2jR9164FtiqRQ4MMTxM6ijyykCprLjwDuespUAPYKOe5cNW03QGq+e4894jm8lRsumhcjTMqq2nGIB0CnE8ZsIb0m1uHptwil/GO+LDNwqGha3okPjEGm8y6r9TOhl1T7yHF9GlJZVAx72+2zeUIXzqvWZr+57J5blr+53gidNTN/7uEnYKyvHkZ7frwUeqMnfXyzLX52yJ8rnvoL8j/Z+Hso5Hpef+1p7gfSI7oPAxd//9L6JcLXPp+PWV7XAR7HOawRl6wR8j5uLq4v3y8RTtoPwraNqCbE4Pa5ZId9z/Eugu2d/Q+AOvy+sm2JYxia4WhTvY4UnTw8G7c8KOq8Rbm1di2uO6evZn45rRtle3usST69NJOUHDsdNAXMe0M5vfz3cH6Lv/d4XIfMP9Pd8aVpgEtDWs78pvj+mFjgjSuV+0O8e11Xx3Gp95qv73oll+anmd0I8vPc9Zfg5uAyeY+2BW/zytxFoVZO/v1iWvzplJwE+95W8NqO99y/neFx+7mv1RdIjug/PB3Sp3wehANeU4d3+iTipeYugXNbvUQSs9/z03/8ikFbONYZ4Xg9v2s1+Xybecyv8jzfKZVwWVJbyHuNCnNsXN9DAm2YrbgJn7/bHQEYF9475axNJ+XGro/gfK/S8L/zLXgLcV8m9LwF2+p2Ti+8PqaWS2uFqlLlDUD7XVvL4ezmfjYg/89V978Sq/NTAd0Ks3/shyrDdU4b8oP1/AL2j8fuLVfmrU3bq+Oc+jNdmtDcPlbx+cfW5r/UXSo/oPnD9PO7CLT2W73mT/IgbIZke6/xFWKYGuKlCJuD+k/rL8yWQh+uQ/B9gQBjX6YobQbcU3x+facCpcVDGZUFfkGEHk57zW+LmK1vs+VLJxTXlXAKkxPtrE0n5cSMibwDeBhbhajB24v4z/xm3isbeYd6/j+f99SfuD9ta4F3giCiWuVOYZa7wj1t1P/PVfe/EovzU0HdCLN/7uJqg04CncfMirvK89wqB5cB/cU2aDaL5+4tF+atT9rr+uQ8jT6O97/lK0sXV597bNCAiIiIiUmUazS0iIiIiEVMwKSIiIiIRUzApIiIiIhFTMCkiIiIiEVMwKSIiIiIRUzApIiIiIhFTMCkiIiIiEVMwKSIiIiIRUzApIiLlMsbMMMZYY8yMWOdFROKTgkkRkSDGmIGeAKoqj/dinW8RkVhQMCkiIiIiEUuLdQZEROLcs8AzYaTbGu2MiIjEIwWTIiIV+8taOz/WmRARiVdq5hYRERGRiCmYFBGJAmPMMs/AnHGe7b7GmFeNMSuMMUXGmNXGmNeMMX3CvN5Bxphxxpg/jDGFxpitxpj5xphHjTEdwrxGU2PM/xljvjTGrDPG7PRc5ydjzJPGmP5hXKONMeZhY8xiY8w2Y0yuMeZzY8zpYZx7ojHmHb/XoMDzOn1rjHnIGDMonHKISHwx1tpY50FEJK4YYwYC0z2bd1lrR0dwjWVAR+Bl4AtgDFAvRNJi4Gpr7XPlXMcAjwLXVnC7IuBSa+2rFeTnNOA/QE5F+bbWmqDzZgCH48rwf8B7wG7lnP6ItfbvIe6dCkwAzqzo3sA6a22rStKISJxRn0kRkejaDzgH2ATcD/wPF1QeBfwdaAg8Y4xZbq2dEuL8+/AFkn8C/wJ+ADKAwcANQANgvDEm11r7YfAFjDFnAq8DBtgBvAh8CKz2nLsncBxwfAXlaA1M9jy/FfgS2AbsD9zhOX6DMWaKtfazoHMvxxdIfgO8APyOG7TUFOjleT32q+D+IhKnVDMpIhIkqGYy3NHcS621BX7XWIarmQQXBB5krV0VdJ/ewFe4gHI50M1aW+x3fC9gLq5L0hKgv7V2Q9A19gdmAJnAGqCztXa73/EWuMAtC9gIDLbW/lROudtba1cG7ZuBq5kEWAkMCJFmd08+M4D3rLUnBx3/EjgU+N5zfjEhGGOaWWs3hjomIvFLfSZFRCp2BTAvjMf+FVzj+uBAEsBaOxt40LPZERgWlORKfN/TI4MDSc81fsDVVoKrHTwtKMnfcIEkwKjyAknPtVaWd8zj6lBprLWLcc3fAIeFOM/bdD2zvEDScx0FkiJ1kIJJEZHoygXereD4i37Pjw465t3+w1o7nfI9X8E1vE3Xq4C3KrhGZbYA71dw/EfPz6bGmMZBx1Z7fg4zxjSvRh5EJA4pmBQRqdhd1loTxmNGOefPrqQ27k9c8zTAPt79xpgMoLtn838VZdBauxZY5tnc2+8aaX7bM621pRVdpxKLKzl/k9/z7KBj4zw/uwG/G2NeMsYMN8Z0RETqPAWTIiLR9VcYadZ5fjbz29ekitdY6/nZ1G9fM3zf82uonsJKjvsHmqn+B6y144C7gZ240eQXAK8CyzxTAz1tjOlVzfyJSIwomBQRia6aGOVY50dKWmvvBLoCNwPTgHzPoY7AKGCuMWZ0bHInItWhYFJEJLpaViGN/wCU3CpewzvIxb+5eRO+GsPWYVwjqqy1K621D1prjwEaAwcCD+CmCDLAncaYE2KYRRGJgIJJEZHo6u3puxiSMaYtvkBvnne/Z3qfJZ7NAyq6gTGmJdApxDV2+m0fYoyJm+98a22JtfZ7a+0twLF+h86IVZ5EJDJx88UiIpKgmgAnVnD8Ir/nnwQd8253M8aEmnLH65IKruEdgd2GOA3UrLXf4uuTqdHeInWMgkkRkeh71BhTppnZGLMvcJNncyVlp955Bl8z9XPGmCZBx/Gs7f0Pz+Ya4O2gJE/j65/4tGei9JCMMe0rKkSkjDHnGWNCLSXpPX4IbtJ1gKXRyIOIRI+WUxQRqViLMEca7/BM3h1sDm65wp+MMd7lFNNwywfeiJtQ3AJXepqld7HW/mKMeQAXLPYEZnu2fyRwOcVMzzUu9V/9xnONdcaYkbi1sZsB3xpjgpdT3AO3nOKJQHoYZa2q8cDDxpj3gJnAb7ilGHfDTXI+ypOuGBgbhfuLSBRpOUURkSBByymGa7m1tpPfNZbhRiq/jFsy8TlC/wNfAlxjrf13OXkxwGPANRXcuwgXSL5aXgJjzDm4QK1hRYWw1pqg82bgllP8wlo7sILrXwC85NnsbK1d5ncsnD8023BlmBBGWhGJI6qZFBGJMmvtf4wx84BrcWtUt8CNtP4CeMhaO6uCcy1wrTHmDdzSjofhRm4X49bzngY8Ya1dXkkeXjPGfIqrBTwWN4F4I1wT+G/Al8Br1ShmRXoBQ4BDcNMDtcSN5i7ADTL6FHjWWrsiSvcXkShSzaSISBT410xaay+IbW5ERKJHA3BEREREJGIKJkVEREQkYgomRURERCRiCiZFREREJGIKJkVEREQkYhrNLSIiIiIRU82kiIiIiERMwaSIiIiIREzBpIiIiIhETMGkiIiIiERMwaSIiIiIREzBpIiIiIhE7P8BnMUSHkaUq+wAAAAASUVORK5CYII=\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='R')\n",
    "\n",
    "plt.plot(list(range(100,400)),Results21[100:], ':r', linewidth=4.0, label='P')\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"
   ]
  },
  {
   "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
}
