{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"nested_n_spheres_ghbnode.ipynb","provenance":[],"collapsed_sections":[]},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"markdown","metadata":{"id":"6S1576wMxDOx"},"source":["# Setup"]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"NvJw9wWHxB9Q","executionInfo":{"status":"ok","timestamp":1620330587596,"user_tz":360,"elapsed":3483,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"cf60964b-f6c5-4457-a46b-dc229f841149"},"source":["import time\n","import os\n","import argparse\n","import numpy as np\n","import torch\n","import torch.nn as nn\n","import torch.optim as optim\n","\n","class ArgumentParser:\n","    def add_argument(self, str, type, default):\n","        setattr(self, str[2:], default)\n","\n","    def parse_args(self):\n","        return self\n","\n","parser = ArgumentParser()\n","parser.add_argument('--tol', type=float, default=1e-7)\n","parser.add_argument('--adjoint', type=eval, default=False)\n","parser.add_argument('--visualise', type=eval, default=True)\n","parser.add_argument('--niters', type=int, default=300)\n","parser.add_argument('--lr', type=float, default=0.01)\n","parser.add_argument('--gpu', type=int, default=0)\n","parser.add_argument('--data_dimension', type=int, default=2)\n","parser.add_argument('--npoints', type=int, default=50)\n","parser.add_argument('--ntest', type=int, default=10)\n","args = parser.parse_args()\n","\n","! pip install torchdiffeq\n","from torchdiffeq import odeint_adjoint as odeint\n"],"execution_count":14,"outputs":[{"output_type":"stream","text":["Requirement already satisfied: torchdiffeq in /usr/local/lib/python3.7/dist-packages (0.2.1)\n","Requirement already satisfied: torch>=1.3.0 in /usr/local/lib/python3.7/dist-packages (from torchdiffeq) (1.8.1+cu101)\n","Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from torch>=1.3.0->torchdiffeq) (1.19.5)\n","Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch>=1.3.0->torchdiffeq) (3.7.4.3)\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"9nLTYRksx4QG","executionInfo":{"status":"ok","timestamp":1620326576087,"user_tz":360,"elapsed":43343,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"a5c5444a-3402-4e7c-9eb1-6478b34f5480"},"source":["from google.colab import drive\n","drive.mount('/content/drive')\n","! cp -r drive/MyDrive/nested-n-spheres/data ./data."],"execution_count":2,"outputs":[{"output_type":"stream","text":["Mounted at /content/drive\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"c_MHUQyK2EvJ","executionInfo":{"status":"ok","timestamp":1620326576089,"user_tz":360,"elapsed":43341,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["import csv\n","class Recorder:\n","    def __init__(self):\n","        self.store = []\n","        self.current = dict()\n","\n","    def __setitem__(self, key, value):\n","        for method in ['detach', 'cpu', 'numpy', 'flatten']:\n","            if hasattr(value, method):\n","                value = getattr(value, method)()\n","        if key in self.current:\n","            self.current[key].append(value)\n","        else:\n","            self.current[key] = [value]\n","\n","    def capture(self, verbose=False):\n","        for i in self.current:\n","            self.current[i] = np.mean(self.current[i])\n","        self.store.append(self.current.copy())\n","        self.current = dict()\n","        if verbose:\n","            for i in self.store[-1]:\n","                print('{}: {}'.format(i, self.store[-1][i]))\n","        return self.store[-1]\n","\n","    def tolist(self):\n","        labels = set()\n","        labels = sorted(labels.union(*self.store))\n","        outlist = []\n","        for obs in self.store:\n","            outlist.append([obs.get(i, np.nan) for i in labels])\n","        return labels, outlist\n","\n","    def writecsv(self, writer):\n","        \n","        labels, outlist = self.tolist()\n","        if isinstance(writer, str):\n","            outfile = open(writer, 'w')\n","            csvwriter = csv.writer(outfile)\n","            csvwriter.writerow(labels)\n","            csvwriter.writerows(outlist)\n","            outfile.close()\n","        else:\n","            csvwriter = writer\n","            csvwriter.writerow(labels)\n","            csvwriter.writerows(outlist)"],"execution_count":3,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"bfV63AOmxGNX"},"source":["# Model"]},{"cell_type":"code","metadata":{"id":"z19w7bIyJTic","executionInfo":{"status":"ok","timestamp":1620326576090,"user_tz":360,"elapsed":43334,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["totallist = []"],"execution_count":4,"outputs":[]},{"cell_type":"code","metadata":{"id":"M6zb7sWmve6K","executionInfo":{"status":"ok","timestamp":1620326576091,"user_tz":360,"elapsed":43332,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["modelname = 'GHBNODE'\n","seed = 100\n","res = 0.0\n","if modelname == 'GHBNODE':\n","    res = 2\n","\n","def tanhc(x):\n","    a = 20\n","    return x#a * torch.tanh(x / a)\n","\n","class initial_velocity(nn.Module):\n","    \n","    def __init__(self, dim, nhidden):\n","        super(initial_velocity, self).__init__()\n","        self.tanh = nn.Hardtanh(min_val=-5.0, max_val=5.0, inplace=False)\n","        self.fc1 = nn.Linear(dim, nhidden)\n","        self.fc2 = nn.Linear(nhidden, nhidden)\n","        self.fc3 = nn.Linear(nhidden, dim)\n","        \n","    def forward(self, x0):\n","        out = self.fc1(x0)\n","        out = self.tanh(out)\n","        out = self.fc2(out)\n","        out = self.tanh(out)\n","        out = self.fc3(out)\n","        return torch.cat((x0, out))\n","\n","\n","class ODEfunc(nn.Module):\n","\n","    def __init__(self, dim, nhidden):\n","        super(ODEfunc, self).__init__()\n","        indim = 2 * dim if modelname == 'SONODE' else dim\n","        self.elu = nn.ELU(inplace=False)\n","        self.fc1 = nn.Linear(indim, nhidden)\n","        self.fc2 = nn.Linear(nhidden, nhidden)\n","        self.fc3 = nn.Linear(nhidden, dim)\n","        self.gamma = nn.Parameter(torch.Tensor([-3.0]))\n","        self.nfe = 0\n","        self.actv = tanhc\n","\n","    def forward(self, t, x):\n","        cutoff = int(len(x)/2)\n","        z = x[:cutoff]\n","        v = x[cutoff:]\n","        self.nfe += 1\n","        if modelname == 'SONODE':\n","            z = torch.cat((z, v), dim=1)\n","        out = self.fc1(z)\n","        out = self.elu(out)\n","        out = self.fc2(out)\n","        out = self.elu(out)\n","        if modelname == 'SONODE':\n","            out = self.fc3(out)\n","            return torch.cat((v, out))\n","        else:\n","            out = self.fc3(out) - torch.sigmoid(self.gamma) * v + res * z\n","            return torch.cat((self.actv(-v), out))\n","    \n","\n","class ODEBlock(nn.Module):\n","\n","    def __init__(self, odefunc, t0_, tN_):\n","        super(ODEBlock, self).__init__()\n","        self.odefunc = odefunc\n","        self.integration_times = torch.tensor([t0_, tN_]).float()\n","        \n","    def forward(self, x):\n","        out = odeint(self.odefunc, x, self.integration_times, rtol=args.tol, atol=args.tol)\n","        out = out[1][:int(len(x)/2)]\n","        return out\n","\n","    @property\n","    def nfe(self):\n","        return self.odefunc.nfe\n","\n","    @nfe.setter\n","    def nfe(self, value):\n","        self.odefunc.nfe = value\n","        \n","        \n","class Decoder(nn.Module):\n","\n","    def __init__(self, in_dim, out_dim):\n","        super(Decoder, self).__init__()\n","        self.tanh = nn.Hardtanh(min_val=-1.0, max_val=1.0, inplace=False)\n","        self.fc = nn.Linear(in_dim, out_dim)\n","\n","    def forward(self, z):\n","        out = self.fc(z)\n","        out = self.tanh(out)\n","        return out\n","\n","\n","def count_parameters(model):\n","    return sum(p.numel() for p in model.parameters() if p.requires_grad)"],"execution_count":5,"outputs":[]},{"cell_type":"code","metadata":{"id":"khWBH-vMS6v5","executionInfo":{"status":"ok","timestamp":1620326576378,"user_tz":360,"elapsed":43616,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["def train():\n","    device = torch.device('cuda:' + str(args.gpu) if torch.cuda.is_available() else 'cpu')\n","    filename = 'hbnode./'\n","    try:\n","        os.makedirs('./'+filename)\n","    except FileExistsError:\n","        pass\n","        \n","    rec = Recorder()\n","    dim = args.data_dimension\n","    outputarr = []\n","\n","    #Download Data\n","    name_in = str(args.data_dimension)+'din_'+str(args.npoints)+'_train.npy'\n","    name_out = str(args.data_dimension)+'dout_'+str(args.npoints)+'_train.npy'\n","    folder_name = 'data./'\n","    z0 = torch.tensor(np.load(folder_name+name_in)).float().to(device)\n","    zN = torch.tensor(np.load(folder_name+name_out)).float().to(device)\n","    viz_z0 = torch.tensor(np.load('data./vis_data/2d_vis_data.npy')).float().to(device)\n","\n","\n","    # model\n","    t0, tN = 0, 1\n","    nhidden = 14\n","    feature_layers = [initial_velocity(dim, nhidden), ODEBlock(ODEfunc(dim, nhidden), t0, tN), Decoder(dim, 1)]\n","    model = nn.Sequential(*feature_layers).to(device)\n","    print(f'Model Parameters = {count_parameters(model)}')\n","    optimizer = optim.Adam(model.parameters(), lr=args.lr)\n","    loss_func = nn.MSELoss()\n","    \n","    itr_arr = np.empty(args.niters)\n","    loss_arr = np.empty(args.niters)\n","    nfe_arr = np.empty(args.niters)\n","    time_arr = np.empty(args.niters)\n","\n","    # training\n","    start_time = time.time()\n","    for itr in range(1, args.niters + 1):\n","        rec['epoch'] = itr\n","        feature_layers[1].nfe = 0\n","        iter_start_time = time.time()\n","        optimizer.zero_grad()\n","\n","        # forward in time and solve ode\n","        pred_out = model[1](model[0](z0))\n","        pred_z = model[2](pred_out)\n","        \n","        # compute loss\n","        loss = loss_func(pred_z, zN)\n","        rec['forward_nfe'] = feature_layers[1].nfe\n","        loss.backward()\n","        optimizer.step()\n","        iter_end_time = time.time()\n","\n","        #make arrays\n","        itr_arr[itr-1] = itr\n","        loss_arr[itr-1] = loss\n","        nfe_arr[itr-1] = feature_layers[1].nfe\n","        time_arr[itr-1] = iter_end_time-iter_start_time\n","        rec['epoch_nfe'] = feature_layers[1].nfe\n","        rec['loss'] = loss\n","        rec['log_loss'] = torch.log10(loss)\n","        rec.capture(verbose=False)\n","        \n","        if itr % 100 == 0:\n","            print('Iter: {}, running MSE: {:.4f}'.format(itr, loss))\n","            # if loss > 0.2:\n","            #     raise StopIteration\n","\n","        feature_layers[1].nfe = 0\n","        pred_out = model[1](model[0](viz_z0))\n","        outputarr.append(pred_out.detach())\n","        \n","\n","    end_time = time.time()\n","    # print('\\n')\n","    # print('Training complete after {} iters.'.format(itr))\n","    # print('Time = ' + str(end_time-start_time))\n","    loss = loss_func(pred_z, zN).detach().numpy()\n","    # print('Train MSE = ' +str(loss))\n","    # print('NFE = ' +str(feature_layers[1].nfe))\n","    # print('Parameters = '+str(count_parameters(model)))\n","    # print()\n","    \n","    np.save(filename+'itr_arr.npy', itr_arr)\n","    np.save(filename+'nfe_arr.npy', nfe_arr)\n","    np.save(filename+'loss_arr.npy', loss_arr)\n","    np.save(filename+'time_arr.npy', time_arr)\n","    torch.save(model, filename+'model.pth')\n","    \n","           \n","    # make test data\n","    name_in = str(args.data_dimension)+'din_'+str(args.ntest)+'_test.npy'\n","    name_out = str(args.data_dimension)+'dout_'+str(args.ntest)+'_test.npy'\n","    folder_name = 'data./'\n","    z0 = torch.tensor(np.load(folder_name+name_in)).float().to(device)\n","    zN = torch.tensor(np.load(folder_name+name_out)).float().to(device)\n","    feature_layers[1].nfe = 0\n","    # Run test data through network\n","    pred_z = model(z0).to(device)\n","\n","    # compute loss\n","    loss = loss_func(pred_z, zN).detach().numpy()\n","    print('Test MSE = ' +str(loss))\n","        \n","    \n","    if args.visualise:\n","        try:\n","            os.makedirs('./figure_data./')\n","        except FileExistsError:\n","            pass\n","        samp_ts = torch.linspace(t0, tN, 30)\n","        if args.data_dimension == 1:\n","            z0 = torch.tensor(np.load('data./vis_data/1d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_1d', pred_z)\n","        elif args.data_dimension == 2:\n","            z0 = torch.tensor(np.load('data./vis_data/2d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            print(pred_z.shape)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_2d', pred_z)\n","        elif args.data_dimension == 3:\n","            z0 = torch.tensor(np.load('data./vis_data/3d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_3d', pred_z)\n","        else:\n","            pass\n","\n","    return rec, outputarr, pred_z"],"execution_count":6,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"VClwZrMj19RU","executionInfo":{"status":"ok","timestamp":1620324162821,"user_tz":360,"elapsed":1894087,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"34c99a16-dd1d-4180-a6c5-27ea00b16be7"},"source":["rec_list = [train()[0] for t in range(100)]"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Model Parameters = 568\n","Iter: 100, running MSE: 0.0008\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3065\n","Iter: 200, running MSE: 0.0051\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1030\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.061154436\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0008\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2755\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0004396746\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0001\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0001\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.07101021\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0857\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.5037\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2623\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.7323882\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1804\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2763\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1388\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2702\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1805\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0303\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0377\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1854\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0499\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0686\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3346\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1615\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1500\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1847\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2871\n","Iter: 200, running MSE: 0.0005\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0229\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1658\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3173\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.22416286\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2768\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0230\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0881\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2351\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1608\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3473\n","Iter: 200, running MSE: 0.0001\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.038506836\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2943\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.017178047\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3447\n","Iter: 200, running MSE: 0.0069\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0383\n","Iter: 200, running MSE: 0.0001\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0616\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0030\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3857\n","Iter: 200, running MSE: 0.0007\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1678\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.6181976\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0632\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0301\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3379\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0313\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1795\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.24286011\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0052\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0003\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3519\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0095\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2514\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.5330818\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0542\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0973\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0853\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0077\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2579\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.00037499896\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0211\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0003\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3195\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2368\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.67675334\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0067\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3176\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.29154244\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0776\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0367\n","Iter: 200, running MSE: 0.0003\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 7.140915e-05\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2174\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.40408507\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.8093\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0028239898\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3527\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3209\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3212\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 2.4812043e-05\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2347\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2060\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0018\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3712\n","Iter: 200, running MSE: 0.3200\n","Iter: 300, running MSE: 0.3200\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0957\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2766\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1958\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.41057768\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1028\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.4478\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1658\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0032\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3111\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.40143877\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1706\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 6.291012e-06\n","torch.Size([30, 240, 2])\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"NTtG4ynGTA-N","colab":{"base_uri":"https://localhost:8080/","height":164},"executionInfo":{"status":"error","timestamp":1620326577149,"user_tz":360,"elapsed":38495,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"e93bacfe-9502-49a8-ad06-e01d49a430f0"},"source":["print(len(rec_list))"],"execution_count":7,"outputs":[{"output_type":"error","ename":"NameError","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)","\u001b[0;32m<ipython-input-7-8bbb3dc628aa>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrec_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m","\u001b[0;31mNameError\u001b[0m: name 'rec_list' is not defined"]}]},{"cell_type":"code","metadata":{"id":"yC2XZ-K6Gt5P","executionInfo":{"status":"aborted","timestamp":1620326577146,"user_tz":360,"elapsed":38042,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["import scipy.io\n","\n","def calc_mean(rec_list, col=2):\n","  m = []\n","  for rec in rec_list:\n","    m.append(np.array(rec.tolist()[1])[:, col])\n","  m = np.array(m)\n","  scipy.io.savemat(f'{modelname}_fnfe.mat', {'data': m})\n","  np.save(f'{modelname}_fnfe.npy', m)\n","  return np.mean(m, axis=0)"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"mFMVHVzSI4Ms","executionInfo":{"status":"aborted","timestamp":1620326577148,"user_tz":360,"elapsed":36817,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["calc_mean(rec_list).shape"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"N-BveXb419Oc","executionInfo":{"status":"ok","timestamp":1620330785421,"user_tz":360,"elapsed":75486,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"ed2f412f-fea7-4e52-95f0-88fd2b56f36a"},"source":["rec, outputarr, pred_z = train()\n","        \n","rec.writecsv('train_{}.csv'.format(modelname))\n","np.save('trajectory_{}'.format(modelname), pred_z)\n","totallist.append(rec.tolist()[1])\n","print(np.array(totallist).shape)\n","np.save('train_{}'.format(modelname), np.array(totallist))\n","outputarr = torch.stack(outputarr, dim=0).numpy()\n","np.save(f'drive/MyDrive/PointCloud/{modelname}_outputarr.npy', outputarr, allow_pickle=True)"],"execution_count":17,"outputs":[{"output_type":"stream","text":["Model Parameters = 568\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","(5, 300, 5)\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"ca3PUVmQ-AKH","colab":{"base_uri":"https://localhost:8080/","height":724},"executionInfo":{"status":"error","timestamp":1620330787445,"user_tz":360,"elapsed":76993,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"6edfc5c1-4b4e-40b3-a91e-051929a07d97"},"source":["import matplotlib.pyplot as plt\n","import matplotlib\n","fsize = 15\n","plt.rc('axes', labelsize=fsize) #fontsize of the x and y labels\n","plt.rc('xtick', labelsize=fsize+5) #fontsize of the x tick labels\n","plt.rc('ytick', labelsize=fsize-5) #fontsize of the y tick labels\n","\n","print(outputarr.shape, type(outputarr))\n","\n","\n","ending_time = 300\n","timespots = np.linspace(0, ending_time, 6, dtype=np.int)\n","timespots[-1] -= 1\n","fig = plt.figure(figsize=(10, 8))\n","gs = fig.add_gridspec(4, 6)\n","axs = [[fig.add_subplot(gs[0, k]) for k in range(6)], [fig.add_subplot(gs[1, :])], [fig.add_subplot(gs[2, :])], [fig.add_subplot(gs[3, :])]]\n","\n","for j in range(6):\n","    for i in range(outputarr.shape[1]):\n","        ts = timespots[j]\n","        col = 'bo' if i < 40 else 'ro'\n","        ax = axs[0][j]\n","        ax.plot(outputarr[ts,i,0], outputarr[ts,i,1], col, alpha=0.4)\n","        ax.set_xticks([])\n","        ax.set_yticks([])\n","\n","f_nfe = calc_mean(rec_list)[:ending_time]\n","f_nfeplot = axs[1][0]\n","f_nfeplot.plot(np.arange(ending_time), f_nfe, linewidth=3)\n","f_nfeplot.set_ylim([10, 42])\n","f_nfeplot.set_yticks([10, 20, 30, 40])\n","f_nfeplot.set_title(f\"{modelname}\".upper(), fontsize=35)\n","f_nfeplot.set_ylabel('Forward', fontsize=25)\n","print(f'Max Forward NFE: {np.max(f_nfe)}')\n","\n","b_nfe = calc_mean(rec_list, 1)[:ending_time] - f_nfe\n","b_nfeplot = axs[2][0]\n","b_nfeplot.plot(np.arange(ending_time), b_nfe, linewidth=3)\n","b_nfeplot.set_ylim([10, 60])\n","b_nfeplot.set_yticks([10, 20, 30, 40, 50, 60])\n","b_nfeplot.set_ylabel('Backward', fontsize=25)\n","print(f'Max Backward NFE: {np.max(b_nfe)}')\n","\n","loss = calc_mean(rec_list, col=4)[:ending_time]\n","lossplot = axs[3][0]\n","lossplot.plot(np.arange(ending_time), loss, linewidth=3)\n","lossplot.set_ylabel('Loss', fontsize=25)\n","lossplot.set_xlabel('Epochs', fontsize=30)\n","lossplot.set_yticks([0.0, 0.5, 1.0, 1.5])\n","lossplot.set_ylim([0, 1.5])\n","print(f'Total NFEs: {np.max(f_nfe) + np.max(b_nfe)}')\n","print(f'Min Loss: {np.min(loss)}')\n","\n","plt.tight_layout()\n","plt.savefig(f'{modelname}_fnfe_pc_plot.pdf', format=\"pdf\", bbox_inches='tight')\n","plt.show()"],"execution_count":18,"outputs":[{"output_type":"stream","text":["(300, 120, 2) <class 'numpy.ndarray'>\n"],"name":"stdout"},{"output_type":"error","ename":"NameError","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)","\u001b[0;32m<ipython-input-18-d18eef8924f4>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     25\u001b[0m         \u001b[0max\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_yticks\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 27\u001b[0;31m \u001b[0mf_nfe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcalc_mean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrec_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mending_time\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     28\u001b[0m \u001b[0mf_nfeplot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0maxs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m \u001b[0mf_nfeplot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mending_time\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mf_nfe\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlinewidth\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m3\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;31mNameError\u001b[0m: name 'calc_mean' is not defined"]},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAmkAAAHbCAYAAACQmw0xAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9fXhc1XnufT/6lmXJki1ZYNnYGAvEl3FAIaQkkARjSGiAtklLISe04bxukxJOek56nfQ9DWlJc9625D1N06Q09MQpzSGhTZo3cb4KFgkJIXaCDcYGY1uyDbZkW5ZtCcnWt7TeP+5Z2VuypJmRZjR7Zu7fdekazZ49W1vPXnvtez3rWc9jzjkIIYQQQohoUZDpExBCCCGEEOcikSaEEEIIEUEk0oQQQgghIohEmhBCCCFEBJFIE0IIIYSIIBJpQgghhBARpCjTJzCZ2tpat2rVqkyfRtayY8eOk865utl+X/afG7J/5pDtM4vsn1lk/8wxV9vPRORE2qpVq7B9+/ZMn8b80doKtLQAHR1AQwOwfj3Q2Djrw5nZ63M5nbyzf4jWVuDxx4Ff/ILvGxuBxYuB0dHEL43snxpaW4GvfY23xunTwJIlwE03AXffPf01kO1Tg++Snn0W2L8fcA64+GLgQx8Cbr55+u/J/qlB9s8smeh7ZiJyIi2vaG0FvvxlKoHiYuCpp4CvfhW45ZagRaRYxImJtLYCf//3wHe+Axw/DpgBy5YBixYBP/85MD4OlJUBJSXA//yfQH09UFcHXHfdzDetSA7fMW7bBpw8CRw5ArzxBgVyQQEfVlu3An/1V8Dq1cD73w/cc4/snyq2bAE2baKde3ooDDo6+OocsGcP8M1vAgsX0v7vfa/sn0rC9u/qAs6eZfsH2Ce98grwrW8B550H/NqvATfcoEdBqoh63yORlklaWijQXn6Zd+nwMFBeDjz5JDAwQPn+9NPcZ/lyoLeXou6++3R3zoFwh3jiBHDmDE0/Ps4b89ChYN+CAj6k+vr42YkTfFBt2wZs3swbd6bRrZgZ30F+5zsctZoB7e209VSMjlIwPPQQ8IUvUCh/9KO6HWaLH6T867+yrZ89y/thciEafz16eoAXXgB27uQ9dN99GqzMhcn27+4GhobO3c/b//Bh/nzve/Suqf+ZPdnS90ikZQLvHXv8cXrQXngBKCpiz9jTA5w6Ra/Z668Db3oTUF3N7/nXlhb1irNkyxbgk5+k7jWjuQcGKNCmqpA2Pg709/PyjI3x5/RpfrZzJ/CxjwHf/rYuR7L4qeWnnqIw6OujODh7dvpOMoxzvE3+6Z8onD/96fSfcy4Rtv+BAxQGJSW8DokwPk6Pw7/8C++f++5L7/nmGlPZv6BgaoE2FWfO8LHx4Q8DP/yh+p9kyLa+RyJtvglPcV5wAfDjH/POHBnh5+PjfH3mGX5+440Tv19VxXkIMSNTzRIDwJ/+KYXZ+DinFYaGKLxmwrng8oQZH+fI6uMf52hMJIa/Bfbt4/Txq68CnZ1s2ol0kmEGBymSi4vTc665yGT7v/QSBcLwMAcuyZRzPniQjv/y8vSdb64xnf0TFWhhDhxQ/5MM2dj3SKSlGq8Odu+m77q6Gli7Nggg8FOc1dXApZdyGOQce8iSEvaSRUWU90NDnOL0HjSA7wsLgUceUZzaNIR1sJ8lfvhhmvbkScaUnTnD0VA8gZYIP/gB8JWvAL//+3M/Vj7gb4HhYTbtRYs4zTA4mJxA8AwPA9/9LgAsqkz1ueYik+3vnfjDwxQLyd4T+/d7kVBWmo7zzTWms3+yIsHzH//BGQIRn2zse5QnLZV4dXDwIIc4b7zBAKeDB7m9tZXCqqqK+9fXU0WMjQUtpLSUaqK4mMPT06cD109PD9DWBhw7RhG3fDlf/bEFgIk6uKCAr11ddE3X1XF6ZmAAWLCAn6eChx/WJUgUfwtUV/M6nHcer8XQEMcfs4Gj2braVJ5nrjKV/UdH2Q3Nxv7Dw17YVVel+lxzkens79zs7D8+zvhAEZ9s7Hsk0lJBays9Ww88QD/q3r2MLl+8mC3g6FH+3tJCz1dvb/Ddm27iUKqsjD+jo7zr1qyhorjvPqCykq2rspLfv+iiiQrEH1sAmKiDPUND/Ln+esaYnT1LDVxczJtzLmJtwQLe8LoEieFvgaYmXovCQjb3srLZTR2YcbwDFJek+lxzkcn2X7WK3UhxcRBtkQwFBfRIaNI5MVJt/5ISeoNEfLKx75FImw1elH3kI8BttwG//dtBFKIZA5WGh7lveTk9YFVVFGvr10/0ji1bRtHlpzqXLAGuuoq93lvewmnMD3+Y0Ykf/jCDoyYrEH9sAeBcHQzQQVlaClx2GXD77bwsfX3sHC+5hJfAX4Yw8UZXxcU8xpIlugSJ4m+B0lLgrW+lB8EM+MAHGF+zenVyormiguMUYGQ4XeecS0y2/4IF9CjceCPTC6xYkbj9Cwo4llyyBJg6clNMZjr7v+tdwIUX8n2iFBXR9suXp+98c4ls7HsUk5YsfkpzbIxTmh0dFGRnzjDgqbycoqm9nUJrYIBP8d5eCrLGRnrHfFT7smXA5z7HJEQnTtDdU1oKLF3KNb6T8QpkcpzasmXzZ4OIs349LxHAS9HbyweJX83Z1ERd/eyzwNvfTqfns89yZvq883gZnAuCqQGKsdJSOjoHB4O/df75FHLr1ukSJEr4FujrAzZsmBhWWV/PzDMtLRzthh/9fpWtjw5YtIjf43XqOjnf/0s2Es/+jzxC+3//++yOpovVKSxkN9XQwFegp3fqPUWYmez/yCOMjvnBD/ioCbf98nI+TsLvq6ooEj70IeCJJ+b/f8k2srHvkUhLhtZW4MEH+RTv7QVqari9ooLxZw0NXJfe0EABd/o0vWUXXcTff+M3uH9j47mB/qtWsWUcPcqn/XSLAaZSIOFjiyl18J/8CT/z21av5g3a1kaT/9Zv0bSPPcbMJz/4AUVaWRn19/g4BVlNDUMCOzv5kKqro0CrrQ1WkIr4THULeNav5zVYtIjVHw4eZGdZW8ttJ0/yfX09b4E1a/iQ2rDhjQQTSIhE7H/bbcBPfsIuxjl6bEpLg5yClZW8t971Lo4nH310cBbrE/OT6ezvu/f3vAf45S+ZZmNggLaur+dkTX8/B5bFxZwF+NjHlCstGbKt75FIS5TWVuCzn+VdMzZGoVZYyOHMokV0sXhZvXAh/c+LFvGpvnp1/BWYM7WcyftNViC/8Rta3TmJ6cw5edvkzq2hIRid/vznvMxjY7wxS0roWSgqoqa+5RZe4pk0tUiecBNftoy32YEDvPWGhhgFoAdT+gjbf+lSPrROnKA4WLKEokzVBtJD2PZlZcA73zmx7a9dq7afTqLY90ikxcOn1Pj61+lCGRvjcKaggE/uoiK6Verr2YstXszhTTqrAiQq6ETS+JFsQwMvYW8vvW0DA7xRz5xh5hR1lOlFTTyzyP6ZQ7bPLFGzv0TaTITjz3yAwOAg5fWCBZzUHhzk8HJ8nGJtwwYNM+eCF8W7djGArKYGuPLKeXNVTTdVqssphBBivpFIm4mWFk5Cb91Kl4pfI21GT5qPJL/gAsalff7z8/s0ny6tfjayZQvwmc8E08kFBRRoxcXAiy8ytfPHPz4v7quojaSEEELkJxJpM7F7NwOTfD6y3t4gHbcZowkvvphLBCsr51+gTU6r/+UvowzInqzfvsLtd7/L/HKDgxTBPlnQwADj+yoqKNg++1kGg0lB5RZTDTZ0jecP2T9zyPaZJQvsL5E2E93dXAiwZAmnOEdGKCBGRhhFuGoV8zlkYnVlOK0+8KvXaiA7sn5v2QL89//OqMyzZyfWovEFBH3E/rFj9FqePMlgsNWrGSgGANddB/zar/H9XG+0LLhhc45pBhtpjekUAbJ/5pDtM0uW2F8ibSaqq7mk7+xZxqDV1lKsjY1xivOqqxJbuZlKvJB4/HGew6WX+pTHQFUVioHoZ/1ubQX+4i+YmMzXQwkTft/fz33eeIMetRdfpIezoYExaz//OT1sV1wB3HprUCYrkRstXGf19deZi2PVKubUSOY4uU488ZqsuPUe1G3bgMOHmdvkxhsDjzXA4+W73T0z2Xc2tg/XFm5vZ7929dWy/1Sko+17+//yl0HK+6amoB+X7QPU90ikzcjatfSk+Zi0ykp2aOXlwBe+MP8XMqz8V6ygSHnuOdY6qq8HensxAkQ/63dLC4tpjo5SBI+OBlljp6KoiN7K8nKKtoICdnKlpRTMw8PAjh0sx7VuHYXzgw8yP134xg3f0MXFwCuv8EF14ACnVktKmPhs61ba1JfbitANO+9s2UIRPDrKfAxDQ2yDN91E7+Xu3bTf2rW091Sj0cl237OHi2wWL+ZxDx9mxY4NG4IERB0dmf2/o4B/oDz5JO3iBw+f/SwfLidOxLe9P44XBgcO0GvQ3k6B0NHBXA/hfkT2J+lo+x0dzNtz4AD775IS9oWnTtH+dXWyvUd9DwCJtJlXE4azOra3s1MsKmIAeyYe3OEpzssuY8daUAC8+ioFy+nT6AGin/W7o4N29JSUzCzSFi3iDXbiBL1pfpXt0BBvNF+QfmSEo9Pt2ymmm5oCj9hNNzGV9OLF3PfrX6fnrLyc2/r7ecxjxxhnuHcvYw0jdsPOKz43YGEhr9Grr9K+ixbRk7tgATvGigrar6rqXG/A5CmFf/934KWXgu+UljKE4MwZ2jw22Mj78g3ebvv20VaHDrGPqq0Fjh/nfe/Tnx85wgU1l1/O74YHFmH7Hz7M9vzCCzxOYyOvZVcXH3Kyf8BMbf/f/o126uiY2f5Ttf3XX+d3Fi7k/TM+zufOihW0f2mpbA+o7wmR3yItnGLj0CF2fKdP8yJ6RR7OLHjDDQlPbaYlvKmjY2KRtuJipkTet4/C4r77MPjXfx39rN8NDbwRjh+n0Jqusq0ZRVRZGac7zSjEfI1Us4n7+xoeJSX8PewR27SJtnv2WY6murp4XO+ZKyriDXvqFLf39ETyhp0XfOPdvBl47TXa4MQJ2rW0lB3m8HAgjM0YLzg8zKmb7m4+iNavnziw6Oxke/WLQ0ZG6MH0v3d30+75XkHDVzbp7KQAcI5e/NJSeg8ADk4AfnbyJD1u73kPr8GRI/wsbP+hIV63qiq29zNn6IWor6dwGB+X/T3e/vv2UUwNDfG1tJQP8/Fx9h++ZtZ09j9x4ty2X17OPmbhwqDtj47y2MePU6zlu+0T6XvKyvh66hTt1tnJ/KR+4JJDfU9+izR/EV96icp8wQJeuKNHGW/W0sKi5kmqq7TFI/q6nUND9KItWMCG6dzEgpJRZ/16xpZ1dtJDOTzMB4f3iJlxBFVczP/tjTd481VX82YaHw9iAz1+6tQ5/vjr6T1ira28AU+c4IOqq4sCzadT8ccwC6Y+I3jDph0/xdDby05yeJj3Q00N7XTqVNDWvL3Gx3mNXniB12zpUl6DL3+Zx6mv5z320ktByYahIdp44UIez1e2r6zM7woa3v6vvBLY29v49Gnayi+sKSjg6/Aw74tvfIMe9osvDjzI3v7f+x6F2fAw7e9LaJw+ze94ZP/A/mfPsp/wIrm/n+22sJCv4+Mz2//JJ1mWZGiIouPMGf4+NsZr6Nv+woXsC5cuze8Y2ET7Hn8/ePuPjNDJMjRE2y9cmFN9T36LNO+Z6ukJgga9F2UOc9OTBfzevRT7r78OPPTQHNqAT4e/bx9HZGbsSK6/nqOMlpZZHnieaWwE3v9+2veNN3gz+mrBa9bw/c6dgXCrqGBnWVgYeBT6+3msgoKJ06UlJbyGNTU8pveIAfz+6CjFW1UVH1A+993YGLeXlQVJie++O3I3bFrZsgV44AG2qZGRwDM5NMRp4NraidPSXih4xscphs1ov95e4Kc/5QPLe3MqK9nxFhXxWM7xWr797fmdNdjHnz32GG3qk2Y7xzbb3s79/DSn9yT7gUpREfd77TX2B0ND7Cd27QrafX092/bICLcND/PvNDXxfT4LhKnsX1BAOwLBQNEsGJz4NgxMbf+zZ4F//udg8F9fz7bvHO8NXwj1He+Q/ZPpe8z4ux+sAEE/cugQcO+9OdX35LdI856p6mreRAsW8Ob0OdFmOdXltV9nZ+DwKi+no+Hee+dQlMCnw3/gATbQmhoGE9fX8wGZLfFTra2MD7vxRuC976Wtn36aRhsc5KjnvPO476lTHGEuX05RVVsbdHKjoxzBeoFVX89to6OMXejvD7wFjY3c14+kqqqC8l7edV5TA9xxR35WjPAxIH760gtkL8TCtvbbvUfTCwcv2PyAZ9cueg980ue+PtrdJyn2nfEVV0S6k0w74fiz4mK2S5+Cxg8i/ECisJDf8fb33jSAv1dVBSEQCxYEouLMGbbzJUuCKf2iIvaB871CPWpMZ3/v0R8bC358AV/vsZ/J/kuXsk8uKWFfVFTEtl9UxGPJ/iTZvgdg2/dhMn57aWnweQ71Pfkt0rxnatkyxnoMDvKCr14966mu1laGevgFodXVHITt3s32U1YG/Oxn/FNJD5z8fD3Axhdetp1N8VNT5Xhbu5Y31k03Maajt5c3Vn09P6+rY6dWWcn9qquB3/xN3ohbt9KgXoxddhmDpMNlulpa2Hn6FT6VlUy3ceIEb9Z16/K7IGdLC+1QU0PbLVjADtIH1nrPQVUVO8xwTBQQPIBWruR39u7lA27hQuDCC3ktfCm1yy/ng+sd7+A1y2cPAjAxbqyqit5fH1TuUwAVFtLGXqSNjgYiuayM16q8nIOYQ4eCMIiyMtq/rY1tffly4M1v5qD0zW+W7YGZ7e+fCWH7j45y2+hoMMibzv41NTzmyAjb/hVXsC/r7JT9Pcn2Pd577JOeFxXR7nV1PE6O9T35LdLChRrPnmUDWLx41iOb1lbg4YcZR3roENtEeXkQ575sGdveoUPAm96UZHaH8CKHwkKmnHjlFeDd7+ZoLJvipyYvgAC4uqy/nz/t7bypLruMHWdbGzvLhgYabtkypiAYHeW12rhxYoqNo0cpziZfwy9/ma7t5mYq5T17+Dfe9jZeqKefzt+KBh0d9F4WFQVxgkVFtHtZGTu84uKJI9PwytrKSr6WlbEzPXaMneGFF3L7xRfTru3t3NdPP0QwBmTe8fdDTU0wtekfRIsXB1NjfvqzrIz299fIXxuAn509ywfYwEBg/6uv5nGXL2fsRb7HP4WZyf6VlbRlRUXg3fHCeXQ0vv2bmoL2395Ou8v+E0m27/G2933PokXB4rJLL825vie/RRqQ0kKNjz8O7N/PfvWKKzi92dXFtrRmDXXA8DCfYe3tbFcJ09LCjmP3bnYYV11Fz9B3v8s51Gy64cPTzJ7eXhqts5OC7eBBetRWrOAUzf79HFUBwIc+NLXHa6ZrGRbkfX0ceU0Vc5YvedEmLz8uLg7E/urVtP+ZM+zsFi9mw734Ytrt5EkK597eIJ3AFVewoz1yhA87gA++qirmITpzhgK8rIwPrkylsYkCU9m+t5d2OXWK9m9tDaY0GxoC+5eW0sYnT/JBVVjI/qCxMbD/kiX8O9dfz9enngpW3C5ezM5I9k/M/lVVwaKlpiY+4I8coc1PnOBnM9n/5EnGWw0P8xjLlrFPy6b+OtWkou/x08cLFtDuJSUUxStXsq3nUN8jkZYCfJv76lf5vFq0iO3jmmuY8SEcpzs8TA1y4gQzeiRMRwd/Kiqo9srLOUXnR2VZ1Oh+Nc0M0FC9vbxB3/QmGrG+nm7pI0cYn1ZURA/X7/1eEL82G49XWMT92Z+d682LYCLDtDDV8uOODo4mrrySv/sVm+vWBatlBwc5FVRby+lp73H23stly1jqK5yjyAu54eEgKeXkChP5xEy2v+gi4K1v5aKZgQF6i/1DJ2z/yy6jraezP8C/UVrK4wwN8ceHQ8j+ydn/9dfZfsfG2Pbf9jbatrJyZvv39nLqzYuL4mKGamSZSEgp6ex7wknLc6jvyR+Rlqa6jOE2V1bGttDWxsFqZSXbxcmTbC9VVWxb3ku+fn0Sf6ihgSWQzj8/2DYwwD9w9Oic/495JezV6ujgDfYbv8H39fWcE66ooFB75ZVA2aaydMd03rxsieubLT4H1IkTHIH6B8ixYxT+115LW7/97ed2eosXTxTV/vOproO/xg8+yAfaunVBDGVPT/54LCfz+OMMKvdpZwBO35SXs+2Njp47VT8b+/v765ln2Nbf+94gflX2T439/XTZdPZ/8EEeb8UKev59229ry8/YV/U9syI/RFoaC6mGY+BXr+b9X1JC3XTBBfSq1dZygNbRwdm8WRUtWL8e+Pa3OaquqaFA6+9no85GYTHVDfbYY7yhtm7le59sdnSUN5knFR6v6bx52RLXNxv8fdDZyU7y5Enaes0avu/sZLuafF9MJ6rjNeDGRrZPXxvPky8ey8m0tnL6pb6ervW9e+lBaGyk3aeyPTA7+/v7y8dbyf7zb3+1/QD1PbMmP0TaVKsJ/fY4FztebePNm4NsGKtXU6j39QXT4uvWAe97HwdPZWUTBwlJc8klTEpZXMzGfeWV7GyScslFmIYGGu/669mB9vTQaEuXBl4AIDUer9ne/NmKH8UeOsSR6/79Qcbtffs4DXDeedPXK51t7Ga+eizD+E7ka1/j1Nnhw7S9r6jR1sbYiJlqxcr+sydT9pftifqeOZEfIm2q1YQJKOrJDrgDB4D776dA96XbysqCJPX79nER1eHDDAEJe83n5N32J7J8ORcJ7NzJkUdFRW7l9PLercWLqWZ7e2l054IEw6n0eKVw0Uik8e3ntdeCxL6nTvG1qIjC+MABxjqleqSZjx7LMOFV2UePclDV1cXPfHUNv5AlHaN82T9z9s932wPqe1JAQfxdcgCvqMMkoKjD6XO+/33gW99iGzp8mDpp/35OafrqQuXl/OySS4C/+7tZVZQ6Fz8Kef55BtEXFDDtxp13Uinmksjw3q2BAboof/xjxuC9//0M8Ovo4Gs+r4yaDb4h+7xOZrSjz0Xkp3x88GQqR5r+mubr9fO2P3qU/7svMeSToI6Oso2nw/aA7J9J++e77QH1PSkgPzxpCSrqyVObu3bRC7t1KxdRVlVxkcm2bYw7KyhgKo1LLw0W/wApbAeT5/EHBljC4Prrmbgvy+bWE2ZggMkG/bV6+umsvLkig/ckL1jAIOmBAY5igSAhZHFx+go854vHcirCpedWrGCHUVQUPKSGh3lvp7O4tuyfOfvns+0B9T0pIHdF2mTFddNNjD2YJv5oqrUFBw9yu0+VY0ZtV1AQVFkZHKSnraCAIWKrV6ewTfhRyPnn8w8tWMDte/dy1UqWza0nxBziB8U0eE/y8uUcXZw6xZFrQQFzxhQVMf/eFVdIDKeayaXnFi5kXA7Ae7ikhB2NbJ8eZP/Mor5nzuSeSGtt5TJrv4pn3TrOe8fxxkxXqejf/52HKCsLHFclJYGntriYiwTq6uh527hx4qnMKeuHH4U0NdGDBvBE0jnqzgRhQ+3YAVx33cRgzyxckRMp1qxhbbyeHnaQ/f1BsXqA8/RLl7JMjTrJ1LJ+PW3f2cnB1alT7Diqqvh5RYVsn05k/8yivmfO5EZMWmsr8MgjwEc+wsj+n/0syLe1dStdXX7lyDR0dAT3reeii6iFfD69kREmkx4ZCarf1NZSpC1axP0np9bp66PO6uvj+9bWJP4vPwqpr+cU5/AwRczx40mWK4gwkw1VVsZYtM7OYJ8sXJETGXwxe58A0hfqrqlho66pCWqj+vl6kVp8HFRZGR9QxcX8ke3nB9k/M6jvSQnZ70kLz1P29PAmbGvjapFFi7jP3r1cLTiDN2a61brvehe95IsX0zv72mtsT4sXU5AVFQV5ENvbmci+oYEaY86zdn4UeOIE51mPHWPDfs97+EdTlOsto4STS1ZXcyVGdzdrat1yS9auyIkMYRdxYyPtuWgRvQmXX859nKPwlxBOPS0t9CY0N7ON19QEoQuNjbJ9upH9M4f6npSQ/SIt3BB6engTVlWxpJAvvNrTE9cbM93agvvuC/7MypWsVlFdTb108CB/v+QSzq4uXUod+MYbFGnXXMOZO5/ia1azdr6MhS8r4lcs5EKsVji5pI8Z2bePI6/W1rnnL0tTlYmsYnL6mepqepYPHeLUQ3k5RXHSJTBCyM7TE7Z/dTWFgu8knJu77YFz7b9mTRB/m+/XQ/bPHJnoe3LQ9tk/3dnRwYf7T37C/Bd79lCo9fWxIQwMUNj4UhLTMNNq3cZGptP44z+mg27pUk6DFhZywcqBA0G+tFOn6Gnzefqeey6YuUtq1s6n3mhr46ivtpbBcXV19AwCVH3ZVhIqTLgMlBn/zwULKLBvvx349Kdnn8ckJfPNOcDk9DNNTVwOf+GFDJw+fpwNdrb1BKey88MPA3/xF3QrP/JI/tk8TNj+TU3sNGpr2cHM1fbAufY/eBD45Cf5ms/t3iP7Z4757nty1PbZ7UlrbQVefJGrQ5YsoXpqb+coyQeTnTjBrLJ33z1tQ5gsxm+4gdrosccmivGw59zT08P9LrmE3+ntZbsrKAhWgu7ZwzaZ8Kydb3y+xtngIE/uxIlA0DQ1Zf8Kz46Oc8tAAfw/51pFQatEyfr1FE1dXRzFlpbyPrn8cnaYN9wwt9FmOJngs88yeeDrrzMg+61v5fZcmJafLZPtPzrKEdy113JF21xH+pPt/8tfcun5qVP8G01NM2fSz3Xmw/5jY8xh2d3NAebAAPDDHwJXXZXf9p/vvidH2372ijQvZHyh3M7OYIpzfJwCbXKh3BkOE64q8NhjDGG76KKJZT6nKlwwMEBN0d/PtujjU4eGeAo+l9oNNyQxa+cbn8+NNjbGRt3by0ZeVMSAzEsu4SgkW5mqDFRJCa/bXG+qWVaZyEnMJr6vqZlx0JIUHR2chm9p4ZT84cNs9CMjfH/6NHPTZHlHOSfC9q+sZMfysY+lx/4dHewfBgfZIZ06RbHc1zf3v5WtpNP+u3cHVVGOHeNI3XvrBgc5lZLP9p/PvidH2372ijQvZIaHeWHGxvg6NASsWsUHw4c/nPBhvKPl6NEgQXVj40QHzOTFBZ2dXIi4eDEHUT5/GsDTKimhCLz66iQHDF5gFBbSy2p0CtIAACAASURBVNTby8ZYVkYBumgRG/v552f3g2+qMlCnT/Mmnis5UrdtzrS08KF0zTXBtp6e1ImmhgaW4mhv53FHR9kxj49zOsMX+c6V1cjJMt/29wlaCwsD++/cyYFPPpJu+3d3cyB97BiFgnMcoJw6xXuhoiJ/7a+2nxKyNybN58zo7+cDYNkyRvb7hQOnTyd0mN27eR2//W2GtbW3B2sQPD70a/16Hta3h5/+lNsXLQpE2fg4hdroKAdtIyPUWwlPjfsp3L/8S+Cb3+SoAOCB+vo413rPPVz5mO3LltNZtmPyxerpiRuXmJNMlVsmlbGM69dzJW5HB0Xw6Ch/AI5iysr4mm/i2DPf9h8ZCab0jh/na2dn/rV7T7rtX10dTPF7+4+N8fXgwfy2v9p+SsheT5r3lPhyE8PD3F5UxItTUxP3EK2t9FQXFgYrs/1gaMWKYD/vgPGaoqUl8HJfdBFnIPv6qAFqa6kHliyh5li+nN9LaADR2so5/JMn+QWz4IFXVkaP06uvAm97W+54hdJVtiN8sea6SjSbSbdH8bXX2Pj9ahkg8KQNDqZm9Vw2M9/2N2MHZkYPD5Ca8IFsJd32Lyqi18y5ifb33pw1a/LX/mr7KSF7RVp4qqy4mDdKby+XXzY1MXleHFpamO1h927qou5uXnPvKR0fPzdNl9cUjzzCAYEZfy6+mPqppIT51C65hE6+a6/l9xIKh2pp4Vx6VVVw04+N8YYvKKDrvLs78Aopd9jM5EDdtlnjV8Ps2sUR/dq1bJg7d3J0ecst3Geu9vnc54LFLGZB/OTwMAOF57p6LlvJpP3Hx3kN6uvZEd1zT2r+p2whvBKsqIhTkRddxAd3qu3/8svsq4uK2PkPDweDlcWL89v+avspIXtFmveU+BJQq1ZxpWB5ecLTWh0dvHeHh4EtW3h96+vpNW1v5zPmyisnOmB8+3v8cQ4Q3niDWTEWLuRs64EDHEA4x3h4nyMtoQFER0dQ28zPnfog7IoKNr7SUrro8tErNBPK1RUQXg1z1VVsnFu3ctSwciU7ydkmQw53wD09XFXlvdcen9vv+uvZkebbdYiC/cfHOWDNt1W1UxVhdo4d+vbt7JBTaf8dO9hXe4FQUsJ+emiIXrR8tr/afkrILpE21YP4z/+carmlha6tJASM98aePEnn24IFHGyVlbF9VVZOXHsQbn8rVlCg9fdz+8AAddRttwEPPMD9Skun9sZNS1ERVZ4PcPMLBgoLedOfdx5zh91885zMmHNM1THnc9qHyathGhu56gwA3v3uc/dN1EbezmNj9CCcPs2GX1zMbT5Z4Pg422w+CjRA9s8kU6XeWbOGcb533jlx6s3vn6z9u7ooPIaHOaVfWsrPi4tp/6Ii2V9tP2Vkj0iL9yCexQXxM6bHj3OAdeIEvbNm9MzW1k50yITb32WX0YHX3c3ZybVr2W58aFzS4VCtrXTLey9EYSFvfr9apaJCAm06lBNtIlOlHxkaOne/ZFOS+BJeL7/MEUptbVCeo6iIbdd7En791/PT9oDsn0mmS71z5Ahw443nbk/U/j65+KFDQR7AxYvZ6ff20mNUUMC+WvafuE1tf05kj0hLw4PYz5i+/jrvva4uXuOaGmqjY8dYOtOH1ITbn69k1NvLdQvl5cBNN1FXtbTMIlG+X67c1MTst319VIsrVjD7/urVuSHQ0jEtqZxoE2looEf26FFOC/hyOJWVE/dLJoi3tRX4znc4ej18mNsGBthZjoywrY6MMJv4JZfwgZavyP6ZYyrbL1vGfnS2QeytrXwQbNsWeHDOnKE48JnuAQqFZctkf7X9lJI9Is3PQ/sbramJwWBzfBA3NgIPPQTcfz8PHW5Lq1bRu+Z14OTFKuPj1FXl5cEgbXx8lqfkE/ONjFBgnH9+UFuutzc3Vsela1pSOdEmsmYNMzL7QU13N0cgS5bwHgoXp403B+9F9aZNTDg8OsrpBT+1cOIEr2V5OR9cf/iH+R0PCKTO/t72u3czaPbw4SBRd2EhH36y/0Smsv2BA8Af/AE9MUDy9t+0iWk2+vuDVYS+CsyKFRQHw8McSN9+u+yvvielZIdIa23laMXnyhgYYCbnK69MaBVnPBobeZj29iBG/4IL6MHu7g7Sukwuwu5Lgt50U3CspOtz+kDI55/nooHqat74Z84E1dyzPWmtJ5Xe0LBHrriYr2vWJNcJ5CptbUwO7EezNTUsxbJwYZCTLpE5+HAcSFsbbw5fRmNsjL/7ih/V1TxeAgmkc55U2D9s+127+B1fb86vYCss5DWR/QOms/3gYHIxKJPbfn9/sIrQB6f7FDONjRQKn/98bvTTc0F9T8rJDpEWzpUxOMgbYnCQndfGjSn5E2vXMjbN1/kGqAXD5TEnp9666ipOifb2Mv3G8ePUCwlVago3wkOH+EdbW4NFAitWsIG/9a1BrrRsJ1XTklN55MzYkfb15W9ONI9fthz+/72LN5mOzIvql14KRIFf6u7Fgj/2JZekplJELpAK+4dtf/Ysbe9/fP5Ev5pQ9g+YyfbJxC5Pbvs+3mxsLBAJXjSUl+dnmpmpUN+TcrJDpPkLX1UV1HisrqaISdGNsX49FwDt389778yZID60szNI6zL5Pt+yheEKPjXL8uUsq7lqVZxTCzfCBQs4v97VFcQ6nD5N17lPuZELpGpa0geRDg8HU98XXXTuctx8JVV29l7KnTuDqYbCQrbP4uJgSfPVV+shFSYV9vcDmiNHOPpzLhAHlZVBJZKlS2X/MKls+97+3vY+JZJPA1BRwaLMDz0k23vU96Sc7BBp/sLX1weJx3p64oqXZGLUGxuBP/kTPv9//GPemxddxOT+M6V1aWvjdGe4TSZUXcB3Al5wApyu27MHuPRSetNKS3Nr2m7yfPFspiVbW7ms1q/c8FPfOVBIN2HiNWxv564u7pOUizdEURFr4x09GpS7GR8PEncuXMipjHx7SCVi/89+ljEzg4NMD7B0aXL2b2hgCMSrr/I+GR8P4tF86oHqai4m+pM/kf39/5+qth+2/9BQUIKvoEBtX33PvJIdIm0WD/fZxKg3NjLl2r59bAtLlwZT3sDUwmvWM3jhEcfAAEdnJSXM7eHJtaS1cy3V5JfBnzpFm11wQSDUc6CQbkIk0rAbGzlySNbFOzlT+7e+FdwMJSV8WHlvQmEhA6Y/9ancaZ+JkGjH4lPpmE18P9Nxw7Y/cIAFhX3BerMgu7pz7GTuuAP46Edl/8mpmFLR9sP2LywM4tAAbrv4YrV99T3zQnaItFk83OPFqE81IADY5jo7mTf25Eng61/nTOTy5VOXA521d9cLz2XLgli7sTEGxxUW5l4i1skG/+AHk/v/vvIV4G/+hkGA5eWM0zl7lvEIxcX0WuTCCth4TNWwu7ooXi+6KGjMybp4wx1wcTHdyW1tQYDm0BB/9w+t//JfGAeSS200ERKxf2cnveLNzcH3krX90aNBObiREW73D6n6euCHP8w/2wOJ23+ubX+y/cvLJ9r/iSfyz/7qezJCQaZPIGnijUhjdHRwsBmmqor3nm8TfX0UX319fP+1r7GdnH8+BVp7O9vEwADbWFsbvxtm/Xo69Xp6eA/7sppx9YIXnqtX82fRInbsq1fnpkB7+GFOU77wAl8ffvhcY07Hli10a4+P007j4xRoftGFczlRSDchJjfszk4uoPHL0X1j3rVr+htgKsId8P79/N17baqruYR+yRKK4vr6vBnFnkMi9n/qqaDAsydZ2xcUBB4zb/srruCgbpbJu3MC2T9zqO/JCNkh0qZTVTM85L2HK4z3cPk2MTTE8l/PPEPP6tNPsy01NbE9mnEA1ddHXbB2Lb8bxmstv7q4sjKOxmptZXX2P/szHmz9euAf/oEuuy9+cRZZcLOAz3+eRn71Varf/n7ejI8/ntj3N22iWq6upkjzcSEjI0Eh3Rxe3TOByQ17717a5rzzgrn5xYuDnIJhZnLxhjvgnh42/EWLuDjDr24bGOAxmprS879lA4nYv76e0+9hkrV9ZSWneoaHg3QDZ8/y97e8JT3/WzYg+2cO9T0ZITtEWlhphxvDZMUUYiYPV0dHEG8+OMhpzDNnGLP/z//MtldRwbbiE9xefz09ulMNBhobqa0+/ek4GmsWYjPraW0Fvv99iqpFi4Lq9cXFwI9+FAjWRx451w5e0P7sZ/xeXx8vSl0dg7F7exk4mGuex5kIN+xjx1g0et8+2qKzk/tUVQUlaxJ18YY7YB8neeGFQfHowUHee5WVwMc+Nj//axRJxP7r1tG7MBfb19Twx0+zjY1xVLluHQNn8xVv/9ZWTos99xzw2muMSfHI/ulBfU9GyA6RNtPc5TTM5OFqaOBAywsxn27Dl3nq7ua28nLGOt5+Owdns05i78XGAw+wUQ8NJSw2s56WFgqy4mK+Lynhz5EjFGvTCdawoPUjtRMnAqFWVsZ56TxY3TMB37D7+4Enn6QdVq+mfZ97jp1lby+nZpJx8YY74Isv5u/FxWz8dXW8ZldfzYDgXChPNlsSsX95Oaff52L74WHgttv4nbIybr/nHuAzn8mv9j4ZH5jup9lqa/mzb18gFGT/9KC+JyNkx8KBoiI2inBerHCW2WmYLnRg/Xrgq1+l8HKO1VbMmPmit5cDKF/N4td/ne3EDwaSyobR2sopPZ8yor+fDfu55+iaq6/P/RqTvhJAayuN7MXaiRM0+Esv0dg1NcFcNMBg1M5OCrHLLuO8dGUlpxyGhznCevDB/OwwGxvZdu68k4L/ueeCufkXXuD0r19Yk4x9ysvpnQBYzaO2ltMNb31rTpZbmTWJ2D8Z764XHps2cfCyaFGQF/I3f1O2n0w4ML2zk/YvKOBUiE9blKx3fbq2L/tPRH3PvBN9kdbaStdqdze9Tv39DB67+GLmB5oFjY0caL30UpDKZeFC9o8rVrAO59vfzsHa6tWzyxbxK0/Qvn1s1AUFjMcqLeUf27t3ju65CBNeyXngAD1hvb10T549y31KS4MaeDU1VMQvvkgB9vnP02N2/vkU6AUFvCB79rBTfvObgQ99KC9HVb/C534pKKDg37uX9wiQ/AMqvLrqjjuCFDd5tIIqaVJt/6efBt70JnY+3v7JroDOF8J5j+rraf9XX2UHfsMNyaf1UdtPDvU980r0RVpLC0eVy5cH1QZqajhnOYeLeM89nC3t7uZ9PjJC/dfTQx1QWkpBP+sE9j6Oznv/zHjOHR0cbXR3z9I9F3EmL6c+eZLiauVK2sEnJ1y4MCip0tdHu/T30x7nn89R1BtvcFtDA9+///2qKuDxcRxDQ0EnWVrKmJlk74tU1lTNFxoaOADxnYivUbh6teyfbqZr++vXJ983yPbJo7Y/r0Q/Js3Ho9XXc5R5xx3ALbfMuZ6lj02rqQnaxapV9LK+8EKCaTQSOW8fCAlw3rSuLqj7FncpaBYSXjq7dSv/x8suo0H376er8t57uaT6yBF60I4do2AbGqJdhoZ4fTs7KXK7u+nunPNFySHWr2dH+fTTQZHZ7m62u0QXovhYyccfpxfTx/QAcWM+8541azgF393Ne7y7m+/XrEn8GLL/7EhF2we47+bNXHn+k59MDH6X7adHbX9eib4nLVW1wKZgZIR6r6CAbWQuXlsA507zDQ0xfu6554J9amqSj1nJJnzNte99jx4yL7CLiliRvqaGBveFivfupTDzU8JmFGYLF3J69MwZetPWrMldm82GxkZ6HE+cYDurrmZwbWlpYqNQX3R2ZIRTzh0dbPw+VjIXp+FTSVsbp+CPHg28+5dfzu2JTMPL/rNnrm0fCOz/2mv05o+NBbHCCcQ75zVq+/NKtEVaayvVkw+8X7eON1SKpgjD+s+XBfUlQWcl0ML1+kZHGSdx880Mfty5k59t2JDb8+1FRQwA9QJtZIQetPFxGrq9nWWdFi8OFgGUlARV7c24fXSUQq20lOIt31ZxJsLoaDDK8IyPx1+I4ttqYSFdx0VF7GCXL58YfJ1L0/CppqODYRjhNpmI7QHZPxXMtu0DE+1/8cWMGz50iCEZ4eB3MTVq+/NKdKc7fWzTggW8GYEgk3SKPCqzrhYwFV/7Gm/2ggIKkKoqio89e9ihbNjAJGy5ni3Z1yosL6dA85mjy8po4P5+XtO6Oo7ARkYo2l59lfYqL6cnzlcUKCzkKDmXbTZbZsrYPBMtLWyTNTW8PkuX0lPZ308RnYvT8KlmtrYHZP9UkCr7L1rEVeYVFfQMDQ3J9vFQ259XoivSwrFN+/fT47J0KR/4KbqASVcLmIlt23i+5eXBkuTly3m+cbPc5hAjI8A73xkU4HWOo9WFC2nkkycpZnfsYO6TpiYWSl+yhKOqoiLuW1/PVaG33Qa87W2Z/q+iyWxHGR0dvJfCpXPq6vjAuvvu/Gmrc2EuIzzZf+6k0v4+bva884D3vle2j4fa/rwS3elOH9vU0sKpM19c9bXXuDQzhUItZW1icl1Rv0Agn2ho4PV673uBa69lzNnx4xSwK1fSYzY4yJFTURE9bH19FGXV1bzuTU3c3tnJa67FAlPjRxk+DjLRPDENDRz87N7N9+XljAkpKpKtE2W2tgdk/1Qg+2cO2X5eia4nraGBK0Y6O+mZWrAgKKydaM3H+eQtb2Fj6++nMOvv5/t8q/MWHmXV1XGxwJvfTMF29dXA+97Hkh8VFRw9HT5MIVZTwxFWXR1v3M7O/Cv5NBXhWq9Tlc5qbOR0QVsb74sHH2Rg7kysX0+bX3klY0COH+fU8sc/nt+2nkw6bA/I/oki+2eWmezf2BjYcfNmVtP5i7+Iv7pWtk+a6Iq09euBgweDMkKjoxRpK1cCv/hFps/uXO65h9N6zlGc+Wm+fKvzNt0c8sgIXdx791LA+oK5IyNcXFFQQLstWxYIu3xfLJBIrdctW9jB7d5N++3ezfczPaz8NVq9mg+5970P+MIX8js58GQStf0nP8l2PjgIPP88sHEj8JWvzHxs2T8+6Wr7gOyfCPHs39oKPPww8MMfMpbv4EEK5U9+cmahJtsnTXSnOxsbg7gmH2y+YgVV+OBgps9uahoamPsLoNBI4bRsVjHVHHJxMVd9lpQEBXO7u7mUvqmJn+/aRY9aZWWS5R1ylMcfZ/xeuBxauNZrSwtXSr3xBqeLFy7kvm+8AXzuczN3fCmd589BZrJ9YyMfRH/6p/T4jo7ysyVL6EH+m79hHOVM9pX9ZyadbR+Q/eMRz/4PPsg8mP39nP2oruYs1wsvcBHdpz41/bFl+6SIrkgDWJ/txz9m51dWxof7qVMMTI8S05W2EAEnT9JO3d0U2gsWBO7u3btZlHfjRt28ntbWIPWMT4j83HNM5/L66/xZvJgPpeLiIK6jrIwri/fty/R/kL3MZPu+vuB+P3WKgw0/4Cgq4hR+V5cyps8Ftf3Mkoj9fY66oqLA/hUVnBmJ4kxXFhNtkXb33Qw0f/VV5tBauJDLpe++OzPnE05W29AQFH5VaYuZaW0FfvYz3uzFxZy27u+nnerqKNBU6mkiLS0TE/wuWMDtO3fyYeTLbBUX8/OiIg4Oysro2Sktzez5ZzMz2X7DhuB+r63lQqaKCrbp3l72UbW1ypg+F9T2M0si9j/vPODll3kNCgpo/8JCxhPn22K5NBNtkQZwZLR6NVV7aSnfZwKfJXl0lAHtQ0McTd9338SCv+HzTiS5Xz7Q0sKHmPc0ALSj/9ED7Vw6Opi8eetWem+6u/k6MsKphxdfZMdYWcmyWpWVQQHa3l7gzjsz/R9kLzPZ/iMfAb71LU5rmtHe4+NBhQwzLpJRxvTZM5P9r72Wg72XXmLoRFcXRXJRkdp+qvD2b2lhmx4ZoX3Ngr7n6NFgIV9FBZ+HxcUMV8m3xXJpJtoiraWFwYXNzcG2np7581C1tnJ+vaWF3rzqaubT8UuIr7ySn6WxdFVO0NFB23gXeWkpR1sjI7yxZadz8alMLrmEA4TxcY5iFy9mguQVK/hz4YVsa8PD/F5BAaclPvrRzJ5/NjOd7VesAL7xDdq/qop90OhokMdx8WKGYtTVKZ3AXJjJ/keOMEi9oYFxvzt2cNqzqEhtP1U0NNDGYUZHKYqPHGHbX76cqzJffplCzXvYLrww/xbLpZloi7RMeahaWxk4+Z3vsAEWFnJ7Xx/F2mWX0QXc3s7G+cEP0qvmz8/HpKm0BSkuprj20xLDw7RbdTXtpQfauaxfzzZ1+DAfVgUFbIvFxbTjqVMUA7W1XEXc1QW8612cOvbT8GJ2TGf7669nYHR5OYXD4CDDLxYulP1TyUz2/+lPOdhbvpze48sv55Tz+ecDd90l26eC9euB+++nfS+4gO3cV4ABgra/ciWvjdp+Wom2SPMeqqGhoPp5aSldsenCBwXv2MHGNzxM93p5ebCy9PhxeviOHwduuGFuyf1yndZW2qSsjDYsLQ0qEZx3nvLjTIdvU/fdR0FmFnjNli9n5+hLbS1fTq/uF7+Y6bPODbztH3iAU2h+dfnevbwWCxfSY7N3r+yfDmay/9AQBZlv+3V1FG+jo4prTRWNjazNefgwp5UB9j39/Wr7GSDaIm39esaB7dvHqYTSUgq1jg4+/NPxcG9p4Yjh4EFOxy1YwI7Bz72PjfH3yVmStax4avyU9YoVwC9/yULGhYXc9rnPyWbxKC/niLWmhgOEri4K3BUrgBtv5D49PRz1itTR2Ahcdx1Xl19wQbC6/NgxYNUqBlbX13Nf2T/1xLO/b/uA7J8O6us5rX/JJWr7GSbaIq2xkaMmH8tUXc2s9aWl6YtL6+jgT1UV/+bYGEcPPT38vKiI4k1ZkhPDT1kXFLBUFEB3eUeHbBePlhZg7VrGP3pvbm0t40Le8pZgRaGm1tODX6UWfq2p4bXo6VFoQ7qR/TOHbB8ZoivSfLqLlhZ6Da6+OlDv/iE/XUqMudDQAPz850GW5b4+CoyKCrrUGxq4eujuuyUyEkGLKmZPRwenHaqqgumFhga2zdWrNbWebkZHuRBg/37avroauO02JrD1FTVk//Qh+2cO2T4yRFOkhZPDXnABG8lzzzH2AGDw7qlTnD5bu5YPst7eICUGEF+8TSfw1q8Hvv1tesouvZR14bq62DAvu0xTdMnig4ABjb6SxQvcqaYXFH+Tfvwqw8lTa1deKfvPB7J/5pDtI0M0a3eGk8Neeik9ZwUFwLZtwNNPMx6sqoqxTbt3U0RVV/M7X/ta/JpvM9Ula2zkNObYGAMl160Dfv/3gd/5HQm0eExVkHe6Wp6yY3zCxerHx/l6+rRWw84Xsn9mkf0zh2wfGaLpSQun3qivpwft1VdZbmLtWk59trRQRPX10at2++1c6fPMM8A73sF4smefZeMqKWFKjT//cx4zXoWAm29mgGRLC5P2LVumpcXT4T2Su3cDBw5M7dnUoorZoVXDmUX2zyyyf+aQ7SNDNEXa5Dim+vpgZectt9Bz1tHBVZZm3P7UU1wN5ByDG7du5crM6mqKuaeeCgqeJ5J/TcIiPuFp6Z6ewLNZVRVMz6k01txQO8wssn9mkf0zh2wfCaIp0qaLY7ruOv7+y18ysHF8nMKguJgC60c/4krMf/gHfre+nvldior4uxcMCmaPTyKLMsIeyZ6eYPXP3r20t0pjzY50LIgRiSP7ZxbZP3PI9pEjmjFp08Ux3X03xdr+/RQGtbX0nC1YQE/b0aPM5zIywhi2zk5g1y6m8Fi3LqgRqfn2mZkpZi+MT1UCBHm8ysuDdCUSvsnja8LGs71ID4m2fZEeZP/Mob4nkkTTkwZM72q97z7gu9+lx6a6mklRKytZQ2x8nOp/YIBToCMj/KmupnjwSfc03z4z8WL2PGGPZFMTV+AODLCIuhe+WsWZHL29idlepIdE275ID7J/5lDfE0miK9Kmo7ER+O3fZibqJUuYDdmLsspKirFVq7g6s6SEZZ36+88VDJpvn55Ea6aGp6Xr6rg8e9cuetUqKyV8Z8PwcOCd9GjaeP7IVL1gQWT/zKG+J5Jkn0gDOO159CinMX09zxUrAsFWVcUVhkeOMHZt6VKlfUiGRGP2JnskV68GNm6UnedCSYniJTOJ4lUzi+yfOdT3RJLsFGk+l1k4RcaaNcA3vsF4Nee4WGDRIuDaa1W+KVmSSUArj2Rqqaqirf3vSv47vyj5cmaR/TOH+p5Ikp0iDZhaHKxaxXxov/gFU3O8850q3zQbFLOXOUpLZftMorafWWT/zKG+J5KY8wVUI4KZdQF4PdPnkcWsdM7VzfbLsv+ckf0zh2yfWWT/zCL7Z4452X4mIifShBBCCCFEVPOkCSGEEELkORJpQgghhBARRCJNCCGEECKCSKQJIYQQQkQQiTQhhBBCiAgikSaEEEIIEUEk0oQQQgghIohEmhBCCCFEBJFIE0IIIYSIIBJpQgghhBARRCJNCCGEECKCSKQJIYQQQkQQiTQhhBBCiAgikSaEEEIIEUHiijQz22RmJ8zs5Wk+NzP7vJm1mdkuM7s69Nm9ZtYa+7k3lScuhBBCCJHLJOJJ+2cAt87w+bsBNMZ+NgJ4BADMbDGATwF4C4BrAXzKzGrmcrJCCCGEEPlCXJHmnPspgNMz7HIHgH9xZBuAajM7H8AtALY4504757oBbMHMYk8IIYQQQsQoSsExGgAcCb1vj22bbvs5mNlG0AuHioqKa5qamlJwWkIIIYQQ6WXHjh0nnXN16Th2KkTanHHOPQrgUQBobm5227dvz/AZCSGEEELEx8xeT9exU7G6swPAitD75bFt020XQgghhBBxSIVI2wzgg7FVntcBeMM5dwzAkwA2mFlNbMHAhtg2IYQQQggRh7jTnWb2dQDvAFBrZu3gis1iAHDO/SOAHwB4D4A2AP0Afj/22Wkz+zSA52OHesg5N9MCBCGEEEIIESOuSHPO/W6czx2AP5rms00ANs3u1IQQQggh8hdVHBBCCCGEiCASaUIIIYQQLtEScwAAIABJREFUEUQiTQghhBAigkikCSGEEEJEEIk0IYQQQogIIpEmhBBCCBFBJNKEEEIIISKIRJoQQgghRASRSBNCCCGEiCASaUIIIYQQEUQiTQghhBAigkikCSGEEEJEEIk0IYQQQogIIpEmhBBCCBFBEhJpZnarme0zszYz+8QUn/+tme2M/ew3s57QZ2Ohzzan8uSFEEIIIXKVong7mFkhgC8CuBlAO4DnzWyzc26P38c598eh/T8K4E2hQww459al7pSFEEIIIXKfRDxp1wJoc84ddM4NA3gCwB0z7P+7AL6eipMTQgghhMhXEhFpDQCOhN63x7adg5mtBHAhgB+FNpeZ2XYz22Zmd876TIUQQggh8oi4051JcheAbzrnxkLbVjrnOsxsNYAfmdlu59yB8JfMbCOAjQBwwQUXpPiUhBBCCCGyj0Q8aR0AVoTeL49tm4q7MGmq0znXEXs9COAZTIxX8/s86pxrds4119XVJXBKQgghhBC5TSIi7XkAjWZ2oZmVgELsnFWaZtYEoAbA1tC2GjMrjf1eC+B6AHsmf1cIIYQQQkwk7nSnc27UzO4H8CSAQgCbnHOvmNlDALY757xguwvAE845F/r6pQC+ZGbjoCD8q/CqUCGEEEIIMTU2UVNlnubmZrd9+/ZMn4YQQgghRFzMbIdzrjkdx1bFASGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQEkUgTQgghhIggEmlCCCGEEBFEIk0IIYQQIoJIpAkhhBBCRBCJNCGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQEkUgTQgghhIggEmlCCCGEEBFEIk0IIYQQIoIkJNLM7FYz22dmbWb2iSk+/z0z6zKznbGf/xz67F4za4393JvKkxdCCCGEyFWK4u1gZoUAvgjgZgDtAJ43s83OuT2Tdv1X59z9k767GMCnADQDcAB2xL7bnZKzF0IIIYTIURLxpF0LoM05d9A5NwzgCQB3JHj8WwBscc6djgmzLQBund2pCiGEEELkD4mItAYAR0Lv22PbJvNbZrbLzL5pZiuS/K4QQgghhAiRqoUD3wWwyjm3FvSWPZbMl81so5ltN7PtXV1dKTolIYQQQojsJRGR1gFgRej98ti2X+GcO+WcG4q9/d8Arkn0u7HvP+qca3bONdfV1SV67kIIIYQQOUsiIu15AI1mdqGZlQC4C8Dm8A5mdn7o7e0AXo39/iSADWZWY2Y1ADbEtgkhhBBCiBmIu7rTOTdqZveD4qoQwCbn3Ctm9hCA7c65zQAeMLPbAYwCOA3g92LfPW1mnwaFHgA85Jw7nYb/QwghhBAipzDnXKbPYQLNzc1u+/btmT4NIYQQQoi4mNkO51xzOo6tigNCCCGEEBFEIk0IIYQQIoJIpAkhhBBCRBCJNCGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQEkUgTQgghhIggEmlCCCGEEBFEIk0IIYQQIoJIpAkhhBBCRBCJNCGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQESUikmdmtZrbPzNrM7BNTfP5fzWyPme0ys6fNbGXoszEz2xn72ZzKkxdCCCGEyFWK4u1gZoUAvgjgZgDtAJ43s83OuT2h3V4E0Oyc6zezDwP4GwC/E/tswDm3LsXnLYQQQgiR0yTiSbsWQJtz7qBzbhjAEwDuCO/gnPuxc64/9nYbgOWpPU0hhBBCiPwiEZHWAOBI6H17bNt03Afgh6H3ZWa23cy2mdmdU33BzDbG9tne1dWVwCkJIYQQQuQ2cac7k8HMPgCgGcCNoc0rnXMdZrYawI/MbLdz7kD4e865RwE8CgDNzc0uleckhBBCCJGNJOJJ6wCwIvR+eWzbBMxsPYD/AeB259yQ3+6c64i9HgTwDIA3zeF8hRBCCCHygkRE2vMAGs3sQjMrAXAXgAmrNM3sTQC+BAq0E6HtNWZWGvu9FsD1AMILDoQQQgghxBTEne50zo2a2f0AngRQCGCTc+4VM3sIwHbn3GYADwNYCOAbZgYAh51ztwO4FMCXzGwcFIR/NWlVqBBCCCGEmAJzLlohYM3NzW779u2ZPg0hhBBCiLiY2Q7nXHM6jq2KA0IIIYQQEUQiTQghhBAigkikCSGEEEJEEIk0IYQQQogIIpEmhBBCCBFBJNKEEEIIISKIRJoQQgghRASRSBNCCCGEiCASaUIIIYQQEUQiTQghhBAigkikCSGEEEJEEIk0IYQQQogIIpEmhBBCCBFBJNKEEEIIISJIQiLNzG41s31m1mZmn5ji81Iz+9fY578ws1Whz/40tn2fmd2SulMXQgghhMhd4oo0MysE8EUA7wZwGYDfNbPLJu12H4Bu59waAH8L4K9j370MwF0ALgdwK4B/iB1PCCGEEELMQCKetGsBtDnnDjrnhgE8AeCOSfvcAeCx2O/fBHCTmVls+xPOuSHn3CEAbbHjCSGEEEKIGUhEpDUAOBJ63x7bNuU+zrlRAG8AWJLgd4UQQgghxCSKMn0CAGBmGwFsjL0dMrOXM3k+Yk7UAjiZ6ZMQs0bXL3vRtctudP2yl0vSdeBERFoHgBWh98tj26bap93MigAsAnAqwe/COfcogEcBwMy2O+eaE/0HRLTQ9ctudP2yF1277EbXL3sxs+3pOnYi053PA2g0swvNrARcCLB50j6bAdwb+/19AH7knHOx7XfFVn9eCKARwC9Tc+pCCCGEELlLXE+ac27UzO4H8CSAQgCbnHOvmNlDALY75zYD+DKAr5pZG4DToJBDbL9/A7AHwCiAP3LOjaXpfxFCCCGEyBkSiklzzv0AwA8mbXsw9PsggPdP893PAPhMEuf0aBL7iuih65fd6PplL7p22Y2uX/aStmtnnJUUQgghhBBRQmWhhBBCCCEiiESaEEIIIUQESbtIM7PlZrbJzI6a2ZCZvWZmnzOzmiSPszj2vddixzkaO+7ydJ17vjPXa2dmFWZ2j5l9zcz2mtlZM+szs+1m9t9iq4VFmkjVvTfpmDeY2ZiZOTP7y1Ser5hIKq+fmV0duw/bY8fqNLOfmNkH03Hu+U4Kn3tvM7PvxL4/aGaHzewHZnZrus493zGz95nZ35vZs2bWG+vr/s8sjzXndpDWmDQzuwjAzwEsBfAdAHvBslDvBLAPwPXOuVMJHGdJ7DgXA/gRmBakCSw7dQLAW51zB9PxP+Qrqbh2sY7kh+CK3x+DZcFqANwO4LzY8W+KLTwRKSRV996kY1YC2AUm3VwI4DPOuT9L5XkLksrrF1ud/3cAugF8H8xVuRjAFQDanXN3pfwfyGNS+Nz7MIB/AHAWwP8HVuxZDuA3ASwA8GexhXkihZjZTgBXATgD2rwJwOPOuQ8keZzU3MPOubT9gGk7HICPTtr+v2Lb/zHB43wptv//O2n7A7Ht/5HO/yMff1Jx7QCsA3APgJJJ2ysB7Igd579l+n/NxZ9U3XuTvrsJFNz/d+wYf5np/zNXf1LYd24AMB47XuUUnxdn+n/NtZ8U9Z3FAHoADAC4ZNJnlwIYBNAPoDTT/2+u/cREVCMAA/CO2DX7P5loB8659HnSYiqyDcBrAC5yzo2HPqsEcCxmhKXOubMzHGch6C0bB3C+c64v9FkBgIMAVsb+hrxpKSBV1y7O37gbwOMAvuece++cT1r8inRcPzO7A8C3AfwnMHXPVyBPWlpI5fUzs5cArAFwgUvScyqSJ4XPvXoAxwHscs5dNcXnuwBcCaBW1zV9mNk7wFmgpDxpqbyH0xmT9s7Y61PhEwSAmNB6DnTZXhfnONcBKAfwXFigxY7jR4jhvyfmTqqu3UyMxF5H53AMMTUpvX5mthTAPwH4tnNuVrEZIilScv3M7AoAawE8BeC0mb3TzD4eiwe9KTbIFaklVffeCQBdAC42s8bwB2Z2Mejp2SmBFllS1gen8yb1BUf3T/N5a+z14nk6jkic+bD5h2Kv/zGHY4ipSfX1+yewr/jDuZyUSJhUXb83x15PAHgGjOd9GMBnAbQA2Glma2Z/mmIKUnLtHKe4/gi873aY2WNm9v+Y2b+AoSKvYJoE8iISpKwPTqjiwCxZFHt9Y5rP/fbqeTqOSJy02jwWyHwrgJ1gnJNILSm7fmb2IXChx+845zpTcG4iPqm6fktjr/eBiwVuA/AzAPUAHgTwAQDfN7MrnXPDsz9dESJl955z7htmdhTA1wGEV+F2guEGCu+JLilrB3E9abHloyfM7OVpPjcz+7yZtZnZLjO7etIunzGzVjO7d6rvi/zCzH4TwOfAeIvfcs6NxPmKyBBmtgq8Vt9wzv1bZs9GzALfvxcCuMs59wPnXK9zrhV86G8HR/K/lakTFNNjZh8APZ7PgosFFsRenwbwBQBPZO7sxHyRyHTnP4Nej+l4Nzg/3ghgI4BHYtuHYq9/Dy47/dSk3CBeafbE+ftecS6a5vNEjyMSJy02N7M7wY7lBIB3aKFH2kjV9dsEri77SCpOSiRMqq6f//y4c25r+IPYdNp3Ym+vTfoMxXSk5NrF4s42gdOa/8k5t9c5N+Cc2wsu3tkB4P2xwHYRPVL2DI0r0pxzPwWX3U/HHQD+xZFtAKrN7HwApbHPVzjnugFswUSx54Mhp5uz9eyLvU43d5vocUTipNzmZvZ+AN8AXfU3Ouf2xfmKmD2pun5Xg1NmXbGEjs7MHDjVAgD/I7bt23M7XTGJVF0/f5zpHgTdsdfyBM9LxCdV124DmIbjJ1MEno8D+Gns7TWzOUmRdlL2DE1FTFoDgCOh9+2xbX7VyYbYKiK/3S9BvR7M87ItzvG3gaP5682scooUHBtib388x/9DBHhbbjCzgimWDyd67fx37gHwGBgX80550NJOqq7fv4BTLJNpBHADGFO4A8CLcz5jESZV128bmAh1lZlVTLHU/4rY66EUnLMgqbp23slRN83nfrtiCaNJyp6hCeVJi8WmfM85d8UUn30PwF85534We/80gP8OJoH7AzBHzwNggNyAc+6zZva/APwxgC855/7QzDaCU6VlFRUVlzc1NcU9JyGEEEKITLNjx45u59zi8DYzexJ0Ij3gnPv70PYJ+ifesVMh0r4E4Bnn3Ndj7/eBAu0d4Kqwd4FTJq+BJWUqwRwi+wH8WjjPi5m5a665Btu3b497TkIIIYQQmcbMhp1zpZO2TS4L9SqAt2Aa/TMdqciTthnAB2OrPK8D8IZz7hiYZPY6ADcB+BqAFeAig4vAOnLXKRGfEEIIIXIN59wBAM3g4su3APhvmIX+iRuTZmZfB71itWbWDuBTYEAjnHP/COAHAN4DlkDoB/D7sc9Om9mnwVIyAPB/Oee+ghlwzllzc3P6Kr4LIYQQQqSW3VNtdM4dQUwTzZa4Is0597txPveZkaf6bBOUrFQIIYQQImlUu00IIYQQIoJIpAkhhBBCRBCJNCGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQEkUgTQgghhIggEmlCCCGEEBFEIk0IIYQQIoJIpAkhhBBCRBCJNCGEEEKICCKRJoQQQggRQSTShBBCCCEiiESaEEIIIUQEkUgTQgghhIggCYk0M7vVzPaZWZuZfWKKz//WzHbGfvabWU/os7HQZ5tTefJCCCGEELlKUbwdzKwQwBcB3AygHcDzZrbZObfH7+Oc++PQ/h8F8KbQIQacc+tSd8pCCCGEELlPIp60awG0OecOOueGATwB4I4Z9v9dAF9PxckJIYQQQuQriYi0BgBHQu/bY9vOwcxWArgQwI9Cm8vMbLuZbTOzO6f53sbYPtu7uroSPHUhhBBCiNwl1QsH7gLwTefcWGjbSudcM4C7AXzOzC6a/CXn3KPOuWbnXHNdXV2KT0kIIYQQIvtIRKR1AFgRer88tm0q7sKkqU7nXEfs9SCAZzAxXk0IIYQQQkxBIiLteQCNZnahmZWAQuycVZpm1gSgBsDW0LYaMyuN/V4L4HoAeyZ/VwghhBBCTCTu6k7n3KiZ3Q/gSQCFADY5514xs4cAbHfOecF2F4AnnHMu9PVLAXzJzMZBQfhX4VWhQgghhBBiamyipso8zc3Nbvv27Zk+DSGEEEKIuJjZjljsfcpRxQEhhBBCiAgikSaEEEIIEUEk0oQQQgghIohEmhBCCCFEBJFIE0IIIYSIIBJpQgghhBARRCJNCCGEECKCSKQJIYQQQkQQiTQhhBBCiAgikSaEEEIIEUEk0oQQQgghIohEmhBCCCFEBJFIE0IIIYSIIBJpQgghhBARJCGRZma3mtk+M2szs09M8fnvmVmXme2M/fzn0Gf3mllr7OfeVJ68EEIIIUSuUhRvBzMrBPBFADcDaAfwvJltds7tmbTrvzrn7p/03cUAPgWgGYADsCP23e6UnL0QQgghRI6SiCftWgBtzrmDzrlhAE8AuCPB498CYItz7nRMmG0BcOvsTlUIIYQQIn9IRKQ1ADgSet8e2zaZ3zKzXWb2TTNbkeR3hRBCCCFEiFQtHPgugFXOubWgt+yxZL5sZhvNbLuZbe/q6krRKQkhhBBCZC+JiLQOACtC75fHtv0K59wp59xQ7O3/BnBNot+Nff9R51yzc665rq4u0XMXQgghhMhZEhFpzwNoNLMLzawEwF0ANod3MLPzQ29vB/Bq7PcnAWwwsxozqwGwIbZNCCGEEELMQNzVnc65UTO7HxRXhQA2OedeMbOHAGx3zm0G8ICZ3Q5gFMBpAL8X++5pM/s0KPQA4CHn3Ok0/B9CCCGEEDmFOecyfQ4TaG5udtu3b8/0aQghhBBCxMXMdjjnmtNxbFUcEEIIIYSIIBJpQgghhBARRCJNCCGEECKCSKQJIYQQQkQQiTQhhBBCiAgikSaEEEIIEUEk0oQQQgghIohEmhBCCCFEBJFIE0IIIYSIIBJpQgghhBARRCJNCCGEECKCSKQJIYQQQkQQiTQhhBBCiAgikSaEEEIIEUEk0oQQQgghIkhCIs3MbjWzfWbWZmafmOLz/2pme8xsl5k9bWYrQ5+NmdnO2M/mVJ68EEIIIUSuUhRvBzMrBPBFADcDaAfwvJltds7tCe32IoBm51y/mX0YwN8A+J3YZwPOuXUpPm8hhBBCiJwmEU/atQDanHMHnXPDAJ4AcEd4B+fcj51z/bG32wAsT+1pCiGEEELkF4mItAYAR0Lv22PbpuM+AD8MvS8zs+1mts3M7pzFOQohhBBC5B1xpzuTwcw+AKAZwI2hzSudcx1mthrAj8xst3PuwKTvbQSwEQAuuOCCVJ6SEEIIIURWkognrQPAitD75bFtE/j/27v7IE+q+t7j74+LEAWCiyxqsTxFFlfE5wmSkFIoIq5JBSiVco0oRu+loqJ1c7XqkmjpvUQq5moiavTKerNejA8oVgl7FQUjPkeU2QpBQVbWFWUXBeRBDfLgst/7R/d4fzuZ2fnNbP92ember6qunj7dfeb070z37zunz+lO8ofAm4BTq+qBifSq2tbOtwBfBp4+ed+qWldVY1U1tmLFilkdgCRJ0mI0TJB2DbAqyZFJ9gbWAjuN0kzydOBCmgDt9oH05Un2aX8+CDgBGBxwIEmSpCnMeLuzqrYnOQe4AlgGrK+q65OcB4xX1QbgHcB+wCVJAH5cVacCTwQuTLKDJiB8+6RRoZIkSZpCqmq+y7CTsbGxGh8fn+9iSJIkzSjJxqoaG0XevnFAkiSphwzSJEmSesggTZIkqYcM0iRJknrIIE2SJKmHDNIkSZJ6yCBNkiSphwzSJEmSesggTZIkqYcM0iRJknrIIE2SJKmHDNIkSZJ6yCBNkiSphwzSJEmSesggTZIkqYeGCtKSrEmyKcnmJOdOsX6fJJ9o138ryRED6/6yTd+U5HndFV2SJGnxmjFIS7IMeB/wfOAY4CVJjpm02auAu6vqKOBdwN+2+x4DrAWeBKwB3t/mJ0mSpF0YpiXtOGBzVW2pqgeBi4HTJm1zGnBR+/OngJOTpE2/uKoeqKofApvb/CRJkrQLew2xzSHALQPLW4FnTbdNVW1P8nPg0W361ZP2PWTyL0hyNnB2u/hAku8OVXr10UHAz+a7EJoz62/hsu4WNutv4XrCqDIeJkgbuapaB6wDSDJeVWPzXCTNkfW3sFl/C5d1t7BZfwtXkvFR5T3M7c5twKEDyyvbtCm3SbIXcABw55D7SpIkaZJhgrRrgFVJjkyyN81AgA2TttkAnNX+/CLgqqqqNn1tO/rzSGAV8O1uii5JkrR4zXi7s+1jdg5wBbAMWF9V1yc5Dxivqg3APwL/lGQzcBdNIEe73SeBG4DtwGur6qEZfuW6uR+OesD6W9isv4XLulvYrL+Fa2R1l6bBS5IkSX3iGwckSZJ6yCBNkiSphwzSJEmSemjkQVqSlUnWJ7k1yQNJbk5yQZLls8znwHa/m9t8bm3zXTmqsi91u1t3SfZN8tIkH0tyY5J7k/wyyXiSN7SjhTUiXZ17k/J8dpKHklSSt3VZXu2sy/pL8oz2PNza5nVbkq8kefkoyr7Udfi99wdJLmv3vz/Jj5NcnmTNqMq+1CV5UZL3Jvlakl+017qPzDGv3f47GOnAgSSPB/4FOBi4DLiR5rVQJwGbgBOq6s4h8nl0m8/RwFU0jwVZTfPaqduB36uqLaM4hqWqi7prLySfoxnx+yWa14ItB04FHtvmf3JV3T+iw1iyujr3JuW5P3AdzZPR9wPOr6o3d1luNbqsv3Z0/ruBu4HP0jyr8kDgWGBrVa3t/ACWsA6/914NvB+4F/g0zRt7VgIvAB4JvLmqzh/FMSxlSa4Fngr8O81nvhr4aFWdOct8ujmHq2pkE81jOwp43aT0v2/TPzBkPhe22//dpPTXt+mfH+VxLMWpi7oDnga8FNh7Uvr+wMY2nzfM97Euxqmrc2/SvutpAu6/avN423wf52KdOrx2ngLsaPPbf4r1D5/vY11sU0fXzocD9wD3AU+YtO6JwP3Ar4B95vt4F9vUBlGrgAAntnX2kfn4O6iq0bWktVHkZuBm4PFVtWNg3f7AT9oP4eCquncX+exH01q2A3hcVf1yYN3DgC3A4e3vsDWtA13V3Qy/40+BjwKfqao/2e1C6zdGUX9JTgMuBV5G83zFD2FL2kh0WX9J/g04CjisZtlyqtnr8HvvMcBPgeuq6qlTrL8OeDJwkPU6OklOpLkLNKuWtC7P4VH2STupnV85WECANtD6Bk2T7fEz5HM88AjgG4MBWpvPxH+Ig79Pu6+rutuVX7fz7buRh6bWaf0lORj4IHBpVc2pb4ZmpZP6S3Is8BTgSuCuJCcleWPbH/Tk9p9cdaurc+924A7g6CSrBlckOZqmpedaA7Te6uwaPMqTdOKt8N+fZv1N7fzoPZSPhrcnPvNXtvPP70YemlrX9fdBmmvFn+9OoTS0rurvd9v57cCXafrzvgN4J/DPwLVJjpp7MTWFTuqumltcr6U57zYmuSjJ3yT5ME1XkeuBMzoor0ajs2vwjK+F2g0HtPOfT7N+Iv1ReygfDW+kn3nbkXkNcC1NPyd1q7P6S/JKmoEeL66q2zoom2bWVf0d3M5fRTNY4I+BrwOPAd4CnAl8NsmTq+rBuRdXAzo796rqkiS3Ah8HBkfh3kbT3cDuPf3V2d/BjC1p7fDR25N8d5r1SfKeJJuTXJfkGZM2OT/JTUnOmmp/LS1JXgBcQNPf4oVV9esZdtE8SXIETV1dUlWfnN/SaA4mru/LgLVVdXlV/aKqbqL50h+n+U/+hfNVQE0vyZk0LZ5foxks8Mh2/kXgH4CL56902lOGud35f2haPabzfJr746uAs4H/1aY/0M7fSzPs9K2Tng0yEWneM8Pvn4g4D5hm/bD5aHgj+cyTnE5zYbkdONGBHiPTVf2tpxld9pouCqWhdVV/E+t/WlXfHFzR3k67rF08btYl1HQ6qbu239l6mtuaL6uqG6vqvqq6kWbwzkbgjLZju/qns+/QGYO0qvoqzbD76ZwGfLgaVwOPSvI4YJ92/aFVdTfwBXYO9iY6Q053z3bCpnY+3b3bYfPR8Dr/zJOcAVxC01T/nKraNMMumruu6u8ZNLfM7mgf6FhJiuZWC8Cb2rRLd6+4mqSr+pvIZ7ovgrvb+SOGLJdm1lXdnULzGI6vTNHxfAfw1XbxmXMppEaus+/QoR7B0d72+ExVHTvFus8Ab6+qr7fLXwT+G00T+rm0Q1CBNwH3VdU7Jw9BpXmW1tkA++677zNXr149Y5kkSZLm28aNG39WVSsmlrt8BMcoBw7c2RbyKJpRKoP+B7AvcGFbwHXAuiSrV69e/b3x8fERFkuSJKkbSX46uFxVP0hyJU2L6Gtpun1NmBz/7FIXQdo24NCB5ZVt2jaajqm/DbyHJqK8Lskf0TxD5Ps0rWuDvtdBeSRJkvaUqW5rvobmtVDvSXIyTXzzLKaPf6bUxXPSNgAvb0d5Hg/8vKp+QvOQ2eOBk4GP0QRyz6e59flu4HgfxCdJkhabqvoBMEYz+PJZwBuYQ/wzY0tako/TvL/qoCRbgbfSdGikqj4AXA78Ec2tzV8Bf9auuyvJX9O8SgbgP1fVh9iFqsrY2Njo3vguSZLUre9MlVhVt9DGRHM1Y5BWVS+ZYf3Ek5GnWrceH1YqSZI0a767TZIkqYcM0iRJknrIIE2SJKmHDNIkSZJ6yCBNkiSphwzSJEmSesggTZIkqYcM0iRJknrIIE2SJKmHDNIkSZJ6yCBNkiSphwzSJEmSesggTZIkqYcM0iRJknpoqCAtyZokm5JsTnLuFOvfleTadvp+knsG1j00sG5Dl4WXJElarPaaaYMky4D3Ac8FtgLXJNlQVTdMbFNVfzGw/euApw9kcV9VPa27IkuSJC1+w7SkHQdsrqotVfUgcDFw2i62fwnw8S4KJ0mStFQNE6QdAtwysLy1TfsPkhwOHAlcNZD8W0nGk1yd5PQ5l1SSJGkFbzg4AAANyUlEQVQJmfF25yytBT5VVQ8NpB1eVduS/A5wVZLvVNUPBndKcjZwNsBhhx3WcZEkSZIWnmFa0rYBhw4sr2zTprKWSbc6q2pbO98CfJmd+6tNbLOuqsaqamzFihVDFEmSJGlxGyZIuwZYleTIJHvTBGL/YZRmktXAcuCbA2nLk+zT/nwQcAJww+R9JUmStLMZb3dW1fYk5wBXAMuA9VV1fZLzgPGqmgjY1gIXV1UN7P5E4MIkO2gCwrcPjgqVJEnS1LJzTDX/xsbGanx8fL6LIUmSNKMkG6tqbBR5+8YBSZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeohgzRJkqQeMkiTJEnqIYM0SZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeohgzRJkqQeMkiTJEnqIYM0SZKkHjJIkyRJ6iGDNEmSpB4aKkhLsibJpiSbk5w7xfpXJLkjybXt9J8G1p2V5KZ2OqvLwkuSJC1We820QZJlwPuA5wJbgWuSbKiqGyZt+omqOmfSvgcCbwXGgAI2tvve3UnpJUmSFqlhWtKOAzZX1ZaqehC4GDhtyPyfB3yhqu5qA7MvAGvmVlRJkqSlY5gg7RDgloHlrW3aZC9Mcl2STyU5dJb7SpIkaUBXAwf+L3BEVT2FprXsotnsnOTsJONJxu+4446OiiRJkrRwDROkbQMOHVhe2ab9RlXdWVUPtIv/G3jmsPu2+6+rqrGqGluxYsWwZZckSVq0hgnSrgFWJTkyyd7AWmDD4AZJHjeweCrwvfbnK4BTkixPshw4pU2TJEnSLsw4urOqtic5hya4Wgasr6rrk5wHjFfVBuD1SU4FtgN3Aa9o970ryV/TBHoA51XVXSM4DkmSpEUlVTXfZdjJ2NhYjY+Pz3cxJEmSZpRkY1WNjSJv3zggSZLUQwZpkiRJPWSQJkmS1EMGaZIkST1kkCZJktRDBmmSJEk9ZJAmSZLUQwZpkiRJPWSQJkmS1EMGaZIkST1kkCZJktRDBmmSJEk9ZJAmSZLUQwZpkiRJPTRUkJZkTZJNSTYnOXeK9f81yQ1JrkvyxSSHD6x7KMm17bShy8JLkiQtVnvNtEGSZcD7gOcCW4FrkmyoqhsGNvtXYKyqfpXk1cD/BF7crruvqp7WcbklSZIWtWFa0o4DNlfVlqp6ELgYOG1wg6r6UlX9ql28GljZbTElSZKWlmGCtEOAWwaWt7Zp03kV8LmB5d9KMp7k6iSnz6GMkiRJS86MtztnI8mZwBjwnIHkw6tqW5LfAa5K8p2q+sGk/c4GzgY47LDDuiySJEnSgjRMS9o24NCB5ZVt2k6S/CHwJuDUqnpgIr2qtrXzLcCXgadP3req1lXVWFWNrVixYlYHIEmStBgNE6RdA6xKcmSSvYG1wE6jNJM8HbiQJkC7fSB9eZJ92p8PAk4ABgccSJIkaQoz3u6squ1JzgGuAJYB66vq+iTnAeNVtQF4B7AfcEkSgB9X1anAE4ELk+ygCQjfPmlUqCRJkqaQqprvMuxkbGysxsfH57sYkiRJM0qysarGRpG3bxyQJEnqIYM0SZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeohgzRJkqQeMkiTJEnqIYM0SZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeohgzRJkqQeMkiTJEnqIYM0SZKkHjJIkyRJ6qGhgrQka5JsSrI5yblTrN8nySfa9d9KcsTAur9s0zcleV53RZckSVq8ZgzSkiwD3gc8HzgGeEmSYyZt9irg7qo6CngX8LftvscAa4EnAWuA97f5SZIkaReGaUk7DthcVVuq6kHgYuC0SducBlzU/vwp4OQkadMvrqoHquqHwOY2P0mSJO3CMEHaIcAtA8tb27Qpt6mq7cDPgUcPua8kSZIm2Wu+CwCQ5Gzg7HbxgSTfnc/yaLccBPxsvguhObP+Fi7rbmGz/hauJ4wq42GCtG3AoQPLK9u0qbbZmmQv4ADgziH3parWAesAkoxX1diwB6B+sf4WNutv4bLuFjbrb+FKMj6qvIe53XkNsCrJkUn2phkIsGHSNhuAs9qfXwRcVVXVpq9tR38eCawCvt1N0SVJkhavGVvSqmp7knOAK4BlwPqquj7JecB4VW0A/hH4pySbgbtoAjna7T4J3ABsB15bVQ+N6FgkSZIWjaH6pFXV5cDlk9LeMvDz/cAZ0+x7PnD+LMq0bhbbqn+sv4XN+lu4rLuFzfpbuEZWd2nuSkqSJKlPfC2UJElSDxmkSZIk9dDIg7QkK5OsT3JrkgeS3JzkgiTLZ5nPge1+N7f53Nrmu3JUZV/qdrfukuyb5KVJPpbkxiT3JvllkvEkb2hHC2tEujr3JuX57CQPJakkb+uyvNpZl/WX5Bntebi1zeu2JF9J8vJRlH2p6/B77w+SXNbuf3+SHye5PMmaUZV9qUvyoiTvTfK1JL9or3UfmWNeu/13MNI+aUkeD/wLcDBwGXAjzWuhTgI2ASdU1Z1D5PPoNp+jgatoHguymua1U7cDv1dVW0ZxDEtVF3XXXkg+RzPi90s0rwVbDpwKPLbN/+R24Ik61NW5NynP/YHraB66uR9wflW9uctyq9Fl/bWj898N3A18luZZlQcCxwJbq2pt5wewhHX4vfdq4P3AvcCnad7YsxJ4AfBI4M3twDx1KMm1wFOBf6f5zFcDH62qM2eZTzfncFWNbKJ5bEcBr5uU/vdt+geGzOfCdvu/m5T++jb986M8jqU4dVF3wNOAlwJ7T0rfH9jY5vOG+T7WxTh1de5N2nc9TcD9V20eb5vv41ysU4fXzlOAHW1++0+x/uHzfayLbero2vlw4B7gPuAJk9Y9Ebgf+BWwz3wf72Kb2iBqFRDgxLbOPjIffwdVNbqWtDaK3AzcDDy+qnYMrNsf+En7IRxcVffuIp/9aFrLdgCPq6pfDqx7GLAFOLz9HbamdaCrupvhd/wp8FHgM1X1J7tdaP3GKOovyWnApcDLaB7d8yFsSRuJLusvyb8BRwGH1SxbTjV7HX7vPQb4KXBdVT11ivXXAU8GDrJeRyfJiTR3gWbVktblOTzKPmkntfMrBwsI0AZa36Bpsj1+hnyOBx4BfGMwQGvzmfgPcfD3afd1VXe78ut2vn038tDUOq2/JAcDHwQurao59c3QrHRSf0mOBZ4CXAncleSkJG9s+4Oe3P6Tq251de7dDtwBHJ1k1eCKJEfTtPRca4DWW51dg0d5kk68cPT706y/qZ0fvYfy0fD2xGf+ynb++d3IQ1Pruv4+SHOt+PPdKZSG1lX9/W47vx34Mk1/3ncA7wT+Gbg2yVFzL6am0EndVXOL67U0593GJBcl+ZskH6bpKnI90zxAXr3Q2TV4qDcOzNEB7fzn06yfSH/UHspHwxvpZ952ZF4DXEvTz0nd6qz+krySZqDHi6vqtg7Kppl1VX8Ht/NX0QwW+GPg68BjgLcAZwKfTfLkqnpw7sXVgM7Ovaq6JMmtwMeBwVG4t9F0N7B7T3919ndgc7f2qCQvAC6g6W/xwqr69Qy7aJ4kOYKmri6pqk/Ob2k0BxPX92XA2qq6vKp+UVU30Xzpj9P8J//C+SqgppfkTJoWz6/RDBZ4ZDv/IvAPwMXzVzrtKaMM0iYixQOmWT+Rfs8eykfDG8lnnuR0mgvL7cCJDvQYma7qbz3N6LLXdFEoDa2r+ptY/9Oq+ubgivZ22mXt4nGzLqGm00ndtf3O1tPc1nxZVd1YVfdV1Y00g3c2Ame0HdvVP519h44ySNvUzqe75zrRGXK6e7Zd56Phdf6ZJzkDuISmqf45VbVphl00d13V3zNobpnd0T7QsZIUza0WgDe1aZfuXnE1SdfXzum+CO5u548YslyaWVd1dwrNYzi+MkXH8x3AV9vFZ86lkBq5zr5DR9kn7Uvt/JQkD5tiCOoJNM95uXqGfK6m+W/+hCT7T/EIjlMm/T7tvq7qbmKflwIX0fSLOckWtJHrqv4+THOLZbJVwLNp+hRuBP51t0usQV1eO+8Fjkiy7xRD/Y9t5z/soMxqdFV3+7TzFdOsn0i3L2E/dfcdOuKHws3qYW40T/ZdPUU+Psx2D08d1t1ZwEO0z7Ob7+NaKlNX9TdN3q/Ah9kuiPqjedNAAe+ifcNMm/5kmn9+f03zHKd5P+bFMnVRdzS3oKv9In/KpHVPa+tuB/Ck+T7exTwxw8NsaVo7V091Ds3272C6aU+/Fup7wLNoniHyfeD3a+A5L+2tFKoqk/KZ/Fqob9N0oJx4LdTvV9UPRnYgS1AXdZfkJJqOrw+j6V9xyxS/6p6qumBEh7FkdXXuTZP3K/BhtiPV4bXzt4Gv0Hyxf4vm+UyPoXm10COA/1JV7x718SwlHdbdeuDPaFrLPg38CDgCOB3YG7igqv5ixIez5LR9p09vFx8LPI+mkeFrbdrPquqN7bZH0LRE/6iqjpiUz6z+Dqa1ByLRQ2ku6D+h+WP7Ec2IseVTbFu0fVqnWHcgzX+FP2rz+QnNF//K+Y62F+u0u3XH/29x2dV083wf52Kdujr3pth2ol5tSVsA9Uf7ntX2i+EBmj5qVwKnzPcxLtapi7qjeSL9K2iecXc3zYO/76IZ3bl2vo9xsU7Afx/2O4smaJ72e2w2fwfTTSNtSZMkSdLc+Jw0SZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeohgzRJkqQeMkiTJEnqIYM0SZKkHjJIkyRJ6iGDNEmSpB4ySJMkSeqh/wf370nM2ujJjgAAAABJRU5ErkJggg==\n","text/plain":["<Figure size 720x576 with 9 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"code","metadata":{"id":"iAKWET7tJfyA"},"source":["m = np.array(rec_list)\n","\n","np.save(f'drive/MyDrive/PointCloud/{modelname}_recs_2.npy', m, allow_pickle=True)\n","\n","# from google.colab import files\n","# # files.download(f'{modelname}_fnfe.mat') \n","# files.download(f'{modelname}_fnfe_pc_plot.pdf')\n","# files.download(f'{modelname}_recs.npy')"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"TSxuc1wLOtmS"},"source":["# Plotting"]},{"cell_type":"code","metadata":{"id":"gyHDfIwujLDe","colab":{"base_uri":"https://localhost:8080/","height":276},"executionInfo":{"status":"ok","timestamp":1620237455417,"user_tz":360,"elapsed":404783,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"5ea46eaa-395a-48e8-c496-2a6c4da04869"},"source":["#! sudo apt install texlive texlive-latex-extra texlive-fonts-recommended dvipng\n","#! pip install latex\n","\n","\n","#sonode\n","import seaborn as sns\n","import matplotlib.pyplot as plt\n","import matplotlib\n","\n","sns.set_style('dark')\n","\n","\n","ax3 = plt.plot()\n","\n","film_data = np.load('figure_data./hbnode_film_2d.npy')\n","\n","#which frame to stop by\n","a = len(film_data)\n","\n","frames = []\n","\n","for i in range(a):\n","    frames += [film_data[i][:120]]\n","    \n","intermediate = np.asarray(frames)\n","\n","inner = []\n","outer = []\n","\n","for i in range(a):\n","    inner += [intermediate[i][:40]]\n","    outer += [intermediate[i][40:]]\n","    \n","inner = np.asarray(inner)\n","outer = np.asarray(outer)\n","\n","\n","#make film image:\n","\n","inner_pic = np.empty((40, a, 2))\n","outer_pic = np.empty((80, a, 2))\n","\n","for i in range(40):\n","    for j in range(a):\n","        inner_pic[i][j] = inner[j][i]\n","           \n","for i in range(40):\n","    inner_pic_plot = np.transpose(inner_pic[i])\n","    plt.plot(inner_pic_plot[0], inner_pic_plot[1], color='#004488', linewidth=0.3)    \n","inner_start_frame = np.transpose(inner[0])\n","inner_end_frame = np.transpose(inner[len(inner)-1])\n","plt.scatter(inner_start_frame[0], inner_start_frame[1], color='#004488', s=25)\n","plt.scatter(inner_end_frame[0], inner_end_frame[1], color='#004488', s=25)\n","\n","\n","for i in range(80):\n","    for j in range(a):\n","        outer_pic[i][j] = outer[j][i]\n","        \n","for i in range(80):\n","    outer_pic_plot = np.transpose(outer_pic[i])\n","    plt.plot(outer_pic_plot[0], outer_pic_plot[1], color='#BB5566', linewidth=0.3)    \n","outer_start_frame = np.transpose(outer[0])\n","outer_end_frame = np.transpose(outer[len(inner)-1])\n","plt.scatter(outer_start_frame[0], outer_start_frame[1], color='#BB5566', s=25)\n","plt.scatter(outer_end_frame[0], outer_end_frame[1], color='#BB5566', s=25)\n","#plt.xlabel('x', fontsize=14)\n","#plt.ylabel('y',fontsize=14)\n","#plt.xticks([])\n","#plt.yticks([])\n","matplotlib.rc('font', size=20)\n","#rc('text', usetex=True)\n","plt.title(modelname, fontsize=40)\n","\n","\n","plt.tight_layout()\n","#sns.set_style('white')\n","plt.savefig('nested_n_spheres_{}.pdf'.format(modelname), bbox_inches='tight')\n"],"execution_count":null,"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAZMAAAEDCAYAAADweukiAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOydd5xW1Z3/3/fep0/vvTHD0Iehi4IgFgRRQyIm0TUx6pqYbEyyycZo/BmTaNy4JtlVk6ipa9sEe4sRxYqKdBgGhum91+eZp972++NhHuaZxsAMyOB9v14K55Zzztw7nM8951uOoOu6joGBgYGBwQQQP+0OGBgYGBhMfQwxMTAwMDCYMIaYGBgYGBhMGENMDAwMDAwmjCEmBgYGBgYTxhATAwMDA4MJY/q0O2BweggEApSVlVFXV0dXVxcejweLxUJ0dDQxMTEUFBSQl5eHKBrfF1OFzs5OSktLaWxspL+/H13XiYqKIiMjgzlz5pCUlPRpd9HgM4QhJmcxgUCAf/zjH7zyyit88sknyLI85vV2u5358+ezbt06LrnkEuLj48e8vrGxkQsvvDBUzsjI4O233z6pvq5Zs4ampqZQeevWrWRmZo6r3bGwWq1ERUWRlpbGnDlzWLNmDStXrjwh0bzuuuvYsWNH2LGioiKeeeaZcdcB8NBDD/Hwww+Hyo888ggXXHDBCdXh9Xr5+9//zosvvsjhw4fHvHbmzJls3LiRq6++GofDcULtPP/889x+++1jXmM2m7FYLMTGxpKUlEROTg7Tp09n0aJFFBUVYTKd3PDyox/9iBdeeOGk7h3MzJkzeemllyZcj8H4MMTkLOXVV1/lv/7rv2htbR33PV6vl+3bt7N9+3buuecePv/5z/PNb36T1NTUU9jTU4vf78fv99PZ2UlJSQl/+9vfyMrK4u6772bFihUnXe+BAwfYunXruEVtMvjHP/7BvffeS2dn57iuLysr47777uOxxx7jzjvvZP369ZPaH1mWkWUZt9tNU1MT+/btC52Li4tj/fr1fPWrXyUnJ2dS2zU4MzHWNM4y/H4/3//+9/n+978/opBkZWWxZMkSLrnkEtavX8/SpUuZNm3asC91WZb5+9//zsUXX3y6un7aaGho4MYbb+Tpp5+eUD0PPvggpyOBhKZp3HPPPXzve98bJiQOh4P58+dz8cUXc8kllzB//vxhs5Curi6+973vcc8996Bp2invL0BPTw9PPfUUl156KT//+c9xu92npV2DTw9jZnIWEQgEuPnmm9m+fXvY8czMTG688UZWr15Nenr6iPf29PTw4YcfsmXLFt58883QoBMIBE55vydKSkrKqMLg8Xhobm5m+/btPPfcczidztC5n/3sZ8ycOZOFCxeeVLtlZWW8/vrrk/7FP5Sf/OQnbN68OexYXl4et956KxdccAF2uz3snM/n49133+XBBx+kqqoqdPyJJ57A7/fz85///IT7sHbtWn74wx+GHdM0DafTicvloqWlhX379rFr166wNjVN48knn2T79u08+uijoy5djsUPf/hD1q5de8L3mc3mE77H4OQxxOQs4pe//GWYkAiCwHe/+11uvPHG4/7DiouLY8OGDWzYsIGqqip+97vf8eqrr57qLk8KJpNpzEGqsLCQ1atXc8MNN3DjjTdSXl4OgK7rPPDAAxOaoTz00EOsXbsWSZJOuo6xeO6554YJybXXXsttt92G1Wod8R6bzcall17KmjVruP/++3niiSdC5zZv3syCBQv4/Oc/f0L9cDgcxxWCgTp37NjBY489xgcffBA6V1lZyfXXX8/f/vY3EhMTT6jtuLi4kxIhg9OLscx1lvDGG2/w5JNPhsqiKPLAAw/wjW9844S/0PLz8/nVr37Fww8/TGxs7GR39VMjOTmZBx54AEEQQsf27NlDR0fHCdUz2GheXV3Nyy+/PGl9HExDQwP33HNP2LFrrrmGu+66a1QhGYzFYuHOO+/kmmuuCTt+zz330NDQMKl9HczSpUv54x//yO233x5mhG9oaOC22247Ze0afLoYYnIWoKoq999/f9ix66+/ng0bNkyo3osvvpgXX3xxQnWcacyYMYOZM2eGyrquU1FRcUJ13HrrrWGD5MMPP3xcT7mT4Te/+Q0ejydUnj17NnfeeecJ13PnnXcya9asUNntdvPf//3fk9LHsbj++uv58Y9/HHZs27ZtvPHGG6e8bYPTjyEmZwFvvPEGjY2NoXJGRgbf/e53J6XutLS0SannTGKod1F3d/cJ33/llVeGyo2NjTz77LOT0rcB2trahg26P/nJT05qOU2SJH7yk5+EHXvjjTdoa2ubUB/HwzXXXDPMiePRRx895e0anH4MMTkLGLy8BbBp06ZxLYMYBLFYLCd8z7e+9a2w5cNHHnlkUp0V/v73v6MoSqi8YMECiouLT7q+ofcPeOudDm655Zawcmlp6XFjZAymHoaYTHE8Hg/79+8PO3aixtXPGvX19WHlkzHuZmRksGnTplC5tbV1wq7Gg/nwww/Dyhs3bpxwnUPr+OijjyZc53iYM2fOMCF87733TkvbBqcPQ0ymOPv37w/7gs3KyiIlJeVT7NGZTUVFRdhXcVxcHIWFhSdV1y233ILNZguVH3vssTAbx8ni9/spLS0NO3buuedOuN7ly5eHlQ8ePHjaXL/POeecsPLevXtPS7sGpw9DTKY4g6OOIfgVaDAynZ2d/OAHPwgLNLz22mtPOu1HcnJymKdUV1dXmBvuyVJaWhpm0I+OjiYrK2vC9WZnZxMVFRUqy7I8TLROFUVFRWHlAfdsg7MHI85kijPUrTU3N/fT6QigKEqYI8CJ3nsq2vV6vWFBi319faFzS5Ys4etf//pJtwvwr//6r/ztb38LzUj+/Oc/c80114QN2ifKUMN4fn7+hPo4gCAI5Ofnh32AtLe3T0rdxyMvLy+s3N7ejqZp48qR1tPTc1K/V8nJySdlDzM4OQwxmeIMHhwBIiMjP6WeBAfB05mr6mTbjYqK4tprr+Vb3/rWhAeb+Ph4vvrVr/L73/8egN7eXv7yl79w6623nnSdg6P0ITgzmSyGitzQ359TxdCfQVEUnE7nuOKY7r///mGu7+PhxRdfDHOJNji1GGIyxRk6GJzIF/GPf/zjcbm0Ll26dFKWb84EEhMTufHGG7nqqqsm7av1hhtu4KmnngqJwF//+leuu+464uLiTqq+U/mBcKaICQRtQwZnD4bN5CxjcHS3wXA6Ozv55S9/yerVq3nqqacmpc7o6GhuuOGGUNntdvOHP/xhUuqGyX2nQ+s6HYkqgdOWYNLg08OYmUxxYmJiwsoul+tT6snk7mcyWe3KsozT6aSyspKtW7eyefNmvF4vbrebn/3sZzQ1NQ1LYHgyfOUrX+Hxxx8PBUA+/fTTfO1rXzupDaqGfsVP5jsduoR2utLljPQzjDcW6r777jPc3acAxsxkijMRMfnBD37A1q1bh/03WV/sZwJms5mEhASWLVvGHXfcwYsvvhjmOv2nP/2JN998c8LtREREcPPNN4fKXq+XRx555KTqGvpOhwrARBj6+zGZ9pixGPozmEym09a2wenBEJMpztAMrLW1teO+dyAb69D/pvJmWMcjNzeXX/ziF2HHfvOb30xK3ddccw3Jycmh8ubNm2lpaTnheobOZqqrqyfct9HqGtzfU0lNTU1YOSUlxdgi+izDeJtTnKGRxQcPHvyUejJ1WLFiRVjOsaqqqklJ72G1WvnGN74RKgcCAX7729+ecD1z584NS9XS19c3KVl+6+vrw2YIZrP5tMUlDc3ScLKBogZnLoaYTHGKi4vDgu4aGxtPSwK/qc7gzMEweSK8adMmMjIyQuUXXniBurq6E6rDZrMNc2n9+OOPJ9y3oXXMmTPntOVwG7ph24IFC05LuwanD0NMpjgD27YO5rnnnvuUejN1iIiICCv39PRMSr0Wi4VvfetbobKiKDz00EMnXM95550XVn7++ecn3LehdUxGipbxcPDgQQ4cOBB2bNWqVaelbYPThyEmZwH/8i//ElZ+5plnDB/+4zA0vmIyv9A/97nPhWUieO2116isrDyhOr70pS+FzTj37t07bKnoRNi3b19Y5LvJZOJLX/rSSdd3IgwEdA4wZ86cYTNDg6mPISZnAWvXrg3LfNvc3Myvf/3rT7FHZzaapg1b1ppMQ7QkSWER8Jqm8eCDD55QHampqcP2Abn77rtRVfWE+6OqKnfffXfYsbVr156WhKBPPfUUb731VtixiaawMTgzMcTkLECSpGGxEo8//jgvvfTSp9SjM5tXX301bFlLFEWWLl06qW2sX78+zMi8ZcuWE06q+L3vfQ+HwxEqHzp0aNg2vuPh3nvvDXMwcDgck7Z52lg8/vjjwzznVqxYwdq1a0952wanH0NMzhLWrl0bttylaRq33XYbv/vd7044zfhkxjWcaezYsYOf/vSnYcdWrVpFQkLCpLYjCALf+c53QmVd13nnnXdOqI6cnBzuuOOOsGNPP/00P//5z8f1TgOBAPfcc8+wuKE77riD7OzsE+rLibBr1y5uvvlm7r333rAEnpmZmSeVY8tgamBEwJ9F3HbbbVRUVPDJJ58AwQHsf/7nf3j22We56aabWL16Nenp6aPef+DAAV555RU2b958uro8KYyVNVhVVZxOJxUVFbz11lu88847Yak9HA4HP/rRj05Jvy666CLmzZtHSUnJSdexadMm9uzZE2Y8f/LJJ/noo4/49re/zZo1a8L2VIFgzqt3332XBx98cJit5gtf+ELYpl7jxePxDHvGmqbhcrlwOp20trayb98+du3aNaJ9qKCggEcfffSkRPtkswaDkTn4dGKIyVmExWLhD3/4A7fffjuvvfZa6HhTUxM//elP+elPf0pWVhZpaWnExcVhsVjweDx0dnZSVVVFf3//sDojIiJYv3796fwxTpiTzVbscDh45JFHTmna/u985zvcdNNNE6rj3nvvxWq18n//93+hY9XV1aFlsMLCQpKTkxEEgfb2dsrLy3G73cPq+fKXv8xdd911Un144403hu1JPx4kSeJLX/oS3//+94d50I2Xk80aDEbm4NOJISZnGVarlV//+tesWrWKBx54YNh+FQ0NDeMKgLPZbFxxxRXceuutJ5Vf6kzn/PPP56677pqUTafGYuXKlSxevJhdu3addB2iKHL33XezePFi7r333lD+LwjOGIZukDaU+Ph47rjjDi6//PKT7sOJEhcXx7p167j++uvJyck5be0afHoYYnKWcuWVV7Ju3TpeffVVXnnlFXbu3Bm2e99IREREMG/ePNatW8dll102oQ2ezhQkSSIiIoKYmBgKCgooKirisssuO60D3He/+91h7tsnw4YNG7jgggvYvHkzzz///HF3KywsLGTjxo188YtfPOlZwViYTCYsFguxsbEkJiaSk5NDYWEhixcvpqio6KR3sDSYmgj66cpBbfCp4vP5OHz4MPX19XR1deHz+bBYLMTExBATE0NeXh75+flGvqQpRHt7O4cOHaKxsTGUwDEyMpLMzExmz559Wlx/DQwGMMTEwMDAwGDCGJ+hBgYGBgYTxhATAwMDA4MJY4iJgYGBgcGEMcTEwMDAwGDCfCq+e5qmoaqG3d/AwMBgKmE2S6Oe+1TERFV1ens9n0bTBgYGBgYnSVLS6LFnxjKXgYGBgcGEMcTEwMDAwGDCGGJiYGBgYDBhDDExMDAwMJgwRia2swxd03CVluFtbMKemUHUnJkIRr4tAwODU4whJlOUkUQDoPrhx/DU1qP5A4hWC5bEBGKK52HPTAcdfM0t2DMziJxVSP/hckN0DAwMJgVDTKYguqYNEw17TjYR03JwV9agqyoAmj+Ar6kFX1MLCMLRm3UEixnRZEJX1WGi48jKPK6wGLMfAwODoXwqWYNlWTXiTCaAs+QQdX95Es1/Ynu7jwfRasGRm820f7s5TCAGBMTT0EjfvhL8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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"bWxtGbLWBMff"},"source":[""],"execution_count":null,"outputs":[]}]}