{"metadata":{"kernelspec":{"language":"python","display_name":"Python 3","name":"python3"},"language_info":{"name":"python","version":"3.10.12","mimetype":"text/x-python","codemirror_mode":{"name":"ipython","version":3},"pygments_lexer":"ipython3","nbconvert_exporter":"python","file_extension":".py"}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"import numpy as np \n#import sdeint\nfrom sklearn.metrics import mean_squared_error\nimport time\n\nimport statsmodels.api as sm\nfrom torch.autograd import Variable\nimport seaborn as sns\nimport torch\n\nimport matplotlib.pyplot as plt\n\n\nimport torch\nfrom torch import nn","metadata":{"_uuid":"8f2839f25d086af736a60e9eeb907d3b93b6e0e5","_cell_guid":"b1076dfc-b9ad-4769-8c92-a6c4dae69d19","execution":{"iopub.status.busy":"2023-08-07T02:16:29.165466Z","iopub.execute_input":"2023-08-07T02:16:29.165986Z","iopub.status.idle":"2023-08-07T02:16:35.294655Z","shell.execute_reply.started":"2023-08-07T02:16:29.165937Z","shell.execute_reply":"2023-08-07T02:16:35.293404Z"},"trusted":true},"execution_count":3,"outputs":[{"name":"stderr","text":"/opt/conda/lib/python3.10/site-packages/scipy/__init__.py:146: UserWarning: A NumPy version >=1.16.5 and <1.23.0 is required for this version of SciPy (detected version 1.23.5\n  warnings.warn(f\"A NumPy version >={np_minversion} and <{np_maxversion}\"\n","output_type":"stream"}]},{"cell_type":"code","source":"class CFG:\n   \n    d = 1\n\n    a = 0.2\n    \n    x0 = 0.5\n    \n    M= 101\n    h = 0.01\n    \n    \n    N = 50\n    \n    epoch=201\n    optim = ['SGD','Adam'][1]\n    lr = 0.002\n    seed = 44\n    hidden_size =108#108\n    \n    \n    lambda1 =1\n    lambda2 =1\n    print_step = 100\n    gap = 10\n","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:10.238108Z","iopub.execute_input":"2023-08-07T02:18:10.238620Z","iopub.status.idle":"2023-08-07T02:18:10.247764Z","shell.execute_reply.started":"2023-08-07T02:18:10.238572Z","shell.execute_reply":"2023-08-07T02:18:10.246454Z"},"trusted":true},"execution_count":22,"outputs":[]},{"cell_type":"code","source":"def seed_torch(seed):\n    torch.manual_seed(seed)\n    torch.cuda.manual_seed(seed)\n    torch.backends.cudnn.deterministic = True\nseed_torch(seed = CFG.seed)\n\ndef deltaW(N, m, h, seed,generator=None):\n    if generator is None:\n        generator = np.random.default_rng(seed=seed)\n    return generator.normal(0.0, np.sqrt(h), (N, m))\n\ndef get_wt(CFG,seed=1):\n    n,h,N,d = CFG.M,CFG.h,CFG.N,CFG.d\n    ts = np.array([i*h for i in range(n)])\n    w_t_increments = np.array([deltaW(N=n-1, m=d, h=h, generator=None,seed=int(i+seed*100)) for i in range(N)])\n    w_t = np.array([np.insert(np.cumsum(i.T),0,np.zeros(1)) for i in w_t_increments])\n    return w_t,ts,w_t_increments","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:11.352108Z","iopub.execute_input":"2023-08-07T02:18:11.352833Z","iopub.status.idle":"2023-08-07T02:18:11.364660Z","shell.execute_reply.started":"2023-08-07T02:18:11.352795Z","shell.execute_reply":"2023-08-07T02:18:11.363259Z"},"trusted":true},"execution_count":23,"outputs":[]},{"cell_type":"code","source":"import torch\n\n\n\n\ndef gradients(u, x, order=1):  \n    if order == 1:  \n        return torch.autograd.grad(u, x,grad_outputs=torch.ones_like(u),  create_graph=True,only_inputs=True,)[0]  \n    else:  \n        return gradients(gradients(u, x), x,order=order-1)\n\n\ndef f(x):\n    return 0.5*0.01*(1-2*x)/(x**(1/2)*(1-x)**(1/2))\ndef g(x):\n    return 0.2*x**0.25*(1-x)**0.25\n\ndef getFL(see):\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    F=[]\n    L=[]\n    x0 = CFG.x0\n\n    xt = np.zeros((CFG.N, CFG.M))\n    xt[:,0] = CFG.x0   \n\n    for i in range(CFG.M-1):\n        \n        xt[:,i+1] = xt[:,i] + f(xt[:,i])*CFG.h +g(xt[:,i])* w_t_increments[:,i].reshape(-1)\n        F.append(f(xt[:,i]))\n        L.append(g(xt[:,i]))\n    \n    F.append(f(xt[:,-1]))\n    L.append(g(xt[:,-1]))\n    \n    F = np.array(F).T\n    L = np.array(L).T\n    return xt,F,L\n","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:11.962390Z","iopub.execute_input":"2023-08-07T02:18:11.962883Z","iopub.status.idle":"2023-08-07T02:18:11.978555Z","shell.execute_reply.started":"2023-08-07T02:18:11.962842Z","shell.execute_reply":"2023-08-07T02:18:11.977338Z"},"trusted":true},"execution_count":24,"outputs":[]},{"cell_type":"code","source":"w_t,ts,w_t_increments = get_wt(CFG,seed=1)\nxt,F,L = getFL(1)","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:12.947483Z","iopub.execute_input":"2023-08-07T02:18:12.947916Z","iopub.status.idle":"2023-08-07T02:18:12.973892Z","shell.execute_reply.started":"2023-08-07T02:18:12.947883Z","shell.execute_reply":"2023-08-07T02:18:12.972654Z"},"trusted":true},"execution_count":25,"outputs":[]},{"cell_type":"code","source":"np.mean(xt[:-1])","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:17:52.952672Z","iopub.execute_input":"2023-08-07T02:17:52.953189Z","iopub.status.idle":"2023-08-07T02:17:52.962209Z","shell.execute_reply.started":"2023-08-07T02:17:52.953143Z","shell.execute_reply":"2023-08-07T02:17:52.960842Z"},"trusted":true},"execution_count":21,"outputs":[{"execution_count":21,"output_type":"execute_result","data":{"text/plain":"0.5008504526885521"},"metadata":{}}]},{"cell_type":"code","source":"sns.set_style(\"darkgrid\") \nsns.distplot(xt[:,-1]\n             ,bins=20\n             ,kde_kws={'color':'g','linestyle':'-','linewidth':3,'alpha':0.7}\n            )\n\n#plt.plot(x,y*(1/np.sqrt(2*3.14159926)))","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:16.541272Z","iopub.execute_input":"2023-08-07T02:18:16.541769Z","iopub.status.idle":"2023-08-07T02:18:17.039952Z","shell.execute_reply.started":"2023-08-07T02:18:16.541732Z","shell.execute_reply":"2023-08-07T02:18:17.038470Z"},"trusted":true},"execution_count":26,"outputs":[{"name":"stderr","text":"/tmp/ipykernel_32/1842864030.py:2: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(xt[:,-1]\n","output_type":"stream"},{"execution_count":26,"output_type":"execute_result","data":{"text/plain":"<Axes: ylabel='Density'>"},"metadata":{}},{"output_type":"display_data","data":{"text/plain":"<Figure size 640x480 with 1 Axes>","image/png":"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Rod4K5aEsdqAsFA9tDaH0/O0ljEQ1qUzy6P5+vT1OvOVQFifzmgv47wa2RqV4uJiLFiwAEuXLkVQUFCbXquysh6iC78ReoMgXPhAKSGLN3GcgUEQBBjNNgBAY6PJ6TFatSoYDRZUOhwQvbxgBEGA0WRDQ6MJZqvzjUrzjIGyLq+1PAThQpPSfH36cp35QqCsz2sJ9HFeHJ8zZGtUcnJyUFlZialTpzbV7HY79u7dixUrVuDw4cNQq9VOvZYoQjErUklZvInjDAA/j0sUXdrzAxG+Wy5is79dma95xkBYl1ddHldZn75cZ74SaONpTXsZ59XI1qiMGDEC69atk9Sefvpp9OjRAw888IDTTQoREREFLtkalbCwMKSmpkpqISEhiIqKalEnIiKi9kn205OJiIiIWiP76cmXe//99+WOQERERArCLSpERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLE0cgcgIvJ3giC4PI8oil5IcmWCcOEP4FpOX2Ykag0bFSKiNrACaDDbXJ4vTKeG1vNxWtCoBAiCgCqTDa62Hb7KSHQ1bFSIiNwkCAIazDbsz6+GxWZ3ej6dRo3MrtGICdJ4fauFWiXAYHUg93wNzArNSHQ1bFSIiNrIYrPDZHXIHeOqzH6QkehKeDAtERERKRYbFSIiIlIsNipERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLHYqBAREZFisVEhIiIixWKjQkRERIrFRoWIiIgUi40KERERKRYbFSIiIlIsNipERESkWGxUiIiISLE0cr75Bx98gJUrV6KwsBAAkJKSglmzZiE7O1vOWERERKQQsjYqiYmJePzxx9GlSxcAwNq1azF7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"},"metadata":{}}]},{"cell_type":"code","source":"class Pde_model(nn.Module):\n    def __init__(self):\n        super(Pde_model, self).__init__()\n        self.hidden_layer1 = torch.nn.Linear(2, CFG.hidden_size)\n        self.hidden_layer2 = torch.nn.Linear(CFG.hidden_size, CFG.hidden_size)\n        self.output_layer = torch.nn.Linear(CFG.hidden_size, 1)\n        self.tanh = nn.Tanh()\n    def forward(self, t,x):\n        x = torch.cat([x,t],dim=1)\n        x = self.hidden_layer1(x)\n        x = self.hidden_layer2(x)\n        x =  self.tanh(x)\n        x = self.hidden_layer2(x)\n        x = self.hidden_layer2(x)\n        x =  self.tanh(x)\n        x = self.output_layer(x)\n        return x\n\n\ndef get_optimizer(model):\n    if CFG.optim == 'SGD':\n        optimizer = torch.optim.SGD(model.parameters(), lr=CFG.lr)\n    if CFG.optim == 'Adam':\n        optimizer = torch.optim.Adam(model.parameters(), lr=CFG.lr, amsgrad = False)\n    return optimizer\n\nclass loss_pde(nn.Module):\n    def __init__(self, **kwargs):\n        super(loss_pde, self).__init__(**kwargs)\n        self.loss_list = []\n    def forward(self,t,xt_l,f,l,model,epoch):\n        loss1=0\n        loss_sum= 0 \n        for i in range(1,xt_l.shape[1]-1):\n            x= xt_l[:,i].view(CFG.N,1)\n            ti = torch.cat([t[i].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n            \n            u = model(ti,x)\n            ut = gradients(u,ti,1)\n            ux =  gradients(u,x,1)\n            uxx =  gradients(u,x,2)\n            fi = f[:,i]\n            li = l[:,i]\n            if i == 0 :\n                loss_sum = (ut+fi*ux+1/2*li**2*uxx)**2\n            else:\n                loss_sum= loss_sum+ (ut+fi*ux+1/2*li**2*uxx)**2\n                    \n        T = torch.cat([t[-1].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n        XT = xt_l[:,-1].view(CFG.N,1)\n        uT = model(T,XT)\n        loss1 = (uT - XT)**2\n       \n        \n        if epoch % 100== 0:\n            print('loss pde ',torch.mean(loss_sum).item())\n            print('loss bound',torch.mean(loss1).item())\n\n            self.loss_list.append(torch.mean(loss_sum).item()+100*torch.mean(loss1).item())\n        return 1*torch.mean(loss_sum)+1*torch.mean(loss1)\n    \n\ndef getFL(see):\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    F=[]\n    L=[]\n    x0 = CFG.x0\n\n    xt = np.zeros((CFG.N, CFG.M))\n    xt[:,0] = CFG.x0   \n\n    for i in range(CFG.M-1):\n        xt[:,i+1] = xt[:,i] + f(xt[:,i])*CFG.h +g(xt[:,i])* w_t_increments[:,i].reshape(-1)\n        F.append(f(xt[:,i]))\n        L.append(g(xt[:,i]))\n    F.append(f(xt[:,-1]))\n    L.append(g(xt[:,-1]))\n    F = np.array(F).T\n    L = np.array(L).T\n    return xt,F,L\n\ndef train(xt,F,L,see):\n    XT = torch.tensor(xt[:,::CFG.gap].astype(np.float32)).requires_grad_(True)#.cuda()#outputs\n    F = torch.tensor(F[:,::CFG.gap].astype(np.float32)).requires_grad_(False)#.cuda()\n    L = torch.tensor(L[:,::CFG.gap].astype(np.float32)).requires_grad_(False)#.cuda()\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    w_t_increments = torch.tensor(w_t_increments.astype(np.float32)).requires_grad_(False)\n    t = torch.tensor(ts[::CFG.gap].astype(np.float32)).reshape(int((CFG.M-1)/CFG.gap)+1,1).requires_grad_(True)#[:,::CFG.gap]\n    t0 = torch.cat([t[0].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n    par = np.array([CFG.x0 for i in range(CFG.N)])\n    par = torch.tensor(par.astype(np.float32)).reshape(CFG.N,1).requires_grad_(True)\n    model = Pde_model()\n    optimizer_list = [get_optimizer(model)]\n    loss = loss_pde()\n    ex=[]\n    for epoch in range(CFG.epoch):\n        optimizer_list[-1].zero_grad()\n        loss_2 = loss(t,XT,F,L,model,epoch)\n        loss_2.backward()\n        optimizer_list[-1].step()\n        if epoch % 100== 0:\n            EX= model(t0,par)\n            print('EX:',torch.mean((XT[:,-1])).item())\n            ex.append(EX[0].item())\n            print('Epoch:{}/{}\\t PDE_loss={:.4f}\\t EX={:.4f}\\t'.format(CFG.epoch,epoch ,loss_2.item(),EX[0].item()))\n    EX=  ex[np.argmin(np.array(loss.loss_list))]\n    return EX,torch.mean((XT[:,-1])).item()","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:19.985857Z","iopub.execute_input":"2023-08-07T02:18:19.987159Z","iopub.status.idle":"2023-08-07T02:18:20.024689Z","shell.execute_reply.started":"2023-08-07T02:18:19.987112Z","shell.execute_reply":"2023-08-07T02:18:20.023743Z"},"trusted":true},"execution_count":27,"outputs":[]},{"cell_type":"code","source":"0.50085","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:20.380675Z","iopub.execute_input":"2023-08-07T02:18:20.381606Z","iopub.status.idle":"2023-08-07T02:18:20.388898Z","shell.execute_reply.started":"2023-08-07T02:18:20.381559Z","shell.execute_reply":"2023-08-07T02:18:20.387546Z"},"trusted":true},"execution_count":28,"outputs":[{"execution_count":28,"output_type":"execute_result","data":{"text/plain":"0.50085"},"metadata":{}}]},{"cell_type":"code","source":"gets = []\nmc= []\nfor i in range(50):\n    see = i \n    print('————————')\n    print(i)\n    xt,F,L = getFL(see)\n\n    ex,ex_mcmc = train(xt,F,L,see)\n    print(ex)\n    gets.append(ex)\n    mc.append(ex_mcmc)\n    print('————————')\n    ","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:18:21.081530Z","iopub.execute_input":"2023-08-07T02:18:21.082052Z","iopub.status.idle":"2023-08-07T02:27:41.610830Z","shell.execute_reply.started":"2023-08-07T02:18:21.082011Z","shell.execute_reply":"2023-08-07T02:27:41.609640Z"},"trusted":true},"execution_count":29,"outputs":[{"name":"stdout","text":"————————\n0\nloss pde  0.0004306691116653383\nloss bound 0.16704457998275757\nEX: 0.47842034697532654\nEpoch:201/0\t PDE_loss=0.1675\t EX=0.3139\t\nloss pde  5.348330159904435e-05\nloss bound 2.193636646552477e-05\nEX: 0.47842034697532654\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4997\t\nloss pde  4.3002411985071376e-05\nloss bound 9.993400453822687e-06\nEX: 0.47842034697532654\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4999\t\n0.4999198317527771\n————————\n————————\n1\nloss pde  0.008776901289820671\nloss bound 0.34050315618515015\nEX: 0.48698386549949646\nEpoch:201/0\t PDE_loss=0.3493\t EX=0.0884\t\nloss pde  7.283750164788216e-05\nloss bound 2.4553028197260574e-05\nEX: 0.48698386549949646\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4984\t\nloss pde  3.368736361153424e-05\nloss bound 3.903338892996544e-06\nEX: 0.48698386549949646\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4990\t\n0.4989945888519287\n————————\n————————\n2\nloss pde  0.027105435729026794\nloss bound 0.3107442557811737\nEX: 0.5171177983283997\nEpoch:201/0\t PDE_loss=0.3378\t EX=0.1367\t\nloss pde  6.690436566714197e-05\nloss bound 3.793225914705545e-05\nEX: 0.5171177983283997\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4999\t\nloss pde  4.9495876737637445e-05\nloss bound 1.0766624654934276e-05\nEX: 0.5171177983283997\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5004\t\n0.5004287958145142\n————————\n————————\n3\nloss pde  0.0010327380150556564\nloss bound 0.3735172152519226\nEX: 0.4874429404735565\nEpoch:201/0\t PDE_loss=0.3745\t EX=0.1056\t\nloss pde  5.397300628828816e-05\nloss bound 2.174897599616088e-05\nEX: 0.4874429404735565\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4997\t\nloss pde  4.774829722009599e-05\nloss bound 1.669675657467451e-05\nEX: 0.4874429404735565\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5005\t\n0.5004953145980835\n————————\n————————\n4\nloss pde  0.00011558132246136665\nloss bound 0.33978888392448425\nEX: 0.5463680028915405\nEpoch:201/0\t PDE_loss=0.3399\t EX=0.2155\t\nloss pde  6.317426596069708e-05\nloss bound 3.423813177505508e-05\nEX: 0.5463680028915405\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4955\t\nloss pde  3.95379975088872e-05\nloss bound 1.9612689357018098e-05\nEX: 0.5463680028915405\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4987\t\n0.49867141246795654\n————————\n————————\n5\nloss pde  0.014070747420191765\nloss bound 0.20583514869213104\nEX: 0.48541367053985596\nEpoch:201/0\t PDE_loss=0.2199\t EX=0.3033\t\nloss pde  4.4501655793283135e-05\nloss bound 1.3075435163045768e-05\nEX: 0.48541367053985596\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4987\t\nloss pde  3.8248814234975725e-05\nloss bound 6.823219791840529e-06\nEX: 0.48541367053985596\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4997\t\n0.4997071921825409\n————————\n————————\n6\nloss pde  0.006108134053647518\nloss bound 0.4285573661327362\nEX: 0.5133393406867981\nEpoch:201/0\t PDE_loss=0.4347\t EX=0.1014\t\nloss pde  6.845548341516405e-05\nloss bound 2.929259790107608e-05\nEX: 0.5133393406867981\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5006\t\nloss pde  4.506220648181625e-05\nloss bound 1.9426604922045954e-05\nEX: 0.5133393406867981\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4999\t\n0.49991440773010254\n————————\n————————\n7\nloss pde  0.004931928124278784\nloss bound 0.16638661921024323\nEX: 0.5330451130867004\nEpoch:201/0\t PDE_loss=0.1713\t EX=0.3399\t\nloss pde  5.220406092121266e-05\nloss bound 1.0190481589233968e-05\nEX: 0.5330451130867004\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4979\t\nloss pde  3.117081359960139e-05\nloss bound 8.764716767473146e-06\nEX: 0.5330451130867004\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4989\t\n0.49891549348831177\n————————\n————————\n8\nloss pde  0.031627021729946136\nloss bound 0.2557993233203888\nEX: 0.5108422040939331\nEpoch:201/0\t PDE_loss=0.2874\t EX=0.1909\t\nloss pde  7.641725824214518e-05\nloss bound 5.628552389680408e-05\nEX: 0.5108422040939331\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4986\t\nloss pde  4.3261199607513845e-05\nloss bound 1.699569111224264e-05\nEX: 0.5108422040939331\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4992\t\n0.4992211163043976\n————————\n————————\n9\nloss pde  0.02586204744875431\nloss bound 0.13033266365528107\nEX: 0.4734853506088257\nEpoch:201/0\t PDE_loss=0.1562\t EX=0.3615\t\nloss pde  7.296030526049435e-05\nloss bound 1.3221856534073595e-05\nEX: 0.4734853506088257\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5028\t\nloss pde  0.0006728566950187087\nloss bound 0.000311094569042325\nEX: 0.4734853506088257\nEpoch:201/200\t PDE_loss=0.0010\t EX=0.4985\t\n0.5027623176574707\n————————\n————————\n10\nloss pde  0.028299782425165176\nloss bound 0.24382679164409637\nEX: 0.4972170889377594\nEpoch:201/0\t PDE_loss=0.2721\t EX=0.2225\t\nloss pde  5.708050593966618e-05\nloss bound 9.267963832826354e-06\nEX: 0.4972170889377594\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5015\t\nloss pde  6.701707025058568e-05\nloss bound 7.869209184718784e-06\nEX: 0.4972170889377594\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5000\t\n0.49995341897010803\n————————\n————————\n11\nloss pde  0.0015118104638531804\nloss bound 0.2706056535243988\nEX: 0.49296629428863525\nEpoch:201/0\t PDE_loss=0.2721\t EX=0.2052\t\nloss pde  6.661947554675862e-05\nloss bound 1.5565645298920572e-05\nEX: 0.49296629428863525\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4980\t\nloss pde  5.641261304845102e-05\nloss bound 1.1793767043855041e-05\nEX: 0.49296629428863525\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4997\t\n0.49973565340042114\n————————\n————————\n12\nloss pde  0.04741726815700531\nloss bound 0.2666369378566742\nEX: 0.4935116469860077\nEpoch:201/0\t PDE_loss=0.3141\t EX=0.2031\t\nloss pde  6.554212450282648e-05\nloss bound 4.875890590483323e-05\nEX: 0.4935116469860077\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5005\t\nloss pde  4.102925231563859e-05\nloss bound 1.5868270565988496e-05\nEX: 0.4935116469860077\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5000\t\n0.5000449419021606\n————————\n————————\n13\nloss pde  0.009037887677550316\nloss bound 0.20002317428588867\nEX: 0.4949328899383545\nEpoch:201/0\t PDE_loss=0.2091\t EX=0.2839\t\nloss pde  4.921725849271752e-05\nloss bound 1.7819642380345613e-05\nEX: 0.4949328899383545\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5002\t\nloss pde  0.002004650654271245\nloss bound 0.0002719116455409676\nEX: 0.4949328899383545\nEpoch:201/200\t PDE_loss=0.0023\t EX=0.5009\t\n0.5002069473266602\n————————\n————————\n14\nloss pde  0.011932549066841602\nloss bound 0.3209987282752991\nEX: 0.5372396111488342\nEpoch:201/0\t PDE_loss=0.3329\t EX=0.2298\t\nloss pde  4.491376239457168e-05\nloss bound 2.510275771783199e-05\nEX: 0.5372396111488342\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4983\t\nloss pde  4.0331353375222534e-05\nloss bound 1.6248339306912385e-05\nEX: 0.5372396111488342\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4997\t\n0.49972859025001526\n————————\n————————\n15\nloss pde  0.0016902628121897578\nloss bound 0.1296357810497284\nEX: 0.4906538128852844\nEpoch:201/0\t PDE_loss=0.1313\t EX=0.3317\t\nloss pde  6.245376425795257e-05\nloss bound 0.00010471612040419132\nEX: 0.4906538128852844\nEpoch:201/100\t PDE_loss=0.0002\t EX=0.4987\t\nloss pde  3.2718882721383125e-05\nloss bound 6.4507353272347245e-06\nEX: 0.4906538128852844\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4996\t\n0.4995918273925781\n————————\n————————\n16\nloss pde  0.00042262612259946764\nloss bound 0.2371581643819809\nEX: 0.49596089124679565\nEpoch:201/0\t PDE_loss=0.2376\t EX=0.2369\t\nloss pde  8.773908484727144e-05\nloss bound 2.1053599994047545e-05\nEX: 0.49596089124679565\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5005\t\nloss pde  5.53801583009772e-05\nloss bound 1.8173235730500892e-05\nEX: 0.49596089124679565\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5005\t\n0.5004932284355164\n————————\n————————\n17\nloss pde  0.04017845541238785\nloss bound 0.30885058641433716\nEX: 0.5171977877616882\nEpoch:201/0\t PDE_loss=0.3490\t EX=0.1969\t\nloss pde  4.4361127947922796e-05\nloss bound 1.4518546777253505e-05\nEX: 0.5171977877616882\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5007\t\nloss pde  3.756370642804541e-05\nloss bound 8.466983672406059e-06\nEX: 0.5171977877616882\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4992\t\n0.4991523325443268\n————————\n————————\n18\nloss pde  0.0022096189204603434\nloss bound 0.3121909201145172\nEX: 0.49219346046447754\nEpoch:201/0\t PDE_loss=0.3144\t EX=0.1777\t\nloss pde  7.545263360952958e-05\nloss bound 7.284207094926387e-05\nEX: 0.49219346046447754\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4995\t\nloss pde  4.40310723206494e-05\nloss bound 6.2096592046145815e-06\nEX: 0.49219346046447754\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4995\t\n0.49954384565353394\n————————\n————————\n19\nloss pde  0.003873838810250163\nloss bound 0.15370404720306396\nEX: 0.4849700629711151\nEpoch:201/0\t PDE_loss=0.1576\t EX=0.3217\t\nloss pde  4.688285116571933e-05\nloss bound 5.5311742471531034e-05\nEX: 0.4849700629711151\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4989\t\nloss pde  3.470201409072615e-05\nloss bound 4.121835900150472e-06\nEX: 0.4849700629711151\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4991\t\n0.4990766942501068\n————————\n————————\n20\nloss pde  0.009676480665802956\nloss bound 0.40189656615257263\nEX: 0.5130488872528076\nEpoch:201/0\t PDE_loss=0.4116\t EX=0.1171\t\nloss pde  5.000651435693726e-05\nloss bound 2.3145885279518552e-05\nEX: 0.5130488872528076\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5019\t\nloss pde  4.547230128082447e-05\nloss bound 1.8647400793270208e-05\nEX: 0.5130488872528076\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5000\t\n0.5000090599060059\n————————\n————————\n21\nloss pde  0.02753578871488571\nloss bound 0.4681544601917267\nEX: 0.504509449005127\nEpoch:201/0\t PDE_loss=0.4957\t EX=0.0685\t\nloss pde  0.0003555358271114528\nloss bound 4.984742554370314e-05\nEX: 0.504509449005127\nEpoch:201/100\t PDE_loss=0.0004\t EX=0.5031\t\nloss pde  4.2102426959900185e-05\nloss bound 1.4229271073418204e-05\nEX: 0.504509449005127\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4997\t\n0.4996790885925293\n————————\n————————\n22\nloss pde  0.0005171461380086839\nloss bound 0.13020852208137512\nEX: 0.5032200813293457\nEpoch:201/0\t PDE_loss=0.1307\t EX=0.4158\t\nloss pde  5.055786459706724e-05\nloss bound 2.0713039702968672e-05\nEX: 0.5032200813293457\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5012\t\nloss pde  4.227560566505417e-05\nloss bound 6.525428034365177e-06\nEX: 0.5032200813293457\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4999\t\n0.4998951852321625\n————————\n————————\n23\nloss pde  0.00022823462495580316\nloss bound 0.28037282824516296\nEX: 0.47915780544281006\nEpoch:201/0\t PDE_loss=0.2806\t EX=0.1486\t\nloss pde  6.334580393740907e-05\nloss bound 3.6024037399329245e-05\nEX: 0.47915780544281006\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5015\t\nloss pde  4.4726217311108485e-05\nloss bound 3.2427233236376196e-05\nEX: 0.47915780544281006\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5001\t\n0.5000644326210022\n————————\n————————\n24\nloss pde  0.00011397081834729761\nloss bound 0.381332129240036\nEX: 0.49293527007102966\nEpoch:201/0\t PDE_loss=0.3814\t EX=0.1207\t\nloss pde  4.783843905897811e-05\nloss bound 1.494994830864016e-05\nEX: 0.49293527007102966\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5023\t\nloss pde  4.60286028101109e-05\nloss bound 1.2881697330158204e-05\nEX: 0.49293527007102966\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5006\t\n0.5006006360054016\n————————\n————————\n25\nloss pde  0.00021609760005958378\nloss bound 0.16799768805503845\nEX: 0.4929713308811188\nEpoch:201/0\t PDE_loss=0.1682\t EX=0.2616\t\nloss pde  5.714318103855476e-05\nloss bound 1.7768838006304577e-05\nEX: 0.4929713308811188\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5000\t\nloss pde  3.958019078709185e-05\nloss bound 9.125657015829347e-06\nEX: 0.4929713308811188\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4998\t\n0.4998452365398407\n————————\n————————\n26\nloss pde  0.037156663835048676\nloss bound 0.11691045761108398\nEX: 0.48784416913986206\nEpoch:201/0\t PDE_loss=0.1541\t EX=0.3870\t\nloss pde  4.742936653201468e-05\nloss bound 1.809215609682724e-05\nEX: 0.48784416913986206\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4978\t\nloss pde  0.0007262666476890445\nloss bound 0.00015691766748204827\nEX: 0.48784416913986206\nEpoch:201/200\t PDE_loss=0.0009\t EX=0.4979\t\n0.49775609374046326\n————————\n————————\n27\nloss pde  0.0034490730613470078\nloss bound 0.247657909989357\nEX: 0.5073139667510986\nEpoch:201/0\t PDE_loss=0.2511\t EX=0.2369\t\nloss pde  5.349323691916652e-05\nloss bound 7.764652764308266e-06\nEX: 0.5073139667510986\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4976\t\nloss pde  3.440975342527963e-05\nloss bound 5.986175892758183e-06\nEX: 0.5073139667510986\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4993\t\n0.4992932081222534\n————————\n————————\n28\nloss pde  0.006717183627188206\nloss bound 0.33988815546035767\nEX: 0.498860627412796\nEpoch:201/0\t PDE_loss=0.3466\t EX=0.1914\t\nloss pde  3.94510971091222e-05\nloss bound 2.4960598238976672e-05\nEX: 0.498860627412796\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4985\t\nloss pde  3.369465412106365e-05\nloss bound 7.749261385470163e-06\nEX: 0.498860627412796\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4994\t\n0.49939650297164917\n————————\n————————\n29\nloss pde  0.00303551834076643\nloss bound 0.26399052143096924\nEX: 0.47863006591796875\nEpoch:201/0\t PDE_loss=0.2670\t EX=0.2174\t\nloss pde  6.159610347822309e-05\nloss bound 4.4407999666873366e-05\nEX: 0.47863006591796875\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5018\t\nloss pde  4.032536890008487e-05\nloss bound 4.231867933413014e-06\nEX: 0.47863006591796875\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4998\t\n0.4998478293418884\n————————\n————————\n30\nloss pde  0.004719390533864498\nloss bound 0.41119736433029175\nEX: 0.5321852564811707\nEpoch:201/0\t PDE_loss=0.4159\t EX=0.1587\t\nloss pde  8.447524305665866e-05\nloss bound 2.2887601517140865e-05\nEX: 0.5321852564811707\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4985\t\nloss pde  4.100315709365532e-05\nloss bound 2.0733237761305645e-05\nEX: 0.5321852564811707\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4997\t\n0.4996669292449951\n————————\n————————\n31\nloss pde  0.007525778375566006\nloss bound 0.19056957960128784\nEX: 0.5048081874847412\nEpoch:201/0\t PDE_loss=0.1981\t EX=0.3464\t\nloss pde  4.38130009570159e-05\nloss bound 7.585930234199623e-06\nEX: 0.5048081874847412\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4979\t\nloss pde  3.3790765883168206e-05\nloss bound 4.720793185697403e-06\nEX: 0.5048081874847412\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4991\t\n0.4991373121738434\n————————\n————————\n32\nloss pde  0.0015442116418853402\nloss bound 0.29769662022590637\nEX: 0.5200803875923157\nEpoch:201/0\t PDE_loss=0.2992\t EX=0.2601\t\nloss pde  5.869269807590172e-05\nloss bound 3.619500785134733e-05\nEX: 0.5200803875923157\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4998\t\nloss pde  5.207377762417309e-05\nloss bound 2.7050878998124972e-05\nEX: 0.5200803875923157\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5004\t\n0.500389814376831\n————————\n————————\n33\nloss pde  0.11791674792766571\nloss bound 0.29894664883613586\nEX: 0.5266813039779663\nEpoch:201/0\t PDE_loss=0.4169\t EX=0.1700\t\nloss pde  7.735288818366826e-05\nloss bound 0.00010603599366731942\nEX: 0.5266813039779663\nEpoch:201/100\t PDE_loss=0.0002\t EX=0.4957\t\nloss pde  4.22966004407499e-05\nloss bound 2.5614486730773933e-05\nEX: 0.5266813039779663\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5001\t\n0.5000927448272705\n————————\n————————\n34\nloss pde  0.006726191844791174\nloss bound 0.3372111916542053\nEX: 0.4943320155143738\nEpoch:201/0\t PDE_loss=0.3439\t EX=0.1225\t\nloss pde  5.489672548719682e-05\nloss bound 7.707295480940957e-06\nEX: 0.4943320155143738\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4998\t\nloss pde  3.840394492726773e-05\nloss bound 6.181945991556859e-06\nEX: 0.4943320155143738\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4990\t\n0.4989827573299408\n————————\n————————\n35\nloss pde  0.03822033852338791\nloss bound 0.17539221048355103\nEX: 0.5017240047454834\nEpoch:201/0\t PDE_loss=0.2136\t EX=0.2820\t\nloss pde  4.3851337977685034e-05\nloss bound 2.8441883841878735e-05\nEX: 0.5017240047454834\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4974\t\nloss pde  3.212473893654533e-05\nloss bound 8.200597221730277e-06\nEX: 0.5017240047454834\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4994\t\n0.49935126304626465\n————————\n————————\n36\nloss pde  0.0032078952062875032\nloss bound 0.20325933396816254\nEX: 0.4899475872516632\nEpoch:201/0\t PDE_loss=0.2065\t EX=0.2800\t\nloss pde  5.2023322496097535e-05\nloss bound 3.0109998988336883e-05\nEX: 0.4899475872516632\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5017\t\nloss pde  5.073757711215876e-05\nloss bound 1.1965282283199485e-05\nEX: 0.4899475872516632\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5003\t\n0.500265896320343\n————————\n————————\n37\nloss pde  0.0006539972964674234\nloss bound 0.2136813998222351\nEX: 0.47084328532218933\nEpoch:201/0\t PDE_loss=0.2143\t EX=0.2832\t\nloss pde  6.31749426247552e-05\nloss bound 2.5421250029467046e-05\nEX: 0.47084328532218933\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5005\t\nloss pde  5.378334390115924e-05\nloss bound 1.3471671081788372e-05\nEX: 0.47084328532218933\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5010\t\n0.5010314583778381\n————————\n————————\n38\nloss pde  0.0006419439450837672\nloss bound 0.36883246898651123\nEX: 0.5083838105201721\nEpoch:201/0\t PDE_loss=0.3695\t EX=0.1123\t\nloss pde  5.048341699875891e-05\nloss bound 2.1139161617611535e-05\nEX: 0.5083838105201721\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4993\t\nloss pde  4.43936005467549e-05\nloss bound 1.2514970876509324e-05\nEX: 0.5083838105201721\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4997\t\n0.499680757522583\n————————\n————————\n39\nloss pde  0.008235624991357327\nloss bound 0.2901710867881775\nEX: 0.4659198820590973\nEpoch:201/0\t PDE_loss=0.2984\t EX=0.1350\t\nloss pde  7.929391722427681e-05\nloss bound 5.5424821766791865e-05\nEX: 0.4659198820590973\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5012\t\nloss pde  4.356834324426018e-05\nloss bound 1.6905727534322068e-05\nEX: 0.4659198820590973\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5006\t\n0.5005711317062378\n————————\n————————\n40\nloss pde  0.0827312245965004\nloss bound 0.17640112340450287\nEX: 0.4864616096019745\nEpoch:201/0\t PDE_loss=0.2591\t EX=0.2101\t\nloss pde  8.348607661901042e-05\nloss bound 1.1007489774783608e-05\nEX: 0.4864616096019745\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4998\t\nloss pde  5.274291106616147e-05\nloss bound 8.752805115364026e-06\nEX: 0.4864616096019745\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5004\t\n0.500400960445404\n————————\n————————\n41\nloss pde  0.0025203765835613012\nloss bound 0.25884562730789185\nEX: 0.5050991773605347\nEpoch:201/0\t PDE_loss=0.2614\t EX=0.2581\t\nloss pde  5.935344233876094e-05\nloss bound 1.2848970072809607e-05\nEX: 0.5050991773605347\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4998\t\nloss pde  3.696939893416129e-05\nloss bound 1.1324545994284563e-05\nEX: 0.5050991773605347\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4994\t\n0.49935734272003174\n————————\n————————\n42\nloss pde  0.01840026117861271\nloss bound 0.20720188319683075\nEX: 0.5123037695884705\nEpoch:201/0\t PDE_loss=0.2256\t EX=0.3031\t\nloss pde  6.947183283045888e-05\nloss bound 2.3625721951248124e-05\nEX: 0.5123037695884705\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4976\t\nloss pde  5.267002052278258e-05\nloss bound 2.4709188437554985e-05\nEX: 0.5123037695884705\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.4995\t\n0.49760228395462036\n————————\n————————\n43\nloss pde  0.00485936040058732\nloss bound 0.2536253035068512\nEX: 0.5448220372200012\nEpoch:201/0\t PDE_loss=0.2585\t EX=0.2647\t\nloss pde  3.6468245525611565e-05\nloss bound 3.297592047601938e-05\nEX: 0.5448220372200012\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4947\t\nloss pde  3.0269950002548285e-05\nloss bound 3.465444933681283e-06\nEX: 0.5448220372200012\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4990\t\n0.49898654222488403\n————————\n————————\n44\nloss pde  0.02622651681303978\nloss bound 0.3627319633960724\nEX: 0.4762721657752991\nEpoch:201/0\t PDE_loss=0.3890\t EX=0.1035\t\nloss pde  5.913203494856134e-05\nloss bound 6.144588041934185e-06\nEX: 0.4762721657752991\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4974\t\nloss pde  3.643586751422845e-05\nloss bound 4.56976749774185e-06\nEX: 0.4762721657752991\nEpoch:201/200\t PDE_loss=0.0000\t EX=0.4987\t\n0.49867793917655945\n————————\n————————\n45\nloss pde  2.857116487575695e-05\nloss bound 0.4306544065475464\nEX: 0.516091525554657\nEpoch:201/0\t PDE_loss=0.4307\t EX=0.0735\t\nloss pde  6.760628457413986e-05\nloss bound 4.363043262856081e-05\nEX: 0.516091525554657\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4985\t\nloss pde  4.0484486817149445e-05\nloss bound 2.3272063117474318e-05\nEX: 0.516091525554657\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5000\t\n0.4999532997608185\n————————\n————————\n46\nloss pde  0.07014340162277222\nloss bound 0.20647287368774414\nEX: 0.5106832981109619\nEpoch:201/0\t PDE_loss=0.2766\t EX=0.2515\t\nloss pde  4.973485920345411e-05\nloss bound 1.7723888959153555e-05\nEX: 0.5106832981109619\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4998\t\nloss pde  0.00018728971190284938\nloss bound 8.843446266837418e-05\nEX: 0.5106832981109619\nEpoch:201/200\t PDE_loss=0.0003\t EX=0.5028\t\n0.49977514147758484\n————————\n————————\n47\nloss pde  0.02296450547873974\nloss bound 0.21375252306461334\nEX: 0.4805651903152466\nEpoch:201/0\t PDE_loss=0.2367\t EX=0.2462\t\nloss pde  5.971455539111048e-05\nloss bound 1.924245952977799e-05\nEX: 0.4805651903152466\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5009\t\nloss pde  0.00020625934121198952\nloss bound 3.907288555637933e-05\nEX: 0.4805651903152466\nEpoch:201/200\t PDE_loss=0.0002\t EX=0.5012\t\n0.5008974075317383\n————————\n————————\n48\nloss pde  0.04025048390030861\nloss bound 0.2523762881755829\nEX: 0.525287389755249\nEpoch:201/0\t PDE_loss=0.2926\t EX=0.2359\t\nloss pde  6.82598547427915e-05\nloss bound 2.1697227566619404e-05\nEX: 0.525287389755249\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.4993\t\nloss pde  5.58071187697351e-05\nloss bound 1.3984871657157782e-05\nEX: 0.525287389755249\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5003\t\n0.5003198981285095\n————————\n————————\n49\nloss pde  0.013200415298342705\nloss bound 0.17952191829681396\nEX: 0.48751235008239746\nEpoch:201/0\t PDE_loss=0.1927\t EX=0.3794\t\nloss pde  4.7063149395398796e-05\nloss bound 1.722998968034517e-05\nEX: 0.48751235008239746\nEpoch:201/100\t PDE_loss=0.0001\t EX=0.5014\t\nloss pde  4.405090294312686e-05\nloss bound 1.013363271340495e-05\nEX: 0.48751235008239746\nEpoch:201/200\t PDE_loss=0.0001\t EX=0.5003\t\n0.5002536177635193\n————————\n","output_type":"stream"}]},{"cell_type":"markdown","source":"gets = [0.5040452480316162,\n 1.0006117820739746,\n 0.5194120407104492,\n 1.0608725547790527,\n 0.9536173343658447,\n 1.1669297218322754,\n 1.1237891912460327,\n 1.081183671951294,\n 1.484188199043274,\n 0.8524646759033203,\n 0.38811734318733215,\n 1.096692442893982,\n 1.0703413486480713,\n 0.6480696797370911,\n 0.9409201741218567,\n 0.8492151498794556,\n 0.9226465821266174,\n 1.0413193702697754,\n 0.8815960884094238,\n 0.9063315987586975,\n -0.3058653771877289,\n 0.8779784440994263,\n 1.112849235534668,\n 1.1847292184829712,\n -0.06060464680194855,\n 1.2826008796691895,\n 1.3401854038238525,\n 1.139715313911438,\n 0.8862456679344177,\n 1.1160441637039185,\n 0.42988818883895874,\n 0.47275060415267944,\n 0.626828134059906,\n 0.84818434715271,\n 1.1829086542129517,\n 0.6303291916847229,\n 0.5806402564048767,\n 1.2531616687774658,\n 0.7980332374572754,\n 1.1377191543579102,\n 1.0188692808151245,\n 1.04985773563385,\n 0.7419564723968506,\n 1.1550623178482056,\n 0.7451250553131104,\n 0.6719911694526672,\n 1.536141037940979,\n 1.6307704448699951,\n 0.7976316213607788,\n 1.532058596611023]","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:03:03.139491Z","iopub.execute_input":"2023-05-21T07:03:03.139921Z","iopub.status.idle":"2023-05-21T07:03:03.153850Z","shell.execute_reply.started":"2023-05-21T07:03:03.139886Z","shell.execute_reply":"2023-05-21T07:03:03.152164Z"}}},{"cell_type":"markdown","source":"mc =[0.4072267413139343,\n 0.7905125617980957,\n 0.14119596779346466,\n 0.8235048055648804,\n 0.8144673109054565,\n 1.3551297187805176,\n 1.098264455795288,\n 0.8126041293144226,\n 0.7994998693466187,\n 0.5472996830940247,\n 0.4792327880859375,\n 0.4681820869445801,\n 1.4748157262802124,\n 0.7485493421554565,\n 0.5000365376472473,\n 0.47936487197875977,\n 0.8503457307815552,\n 0.9543734788894653,\n 1.0040271282196045,\n 0.9011006355285645,\n -0.33075255155563354,\n 0.7004958391189575,\n 1.7973620891571045,\n 1.0415047407150269,\n -0.038519859313964844,\n 0.9927854537963867,\n 1.5612447261810303,\n 0.8769102096557617,\n 0.8196353912353516,\n 1.0094460248947144,\n 0.6708841919898987,\n 0.7018336653709412,\n 0.24742965400218964,\n 0.6030243039131165,\n 1.3946119546890259,\n 0.6475545763969421,\n 0.5728421211242676,\n 0.8419492840766907,\n 1.0349677801132202,\n 1.2212506532669067,\n 0.9936771392822266,\n 1.4519237279891968,\n 0.8844783902168274,\n 1.529846429824829,\n 0.45020461082458496,\n 0.49223384261131287,\n 1.1970343589782715,\n 2.162999153137207,\n 0.9228331446647644,\n 1.6541998386383057]","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:03:04.172506Z","iopub.execute_input":"2023-05-21T07:03:04.173248Z","iopub.status.idle":"2023-05-21T07:03:04.183885Z","shell.execute_reply.started":"2023-05-21T07:03:04.173202Z","shell.execute_reply":"2023-05-21T07:03:04.182663Z"}}},{"cell_type":"code","source":"","metadata":{},"execution_count":null,"outputs":[]},{"cell_type":"code","source":"sns.set_style(\"darkgrid\") \nplt.figure(figsize=(10, 6)) \nsns.distplot(np.array(gets)\n             ,bins=30,label='Euler Maruyama method+FCM')\n\n#plt.plot(0.64)\nplt.axvline(0.50000,c='r',ls='-.',label='Real expectations')\n\nsns.distplot(np.array(mc)\n             ,bins=30,\n             label='Distribution of experience obtained by Euler Maruyama method'\n            )\nplt.legend()\n\nplt.savefig('mc2.png', bbox_inches='tight')","metadata":{"execution":{"iopub.status.busy":"2023-08-07T02:37:36.758446Z","iopub.execute_input":"2023-08-07T02:37:36.758932Z","iopub.status.idle":"2023-08-07T02:37:37.932687Z","shell.execute_reply.started":"2023-08-07T02:37:36.758895Z","shell.execute_reply":"2023-08-07T02:37:37.931400Z"},"trusted":true},"execution_count":42,"outputs":[{"name":"stderr","text":"/tmp/ipykernel_32/2818211990.py:3: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(np.array(gets)\n/tmp/ipykernel_32/2818211990.py:9: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(np.array(mc)\n","output_type":"stream"},{"output_type":"display_data","data":{"text/plain":"<Figure size 1000x600 with 1 Axes>","image/png":"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vGTJInXv3ivHfunpaerf/yZNmzZHEye+IcMwNHz4o/J6g4Ps5MmT1K9ff7399vtq3bpNgfepZcvzVK1adX3++dLANrfbrS+++FTduvWU5Jvm1bDhuRo/foLmzHlPvXpdo2efHal169YGHevTT5coISFB06bNVt++1+mll57XU089oaZNm2vGjLd10UVt9OyzI5Seni7J94G/cuUqGjVqrN5+e74GDRqsqVNf11dfLSuw3TNmTNVDDz2uyZOna9++vXrqqWF6//15GjnyWb3wwitatepHLVjwbmD/qVPf0NKln+jRR4fprbfe0/XX36jRo0fo119/VuXKVTRmjK8P58//SAsXfqYHHng02/1arOjoGE2dOkv33DNUs2b9RytXrgjch+HDH9HRo0c1adJUTZjwunbu3KERI54MXP+rr5ZpxowpuvPOezV9+hwlJibpo48WFHgfi2rDhr+0efM/6t//plzPIRMfHx/0c8OG5+qss6rrv//9WpK0d+8e/fbbr7ryym4l1kYAkY0gBQBnuOXLv9MVV3QI+ncqf2GfO3eOrrjiSl133Y2qWbOWmjVroQceeEyffbZEGRkZgf3OO+9C3XjjANWoUVM1atTM95hXXtlda9as1u7du7Rnz26tWfObunTJ+QH20ks7q2PHTqpZs5bq12+oYcNGaNOmjdqy5Z+g/fr1u0EdO3ZStWrVlZSUXKj71aNHby1dmhXmfvjhu8yRkyskScnJlXXjjQNUv35DVa9eQ9de218XXXSxvvnmy6Dj1KtXXwMH3qGaNWtpwIBBioqKUkJCBfXqdY1q1qylQYPu0JEjR7Rx4wZJvmlot99+l849t4mqVauuLl26qmvXnvrmm4KD1ODB96h585Zq0KCRunfvrdWrf9EjjwxTgwaN1KJFK116aWf98svPkqS0tDS9995cPfnkCLVu3UbVq9dQt2491aVLVy1c+KGsVqvi430nm65YsZISE5MUFxcXuK26devrttvuVM2atdS1aw81anSuVq1aKUlatepHbdq0USNHPqtGjc5VkyZN9dRTo7R69S/68891kqT335+n7t17qWfPq1WrVh3deee9qlPn7EL1TX4++uj9oOf2pEkTJEnbt2+XJNWuXafQx/IF+kWSpKVLP9HFF7crllEzAGUTU/sA4AzXqtX5evTRJ4O2lS9fvsjH++uv9dq5c7uW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ww/fB65TmOfpyfzTLX/88QcNGnSjOnVqp/vvv1uHDh3UDz98r5tuulZdunTUyJHDlZ6eHrieaZp6553Z6tevtzp1aqdbb70h8JzK7/ey77refF8Xe/bs0bBhD+uKKzqoS5eOeuqpYTp4MCVon6K+Lk4FQQoAkMP551+oevUa6Ntvv8718vfff1ffffc/jRr1vObO/UBPPTVaVaueJUmaNm2OJGn48JFauPCzwM+StHPndn399ZcaM2acZs7Mex3U3LlvqW7d+po+/W0NGDBQkyZN0MqVKwrV9sqVq2jMmPGZx/lACxd+pgceeDTXfZ977mn99defGjfuZU2ePFOmaeqxxx4IhB5JSk9P17x5b+mpp0bptdemad++PXr99VfyvP39+/fpscceUKNGTTRr1jw98siTWrJkoWbPni7JN93rjjvuVuXKVXI8Ptlt2rRRDz88VB07XqbZs+fpmWee0++/r9aECb771rVrD118cTuNGvVvud1urVixXAsXfqiRI0crJiamUI+l//4ePHhAL744UdOnv6UGDRrpwQfv0dGjRwLHKEy/PffcM1qz5jc988xzmj37XV122eV69NHgYFrQY/nRRwv08svj1avXNZo9+109//zLqlGjZkhtzS49PV2PPDJU8fHx+s9/Zmv06Oe1atVPgcfQb9Wqldq6dbNefXWynn56jP73v/9qxoypgf5q2rS5eva8RgsXfqaFCz9T5cpVZJqmKleuolGjxurtt+dr0KDBmjr1dX311bJc2+L36aeLFR0do6lTZ+mee4Zq1qz/hNQfX321TDNmTNGdd96r6dPnKDExSR99tCDf2/R7442JGjLkAU2bNkcVK1bSsGEPy+12KyYmRp07d9HSpZ8E7b906Se69NLOio0tV6jjF4eCnvd+8+a9pbPPrqvp09/WwIF35HvMbt16asmSrPu2ZMkide/eK8d+6elp6t//Jk2bNkcTJ74hwzA0fPij8nq9QftNnjxJ/fr119tvv6/WrdsUeJ9atjxP1apV1+efLw1sc7vd+uKLT9Wtmy9sOZ1ONWx4rsaPn6A5c95Tr17X6NlnR2rdurVBx/r00yVKSEjQtGmz1bfvdXrppef11FNPqGnT5pox421ddFEbPfvsiEDAKerzVPL9ceGhhx7X5MnTtW/fXj311DC9//48jRz5rF544RWtWvVj0B9mpk59Q0uXfqJHHx2mt956T9dff6NGjx6hX3/9ucDfywW9LoYPf0RHjx7VpElTNWHC69q5c4dGjHgycP1TeV2cCoIUACBXtWvX1p49u3O9bN++PapZs5aaN2+pqlXPUosWLXXFFVdJkipWrChJiouLV2JiUuBnyTdq8dRTo9SgQSPVq1c/zwIZzZq10IABA1WrVm1de21/XXppJ733XuEKUFit1sBarooVKykxMSnXKVbbt2/Td9/9T0888W+1aNFK9es30MiRo7V//76gohput1uPPTZcjRo1VsOGjdSnz3X6+eeVed7+hx++r8qVq+jhhx9X7dp1dMkll+q22+7Su+++I6/Xq7i4OMXGxspiseR4fLKbO3eOrrjiSl133Y2qWbOWmjVroQceeEyffbZEGRkZkqTHHhuulJQUvfLKi3ruuWc0aNBgnXtuk0I/lr/8skr//LNRo0ePU6NGjVWzZi0NGfKg4uLi9c03XwWOUVC/7dy5Q19++blGjx6nFi1aqXr1GrrxxgFq1qxl0Ifzgh7L2bOnq3//m3TddTeoVq3aOvfcJrruuhtDamt2X3zxqTIyMvTvf4/SOefU0/nnX6iHH35Mn3++NOiv2Xa7XU8+OVLnnFNXbdu21x133KUFC94L9JfNZlN0dHRgxMVqtcpms+n22+/Suec2UbVq1dWlS1d17dpT33yT/wfUunXr67bb7lTNmrXUtWsPNWp0rlatWlno+/j++/PUvXsv9ex5tWrVqqM777xXdeqcne9t+g0aNFgXXnix6tatp3//+2kdPJgSGKnp2bO3fvpphQ4c2C9JOnz4sJYv/79cA0d2y5d/pyuu6BD0b9as/xSqPbkpzPNeks4770LdeOMA1ahRMxC283Llld21Zs1q7d69S3v27NaaNb+pS5duOfa79NLO6tixk2rWrKX69Rtq2LAR2rRpo7Zs+Sdov379blDHjp1UrVp1JSUlF+p+9ejRO+i18MMP3yk9PV2dOl0hSUpOrqwbbxyg+vUbqnr1Grr22v666KKLc4wS1qtXXwMH3qGaNWtpwIBBioqKUkJCBfXqdY1q1qylQYPu0JEjR7Rx4wZJKvLzVJIGD75HzZu3VIMGjdS9e2+tXv2LHnlkmBo0aKQWLVrp0ks765dffpbkG9V87725evLJEWrduo2qV6+hbt16qkuXrlq48MMCfy/n97pYtepHbdq0USNHPqtGjc5VkyZN9dRTo7R69S/68891kk7tdXEqmNQJAMiVb5lV7kGna9eeeuih+3TDDX118cVt1LZtB1100cUFHrNq1bPyDA7ZNW3aLOjnJk2a6/3385+OEqqtWzfLarWqceOmgW0JCRVUq1Ztbd26ObAtOjpa1avXCPycmJikQ4cO5nPcLWratHlQ2GjWrIXS0lK1b98+Va1auHUZf/21Xjt3bg+a3mOaprxer3bv3qU6dc5W+fLlNWzYU3r44SFq1qy5br55YI7j5PdY/vXXn0pLS1P37p2D9snIyAia0lRQv/3113qZpqkbbugTtN3pdCohIWstVX6P5aFDB3XgwH5dcMFFedxG4dqa3datm1WvXv2gEbpmzVrK6/Vq27atqlQpUZLvw2l0dHRgnyZNmmf2197ASGtuPv54gT75ZKH27t2tjIwMuVwu1a/fIM/9Jd8HxuyyPwaFuY9btmxW797Bj3PTps0CH2jz06RJ88D35csnBD3XGzduqjp1ztGnny7RgAED9fnnS1SlSlW1bHlevsds1ep8Pfrok0Hb/FP7iqIwz3tJatTo3EIfs0KFCmrTpp0+/XSxTNNU27btVKFChRz77dy5Q9Omval169bqyJHDMk3fSNTevXt0zjn1AvuFctt+3br11LRpb2rt2jVq2rSZlixZpE6dLg88Nz0ej95+e5a+/nqZ9u/fL5fLKafTqejomKDjZH/+ZC8Q5Od/Th8+nPU7qijP05Nvq1KlSjlev5UqJQaCzJYt/8jpzNBDD90XdAzfbQVPoSzotqTg18WWLVtUuXKVoDVtZ599juLi4rVly2ade26TU3pdnAqCFAAgV1u3bla1atVyvaxhw0Z6//2FWrFiuVat+kkjRgzTBRdcpGefHZ/r/n4nfygIjS+YGIZvMkX2ghrZp+IVVl4FOUxTQSHo5IXkhmHkW8wj98vMzOuG0j6vevfuo2uv7Z/jsuwfKFav/kVWq1UHDhxQenqaypUrTIEDX0O8Xq8SE5M0adKUHHvExWVV1Sqo30zTK6vVqunT35LFYg26LHuIye+xjIqKyvc2CtvW4HaZeY56Fu50AXnv89VXy/TqqxM0ZMiDatq0mWJjy2nu3Dn64491+R4xv8egKPfxVGV/HHr27K0PPpivAQMGaunST9StW88CH6eYmJg8R4SK8lot7PM++/OqMLp37x2YHvjww4/nus8TTzykypWr6Ikn/qWkpGR5vV7dcsv1crmC23zybVsslhyv+5PvZ8WKldSuXQctXbpI1atX1w8/fB/Uz++++7bmz5+r++9/ROecU08xMTF69dWX5Ha7go6T2/Mn+zZ/f3m9vvYU9Xl68m2dfDt+/tvxfx0//hUlJ1cO2ievQiAF3S//Y+r7mtvzMO/Xd2khSAEAcvj555XatGljYFpVbsqVi1Pnzl3UuXMXXXppZz3yyFAdPXpE5csnyGazyesteiW+devW5Pi5du3akqSKFStIUtDC7Y0bg8/D5H/jzq8NdeqcI4/Hoz/+WBuonnfkyGFt375VtWvXKXLb69Q5W99++3XQh/g1a35XbGy5HB8w8tOgQSNt3vxPvtOW1qz5TXPnztHzz7+syZNf04QJL+jf/34maJ/8HsuGDRvp4MEUWa1WnXVW7qG5MOrXbyiPx6NDhw6pRYtWRTpGbGw5nXVWNa1a9ZPOO++CHJcXpa3+EZa0tLTAh981a1bLYrGoZs1agf02btygjIz0QFW3devWKCYmVpUr+/rLbrfneC79/vuvatasufr06RfYtnPnztDudBHuY506Z2vdurXq2rVHYNvJ62jysm7dmsCI6NGjR7V9+zbVqlUncHmXLt30xhuT9P7772rz5n+CbqMoCvNaPVlhnvdF0bp1m0ABkYsuyrmu6ciRw9qyZbMee2x44Dn822+rC3XsChUq6uDBlKDXfG5FUHr0uFpPPz1clStXUfXqNdS8ecvAZb/9tlrt23fUlVf6phx6vV5t377tlKenlcTzNDdnn322HA6H9u7do1atzs91n8L8Xs7r2Pv27dHevXsCYXrz5n90/PjxwONzKq+LU8EaKQA4wzmdLqWkHND+/fv011/rNWfODA0b9ojatu2gq67qnut13nvvHX355efaunWLtm3bqm+++VKJiYmBv5pXrVpNq1atVErKAR09erQQrTDkrnKWPJnTqNas+U3vvDNb27Zt1QcfzNd///uV+vW7QZIUFRWtJk2a6e23Z2vz5n+0evUvmjr1zaCjVa16lgzD0PLl3+nQoUO5VmmrWbOWOnToqHHjxui331Zrw4a/NWrUCCUnV1aHDpcW/gE8SZ8+/bRv315NmDBeW7du0f/93381Y8YUXX/9jUHn5SrITTfdqrVrf9dLL43Thg1/Za7p+jbwV/XU1BMaPXqE+va9Xm3atNPIkc/q66+/1NdfB6+pyO+xvOCC1mrSpJmefPJR/fjjD9q9e5fWrPlNU6e+ofXr/yh0W2vVqq0uXbrq2WdH6ttvv9auXTv155/r9Pbbs/TDD98V+ji33Xan3n33Hb3//rvavn2b/vprfWAxe1Ha2qVLVzkcDo0ZM1L//LNRv/yyShMmvKArr+wWmAIl+aYfjR07Wps3/6MffvheM2ZMVd++1wX6q2rVavrjj7XavXuXDh8+LK/Xq+rVa2r9+j/0448/aNu2rZo27U2tX1/wX/nzU5j72K9ffy1dukiLFy/Utm1bNX36FG3e/E8BR/aZNWuaVq36Sf/8s1HPPfe0EhIqBJ3rrXz58urY8TK98cZEXXjhxapcuUqBx/T//sj+7/Dhw5IK91o9WUHP+6KyWq1655339c4778tqtea4PD6+vBISErRo0YfasWO7fv55pV577eVcjpRTq1bn6/DhQ3rnndnauXOHPvhgvlasWJ5jv9at26hcuTjNnj09UGTCr0aNGlq58ketWfObtmzZrBdeeC5HVbqiKInnaW5iY8upf/+bNWnSy/r008XauXOH/v57vT74YH6g+mthfi/n5oILWqtu3XoaNeop/fXXev3xx1o9++xItWx5nho1aizp1F4Xp4IRKQAoaTZHPhOEivd2iuLHH5erd++rAouB69WrrwcffFRdu/bI84N/TEys3nlntnbs2C6LxaJGjZrohRcmBvYfMuRBvfbaBH3yyUdKTq6sBQs+yfU4AYYhd5Wqslh8j1T//jfrr7/Wa+bMaYqNLaf77nswqDrWk0+O0Nixo3THHQNUq1Zt3Xvv/XrooSGBy5OTK+v22+/S5MmT9Nxzz+iqq7rnetLNJ58cqYkTX9QTTzwol8ulFi3O0wsvTDyl88IkJ1fWCy9M1BtvTNTAgTeofPny6t69t2699faQjlOvXn299tpUTZ36hu69d7AkU9Wq1VDnzr7F6a+88qJiYmJ0112+NQnnnFNX99wzVC++OFbNmjUPjH7l91gahqEXX5yoqVPf0Nixo3T48CFVqpSoli3PU8WKlUJq7/DhIzV79nS99tor2r9/nxISEtSkSXO1adO+0Mfo2rWHMjIyNH/+XL3++itKSKigyy7rXOS2RkdH6+WXX9PEiS/qjjtuVXR0tDp27KShQx8K2u+CCy7MLOwwWE6nS5df3kW33XZn4PIbbrhZY8Y8rZtv7qeMjAy9//4iXX11X23c+LdGjnxSkqHLL79S11zTL9cP0IVVmPvYuXMX7dy5Q5MnT1JGhlOXXtpJV1/dVz/9VHBVy7vvHqqJE1/Ujh3bVa9efT3//Ms5pl316NFby5Z9VmCRCT//74/satWqrblzP5BU8Gv1ZAU9709FftNeLRaLnn76OU2c+KJuueV61axZWw8++KiGDr2rwOPWqXO2HnnkCc2ZM1OzZ09Xx46ddMMNN2vRoo9y3Ea3br5TRVx1VfBo38CBd2j37l16+OGhio6OVq9e16hDh0t14sTxot3ZTCXxPM3L4MH3qGLFSnrrrZnatWun4uLi1aBBI91yyyBJhf+9fDLDMPTccy/plVfGa8iQwTIMi1q3bqOHHnossM+pvC5OhWGezqfcDtGBA8cUKY+GYUhJSfER1SbkRD+VDaXRTy6XUykpu5WYeFbQyShjjFQZzmMlc6O5MB3xSjNjS+32ipPba8piMZgqUYyuvbanrrvuhnynaBaFzWaR2+0teEeEVVH66YsvPtXEiS/q448/K9TaFoRm3LhndfBgisaNmxDYxuspPPJ635ayPjcUhBEpAChBaWasDEfpnYOlzP5tzDRlpKfLsBhSdJTyW+QPoPilp6dr166deuutmerVqw8hqpgdP35cf/65Tl988amef/6lgq+AMoEgBQAlrMyGm9Lk9Srq7z8lSe7mLSRLzjUMAErOO+/M1pw5M9Sy5XkaMGBQuJtz2hk27GH9+ec69e7dRxdeWPCpIlA2MLUvm0iansWUsbKBfiobwjm1D4Xk8cj65zpJhjyNGxOkIhxTkcoG+qlsoJ/Cg6l9AIDTg9WqjMbNWCMFACgzeL8CgGLEID8AAJGvON6vCVIAUAz85yVxOjPC3BIAAFAQ//u11Vr0CXpM7QOAYmCxWBUTE6fjxw9JkhyOqMAZ7lEIXq+M7dvkleSpWUsK4cS1KH1eryGPh9HXSEc/lQ30U+kyTVNOZ4aOHz+kmJi4kE6UfjKCFAAUk/LlfSfM9IcphMBrynJon+/bWIdkIYRGMovFIq+XxfGRjn4qG+in8IiJiQu8bxcVQQoAiolhGEpISFR8fEV5PO5wN6dMMdLSVPHenpKkQ19/JzM6JswtQl4MQ6pYsZwOHTpBtdIIRj+VDfRTeFittlMaifIjSAFAMbNYLLJYKIEeCsPlVvTWrZIkh80uLyXkI5ZhSNHR0bLbXXzwi2D0U9lAP5VtTEIHAISdJ9wNAAAgRAQpAEBYGYah426iFACgbCFIAQAAAECIwhqk3G63JkyYoE6dOql58+bq3LmzXnvttaDKJaZpatKkSWrfvr2aN2+uAQMGaMOGDUHHcTqdGj16tFq3bq2WLVvq7rvv1p49e0r77gAAAAA4Q4Q1SE2bNk3vvvuuRowYoaVLl+qxxx7T9OnT9dZbbwXtM3PmTI0YMUILFixQUlKSBg0apOPHjwf2GTNmjJYtW6YJEyZo7ty5Sk1N1V133SWPh6kiAAAAAIpfWIPU6tWr1blzZ1166aWqUaOGrrrqKrVv315r166V5BuNmjNnju6++2516dJFDRo00Lhx45Senq7FixdLko4dO6YPPvhAw4YNU9u2bdW4cWO98MIL+vvvv7V8+fJw3j0AAAAAp6mwlj8///zz9e6772rz5s06++yztX79ev38888aPny4JGnHjh3av3+/2rdvH7iOw+HQhRdeqF9//VX9+/fX2rVr5XK51K5du8A+VapUUf369fXrr7+qQ4cOhW6PEUHnf/S3JZLahJzop7KBfopshiEZJ/9MX0UsXk9lA/1UNtBPkamw/RHWIDV48GAdO3ZMXbt2ldVqlcfj0UMPPaQePXpIkvbv3y9JSkxMDLpeUlKSdu3aJUk6cOCA7Ha7EhIScuxz4MCBkNqTmBhf1LtSYiKxTciJfiob6KfI5UxPC3xfqVKcVK5cGFuDwuD1VDbQT2UD/VQ2hTVILV26VIsWLdJLL72kevXq6c8//9TYsWNVuXJlXXPNNYH9jJNioVmIM5YVZp+TpaQci5iToRmG70UVSW1CTvRT2UA/RTbDMJSW7gr8fPDgcXnTvPlcA+HE66lsoJ/KBvopMvn7pSBhDVLjx4/XnXfeqe7du0uSGjZsqF27dmnKlCm65pprlJycLMk36lS5cuXA9VJSUpSUlCTJN/Lkcrl05MiRoFGplJQUtWrVKqT2mKYi7kkciW1CTvRT2UA/RS6v1aYDA25XtMMq02qjn8oAXk9lA/1UNtBPZVNYi02kp6fnGG2yWq2B0aQaNWooOTlZ33//feByp9OplStXBkJS06ZNZbfbg/bZt2+fNmzYEHKQAgCESVSUdj37gg6/MEGKigp3awAAKFBYR6Quu+wyTZ48WdWqVQtM7Zs5c6b69u0ryTfd45ZbbtGUKVNUp04d1a5dW1OmTFF0dHRgHVV8fLz69u2rcePGqWLFikpISNC4cePUoEEDtW3bNpx3DwAAAMBpKqxB6t///rcmTpyoZ555RikpKapcubKuv/563XfffYF9Bg8erIyMDD3zzDM6cuSIWrRooRkzZiguLi6wz/Dhw2Wz2fTggw8qPT1dbdq00fPPPy+r1RqOuwUACJVpyppyQJYMh1SxUrhbAwBAgQyzKFUZTlMHDkTOQj/DkJKS4iOqTciJfiob6KfIZhiGjhw5qrr1qkuSUrbukTcmNsytQl54PZUN9FPZQD9FJn+/FCSsa6QAAAAAoCwK69Q+AAAkyYwtp9+3HlSl+CjFeL2Slz/NAgAiGyNSAAAAABAighQAAAAAhIggBQAIOyM9XbXuGahKA2+W0tPD3RwAAApEkAIAhJ/XowpLFyl20UeSxxPu1gAAUCCCFAAAAACEiCAFAAAAACEiSAEAAABAiAhSAAAAABAighQAAAAAhIggBQAAAAAhIkgBAAAAQIgIUgAAAAAQIoIUAAAAAISIIAUAAAAAISJIAQAAAECIbOFuAAAAslh1uFsvOWxWyWoNd2sAACgQQQoAEHZmdLS2vTlLleKjFOP1Sl4z3E0CACBfTO0DAAAAgBARpAAAAAAgRAQpAEDYGakn1Lx2JdWoVE46cSLczQEAoEAEKQAAAAAIEcUmAABhZ8bEat0vf6tinENRsbEStSYAABGOIAUACD/DkCcxSd74KMnrlUySFAAgsjG1DwAAAABCRJACAIRfRoaq/fsxVXjsISkjI9ytAQCgQAQpAEDYGR63kt6arrjpUyW3O9zNAQCgQAQpAAAAAAgRQQoAAAAAQkSQAgAAAIAQEaQAAAAAIEQEKQAAAAAIEUEKAAAAAEJEkAIAAACAEBGkAAAAACBEBCkAAAAACBFBCgAAAABCRJACAAAAgBDZwt0AAABkWHT84nayWy2Shb/xAQAiH0EKABB2ZkyM/nnvE1WKj1KM1yt5zXA3CQCAfPFnPwAAAAAIEUEKAAAAAEJEkAIAhJ2RekKNW9XXWfVrSydOhLs5AAAUiDVSAICIYDuYEu4mAABQaAQpAEDYmdEx+mvZ90qIdcgeExPu5gAAUCCCFAAg/CwWZTQ4V+74KNmp2gcAKANYIwUAAAAAIWJECgAQfk6nqrzyomIcNrkefESy2cPdIgAA8kWQAgCEneF2qcor4yVJKffdT5ACAEQ8pvYBAAAAQIgIUgAAAAAQIoIUAAAAAISIIAUAAAAAISJIAQAAAECICFIAAAAAECKCFAAAAACEiCAFAAAAACEiSAEAAABAiAhSAAAAABAighQAAAAAhMgW7gYAACAZSq/fUFaLRTKMcDcGAIACEaQAAGFnxsbq7y9/UKX4KMV4vZLXDHeTAADIF1P7AAAAACBEBCkAAAAACBFBCgAQdkZqqhpc3kZV2lwgpaaGuzkAABSINVIAgAhgKnrDX5nfsj4KABD5CFIAgLAzo6K16d1FKh9rlyU6OtzNAQCgQAQpAED4Wa060aa9oqjaBwAoI1gjBQAAAAAhYkQKABB+LpcSZ89UbLRN3gEDJStvTwCAyMY7FQAg7AyXU9VHPC5JSrn+RimGtycAQGRjah8AAAAAhIggBQAAAAAhIkgBAAAAQIgIUgAAAAAQIoIUAAAAAISIIAUAAAAAISJIAQAAAECICFIAAAAAECKCFAAAAACEiCAFAAAAACEiSAEAAABAiGzhbgAAAJLkrpQowzDC3QwAAAol7CNSe/fu1aOPPqrWrVurRYsW6t27t9auXRu43DRNTZo0Se3bt1fz5s01YMAAbdiwIegYTqdTo0ePVuvWrdWyZUvdfffd2rNnT2nfFQBAEZmx5fTHrxu0e8NWqVy5cDcHAIAChTVIHTlyRDfccIPsdrumTZumJUuWaNiwYSpfvnxgn2nTpmnmzJkaMWKEFixYoKSkJA0aNEjHjx8P7DNmzBgtW7ZMEyZM0Ny5c5Wamqq77rpLHo8nHHcLAAAAwGkurFP7pk2bpqpVq2rs2LGBbTVq1Ah8b5qm5syZo7vvvltdunSRJI0bN05t27bV4sWL1b9/fx07dkwffPCBxo8fr7Zt20qSXnjhBV166aVavny5OnToUOj2RNKMEn9bIqlNyIl+Khvop8hmGJIhZf6X+TN9FbF4PZUN9FPZQD9FpsL2R1iD1Ndff6327dvr/vvv18qVK1WlShXdeOONuu666yRJO3bs0P79+9W+ffvAdRwOhy688EL9+uuv6t+/v9auXSuXy6V27doF9qlSpYrq16+vX3/9NaQglZgYX3x3rphEYpuQE/1UNtBPkStjd4qqXn+1bBZDUcs+l2Jiwt0kFIDXU9lAP5UN9FPZFNYgtX37ds2bN0+DBg3S3Xffrd9//13PPvusHA6Hrr76au3fv1+SlJiYGHS9pKQk7dq1S5J04MAB2e12JSQk5NjnwIEDIbUnJeWYTPMU7lAxMgzfiyqS2oSc6KeygX6KbIZhKD01Q9V++E6SdPDAUXlj3GFuFfLC66lsoJ/KBvopMvn7pSBhDVKmaapp06Z6+OGHJUmNGzfWxo0bNW/ePF199dWB/U6u4mQW4plWmH1yXkcR9ySOxDYhJ/qpbKCfIpfXEaWtb8xQXLRdckTRT2UAr6eygX4qG+insimsxSaSk5NVt27doG3nnHNOYLQpOTlZknKMLKWkpCgpKUmSb+TJ5XLpyJEjee4DAIhwNpuOdL9aaVf3kWycmQMAEPnCGqTOO+88bd68OWjbli1bVL16dUm+whPJycn6/vvvA5c7nU6tXLlSrVq1kiQ1bdpUdrs9aJ99+/Zpw4YNgX0AAAAAoDiF9c9+t956q2644QZNnjxZXbt21e+//6758+dr1KhRknxT+m655RZNmTJFderUUe3atTVlyhRFR0erR48ekqT4+Hj17dtX48aNU8WKFZWQkKBx48apQYMGgSp+AIAI53YrYckixUTbpW49JIs13C0CACBfYQ1SzZs312uvvaaXX35Zr7/+umrUqKHhw4erV69egX0GDx6sjIwMPfPMMzpy5IhatGihGTNmKC4uLrDP8OHDZbPZ9OCDDyo9PV1t2rTR888/L6uVN2IAKAsMZ4Zq33ubJCll6x4pJjbMLQIAIH+GWZSqDKepAwcip2KKYUhJSfER1SbkRD+VDfRTZDMMQ0eOHFXder5p3Slb98hLkIpYvJ7KBvqpbKCfIpO/XwoS1jVSAAAAAFAWEaQAAKXOlfmvqJcDABBuBCkAQKkyDEPHnR4dd3pynCfQd7nyvRwAgEhAkAIAAACAEBGkAAAAACBEBCkAAAAACBFBCgAAAABCRJACAAAAgBARpAAAAAAgRAQpAAAAAAgRQQoAAAAAQmQLdwMAADBjy+n3rQdVKT5KsaZXSnOHu0kAAOSLESkAAAAACBFBCgAAAABCRJACAISdkZ6uWvcMVKWBN0vp6eFuDgAABSJIAQDCz+tRhaWLFLvoI8njCXdrAAAoEMUmAABhZ9od2jlqvGKjbZLDIVFrAgAQ4QhSAIDws9uVcusdMv1V+9wkKQBAZGNqHwAAAACEiBEpAED4eTwq98P3ioq1Sxe3CXdrAAAoEEEKABB2Rka66vbvJUk6uG2PZIkKc4sAAMgfU/sAAAAAIERFClLbt28v7nYAAAAAQJlRpCDVpUsXDRgwQAsXLlRGRkZxtwkAAAAAIlqRgtTChQvVuHFjjRs3Tu3atdOIESP0+++/F3fbAABniJnLt4a7CQAAhKRIQapBgwZ68skn9b///U9jx47V/v37deONN6p79+6aOXOmDh48WNztBACcpg6nufTBr7vC3QwAAEJySsUmbDabrrjiCk2cOFGPPvqotm3bpnHjxumSSy7R448/rn379hVXOwEAp6kdh9PC3QQAAEJ2SuXP16xZow8++EBLly5VTEyMbrvtNl177bXat2+fXn31Vd17771asGBBcbUVAHAa2n0kPdxNAAAgZEUKUjNnztSHH36ozZs365JLLtG4cePUsWNHWSy+Aa6aNWtq1KhR6tq1a7E2FgBw+tl9lKJFAICyp0hBat68eerbt6/69Omj5OTkXPc566yzNGbMmFNqHADg9Hco1RnuJgAAELIiBakZM2aoWrVqgREoP9M0tXv3blWrVk0Oh0PXXHNNsTQSAHD6OprhDncTAAAIWZGKTVxxxRU6dOhQju2HDx9W586dT7lRAIAzx9H04CDl8njD1BIAAAqvSEHKNM1ct6empioqKuqUGgQAOLMcTXcF/Zzm8oSpJQAAFF5IU/vGjh0rSTIMQxMnTlRMTEzgMo/Ho99//12NGjUq3hYCAE5rx9LdSrNH6byh70iS5lij5AhzmwAAKEhIQeqPP/6Q5BuR+vvvv2W32wOXORwONWrUSLfddlvxthAAcFo7mu6WDEMHYxMkSSdcHjmi7AVcCwCA8AopSL311luSpCeffFL/+te/FBcXVyKNAgCcOVJPmsp3IsOjiry9AAAiXJGq9vmn+AEAcKpSnR453C6N+t90Od2m0nq9LCWWC3ezAADIV6GD1JAhQ/T8888rLi5OQ4YMyXff11577ZQbBgA4/bk8Xrm9pmK8HvVfuViSND/1+TC3CgCAghU6SMXHx+f6PQAAReWv0Oe2WvVu10HaczRdFUwjzK0CAKBghQ5S2afzMbUPAFAcUp2Z66McDi265k4t35Six40izToHAKBUFek8Uunp6UpLSwv8vHPnTs2aNUvfffddsTUMAHD6S3f5Tr4bbbMqyuZ7S8pwcUJeAEDkK1KQuvfee/Xxxx9Lko4ePap+/fpp5syZuvfeezV37tzibB8A4DTmr9gXYzVUZ89m1d+/VelOVwHXAgAg/IoUpNatW6cLLrhAkvT5558rKSlJ33zzjcaNGxcokQ4AQEH8U/sqWFwaOby/ls24T97U1DC3CgCAghV5al+5cr7StN999526dOkii8Wili1bateuXcXaQADA6Ss9c0Qq2mbNts0MV3MAACi0IgWpWrVq6csvv9Tu3bv13XffqV27dpKklJQUTtILACg0/9S+aHtWkMo46QS9AABEoiIFqfvuu0/jx49Xp06d1KJFC7Vq1UqS9P333+vcc88t1gYCAE5fgTVS9qy3owwPxSYAAJGvSDVmr7rqKp1//vnav3+/GjVqFNjepk0bXX755cXWOADA6S3NmXNEKt3NiBQAIPIV+WQdycnJSk5ODtrWvHnzU24QAODMkZbb1D43I1IAgMhXpCCVmpqqqVOnasWKFUpJSZHXG/ym99VXXxVL4wAApzd/kIoJKjZBkAIARL4iBal///vf+umnn9S7d28lJyfLMIzibhcA4AyQ6vSFpqjsa6QYkQIAlAFFClL/+9//NGXKFJ1//vnF3R4AwBkka2pf9iDFGikAQOQrUtW+8uXLq0KFCsXcFADAmSYwtY81UgCAMqZIQeqBBx7QxIkTlZaWVtztAQCcQfxBKsqa9XaUTpACAJQBRZraN3PmTG3btk1t27ZVjRo1ZLMFH+ajjz4qlsYBAE5v/tEnhy3b1D6KTQAAyoAiBSnOFQUAKA7+IBVlo9gEAKBsKVKQGjJkSHG3AwBwBvJP47OUK6dVi/6rJz9ep+NWu7ymKQsVYQEAEaxIa6Qk6ejRo3r//ff10ksv6fDhw5KkdevWae/evcXVNgDAac7pH5Fy2OQ+t7E2JNeWaVjk9JhhbhkAAPkr0ojU+vXrNWjQIMXHx2vnzp267rrrVKFCBS1btky7du3S+PHji7udAIDTkL/UeZTNInu2ghMnnB7F2Ir8tz4AAEpckd6lnn/+eV1zzTX64osv5HA4AtsvueQSrVq1qtgaBwA4vQXWSJluVZ84Xg9+947sHpdcHtZJAQAiW5GC1Jo1a9S/f/8c26tUqaL9+/efcqMAAGcGf5CKNr2qOnG8Hvx+nmwej1xM7QMARLgiTe2LiorS8ePHc2zfvHmzKlWqdMqNAgCcGfzFJuxRdh0YcLu++HOvPBarXF5GpAAAka1II1KdO3fW66+/LpfLFdi2a9cuvfTSS+rSpUuxNQ4AcPryeE15vL6RJ3tsjHY9+4LG9xgqp80uNyNSAIAIV6Qg9cQTT+jgwYNq27atMjIyNGDAAHXp0kXlypXTQw89VNxtBACchvyFJqSs80jZM7+yRgoAEOmKNLUvLi5O8+bN04oVK7Ru3Tp5vV41adJEbdu2Le72AQBOU9lPvOuwGnLtO6DktCPab0YFyqIDABCpQg5SXq9XH374oZYtW6adO3fKMAxVr15dycnJMk1TBidQBAAUgj8sOayGrOlpanBeAy2VdO5DC+TyMrUPABDZQgpSpmnqnnvu0bfffqtGjRqpQYMGMk1TmzZt0rBhw/TFF1/ojTfeKKm2AgBOI4HS5zZrjsuY2gcAiHQhBakPP/xQK1eu1KxZs3TxxRcHXfbDDz/ovvvu08cff6yrr766ONsIADgNOT3+IJVzuS7lzwEAkS6kYhNLlizR3XffnSNESVKbNm1055136pNPPim2xgEATl9ZI1I534rcjEgBACJcSEHqr7/+UocOHfK8/JJLLtH69etPuVEAgNOfM58gxdQ+AECkCylIHTlyRImJiXlenpiYqCNHjpxyowAApz9/kIrOdY0UU/sAAJEtpCDl8Xhks+W9rMpqtcrj8eR5OQAAfhn+NVJ2RqQAAGVPyFX7hg0bJofDkevlTqezWBoFADj95T+1jxEpAEBkCylIXXPNNQXuQ8U+AEBh5FdswsmIFAAgwoUUpMaOHVtS7QAAnGHyG5Giah8AINKFtEYKAIDiEhiRsjK1DwBQ9hCkAABhkTUilVvVPkakAACRjSAFAAiLQNU+ziMFACiDQlojBQBAcQmMSNktMqOitendRfpxy0FlpNiZ2gcAiHiMSAEAwiLD7TvvYJTNIlmtOtGmvXa3ai2vxcqIFAAg4hGkAABhkVv5c0dm4QmXlxEpAEBkY2ofACAs/FP7om1WyeVS4uyZaplyQjZ7K8qfAwAiHkEKABAW2UekDJdT1Uc8ruqS7A8tYI0UACDiEaQAAGHhyl61z2LV4W69dCTNJa/FIicjUgCACBcxa6SmTJmihg0basyYMYFtpmlq0qRJat++vZo3b64BAwZow4YNQddzOp0aPXq0WrdurZYtW+ruu+/Wnj17Srv5AIAQZR+RMqOjte3NWVr+/JvKsDnkYUQKABDhIiJI/f7773rvvffUsGHDoO3Tpk3TzJkzNWLECC1YsEBJSUkaNGiQjh8/HthnzJgxWrZsmSZMmKC5c+cqNTVVd911lzweT2nfDQBACJy5FJuwZxabcHsZkQIARLawB6kTJ07oscce07PPPquEhITAdtM0NWfOHN19993q0qWLGjRooHHjxik9PV2LFy+WJB07dkwffPCBhg0bprZt26px48Z64YUX9Pfff2v58uXhuksAgELwn5A32mYNbLNbDUlijRQAIOKFfY3UqFGj1LFjR7Vt21ZvvvlmYPuOHTu0f/9+tW/fPrDN4XDowgsv1K+//qr+/ftr7dq1crlcateuXWCfKlWqqH79+vr111/VoUOHkNpiGKd+f4qLvy2R1CbkRD+VDfRTZDEMyVC2qn12iyypJ9S8XnU1lzTsoQVye2Mkgz6LRLyeygb6qWygnyJTYfsjrEFqyZIl+uOPP7RgwYIcl+3fv1+SlJiYGLQ9KSlJu3btkiQdOHBAdrs9aCTLv8+BAwdCbk9iYnzI1ylpkdgm5EQ/lQ30U+RIO5QqZ+aoU5WkOMW404Mu95imYmIcSqwYG47moRB4PZUN9FPZQD+VTWELUrt379aYMWM0Y8YMRUVF5bmfcVIkNM2Cp3sUZp/cpKQcUxGvWuwMw/eiiqQ2ISf6qWygnyKLYRhKS3crw+Vby5p6PF1WuYL2cbu9SktzKsXrLfLvdJQMXk9lA/1UNtBPkcnfLwUJW5Bat26dUlJS1KdPn8A2j8ejlStX6p133tFnn30myTfqVLly5cA+KSkpSkpKkuQbeXK5XDpy5EjQqFRKSopatWoVcptMUxH3JI7ENiEn+qlsoJ8ih9c0s6r2WS0yT6oP5PKakkmfRTL6pmygn8oG+qlsCluxiYsvvliffPKJPv7448C/pk2bqmfPnvr4449Vs2ZNJScn6/vvvw9cx+l0auXKlYGQ1LRpU9nt9qB99u3bpw0bNhQpSAEASofLa8r/mSEqW7EJP6r2AQAiXdhGpOLi4tSgQYOgbbGxsapQoUJg+y233KIpU6aoTp06ql27tqZMmaLo6Gj16NFDkhQfH6++fftq3LhxqlixohISEjRu3Dg1aNBAbdu2LfX7BAAoHH+hCclX/jwtI/hyN1X7AAARLuxV+/IzePBgZWRk6JlnntGRI0fUokULzZgxQ3FxcYF9hg8fLpvNpgcffFDp6elq06aNnn/+eVmtOf/CCQCIDP5pfYZ8Jc/TTrrc7SVIAQAiW0QFqbfeeivoZ8MwNHToUA0dOjTP60RFRempp57SU089VdLNAwAUk+wn4z25qJAkebymvCwYAABEsLCfkBcAcOYJFJqw5/02xKgUACCSEaQAAKXO6ck8GW8uhSb83B4KTgAAIhdBCgBQ6rJP7csLBScAAJGMIAUAKHUZ+QQpS+aSKRdT+wAAEYwgBQAodU637wy8uQUpm8W3jal9AIBIFlFV+wAAZ4aTR6RMR5S2vjFD8TF2mRsdkptiEwCAyMaIFACg1PmLTUT5i03YbDrS/WqlX91Hht33Nz6CFAAgkhGkAAClLr81Uv6pfS6m9gEAIhhT+wAApS5HkHK7lbBkkaJj7IpWsm8TVfsAABGMIAUAKHWuk4KU4cxQ7XtvkyTFjFosial9AIDIRpACAJQ6V+Zok8OaOSJlWHT84nayWy2yWq2SPEztAwBENNZIAQBKnb/YhD9ImTEx+ue9T5Sy+DN5o6MlMSIFAIhsBCkAQKnzjzY5bEaOyyg2AQAoCwhSAIBSd/KIVHY2qy9cMSIFAIhkBCkAQKlzujPXSPmLTaSeUONW9VWlXm3FudIlUbUPABDZKDYBACh1rlxGpGwHU3xfM7e5vEztAwBELkakAAClLjC1L9cT8mZO7WNECgAQwQhSAIBS5y9/LqtF7pMus/pHpAhSAIAIRpACAJQ6/9Q+l8fUCZdH2Wv3WTJHpDxM7QMARDCCFACg1PmDlN2as/y5PTNIuajaBwCIYAQpAECpy7f8OWukAABlAEEKAFDq/OXP7bkWm/BtczO1DwAQwQhSAIBSF5jaZ8k5tc9/Ql6KTQAAIhlBCgBQ6vIvf86IFAAg8hGkAAClLqvYRC5ByurfhxEpAEDkIkgBAEpdYI1ULkHKSrEJAEAZQJACAJS6fMufZ25jah8AIJLZwt0AAMCZxeM15c48R5S//Llpd2j36PGyWC0yHFGSmNoHAIhsBCkAQKnyj0ZJ2cqf2+06OHCw7DarLKt3SFIgbAEAEImY2gcAKFXO7EEqt/Ln/qp9Hqb2AQAiFyNSAIBS5XT7ApLFyCosIY9HsT8sl81qkSPubEmMSAEAIhtBCgBQqpyerIp9huELUkZGus6+rqckKWrJakkEKQBAZCNIAQBKlX9EKrj0uaH0Bo1kSLJmnkjKxdQ+AEAEI0gBAEqVM5fS52ZsrDZ99YPsNquMjfslcR4pAEBko9gEAKBU+YOUI5eT8UpZI1UupvYBACIYQQoAUKoy/FP7bLm/Bdn8J+Rlah8AIIIRpAAApcrlyblGykhNVd3ObVS740WKcqZLotgEACCysUYKAFCq/CNSDmv2c0iZiv57vSTJlrmZYhMAgEjGiBQAoFS5spU/z40tczsjUgCASEaQAgCUqqwRqTyClOFfI0WQAgBELoIUAKBU+afs2YKm9mWxBqr2MbUPABC5CFIAgFIVGJHKo2qf3Xc+XkakAAARjSAFAChVBZ1HymbJnNrnNWWahCkAQGQiSAEASpUzl/Ln2dmybfdQcAIAEKEIUgCAUuV0FxCkLFlrp1xM7wMARCiCFACgVGWNSOVebCL7iBQFJwAAkYogBQAoVU63b5Qpr2ITFkPyRyxGpAAAkYogBQAoVQWtkTIMI1Aa3V8qHQCASEOQAgCUKmfghLy5T+2TJJvF9/bkptgEACBC2cLdAADAmSW3ESnTZte+h56Q1WJINrtvRMrFiBQAIHIRpAAApSrXqX0Oh/Y/PEx2m1WmxxOo3McaKQBApGJqHwCgVAWm9uVRbEJStiDFiBQAIDIxIgUAKFW5lj/3ehX113rZbFa5zqkXKIHuYo0UACBCEaQAAKUqtxPyGulpqnt5W0nSH3/vCIxIuRmRAgBEKIIUAKBUOTPXPZ1c/txdKTHwvX9Eiqp9AIBIRZACAJSqrPLn2ar2xZbTX79tDBSbsFNsAgAQ4Sg2AQAoVf41UvkWm+CEvACACEeQAgCUqlyLTZzEf0Jeik0AACIVQQoAUKpyLTaRlqY6/XqoRp9uMtLSGJECAEQ81kgBAEpVrifkNb0qt+L7wPdZVfsYkQIARCZGpAAApSqr2EQ+U/v855FiRAoAEKEIUgCAUuP2mvIPMp1c/jy7QNU+1kgBACIUQQoAUGqyjzDlV7XPamGNFAAgshGkAAClJsOdFYzyG5HKmtrHiBQAIDIRpAAApcY/wmQxskadcmNjRAoAEOEIUgCAUuMfkcpvWp+UdY4pN2ukAAARiiAFACg1/ql6+U3rk7JOyOtkRAoAEKEIUgCAUpNV+ryQI1KskQIARCiCFACg1GSdjDfv9VFSVrEJRqQAAJGKIAUAKDX+YFTYNVIEKQBApCJIAQBKTUZhp/ZlrpFiah8AIFLZwt0AAMCZwxWY2pcVpAxDMq02HbzldlkshmS1ycaIFAAgwhGkAAAlwpX51Z5t28nlz32nizLkjYrS7jEvym6zyvR4FJV5ebrbK9dJxwAAIBIwtQ8AUOwMw9Bxp0fHnR4ZRlZhCVfmeaH8J+M1DENpbq+cHlPKVn/CX2wizeXViZOOAQBAJGBECgBQavIsf26ash5MkdVilatChcDUPxdT+wAAEYogBQAoNc7ACXmDR5iMtFQ1alFfkvTH3ztkzxyxcnspNgEAiExM7QMAlJrCn5CXESkAQGRjRAoAUGoCJ+Q96TxSZmw5rdtxSHarr9iE3XpEkuSi/DkAIEIxIgUAKDXOXMqf58ZfbMLtZUQKABCZCFIAgFJT+Kl9vjVSjEgBACIVQQoAUGqyRqROKjaRnq4adw3UWYNvkZGezhopAEDEI0gBAEqNf0Tq5DVS8nqUsGSh4hd/LHk9svmr9jEiBQCIUAQpAECpCZQ/t1C1DwBQthGkAAClJrBG6uQRqZPYrFnnkTJNRqUAAJEnrEFqypQp6tu3r1q1aqU2bdro3nvv1T///BO0j2mamjRpktq3b6/mzZtrwIAB2rBhQ9A+TqdTo0ePVuvWrdWyZUvdfffd2rNnT2neFQBAIWR4/MUmjHz3y17Vj5PyAgAiUViD1E8//aSbbrpJ8+fP18yZM+XxeHT77bcrNTU1sM+0adM0c+ZMjRgxQgsWLFBSUpIGDRqk48ePB/YZM2aMli1bpgkTJmju3LlKTU3VXXfdJY/HE467BQDIg6uQ5c+zF6Ngeh8AIBKFNUhNnz5dffr0Uf369dWoUSONHTtWu3bt0rp16yT5RqPmzJmju+++W126dFGDBg00btw4paena/HixZKkY8eO6YMPPtCwYcPUtm1bNW7cWC+88IL+/vtvLV++PJx3DwBwkjyLTZzElm0NFQUnAACRyBbuBmR37NgxSVJCQoIkaceOHdq/f7/at28f2MfhcOjCCy/Ur7/+qv79+2vt2rVyuVxq165dYJ8qVaqofv36+vXXX9WhQ4dC376R/0yTUuVvSyS1CTnRT2UD/VT6DEMysn3vF1T+PHt/nNQ3VqshiyF5Tcnp9dJ3EYTXU9lAP5UN9FNkKmx/REyQMk1TY8eO1fnnn68GDRpIkvbv3y9JSkxMDNo3KSlJu3btkiQdOHBAdrs9EL6y73PgwIGQ2pCYGF/U5peYSGwTcqKfygb6qXSlHfJN006sGBvY5slMTDF2m+xWa2C7ke17u9Uq02qV3WpRhtsrq92mxMS4Umo1CovXU9lAP5UN9FPZFDFBatSoUfr77781d+7cHJcZJ8XCwlRwKkqVp5SUY4qU4lCG4XtRRVKbkBP9VDbQT6XPMAylpbslSSleb+B3clqGb5vVkFzZ1rEa2b53eTwyPR7ZrIYy3NLx1AylpBynel+E4PVUNtBPZQP9FJn8/VKQiAhSo0eP1tdff623335bVatWDWxPTk6W5Bt1qly5cmB7SkqKkpKSJPlGnlwul44cORI0KpWSkqJWrVqF1A7TVMQ9iSOxTciJfiob6KfS5X+osz/uQWukzFx2zvazryCFRy63Sd9FIPqkbKCfygb6qWwKa7EJ0zQ1atQoffHFF5o9e7Zq1qwZdHmNGjWUnJys77//PrDN6XRq5cqVgZDUtGlT2e32oH327dunDRs2hBykAAAlK6OQVfskyW7xzUagah8AIBKFdUTqmWee0eLFi/XGG2+oXLlygTVR8fHxio6OlmEYuuWWWzRlyhTVqVNHtWvX1pQpUxQdHa0ePXoE9u3bt6/GjRunihUrKiEhQePGjVODBg3Utm3bcN49AMBJAifkLeA8UlJW2HJRtQ8AEIHCGqTmzZsnSRowYEDQ9rFjx6pPnz6SpMGDBysjI0PPPPOMjhw5ohYtWmjGjBmKi8taeDx8+HDZbDY9+OCDSk9PV5s2bfT888/Lmm3xMgAg/JyBE/KeNCJlsepI996yGIZk8f3uzgpSjEgBACJPWIPUX3/9VeA+hmFo6NChGjp0aJ77REVF6amnntJTTz1VnM0DABQj0zTzPI+UGR2tHVNm+Sr2eTySKdkyR63cXkakAACRJ6xrpAAAZw631wzUlMgxIpULu4URKQBA5CJIAQBKRYY7KxAVqtiE1V9sghEpAEDkIUgBAEqF05M9SAUXmzBST6hJjYpqcFZ5GaknJEk21kgBACIYQQoAUCoC66OsRo4TreeGESkAQCSLiBPyAgBOf87MQJTb+igzJlbrf9sgu8UqMyZWkmTLXCPl9jIiBQCIPAQpAECpCJxDypbLZAjDkCcxSRarVcqs2seIFAAgkjG1DwBQKjI8/ql9hXvr8e/nZI0UACACEaQAAKUiMCKVS5AyMjJ01r8eVeUnH5aRkSEp23mkGJECAEQgghQAoFRkTe3LpdCEx61Ks6erwqz/SB63pKwRKar2AQAiEUEKAFAq/FP7CnMyXkmyWTJHpLyMSAEAIg9BCgBQKvwjS7kWm8gFa6QAAJGMIAUAKBUZ7lCLTfir9hGkAACRhyAFACgV+RWbyI0tcz+KTQAAIhFBCgBQKvxT9OyFntrHiBQAIHIRpAAApSIjMCKVS9W+XGRV7WNECgAQeQhSAIBS4Q9EhS42YWFECgAQuQhSAIBS4S9/XuhiEzZ/1T5GpAAAkYcgBQAoFaEWm4jylz93MyIFAIg8BCkAQKkIBKnCTu2zcR4pAEDkIkgBAEqFf2pfoUekbIxIAQAily3cDQAAnBn8RSMctlyq9hkWnbi4nQzDkAxfgPKvpWJECgAQiQhSAIBS4R9Zyq3YhBkToy0LFstutcr0eCQza0QqgxEpAEAEYmofAKBUZIRYbIIRKQBAJCNIAQBKhdMTWrEJ1kgBACIZQQoAUCryK39upJ5Qw+b1dE6Ts2WknpCUNSKV4fbKNDmXFAAgsrBGCgBQKvwn1s1rap/tYErQz1HZRq5cHlN2ay5FKgAACBOCFACgVGQEik3kDERmdIw2frVcNqtVZnSMpOApgBlur+xWa+k0FACAQiBIAQBKRbrbI0mKtucSiCwWZTQ8V16rVcqs2mezGDIkmfKdgypOBCkAQORgjRQAoFSku3wjUlH2wr31GIYRGJXKcHlKrF0AABQFI1IAgFIRGJGy5RxZMpxOJb32sqwWQ3vve0im3SHJt54qw+2lBDoAIOIQpAAApSIwIpVb+XO3S5UnjJMk7b1riOQPUjaLlMFJeQEAkYepfQCAEuf2eOX2+qr2FXZqnxRcAh0AgEhCkAIAlLj0bEEoxm6V1VK4Uub+0auCgpStkCf5BQCguPDOAwAocf4gZci37slmsfh+KIC/VLoznyBlGIZsNqsMg/NMAQBKD0EKAFDi0l3+0ueWkAKPI7MwRTpT+wAAEYYgBQAocf4glFvFvvw4/CNSVO0DAEQYghQAoMRlZBuRCoWjkGukAAAobQQpAECJK/qIFEEKABCZCFIAgBIXCFJFHpHyFHubAAA4FQQpAECJy5raF+KIFFP7AAARiiAFAChxWVP7Qnvb8U8FTHMxIgUAiCwEKQBAifOXP48KNUhlTgVMczIiBQCILLZwNwAAcPrLWiOVx9Q+w1B6g0a+c/RmO8+Uf39GpAAAkYYgBQAocemu/Kf2mTGx2vT1D7JbrTI9Hsn0bQ+MSBGkAAARhql9AIASl+4uWrGJKNZIAQAiFEEKAFDiChqRyksMU/sAABGKIAUAKHFpBZQ/N9JSVbdTG9XueJGMtNTA9qjMqX2pLopNAAAiC2ukAAAl7oTTF6TKOfKY2meaiv57feB7P/+IVDojUgCACEOQAgCUuBNOtySpnCP3tx0zKlqb538im9UiMyo6sN1fLp2pfQCASEOQAgCUuBMZviAUF5XHiJTVqtS27WW3WqVsVfv8I1KpToIUACCysEYKAFDijvtHpKJC+/tdVLapfWa2KX8AAIQbI1IAgBLnH5HKc42Uy6VKc2fJYrHowA23SDa7pKwqfx5TcnlMOWxG7tcHAKCUEaQAACXOX2wiLo8RKcPl1Fn/flySlHJtf5n+IJWtyl+qyyNHiOXTAQAoKbwjAQBKlGmagWITcXmNSOXBajFkt/pGoajcBwCIJAQpAECJSnN55c1c3pRX1b78BApOEKQAABGEIAUAKFH+0SirIUXbQ3/b8U/vS+OkvACACEKQAgCUqEChiSibDCP0YhExmeGLqX0AgEhCkAIAlKgj6S5JeReaKIh/at/xDIIUACByEKQAACXqUJovSFWMsRfp+v5zTx3PcBdbmwAAOFUEKQBAiTqcmhmkYosWpOIzg9QxghQAIIIQpAAAJco/IlWhyCNSvql9BCkAQCQhSAEAStShVKekok/ti3MwtQ8AEHkIUgCAErXvmC9IJcU5inR9f5GKY+kEKQBA5CBIAQBK1K6j6ZKkauWji3R9pvYBACJR0WrRAgBQSLuO+ILUWQn5Byl3pcRct8dRbAIAEIEIUgBwBirKiXElyTTNQu+7Yd9xHUlz6XCaSxZDqlkhJu/jxpbTX79vlN1qlenxSNluhql9AIBIRJACgDNMjJEqw3msSNc1HfFKM2ML3O/dX3boxa83BX6ul1ROsQ5rkW4zjvNIAQAiEEEKAM4ghmHIcB6Tuf1Hye0M7co2h4yarWU4yuU7MuU1Tc35aXvQtsvqJxWluZKkuMw1UkcJUgCACEKQAoAzkdsp05Ue0lUKOxlw7e5j2nfcqVi7Vc/2aqyUYxnq3rhy/sdOS1PtW/rJMAxtmTNfZnTWNED/iNSJDI+8pilLEaclAgBQnAhSAIBitWbXUUlSq5oJalqtvCpF2QpeW2V6VW7F94HvsyuXGaRM+ab3lY8u2vmoAAAoTgQpAECx2rD/uCSpbnK5Ql/HdERp++SZslosMh1RQZc5rBaVc1h1wunRwVQXQQoAEBEIUgCAYvX3/hOSpHOSCh+kZLPpaI+rZbdapZOq9klSYjmHTjjTdDDVqTqVCi52AQBASSNIAUAxKkpZcdM0i3y9SOPyeLU5JVVSiEGqAInlHNp2KE0pJ1zFdkwAAE4FQQoAikmRyoobhmx2h9zOjJBvr7ClyEvTloOpcntNxUVZVSU+quAr+LndKv/5YlktFh3q0k2yBr89VYr1Tec7eCLESoMAAJQQghQAFIMilxWPjpdRub7MXeskdwhhqpClyEvbhsxpffWT40IaZTOcGap59yBJ0uG/d8iMOTlIOSRJKakEKQBAZCBIAUBxCrGsuGGLKtr1Qm1XKfl7nz9IFd+0Psk3tU+SDjK1DwAQIQhSACLe6bJ+qESYpuT1SKZb8npkeN2S6fF9b7qzlRI3JMOQDIsM1wEp41i2ETBDppG5z0n7yrBmfi1cH/gr9jVIjivGOylVjvMFzr3Hco7aLV67R5+u36eeTarqykbJge1l6XlTltoKAPAhSAGIaEVad6QwrR8yTcmdISPjqOTJkOHJkOHOyPzeKcOTIXmcvrDjdfm+Goasm8op6uheyZ0uw+uSPK7gfbyuzGDk9YUk05TklUxT5UxP6dw1f6iyOhRjsUsWu0yrzffVkvnVsGpkSobSHRbV/SNB9o1RksUmmyNGpsUhWR2SNUp2i11ea5Tchl2m1SGvJUrySDrfLrml8luWyBsdL9PqkMdwyG6P0rmmR42MbbIcSpHlaAXJ6pBpjdIf+zM06rM/5ZVFP205pLqJsaqXXK5MPW/KUlsBAFkIUgAiVpHXHRV1/ZDHKSPjiCwZR3xf0w/L8H9/0lfDeUyG64QM53EZruMynCd8P59ct7uQrEW6Vv5M/2iS76fMAOb7Gmo7fSHO6wt3+ezXRJIskg7kvU90Xhf0iJEk1fj+sRwX1ZT0WZQkp6S3srZfIumfaMltWuSUXeYCh6KjY2VYrZLX43sMLDbJYssMfPl8b4uWKp4tRSXJtEbJtEZJ1iiZtsyv1iiZtuhs30fl+D7r8S6cUn+OAwCKDUEKQOQLZf2QxyWL4ZVx6B/ZvNtlpB+WJeOwZMtQzMG9MtKPyOI8KiPdH4wOZwUkd1qxNNeUERgxCfqwbY3ybbfYJKtvVEeOOFkq1pDn6H6Zpikzc7t/lCcw8mPYJMOSOTJkkeGIkVG7rdKjqgbCgu+rNbBvbtPxDEOKztgjc/P/+R5Tf7iSMr/33QOZpi84mVkjYYbVJqPG+XJaE2R6XDI87swphW4ZXpfWbE/RjB/+Ua3yNj1yaW2dcDpleFwqZ7h80wg9Thlep5wu3/deV7oMj1MWr1NGRqoSPl8k2QydaN9OhumW4XUGLrd6nDp07JgccivO5vGN8GULgzbDK5syJG+GlBr66E52jlO4rmlxZPW5LVsYs0ZJtmzPA/9ltmhZ5ZZ5fL9MGTKtjszniF2y2jNH8uyBET3/80NR8ZLXXeR2lqWphGWprae7ovSFRH/g9EWQAhB53GmyZByRJeOoLCf+kfavldJ9Qcdwpfm+Zv7TST8b2T5cnjzpqTDlD0wZMqPKy4xKkDcqQWbmP2/Q1woyHXG+f/Zyge+jlSrvrtUyPd5CrykyYhLkqNZErm2/ynSFEOSi4mSLT1KUxyPJLSnDl4cKmulnscgmlwIlGwxDgbVReTQ58BEoKk62ijVl9xjZtwYs/6eCvvZW0NVnlZelVjXZPb71WYbVItMRpzQzVoZh6KjbK68MZWQ78a6RekIJt78nSdr69EyZMeVkMaQES5qi3McVbbWo31v/aPMhp6ZeVUPtasXqkz8OatRXO1QvwdT866rrlnc3KuV4moa3r6gO1SX3jt8k54nMoOfJFvo8mdMms2/LnGZZrpJMtzMz+PmmZCrzn+/7zECYGQzlyfAFTf/D6XXKcDolnVqYK5T/SrEWu0xbjEx7jExbjGSLyfw51vc187Ls2232zKBti/Zdx39de3TWMewxvhE6iz3wXGba45mtqH0h0R84fRGkABQ/r8c39S0j2+iP0z8t7qiMjKNZU+T8+2QczRoZ8oR+TqXsTBlSVHl5oyr4gk90ghzxiUozyp0UiirkCEpmVPmQp2dJvr/Ums49vuld3sJX3ysyi1WG80ToZdMzy60Xqe5fAbe5ZkuCpCg1suyUuXmTPG5fwDCjo2XUvEiGI7RKfoZhyOo8JnPHTzLlVqOYeG0+FK21f61XW2+qFv2eoFRFq0PVE9KBv9WsSqymH6ukd//xqEPz2vKeOBFSOPWHWmeoj6nXIzmi5ahUU66dayXXCV8w87gCo3XKvuYt2xo4WSyyRcfLc2i7b42cx+nbzx/eAmvmXIERPXlcgdE4w+uS4XRJzqMhPbaFZRqWwOiqosor2hEv0xYrxcYp3ozKCm32WJk231fZooN+9n2NyfreFiNlBj1Z8p7UyrTHyFHkvpDoD5zWCFIAcvI4fWt/nMdkOI/L4vJ9NTIOZwtB/kB0WIbzqCzpR2Q4M8NQEf9qmZ1pWH2hxhGXOeUpKugv79n/ch74y3vmhzojuryMczoqzVFVpmnKMKSkpHidOHBMp937eFHLrRfzbbq80s8pSZKk8xKOy3S5ZWYGKdlCD6bZed1OmaZTTeJt+lTRWnPQor3HXFqx3zcJr3uVI5Lb1JWV3Zq+MVbf7rboaIY377VYBQnxMZUkQ7FSdAXfCKUKf3+NmAQZ1ZrIGcqIpGkGpllmWOJ9o7KuVMk/KutKzRqhdaWdtD1V9oyD0tGdkistEM4Mjytr1M3rkpFZxMQwvb6A506XMo4E3bNieCb5XtdBocv/mo6V7LGyWA0p9ZDvd4DF7gtegamvtqxCJ9nWvMlRToqtJGv0cXktUUFTLWVxFHq0GLko0msDOH0RpIAyLjBn3eMMfFAyXKlBQSjwNRCIjslwHZcl++WuE1n7neKIkJ9piwka6fGN/JSX6fCNEnkd5X3T5LJfFlVBZnSCTHucDIsRvJ6n0A+Kb32QkVnS2/8QFXZ+P381Dd1vh6OU6rGogt2jhvEu5fj4ZGT1gyVzOqHVYmRN7bNk7W+1GDItvsuzd1mLCr7n5aqD0Xp3W5y8MtSyQoZqxnokWdQo3qV6cU5tPO7Qkg2p6lu+xO5ueBmGb41dTAWZjioh/XEgxxq5vHg92UbAnLIYhowq58plxMhwpSo+yqvjhw9KTv/vnOCwZrhSJX+gc6VmhTt/4POPqGVWt5QOndpjcrKfck7t9ctar2jPXIvmyBbIfGvTsrYFr2kM2t9/fX+Qszp8+1uDj2VaHL6AZ7VnrmP0BUJ/MDQNm+S/jmH13ZbhvzxncRT/iDm/p4DwO22C1DvvvKPp06dr//79ql+/voYPH64LLrgg3M0CMs/z48wqg+3O/ODgyZDhTpfhSfd9CHGlSv4Q5P/qSsv63p31szI/mFjcJzI/sKQF/oJcrE23Rcu0l/ONCjnKSY54KaaCvLbYrNGiqPIyHfFSVLzMqHiZjvjAZbJmLts3DNnsDrmdwQEt2+qck5yQXCdyrucpLItNNoup6Iy9CnxSP+xQdEbhpqQwnz90C3f6pu1dkpwmy8mdGtQfksXrlSlD7uwfBD2pgW8ruvdLnhMyTIuiLW6lZy7Jal7BqbOi3dqdbtO0fxIkSdfXyhr9NAzpmhon9MJ6h2b/fly925ZMNcSIkNtzvFDXK+RrymKVLDEy5auk6I2Kk716S1n96+NiHTKSs15P2UqW5CroNWWamaNcqcEhy/87LvN3ocWdJkf6XunA3zJd6ZnTIbNPlXQHnyYg+xo4w/B9707P8YehrPBWNpkysgWs4FAWCGP+nx1RSvAamcEu5+U5qlcaeVe3tJvpMg9tk2l6A+eYM4PONWeRLJasaqH+y+zRMvYnyuo44AuNeVTN9F2W2bYQzl0HhNNpEaSWLl2qsWPHauTIkTrvvPP07rvvavDgwVqyZImqVasW7uYhVP4qYl6PfOfK8Uperwx5M7f5T0Dq9YUH08w8t85JP2d7w/WtLwg+L0/W+Xmy73fS+oUcx3BlC0GZb8YWtxLSU7OdLygj+PtSfsMOrGmwxWSVarZFZ34fLTM6XtaE6nKnHfO9cWVeZtqifd9bo7NKOZ+8fiE6Xo7K9XNfQ+L2SO7D0onDORuVuS6n1Nbz5LaWp1yUzBOFuG3m84ds9SGHFu/yBam+NU/k3CGoP5zyeE2ZkrzerMfXSMvqG3PzcpkxUbJEx8uoWj/rMIZ0c51jemF9RUlS4/IZ6npWqrI/P66pflxTNyXon0NuTfqrnIbWTZP1dPw8Vtpr5E6+vcK+nqScrynD8BW4sMfIjEnM82q+dTmhj0gb9mgZZ3cITO3N8ccsj9M3VdHrClqDZphuRWXsk7nXdx+zn9zaV70y2/fezJNde92SxSJrVLy8x/dlrYvzX2b69/dkHssb/H4l07e+0p2RtY/pzXqPyyWeGjIz359cMlTwdFB7oR+5ErRSmZG88IJComENDoOWk0b2MkfycguJ/vCW52kPsoXH3IJlUNjL7XJr7rcRfLk1M3Bm/vkwM2iahsX3i83t8D13ZMm2z+n4i+v0c1oEqZkzZ6pv377q16+fJOlf//qXvvvuO82bN0+PPPJIoY9jsSjs6yei/nhXUX8vkuSVbFYluPwVyE4uT5z1fdYv2uz75LJ/9n1yPaYZ/L0k46Sfffvkc/1ct/l+NrKVU5b/nDRB4SfzZ2VVwCorcn2jMiTZHL5/2fjKI/vPRePIDDH+9T7RgcXYvvUC0b7qWdbsi7WjA+sHHEqT98AmSYavLLI1cwpJfqLi5EiuK/eeP33VyUKROa3EsNp8f5UsretFxfqmvhSWIzbn7VlskrUQt221SRaLLBYp5A+bhiFFxcqwhvDRxd/Wot7H0rpeHtf9z4YYTd9YTtEOQ5dUydB5VR0yDIckQxa3V4YhGUH9YcpimPJKMoxsQcrqleLjM7/3TYkyrL7+t0aXk+GNkmRqQEOpQmyq9mdYdG2tdNmi4iUZks2QYTVVPtrU8Auk0b/Y9N728vp2fzm9cMER1Y8vxIhtMT82pXK9cL2mCvt6kkr/NWWzn3R7hqRoyZFz1dzJ73CejL2+aX/uEMbBM3+nuoryO7Wg6wbeK7NCmGGaksWQUbWZnNbyvss87szA5jt5t2+dm1fly9l07MjxQLETmV5fcDT9lSu9WSf89rqy/RHSk7l/Zmj0emR1HZNO7Mu8fl7v5ScFQdN34vDMzsilne483/ONoK+ZIbbsfTwotKSTfjZlKBCsjKyvZvZt2UKZL5gpl+3+10Bm9U0j+JFVQT8HyTllO7/rmtn3PzkY5rgd35Tl1FZ3y12zXS63XboKm2MNs4z/ydXpdKply5aaOHGirrjiisD2Z599VuvXr9fbb78dxtYBAAAAOB2dWimlCHDo0CF5PB4lJgZPD0hKStL+/fvD1CoAAAAAp7MyH6T8Tq7G5St5zPxSAAAAAMWvzAepihUrymq16sCBA0HbU1JSlJR08oxTAAAAADh1ZT5IORwONWnSRN9//33Q9uXLl6tVq1ZhahUAAACA09lpUbVv0KBBevzxx9W0aVO1atVK7733nnbv3q3+/fuHu2kAAAAATkOnRZDq1q2bDh06pDfeeEP79u1TgwYNNHXqVFWvXj3cTQMAAABwGirz5c8BAAAAoLSV+TVSAAAAAFDaCFIAAAAAECKCFAAAAACEiCAFAAAAACEiSJWSd955R506dVKzZs3Up08frVq1qlDX+/nnn9W4cWP17t07z32WLFmihg0b6t577y2u5p6xSqKfjh49qmeeeUbt27dXs2bN1LVrV3377bfF3fQzSkn006xZs3TllVeqefPm6tixo5577jllZGQUd9PPKKH0048//qiGDRvm+Ldp06ag/T7//HN169ZNTZs2Vbdu3bRs2bKSvhunveLup/nz5+vGG2/UhRdeqAsvvFADBw7U77//Xhp35bRWEq8nPz5HFJ+S6Cc+R0QwEyVuyZIlZpMmTcz58+ebGzduNJ999lmzZcuW5s6dO/O93tGjR83OnTubt912m9mrV69c99mxY4fZoUMH88YbbzTvueeekmj+GaMk+ikjI8Ps06ePOXjwYHPVqlXmjh07zJUrV5p//vlnSd6V01pJ9NPChQvNpk2bmosWLTK3b99u/t///Z/Zrl07c8yYMSV5V05rofbTihUrzAYNGpj//POPuW/fvsA/t9sd2OeXX34xzz33XHPy5Mnmxo0bzcmTJ5uNGzc2V69eXVp367RTEv308MMPm2+//bb5xx9/mBs3bjSHDRtmnn/++eaePXtK626ddkqin/z4HFF8SqKf+BwR2RiRKgUzZ85U37591a9fP9WtW1f/+te/VLVqVc2bNy/f640YMUI9evRQy5Ytc73c4/Ho0Ucf1dChQ1WzZs0SaPmZpST66YMPPtCRI0f0+uuv6/zzz1f16tV1wQUXqFGjRiV0L05/JdFPq1ev1nnnnaeePXuqRo0aat++vXr06KG1a9eW0L04/RW1nxITE5WcnBz4Z7VaA5fNnj1bbdu21V133aW6devqrrvu0sUXX6zZs2eX9N05bZVEP7300ku66aabdO6556pu3bp69tln5fV69cMPP5T03TltlUQ/SXyOKG4l0U98johsBKkS5nQ6tW7dOrVv3z5oe7t27fTrr7/meb0PPvhA27Zt05AhQ/Lc5/XXX1elSpXUr1+/Ymvvmaqk+unrr79Wy5YtNWrUKLVt21Y9evTQ5MmT5fF4irX9Z4qS6qfzzz9f69atC0w/2r59u7799ltdeumlxdb2M0lR+0mSrr76arVv31633nqrVqxYEXTZ6tWrcxyzQ4cOBR4TuSupfjpZWlqa3G63EhISTrnNZ6KS7Cc+RxSfkuonPkdENlu4G3C6O3TokDwejxITE4O2JyUlaf/+/bleZ8uWLXrppZf0zjvvyGbLvYt+/vlnLViwQB9//HFxN/mMVFL9tH37dq1YsUI9e/bU1KlTtXXrVo0aNUputzvfkIzclVQ/de/eXQcPHtSNN94o0zTldrt1ww036M477yz2+3AmKEo/JScna/To0WrSpImcTqcWLlyogQMH6q233tKFF14oSTpw4ECOYyYmJuZ5TOSvpPrpZC+99JKqVKmitm3bFvt9OBOUVD/xOaJ4lVQ/8TkishGkSolhGEE/m6aZY5vkG2Z/5JFHNHToUJ199tm5Huv48eN67LHHNHr0aFWqVKlE2numKs5+8l8/MTFRo0ePltVqVdOmTbVv3z5Nnz6dX4CnoLj76ccff9TkyZM1cuRINW/eXNu2bdOYMWP0+uuv67777iv29p8pCttPknTOOefonHPOCfzcqlUr7dmzR9OnTw/6gB7KMVE4JdFPftOmTdOSJUs0Z84cRUVFFW/DzzDF2U98jig5xf164nNEZCNIlbCKFSvKarXqwIEDQdtTUlKUlJSUY/8TJ05o7dq1+vPPPzV69GhJktfrlWmaaty4saZPn64KFSpo586duueeewLX83q9kqTGjRvrs88+U61atUrwXp1+SqKf2rRpo+TkZNlstqD5zuecc472798vp9Mph8NRsnfsNFNS/TRx4kT16tUrML2lYcOGSk1N1YgRI3TPPffIYmEWdChC7ae8tGjRQosWLQr8nJSUlOOYBw8eDOmYyFJS/eQ3ffp0TZkyRTNnzmQ9xykoiX7avn07nyOKWUm9nvgcEdkIUiXM4XCoSZMm+v7773XFFVcEti9fvlydO3fOsX9cXJw++eSToG1z587VihUr9Oqrr6pGjRqyWq059nnllVd04sSJwMJGhKYk+kmSzjvvPC1evFherzfwYXzLli1KTk7ml18RlFQ/paen5whLVqtVpmnKNM0SuCent1D7KS9//vmnkpOTAz+3bNlS33//vQYOHBjY9t1336lVq1bF0u4zTUn1kyT95z//0Ztvvqnp06erWbNmxdbmM1FJ9NM555zD54hiVlKvJz5HRDaCVCkYNGiQHn/8cTVt2lStWrXSe++9p927d6t///6SfPPH9+7dq/Hjx8tisahBgwZB109MTFRUVFTQ9pP3KV++fK7bUXgl0U833HCD3nrrLY0ZM0Y333yztm7dqilTpmjAgAGlet9OJyXRT5dddplmzpypxo0bB6b2TZw4UZ06dcpR5QqFE0o/Sb7zeNWoUUP16tWTy+XSokWL9Pnnn2vSpEmBY95yyy26+eabNXXqVHXu3FlfffWVfvjhB82dOzcs9/F0UBL9NG3aNE2cOFEvvfSSqlevHlgfEhsbq3LlypX+nTwNFHc/nfw7UOJzRHEoidcTnyMiG0GqFHTr1k2HDh3SG2+8oX379qlBgwaaOnWqqlevLknav3+/du/eHeZWoiT66ayzztKMGTM0duxY9erVS1WqVNEtt9yiwYMHl8RdOCOURD/dc889MgxDr7zyivbu3atKlSrpsssu00MPPVQSd+GMEGo/uVwujRs3Tnv37lV0dLTq1aunqVOnqmPHjoF9zjvvPL388st65ZVX9Oqrr6pmzZqaMGGCWrRoUer373RREv00b948uVwu3X///UG3NWTIEA0dOrR07thppiT6CcWvJPqJzxGRzTCZtwIAAAAAIWEFNQAAAACEiCAFAAAAACEiSAEAAABAiAhSAAAAABAighQAAAAAhIggBQAAAAAhIkgBAAAAQIgIUgAAAAAQIoIUAAAAAISIIAUAAAAAISJIAQAAAECI/h/1h8CK57wG5AAAAABJRU5ErkJggg=="},"metadata":{}}]},{"cell_type":"code","source":"","metadata":{},"execution_count":null,"outputs":[]}]}