{
 "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": [
    "# import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\"\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 = 10000\n",
    "epochstep = epochs/100\n",
    "nofclasses=12\n",
    "batchsize=64 \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_imgs\", dtype='float32')  # adapt this if using `channels_first` image data format\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": "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ReadData(sourceL,targetL,distL):\n",
    "\n",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/imageCLEF_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/imageCLEF_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",
    "\n",
    "    USPSMat  = []\n",
    "    USPSTar  = []\n",
    "    curPath  = r'/nas/home/imageCLEF_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",
    "    dataZ_test = dataZ_train\n",
    "    labelZ_train = keras.utils.to_categorical(labelZ_train, nofclasses)\n",
    "    labelZ_test = labelZ_train\n",
    "            \n",
    "\n",
    "    task1 = 0\n",
    "    task2 = 1\n",
    "    task3 = 2\n",
    "     \n",
    "\n",
    "    DATAX_train = {}\n",
    "    DATAY_train = {}\n",
    "    DATAX_test = {}\n",
    "    DATAY_test = {}\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",
    " \n",
    "                \n",
    "            \n",
    "            \n",
    "            \n",
    "    return DATAX_train, DATAY_train, DATAX_test, DATAY_test\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Losses(encoderX,classifier,labelX,imgX):\n",
    "\n",
    "    discriminationLoss=K.mean(K.binary_crossentropy(labelX,classifier(encoderX(imgX)))) \n",
    "\n",
    "\n",
    "\n",
    "    params=encoderX.weights  + classifier.weights  \n",
    "\n",
    "\n",
    "    regLoss = (K.mean(K.square(encoderX.weights[0]))+K.mean(K.square(classifier.weights[0])))\n",
    "\n",
    "    lambdareg = 1e1\n",
    "\n",
    "    myLoss = discriminationLoss + lambdareg*regLoss\n",
    "\n",
    "    opt = SGD(lr=1e-3, momentum = .9) # very important \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": 13,
   "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": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "numtrial = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "def genresults(sourceL,targetL,distL):\n",
    "\n",
    "\n",
    "    DATAX_train, DATAY_train, DATAX_test, DATAY_test = ReadData(sourceL,targetL,distL)\n",
    "    nofclasses=12\n",
    "    ntask = 0\n",
    "    epochs = 10000\n",
    "    epochstep = epochs/100\n",
    "    nofclasses=12\n",
    "    batchsize=64 \n",
    "    nofprojections = 100\n",
    "\n",
    "    \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",
    "     \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 = 10000\n",
    "        epochstep = epochs/100\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",
    "\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",
    "\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 = 200\n",
    "        epochs2 = 25 * 1000\n",
    "        epochstep = epochs2/100\n",
    "        \n",
    "        for ntask in range(1,3):\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",
    "                    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",
    "            \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 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "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": [
    "Results = np.zeros([6,numtrial])\n",
    "\n",
    "sourceL = 'i_i.csv'\n",
    "targetL = 'i_p.csv'\n",
    "distL =  'i_c.csv'\n",
    "Results1, Results2, Results3 = genresults(sourceL,targetL,distL)\n",
    " \n",
    "\n",
    "sourceL = 'c_c.csv'\n",
    "targetL = 'c_i.csv'\n",
    "distL =  'c_p.csv'\n",
    "Results11, Results21, Results31 = genresults(sourceL,targetL,distL)\n",
    " \n",
    "\n",
    "sourceL = 'p_p.csv'\n",
    "targetL = 'p_i.csv'\n",
    "distL =  'p_c.csv'\n",
    "Results12, Results22, Results32 = genresults(sourceL,targetL,distL)\n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[6.166666666666667,\n",
       " 17.666666666666668,\n",
       " 28.0,\n",
       " 34.0,\n",
       " 42.666666666666664,\n",
       " 48.333333333333336,\n",
       " 53.0,\n",
       " 56.833333333333336,\n",
       " 57.5,\n",
       " 58.0,\n",
       " 59.0,\n",
       " 59.833333333333336,\n",
       " 61.0,\n",
       " 63.0,\n",
       " 64.33333333333333,\n",
       " 66.5,\n",
       " 68.66666666666667,\n",
       " 71.0,\n",
       " 72.83333333333333,\n",
       " 75.0,\n",
       " 77.66666666666667,\n",
       " 80.0,\n",
       " 82.16666666666667,\n",
       " 83.33333333333333,\n",
       " 85.83333333333333,\n",
       " 86.83333333333333,\n",
       " 87.66666666666667,\n",
       " 89.0,\n",
       " 90.16666666666667,\n",
       " 90.33333333333333,\n",
       " 90.33333333333333,\n",
       " 90.66666666666667,\n",
       " 90.83333333333333,\n",
       " 91.0,\n",
       " 91.0,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.5,\n",
       " 91.5,\n",
       " 91.33333333333333,\n",
       " 91.33333333333333,\n",
       " 91.33333333333333,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.5,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 92.0,\n",
       " 92.0,\n",
       " 92.0,\n",
       " 92.0,\n",
       " 92.0,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.16666666666667,\n",
       " 92.33333333333333,\n",
       " 92.33333333333333,\n",
       " 92.5,\n",
       " 92.5,\n",
       " 92.5,\n",
       " 92.5,\n",
       " 92.66666666666667,\n",
       " 92.66666666666667,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 92.83333333333333,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 92.83333333333333,\n",
       " 93.0,\n",
       " 93.0,\n",
       " 89.66666666666667,\n",
       " 91.83333333333333,\n",
       " 92.33333333333333,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.16666666666667,\n",
       " 91.83333333333333,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.33333333333333,\n",
       " 91.16666666666667,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.16666666666667,\n",
       " 91.83333333333333,\n",
       " 91.66666666666667,\n",
       " 90.66666666666667,\n",
       " 91.83333333333333,\n",
       " 91.83333333333333,\n",
       " 91.16666666666667,\n",
       " 91.5,\n",
       " 91.0,\n",
       " 91.16666666666667,\n",
       " 91.33333333333333,\n",
       " 90.83333333333333,\n",
       " 91.33333333333333,\n",
       " 91.0,\n",
       " 90.5,\n",
       " 90.83333333333333,\n",
       " 91.0,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.0,\n",
       " 91.33333333333333,\n",
       " 91.16666666666667,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 92.0,\n",
       " 91.0,\n",
       " 91.16666666666667,\n",
       " 91.33333333333333,\n",
       " 92.16666666666667,\n",
       " 91.66666666666667,\n",
       " 91.83333333333333,\n",
       " 92.0,\n",
       " 91.16666666666667,\n",
       " 91.33333333333333,\n",
       " 91.66666666666667,\n",
       " 92.0,\n",
       " 92.0,\n",
       " 91.5,\n",
       " 92.16666666666667,\n",
       " 91.66666666666667,\n",
       " 91.83333333333333,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.83333333333333,\n",
       " 92.16666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.0,\n",
       " 91.16666666666667,\n",
       " 91.66666666666667,\n",
       " 92.0,\n",
       " 91.83333333333333,\n",
       " 91.33333333333333,\n",
       " 91.83333333333333,\n",
       " 92.0,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 92.0,\n",
       " 91.5,\n",
       " 91.83333333333333,\n",
       " 92.0,\n",
       " 91.33333333333333,\n",
       " 91.66666666666667,\n",
       " 91.83333333333333,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 91.83333333333333,\n",
       " 91.83333333333333,\n",
       " 91.66666666666667,\n",
       " 91.83333333333333,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.83333333333333,\n",
       " 91.66666666666667,\n",
       " 91.5,\n",
       " 91.66666666666667,\n",
       " 91.66666666666667,\n",
       " 94.66666666666667,\n",
       " 94.33333333333333,\n",
       " 94.33333333333333,\n",
       " 94.0,\n",
       " 94.83333333333333,\n",
       " 95.16666666666667,\n",
       " 94.83333333333333,\n",
       " 94.5,\n",
       " 93.5,\n",
       " 93.16666666666667,\n",
       " 93.66666666666667,\n",
       " 93.83333333333333,\n",
       " 93.5,\n",
       " 94.5,\n",
       " 94.66666666666667,\n",
       " 94.83333333333333,\n",
       " 95.0,\n",
       " 95.33333333333333,\n",
       " 94.83333333333333,\n",
       " 94.83333333333333,\n",
       " 95.33333333333333,\n",
       " 95.83333333333333,\n",
       " 96.33333333333333,\n",
       " 95.83333333333333,\n",
       " 96.16666666666667,\n",
       " 95.66666666666667,\n",
       " 96.16666666666667,\n",
       " 95.83333333333333,\n",
       " 96.33333333333333,\n",
       " 96.66666666666667,\n",
       " 96.66666666666667,\n",
       " 96.33333333333333,\n",
       " 96.66666666666667,\n",
       " 96.83333333333333,\n",
       " 96.83333333333333,\n",
       " 96.5,\n",
       " 96.33333333333333,\n",
       " 96.83333333333333,\n",
       " 97.16666666666667,\n",
       " 97.0,\n",
       " 97.0,\n",
       " 96.83333333333333,\n",
       " 96.83333333333333,\n",
       " 97.16666666666667,\n",
       " 97.33333333333333,\n",
       " 97.0,\n",
       " 97.16666666666667,\n",
       " 97.5,\n",
       " 97.16666666666667,\n",
       " 97.5,\n",
       " 97.33333333333333,\n",
       " 97.33333333333333,\n",
       " 97.5,\n",
       " 97.33333333333333,\n",
       " 97.33333333333333,\n",
       " 97.5,\n",
       " 97.5,\n",
       " 97.33333333333333,\n",
       " 97.66666666666667,\n",
       " 97.16666666666667,\n",
       " 97.33333333333333,\n",
       " 97.5,\n",
       " 97.83333333333333,\n",
       " 97.66666666666667,\n",
       " 97.83333333333333,\n",
       " 97.83333333333333,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.33333333333333,\n",
       " 97.5,\n",
       " 97.83333333333333,\n",
       " 97.5,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.66666666666667,\n",
       " 97.5,\n",
       " 97.5,\n",
       " 97.5,\n",
       " 97.5,\n",
       " 97.33333333333333,\n",
       " 97.83333333333333,\n",
       " 97.5,\n",
       " 97.83333333333333,\n",
       " 97.33333333333333,\n",
       " 97.66666666666667,\n",
       " 97.5,\n",
       " 98.16666666666667,\n",
       " 98.5,\n",
       " 97.83333333333333,\n",
       " 97.66666666666667,\n",
       " 98.16666666666667,\n",
       " 97.66666666666667,\n",
       " 98.0,\n",
       " 97.83333333333333,\n",
       " 98.0,\n",
       " 98.16666666666667]"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Results3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApMAAAJxCAYAAAAemjl0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAB5J0lEQVR4nO3dd3hUVf7H8c9JQgkQOtJEqrr2AvYGoq69rGVV/IkVe1t7W1HXiu66a2dV7BXL2juxYAPsDUGKIEWkSCAJgeT7++PMMCUzk8lkJpPMvF/Pc5+ZO7edOZlMPjn3nnOdmQkAAABIRUG2CwAAAIDmizAJAACAlBEmAQAAkDLCJAAAAFJGmAQAAEDKCJMAAABIGWESAAAAKWs2YdI518Y5t49z7grn3HPOudnOOQtMo5PcR3fn3K3OuanOuQrn3BLn3AfOuZOccy6J7Qc65+51zs10zlU65xY5595wzh3a4DcIAADQDLnmMmi5c26opAlxFl9tZqPr2H6wpDckdQm8tEJSa0lFgfk3JB1oZlVxtt9X0jOS2gReWi6pnUKBfJykE625VCgAAEAaNJuWyYClkt6RNEbSUZIWJLORc66DpJflg+SPkrYxsxJJbSWdKWm1pD9Lui3O9v0lPS0fJCdK2tDMOkjqIOmawGrHS7owlTcFAADQXDWnlslCM6uOem2WpL6qo2XSOXetpCskVUjaxMxmRi2/VNL1kqolbWxmP0Utf0TSMfLhdSMzWxa1/F5Jo+RbK/uZ2dK63k/Xrl2tX79+da3WICtXrlTbtm0zeox8Q52mH3WaftRp+lGn6UV9pl+m63TKlCm/m1m3WMuKYr3YFEUHyXo6NvD4ZHSQDLhd0mXyp61HSLoquMA511ZS8JrIu6ODZMAN8mGyvaSD5U95J9SvXz9Nnjw5yeKnprS0VEOHDs3oMfINdZp+1Gn6UafpR52mF/WZfpmuU+fc7HjLmttp7npzzm0oab3A7Gux1jGzFZI+CMzuFbV4Z0nFdWw/S9IPcbYHAADIWTkfJiVtGvb82wTrBZdt3MDtN0myXAAAAM1ePoTJXmHPf02wXnBZe+dcuxjbLzWziiS275VgHQAAgJySD2GyJOx5eYL1wpeVxHieaNvw5SUJ1wIAAMghzaYDTi5wzo2S76ij7t27q7S0NKPHW7FiRcaPkW+o0/SjTtOPOk0/6jS9qM/0y2ad5kOYLAt73kZ++J5Y2oQ9L4vxPHx5ou3L4q1gZmMljZWkIUOGWKZ7stFbLv2o0/SjTtOPOk0/6jS9qM/0y2ad5kOYnBf2vLfih8negcflgd7d0dt3cs4VJ7husnfU+kDeW7VKqqmJvaxlS6mwsHHLAwBIv3y4ZjK8B/amcdcKLfu+gdt/l2S5gGajpkb6+efQNGNG/HUXLpQeekgaPFhq3Vpq0yb21KGDdMstjfceAACZkQ8tkz9J+kV+rMm95e+vHSEwMPkugdk3oxZ/KH/nnOLA9pNibN9X0kZxtgeatCVLpO+/94GxpETaaqva66xaJQ0aFJpv3VqqiNNG/7e/SY8/XvdxV66ULrxQGjWqjzjbBQDNV863TJq/X+TDgdkjnXP9Yqx2hvzdb6olPRa1/UpJzwZmTwvc5zvaxYHHMkkvNLDIQKN5/XWpXz9pl12k3XaTTj214fssqOe3ytixAzVihDRrVsOPDQBofM2qZdI510lS+FVWwT9bbZxzXcNer4y67vEWSSdJ6iHpFefcsWY2xTnXUtKJkq4NrDc2+r7cAX+XdIiknpJecs6daGbTAi2a50sK/gn+RzL35QbSwUz69FPpk0+k6hRuNlpRIV13nVRZmf6yhSsq8lO4Vat8+YMef1x68UXplVekXXfNbHkAAOnVrMKkpC8k9Y3x+oWBKeghSccFZ8zsD+fc/pLekL/DzWTnXJmk1pJaBFZ7U9J5sQ5qZjOdc0fInyLfRdJPzrk/5Fszg+F2nKQxqb0toH4+/VS69FJpwoTGOZ5z0oABoflWreKvu8460vrrS9tvL118sbRJjHtCvfeetPfekUF2xQpp//2lV1/1+3/9dWmzzaQDD6x/aycANHdVVVV68MEHVVhYqJEjR6oo+r/yJqTplizNAi2Rm8ifkt5fUh9JK+U72Dwk6QEzi9PvVDKzV51zmwe231O+lXKpfMC918yejbctkC733Sfde680eXL6973DDj68xdK6te94k4xbb/VTIrvtJr39tjRqlL9eM6iszJ9yD9e3r7TtttIGG0hnn+3DKgDkgiVLlqhz5861Xq+urtY+++yjd999V5L0/PPP65hjjtFnn32moUOHqkePHtpmm23knGvsIsfUrMKkmfVr4PYLJf0tMKWy/c8KDDoOxDJtmvTvf0vffBN5GleS+vf3vZxjOe006buwcQDuukvaNMbYAZMmZSZI3nijb0VsTDvtJH39tXT88bP0yCP94q43e7afJB9AP/qIlkoA8b3xxhtauHChnn/+eS1evFitW7fWnnvuqdNPP11t27Zt9PKsWbNGd9xxhyZOnKgjjzxShx56qCTpt99+04ABA7Tvvvvq0ksv1VZhvR9vvPHGtUFSkl555RW98sorkqR//etfkqSXXnpJ+++/fyO+k/iaVZgEmoKff/bh68MPpdWrQ6+vWiXNnRt/uyVL4i/76ivp449D88vjjYYaw/Dh0hZbJL9+uKIiadgwf8o5GwoLpRNOmKU+ffrp+uvrXv/LL6Vvv5U23zzjRQPQxJiZbr/9dj3xxBPaeeeddf3116tFixYR6/zwww/aO8YX2ltvvaWLL75Y/fv3j2jNa9++vc455xyNHDkyYv3y8nLdfvvtGj9+vJYurd0VYpNNNtH555+vXeu4yLumpkbHHXecHnvM9+0dP368Tj31VH3//fd6//33JUnPPPOMnnnmGZ1wwgm6//77NXXqVF1xxRV11sfll1+ufffdVwVN4b9rM2PKwjR48GDLtAkTJmT8GLlq9WqzJUv8NH++2b/+ZbbRRmYtWlSbb3Os/7TJJvGPt8MOketOnBh7vVGjQutsu63ZO+9k5O03quDn9PnnfR3Hq7+LLjKbNy9y20ceMRs0yGzXXc2++y5yWXW12fLljfIWmhx+99OPOk1eTU2NVVdXr51/4YUXbMMNN7Qtt9zSPvjgAzOrXZ+vvvqq9ejRw0aMGGFTpkyxjz/+2A477DDr1KmTFRcX27rrrmuSIqZzzz231rEPPfTQWuslM915550R+3n//fdt6NChdW7nnLPi4uK1U0lJid1yyy1r9/PKK6/YoEGDkirD1VdfbVdddZV16NAh6XI/9thja4+V6c+opMkWJ9NkPVTl60SYbHqmTjX74AOz0083a9cutcCY6TD56admjz9u9tlnZjU1mamHxhb+OV292uz9980mTfLvb8YMH+Sfeab2+504MVRfzpk9+GDk8vnz/bIttjC77z6zb74x++OPTL+bpoHf/fSjTs0WLVpkNQm+eGbNmmXHH3+8derUydZff32bMGGCPfPMM1ZQUBARgCZOnFirPletWmX9+/evVwAsKCiwyZMnr93HpEmTUgqSkqy4uNjmhf23+vLLL1vr1q3rvZ+ioiKbPn362v1MnDgxqe26dOliCxYssG233TbpY+2222722WefrT0WYTIPJ8Jk46qp8UHliy/ir9OnT3pC4wYbmP3nP2alpWbvvReaJk2Kf+wvvohcd9mydNdA05XK53TVKh/OJbPCQh+wowXDZPhUWGh2772hdWbONHvzTbO33vLrN4affqrdwppuzfV3f+5cs6+/bpr/KDXXOk2H5cuX28EHH7w29Nx///211nniiSesVatWSYWgzp072zsxTqs8/PDD9Q5vu+2229rtFy5caGeffba1bt3aCgsL7YgjjrDHH3/czj//fGvXrl3cfbRt2zaiPE899ZQVFRWlFEpPP/30tfv55ptvrE2bNkltd80115iZ2cqVK+2mm26yLl26mCQ78sgj7aijjjJJtsEGG9jkyZNt7ty5Nn369FrBnjCZhxNhsvEsXx4KEx06xF+vPmFy0019KJk61WzatNA0Z07T/EPYlKXyOZ00ybdE7r+//3kMHmz2+eeR68QKk5JZUZFvpfzPfyJfLygwGznSB8xo339v9sorZpWVqbxDb80as5NOCh1v//19cDIz+/hjs08+8f/wpEO2f/cXLTJ78kmzcePMysqS2+aee8xatvR1c+CBZrNm+UsfYv085s41e+MNs8WL01Peqiqz117zv8/xZLtOM6mmpsYmT55sDz74oI0bN84++uijtcvKy8tt2LBhEcEn/NSqmdmLL75ohYWF9QpdBx54YMSp8CVLlthnn31mPXv2THofhxxyiM2dO7fW+6moqLDlUde4VFVV2bRp0yKm//znP9a5c2f7+OOPI9Z9+eWXrX///rbuuuvahRdeaJMnT47Y7oUXXrDhw4fXes8FBQU2M+wDu2bNGrvgggusTZs2tvHGG8d8D61bt7ZDDz3UKqO+XNasWWOLwz7gK1assKqqqoQ/R8JkHk6EycYzenTqYbJjRz+tt57ZOeeYPfHEx1ZR0Vglzw+pfk4rKkI/s+OOq7187tz4/wy0bu3DY6xlLVqYnX222cKFfj//+U9o3Y03rn8LZlWVWXm5D6rRxyooMCsuDs1vsIG/NvS228x++CG0j6+/Nhszxuzuu/21oNHWrPGXAjz/vNnKlcnX6c8/+xD3zTf1f0+xQp6Z2bffmnXvHnpPsdabONHsuutC03nnxf9ZFRSYHXyw2bXXmj3xhNkDD/ifn+QvR/n73/3lC/H+zr70UuIzEnPmmG24Yeh4Bx7o62P+fLPHHjMLVmUufJ9++umnNm7cuIjXFixYYLvttlutkHPuuedaTU2NHXHEERGvb7755hEh0Mxs2rRp1rdv33qFySFDhkQEqOrqanviiSds++23t44dO1qnTp1sl112sWeffdYWLVpkN910k22zzTY2dOhQGzZsmD3//PNpqZOyOP/tJDqdH7Rq1SpbuXJlxLRq1aq460+dOtV22WUX22KLLex///ufmVmtumwIwmQeToTJxrFokVlJSegPRaIwufvuPizsvLPZ7bfHboWiTtMv1Tr95z/9z3Sddcx+/z32Ot9/74Nmsi3O4VPbtmZdutR+/ZFHIo8xb54POkuW1D5+VVWo9bS+k3NmxxxjduutvjU12Ko6bVrkMVasMNtll9B2PXuajR9f+6LbVavM9tzTt46OHm12552hUFZYaHbTTWbXX++vGT77bB/cfv3V7JZbzG680YfzoBtu8CH45psjQ9yMGWY77mi29dah8sQKkzfckFqdJJrOOy/2Z+Cww/z7e/LJ2suWLTP705/q3vcZZ5i9++6E2AdoJsaOHWvOOdtss80iXl+zZk3cVrMBAwbUem2HHXaIGYDmzJljG264oRUUFFi3bt0itunWrZs98cQTNnbsWNtll13sb3/7m7366quN9dbzBmEyDyfCZHr9/ru/Fi3aSy+F/mBKPljG+qOfrHyq08aSap1efbXZscfW7sUdS02N2QEHNCysFBT4VrFo333nlw8cGGrNNPMtp6kGyUTTUUeFjrFqldkee0QuHzYsdvC5886GHbdlS7OhQ30rYfjv1BZbmP34oz9GMGMcf3xoeWOFScmH4WiHHRZa/umntT8XiVpFw6cjj5wd/wPWxD3++OPmnDNJtcKkmdlzzz0XM0xGT71797bf4/3nZv6axfHjx1tNTY09++yzNmLECLv11ltjtv7xXZp+hMk8nAiT6VFT43v7tm/vWxRjnZmYO9fsmmvMLr+8dqtOfeVDnTa2xqrTX34x69atdkg44AB/mnjcOH85Q6JA8dZbtfcbDJOS2Z//7AOemQ+6sfaxzjr+komGhKYvv/THiBWG3nuvdp2uWGHWo0fDjhlv6tLF7LffIusjeFlAq1aRy4IyFSYlsyuuCB2nujoyTL74Yu2y1NT474Zk9h0dRrMp3ulZM3994KWXXmr777+/3XDDDdaiRYu1gXCzzTar1bJYU1Nj2267rXXv3j1ukCwqKrKvgxf5pgHfpelHmMzDiTCZHldcEfll/8ormT1ePtRpY2vMOp0+3besBT8vPXv6kBlUWWn273/XDp0tW5q98ELt/VVU+GsEg+tttpnZggV+2YIF/pRyMFgFT1vPmeOX33lnaFnv3mYvv+xPNZ99tr92MlaYGTzYn94P7sPMh6Grrgqts2xZ7Tp9/vm6g1Kq00MPRdbJX/7iXz/xxNjXd5r5kQ4uvTRyGj3abPJkH3zvvdfs6ad9553nnvNh769/DbWIFhX5erj66sjLWHbd1Q+bFfT225HXQm+6qf/HIZann/bXnW66afz3esklsbdtbEuXLrXevXvb2WefXaujybx58+IGQknWqlWriA42QcH9fPbZZ9a+ffta21122WVpfQ98l6YfYTIPJ8JkwyxZ4q/tiv6y32KL+H/A0iGX6zRbslGnX3/tO1fE60yzfLkPFnfc4YNN8DRutMrKyB7aktnmm0cGlp9/Nnv00dg9hb/6yl+bGD3+5Zo1Zg8/bNavn60Ns3fckfg93X+/v0bYLHad/vij2dixvsPK+uuHQtmGG4ZC2rrrml14odkRR8TvoBQ+/fWvkWcDamp8L+vAuNRpN3++D5fhZxh+/91fD/nxx7HPTIwd61tIJR8sf/458THWrPEt0M8+6zs9hb/fY49N7/tJ1amnnro25K277rr24osvWnV1td19990Jg6QkezB6QNYYZs6caSNGjFh7anz77be38vLytL4HvkvTjzCZhxNhMnVvvWXWqVPtP2xt2vgv/zpGT2iQXK3TbGrudbpyZejayE6dfAtjuqxa5Xsih7eeJqOuOl292gfZGTP8/K+/mk2ZEtnpbO5c35N55UrfAvvuuz7IBaePP47fytfUzJ3rh45K0NE2ppdfjvyO2XPPzJSvPj788MNaAfHKK6+0q6++us4gedBBByXVSzlo9uzZ9t5779UatiYdmvvvfVOUzTDJvbnRLKxeLU2aJL30kr8vdrR27aR33pG23bbxy4b81qaN9OKL0qxZUufOUocO6dt3y5bSllumb39BRUWR9zfv1ctP4Xr39lPQsGHpL0djiX4vyerZM3J+3rz0lCdZU6dOVXV1tTbeeGNJUlVVlU455ZSIdTbYYANddtllWr58uf79739ryZIlMffVrl073X777RH3pa7Leuutp/XWWy/1N4C80QTuDg7EV10tPfqotOGG0k47xQ6SPXtKr71GkET2OCf175/eIInsiw7Y8+fHX7esrEzjx4/X999/3+DjmpkuuOAC/elPf9Imm2yiiy66SJI0ZswYfffddxHr3nPPPWrdurXWWWcd3XLLLRHLevbsqYEDB2rgwIF64YUX1KdPnwaXDYiFlkk0WW+/LZ13nvTtt/HXueQS6corfesQAKRTt25SQYFUU+PnlyyRKiul1q0j15s+fbp23313zZkzR4WFhbr77rt18sknp3zc6upqzQtrBh0zZozWW289XXvttRHrHX/88RoW1mR83HHHafny5Xr00Ue17bbb6tZbb1Xr6MICGUCYRJP0xhvSfvv5lsl4rr9euvTSxisTgPxSWCj16BF5envBAqlfv9D8nDlztMcee2jOnDmSfBA85ZRT1LZtWx199NEpHbeoqEjXX3+9Fi9erDfffFOSdNZZZ0Ws07VrV40ZMybiNeeczjnnHJ1zzjkpHRdIFWESTU5NjXT++bWDZGGhP5Xdq5d08MHSMcdkpXgA8kjPnpFhct68UJg0Mx199NGaPXt2xDZmpmOPPVZt27bVQQcdlNJxFy1apLfeeivu8n/961/q0qVLSvsG0o1rJtHkvPyyFHVZkEaMkKZOlT76SBo/niAJoHEkum7y888/14cffhhzu+rqah1xxBF655134u572bJlOvzww2OGxm222UZnn312zO323HNPjRgxou7CA42EMIkmY/Vq/1//CSdEvn7kkb4TzsCB2SkXgPyVqEf3uHHjEm5bVVWlkSNHqqqqKubySy+9VOPHj9ell17qx+qLcu2112qzzTaLeK179+6655576tUrG8g0TnMjq2pqfEvjDTdIX34Ze51LLmnUIgHAWr5l8jZJ3SX11vff95bZAFVVVemRRx6JWHf8+PH6448/dOKJJ0qSWrZsqS233FK///67ekU1ca5evVpPPfWUJGnKlCl69tlndcghh6iwsHDtOiUlJZo4caLefPNNLV26VG3atNHw4cPVvXv3zL1hIAWESWTNqlXS/vv7Xtvx7LuvtMUWjVcmAAjXqVOZpPPWzo8d20J33bVK48eP1/Lly9e+3rlzZ+2///5q1aqVli5dqj59+mifffZRSUlJxP7MTAsXLtQHH3ygpUuXrn398MMP1+rVq2sdv6SkRIceemj63xiQRoRJZM0LLyQOkuuvL/33v41WHACopUWLXyPmW7bspYqKCt15550Rr48YMUKtWrWSJJ1//vkx9/X+++/rkksu0ccff1xr2XHHHaeiIv4ko3nik4usiXXdemGhNGCAdOqp0umn1x7PDQAaV2SYLCjoraqqKpWXl699raioqM5xJe+7776E6xxyyCENKyaQRYRJZM2hh0pt20qffSZNmCCNGSNdcEG2SwUAIWvWzIua762OHTvq7bff1pVXXqnvvvtOp59+eq2OMuF+/vnnWuNEhmvTpo323HPPtJUZaGyESWTN0KF+knxHnOBdJgCgqSgri2yZ3G8/f5Pvrl276u67765zezPTqaeeqsrKyrjr7L333iouLm5YQYEsYmggNAkFBRKXCwFoaubPjwyTO+7Yu17bV1RU6OKLL9agQYPWvrb99turoCD05/fMM89sWCGBLOPPNwAAcfz6a2SY7N27fmGyqqpKV111laZPny5J2n333fX222/r888/18svv6xdd9014v7aQHNEmAQAII6Ghskff/xR33//vSRp3XXX1dixY+Wc0+DBgzV48OC0lRPIJsIkAABxNDRMbr/99po+fbqmTJmirbfeWl27dk1n8fLe8uX+Eqk2bbJdksa3dKnUoYO/TCzbmkARkG/KyqTHH5emT5di3EEMAJqE6upqLViwIOK1Xr16qaZG+t//pNLS5PbTpUsX7bXXXgTJNLvvPqlbNx+oHnggc8dZtUr66it/y99oixdL338vVVdn7vixnHuu1KWL1KOH9PXXjXvsWAiTaHQffiiNGOEHJe/SxY8nCQBNzcKFC1UdlhI6d+6s8eOLtfnm0sEHSxdeyD/E2bJggXTmmVJVlbRmjR+bOHA1QVrNnSv16ydtuaWfwm5apHfekXr3ljbZxA91t2ZNcvusqfH/iAQuo5Xkg+o770iPPio9/bS0cGH87X/4Qfr3v/1nb9Ei6dhjs/85JEyi0YUPVr50KUMCAWiaok9xd+nSS8ceK333nZ+fPFl66y3/fMEC6eGHfQtWUzB5si/Pb79luySZcdttvsUwaPVq6fjjQ39Pli+XHnpIeu+92Nub+fB2330+kIVbvVp6/nnpqaekyy7zP1vJh9Ubbghtf+65oTL873/SHXfUXe6lS6WddpKGDfMNKs8/78t8+OHSHntI//d/0l//Kg0cGPqcRfvss8j5r76SXn+97mNnEmESje6DDyLnd945O+UAgESiw+SAAb114IGR61x/vT/VudNO0siRvvXqjTcyW67586Ubb/RhMdY/4zffLG2zjS/PdtslbuVqTN9+K117bcPr57ffpFtvrf36Z59JW28tTZwo7bKLdNxxfizj226rve455/jwdvLJ0vbbR7Y4nn229Je/SEceKT3ySOR2Y8b4dadM8e8n3KWXSr/8ErvMa9b4Y3XuLH3ySej1887zgfZ//4tcf+VK6aqrYu9r6tTar11/fex1GwthEo3ugAOkvfaS2rXz87vskt3yAEAs8+ZF3v2md+/euvzy0PzJJ/uWpZtukmbMCL1+++2ZK9OqVdLw4T64jBzpW8eCamqkf/5Tuvji0GuzZvnA0lAffSSddpp0772pnVL9+WffcPD3v0t77y198EFq14/++qs0aFD8U8pffeWPE34d4cUX1w5gxxwTej5jRqjOfvhBuueexGXo3NmH9WiVldLo0bG3qanxoTHa7NnSKafE3ubFF6Xff6/9+o8/1n7tp5+kJUtaxi1zphEm0eguvND/Z7p0qfTFF9J662W7RABQ23777aenn35at912m/76179qn3320bbbSv/4h/T++9LYsVKnTtKkSZHbvfJK5sr01ls+8ATdfrsvy6uv+la588+PXL9TJ/89m8xp0M8/96dbR43yra1BU6dKe+7pQ9app8Zu6Ytl1Sof0g47TNpnH+mPP0LLHn20b3I7idKrl7TRRvXbpqrKtz6Gh+A+ffy1jkH//a8PosXF0oYbplQ0nX22v5ZR8nV2ySVSEjdJimv1aumJJ2q/Hv7zl/w/FbNmSZ07V6V+sIYyM6YsTIMHD7ZMmzBhQsaPkW+o0/SjTtOPOk2/RHVaVWXmo0poWrAgM+U48cTax6prqqoyW7Ei9v5WrTJ77TWzI4+M3GbgQLOjjjIbMqT2/rp0idzf77+b3XmnWUVF5L5HjUpcrq+/NnvkEX+MY44xW748uTp4++3QPjbZxGzyZLMNN0x8rEsvNVuzJrSPysrQss6dzZ54wqymxi+bObP+dfzBB37b774z22GH0OuDBvn9rlqV3H46d46cb9PGrH9/s59+8vuvqjIrKopcZ9kyvyzTv/eSJlucTMM4kwAANECLFtLgwf46uqCvvvKX8wT98YdvIQvq0iX58QHn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M888U1988UWtZcuWLdOyZcv0448/6tFHH1Xnzp11+eWX69xzz8362KCEyRzGoOUAADQPjzzyiE466SRVVVVJkoYMGaJDDz1UW2+9tbp27aqysjLNmjVLr7/+ul588UUtWbJE559/vk444QR17Ngxq2UnTOYos9phslWrLBUGAADEVVpaquOPP17V1dVq06aN7rvvPh111FG11tttt900cuRILVy4UKNHj9Y999yThdLWRpjMUWvWSDU1oZHui4r8BAAAmo6KigodffTRqq6uVkFBgV566SXtvvvuCbfp3r277r77bg0fPlwtWrRopJLGR7zIUZWVkfNcLwkAQNPzwAMPaP78+ZKk0047rc4gGe6www7LVLHqhaGBclRFReQ810sCAND0jBs3TpK/b/a5556b3cKkiDCZo6JbJrleEgCApmX58uX68ssvJUkbbLCBBg0alN0CpYgwmaNWr46cb9kyO+UAAACxffPNN6qurpYkDR48OMulSR1hMke1aiUNGbJEQ4dKO+0kNePPKACgiXIutal9+5Kk1x01KvnjxzNqVGrlzLTFixevfd69e/fMHzBD6ICTo9ZdVxoz5msNHTo020UBAAAxlJWVrX3etm3bLJakYWiZBAAAyIKSkpK1z1euXJnFkjQMYRIAACALunTpsvb5woULs1iShuE0NwAASIlZatuVlZVFtMpl+vhjx/qpqdlss81UWFio6upqTZkyJdvFSRktkwAAAFnQvn17bbnllpKkn376SdOmTctugVJEmAQAAMiS448/XpJkZvr3v/+d5dKkhjCZo959VzryyO21/vrSxhtLZ56Z7RIBAIBoJ5xwgnr27ClJuvvuu/Xuu+8mve2zzz7bJDruECZz1PLl0sKFrTV9uvTDD9LcudkuEQAAiFZcXKzHHntMhYWFqqmp0QEHHKCnnnoq4TaLFi3SGWecocMOO0yro+9SkgV0wMlR0Z+tFi2yUw4AAJDYsGHD9MADD+jkk09WeXm5jjzySN1666067LDDtNVWW6lLly5asWKFZs+erTfeeEP/+9//tGLFimwXey3CZI4iTAIA0Hwce+yxGjhwoM466yx98cUXmjRpkiZNmhR3/a5du+qqq65S+/btG7GUseVNmHTOdZF0oKThkraW1Ff+/S+SNFnSQ2b2fB37KJF0vqRDJfWXVC3pJ0lPSrrdzKoy9gbq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mjlzpu6///4slzQSYTIHESYBAMgdxcXFuu6669bOv/baa1ksTW2EyRxEmAQAILdsv/32a5/Pnj07iyWpjTCZgwiTAADklhZhf8yrq6uzWJLaCJM5iDAJAEBu+frrr9c+79WrVxZLUhthMgcRJgEAyC3XX3/92ufDhg3LYklqI0zmIMIkAKAxxBtsu65p1113jbvPwYMHp7zfeEaNGpXW/TWWiooKffzxxzrwwAP1wgsvSJLat2+vU045JbsFi1KU7QIg/U48UdprL2nGjF/Uo8d66tEj2yUCAAB1ufrqq3X11VfHXd6+fXs9++yz6tatWyOWqm6EyRx02mn+sbR0hoYOXS+7hQEAAA3Sp08fHXzwwbrgggu03npN7+86YRIAAKAJOO2003T66aevnW/durW6dOmiTp06ZbFUdSNMAgCAlJhZStuVlZXFXTZlypRUixPX2LFjNXbs2LTvN92Cd8BpbuiAAwAAgJQRJgEAAJAywiQAAABSRpgEAABAygiTAAAASBlhEgAAACkjTAIAACBljDMJAACQJUOHDk15vM6mgpZJAAAApIwwCQAAgJQRJgEAAJAywiQAAABSRpgEAABAygiTAAAASBlhEgAAACkjTAIAACBlhEkAAACkjDAJAACAlBEmAQDAWs391n6IL1M/W8IkAACQJBUUFKimpibbxUCG1NTUqKAg/dGPMAkAACRJxcXFWrlyZbaLgQxZuXKliouL075fwiQAAJAklZSUqKysLNvFQIaUlZWppKQk7fslTAIAAElS+/btVV5erqVLl2a7KEizpUuXqry8XO3bt0/7vovSvkcAANAsFRYWqm/fvpo9e7bKy8tVUlKitm3bqqCgQM65bBcP9WBmqqmp0cqVK1VWVqby8nL17dtXhYWFaT8WYRIAAKzVsmVLDRgwQMuXL9eyZcs0f/78tHfKqaysVOvWrdO6z3wXq04LCgpUXFyskpIS9ejRIyNBUiJMAgCAKIWFherUqZM6deqUkf2XlpZqq622ysi+81U265RrJgEAAJAywiQAAABSRpgEAABAygiT9eScK3HOjXbOfeOcW+Gc+8M5N8k5d75zrmW2ywcAANCY6IBTD865vpJKJfULvFQuqZWkIYFphHNuuJkxQBcAAMgLtEwmyTlXJOkl+SA5X9KeZtZWUhtJR0oqk7SVpEezVUYAAIDGRphM3khJ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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='C')\n",
    "\n",
    "plt.plot(list(range(100,300)),Results2[100:], 'r', linewidth=4.0, label='I')\n",
    "\n",
    "plt.plot(list(range(200,300)),Results3[200:], '--k', linewidth=4.0, label='P')\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": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "92.83333333333333"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Results3[97]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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K8eMCYfAAQBZRZhErc8/rz8/dmxeqgHUV1UlHX1080Hymmuko47KTZ0AALUIk6h1+eXSeedJb70Veil32infNQIUDm2//nrD5QMHhvA4Zoy06abSxhvnvm4AAMIk6uvTJ9yLe+LEfNcEUBhe4Lzz6i/r1096+OFwHgZDDwBA3hEmAbRfDz0kfftt3XxZmfT229KQIfmrEwDk2erVq1VeXq6hQ4dqgw02yHd1VJTvCgBAo264of78oYcSJAEUtKqqKm2//fbaeeedNWbMGN122235rhJhEkA7NXeu9Pjj9ZcddlheqgIA7cXjjz+ul156SZK01lpr6Uc1w5/lEWESQPvjLv3xj+EONzU22UQaNy5/dQKAduC+++6rfT5+/Hg9nvxPdx5wziQkSXfdFcaBHjAgTNtuK40ale9aoWCdf770j3/UX3b44dz2EEBBq6qq0oMPPlg7/+ijj+oXv/hFHmsUECYhKVwce8stdfPXXUeYRJ689pp01ln1lw0axCFuAAXv5Zdf1vz582vne/XqpYntYPgVwiQkSQmfTUmhdxLIi6uuqj/fq5f06KNh3CoAKADffvutqhNP85G0atUqTZkypd6yH/7wh+rSpUsuq5YSYRKSCJNoJ5YtC+dcJLrhBu7tCSAWFi5cqM8//1xmptGjR6t79+4py40bN06fJ9+WLoW99torwzVMDxfgQBJhEu3E3XdLS5fWzQ8eLO2xR/7qAwAZcu2112rQoEEaO3asNt10U/Xt21ennHKKvvnmm7T2V1paql133TXDtUwPPZOQRJhEO5E8ruQhh0id+JoC0LHdfPPNOvroo+stW7lypf7yl79o0aJFuu6661q1v5KSEl111VUqKyvLZDXTxrc0tGyZtHx53XyXLuFGI0BOLVggPfdc/WWHH56fugBAhpSXl+uII45Iua5Tp04644wzGizv27evKisrGyzv0aOH9thjD/3ud7/T4MGDM17XdBEmkbJXkhFYkHOvvVZ/fpNNpPXXz09dACADli9frqOOOkpVVVUp10+ZMkUjR45ssHz69OnZrlpGcc4kOMSN9uHVV+vPb7VVfuoBAG00Y8YMnXjiierevbs++eST2uVmprvuukvLly/XJZdcojPPPDOPtcwceiZBmET7kBwmt9wyP/UAgDR99tln2nnnnfXxxx+nXH/cccdpv/32kyT96le/ymXVsoqeSRAmkX/uDQ9zEyYBdDArV65sNEgOGTJEf/rTn3Jco9wgTIIwifybPVuaN69uvqRE2nDD/NUHADKoW7duuummm9SzZ898VyUrOMwNwiTyL/kQ9+abMyQQgHbpm2++0apVqzRkyJAmy2288ca1F9hsvvnmGjRoUI5qmHt8W4MwifzjfEkAHcCiRYu0yy67aNGiRXr66ac1fPjweuuHDx+u119/Xb169dKoUaNkBTI0Coe5oa+/rj9PmETOPf10/XnCJIB2pLq6WnfccYfGjh2rN954Q59++qm23XZbvf/++/XKdevWTZtvvrlGjx5dMEFSomcSomcS+VX66afSG2/ULTCTtt02fxUCAEmzZ8/Wbbfdpnnz5umJJ57Qe++9V2/9l19+qXPPPVd33HFHnmrYfhAmQZhEXg16/PH6CyZNktZeOz+VAVCwVqxYoVtuuUXvvvuuhg8frj/+8Y/69ttvGy2/zTbb6Nprr81hDdsvwiSUfI95wiRyZvVqDXzqqfrLuIUigBx7+OGHddxxx2n27NnNli0uLtbRRx+tCy+8UKWlpTmoXftHmCxwq1ZJFRV180VFUu/eeasOCs2TT6rLwoV18716SXvtlbfqACg8n3zyifbee2+tWbOm2bIHHHCAzjvvPI0ePToHNes4uACnwCX34PftGwIlkBNvvll/ft99wxiTAJBh1dXVKZePGjVKzzzzjMaMGZNy/aBBg/SXv/xF77zzjm6//XaCZArEhgKXHCb7989PPVCgFiyoP7/++vmpB4BYWrVqla644gqNGjVKvXv31tixY3Xbbbc1KPf9739f06dP1xFHHFFv+fHHH68vv/xSv/zlL7XRRhvlqtodDoe5C1zy+ZL9+uWnHihQyWGyb9/81ANA7Hz++efadddd612F/dZbb+lXv/qVfvrTn6pT0o0RunbtqmuvvVbXXXed5syZo+XLl2vUqFG5rnaHRM9kgUvumSRMIqcIkwCyYO7cudpxxx0bDOcjSV9//bVuuummlNvVjA05ZMgQgmQrECYLHIe5kVeESQAZ5O66+uqrtemmm+rjjz9utNw555yjlStX5rBm8cZh7gLHYW7kFWESQAb94he/0OWXX95g+c4776wJEyboySefVJ8+fXTyySera9eueahhPBEmC9zy5eGGI+5hnjCJnEoOk3365KceADq8K6+8MmWQnDx5su677z516dJFv//97/NQs/jjMHeB+8MfpDVrwuHuDz5gvGjkkDs9kwAyorKyUscdd1yD5b/97W917733qkuXLnmoVeGgZxIqKgp/w/k7jpyqrAyj5tfo2pUxJgGk5c4772yw7Mknn9ROO+2Uh9oUHnomAeRH4p1vpPDfTHQlJQAkW716tU4//XQNGzZMP/rRj7R69WpJYSzJ888/v17ZY489liCZQ4RJAPnBIW4ALVRdXa3DDjtMF1xwgT7//HP17t1bnTt3liRVVVXpoIMOqr1P9rhx43TBBRfks7oFh8PcAPKDMAmgCcuWLdO0adP0xRdf6LrrrtMzzzwjSercubPOPffc2nIlJSU677zzdNppp+nTTz/VmDFjGgxIjuyitQHkB2ESQAqVlZW67LLLdOGFF2rx4sUN1vft21cvvPCChg0bVjvIuCSVlpZqk002yWVVESFMFrCFC6VjjgnDAfXvL62zTpgHcoIwCSDJwoULteOOO2r69OmNlnF3bbvttvWCJPKLMFnA5s2T/vWvuvnRowmTyCHCJIDIokWLtHTpUv34xz9uMkhuvfXWuvnmmzVixIgc1g7NIUwWMO7LjbwiTAKIHHnkkbr33nsbLC8pKdEWW2yhtddeW/vvv7/22GMPeiTbIcJkAeNWisgrwiQASR9++KEeeOCBBsu33XZb3X///erHH6d2jzBZwDbfXLrtttBD+c030qhR+a4RCgphEigY8+fP19NPP63999+/wbqzzjpLVVVV9ZZtueWWeuSRR9SzZ89cVRFtQJgsYOusIx14YL5rgYJFmARiafny5eratas++OADHXzwwZo+fbqqq6tVVFSkTTfdVGPGjKktW11drSFDhqhLly5atWqVevXqpVNPPVW//OUvVcIdsToMBi0HkB+ESSBWPv74Yx144IHq1auXiouLteGGG2ratGmqrq6WFILjmWeeWW+boqIiXXrppfriiy/0zDPPaPbs2Tr99NMJkh0MPZMA8oMwCcTGzTffrKOOOqr2FoeNuffee/Xaa681WD5gwABtv/322aoesoyeSQD5QZgEYuHOO+/U4Ycf3myQHDlypP7yl78wsHgM0TMJIPdWrZKWLaubLy6WysryVx8ArVZdXa2DDz5Yt99+e5PlDj74YF1//fXc4jDG+MkWsFdflaqrpZ49wzRwoNS5c75rhYKwcGH9+T59JMaOA9qdmTNn6uabb1ZxcbFOOukklSX801dUVKSXXnqpXvni4mL96U9/0sqVK/Wf//xHkyZN0oknnkiQjDl+ugXsiCOkd9+tm3/7bYmjD8gJDnED7dry5ct1+umn64orrqg9fP3vf/9bzzzzjIqKUp8hZ2a68cYb9bOf/SyXVUU7wDmTBWzJkvrzDOeFnCFMAu3WypUrtffee+uyyy6rdx7kc889p6lTp6bcZuONN9YTTzxBkCxQ9EwWMMIk8mbECOmqq6SFC/X5m29q3a23zneNgIK2fPly/f3vf9dNN92kdxMPWSU59thjteeee2rIkCGSpFNOOUUjR47UrrvuquLi4lxVF+0MYbJAuTcMk1z/gJwZMkQ65hhJ0qfl5Vp34sT81gcoYO+8844mT56s2bNnt6j88ccfr3vvvVdmphNPPDHLtUNHwGHuArVsWQiUNbp3lzg/GgAKy4oVK7TPPvs0GiTXX399nX766fWWlZaWyrhgDgmIDwWKQ9wAEG/urv/+97+aPXu2ioqKNG7cOI0YMaJemcsuu0wfffRRyu3Hjx+ve++9V0OGDNH8+fN1ww03aKONNtJFF12Ui+qjAyFMFigOcQNAfFVXV+vII4/UjTfeWLusqKhIF110kY477jh169ZNknTCCSdo3rx5+tvf/qbq6mptv/32uuqqq7TWWmupd+/etdtOnTpVV1xxhTp16kSvJBogTBaoior68/RMAkDHs3LlSt1999368ssvtc8++2jhwoV69NFHdemll2rx4sX1ylZXV2uHHXaoDZKS1KNHD1166aU66KCDdPbZZ+v2229Xr169Ur5WZwYiRiMIkwWKw9wA0LE9+OCDmjJliubNmydJOu2005rd5owzztAjjzzSYPn48eNTLgdaggtwChRhEgA6tk8//bQ2SDanZ/Ql/+ijj+qFF17IZrVQgOiZLFCESQCIvwEDBqi8vFwbbLCBHnzwQb355pv1bokIZAJhskARJgGgffv6669144036qSTTqp3nmNzxo0bp913310DBw7U3nvvrcGDB0uS9tprL+21115Zqi0KWcGFSTPbSdLRkr4naaAklzRX0iuSprr7c01sWybpFEk/ljRCUpWkDyXdKelyd1+V3dpnDmESANqvf/3rXzriiCO0dOlS/fvf/9b999+v0tLSemV22WUX3XXXXZowYYIGDBigF198UaWlpdpiiy244ho5VTBh0sJv1pWSjklYvDx6HBFNB5rZpe7+qxTbD5NULml4tKhSUldJ46PpIDPb0d0XZuUNZFjy1dwc9QCA9uH+++/XAQccoKqqKknSU089pZ133lmPPPJIveF6xowZozFjxtTOb7/99rmuKiCpsC7AOUx1QfJuSeu5e3d37y5pA0kPROt+aWZ7J25oZp0kPaQQJOdK2sndSyV1l7S/pApJm0m6NcvvIWPomQSA9uff//63fvrTn9YGyRpz587VnDlz8lQroGmFFCYPiR4/lnSAu9cO+e/uH0jaT9Kn0aKfJG17qKRNouc/dvenou2q3f2fqgupk81sx2xUPtMIkwDQPqxcuVI333yzDjjgAO28885atarujKmioiL96U9/0nvvvacNN9wwj7UEGlcwh7klDY4e33L3Nckr3X21mb0paaSkHkmrD40en3X3V1Ls+05J5yscKj9E0tMZqXEWESYBIP8qKiq0yy676JVXUv1pka699lodfvjhOa4V0DqF1DNZ0+u4aXTYuh4z6yxpbDT7esLy7pImRLOPpdqxu7ukx6PZnTNR2WwjTAJAfn3zzTfafffdGw2Sf/3rXwmS6BAKKUxeGT2OlnSHmY2uWWFm60u6S6FX8hNJlyZsN0Z17fROE/uvWTfIzPpmpMZZRJgEgPxYunSpzj//fI0ePVrPP/98yjLnnXeeTjrppBzXDEhPwRzmdveHzOyXkv4saV9J+5pZzdXcJZIWKQTOM909MWoNSXj+ZRMvkbhuiKQFba50FiWHSa7mBoDcuO6663TmmWemXHfiiSdq8uTJ2nXXXXNcKyB9BRMmJcndLzOzjyRdL2kthRBZo4vCuZK9VD8IJsasyiZ2n7guZTQzsymSpkjSwIEDVV5e3uK6p2Pp0qWNvsaCBdsovOXgnXde1pw5HWaYzLxpqk2RHto082jTzMtkm26wwQbq37+/vvnmm9plo0aN0iWXXKJevXpJUux/fnxGMy+vberuBTEpDOPzT4VByl+TtJOk/tG0U7TMJc2X9N2E7Q6Mlruk0U3sf6eEcls3V5/NN9/cs+3ZZ59tdF23bu5S3bRsWdarEwtNtSnSQ5tmHm2aeclt+tVXX/maNWvS3t/UqVNdkvfp08f//Oc/e2VlZRtr2LHwGc28bLeppNe9kUxTSD2TFykM+fOBpO+7+4qEdf82sxclvSlpPUlXSPp+tC5xeO/uTew/cV1Fo6XagVWrpBUJ7764WCopabw8ACBYtWqVJk+erKefflobbrih/vnPf2rjjTdu9X4OP/xwLVq0SEcffXS9gciBjqggLsCJboM4JZq9IilISpLcfbmkv0ez25rZWtHzxFFi127iZRLXteuRZZPvftOzp8SdtwCgea+88oreeOMNSdL//vc/TZo0SR999FGDco899piOOOIIffDBByn306lTJ/3mN78hSCIWCiJMKvQ21vTCftJEucRvhBHR43uSqqPnTf37WbPuK3fvUBffcCU3ALTMdtttp7lz5+rvfw99D/PmzdOkSZP0zDPP6NJLL9W5556rSy65RAcddJBuuOEGjRkzRvvtt1+joRKIg0I5zF2d8HxYE+UGJjyvkCR3rzSzlxQOe++qcLi8nui+37tEs0+2rarZN2CAdN99IVRWVEhdujS/DQAguPTSS/W73/2udv7zzz/XjjumvvmZu+vuu+/W6aefnqvqATlXKGHyfUnLFa7ePsrMrvGku+CYWbHqDoUvVDi3ssZNCmFyezP7nrv/N2n/+ymMUSlJN2e68pnWo4e01175rgUAdEynnnqqPvjgA914440tKr/rrrtqs802y26lgDwqiMPc0fmQ10az4yQ9ZGabmFlRNH1X0qOStonKXObuVQm7uEnSDEkm6Z6a+29H2+4n6Zqo3GPu3u5vpQgASF9RUZGuueYa7bvvvi0qn9iLCcRRofRMStJpkr6jcKi6ZloZreuaUO4Ohfts13L3NWa2p6RnJQ2X9JSZVSqE8W5RsemSDspW5QEA+TFz5kx98cUX9ZZ16tRJt912m1avXq0HHnhAkjRy5EjtsMMOeuGFF2rPkfzJT36i73//+w32CcRJwYRJd19uZpMl/VjSzyRtrjBwuUuaLelVSTe4+yONbD8z6sH8taR9FC7QWS3pXYUAerm7M+o3AMTMueeeqwceeECbbrqpNtlkk9rlXbp00X333afnnntOxcXF2nrrrdWpUydVVVXpxRdfVGVlpSZNmiRjuAzEXMGESUmKBt28O5rS2b5C0tnRBAAoAM8995wWLlyo7bbbTg8//LA23HDD2iF9zEwTJ06sV764uFjbbbdd7isK5ElBhUkE774rzZ4dhgTq2VNaZx2Joc4AoKGqqqraQ9wLFy7UhAkTVJE8WC9Q4AriAhzUd+210m67SRMmSJtsIl1/fb5rBADt07x587R69era+b59+6pHjx55rBHQ/hAmCxCDlgNAy8yaNave/LrrrpunmgDtF2GyACWHybKy/NQDANq7zz//vN78sGFN3fcCKEycM1mAvvtdadGicPebJUuktdZqdhMAKEjJYZKeSaAhwmQBOuusfNcAADoGwiTQPA5zAwDQCM6ZBJpHmAQAoBGcMwk0jzAJAEAjOMwNNI8wCQBAChUVFVq4cGHtfOfOnTVw4MA81ghonwiTAACkkNwrOXToUBUV8WcTSMZvRYGZO1caMEAaNUrabDNpn33yXSMAaJ84xA20DEMDFZjFi6VvvgmTJC1blt/6AEB7xcU3QMsQJgtMRUX9eW6lCACpTZ48WXfffbdmzZqll19+Wbvssku+qwS0S4TJAsN9uQGgZYYOHaqhQ4dKksaNG6eJEyfmt0JAO8U5kwWGMAkAADKJMFlgCJMAACCTCJMFJjlMlpXlpx4AACAeCJMFhp5JAACQSYTJAkOYBAAAmUSYLDAMDQQAADKJMFlg6JkEAACZRJgsMIRJAACQSYTJAsPV3AAAIJMIkwWGnkkAAJBJhMkCQ5gEAACZRJgsMFzNDQAAMokwWWDomQQAAJlEmCwgq1dLK1bUzRcVSSUl+asPAADo+AiTBaSysv589+6SWX7qAgAA4oEwWUCWL68/T68kAABoK8JkAUk8xC0RJgEAQNsRJgsIPZMAACDTCJMFJDlMduuWn3oAAID4IEwWEHomAQBAphEmCwhhEgAAZFqnfFcAudO3r7TnniFUrlghffe7+a4RAADo6AiTBWTcOOmBB/JdCwAAECcc5gYAAEDaCJMAAABIG2ESAAAAaSNMAgAAIG2ESQAAAKSNMFlAzj5bGjhQGj5cGjNGuuGGfNcIAAB0dAwNVEAWLJC+/rpuvqIif3UBAADxQM9kAVmxov489+YGAABtRZgsINxOEQAAZBqHuQvI1VdLF18cQuXy5dLgwfmuEQAA6OgIkwWktDRMAAAAmcJhbgAAAKSNMAkAAIC0ESYBAACQNsIkAAAA0sYFOAXkT3+SVq4MQwKVlEhHHCGVleW7VgAAoCMjTBaQSy+Vvvmmbn7//QmTAACgbTjMXUAYtBwAAGQaYbJAuBMmAQBA5hEmC8SaNVJ1dd18cbHUuXP+6gMAAOKBMFkgknslu3XLTz0AAEC8ECYLBIe4AQBANhAmCwRhEgAAZANhskAQJgEAQDYQJgvEihX15wmTAAAgEwiTBYILcAAAQDYQJgsEh7kBAEA2ECYLBGESAABkA2GyQHDOJAAAyAbCZIGgZxIAAGQDYbJAcAEOAADIBsJkgaBnEgAAZANhskBwziQAAMgGwmSBoGcSAABkA2GyQBAmAQBANhAmCwQX4AAAgGwgTBYIeiYBAEA2ECYLBBfgAACAbCBMFgh6JgEAQDYQJgsEYRIAAGQDYbJAVFbWnydMAgCATOiU7wogNx5/XFq2TFq6NDwOHZrvGgEAgDggTBaIrl3D1LdvvmsCAADihMPcAAAASBthEgAAAGkjTAIAACBthEkAAACkjQtwCsCyZdLpp0ulpVKPHlK/ftIxx+S7VgAAIA4IkwVg0SLpb3+rmx88mDAJAAAyg8PcBWDp0vrzpaX5qQcAAIifggyTZtbTzE4zs5fNbL6ZrTSzL8zsWTM7x8x6N7JdWbR+hpktNbPFZvaamZ1iZl1y/DZabNmy+vM9euSnHgAAIH4K7jC3mW0v6Q5JA6NFqyRVSlo7miZKul/Sm0nbDZNULml4tKhSUldJ46PpIDPb0d0XZrH6aRkyRLr00rq736y1Vr5rBAAA4qKgwqSZTZD0iKQSSfdKukDSNHd3M+suaSNJP5K0OGm7TpIeUgiScyUd4u5PmVmRpP0kXSNpM0m3Svphbt5Nyw0aJJ18cr5rAQAA4qhgwmQUFm9WCJKXu/tJievdvVLSa9GU7FBJm0TPf+zur0TbVEv6ZxQqb5c0OeqdfDpLbwMAAKBdKaRzJg+WNFLSV5JObeW2h0aPz9YEySR3Svosen5IetUDAADoeAopTNaEvH+5+4qWbhT1aE6IZh9LVcbdXdLj0ezOadcQAACggymIMGlmNRfKSNI0M1vXzKaa2WwzW2Vm88zsITNLdb7jGNW10ztNvEzNukFm1jdDVQcAAGjXCiJMKlw4UzN0z0iF4He0pLUkLYsed5f0sJldY2aWsO2QhOdfNvEaieuGNFoqD+bMkd57T5o9W1qwQFq9Ot81AgAAcVEoYbJPwvMzJa1WuAq7h7v3kTRM0r+i9UdJ+mVC+bKE55VNvEbiurJGS+XBRRdJG24orbtuuJVi4t1wAAAA2qJQruYuSnp+pLvfX7PA3T83s/0lrSdpU0mnm9nf3H1NJithZlMkTZGkgQMHqry8PJO7b2Dp0qUqLy/XRx+tp8TO0i+//EDl5XOz+tpxVdOmyBzaNPNo08yjTTOL9sy8fLZpoYTJioTnHyUGyRruXm1mF0u6RVI/SZtL+m/Stt2beI3EdRWpCrj7VElTJWn8+PE+ceLEltQ9beXl5Zo4caKmTq2/fNy49TVx4vpZfe24qmlTZA5tmnm0aebRpplFe2ZePtu0UA5zJ57P+H4T5f6X8HxY9DgnYdnaTWybuG5Oo6XygNspAgCAbCmIMOnuC9T0xTM1Ei+88ejxPUnV0fONm9i2Zt1X0eu1G0uX1p8vLc1PPQAAQPwURJiMPBk9jmmizIYJzz+Tau+M81K0bNdUG0VXf++S9DrtRnKYpGcSAABkSiGFyRuix9FmtlfyyuiWiL+OZr+U9EbC6puix+3N7Hsp9r2fwpBDUrhlY7uSfJibnkkAAJApBRMm3f0FSXdHs9ea2Y/NrJMkmdm6ku6Q9N1o/RnRfbdr3CRphsJh8HvMbMdouyIz20/SNVG5x9rjfbnpmQQAANlSKFdz1zhMYYDyHygEy5VmVqn641Ce6+43JW7k7mvMbE9JzyoMgP5UtF2RpG5RsemSDspq7dNEzyQAAMiWgumZlCR3XyZpe4W73zyvcPebHgqHte+UNMHdz2lk25kKPZfnKdxBxxUGP5+mcHh8K3dfmN13kB56JgEAQLYUWs+kosPX10ZTa7etkHR2NHUIVVXSihX1l5WU5KcuAAAgfgqqZ7IQpTrEXcRPHQAAZAixIuYYsBwAAGQTYTLmGLAcAABkE2Ey5uiZBAAA2USYjDl6JgEAQDYRJmOOnkkAAJBNhMmYo2cSAABkE2Ey5hiwHAAAZBNhMua4lSIAAMgmwmTMrV5df75Ll/zUAwAAxBNhMubWrKk/36ngbqAJAACyiTAZc4RJAACQTYTJmCNMAgCAbCJMxhxhEgAAZBPRIuZ22ilcwb1mTZi23TbfNQIAAHFCmIy5bbYJEwAAQDZwmBsAAABpI0wCAAAgbYRJAAAApI0wCQAAgLS1+gIcMxso6YJo9ix3/7KZ8mtL+oMkl/Qbd1/Q6loibXPmSEuXhiGBOnWS+vXj/twAACBz0umZPFjSYZI2ay5ISlJUZmy0zUFpvB7a4IwzpPXXl0aNkoYNk+66K981AgAAcZJOmNxJoZfx7lZsc5ckk7RbGq+HNmDQcgAAkE3phMlNosdXW7HN69Hjd9N4PbQBYRIAAGRTOtGiX/T4dSu2mR899k/j9dAGAwdK3/lO3R1wevTId40AAECcpBMml0sqi6aWqim7Oo3XQxtcdlmYAAAAsiGdw9w1F91s0Ypttowe56bxegAAAGin0gmTzytcTHOCmXVtrrCZdZN0vMJFO8+n8XoAAABop9IJk9dFj8Ml/cvMGj3cHa27S9KIaNH1abweAAAA2qlWnzPp7q+b2U2SDpX0Q0kfmNn1kl5Q3WHswZJ+IOlwSQMVeiXvcPeXM1JrAAAAtAvpDhRzjKQBkiZLGiTpd9GUzKLHxyUdmeZrAQAAoJ1K697c7r7K3XeXdIKkzxVCY6rp86jMD919ZUZqjFb5+c+l7beXdtpJ2m036f33810jAAAQJ20awtrd/2FmVyoMRj5OobdSkr6RNE3S2+7ubasi2uL116Vp0+rmzzsvf3UBAADx0+b7oURh8a1oQjvDHXAAAEA2pXWYGx0HYRIAAGRTq6OFmRVLmhDNvuXui5sp31t19+R+gcPeuUWYBAAA2ZROz+SPJJVLulctuz3iqqjsswpDCSGHCJMAACCb0gmTe0WP/3L3yuYKR2X+qXB19z5pvB7agDAJAACyKZ0wuaXCIOTPtmKbmrLfS+P10AaESQAAkE3phMmh0eOnrdhmZvS4bhqvhzYgTAIAgGxKJ0zWbNOaC2lqynZO4/XQBslhsjM/AQAAkEHphMn50eN3WrFNTdkFabwe2oCeSQAAkE3phMk3FC6m2b8V2xwQPTKweY4RJgEAQDalEybvjx73MLODmyscldlD4VD3fWm8HtqAMAkAALIpnTB5q6SPFXonbzCzv5vZ6ORCZvYdM/uHpBsUguTM6DlyiDAJAACyqdXRwt3XmNnekl6U1EvSsZKONbOvJc2Nig2WtFb03CRVSNrb3VsyyDkyxF2qqqq/rLg4P3UBAADxlNa9ud39XYXxJl9TCIsmaaCksdE0MGH565K2cPe3215dtEZ1tdWbLy6WzBopDAAAkIa0D3q6+0eSvmdmO0raXdI4SQOi1d9ImibpIXd/ps21RFqqquonRw5xAwCATGtzvHD3pyU93VQZMytRuJXioe6+c1tfEy1DmAQAANmW1XhhZj+QdKikfSX1yOZroSHCJAAAyLaMxwszGyXpEEk/kzS8ZnH02Jq75qCNCJMAACDbMhIvzKxM0k8VeiG3qVkcPbqk/0i6O5qQI4RJAACQbWnHCzMzSTsrBMgfSepWs0ohQE6XdJOke9z9yzbWE2kgTAIAgGxrdbwws40UAuRBkgbVLI4eP1Ldfbj/7O53tbmGSBthEgAAZFuL4oWZ9ZN0oEKI3KxmcfT4jaR/SrrF3V81s+qM1xJpIUwCAIBsazJeRHe6OUTSbpI6qy5ArpD0kKRbJD3u7mtS7wH5RJgEAADZ1ly8uEfh/Mea8yCfUwiQd7v7kizXDW1UVOTaYINwf+41a6S11853jQAAQNy0tK+qQtIv3P3GLNYFGbbOOsv13nv5rgUAAIizltyb2xQGHL/OzGaZ2QVmtnGW6wUAAIAOoLkwuYmkSyR9pRAqh0o6VdJbZjbdzH5pZoOa2gEAAADiq8kw6e7vuvtvFELkZIWrtlcqBMtNJV0sabaZPWFmB5lZ92xXGAAAAO1HSw5zy92r3f1xdz9AYWzJYyS9rBAqiyVNknSzpHnZqigAAADanxaFyUTuvsTdr3H3bSWtJ+l8SZ8rBMtS1d1/+3Izu8rMJplZq18HAAAA7V+bQp67f+zuZ7n7CEk7KNw+cZlCsBwg6WhJT0iaZ2bXmtmuba0wWu7dd3vqBz+QdthB2nln6ayz8l0jAAAQNxkbxtrdyyWVm9nxkvZVGOx8e4Vg2U/S4ZIOy+RrommLF3fWCy/UzXfpkr+6AACAeMr44Wd3r3T3m919kqThks6S9KFCqLSmtkVmcQccAACQbVk9l9HdZ7v7+e6+gaQJkqZm8/VQH2ESAABkW87ihbu/IumVXL0epLFjF+m55+pupzhgQL5rBAAA4oa+qhjr3Xu1fvCDfNcCAADEGUP2AAAAIG2ESQAAAKSNMAkAAIC0ESYBAACQNi7AibHPPuuuL74IQwJ16iStv760ySb5rhUAAIgTwmSM/fe//XT11XXzv/61dNFF+asPAACIHw5zxxiDlgMAgGwjTMYYYRIAAGQbYTLGCJMAACDbCJMxRpgEAADZRpiMMcIkAADINsJkjBEmAQBAthEmY4wwCQAAso0wGWOESQAAkG2EyRgjTAIAgGwjTMYYYRIAAGQbYTLGCJMAACDbCJMxRpgEAADZRpiMMcIkAADINsJkjBEmAQBAthV0mDSz35qZ10zNlC0zs3PMbIaZLTWzxWb2mpmdYmZdclXn1iBMAgCAbCvYeGFm60s6u4Vlh0kqlzQ8WlQpqauk8dF0kJnt6O4LM1/T9BEmAQBAthVkz6SZFUm6XlI3Sa80U7aTpIcUguRcSTu5e6mk7pL2l1QhaTNJt2axymkhTAIAgGwryDAp6URJ20i6TdKTzZQ9VNIm0fMfu/tTkuTu1e7+T0nHROsmm9mO2ahsugiTAAAg2wouTJrZCEnnS/pW0i9bsMmh0eOz7p6qF/NOSZ9Fzw9pew0zhzAJAACyreDCpKRrJJVK+pW7z2+qoJl1lzQhmn0sVRl3d0mPR7M7Z6qSmUCYBAAA2VZQYdLMjpa0o6Sn3P3mFmwyRnVt9E4T5WrWDTKzvm2oYkYRJgEAQLYVTJg0s7UlXSRpuerOc2zOkITnXzZRLnHdkEZL5RhhEgAAZFshxYurJfWSdJq7f9rCbcoSnlc2US5xXVmjpXKMMAkAALKtIOKFmf1M0g8lvSnpL3msxxRJUyRp4MCBKi8vz+rrrV69eb35N954VQsXNpWJ0ZylS5dm/edWaGjTzKNNM482zSzaM/Py2aaxD5NmNlDSZZKqJB3t7mtasXlFwvPuTZRLXFfRWCF3nyppqiSNHz/eJ06c2IqqtN4ZZ7yuDTYYrzVrpDVrpAkTtlSPHll9ydgrLy9Xtn9uhYY2zTzaNPNo08yiPTMvn20a+zAp6f8k9ZN0paT3zSw5TtXeCjFh3Sp3XyVpTkK5tSW93chrrJ3wfE4jZXJu/fWXarvt8l0LAAAQZ4VwAc6I6PFYhV7D5Ol3CWVrll0Yzb8nqTp6vnETr1Gz7it3X5CBOgMAAHQIhRAm0+bulZJeimZ3TVXGzEzSLtFsc3fTAQAAiJXYh0l3n+ju1tgk6dyEsjXLT07YxU3R4/Zm9r0UL7GfpJHR85aMXQkAABAbsQ+TGXCTpBmSTNI9NfffNrMiM9tP4Y46kvSYuz+dpzoCAADkRSFcgNMm7r7GzPaU9Kyk4ZKeMrNKhSDeLSo2XdJB+alh4556ai19+WUYX7JTJ2nPPaXOnfNdKwAAECeEyRZw95lm9l1Jv5a0j8JFPaslvSvpDkmXR1d/tysXX7y+Vq6sm1+2jDAJAAAyq+DDpLufI+mcFpSrkHR2NHUI3AEHAABkG+dMxhhhEgAAZBvxIqbcpUmT5ql//0G1d8Ap4l8HAACQYYTJmDKTTj/9fU2cOCjfVQEAADFGXxUAAADSRpgEAABA2giTAAAASBthEgAAAGkjTAIAACBthMmYmj1b2nnnH6hHD6l3b2nTTfNdIwAAEEcMDRRTa9ZIq1cXafXqML94cX7rAwAA4omeyZiqqqo/X1ycn3oAAIB4I0zGFGESAADkAmEypgiTAAAgFwiTMUWYBAAAuUCYjKnq6vrzRfykAQBAFhAxYoqeSQAAkAuEyZgiTAIAgFwgTMYUYRIAAOQCYTKmCJMAACAXCJMxRZgEAAC5QJiMKcIkAADIBcJkTDE0EAAAyAUiRkzRMwkAAHKBMBlThEkAAJALhMmYIkwCAIBcIEzGFGESAADkAmEypgiTAAAgFwiTMcXV3AAAIBeIGDFFzyQAAMgFwmRMESYBAEAuECZjijAJAABygTAZU4RJAACQC4TJmCJMAgCAXOiU7wogO0aNkiZNmqf+/QeqqkraYot81wgAAMQRYTKmJk6UpPc0ceLAPNcEAADEGYe5AQAAkDbCJAAAANJGmAQAAEDaCJMAAABIG2ESAAAAaSNMxtSFF0q77vp9lZVJvXpJ552X7xoBAIA4YmigmFq5Ulq5slgrV4b5VavyWx8AABBP9EzGFHfAAQAAuUCYjKnq6vrzhEkAAJANHOaOqbPOkrbe+nltu+0PVFUlde2a7xoBAIA4IkzGVOfOUklJtcrK8l0TAAAQZxzmBgAAQNoIkwAAAEgbYRIAAABpI0wCAAAgbVyAE1N33SXddddoPfRQGBZon32krbbKd60AAEDcECZj6umnpXvuWad2fuRIwiQAAMg8DnPHFHfAAQAAuUCYjCnCJAAAyAXCZEwRJgEAQC4QJmMq+d7cRfykAQBAFnABTkzRMwkASFdVVZWWLFmiiooKLV++XNXJPRRt1KtXL7333nsZ3WehS9WmRUVFKikpUVlZmXr27KniLIUBwmRMESYBAOlYtWqVZs2ape7du6t3795ae+21VVRUJDPL2GtUVFSorKwsY/tDwzZ1d1VXV2vZsmWqqKjQN998o2HDhqlLly4Zf23CZEwRJgEArVVVVaVZs2apf//+6tOnT76rgzYwMxUXF6tnz57q2bOnFi5cqFmzZmnkyJEZ76HkTLqYIkwCAFpryZIl6t69O0Eyhvr06aPu3btryZIlGd83YTKmCJMAgNbi8HO8lZWVqaKiIuP7JUzGVPK50oRJAEBzli9frtLS0nxXA1lSWlqq5cuXZ3y/hMmYSu6ZZGggAEBzqqurVcQfjNgqKirK+JX5EmEytjjMDQBIRyav2kb7kq2fLWEypgiTAAAgFwiTMUWYBAAAuUCYjCnCJAAAyAXCZEwRJgEAQC4QJmMq+WItLs4DAADZQMSIKXomAQBo/8rLy2VmKaeSkhINHTpUu+++u6699lqtWLEi39VNiTAZU4RJAAA6thUrVuiLL77QI488oqOPPlpjx47VBx98kO9qNUCYjCnCJAAAHcuxxx6rGTNm1E7//e9/dfXVV2vMmDGSpA8++EC77bZbVu5i0xaEyZgiTAIA0LGstdZa2njjjWunLbfcUlOmTNG0adO05ZZbSpI+++wzXXfddXmuaX2EyZgiTAIAEA8lJSU6//zza+cfe+yxPNamIcJkTBEmAQCIj6222qr2+axZs/JYk4YIkzHF0EAAAMRH586da59XJfcY5RkRI6b+9z/p0Uef1+LF0oIF0ogR+a4RAABI19tvv137fMiQIXmsSUOd8l0BZEfXrlJJSbV69sx3TQAAQFv96U9/qn2+/fbb57EmDdEzCQAA0mKW3tSzZ1mLy06Z0vLXb8yUKenVM9+WL1+uV155RXvuuafuv/9+SVLPnj11zDHH5LdiSeiZBAAAaAfOPfdcnXvuuY2u79mzp+655x4NGDAgh7VqHj2TAAAA7djQoUN14oknasaMGZo0aVK+q9MAPZMAAADtwLHHHqvjjjuudr5bt27q16+f+vTpk8daNY8wGVOnnSZ9+ukoPfxwGGPy3HOlbt3yXSsAQJy4p7ddRUWFysrKcvb6U6eGqb2ruQNOR0OYjKkrrpCWLRtaO3/mmYRJAACQeZwzGVPcAQcAAOQCYTKmCJMAACAXOMwdUxdfLL3//scaMWK0qqulTvykAQBAFhAxYuqkk6Ty8i80ceLofFcFAADEGIe5AQAAkLaCCZNm1s/MDjezW83sf2a2zMxWmtkXZna/me3dgn2Umdk5ZjbDzJaa2WIze83MTjGzLrl4HwAAAO1JIR3m/kr13+8KSaslrR1NPzKzxyTt6+6VyRub2TBJ5ZKGR4sqJXWVND6aDjKzHd19YbbeAAAAiJeJEyfK0x2ws50omJ5JhSD5qqTjJI1y9xJ37yFphKTrojK7Sbo6eUMz6yTpIYUgOVfSTu5eKqm7pP0lVUjaTNKtWX4PAAAA7Uohhckd3P177n6lu39as9DdZ7r7UaoLkT8zs6FJ2x4qaZPo+Y/d/alo22p3/6ekY6J1k81sxyy+hxapqpLefVeaNau7PvxQ+uyzfNcIAADEVcGESXd/tpki1yU8H5+07tDo8Vl3fyXFtndKqolsh6RRvYxaskTaeGPpsMO21PrrS5ttlu8aAQCAuCqYMNkCKxKe1w7xbWbdJU2IZh9LtaGHkx0ej2Z3zkrtWoEBywEAQK4QJutMTHg+I+H5GNW10ztNbF+zbpCZ9c1gvVqNMAkAAHKFMCnJzHpL+l00+4K7f5CwekjC8y+b2E3iuiGNlsqB6ur680X8lAEAQJYU0tBAKZlZkaRbJA1WONR9QlKRsoTnDYYMamRdWaoCZjZF0hRJGjhwoMrLy1tb3RaZP7+rpK1r56uqVqq8PNWpnmitpUuXZu3nVqho08yjTTOvUNq0V69eqqioyPrrVFVV5eR1CklL23TFihUZ/ywXfJiU9FdJu0fPj3f3t7P1Qu4+VdJUSRo/frxPnDgxK68za1b9+ZKSrsrWaxWa8vJy2jLDaNPMo00zr1Da9L333lNZWcr+kIyqqKjIyesUkpa2abdu3bRZhq/MLegDoGZ2sep6In/p7tenKJYY87s3sbvEdXn9d4tzJgEAQK4UbJg0swslnRLN/trdL2uk6JyE52s3scvEdXMaLZUDhEkAAJArBRkmzewiSb+JZk9190uaKP6epJpLWjZuolzNuq/cfUEbq9gmhEkAAJArBRcmo0Pbv45mT3X3i5oqH92n+6VodtdG9mmSdolmn8xEPduCMAkAAHKloMJkFCQTD203GSQT3BQ9bm9m30uxfj9JI6PnN7ehihnB0EAAACBXCiZmJJ0j+atmDm0nu0lhIHOTdE/N/bfNrMjM9pN0TVTuMXd/OlN1Thc9kwAAIFcKYmggM1tXdedIVks6zcxOa2KTi9394poZd19jZntKelbScElPmVmlQhjvFhWbLumgTNc9HYRJAACQKwURJlW/B7ZI0sBmyvdIXuDuM83suwrnW+4jaYSk1ZLelXSHpMvdfVVmqts2hEkAAJArBREm3X2mwiHqtu6nQtLZ0dRuESYBAECuFMw5k4WEMAkAAHKFMBlDXM0NAAByhZgRQ/RMAgCAXCFMxhBhEgCAjqG8vFxmJjPTOeeck+/qpIUwGUOESQAAkCuEyRgiTAIAgFwhTMYQYRIAAOQKYTKGCJMAACBXCJMxxNBAAAAgV4gZMUTPJAAAyJWCuJ1ioRk7VrrsMumDDz7WiBGjtd56+a4RAACIK8JkDH3nO9IvfiGVl3+hiRNH57s6AAAgxgiTAACgdczatHlZhqqRM+75rkG7xjmTAAAASBthEgAAAGkjTAIAACBtnDMZQ99+K331lfT559310UdSnz5S//75rhUAIDbaeA5hRUWFyso63JmTaAQ9kzF0xx3SxhtLhx66pdZbTzr77HzXCAAAxBVhMoYYtBwAAOQKYTKGCJMAACBXOGcyhvr2lcaMkZYurVSXLt01YEC+awQAAOKKMBlDhx0WpvLyVzVx4sQ81wYAAMQZh7kBAACQNsIkAAAA0sZhbgAAgDyZOHGivIPf+5ueSQAAAKSNMAkAAIC0cZg7hv7xD+n226WKirHq21c65hhp//3zXSsAABBHhMkY+vRT6aWXJKm3JGny5HzWBgAAxBmHuWOourr+fBE/ZQAAkCXEjBjidooAACBXCJMxRJgEAAC5QpiMIcIkAADIFcJkDBEmAQBArhAmY4gwCQAAcoUwGUOESQAAkCuEyRhiaCAAAJArxIwYomcSAADkCmEyhgiTAAAgVwiTMUSYBAAAuUKYjCHCJAAAyBXCZAwRJgEAQK4QJmMo+WpuwiQAAMgWwmQMJfdMMjQQAADIFmJGDHGYGwAA5EqnfFcAmUeYBACgY3J3Pf7443r44Yf14osv6quvvtLChQtVWlqqQYMGafz48Zo8ebL22msvlZSU5Lu6kgiTsUSYBACg43n55Zd1wgknaPr06Q3WLVq0SIsWLdL777+vW2+9VX379tUZZ5yhk08+WUV5Pp+NMBlDhEkAADqWW265RUcddZRWrVolSRo/frx+/OMfa9y4cerfv78qKio0c+ZMPf7443rwwQe1YMECnXLKKTriiCPUu3fvvNadMBlDhEkAADqO8vJyHX744aqqqlL37t117bXX6oADDmhQbrvtttOhhx6qefPm6ZxzztFVV12Vh9o2RJiMoeShgbiaGwCA9mn58uU68MADVVVVpaKiIj300EPaYYcdmtxm4MCBuvLKK7Xjjjuqc+fOOapp4wiTMUTPJAAAHcP111+vuXPnSpKOPfbYZoNkon333Tdb1WoV+qxiiDAJAEDHcMMNN0iSzEwnn3xyfiuTJnomY2jECGn5cmnp0kp16dJd7WTkAAAAkGDJkiV68803JUnrrbeeRo8end8KpYkwGUN33x0ey8tf1cSJE/NaFwAAkNqMGTNUFR1O3HzzzfNcm/RxmBsAAKTFzNKafvCDHzS6z8033zzt/TZmypQpGd1fpnz77be1zwcOHJj118sWwiQAAEAeVFRU1D4vLS3NY03ahjAJAACQB2VlZbXPly1blseatA1hEgAAIA/69etX+3zevHl5rEnbECYBAEBa3D2t6fnnn290n9OmTUt7v42ZOnVqRveXKZtssomKo/H7pk2blvXXyxbCJAAAQB707NlTY8eOlSR9+OGH+uijj/JboTQRJgEAAPLk8MMPlxR6ef/617/muTbpIUwCAADkyRFHHKHBgwdLkq688ko988wzLd72nnvuaRcX7hAmAQAA8qSkpES33XabiouLVV1drT322EP//Oc/m9xm/vz5Ov7447Xvvvtq9erVOapp47gDDgAAQB5tv/32uv7663X00UersrJS+++/vy655BLtu+++2myzzdSvXz8tXbpUs2bN0hNPPKEHHnhAS5cuzXe1axEmAQAA8uyQQw7RqFGjdOKJJ2r69Ol67bXX9NprrzVavn///jr77LPVs2fPHNYyNcIkAABAOzBhwgRNmzZNjz32mB5++GG99NJLmjt3rhYuXKjS0lINGTJE48eP1w9/+EPttdde6tq1a76rLIkwCQAA0G6YmSZPnqzJkyfnuyotxgU4AAAASBthEgAAAGkjTAIAACBthEkAAACkjTAJAACAtBEmAQAAkDbCJAAAANJGmAQAAEDaCJMAAABIG2ESAAAAaSNMAgCAWu6e7yogS7L1syVMAgAASVJRUZGqq6vzXQ1kSXV1tYqKMh/9CJMAAECSVFJSomXLluW7GsiSZcuWqaSkJOP7JUwCAABJUllZmSoqKvJdDWRJRUWFysrKMr5fwiQAAJAk9ezZU5WVlVq4cGG+q4IMW7hwoSorK9WzZ8+M77tTxvcIAAA6pOLiYg0bNkyzZs1SZWWlysrKVFpaqqKiIplZvquHVnB3VVdXa9myZaqoqFBlZaWGDRum4uLijL8WYRIAANTq0qWLRo4cqSVLlmjRokWaO3duxi/KWbFihbp165bRfRa6VG1aVFSkkpISlZWVadCgQVkJkhJhEgAAJCkuLlafPn3Up0+frOy/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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='P')\n",
    "\n",
    "plt.plot(list(range(100,300)),Results21[100:], 'r', linewidth=4.0, label='I')\n",
    "\n",
    "plt.plot(list(range(200,300)),Results31[200:], '--k', linewidth=4.0, label='C')\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": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "250"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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
}
