{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"MPINN_1D_LBFGS.ipynb","provenance":[],"collapsed_sections":[]},"kernelspec":{"display_name":"Python 3","language":"python","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.6.6"},"accelerator":"GPU"},"cells":[{"cell_type":"markdown","metadata":{"id":"z5o6UD4m_sFi"},"source":["# Numerical results for one dimensional equation (with BFGS solver)"]},{"cell_type":"markdown","metadata":{"id":"lDlIo9lR_sFs"},"source":["We consider first a 1D linear problem:\n","\n","$$ \\frac{d^2 u(x)}{dx^2} - u(x) = f(x)$$\n","\n","with $f(x) = -(\\pi^2 + 1)sin(x\\pi)$.\n","\n","on $\\Omega = [-1,1]$ avec $u(-1) = u(1) = 0$."]},{"cell_type":"markdown","metadata":{"id":"7qdVngR5_sFu"},"source":["### 1. Import and settings "]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"noY61scM_sFu","executionInfo":{"status":"ok","timestamp":1633451455203,"user_tz":-120,"elapsed":193,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"d8e9ab2f-fbad-409b-f7cb-9164644d6406"},"source":["import numpy as np\n","import matplotlib.pyplot as plt\n","import numpy\n","import torch\n","import torch.nn as nn\n","import torch.nn.functional as F\n","import torch.utils.data.dataloader as dataloader\n","import torch.optim as optim\n","from torch.autograd import grad\n","import pickle\n","from numpy import arange\n","from torch.optim.lr_scheduler import StepLR\n","\n","\n","SEED = 95\n","\n","# CUDA?\n","cuda = torch.cuda.is_available()\n","\n","# For reproducibility\n","torch.manual_seed(SEED)\n","device = torch.device(\"cuda\" if cuda else \"cpu\")\n","\n","if cuda:\n","    torch.cuda.manual_seed(SEED)\n","    print('Cuda in use')\n","else:\n","    print('No cuda')"],"execution_count":168,"outputs":[{"output_type":"stream","name":"stdout","text":["Cuda in use\n"]}]},{"cell_type":"markdown","metadata":{"id":"QVWCFkJttTe2"},"source":["### 2. Model class"]},{"cell_type":"code","metadata":{"id":"93wd-rdK_sFx","executionInfo":{"status":"ok","timestamp":1633451455740,"user_tz":-120,"elapsed":351,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["class PINN(nn.Module):\n","    \"\"\"\n","    Allows the creation of Physics informed neural \n","    networks made of :\n","        - an input layer taking one element: the position in space x\n","        - h hidden layer of i neurons \n","        - an output layer allowing us to obtain u \n","    \"\"\"\n","\n","    def __init__(self,h,i):\n","        super(PINN,self).__init__()\n","        self.il = nn.Linear(1,i) \n","        self.hidden = nn.ModuleList()\n","        for k in range(h):\n","            self.hidden.append(nn.Linear(i,i))\n","        self.ol = nn.Linear(i,1)\n","        self.tn = nn.Tanh()  \n","    \n","    def forward(self,x):\n","        u = x\n","        u = self.tn(self.il(u))\n","        for layer in self.hidden :\n","            u = self.tn(layer(u))\n","        out =  self.ol(u)\n","        return out"],"execution_count":169,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"R1xqEXULtTe3"},"source":["### 3.Creating the database"]},{"cell_type":"markdown","metadata":{"id":"BLs-nI1E0LmP"},"source":["#### 3.1 Create the data "]},{"cell_type":"code","metadata":{"id":"1X50uzOn_sFy","executionInfo":{"status":"ok","timestamp":1633451455741,"user_tz":-120,"elapsed":10,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["#physic value \n","alpha = 5\n","# discretization numbers\n","nx = 50\n","nxH = 50\n","nxt=100\n","\n","# discretization arrays \n","x = np.linspace(-1,1,nx)\n","xt = np.linspace(-1,1,nxt)\n","xH = np.linspace(-1,1,nxH)\n","\n","# groundtruth value \n","groundtruth = np.sin(np.pi*xt)+np.sin(alpha*np.pi*xt)\n","\n","nf = x.shape[0]-1\n","\n","# second member function\n","f = -(np.pi**2 + 1)*np.sin(np.pi*x)-(alpha**2*np.pi**2 + 1)*np.sin(alpha*np.pi*x)\n","fH = -(np.pi**2 + 1)*np.sin(np.pi*xH)-(alpha**2*np.pi**2 + 1)*np.sin(alpha*np.pi*xH)\n","\n","\n","# BC's \n","x_bc = np.array([-1.0, 1.0])\n","u_bc = np.array([0.0,0.0])"],"execution_count":170,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"Rj4JzbmX0t9q"},"source":["#### 3.2 From numpy to Pytorch"]},{"cell_type":"code","metadata":{"id":"GDKt5ZkE_sFy","executionInfo":{"status":"ok","timestamp":1633451455742,"user_tz":-120,"elapsed":11,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["#From numpy to pytorch \n","\n","tensor_x = torch.from_numpy(x).float()\n","tensor_f = torch.from_numpy(f).float()\n","tensor_xH = torch.from_numpy(xH).float()\n","tensor_fH = torch.from_numpy(fH).float()\n","tensor_xt = torch.from_numpy(xt).float()\n","\n","\n","tensor_x_bc = torch.from_numpy(x_bc).float()\n","tensor_u_bc = torch.from_numpy(u_bc).float()\n","\n","#add a dimension to create a batch format \n","\n","tensor_x = tensor_x.reshape(nx,1)\n","tensor_xt = tensor_xt.reshape(nxt,1)\n","tensor_f = tensor_f.reshape(nx,1)\n","tensor_xH = tensor_xH.reshape(nxH,1)\n","tensor_fH = tensor_fH.reshape(nxH,1)\n","tensor_x_bc = tensor_x_bc.reshape(2,1)\n","tensor_u_bc = tensor_u_bc.reshape(2,1)\n","\n","#necessary to derive\n","\n","tensor_x.requires_grad = True\n","tensor_xt.requires_grad = True\n","tensor_xH.requires_grad = True\n","\n","#Put data on device \n","\n","tensor_x = tensor_x.to(device)\n","tensor_xt = tensor_xt.to(device)\n","tensor_f = tensor_f.to(device)\n","tensor_xH = tensor_xH.to(device)\n","tensor_fH = tensor_fH.to(device)\n","tensor_x_bc = tensor_x_bc.to(device)\n","tensor_u_bc = tensor_u_bc.to(device)"],"execution_count":171,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"x8OSjC6KtTe4"},"source":["### Network training function"]},{"cell_type":"code","metadata":{"id":"Mytvfjkzr9du","executionInfo":{"status":"ok","timestamp":1633451455742,"user_tz":-120,"elapsed":10,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["def train_one(model,optimizer,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,tot,tol,mpinn=False,model_2=None):\n","    \"\"\"\n","    Train PINN to solve a given equation \n","    \n","    Inputs : \n","        model : Pytorch Model : model to be trained \n","        optimizer : Pytorch optimizer : optimizer associated to the model \n","        tensor_x : Pytorch Tensor : tensor of internal conditions points  \n","        tensor_xt : Pytorch Tensor : test point tensor \n","        tensor_x_bc : Pytorch Tensor : Boundary condition point tensor  \n","        tensor_u_bc : Pytorch Tensor : Boundary condition values \n","        tensor_f : Pytorch Tensor : Interior values \n","        groundtruth : numpy array : true value at the xt points \n","        tot : int : maximum number of epoch\n","        tol : float : convergence threshold \n","        mpinn : bool : if it's an MPINN the error is calculated differently with model2\n","        model_2 : Pytorch model : the complementary model of mpinn for calculating the error\n","    Outputs : \n","        local_loss_cl : list(float) : list of the boundary loss values \n","        local_loss_inter : list(float) : list of the interior loss values \n","        local_loss_total : list(float) : list of the total loss values\n","        error_train : list(float) : list of the error values at xt points \n","    \"\"\"\n","    local_loss_cl = []\n","    local_loss_total = []\n","    local_loss_inter = []\n","\n","    loss_interieure = nn.MSELoss()\n","    loss_bc = nn.MSELoss()\n","    loss_data = nn.MSELoss()\n","    \n","    error_train = []\n","    for epoc in range(1, tot+1):\n","        def closure():\n","          optimizer.zero_grad() \n","          \n","          outputs_cl = model(tensor_x_bc)\n","          loss_cl = loss_bc(outputs_cl,tensor_u_bc)\n","          local_loss_cl.append(loss_cl.cpu().item())\n","\n","          outputs_interieur = model(tensor_x)\n","          grad_outputs = torch.ones_like(outputs_interieur)\n","          outputs_interieur_u_x = grad([outputs_interieur],[tensor_x], grad_outputs = grad_outputs,create_graph=True,allow_unused=True)[0]\n","          outputs_interieur_u_xx = grad([outputs_interieur_u_x],[tensor_x], grad_outputs = grad_outputs,create_graph=True,allow_unused=True)[0]\n","          f_pred = outputs_interieur_u_xx - outputs_interieur\n","          loss_inter = loss_interieure(f_pred,tensor_f)\n","          local_loss_inter.append(loss_inter.cpu().item())\n","\n","\n","          loss_total = loss_inter + loss_cl \n","          loss_print=loss_total.cpu().item()\n","          local_loss_total.append(loss_total.cpu().item())\n","          loss_total.backward(retain_graph=True)\n","          return(loss_total)\n","          \n","        # Backpropagation\n","        optimizer.step(closure)\n","        \n","        # Test \n","        if mpinn : \n","            prediction = model(tensor_xt).cpu().detach().numpy() + model_2(tensor_xt).cpu().detach().numpy()\n","            pp=np.squeeze(prediction)\n","            error_train.append(np.sqrt(np.mean((pp-groundtruth)**2)))\n","        else : \n","            prediction = model(tensor_xt).cpu().detach().numpy()\n","            pp=np.squeeze(prediction)\n","            error_train.append(np.sqrt(np.mean((pp-groundtruth)**2)))\n","\n","        if epoc%1000 == 0 :\n","            print('Total loss = {:.6f} error = {:.6f} in epoch : {}'.format(local_loss_total[-1],error_train[-1],epoc))\n","\n","        if error_train[-1]<tol:\n","            print('The network has converged, error = {:.6f}'.format(loss_print))\n","            break\n","\n","    return epoc,local_loss_cl,local_loss_inter,local_loss_total,error_train"],"execution_count":172,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"z5DtKYsi00RJ"},"source":["### Residual computation fonction"]},{"cell_type":"code","metadata":{"id":"yslsmOINtTe6","executionInfo":{"status":"ok","timestamp":1633451455743,"user_tz":-120,"elapsed":10,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["def compute_res_bc(model,tensor_x,tensor_x_bc,tensor_f):\n","    \"\"\"\n","    Calculates the residual associated with the network to define the new correction problem. \n","    Inputs :\n","      model : Pytorch Model : model to be trained \n","      tensor_x : Pytorch Tensor : tensor of internal conditions points  \n","      tensor_f : Pytorch Tensor : Interior values \n","    Output :\n","      res : Pytorch Tensor : Residual of the model \n","      bc : Pytorch Tensor : Boundary value of the model \n","    \"\"\"\n","    outputs_interieur = model(tensor_x)\n","    grad_outputs = torch.ones_like(outputs_interieur)\n","    outputs_interieur_u_x = grad([outputs_interieur],[tensor_x],grad_outputs=grad_outputs,create_graph=True,allow_unused=True)[0]\n","    outputs_interieur_u_xx = grad([outputs_interieur_u_x],[tensor_x],grad_outputs=grad_outputs,create_graph=True,allow_unused=True)[0] \n","    f_pred = outputs_interieur_u_xx - outputs_interieur\n","    res = f_pred-tensor_f\n","    bc = model(tensor_x_bc)\n","    return res,bc"],"execution_count":173,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"JQWnrphptTe6"},"source":["### Main loop : VCycle training"]},{"cell_type":"code","metadata":{"id":"7DU-hoAwegZt","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1633451493336,"user_tz":-120,"elapsed":37603,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"ee403ec5-d1c9-45de-b583-fc2294ce55fc"},"source":["#Create network for the fine and the coarse resolution \n","h=200\n","H=100\n","modelh = PINN(4,h) \n","modelh = modelh.to(device)\n","modelH = PINN(4,H) \n","modelH = modelH.to(device)\n","\n","#stockage des valeurs des loss à chacune des étapes \n","losses_total = []\n","losses_bc = []\n","losses_interieur = [] \n","\n","error=[]\n","\n","losses_totalH = []\n","losses_bcH = []\n","losses_interieurH = [] \n","\n","optimizerh = optim.LBFGS(modelh.parameters(),line_search_fn='strong_wolfe')\n","optimizerH = optim.LBFGS(modelH.parameters(),line_search_fn='strong_wolfe')\n","\n","#first training epocs\n","stampo=[]\n","tol=1e-6\n","nit=1\n","epocs = 5000\n","\n","epoc_h,_,_,local_loss_total_h,error_h = train_one(modelh,optimizerh,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,nit,tol)\n","stampo.append(local_loss_total_h[-1])\n","print('Loss value after first training {}'.format(stampo[-1]))\n","error = error+error_h\n","losses_total = losses_total+local_loss_total_h\n","resh,BCh = compute_res_bc(modelh,tensor_xH,tensor_x_bc,tensor_fH)\n","\n","nitf=2\n","nitc=2\n","ncicleV=50\n","for i in range(1,ncicleV+1):\n","    _,_,_,local_loss_total_H,error_H = train_one(modelH,optimizerH,tensor_xH,tensor_xt,tensor_x_bc,tensor_u_bc-BCh,-resh,groundtruth,nit,tol,mpinn=True,model_2=modelh)\n","    resH,BCH = compute_res_bc(modelH,tensor_x,tensor_x_bc,tensor_f)\n","    _,_,_,local_loss_total_h,error_h = train_one(modelh,optimizerh,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc-BCH,-resH,groundtruth,nit,tol,mpinn=True,model_2=modelH)\n","    resh,BCh = compute_res_bc(modelh,tensor_xH,tensor_x_bc,tensor_fH)\n","    losses_total = losses_total+local_loss_total_h\n","    error = error+error_h  \n","    stampo.append(local_loss_total_H[-1])\n","    if i%5 == 0 :\n","        print('Loss value at Vcycle number {} : {}'.format(i,stampo[-1]))\n","        print('Error value at Vcycle number {} : {}'.format(i,error[-1]))\n","    if error[-1]<tol:\n","        print('Number of V cycles = {} '.format(i))\n","        break"],"execution_count":174,"outputs":[{"output_type":"stream","name":"stdout","text":["Loss value after first training 23316.12109375\n","Loss value at Vcycle number 5 : 116.0240478515625\n","Error value at Vcycle number 5 : 1.0117337246824811\n","Loss value at Vcycle number 10 : 0.2343420386314392\n","Error value at Vcycle number 10 : 0.08466568627184605\n","Loss value at Vcycle number 15 : 0.030506759881973267\n","Error value at Vcycle number 15 : 0.01497363915258144\n","Loss value at Vcycle number 20 : 0.00820703525096178\n","Error value at Vcycle number 20 : 0.005688494735695503\n","Loss value at Vcycle number 25 : 0.0034605551045387983\n","Error value at Vcycle number 25 : 0.0012881400747167334\n","Loss value at Vcycle number 30 : 0.003417049301788211\n","Error value at Vcycle number 30 : 0.0012881400747167334\n","Loss value at Vcycle number 35 : 0.003417049301788211\n","Error value at Vcycle number 35 : 0.0012881400747167334\n","Loss value at Vcycle number 40 : 0.003417049301788211\n","Error value at Vcycle number 40 : 0.0012881400747167334\n","Loss value at Vcycle number 45 : 0.003417049301788211\n","Error value at Vcycle number 45 : 0.0012881400747167334\n","Loss value at Vcycle number 50 : 0.003417049301788211\n","Error value at Vcycle number 50 : 0.0012881400747167334\n"]}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":298},"id":"dIoZTMQ5ZCwQ","executionInfo":{"status":"ok","timestamp":1633451493629,"user_tz":-120,"elapsed":315,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"8a08e726-af2e-485a-f63e-076caae908c5"},"source":["plt.title('Loss function')\n","plt.semilogy(losses_total,color='red',label = 'MPINN',linestyle='dashed')\n","plt.legend()"],"execution_count":175,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7f4b270df3d0>"]},"metadata":{},"execution_count":175},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"}}]},{"cell_type":"markdown","metadata":{"id":"Vbd-6oywtTe8"},"source":["### Train classic PINN"]},{"cell_type":"code","metadata":{"id":"5zT_Sl3AtTe8","executionInfo":{"status":"ok","timestamp":1633451493630,"user_tz":-120,"elapsed":7,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["#Create a network for classical PINN training\n","mynet_one = PINN(4,h) \n","mynet_one = mynet_one.to(device)\n","optimizer_one=optim.LBFGS(mynet_one.parameters(),line_search_fn='strong_wolfe')\n","\n","\n","a=3\n","b=6\n","c=-(6*h+3*h**2+6*H+3*H**2)\n","htilde=np.floor(-b+np.sqrt(b**2-4*a*c)/(2*a))\n","htilde=int(htilde)\n","\n","mynet_one2 = PINN(4,htilde) \n","mynet_one2 = mynet_one2.to(device)\n","optimizer_one2=optim.LBFGS(mynet_one2.parameters(),line_search_fn='strong_wolfe')"],"execution_count":176,"outputs":[]},{"cell_type":"code","metadata":{"id":"LOTlP9r2q_tm","scrolled":false,"executionInfo":{"status":"ok","timestamp":1633451511043,"user_tz":-120,"elapsed":17420,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["\n","epoc,_,_,pinn_loss_total,error_train = train_one(mynet_one,optimizer_one,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,100,tol)\n"],"execution_count":177,"outputs":[]},{"cell_type":"code","metadata":{"id":"_SR6h7LCwzvb","executionInfo":{"status":"ok","timestamp":1633451534327,"user_tz":-120,"elapsed":23302,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["epoc2,_,_,pinn_loss_total_2,error_train_2 = train_one(mynet_one2,optimizer_one2,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,100,tol)"],"execution_count":178,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"jDg0LjO2tTe9"},"source":["### Plot RMSE and Loss "]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":298},"id":"476apy8ZzjN4","executionInfo":{"status":"ok","timestamp":1633451534654,"user_tz":-120,"elapsed":344,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"524c8791-8398-4dad-b723-94fc38de0b73"},"source":["predictionh = modelh(tensor_xt).cpu().detach().numpy()\n","predictionH = modelH(tensor_xt).cpu().detach().numpy()\n","prediction = mynet_one(tensor_xt).cpu().detach().numpy()\n","\n","#pp=np.squeeze(predictionh+predictionH)\n","\n","plt.figure()\n","plt.plot(xt,groundtruth,color='blue',label='groundtruth')\n","plt.scatter(xt,predictionh+predictionH,color='red',label='MPINN')\n","plt.scatter(xt,prediction,color='black',label='PINN',marker='^')\n","plt.title('PDE solution')\n","plt.legend()"],"execution_count":179,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7f4b278793d0>"]},"metadata":{},"execution_count":179},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"}}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":333},"id":"OTsx1khJ-BPw","executionInfo":{"status":"ok","timestamp":1633451534916,"user_tz":-120,"elapsed":270,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"1d2f9821-edaf-4a59-e188-63cfc04b76c2"},"source":["plt.title('Loss function')\n","#plt.semilogy(losses_totalH,label = 'Loss H')\n","plt.semilogy(losses_total,color='red',label = 'MPINN',linestyle='dashed')\n","plt.semilogy(pinn_loss_total,color='black', label = 'PINN h')\n","plt.semilogy(pinn_loss_total_2,color='green', label = r'PINN $\\tilde{h}$')\n","plt.legend()\n","print(losses_total[-1])\n","print(pinn_loss_total[-1])\n","print(pinn_loss_total_2[-1])"],"execution_count":180,"outputs":[{"output_type":"stream","name":"stdout","text":["0.003417091676965356\n","0.015300939790904522\n","0.01808411255478859\n"]},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAXwAAAEICAYAAABcVE8dAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deZyN5f/48dd79rEvM4UZY2xhEmNM5JPQJpS0yihlKW2UTyrCr/T1abGUhCIRSpbSYklIi2wJIRKGRkaJsTWWMdv1++M+M+fMmGHWc86c834+HvM493Xd97nv9z2H97nnuq/7usQYg1JKKc/n4+oAlFJKOYcmfKWU8hKa8JVSyktowldKKS+hCV8ppbyEJnyllPISmvCVykVEgkVksYicEpFPnHzsnSLSwZnHVN7Dz9UBKJUfEUkAHjbGfOPkQ98DXA5UN8akl9ZBRGQmkGiMGZFVZ4y5srSOp5Re4St1oTrAntJM9kq5giZ8VeaISKCIvCUif9l+3hKRQNu6EBFZIiInReS4iPwoIj62dUNE5JCIJIvIbhG5MY99vwy8CNwnIqdFpJ+IjBSRjxy2iRQRIyJ+tvL3IjJKRNba9r1CREIctm8rIutsMR0Ukd4i0h+4H3jedpzFtm0TROSmApxnBxFJFJHBInJERP4WkT6l9TtXnkETviqLhgPXANFAc6AVkNUsMhhIBEKxmmWGAUZEGgEDgKuNMRWBW4CE3Ds2xrwEvArMN8ZUMMZML2BMPYE+wGVAAPAsgIjUAZYBE20xRQNbjTHvAXOAMbbjdC3keQLUACoDYUA/YLKIVC1gvMoLacJXZdH9wP8ZY44YY44CLwO9bOvSgJpAHWNMmjHmR2MNGJUBBAJRIuJvjEkwxuwrwZg+MMbsMcacAxZgJWmwvgi+McbMtcVzzBiztYD7vNh5gnWu/2fb71fAaaBRyZyO8kSa8FVZVAs44FA+YKsDGAvEAytEZL+IDAUwxsQDg4CRwBERmScitSg5hx2WzwIVbMu1gaJ+sVzsPAGO5brP4HhcpS6gCV+VRX9h3VjNEmGrwxiTbIwZbIypB9wOPJPVVm+M+dgY09b2XgOMLuDxzgDlHMo1ChHrQaB+PusuNVRtvuepVFFowlfuzl9Eghx+/IC5wAgRCbXdHH0R+AhARG4TkQYiIsAprKacTBFpJCI32G56pgDngMwCxrAVaCciESJSGXihEPHPAW4Ske4i4ici1UUkq7nnH6DeRd6b73kqVRSa8JW7+worOWf9jAT+B2wCtgO/AltsdQANgW+w2rPXA+8YY77Dar9/HUjCan65jAImbmPMSmC+7XibgSUFDd4Y8yfQBetm8nGsL4/mttXTse4pnBSRL/J4+8XOU6lCE50ARSmlvINe4SullJfQhK+UUl5CE75SSnkJTfhKKeUl3Hq0zJCQEBMZGenqMJRSqszYvHlzkjEmNK91bp3wIyMj2bRpk6vDUEqpMkNEDuS3Tpt0lFLKS2jCV0opL6EJXymlvIRbt+ErpVRaWhqJiYmkpKS4OhS3EhQURHh4OP7+/gV+jyZ8pZRbS0xMpGLFikRGRmKNiaeMMRw7dozExETq1q1b4Pdpk45Syq2lpKRQvXp1TfYORITq1asX+q8eTfhKKbenyf5CRfmdaMJXSikv4dkJf9s2+O03V0ehlCrjRIQHHnggu5yenk5oaCi33XYbADNnziQ0NJTo6GiioqKYNm1adv2AAQMAGDlyJOXKlePIkSPZ+6lQoUKOYwwePDi7PG7cOEaOHFmi5+HZCb9/f3D4BSqlVFGUL1+eHTt2cO7cOQBWrlxJWFhYjm3uu+8+tm7dyvfff8+wYcP4559/LthPSEgIb7zxRp7HCAwM5LPPPiMpKankT8CmVBK+iNQTkeki8qlDXXkRmSUi00Tk/tI47gU2boSvv3bKoZRSnq1Lly4sXboUgLlz5xIXF5fndpdddhn169fnwIELRzjo27cv8+fP5/jx4xes8/Pzo3///owfP75kA3dQ4IQvIjNE5IiI7MhV30lEdotIvIgMBTDG7DfG9Mu1i7uAT40xj2BNLq2UUoXXocOFP++8Y607ezbv9TNnWuuTki5cV0A9evRg3rx5pKSksH37dlq3bp3ndvv372f//v00aNDggnUVKlSgb9++TJgwIc/3Pvnkk8yZM4dTp04VOK7CKMwV/kygk2OFiPgCk4HOQBQQJyJR+bw/HDhoW84oXJhKKeVazZo1IyEhgblz59KlS5cL1s+fP5/o6Gji4uKYOnUq1apVy3M/Tz31FLNmzSI5OfmCdZUqVeLBBx/k7bffLvH4oRAPXhljVotIZK7qVkC8MWY/gIjMA7oBed0pTcRK+lvx9HsHSqnS8/33+a8rV+7i60NCLr7+Em6//XaeffZZvv/+e44dO5Zj3X333cekSZMuuY8qVarQs2dPJk+enOf6QYMGERMTQ58+fYocZ36Km3jDsF+1g5XUw0SkuohMAVqIyAu2dZ8Bd4vIu8Di/HYoIv1FZJOIbDp69GjxoivEI8dKKXUpffv25aWXXuKqq64q1n6eeeYZpk6dSnp6+gXrqlWrRvfu3Zk+fXqxjpGXUrnSNsYcM8Y8Zoypb4x5zVZ3xhjTxxjzuDFmzkXe+54xJtYYExsamucY/gU3ciS88MIlN1NKqYIIDw/nqaeeKvZ+QkJCuPPOOzl//nye6wcPHlwqvXXEGFPwja0mnSXGmKa2chtgpDHmFlv5BYCsJF9csbGxplgToKxdC8HBEBNTEuEopVxg165dNGnSxNVhuKW8fjcistkYE5vX9sUdPO1noKGI1AUOAT2AnsXcZ8kZMAAiIuDLL10diVJKuVxhumXOBdYDjUQkUUT6GWPSgQHAcmAXsMAYs7N0Qi2CrVth0SJXR6GUUm6hML108nzKwBjzFfBViUWklFKqVGj3SKWU8hKa8JVSykt4dsKvV8/VESillNvw7IT/wgswZIiro1BKlXG+vr5ER0fTtGlT7r33Xs6ePQvYhzdOSEhARJg4cWL2ewYMGMBM2xg+vXv3JiwsLLvffVJSEpGRkRccJyEhgaZNm5baeXh2wq9dG+64w9VRKKXKuODgYLZu3cqOHTsICAhgypQpF2xz2WWXMWHCBFJTU/Pch6+vLzNmzCjtUC/KsxP+M89APmNPK6VUUVx33XXEx8dfUB8aGsqNN97IrFmz8nzfoEGDGD9+fJ7DKTjKyMjgkUce4corr6Rjx47ZY/CXhOI+eOXefvtNZ7xSyoMMGjSIrVu3lug+o6Ojeeuttwq0bXp6OsuWLaNTp055rh8yZAidO3emb9++F6yLiIigbdu2fPjhh3Tt2jXfY+zdu5e5c+cybdo0unfvzsKFC3PMtlUcnn2Fr5RSJeDcuXNER0cTGxtLREQE/frlnu7DUq9ePVq3bs3HH3+c5/oXXniBsWPHkpmZme+x6tatS3R0NAAtW7YkISGh2PFn8ewrfKWURynolXhJy2rDL4hhw4Zxzz330L59+wvWNWzYkOjoaBYsWJDv+wMDA7OXfX19S7RJR6/wlVKqBDVu3JioqCgWL857FPjhw4czbtw4J0dl8eyEX4jpy5RSqqQMHz6cxMTEPNddeeWVxLhoBN9CDY/sbMUeHvmLL2D9ehg9uuSCUko5lQ6PnL/CDo/s2Vf4GRmQx9yTSinljTw74Q8eDC66yaOUUu7Gs3vpHDhg/SillPLwK3yllFLZvCPhu/GNaaWUchbvSPgXeapNKaW8hWcn/AcftF414SullIfftO3bFyIiQMTVkSilVKF07dqVVq1aceLECUaPHo2/v3+x9+nZV/j790O7duDn2d9rSinPcvz4cW666SYCAgJISUkpkWQPTrzCF5EI4G3gOLDHGPN6qR/0+efh6qvhxhvBx7O/25RSnqNatWo8/fTTJb7fYmVBEZkhIkdEZEeu+k4isltE4kVkqK36KuBTY0xfoEVxjltgSUmwbBkkJzvlcEopz3WpaQ5FhMGDB2dvP27cOEaOHJldvtR6R6tWraJXr14lfg7FveydCeSYCUBEfIHJQGcgCogTkShgA9BPRL4Fvi7mcQsnI8Oph1NKeZ5LTXMYGBjIZ599RlJSUp7vv9R6R9u2baNFi5K/Li5WwjfGrMZqonHUCog3xuw3xqQC84BuQB/gJWPMDcCt+e1TRPqLyCYR2XT06NHihGenCV8pVYLymubQz8+P/v37M378+Dzfc6n1jrZt28bhw4dp164dERERfPPNNyUSd2k0bIcBBx3Kiba6r4GnRGQKkJDfm40x7xljYo0xsaGhoSUTkSZ8pVQJyZrm8Kqrrrpg3ZNPPsmcOXM4depUnu+91Pos27ZtIzQ0lNWrVzNhwgTmzJlTIrE77aatMWYHcI+zjgfA//t/MGqU9sNXykMM+noQWw+X8Jy2NaJ5q9OlB1nMmuYQrCv8vKY5rFSpEg8++CBvv/02wcHBhV4PkJaWxrFjx7Lb+9PS0qhSpUphTilfpZHwDwG1Hcrhtjrnu/tuqFABKlZ0yeGVUp6joNMcDho0iJiYGPr06VOk9bt27aJ58+b42HoWbt++naZNmxY9cAelkfB/BhqKSF2sRN8D6FkKx7m077+Hpk014SvlIQpyJe5q1apVo3v37kyfPp2+ffsWev22bdto3rx5dnn79u1069atRGIrbrfMucB6oJGIJIpIP2NMOjAAWA7sAhYYY3YWP9QiGD4c3nwTUlNdcnillHcaPHjwRXvjXGz9tm3baNasWXZ5x44dJXaF79lTHGYNqbB3LzRoUDJBKaWcSqc4zJ9OcZgX7aWjlFJekvC1l45SSnlJwtcrfKWU8vCE//771qte4StVprnzvUZXKcrvxLMT/vXXw+TJUKuWqyNRShVRUFAQx44d06TvwBjDsWPHCAoKKtT7PHug+I8+gubNISTE1ZEopYooPDycxMRESmxsLQ8RFBREeHh4od7j2Ql/1Ci45hq46SYoX97V0SilisDf35+6deu6OgyP4NFNOsk+6fy2ew38+qurQ1FKKZfz6Cv823rC6kgw2ktHKaU8+wp/daRtQXvpKKWUZyf8LCY93dUhKKWUy3lFws/MSHN1CEop5XLekfCbNHZ1CEop5XJekfBNjRquDkEppVzOKxJ+ZpI+sKGUUt6R8Nevc3UISinlct6R8NP1pq1SSnlFwtcHr5RSyksSfmaG9sNXSinvSPjapKOUUl6S8Ntc4+oQlFLK5Zw2eJqI+ACjgErAJmPMLGcd24TpBChKKVWsK3wRmSEiR0RkR676TiKyW0TiRWSorbobEA6kAYnFOW5hZR7805mHU0opt1TcJp2ZQCfHChHxBSYDnYEoIE5EooBGwDpjzDPA48U8bqFkfrvKmYdTSim3VKyEb4xZDRzPVd0KiDfG7DfGpALzsK7uE4ETtm3y7ScpIv1FZJOIbCqpKc20l45SSpXOTdsw4KBDOdFW9xlwi4hMBFbn92ZjzHvGmFhjTGxoaGiJBKT98JVSyok3bY0xZ4F+zjqeo8xMvcJXSqnSuMI/BNR2KIfb6lxGm3SUUqp0Ev7PQEMRqSsiAUAPYFEpHKfAMjt3uvRGSinl4YrbLXMusB5oJCKJItLPGJMODACWA7uABcaYncUPtehMLe2Hr5RSxWrDN8bE5VP/FfBVcfZdkjL37IbW9VwdhlJKuZTnDq1gTPZi5vKvXRiIUkq5B69I+CZTu2UqpZRXJPxM7YevlFIenPAdaD98pZTy5ITv65u9mJmeDkeOwI8/ujAgpZRyLc9N+A4ye8bBf/8L7dq5OhSllHIZz0346fZmnNRqVaFhQ6vg0LavlFLexHMTfmZm9uL5nzZAQIBVSNPpDpVS3slpg6c5ncOVfMqSxTBrpVVITbUnf6WU8iKee4XvkPDTHK/qU1NdEIxSSrmeVyT8lNTzUKeOVdCre6WUl/LcJh2R7MXUtFRo3RqCg6FCBRcGpZRSruO5CT8oKHsxNT0NMs/BuXOQkZGjj75SSnkLz23ScbDhjmgr2R84AHv2uDocpZRyCY9N+D/u+SZ7+Z1Ds+Hxx62C3rRVSnkpj0347ebenKPcM+FNltWEP/74w0URKaWUa3lkG77PUB8Izlk3N3ktc+8B7rwTo0/beq6UFOvV4R6OUsrikVf410kr6u7P47usOtAN4o/H81fyX06PSznB5ZdbvbGy/PQTfPmltfz111C5Mpw+7ZrYlHIxj7zC/+G1DdYQComJEBHBvsWzuXX18+z+JwmioeFEa1ydzBczEYfum6oMu/ZaaN8e/v3XKq9ZY9232bHDKhsDw4db63fvhpYtXRerUi7ikVf4APj7Q9264OtL/Tv68PubRzk4+iCRf0Zmb3Lq3CnXxadK1rp1MH68vXz6tD3Zg/VcxpYt1rI+i6G8lOcm/DyEh4fz+zD7/LbPPHAHZ48edWFEqkSlpMDDD0OvXhAfn/92lSs7Lyal3IhTE76IlBeRTSJymzOP6yiwXkP8jXXaH2z7gfKXXcbiyZNdFY4qadOmwezZ9uctGjWCJ56wr+/aFQIDXRObUi5WrIQvIjNE5IiI7MhV30lEdotIvIgMdVg1BFhQnGMWm48Px4dZTTnR90cCcPuAAUx++WUXBqVKzPDhMGCAvdy0ac72+sWL4cwZ58ellBso7hX+TKCTY4WI+AKTgc5AFBAnIlEicjPwG3CkmMcstgoBVhvuVt8E/trzK11atmTAyJHc3749+/btc3F0qlhefRUmT4Zq1azywoUwZEjObbRbrvJSxUr4xpjVwPFc1a2AeGPMfmNMKjAP6AZ0AK4BegKPiEiexxaR/rZmn01HndC+nnZZJT5etYpnGzXiyzVraNOmDb///nupH1eVsDp14Omn7eWYGPtyUlLObfW+jfJSpdGGHwYcdCgnAmHGmOHGmEHAx8A0Y0xmXm82xrxnjIk1xsSGhoaWQng5nUw5SeXKlRl7//1sycwkIzmZJk2asGzZslI/tipBCQnw1lsXX1+vnrOiUcotOb2XjjFmpjFmibOPm9vAVgMBK+ED8PjjXHHTTQw5fx6ALl26WBOnJCZaXfo+/9xVoaqCuPpqGDjQXq5UCSpWtJfr1LHqlPJipZHwDwG1Hcrhtjq30ju6NwDHz9lapEJCYOVKnt27lxHNmwMwbtw4WGmbGnH6dBdEqQps0yaYNMlezsiA5GR7WQS2brWWtVum8lKl8aTtz0BDEamLleh7YLXbu5XwSuEA7D+xP0e9T/36jNq6lV333MPLL7/MPddfT0OA2FjnB6kK7/HHreS+a1f+21St6rx4lHIjxe2WORdYDzQSkUQR6WeMSQcGAMuBXcACY8zO4odaskLLWfcHBq8YnOf6iRMnEhQUxKNr12IAqld3XnCq6N55x+qlk9UPv2lTGOrQM7hrV50AR3mt4vbSiTPG1DTG+Btjwo0x0231XxljrjDG1DfGvFIyoZYsESGmptWT4+iZC3tt1KxZk7Fjx/JdcjIfgNXko9zf88/DQw/Zy3XrWgOqZVm8GPr1c35cSrkBrxpaIbcJnSYAsO7gujzX9+vXj2sCAhgD2sOjLPD3h7FjrSdts76glyy5sB/+woXOj00pN+DVCT+2ViwBvgGs+XNNnut9fHy4NTiY3cC327Y5NzhVOFdckTOxX3ml9WqMznKmlI1XJ/wgvyD+U/s/LN6zON9JUXo3bgzAgtdec2ZoqrB274ZRo/Jff+wYNGliLWv3TOWlvDrhA/Rs2pPdx3azYt+KPNeHP/YYdwFf/fOPzpTlzpo3hz597OWaNXP2w69WzT4L1nffOTc2pdyE1yf8B5o9QHilcMZvGJ/3BufPcwtw8Nw5du/e7dTYVCFs3w4zZ9rLefXD/+UXazkhwZmRKeU2vD7hB/sH81Dzh1ixb0WevXVo0oRbbItLly51amyqCJ5+2uqGmZXcAXxy/TO/+27nxqSUm/D6hA/QrVE3DIYJP024cGW7dtTp3JmW/v7M/egj5wenCuett+C11+wToMTEwIsvujYmpdyEJnygZa2WRFSO4NUfX2XqpqkXbvDSS3Tv0IHNW7dyKDERjuceIFS5jWeegW7d7OXLLoP0dNfFo5Qb0YQP+IgPmx7ZxI31buTxpY8zYcOEnM07rVvTbeJEfHx8GP7ww1af/Ecfhb17XRe0ulDlyta8tosWQdZIqytXwv/+59q4lHITmvBtQsuH8sV9X9CyVksGLR9E7fG1uWfBPaw+sJr0zHQaNWrE0KFDmbV8OT9eeSXMmAFt2oBtdE3lYs2awQsv2MsNGlivGRmuiUcpN6QJ30H5gPL89PBPbO6/mUdiHmH1gdW0n9mesDfDeOm7l+j7dF9CQ0N5pWJFmDDB6tt94oSrw1Zg3aR97jl72ccHAgLs5dRU60sB9Klp5bU04efiIz7E1IxhYpeJ/PH0H8y+YzatwloxavUomkxtQt2BdVm+czlrDh+23vDvv64NWFmaNYPu3e3lyMic642xT234ySdOC0spd6IJ/yLKB5SnV/NeLI5bzN6Be+lYvyMbMzdCP2i/8BXuadOG/efOuTpMBbBzZ84xcnIPqRAYCL/+ai3r8xTKS2nCL6D61eqzpOcSDgw6QNOQpvjd48eS1C20aNeOJUtcPoGXyvLcc/DKK7B+vb0u91AKPd1uegalnEITfiFFVI7g856fE1WjMee7nqfSdQH06NGDAwcOuDo0BTBmDAwbBn/8YZXbtMl5M1cpL6YJvwgaVGvAz/1+4o6kEA7FJnGm4hkiIyM5ffq0q0NTTz0FHTrYy+XKgX4ZKwVowi8yv4AgPhj1K0HGF2616ma+/rprg/J2tWrBxInwww/WA1dgLU+Z4tq4lHITmvCLoUqVGgxpPxxqQ726wvOvvsqv27e7OizvdPXVOZtuIiKsV33KVqlsmvCLaXBbq+/3/ocM/tcF0KlzZ72J6wrffptzeOSAgJzDIxtjjasD0LKlc2NTyk1owi+mCgEVCPQNBODfG85TLsCfrl278v7777s4Mi9z3XU5e99ccUXO4ZGPH4eseyxT8xgvSSkvoAm/BJwbfo7rIq4DoOpdx4mpCi+9+CLnddgF59m61RpDJz/Vq8OePdZyVn98pbyM0xK+iNwhItNEZL6IdHTWcZ1BRPih9w+MuWkMO4OT8e8Mf/39NzMdJ+RQzjFiBLz9ds5ZrWrUyLmNY9OPUl6kWAlfRGaIyBER2ZGrvpOI7BaReBEZCmCM+cIY8wjwGHBfcY7rjkSE5659juEbAvjpCojoXJXRo0eTmZnp6tC8y6hRMHCgvStmhw45x9hRyosV9wp/JtDJsUJEfIHJQGcgCogTkSiHTUbY1nukp17+mthDcOjqk/yR8gcbN250dUje5cknrfltsxiT86lbpbxYsRK+MWY1kHs2kFZAvDFmvzEmFZgHdBPLaGCZMWZLfvsUkf4isklENh09mseUg26uwrXXs+L0nVx2TpC7hDnz57g6JO/RsCG88441v21WP/x16+DTT10bl1JuojTa8MOAgw7lRFvdQOAm4B4ReSy/Nxtj3jPGxBpjYkOzJrEoY6o2b83MzzIxoYZp+6fpE7jO0K5dzn74We32aWmuiUcpN+S0m7bGmLeNMS2NMY8ZYzz70ce4ODoeqchdh2pxPuY8Q6YMcXVEnu+TT+C22+zl4OD8++F39Kg+A0oVWGkk/ENAbYdyuK3Oe0REwCuvMLvFEILPBjP18FQSkxJdHZVn69oVHnzQXm7WLGc//IMHISnJWtYpD5WXKo2E/zPQUETqikgA0AO4SAdpDzVwIOUff4o32r5BRsUMmg5tSvyBeFdH5ZkyMmDjRvj66/y3iYiAP/+0ln/+2TlxKeVmitstcy6wHmgkIoki0s8Ykw4MAJYDu4AFxpidxQ+1DEpL4/GDhnuTruRU7VM0frcxH/7yoauj8jxZM1mB1S1z+nT46it7Xe7Zr5580ilhKeVuittLJ84YU9MY42+MCTfGTLfVf2WMucIYU98Y80rJhFoGZWbC+vUsmLSTYStrkHEyg95f9mb9Qe0mWKIcE/6IEdC3LxyytSLecgs8+6xr4lLKzejQCqUpMBA+/BA+/JBX1h6m98owMk9mctfHd3Em9Yyro/NMfftCWJi9fPo0LFjguniUciOa8J3hgQfguut4q1ZdLlt3GYdTDjPi2xEYxytTVXRZv8eYGPjgA/jrL8jq0rtpE6xe7brYlHIjmvCdpVkzKkdF8fx9z8MmeOunt7hx9o2kZqRe+r3q4kTg1lvh+eftdSEh1qsOYKdUNk34zjJpEkyeTO/evQlcFUib5DZ8l/AdH23/yNWRlX3+/tbv95pr7HWVKl3YD79FC2v53nudG59SbkITvrOsXQv+/lTfuZM7br+D+A/jiQqJYvLPk0lJT3F1dGXfAw9Av372cmxszn74v/8OibZnIQYNcm5sSrkJTfjO0rat9bpyJXfddRdHjxyla9WubPl7C7XeqMW0zdNcG19Zdv689YW6alX+2zRpAlljM2mbvvJSmvCdLSaGrl27EhISwvaPtrPqwVVE14im/5L+jF4z2tXRlU2OQ1CPHQvz58PChfa6OnVybu845o5SXkQTvrMEBFiv0dEEBwfz/PPPs2zZMjL3ZbKi1wrimsYxdNVQhqwcwtm0s66Ntaxx7O00aBB06waHD1vlbt1g2DDXxKWUm9GE7yw33GC9+vsD8PTTTxMaGsq4cePw8/Fj9p2zebjFw4xZN4bb597uwkDLuF69oHJl+5fAP//AW28VfX+TJlkTpCvlATThO0tEhPU6dy4AAQEB9O/fn+XLlzNx4kT8fPyYdvs0xtw0hlV/rGLNn2tcGGwZk5Xc27WDefOsNv2sfvhbt8KuXUXf98CB0Lt3sUNUyh1owneWli2t17P25prhw4cTExPD8OHDOXbsGABPXP0EIeVCeG7lc5xO1XH0C8TXF3r0yDmEQuXK1mtKCfSAOnjw0tsoVQZowneW/v2tQby++ALS0wEIDg5m1qxZJCcnM378eADKB5Rn9E2j2ZC4gRtm3UB6ZroLgy4jgoJg5Eho0MBeV716/uPhO3bfVMqLaMJ3prFjrSaGd9/NrmratCn33nsvb7/9NgdsE2/3bdGXyQ0H8fNfP7kyJEIAABnySURBVPP6mtddFW3Z8vjj8Oij9vJ//pOzH/7mzbB3r7X8wAPOjU0pN6EJ35nuvhuuvx5mz87Rs+T1118nMzOTl19+Obvuifvf4u7f4PU1r5N8Pjmvvaksycnw3Xfw44/5b+P4INaKFc6JSyk3ownfmUSs0TPXrLGWt22D+Hjq1atH165dWbp0KZlZfcofeohn/ricM2ln+OS3T1wbt7tz7Ic/aRIsWQIfOQxZkXs8/NdeK/i+K1a0xulRygNowne2sDBr2GSAZ56BK66AkSPp1KkTR44cYedO21wxKSm0OVWJppc15ZUfXyHpbJLrYnZ3jv3we/e2xtSx3QSnRw948cWi7/uff+Dzz4sVnlLuQhO+K82ZY3UfnDOHNq1bA7Bx40Zr3fz5yJ69TLhxHIf+PUSTyU1Y+NvCi+xMAVY//JAQ+5fAvn05R9EsrHHj4IcfSiY2pVxME74r1agBw4dDfDwNbriBKuXK8WOudugbarRh4yMbiawSSc/PenLwlHYRvEBWcr/tNvvVePXq1utvv9knLy+KF1+0/kpQygNowne1AQPg44/xad6c7h07MmfOHN4cNgzz9NPW+vPnaXZ5Mz6991OMMYz8fqRLw3VLAQHwyCM5R8EsX956PVMCM4tlNQ8pVcb5uToAr+fjA3FxEBfH6ydOcKhXLwa/9hrfAHOByrYHh+pUqUPfFn2Zunkq/6n9H/rFaF/ybOXLwxNPZD/fAEDNmtYN16yeOWlpVk+dbdtg8GDXxKmUi+kVvhupWrUqixcv5v+eeYZlwP8gx4xNr9/0OjE1YxiwbAAPL3qYTX9tclWo7mfIEGsYhCzt2uXsh79mDezYYS3fcotzY1PKTTgt4YtIeRGZJSLTROR+Zx23rBER/t8bb3A/MBHYlZCQva5KUBW+6vkV90bdy4KdC2gzvQ1TN011Vaju49gxq2/9hg35b3P99ZCRYS0v1JvfyjsVK+GLyAwROSIiO3LVdxKR3SISLyJDbdV3AZ8aYx4BdDjISxjeowfpPj5E3Xwzzz33HKmp1ty3l1e4nNl3zubgfw/SsX5HHlv6GB0/7Mgrq19hx5Edl9irh3Lsljl9ujW65VSHL8Lc4+FPLcSXZHQ0dOhQrPCUchfFvcKfCXRyrBARX2Ay0BmIAuJEJAoIB7K6mGQU87ger8ncuWz55Rce7tKFcePG0bZmTdZ89BHGltwqB1VmUY9FjLp+FAknExjx3QhaTG3BuoPrXBy5Czgm/DvugLp14d9/rXLfvjBqVNH3/csv1lO8SnmAYiV8Y8xq4Hiu6lZAvDFmvzEmFZgHdAMSsZL+RY8rIv1FZJOIbDqaNSWdl2rWrBnTBg7kk1atiD9+nOt69aJRxYo8Ur48qz7/HF8fX0a0G8GegXv4e/DfhFcK58HPH/TuoRgefNBK+FlfAtu3F31448xM6+G4lStLLDylXKk02vDDsF/Jg5Xow4DPgLtF5F1gcX5vNsa8Z4yJNcbEhmaNae7NOnXinp9+4s+dO5lx9dVEnjnDJ2fPcvPdd7PCYUyYGhVqMLPbTPaf2E/NN2rSYWYHhq8azrGzXtClMCu5x8XB0qXWctWq1uvvv+cceqEwMjNh/Hi4XVsglWdw2k1bY8wZY0wfY8zjxpg5zjqup6gQFUWfjRtZ8eij/AkYY7jlllvYsmVLdjNP+8j2fN/7e3pH9yYlPYVX17xKyNgQZvwyI3sbjxQcDP/9r9U1M0tQkPV62jangK9v4feb9TsriTH1lXIDpZHwDwG1HcrhtjpVEl5/nUo+Pnx07bUAtGzZkipVqtCyZUteeOEFKp2oxKQuk9jw8AYWx1l/SPVb1I8mk5swbNUwVh9YTVpGmivPoORVrAj33ZezH37dujnHw09OhqZNreWCDrVQ1L8MlHJTpZHwfwYaikhdEQkAegCLSuE43qlKFRg2jPvXrmX3m2/y5ptv8tBDD1G5UiXGjh1LixYtiImJ4X//+x+Xn7qc8yPOM+XWKVxe4XLGrB1D+5ntCR0bypCVQ0jNSM37GCLQp49zz6s4MjNh6FB46il73Q035OyHv2KFvR9+u3YF268n/1WkvJMxpsg/WA+D/g2kYbXV97PVdwH2APuA4UXdf8uWLY3KQ0aGMZ99ZsxffxmTmWlMnz7GjBhhkpKSzKRJk0x0dLQBDGCeeeYZk5mZaYwx5uS5k+bTnZ+aTh91MozEDF4+OO/9W6nOiSdUTH/9ZY8ZjPHxMebw4Zx1jj+3316w/Z49W/Z+F8rrAZtMfjk7vxXu8KMJv4A6d7Y+yn37squSkpLMbbfdZgDz1VdfmczMTBMTE2OmTp1qjDHm0cWPGkZiWkxpYe6cd6eZvmW6ycjMsN5c1pLcoUP2mOfONWbDBmOef95eFxl5YdIvqPvvN+baa0svdqVK2MUSvg6t4Amee8567dkzu6p69ep8+umnNGrUiC5dunDDDTewZcsWHrVNAzipyyT+d/3/CCkXwvZ/ttNvUT9u/vBmfk/6HSIiCjdJiKs5Nr106GDdxM260frEE/Dqq0Xf90cfWcMyKOUBNOF7guuvt0aK3LLFPnwAEBgYyPLly3nwwQf5/vvvs+vXrl2Ln48fw9sNZ0WvFewduJdpXafxU+JPNJnchNABZ2lfYxlj1o4hI7OMPSP3wAPQvLn9S2D9+hxfhIWSkmKNwqlTIioPoQnfU1x1FVSoAGfPWuWtW+HAAepERDBr1iySk5N57733qFu3Lm3btiU2NpZVq1YB1vg9D8c8zJ6Be5jUeRJ30oRzhxMZ8s0QWkxtwZi1Y/gh4QfOpp114QleRFZyf+wxsJ0TlSpZr/HxRd9vaiq8/74OtqY8hhg37okQGxtrNm3SESEL5PRpq/nhscescs2acPgwtGwJI0dak4MAp06dYsqUKUyZMoWEhATuvfdeZsyYQYUKFbBtYPUEAj7YMoNX17xK/HEraQb7BRMVGkXtyrWpX7U+V9e6mpvr30y14GrOPtucTp2CN9+0HpCKjbXqRo60frKEhOScCCUz0+qNdDEnT9of4HLj/ydKORKRzcaY2DzXacL3UCtXWrM9DR1qNU2MHQvPPmutM4aU8+cZN24cL730Eh07dmTRokX4+/tbXxI1a2ZvB3D0zFE2HtrIin0r2HN8D3+e+pP9J/aTkp5ClaAqLOy+kBvq3pB96ISTCVQPrk7FwIq5oyo9P/xgdcPs2tUqL1gA/frZu2aePAlt2sCuXTBsGLzyyqX3eeIEVLN9mbnx/xOlHGnC92ZbtkD//lbC2rzZauO/+27r5uakSbx/9dU8Mm8eUVFRtG7dmso+PkRNn05PoPxF/m2kZ6bzU+JPPLL4EXYl7aJxSGPqVa1HOf9yfPrbpwBM7jKZJ65+It99lJiMDGjbFo4eteawBWvI5KxpDgFmzYKHHrKWP//cGmTtUo4ft+/Djf+fKOVIE76ymjNCQqyr1ptvtpK/zYLZs3nr3Xc5ePAgx48d4+y5c9QBJi9Zwq233nrR3Z44d4L3Nr/HhkMbOHDyACdSTpBwMiF7feaLmcilmk6K688/cw6BXL067NmTM+E7uuYa+P57CAy8+H414asySBO+yikjw2rycOy9EhwMwcGYb75hdUwMTwC7fX359ttvaVfQJ1Nt9hzbQ6NJjQBoHdaaXs16cXfU3dSoUKMET8LBgQMQGWktf/GFNazCjBkwYYJVV6eOtY2j06ft895ezJAh1vj6P/9coiErVVoulvC1l4438vW1RpbcsgXmzbP6qT/xBPTogVSqRPvWrVm3cCER4eG0b9+e6tWr07x5c5YvX16g3V9R/QpSR6TyTpd3OJ16mgHLBlDrjVq0mtaKqMlRzNsxr2R7/DhetLRoYbXbZ3VPHTwYxoy58D0ZBexuOnq0JnvlMfQKX+Xr7wce4MM5czgArPTxIcnPj/0JCVTJuqlbQL8d/Y1Pdn7Coj2L2PL3FgCC/IK4tva1RFaJJKxiGGGVwrJfIypHFK7nT0KCdVUPVlv+mjXw5JMwebLVXfXXXy98z/Hj9h44+Tl1Ch591Lr5e/PNBY9HKRfSJh1VNMuXw7ZtcOYMW9evp8XKldxYsyaLd+4k+FLJMh9n086yZM8S1h1cx9qDa0n8N5F/Tv+DIee/w5ByITQJaULjkMY0CWlCk9AmtAprlfcXwR9/QL161iiYWVfzWcvlytmfTXCUlJR/G3+WPHosKeXuNOGr4jOGYf7+vJaRgQ9wec2ahIWF0bBhQ0aNGkX9+vWLvOu0jDQOnz7MoeRDHPr3EAknE/g96Xd2Je1iV9Iujp+zJlUL8gvioeYP0fOqnjSs1pAaFWpYN4RPnYJp06BTJ+uKHqzuqGPH2ptuGje2JkPJUpCE/9dfEBaWff5KlQUXS/h+zg5GlVEivHL+PB07d+bblSs5FBjIoYAAli5dypdffsmYMWN44oknitQjx9/Xn9qVa1O7cu081x89c5SdR3fy8a8f88HWD5i62ZqEvJx/OS4vfzkVAytSySeTiss+osK9UCUFOtQ/y63VylP5qG1u2x9/hOuus5L+iBGXTvagSV55HL3CV4WTnm7d5B09Gs6e5c/u3Xls3z6Wbd7MjBkz6FPccfRTUqx5ZP/v/6xupLkcOXOErYe3svfYXuKPx5N0Lonkc6f4d913JJsUkn3SOVIeTgRDYDp03gud4iHmgeeIeWYsvgbrRvV99106lsREqG37EnLj/ydKOdImHVXyTpywbmZ+/jmZwPVBQWwEvv76a9q3b1/0/c6ebT0g1a+fNY5NQcTHQ8OG2cXMhg3Y8PlEFjzbmQVXwt8OD/wGp0GVdD+q1KpL1Qqh1KlchytDr+TuqLtpHNI45361SUeVQdqko0pe1arw2WeQkoLP0KHMmzCBlpUqERcXx4IFC2jbtm3R9pt1RV2YnkCOyXjlSnwiIvjPpEn852sYtwI2xNZgR+Zh/ikP/wbCv4HpnGhcn2OSwvrE9czbMY8R342g+eXNaRvRlg6RHWhZsyV1atbBZ8KEgn/xKOXm9ApfFd/ff0ODBuw4e5Ybq1ThyMmTPHLffbz88svUbNSocPvKuqqeMsXqElkQe/ZA1nH27YO9e2HJEpg0ybp5e/XV1nASjuLjwXaj+fDpw8zcOpPvEr5j7Z9rOZN2JnuzljVbUq9qPULLhVK9XHUqBVaiUmAlKgZUtO4d2JYrBVaiWnA1qgYXrfeSUiVFr/BV6apZE44coen777Pj7rt57c03mTB+PNPmz6eGnx9NoqJo0rYtISEhlCtXjvLly+Pn50dKSgpdu3alXr16F97sPX26aLHce6/1QFnWl8Xnn8Prr1+4ncODVzUq1GBo26EMbTuUtIw0tvy9hV8O/8LW/evYt+ErttX4h2Oc4/i54xd0H82tVsVadKrfiX4x/bi61tX4+/oX7TyUKgV6ha9Kxc4PPmD5/Pn8+s037MrIYLe/PyfT0vLcNiIigm7duhEXF0ebhARryIdNm6yhnQti926r2+Wrr1ojYQIMHAgTJ0JAgDWufW67dlnvuZh9+6BBA2s5NZVMP1/OpJ7h3/P/kpyabL2eT85ePnLmCL8c/oUvf/+SM2lnCPYLpnV4a9rXac9dTe6iYbWGBPsHF+yclCoivWmrXGfPHnj7bfj2W8wXX3AuPJwzkyZxdsgQjgMbXn2VBStWZM/I9WynTvT9+msazJiBf0F7/Jw8CfPnw4032m/ePvUUvPeefarD//wH1q2zv2ffPuthrYvZuxeuuMJaPncOgoIKFk7KSVbsW8HaP9ey9uBafjn8C5kms2DnohQQWi6UI88dKdJ73SLhi8gdwK1AJWC6MeaS88ZpwvdQv/0GV15pL991F9tfeolhw4axbOlSMrHaGi+/7DJ88hnR8oImoHPnrGaa49ZDWoSEWMuZtkQbFgb//GN1K61c2fq5lPR0654CWDeTizjqZ0ZwBufCzpFRLgPj674XWO5GyPv33aBBA26zTejjCsaYUh8Btpx/OZ6/9vkivbfYbfgiMgO4DThijGnqUN8JmAD4Au8bY/JoLLUYY74AvhCRqsA4QCcK9VZRUVYinjULtm+HGjVo1qwZS5Ys4Q8RfgR2A39XqQLXXmu959QpazjjoCAuuEjJyIBFizDnztlTRMeO8PHH9m1CQ+HQIWs5Oto+9s7FnDpl3QMAaNcO/LU93lkudiHask5LBnYY6MRoPEeBrvBFpB1wGpidlfBFxBfYA9wMJAI/A3FYyf+1XLvoa4w5YnvfG8AcY8yWSx1Xr/C9UEICPP209WRsjx7wzjvWl0NgoHXFfdVV1jg56enQvbs1Vs6uXdaXSJZrroHFi60kn5dateDTT60ZsC5m//7snjycOJE99aNS7qzYV/jGmNUiEpmruhUQb4zZbzvIPKCbMeY1rL8GcgchwOvAsoIke+WlIiPhyy+t5azmmMxM64GsBQus8e579bLqu3e3Xm+wT6/IunVW883LL9vrco+H/9dfVvPOpdSrZ90bGD++yM05SrmT4nTLDAMOOpQTgdYX2X4gcBNQWUQaGGOm5LWRiPQH+oPVe0N5MR/bdA1+ftb4/XFxVlv93r3WXwLlylnNOY5j2ycnW6NkTp5slV980WrCueuunPsuaLfP7t3tXyxKlXFOmwDFGPO2MaalMeax/JK9bbv3jDGxxpjY0Pz+JFfeKzgYmjWD22+3yr6+1hcAWE04R49aXTqzrFt3YbIH++TmF/PHH9C+vTUdolIeoDgJ/xDgOLxhuK1OKeeqXNkaXuHIEbj/ftiwwfoLoHdvq2vm2LHwwAP2piCAtWsvvd/Tp2H1arj++oI1ASnl5orTpPMz0FBE6mIl+h5Az4u/RSknqVMHPvjAWn72WXv97NnwxhvWTViwJke56iprasS337Zu6GbJdOg7f/586cesVCkraLfMuUAHIEREEoGXjDHTRWQAsByrZ84MY8zOUotUqZIyeLB9wLXkZOuJ3k8+sZqCuneHmBirh5BjD7bjx0HvKakyTp+0VQpg6VJ45RXYvBkqVIBjx6zlWFvvtqeespqGAgLg33+tm8dgNScV8AlcpZzBLZ60LQpN+MrpUlOtLpwNG8Ivv1hX+1myhld47DGYas26RUAA1KhhPYm7Zo1VN2AAfPddzv1GRMCyZdZynz6wcWPO9Y0bw8KF1vJ998GOHTnXt2xpNUcB3HabdUPZUbt28O67RTtn5VF0tEylCiogwD4eT4sWVrPOyZPWw11ZV/JxcdC8udUddM8e64rfcQiI2rVzPggG1pdClsjIC7uFRkbal+vWzXn/IPf6+vWt3kqOtLlJFYBe4SullAe52BW+0/rhK6WUci1N+Eop5SU04SullJfQhK+UUl5CE75SSnkJTfhKKeUlNOErpZSX0ISvlFJewq0fvBKRo8CBS26YtxAgqQTDcRd6XmWPp56bnpd7qmOMyXMyEbdO+MUhIpvye9qsLNPzKns89dz0vMoebdJRSikvoQlfKaW8hCcn/PdcHUAp0fMqezz13PS8yhiPbcNXSimVkydf4SullHKgCV8ppbyExyV8EekkIrtFJF5Ehro6nsIQkdoi8p2I/CYiO0XkaVt9NRFZKSJ7ba9VbfUiIm/bznW7iMRc/AiuJSK+IvKLiCyxleuKyE+2+OeLSICtPtBWjretj3Rl3JciIlVE5FMR+V1EdolIG0/4zETkv7Z/hztEZK6IBJXVz0xEZojIERHZ4VBX6M9IRB6ybb9XRB5yxbkUh0clfBHxBSYDnYEoIE5Eoi7+LreSDgw2xkQB1wBP2uIfCqwyxjQEVtnKYJ1nQ9tPf8DdJzV9GtjlUB4NjDfGNABOAP1s9f2AE7b68bbt3NkE4GtjTGOgOdY5lunPTETCgKeAWGNMU8AX6EHZ/cxmAp1y1RXqMxKRasBLQGugFfBS1pdEmWGM8ZgfoA2w3KH8AvCCq+Mqxvl8CdwM7AZq2upqArtty1OBOIfts7dztx8gHOs/1Q3AEkCwnmb0y/3ZAcuBNrZlP9t24upzyOe8KgN/5I6vrH9mQBhwEKhm+wyWALeU5c8MiAR2FPUzAuKAqQ71ObYrCz8edYWP/R9plkRbXZlj+5O4BfATcLkx5m/bqsPA5bblsnS+bwHPA1mzc1cHThpj0m1lx9izz8u2/pRte3dUFzgKfGBrrnpfRMpTxj8zY8whYBzwJ/A31mewGc/4zLIU9jMqE5/dxXhawvcIIlIBWAgMMsb867jOWJcWZaovrYjcBhwxxmx2dSylwA+IAd41xrQAzmBvGgDK7GdWFeiG9YVWCyjPhU0iHqMsfkZF4WkJ/xBQ26EcbqsrM0TEHyvZzzHGfGar/kdEatrW1wSO2OrLyvleC9wuIgnAPKxmnQlAFRHxs23jGHv2ednWVwaOOTPgQkgEEo0xP9nKn2J9AZT1z+wm4A9jzFFjTBrwGdbn6AmfWZbCfkZl5bPLl6cl/J+BhraeBAFYN5kWuTimAhMRAaYDu4wxbzqsWgRk9Qh4CKttP6v+QVuvgmuAUw5/oroNY8wLxphwY0wk1mfyrTHmfuA74B7bZrnPK+t877Ft75ZXX8aYw8BBEWlkq7oR+I0y/plhNeVcIyLlbP8us86rzH9mDgr7GS0HOopIVdtfQB1tdWWHq28ilPQP0AXYA+wDhrs6nkLG3hbrz8rtwFbbTxesttBVwF7gG6CabXvB6pW0D/gVq0eFy8/jEufYAVhiW64HbATigU+AQFt9kK0cb1tfz9VxX+KcooFNts/tC6CqJ3xmwMvA78AO4EMgsKx+ZsBcrHsRaVh/lfUrymcE9LWdYzzQx9XnVdgfHVpBKaW8hKc16SillMqHJnyllPISmvCVUspLaMJXSikvoQlfKaW8hCZ8pZTyEprwlVLKS/x/uznRHKRIN0oAAAAASUVORK5CYII=\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"}}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":333},"id":"jy_CDp9yo8c_","executionInfo":{"status":"ok","timestamp":1633451535625,"user_tz":-120,"elapsed":714,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"3504f7a4-2fb9-4849-ef29-1cfd6d7faacb"},"source":["plt.title('RMSE')\n","plt.semilogy(error,label = 'MPINN',linestyle='dashed',color='red')\n","plt.semilogy(error_train,color = 'black',label='PINN h')\n","plt.semilogy(error_train_2,color = 'green',label=r'PINN $\\tilde{h}$')\n","plt.legend()\n","print(error[-1])\n","print(error_train[-1])\n","print(error_train_2[-1])"],"execution_count":181,"outputs":[{"output_type":"stream","name":"stdout","text":["0.0012881400747167334\n","0.006266018424977483\n","0.006734193686157428\n"]},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"}}]},{"cell_type":"code","metadata":{"id":"Giqn6HFHRlT9","colab":{"base_uri":"https://localhost:8080/","height":236},"executionInfo":{"status":"error","timestamp":1633451535908,"user_tz":-120,"elapsed":291,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"e24436d7-cdb5-4ab6-fca3-704694de3c5e"},"source":["xx=np.array(range(0,15000))\n","vecx2=3*nx*(nh+nH)*xx\n","vecx=3*nx*nH*xx\n","#vecxH=3*(nx**2/2*15+nxH**2/2*10)*xx\n","plt.semilogy(vecx,error_train,color = 'black',label='PINN h')\n","plt.semilogy(vecx2,error_train_2,color = 'green',label='PINN h+H')\n","print(len(error_train))\n","print(len(error_train))\n","\n","s=0\n","yy=xx\n","for i in range(0,15000-1):\n","  if i%5==0:\n","    add=nxH*nh+nx*nH\n","  else:\n","    add=nx*nh\n","  yy[i+1]=yy[i]+add\n","  \n","  \n","yy=3*yy\n","print(yy)\n","plt.semilogy(yy,error[:15000],label = 'MPINN',color='red')\n","plt.xlabel('operations')\n","plt.ylabel('RMSE')\n","plt.legend()"],"execution_count":182,"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-182-8f63dab9a2ac>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mxx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m15000\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[0;32m----> 2\u001b[0;31m \u001b[0mvecx2\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m3\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnx\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnh\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0mnH\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mxx\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0mvecx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m3\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnx\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnH\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mxx\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;31m#vecxH=3*(nx**2/2*15+nxH**2/2*10)*xx\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msemilogy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mvecx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0merror_train\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mcolor\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m'black'\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'PINN h'\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 'nh' is not defined"]}]}]}