{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"MPINN_2D.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 two dimensional equation (with ADAM solver)"]},{"cell_type":"markdown","metadata":{"id":"lDlIo9lR_sFs"},"source":["We consider a 2D linear problem:\n","\n","$$-\\Delta u + \\alpha e^u=f$$ on $$(x,t)\\in\\Omega = [0,1]\\times[0,1]$$\n","\n","Boundary conditions : $$u(0,t) = 0\\text{ , }u(w,t) = 0 \\forall t \\in [0,1]$$  \n","\n","Initial conditions :  $$u(x,0) = 0 , u(x,1) = 0\\forall x \\in [0,1]$$\n","\n"]},{"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":1622563131510,"user_tz":-120,"elapsed":3049,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"795e1101-6bbd-48cd-a624-53d693f1122a"},"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 = 42\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":null,"outputs":[{"output_type":"stream","text":["Cuda in use\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"QVWCFkJttTe2"},"source":["### 2. Model class"]},{"cell_type":"code","metadata":{"id":"93wd-rdK_sFx"},"source":["class PINN(nn.Module):\n","    \"\"\"\n","    Allows the creation of Physics informed neural \n","    networks made of :\n","        - an input layer taking two elements: the position in space x and in time t \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(2,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,t):\n","        u = torch.cat((x,t),1)\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":null,"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"},"source":["# Number of points \n","nx = 22\n","nt = 22\n","nxH = 20\n","ntH = 20\n","w=1\n","tf =1\n","# Coordinates of points in the domain \n","vx = np.linspace( 0, w, nx)\n","vxH = np.linspace( 0, w, nxH)\n","  \n","vt = np.linspace(0,tf,nt)\n","vtH = np.linspace(0,tf,ntH)\n","\n","# Create grid of points \n","xx,tt = np.meshgrid(vx,vt)\n","xxH,ttH = np.meshgrid(vxH,vtH)\n","\n","\n","# Data classification \n","mask_cl = np.bitwise_or(xx == 0 , xx == w)\n","\n","mask_ci = np.bitwise_or(tt==0,tt==tf)\n","\n","mask_inter = np.bitwise_not(np.bitwise_or(mask_ci,mask_cl))\n","\n","mask_clH = np.bitwise_or(xxH == 0 , xxH == w)\n","\n","mask_ciH = np.bitwise_or(ttH==0,ttH==tf)\n","\n","mask_interH = np.bitwise_not(np.bitwise_or(mask_ciH,mask_clH))\n","\n","# Boundary conditions \n","xx_init = xx[mask_ci].copy()\n","tt_init = tt[mask_ci].copy()\n","T_init = np.zeros(tt_init.shape)\n","\n","xx_initH = xxH[mask_ciH].copy()\n","tt_initH = ttH[mask_ciH].copy()\n","T_initH = np.zeros(tt_initH.shape)\n","\n","\n","xx_cl = xx[mask_cl].copy()\n","tt_cl = tt[mask_cl].copy()\n","T_cl = np.zeros(tt_cl.shape)\n","T_cl[xx_cl==0] = 0\n","T_cl[xx_cl==w] = 0\n","\n","xx_clH = xxH[mask_clH].copy()\n","tt_clH = ttH[mask_clH].copy()\n","T_clH = np.zeros(tt_clH.shape)\n","T_clH[xx_clH==0] = 0\n","T_clH[xx_clH==w] = 0\n","\n","# Interior condition \n","xx_inter = xx[mask_inter].copy()\n","tt_inter = tt[mask_inter].copy()\n","\n","xx_interH = xxH[mask_interH].copy()\n","tt_interH = ttH[mask_interH].copy()\n","\n","#nonlin parameter\n","alpha=0.1\n","#solution parameter\n","beta=3\n","def uu(x,y):\n","    \"\"\"\n","    Problem solution\n","    \"\"\"\n","    a=np.pi*x\n","    b=np.pi*y\n","    ux=np.sin(a)+np.sin(beta*a)\n","    uy=np.sin(b)+np.sin(beta*b)\n","    u=ux*uy\n","    return u\n","\n","def ff(x,y):\n","    \"\"\"\n","    equation second term function \n","    \"\"\"\n","    a=np.pi*x\n","    b=np.pi*y\n","    ux=np.sin(a)+np.sin(beta*a)\n","    uy=np.sin(b)+np.sin(beta*b)\n","    f=uy*(np.pi**2*np.sin(a)+beta**2*np.pi**2*np.sin(beta*a))+ux*(np.pi**2*np.sin(b)+beta**2*np.pi**2*np.sin(beta*b))+alpha*np.sin(ux*uy)\n","    return f\n","\n","f_interH=ff(xx_interH,tt_interH) \n","f_inter=ff(xx_inter,tt_inter) \n","\n","groundtruth=uu(xx_inter,tt_inter)\n","groundtruthH=uu(xx_interH,tt_interH)"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"Rj4JzbmX0t9q"},"source":["#### 3.2 From numpy to Pytorch"]},{"cell_type":"code","metadata":{"id":"GDKt5ZkE_sFy"},"source":["# Add of a dimension for the format 'batch'\n","\n","xx_init = np.expand_dims(xx_init, axis=1) \n","tt_init = np.expand_dims(tt_init, axis=1) \n","T_init = np.expand_dims(T_init, axis=1) \n","\n","xx_initH = np.expand_dims(xx_initH, axis=1) \n","tt_initH = np.expand_dims(tt_initH, axis=1) \n","T_initH = np.expand_dims(T_initH, axis=1) \n","\n","xx_cl = np.expand_dims(xx_cl, axis=1) \n","tt_cl = np.expand_dims(tt_cl, axis=1) \n","T_cl = np.expand_dims(T_cl, axis=1) \n","\n","xx_clH = np.expand_dims(xx_clH, axis=1) \n","tt_clH = np.expand_dims(tt_clH, axis=1) \n","T_clH = np.expand_dims(T_clH, axis=1) \n","\n","xx_inter = np.expand_dims(xx_inter, axis=1) \n","tt_inter = np.expand_dims(tt_inter, axis=1) \n","f_inter = np.expand_dims(f_inter, axis=1) \n","\n","xx_interH = np.expand_dims(xx_interH, axis=1) \n","tt_interH = np.expand_dims(tt_interH, axis=1) \n","f_interH = np.expand_dims(f_interH, axis=1) \n","\n","\n","# Transformation in tensor form  \n","tensor_xx = torch.from_numpy(xx).float().to(device)\n","tensor_tt = torch.from_numpy(tt).float().to(device)\n","\n","tensor_xx_init = torch.from_numpy(xx_init).float().to(device)\n","tensor_xx_init.requires_grad = True\n","tensor_tt_init = torch.from_numpy(tt_init).float().to(device)\n","tensor_tt_init.requires_grad = True\n","tensor_T_init = torch.from_numpy(T_init).float().to(device)\n","tensor_T_init.requires_grad = True\n","\n","tensor_xx_cl = torch.from_numpy(xx_cl).float().to(device)\n","tensor_xx_cl.requires_grad = True\n","tensor_tt_cl = torch.from_numpy(tt_cl).float().to(device)\n","tensor_tt_cl.requires_grad = True\n","tensor_T_cl = torch.from_numpy(T_cl).float().to(device)\n","tensor_T_cl.requires_grad = True\n","\n","tensor_xx_inter = torch.from_numpy(xx_inter).float().to(device)\n","tensor_xx_inter.requires_grad = True\n","tensor_tt_inter = torch.from_numpy(tt_inter).float().to(device)\n","tensor_tt_inter.requires_grad = True\n","tensor_f_inter = torch.from_numpy(f_inter).float().to(device)\n","tensor_f_inter.requires_grad = True\n","    \n","\n","tensor_xxH = torch.from_numpy(xxH).float().to(device)\n","tensor_ttH = torch.from_numpy(ttH).float().to(device)\n","\n","tensor_xx_initH = torch.from_numpy(xx_initH).float().to(device)\n","tensor_xx_initH.requires_grad = True\n","tensor_tt_initH = torch.from_numpy(tt_initH).float().to(device)\n","tensor_tt_initH.requires_grad = True\n","tensor_T_initH = torch.from_numpy(T_initH).float().to(device)\n","tensor_T_initH.requires_grad = True\n","\n","tensor_xx_clH = torch.from_numpy(xx_clH).float().to(device)\n","tensor_xx_clH.requires_grad = True\n","tensor_tt_clH = torch.from_numpy(tt_clH).float().to(device)\n","tensor_tt_clH.requires_grad = True\n","tensor_T_clH = torch.from_numpy(T_clH).float().to(device)\n","tensor_T_clH.requires_grad = True\n","\n","tensor_xx_interH = torch.from_numpy(xx_interH).float().to(device)\n","tensor_xx_interH.requires_grad = True\n","tensor_tt_interH = torch.from_numpy(tt_interH).float().to(device)\n","tensor_tt_interH.requires_grad = True\n","tensor_f_interH = torch.from_numpy(f_interH).float().to(device)\n","tensor_f_interH.requires_grad = True"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"I6KHCtqxcSKY"},"source":["@torch.jit.script\n","def compute_grads(outputs_interieur: torch.Tensor,x_interieur_tensor: torch.Tensor,t_interieur_tensor: torch.Tensor):\n","    \"\"\"\n","    Compute first and second derivative of the network with respect to their inputs \n","    \"\"\"\n","    #second derivative x \n","    grad_outputs = torch.jit.annotate(List[Optional[torch.Tensor]], [torch.ones_like(outputs_interieur)])\n","    \n","    outputs_interieur_u_x = grad([outputs_interieur],[x_interieur_tensor], grad_outputs = grad_outputs,create_graph=True)[0]\n","    \n","    if outputs_interieur_u_x is not None:\n","        outputs_interieur_u_xx = grad([outputs_interieur_u_x],[x_interieur_tensor], grad_outputs = grad_outputs,create_graph=True)[0]\n","    \n","    else :\n","        outputs_interieur_u_xx = torch.tensor([0])\n","    #second derivative t\n","    outputs_interieur_u_t = grad([outputs_interieur],[t_interieur_tensor], grad_outputs = grad_outputs,create_graph=True)[0]\n","    \n","    if outputs_interieur_u_t is not None:\n","        outputs_interieur_u_tt = grad([outputs_interieur_u_t],[t_interieur_tensor], grad_outputs = grad_outputs,create_graph=True)[0]\n","    else : \n","        outputs_interieur_u_tt = torch.tensor([0])\n","    return outputs_interieur_u_x,outputs_interieur_u_xx,outputs_interieur_u_t,outputs_interieur_u_tt"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"x8OSjC6KtTe4"},"source":["### Network training function"]},{"cell_type":"code","metadata":{"id":"Mytvfjkzr9du"},"source":["def train_one(model,optimizer,scheduler,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","              \n","              tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter,groundtruth,tot,tol,mpinn=False,model_2=None,adu=0):\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","        scheduler : Pytorch scheduler : optimizer associated to the model\n","        tensor_xx_init : Pytorch Tensor : x-coordinates of the initial conditions\n","        tensor_tt_init : Pytorch Tensor : t-coordinates of the initial conditions\n","        tensor_T_init : Pytorch Tensor : value at initial conditions\n","        tensor_xx_cl : Pytorch Tensor : x-coordinates of the boundary conditions\n","        tensor_tt_cl : Pytorch Tensor : x-coordinates of the boundary conditions\n","        tensor_T_cl : Pytorch Tensor : value at boundary conditions\n","        tensor_xx_inter : Pytorch Tensor : x-coordinates of the interior conditions\n","        tensor_tt_inter : Pytorch Tensor : t-coordinates of the interior conditions\n","        tensor_f_inter : Pytorch Tensor : second term value at interior conditions\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","        adu : Pytorch Tensor : additional tensor for correction calculation\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_init = []\n","    local_loss_total = []\n","    local_loss_inter = []\n","\n","    loss_interieure = nn.MSELoss()\n","    loss_bc = nn.MSELoss()\n","    loss_initiale = nn.MSELoss()\n","    \n","    error_train = []\n","    for epoc in range(1, tot+1):\n","        #Train \n","        optimizer.zero_grad() \n","        \n","        #Initial \n","        outputs_init = model(tensor_xx_init,tensor_tt_init)\n","        loss_init = loss_initiale(outputs_init,tensor_T_init)\n","        local_loss_init.append(loss_init.cpu().item())\n","\n","        #Boundary\n","        outputs_cl = model(tensor_xx_cl,tensor_tt_cl)\n","        loss_cl = loss_bc(outputs_cl,tensor_T_cl)\n","        local_loss_cl.append(loss_cl.cpu().item())\n","\n","        #Interior\n","        outputs_interieur = model(tensor_xx_inter,tensor_tt_inter)\n","        outputs_interieur_T_t,outputs_interieur_T_tt,outputs_interieur_T_x,outputs_interieur_T_xx = compute_grads(outputs_interieur,tensor_tt_inter,tensor_xx_inter)\n","        delta = -outputs_interieur_T_tt-outputs_interieur_T_xx\n","        f_pred = delta+alpha*torch.sin(outputs_interieur+adu)\n","        loss_inter = loss_interieure(f_pred,tensor_f_inter)\n","        local_loss_inter.append(loss_inter.cpu().item())\n","\n","        loss_total = loss_inter + loss_cl + loss_init \n","        loss_print=loss_total.cpu().item()\n","        local_loss_total.append(loss_total.cpu().item())\n","\n","        # Backpropagation\n","        loss_total.backward(retain_graph=True)\n","        optimizer.step()\n","        scheduler.step()\n","        \n","        # Test \n","        if mpinn : \n","            prediction = model(tensor_xx_inter,tensor_tt_inter).cpu().detach().numpy() + model_2(tensor_xx_inter,tensor_tt_inter).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_xx_inter,tensor_tt_inter).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_init,local_loss_inter,local_loss_total,error_train"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"z5DtKYsi00RJ"},"source":["### Residual computation fonction"]},{"cell_type":"code","metadata":{"id":"yslsmOINtTe6"},"source":["def compute_res_bc(model,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","              \n","              tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter):\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_xx_inter,tensor_tt_inter)\n","    outputs_interieur_T_t,outputs_interieur_T_tt,outputs_interieur_T_x,outputs_interieur_T_xx = compute_grads(outputs_interieur,tensor_tt_inter,tensor_xx_inter)\n","\n","\n","    f_pred = -outputs_interieur_T_tt-outputs_interieur_T_xx\n","    res = f_pred-tensor_f_inter\n","    bc = (model(tensor_xx_cl,tensor_tt_cl))\n","    init = (model(tensor_xx_init,tensor_tt_init))\n","    return res,bc,init,outputs_interieur"],"execution_count":null,"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":1622563620140,"user_tz":-120,"elapsed":477809,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"f7c4a9d7-e3b9-4875-cc51-a517d12fefe8"},"source":["#Create network for the fine and the coarse resolution \n","modelh = PINN(1,10) \n","modelh = modelh.to(device)\n","modelH = PINN(1,5) \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.Adam(modelh.parameters(), lr=5e-2)\n","optimizerH = optim.Adam(modelH.parameters(), lr=5e-2)\n","schedulerh = StepLR(optimizerh, step_size=500, gamma=0.9)#300,0.05\n","schedulerH = StepLR(optimizerH, step_size=500, gamma=0.9)\n","\n","#first training epocs\n","stampo=[]\n","tol=1e-6\n","nit=50\n","\n","epoc_h,_,_,_,local_loss_total_h,error_h = train_one(modelh,optimizerh,schedulerh,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","                                                  tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter,groundtruth,nit,tol)\n","\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,inith,uh = compute_res_bc(modelh,tensor_xx_initH,tensor_tt_initH,tensor_T_initH,tensor_xx_clH,tensor_tt_clH, \\\n","                                   tensor_T_clH,tensor_xx_interH,tensor_tt_interH,tensor_f_interH)\n","\n","nitf=50\n","nitc=50\n","ncicleV=600\n","for i in range(1,ncicleV+1):\n","    _,_,_,_,local_loss_total_H,error_H = train_one(modelH,optimizerH,schedulerH,tensor_xx_initH,tensor_tt_initH,tensor_T_initH-inith,tensor_xx_clH, \\\n","                                                 tensor_tt_clH,tensor_T_clH-bch,tensor_xx_interH,tensor_tt_interH,-resh,groundtruthH,nit,tol,mpinn=True,model_2=modelh,adu=uh)\n","    resH,bcH,initH,uH = compute_res_bc(modelH,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","                                       tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter)\n","    _,_,_,_,local_loss_total_h,error_h = train_one(modelh,optimizerh,schedulerh,tensor_xx_init,tensor_tt_init,tensor_T_init-initH,tensor_xx_cl,tensor_tt_cl, \\\n","                                                 tensor_T_cl-bcH,tensor_xx_inter,tensor_tt_inter,-resH,groundtruth,nit,tol,mpinn=True,model_2=modelH,adu=uH)\n","    \n","    resh,bch,inith,uh = compute_res_bc(modelh,tensor_xx_initH,tensor_tt_initH,tensor_T_initH,tensor_xx_clH,tensor_tt_clH, \\\n","                                       tensor_T_clH,tensor_xx_interH,tensor_tt_interH,tensor_f_interH)\n","    \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%50 == 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":null,"outputs":[{"output_type":"stream","text":["Loss value after first training 8581.70703125\n","Loss value at Vcycle number 50 : 20.138132095336914\n","Error value at Vcycle number 50 : 0.4485200493268407\n","Loss value at Vcycle number 100 : 9.526224136352539\n","Error value at Vcycle number 100 : 0.38074740386406014\n","Loss value at Vcycle number 150 : 6.611858367919922\n","Error value at Vcycle number 150 : 0.3462482175307159\n","Loss value at Vcycle number 200 : 4.330914497375488\n","Error value at Vcycle number 200 : 0.25802159593100094\n","Loss value at Vcycle number 250 : 3.0876715183258057\n","Error value at Vcycle number 250 : 0.2093909607519663\n","Loss value at Vcycle number 300 : 2.5295324325561523\n","Error value at Vcycle number 300 : 0.19219719746052766\n","Loss value at Vcycle number 350 : 2.177154302597046\n","Error value at Vcycle number 350 : 0.1837116927715114\n","Loss value at Vcycle number 400 : 1.9529774188995361\n","Error value at Vcycle number 400 : 0.1782557189542768\n","Loss value at Vcycle number 450 : 1.7868014574050903\n","Error value at Vcycle number 450 : 0.1751703622226956\n","Loss value at Vcycle number 500 : 1.677253007888794\n","Error value at Vcycle number 500 : 0.17262703824285625\n","Loss value at Vcycle number 550 : 1.6073261499404907\n","Error value at Vcycle number 550 : 0.17120220599304187\n","Loss value at Vcycle number 600 : 1.5691412687301636\n","Error value at Vcycle number 600 : 0.16983033361094105\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":298},"id":"dIoZTMQ5ZCwQ","executionInfo":{"status":"ok","timestamp":1622563620904,"user_tz":-120,"elapsed":778,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"0bbc7060-9db9-4e45-cc13-685234bf1607"},"source":["plt.title('Loss function')\n","plt.semilogy(losses_total,color='red',label = 'MPINN',linestyle='dashed')\n","plt.legend()"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7fd611591a10>"]},"metadata":{"tags":[]},"execution_count":9},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAXcAAAEICAYAAACktLTqAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deZgU1bnH8e8LA8OqIIsLA7JqREVCxn2N1wUJqDEGQROjolyNXPcYo0bR+FxjcnNNiCQRAyFGAyjmRkkgRo0ETDQsCSKLIEEQUBlARREQBs7943TR1d3VPT0zPdPL/D7PM09Vn6quOsUMb1e/59Q55pxDRERKS7N8V0BERHJPwV1EpAQpuIuIlCAFdxGREqTgLiJSghTcRURKkIK7NGlm1trMZpjZVjN7upHPvdTMzmjMc0rTUZbvCogAmNka4Grn3IuNfOqLgQOBTs656oY6iZlNBtY75+4OypxzRzbU+UR05y5N3aHAyoYM7CL5oOAuBc3Mys3sx2b2buznx2ZWHtvW2cz+YGYfmdkHZjbXzJrFtn3bzDaY2SdmtsLM/iPi2PcB9wCXmNk2MxtlZmPN7InQPj3NzJlZWez1bDP7npn9LXbsP5tZ59D+p5jZ32N1WmdmV5jZaOAy4PbYeWbE9l1jZmdlcZ1nmNl6M7vVzKrM7D0zu7Kh/s2lNCi4S6G7CzgBGAgcAxwHBKmNW4H1QBd8auVOwJnZ4cAY4FjnXHvgXGBN8oGdc/cC/w1Mc861c85NzLJOlwJXAl2BlsBtAGZ2KDAL+GmsTgOBRc65CcCTwA9i5xlWy+sEOAjYH+gGjALGm1nHLOsrTZCCuxS6y4D7nXNVzrlNwH3A12PbdgMHA4c653Y75+Y6P1jSHqAc6G9mLZxza5xz/85hnX7lnFvpnNsBPIUPyOCD/ovOuSmx+mxxzi3K8piZrhP8td4fO+5MYBtweG4uR0qRgrsUukOAtaHXa2NlAD8EVgF/NrPVZnYHgHNuFXATMBaoMrOpZnYIufN+aH070C623h2o64dIpusE2JLULhA+r0gKBXcpdO/iGz0DPWJlOOc+cc7d6pzrDZwP3BLk1p1zv3XOnRJ7rwMeyvJ8nwJtQq8PqkVd1wF90myrafjVtNcpUhcK7lJIWphZq9BPGTAFuNvMusQaLu8BngAws6Fm1tfMDNiKT8fsNbPDzezMWIPkTmAHsDfLOiwCTjOzHma2P/CdWtT/SeAsMxtuZmVm1snMgpTNRqB3hvemvU6RulBwl0IyEx+Ig5+xwAPAAmAx8Abwz1gZQD/gRXz++VXgZ865l/H59u8Dm/EplK5kGaSdcy8A02LnWwj8IdvKO+feAYbgG3o/wH9QHBPbPBHfBvCRmf0+4u2ZrlOk1kyTdYiIlB7duYuIlCAFdxGREqTgLiJSghTcRURKUEGMCtm5c2fXs2fPfFdDRKSoLFy4cLNzrkvUtoII7j179mTBggX5roaISFExs7XptiktIyJSgvIa3M1smJlN2Lp1az6rISJScvIa3J1zM5xzo/fff/98VkNEpOQURM5dRCRs9+7drF+/np07d+a7KgWhVatWVFRU0KJFi6zfo+AuIgVn/fr1tG/fnp49e+LHhWu6nHNs2bKF9evX06tXr6zfpwZVESk4O3fupFOnTk0+sAOYGZ06dar1txgFdxEpSArscXX5t1BwFxEpQcUd3J95Bk44AT79NN81EZESY2Z87Wtf2/e6urqaLl26MHToUAAmT55Mly5dGDhwIP379+exxx7bVz5mzBgAxo4dS5s2baiqqtp3nHbt2iWc49Zbb933+n/+538YO3ZsTupf3MF9yxb4xz/go4/yXRMRKTFt27ZlyZIl7NixA4AXXniBbt26JexzySWXsGjRImbPns2dd97Jxo0bU47TuXNnfvSjH0Weo7y8nN/97nds3rw55/Uv7uDeJjbV5fbt+a2HiJSkIUOG8Mc//hGAKVOmMHLkyMj9unbtSp8+fVi7NnU0gKuuuopp06bxwQcfpGwrKytj9OjRPPzww7mtOMUe3Nu29UulZURK2xlnpP787Gd+2/bt0dsnT/bbN29O3ZalESNGMHXqVHbu3MnixYs5/vjjI/dbvXo1q1evpm/fvinb2rVrx1VXXcVPfvKTyPdef/31PPnkk+T6Sf3i7ueuO3cRaUADBgxgzZo1TJkyhSFDhqRsnzZtGq+88grl5eU8+uijHHDAAZHHueGGGxg4cCC33XZbyrb99tuPyy+/nHHjxtG6deuc1b1BgruZtQX+Cox1zmU9wXCtdekCxx0HLVs22ClEpADMnp1+W5s2mbd37px5ew3OP/98brvtNmbPns2WLVsStl1yySU88sgjNR6jQ4cOXHrppYwfPz5y+0033cSgQYO48sor61zPZFmlZcxskplVmdmSpPLBZrbCzFaZ2R2hTd8GnspZLdMZNMg3qFZWNvipRKRpuuqqq7j33ns5+uij63WcW265hUcffZTq6uqUbQcccADDhw9n4sSJ9TpHWLY598nA4HCBmTUHxgPnAf2BkWbW38zOBpYBVckHEREpNhUVFdxwww31Pk7nzp358pe/zGeffRa5/dZbb81prxlzzmW3o1lP4A/OuaNir0/Ep13Ojb3+TmzXdkBbfMDfAXzZObc34nijgdEAPXr0+EJUK3ONNm2Cs8+Gu+6Cr3619u8XkYK0fPlyjjjiiHxXo6BE/ZuY2ULnXGTqoj45927AutDr9cDxzrkxsZNeAWyOCuwAzrkJwASAysrK7D5hkpWVweuvw7vv1untIiKlqsF6yzjnJte0j5kNA4ZFdR/KStBbRl0hRUQS1Kef+wage+h1Rawsa/WerKNlSzADjfksUnKyTRk3BXX5t6hPcJ8P9DOzXmbWEhgBPFeP49WeGTRvDnv2NOppRaRhtWrVii1btijAEx/PvVWrVrV6X1ZpGTObApwBdDaz9cC9zrmJZjYGeB5oDkxyzi2tzcnrnZYBOOss6N277u8XkYJTUVHB+vXr2bRpU76rUhCCmZhqI+veMg2psrLSLViwIN/VEBEpKpl6yxT32DIiIhIpr8HdzIaZ2YR6DZgzYAA88EDuKiUiUgLyGtzr3VsG4J13/KhvIiKyT/GnZZo1g72Rz0mJiDRZxZ+WadZMXSFFRJIUf1qmeXPduYuIJCn+tMyXvgTHHJPvWoiIFJTinokJYNKkfNdARKTgFH/OXUREUhR/zn3QIBgzJneVEhEpAcWfc//4Y/jww3zXQkSkoBR/cK+uhirN6CciElb8Dapr1/ofERHZRw2qIiIlqPgbVEVEJEXx59zbt/dLPaUqIrJP8Qf3q6/2S40vIyKyT/EH9x/8AHbtgrLibxsWEcmV4o+ICuoiIimKv7fMX/4C118PO3fmrmIiIkWu+HvLvP46/Oxn8NlnuauYiEiRK/6ce7PYJahBVURkn+IP7s2b+6W6QoqI7FP8wT24c1dwFxHZp/iDe4sWUF6u4C4iElL8wf2aa3xPmYMOyndNREQKRvEHdxERSVH8wX3uXLj8cti0Kd81EREpGMX/ENPq1fCb38C2bbmrmIhIkSv+h5jKy/1ST6iKiOxT/GmZDh38UvOoiojsU/zBvWNHv1RwFxHZp/iDe6dO/mf37nzXRESkYBT/eLl9+8LmzfmuhYhIQSn+O3cREUlRGsH961+Hn/8837UQESkYpRHc//pXmDcv37UQESkYpRHcO3ZUbxkRkZDSCO4dOsBHH+W7FiIiBaM0gnu7drB9e75rISJSMHLeFdLMjgBuBDoDLznnGr6ls2dPKCv+Xp0iIrmS1Z27mU0ysyozW5JUPtjMVpjZKjO7A8A5t9w5dy0wHDg591WOMH48PPtso5xKRKQYZJuWmQwMDheYWXNgPHAe0B8YaWb9Y9vOB/4IzMxZTUVEJGtZBXfn3Bzgg6Ti44BVzrnVzrldwFTggtj+zznnzgMuy2Vl03r0UTj77EY5lYhIMahPorobsC70ej1wvJmdAVwElJPhzt3MRgOjAXr06FGPagDr18PLL4NzYFa/Y4mIlICct0I652YDs7PYbwIwAaCystLV66Rt2sCePbBrV3x8dxGRJqw+XSE3AN1DrytiZVnLyUxMAK1b+6W6Q4qIAPUL7vOBfmbWy8xaAiOA52pzgJzMxAT+zh0U3EVEYrLtCjkFeBU43MzWm9ko51w1MAZ4HlgOPOWcW1qbk+fszv2QQ+C443zOXUREMFcAAbGystItWLAg39UQESkqZrbQOVcZta00hh8IaDYmEREgz8E9Z2kZgCOPhO9+t/7HEREpAXkN7jlrUAV45x3duYuIxJROWqZ5c6iuznctREQKQukE97Iy/yCTiIiUUM69rEx37iIiMaWTcx8+HI4/Pv32IUPgpJPqfx4RkSJQOjNcjBuXefusWY1TDxGRAlA6OfejjoKLL853LURECkJe79zNbBgwrG/fvvU/2NKl/kdEREoo5y4iIvuUTlrm6qvhsMM0eJiICKUU3MeP990hn38+evvEiTB5cqNWSUQkX0qnt8xPfwrLlsF550XfvV91VePXSUQkT0rnIaaaJuo4/XTo2bP+5xERKQKlM567c9As9ln1yCNw/fWJ24OJswvgekVEcqFpjOceBG+AX/4yf/UQESkApRPcw3LRb15EpIiVVnB/9lm/7NUrv/UQEcmz0gru55/vlz/8ITz4YH7rIiKSR6XTWybwox/55Z13Jpa3bZu7c4iIFLjSG36gd+/o8oqK3J1DRKTAlVZaBuDss+Prs2fH11esaPSqiIjkS+k8oRoIp1+++EU/DPDhh+evPiIieVB6wR3gxBPh1Vf9+vTp+a2LiEgelF5aBuCuu/JdAxGRvCrN4D54cL5rICKSV6UZ3Js3z3cNRETyqjSDu4hIE1d6DzEFFi3K/TFFRIpE6T3EFDjmmNwfU0SkSCgtIyJSghTcAzt3wo4d+a6FiEhOlHZwf/vt7Pft3h3atGm4uoiINKLSDu61mTN18+YGq4aISGMr7eBeG337xudgFREpcqUfzb75zfj6nDnp91u1Cvbubfj6iIg0gtIP7iefHF+fPz9/9RARaUSlH9xHjoyv33pr/uohItKISj+4m+W7BiIija70gzvARRfF1z/4wA9NcMEFsGxZ/uokItKAGiS4m9mFZvaYmU0zs3Ma4hy1cskl8fVPPoFNm+C55+DDD/NXJxGRBpR1cDezSWZWZWZLksoHm9kKM1tlZncAOOd+75y7BrgWuCTqeI3q4IMTX8+a5Zdz5/q0zeTJjV4lEZGGVJs798lAwiwYZtYcGA+cB/QHRppZ/9Aud8e259epp8bX9+yBhx/26y+/7JcTJzZ+nUREGlDWwd05Nwf4IKn4OGCVc261c24XMBW4wLyHgFnOuX9GHc/MRpvZAjNbsGnTprrWP3u33+6Xu3aFK+GXmtxDREpMfXPu3YB1odfrY2X/BZwFXGxm10a90Tk3wTlX6Zyr7NKlSz2rkYUzz/RPoToXLzvsMOjQAUaPjn7P22/HJ9oWESkiDdKg6pwb55z7gnPuWufcL9Lt16CTdSQ791x46y044gh46SVfdvHFvlH10kuj39O7N5x0Ut3PuWoVPPMMfPZZ3Y8hIlIH9Q3uG4DuodcVsbKsNOhkHcm2b4dp02DjRmjRAjp3ho8/hq9/HWbPjn7P5ZfDoYfW/ZyzZvkPkG3b6n4MEZE6KKvn++cD/cysFz6ojwDS3Abn2YoVMGIEnH02rFvnR4HctAmeeCLzg07J2z76CM45B267DYYPz+7c4VSQiEgjqE1XyCnAq8DhZrbezEY556qBMcDzwHLgKefc0locs/HSMkce6ZcHHABvvunX18WaC4I0DSQG4scfhzVr4PTTYflyX1ZV5ceoufvums85YYJfqj+9iDSyrO/cnXMj05TPBGbW5eTOuRnAjMrKymvq8v5aadkSjjrKz7gUeOQRv3z33XjZ3r2pvWfmzPEPP9VWkGvXaJMi0siaxvADgS5dfComEHVHHb5zHzo0vp48mYdSLSJSwPIa3Bs1LQPwuc/BypXx19XVqfuEg3a4i+a//+2XtRmI7Mtf9suOHbN/j4hIDuQ1uDdqbxmA+++Hd96pqVLx9Rkz4utBWiaYraldO79ctcr3xIkSDHvQsmXt6yoiUg9NKy3TuTO0bg0HHZR+n3BwD6di7rrLL7t1g5/8BH71K59L79cv/vRrsrIyf6e/Z0/96y4iUgv17QpZL2Y2DBjWt2/fxjnhzp1w553w/vvp92nRIrp8//1h5kwYN873XzeLN5R27Rr9nrIy/2Gxe3f96i0iUktNKy1TXg5PPZV5n3STZH/1qzBsGDz/vE+3TJ4cv8t/8MHMd+hqfBWRRta00jJm0KtX5n3S3WUfckg8z75xI1x5ZTxoB90rkz84xo3zy8ZqMBYRiWlawR384GGZBH3T585NLO/VC266KfN7L700MU8fpG105y4ijaxpdYUEOOuszNs3bvTL005LLH/wQT/swFVXxcuiukWWl9evfo3pgw/g//4v37UQkQbQtHLuUPOd+9I0oyesXOmfZJ00KV4WNQ58kLOfPx/69PHrBx5Y+3o2hosu8j/vvZfvmohIjuW1t0xeHHts5u3per4APPtszcfftQvatoWrr4bFi31Zuh44+fb2234ZnsBEREpC08u5N2vmUyzptG6dftuTTya+jgqKQVkQ2M0Sx7Opyfbt/gPoiSeyf0/YP/8JO3Zkt+8VV/hl+/Z1O5eIFKymF9whNZ8e1q6dbwA9++zMx7j//ugBwVq1SnztHKxf79fnzYMePTL3ntm+HRYs8GPP19aWLfCFL8QfuKrJwQf7IRbKmt4XOJFS1/QaVAFOOCH9tupqH5BfeCHzMf75z+x7wbzyil/ee68fZvjvf0+/b3Dnv2BB9LYbb0wcojgsaODt2TO7eh17LHzrWxoeQaQENb0GVfCpmaOOit72zjvRQXvgQP+UauD3v49+f1Q/+aB/fCD5+GvX+j7x4YbNqJ44W7f6/S65JPrcmT5sXnstdWTLV17xQydkm8YRkaLRNNMyAPfcE13+7LPR6ZbLLksNqlHBNOq9waiQI0b4Ze/eidvffNPfka9Zk923gXQjUwaDm/32t6nbTjwRTj01sSxoIE438JmIFK2mG9z79Ysu37kzOkAvXOhnZAqL6grZoUNqWXC8IUPg4Ydh7FjYEJpqNkjTLF0az39365ax+pGC4Q/CY9aHvfVW4utVqxLfJyIlo+kG9wED4uOth735ZvTd89Sp8ZmbAlEPLJmljhN/yCF+uWYN3HyzbywNAiv4eVkBPv0U9tvPr3/lK6nHrumuPmjMHTgwdVuLFulHrxSRktN0u0k0a+Z7vCQ/odmuXfreI6++WvNxd+yA++5LLAuO98c/xsuqquLr4aDdunX89W9+A8cfD4cd5u/2g8bWdGmZtm39Mjn9IiJNTtMN7hDdqNqyZfZdAz/9NLVs0aLU+VaD4732WrwsCNA7d8Kjj8bLPvzQT+J96aU+d15e7vcJPjBuvx0GD46uT/ChENWou3t3ar/8q6/2PXgau0FbRBpc0+wKGZYc4DdujJ5+L1nXrtG5+bffTi1PznWHjR8fD7qVlfEHnoJG0WAgs8BDD8EXvxh9rODfcWbEfOXNmqU+oHXIIb5xN6rtINmnn6rhVaSINM2ukGH/+lfi63nzou/Ik1VVRefAu3aFiRMTy4LByMJdDoOAGox107o1dOqU+MHSqpXvhx721a8mTv8XFnS5vPji1G179ybm+cF/sF12Wfox7MPOOMOfW0SKQtNtUA2UlfncdljUHXm2OndOLVuzxjfUzpkTL+vTxzes3nijf/2lL6XeWUcF3enTYdQov75oEdxxR/xDpqYG16lTE1/Pnw/f+152/dwXLIj+RiAiBUnBHeBrX4O//CX+OtsnT6P269IltWy//WDFivjrJ5+E/v39A0lr1/qy6dPj64FTT4Ujj0w9XpCvP+kkn6YJUjlBrj/5m0M6Tz/tl0q3iJQcBfdAOI+dbqCv++9PfB012uO2bXDNNall4SEBLrvMPy2aPAzB8uWJ3Suffx7+/W+/fvzxcMwxfj3oaXPzzX7Zpo3/cAo+bNK1YbRpk/g6+DCpzzcVESlICu5hzzzjl7fdFr09+anW5GAJPpAnDx5WVZUaQJPz3+DvpIOnWQPTp/vlP/4Br7+euC08Jsyzz8brU1mZeuzycviv/0osC/L7Cu4iJUfBPeyii+C662DKlOzf06NH4uubb/b59bATT4yPDBkI93MPvPhi/NtAELiXL09/7vAAYqedFu/nfvzxNdcb/OQjkJgyEpGSoOCebNy47Ifb/fBDP9BY2Guv+V4vYT16wBFH1Hy8Hj3iPWsyTaBxyil+GU7h7Ldf5uEHPvssdZiBIM1zwAE11230aLjzzpr3E5GCoOCerKwMhg+HM8+sed90Da/JaY61a1OfKv3tb+O9XgJXXJEa1JOHOJgyxY9PA4l13Lo1PozB978fXa/gzj6wbp1fJn9ARXngAbjllpr3E5GCoIeY0nnpJZ+uuPtuP1NRMB9qWLrg/tRTia8nTPBzsIYtXw7f/W5i2aBBiR8M++0H116buM/Ikb5BFhL745eXp59FKgjiyfPDBjn6Dz5ILN+7N/UDauhQ36tIRIqCHmLK5LDDfD/wb30r3mulJlFDCf/rX6ljqXfvnjpWTXJ+/eOPUwMvxD8oku/Qoz5spkyJtwsEjbOBoB0guStk585w6KGJZfPmwZ/+lHp8ESlISstk46ab4POfTy2PCqbJ3SUBzjsvdbajgQPhxz9OLFu8OPWYyQ9YpTv/q6/6njrJknvuREm+4//ww9QGYBEpKgru2Wjf3t+5JjeKRvV4gdQhA/bs8cMShG3e7Ls3hk2Zkj61MmBAasNn+Dw7dkR/2GSa8DuQ3P2yRw//rUVEipaCe7bKymDZssQAGvX0KMCkSYmv//zn1Aejgl4xyaKGLwB/Vx+VogmYpU7nB5kHLQu8/37i6x49oKKi5veJSMFScK+LPXt88Es3rvqWLallyTn3qIeYILsRGgMPPRRfP/fceG+YYMIPSN9P/rrr4usffpi4bcOG1PqKSFFRcK+LZs18D5RFi/yY6DUZPDj1waLkB50C2XRLTHeOoIdL+BtFMOpksvAdffKwx506pU7zd+ONvjukiBQFBff6GDAAHnssc7oEajcfajZjyacT3IGHe+GEx7QJCz/d+sYbiducSx2R8uab4fLL6143EWlUCu650LGjD4iffOLHPU82caLPmSeL6jYZzumfeCKcdVb29UjukQPZjfi4YEHi64ULE6cEBBgxIrtvKSJSEBTcc6ldOz8+zK9+lbotaqKLqG6TYa++6o+Xrajp9f72t5rfF87RJ9u710/t99prvmE4nd/9zrdB3HBD5nPt3esn/547t+Z6iUidKbjnWvPmfhgB5/zP3r0weXLtGkrrasKE1LILL6z5fclj4YQtWQI//GHNxwi+IUQ1Joft3Ok/CGbPrvmYIlJnCu4NzQy+8Q0/cNc3v1nz/pnuomsSNaZMVKoGfMonkGmaveTxaNIJjlHTRCdBD6N09RKRnMh5cDez3mY20cym17x3E9K8uZ8M2zk/DMDRR0fvV5/gHiUYZCxZ797x9WAGpyjt22d3niBo1xTcg4HRwjNfiUjOZRXczWySmVWZ2ZKk8sFmtsLMVpnZHQDOudXOuVHRRxLA55yDoQaSJ+DIZriAKEOG+CENki1aFL1/eKKRz30u/XGThwmuSU3BPWgXSG7EbQiPP579lIMiJSbbO/fJwOBwgZk1B8YD5wH9gZFm1j+ntWsKBgyI5+bHjYve54ILaj7OzJlw+OHx1/Pm+bFrjjsuev9wzrtfv/THTTflIPgB0R55xK8Hg5OF+/PPmQP33Rf93nQPgOXSN76hHj7SZGUV3J1zc4DkztzHAatid+q7gKlAFlHIM7PRZrbAzBZsippcoqkx89PgBQ2xy5b5bpA/+AE891zq/h9/nFoW7rv+rW/5vunpJuIIP8SUKUWSKR8/aFB86r7gm8Cpp8a3n346jB2b+J6yMr8cMiT9cUWk3uqTc+8GrAu9Xg90M7NOZvYL4PNm9p10b3bOTXDOVTrnKrt06VKPapSoI46AF17wQXrlShg2LHF71DDJ4RTKnDl+GdW/PlmmnHumfvLHHhtfDybrDpdFCT4sglmgRKRB5LxB1Tm3xTl3rXOuj3PuwUz7FvRkHYWkXz9/9x6kb/72t+g8efIYMVBz10TI/ARtpuB+xhnxNoKo3H7UA13BEAnB/K0i0iDqE9w3AN1DrytiZVkr+Mk6CpEZnHSSHxAsSN/cfnv6/bMJ7gcemH5bpgbSqqp4Tr5799TtkyalDmscpG8y9a0XkXqrT3CfD/Qzs15m1hIYAUQkh6VBHXGEHx3SOZ+Hf/nlxO3Jd/NRE28nz9MaljwOfdiG0Gd5VNfOXbv83K51tXJl9GTf2TrttNRB0USaiGy7Qk4BXgUON7P1ZjbKOVcNjAGeB5YDTznnlmY6TsRxlZbJpfbtfSokaJRduTJ1jJjycpgxI7EseZ7WsA4d0m/r2zce/IO7/3A//VGj4Jxz/IfOjh2+LFi+8EKNl8Phh6cf1TIb06fXbvgGkRJSls1OzrmRacpnAjPrenLn3AxgRmVl5TV1PYZk0K+f/3HOTw5y0EG+fOHC1H137ozuY//ZZ+mP/8Yb8dmogjlmw714gnFt9t/fp23eeSf+zWFJwiMT6UX1CsrW9Om+kXnMmLofQ6RIZRXcpQQceGD8jv6zz3w6Z8SI+PaVK/0sUE88ES9bvTo1reJcvI96ELydg7VrM59/3br4vhBvWAV46ik/Xvw770CLFonvS9dPPxvBcA8K7tIE5XVsGaVl8sDM36Ffckk82G/d6h+mmjEDvv3t+L4vvph65xyMNx9Oq+zZE38QKlOOHuIDqIXHwH/pJT/VX/fuiQ9iHXpo6ry14Pvlm6V/+lZE8hvc1VumQAR58q99zTdCBj73OT8eTlhw1x4eKbK6Ot7HPt2k4cnvD+vVyy83bvTfIAL33OOfMk327LN++de/Zj6XSBOmUSElrm1bHzD37vVdLfffH55+Osey9FUAAA1tSURBVHGfYDam8LAEu3bVPKZMJukm8f7Od2DatPjrxx7z6Zvg7r8xhlEWKVJKy0gqM3/XPmBA6mQff/qTX4Yn23j+eZ+vTxY1cUfUt7RgeIWjjoJTTomXV1X5RtHAyy/7MXTOPdcf56STsrsekSZIaRlJL3hgKngy9o47fKNn0DMmMHx44lOuF1/sl+nuyJMFY8aPGwc//3nitvBDWMHcrueeCx995Me2EZFISstIdszgwQf9VIJRg4mF7/CfecYvZ81K3e8Xv0gtu+UWv7z5ZnjggfR1mDrV5+TfeANGjoQ338y+/iJNjIK71F6vXv4uOvz0a3hESojOwX/8cXS3xODD4vXXfY69pvz9H/7gA/38+bWrt0gTopy71F2HDvGUzfz5MGVKfFvUcATbtkU3ggbDBgeCp1jTCdJCNfWtF2nClHOX+jODykr/UNT27fCrX0U3sM6cmd047uEHnKIEwyckf1sIyzSapUgToLSM5Fbr1nDFFX6mpzVrEreNGZPdxNitW2e3Pd1EIrNnZz+x99y58Oij2e0rUkQU3KXhHHpo/CnYGTP8eDJf+Up8ezCfarJMU/tBPB2zbl309mCikmxccEHmgdNEipSCuzSOoUP9CI8jR/qgfO+9qePIBP77v7M7ZjCF4O7dfjiFZcv867JaDJkUNcGJSAlQg6o0voqK+NyqzvlJPZIFg35FCRprg0m5V6/2g4/99Kf+9dChfv5WkSZMDaqSX2Zw5ZU+yG/bBr/9Ldx0E/z+9/F9qqvhe9+Lv37jDb8MGl6DrpNBH/oBAzI3ttbFunWJg501pp0783duKVpKy0jhaNvWp226dPGzPK1d6/P0zkU3ej7zjB8L5+tfTyw/9dTapWYgtYfO2LGJg5wdfTTcd1/tjpkrp5+uaQml1jSeuxQms3jaBfyd88qVqRODJ0/CHTXq5Lx56ceFv+wy39gbvK+6OrotYOtWPzyCc76b5z33RB/vD3+Ajh3h5JOjt9fFvHm5O5Y0GebqM5pfjlRWVroFCxbkuxpSbDZv9oFv0qT4kAdRysp8o+u77/og3adPvEtm8BBW8HDV9u2J3SiD/x/JHxrp/t8E++Xy/9UVV/gHxDLNiiVNkpktdM5VRm1TWkaKV+fO/qGo6dPjXS7XrYsPUxxMKxiMYDl5MvTvD23a+MlFhg71feXLyvwY8c75oY7Dapqge86cxJRO//7xgdOy8fDDvo0hkzZtEuemFcmCestIaamo8MHVOXjvPb884QS/bfhwePxxP7rlwIF+hMvAhRf6kS2TZ3d67rn0d+GzZvl8+Nix8Sdily1LHKa4JvPmRQ+wFrZ1q7psSq2pt4w0HX37+sbXBx7wd/eLF/sZpCZMgGHD/Pbk4REOOgg++ST1WIsWQZBK/N73Up+I/c1v4Mgj472A+vSBX/4yvv3pp/0+Tz+dOPtUlDZt/By4IrWgnLtIOhs2+Lv5Tz5JTYvcf39qo2p48vDA1q0+n9+unT9G8C012xw+wODBfkKUAvi/KoUlU85dvWVE0gkmIGnfPjGwVlX5XH1lJYweDevXpz9G+Fvpxx/7lFBFRfr9N2zw3T+nT/fTCoIP7OBHy6xp3B2RGN25i+SScz5dU1XlG2yvucY3yoYfyior810uw0aN8sMmL14cL1uwAL7whfhd/ocf+mGW6+v1130aqW/f+h9L8kp37iKNxQyOPdavR9047dzpc/CrVsGJJ/qyRx/1d+ebNyfuO3OmD+7HHusDf7du/ttC166+LaBvXz9hOMCKFb7nzrPP+id1Kyr8N4VZs/y4O2EDB6avn5QM3bmLFJpPPvGpmaOO8imhlSvh8MPhrLNg1y7YuNH/VFTEh2I4+WT4+9/jx/j008RG3quvhoce8sMhByNzbt7sB1+LevDr/ff9g19//nPqg2PJrrvOf6AUQCxpajLduSu4ixSr3bvjT9POnQvjx/tpCg891I+l/8AD8N3vxvePmiylZUvfG6dlS/jf//VP7N5zj/82UVXl00ojR0KrVv7J2+BZgnPOiR+jIR7ckqwouIs0dc75BtkVK3wD8OrV/uGr99/35bt2+W6iJ5/sPxyCZwB++lP/bEDyfLVVVX4MoLPOig/SduGFfsiI/ff33xr+8z99G8GSJbB0qW+E3rLFf1i0axc95aLUSsEGdzMbBgzr27fvNW+99Vbe6iEiSaqr/R158+bw4ov+W8JHH/k00IMP+g8GMz80wq9/7d/TtatvU/jkk/gdfkWFfw4gudvotdfCz3/u9z/6aP/toU0b/6HQoYP/UDn4YN/APGdOfJ7dFSvgsMN8fZYt898oXnvNT/FYXh4//rZt/id4SrlEFWxwD+jOXaSE7N0b77bZrJkfrnjjRt/H/9prfernuOP8073bt/v2gO3bfTvB9u3+p3Nn3zh8991+iIbAfff5D4oNG1K7lA4aBAsX+vUgVXT88b4erVr5Hkvl5TB1Krzyii9r3dr/tGwJt93m3zNnjh+RtEULX96ihf/QOfNMv/2tt/wHR8uW8e2tW8cfNNu1y1938+bR7Rk5pOAuIsUpCPrbtsHbb/uG5W7dfPmf/uTv/EeNguuv908BX3edf9+wYX6EznPO8R80O3b4O/zmzeHb3/ZPC+/c6cud88F72zb/3ssu8/MKhHXt6j+gAM4/Pz5Je6BPH98DCvyHwMsv+8AefAB8/vN+eOrg/UuX+rpcdBF8//t1/udRcBcRieKcv9Ouro73Ltq0yXcj3bXLp3927fLllbEYOn++/+YQbNu1y6eUgi6nTz7p2zTC7z/oILj9dr/93nv99upqP/dAplnHaqDgLiJSgjTkr4hIE6PgLiJSghTcRURKkIK7iEgJUnAXESlBCu4iIiVIwV1EpAQpuIuIlKCCeIjJzDYBa+v49s7A5hr3Kg66lsJTKtcBpXMtpXIdUP9rOdQ51yVqQ0EE9/owswXpntAqNrqWwlMq1wGlcy2lch3QsNeitIyISAlScBcRKUGlENwn5LsCOaRrKTylch1QOtdSKtcBDXgtRZ9zFxGRVKVw5y4iIkkU3EVESlBRB3czG2xmK8xslZndke/6RDGzNWb2hpktMrMFsbIDzOwFM3srtuwYKzczGxe7nsVmNih0nG/E9n/LzL7RSHWfZGZVZrYkVJazupvZF2L/Nqti722wCSfTXMtYM9sQ+90sMrMhoW3fidVrhZmdGyqP/Jszs15m9o9Y+TQza9lA19HdzF42s2VmttTMboyVF9XvJcN1FOPvpJWZzTOz12PXcl+m85tZeez1qtj2nnW9xoycc0X5AzQH/g30BloCrwP9812viHquATonlf0AuCO2fgfwUGx9CDALMOAE4B+x8gOA1bFlx9h6x0ao+2nAIGBJQ9QdmBfb12LvPa+Rr2UscFvEvv1jf0/lQK/Y31nzTH9zwFPAiNj6L4DrGug6DgYGxdbbAytj9S2q30uG6yjG34kB7WLrLYB/xP79Is8PfBP4RWx9BDCtrteY6aeY79yPA1Y551Y753YBU4EL8lynbF0A/Dq2/mvgwlD54857DehgZgcD5wIvOOc+cM59CLwADG7oSjrn5gAfNETdY9v2c8695vxf9uOhYzXWtaRzATDVOfeZc+5tYBX+7y3yby52Z3smMD32/vC/S045595zzv0ztv4JsBzoRpH9XjJcRzqF/DtxzrnY7Nq0iP24DOcP/66mA/8Rq2+trrGmehVzcO8GrAu9Xk/mP458ccCfzWyhmY2OlR3onHsvtv4+cGBsPd01FdK15qru3WLryeWNbUwsXTEpSGVQ+2vpBHzknKtOKm9Qsa/zn8ffKRbt7yXpOqAIfydm1tzMFgFV+A/Kf2c4/746x7ZvjdU3p///izm4F4tTnHODgPOA683stPDG2N1RUfZHLea6x/wc6AMMBN4DfpTf6mTPzNoBzwA3Oec+Dm8rpt9LxHUU5e/EObfHOTcQqMDfaX8uz1Uq6uC+Aegeel0RKysozrkNsWUV8H/4X/zG2NdfYsuq2O7prqmQrjVXdd8QW08ubzTOuY2x/5R7gcfwvxuo/bVswac7ypLKG4SZtcAHxCedc7+LFRfd7yXqOor1dxJwzn0EvAycmOH8++oc275/rL65/f/fEA0MjfEDlOEbgXoRb2Q4Mt/1SqpjW6B9aP3v+Fz5D0ls/PpBbP1LJDZ+zYuVHwC8jW/46hhbP6CRrqEniY2QOas7qQ13Qxr5Wg4Ord+Mz3cCHEliw9ZqfKNW2r854GkSG8++2UDXYPg8+I+Tyovq95LhOorxd9IF6BBbbw3MBYamOz9wPYkNqk/V9Roz1qsh/zM19A++J8BKfH7rrnzXJ6J+vWO/iNeBpUEd8fm1l4C3gBdD/6kMGB+7njeAytCxrsI3sKwCrmyk+k/BfzXejc/zjcpl3YFKYEnsPY8Qe2K6Ea/lN7G6LgaeSwosd8XqtYJQb5F0f3Ox3/W82DU+DZQ30HWcgk+5LAYWxX6GFNvvJcN1FOPvZADwr1idlwD3ZDo/0Cr2elVse++6XmOmHw0/ICJSgoo55y4iImkouIuIlCAFdxGREqTgLiJSghTcRURKkIK7iEgJUnAXESlB/w9HwLc8ToJTTwAAAABJRU5ErkJggg==\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"markdown","metadata":{"id":"Vbd-6oywtTe8"},"source":["### Train classic PINN"]},{"cell_type":"code","metadata":{"id":"5zT_Sl3AtTe8"},"source":["#Create a network for classical PINN training\n","mynet_one = PINN(1,10) \n","mynet_one = mynet_one.to(device)\n","optimizer_one=optim.Adam(mynet_one.parameters(), lr=5e-2)\n","scheduler = StepLR(optimizer_one, step_size=500, gamma=0.9)\n","\n","mynet_one2 = PINN(1,15) \n","mynet_one2 = mynet_one2.to(device)\n","optimizer_one2=optim.Adam(mynet_one2.parameters(), lr=5e-2)\n","scheduler2 = StepLR(optimizer_one2, step_size=500, gamma=0.9)"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"LOTlP9r2q_tm","scrolled":false,"executionInfo":{"status":"ok","timestamp":1622563795931,"user_tz":-120,"elapsed":175031,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"92f8e50b-04b1-4693-ce99-ccc57605bb26"},"source":["\n","epoc,_,_,_,pinn_loss_total,error_train = train_one(mynet_one,optimizer_one,scheduler,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","                                                  tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter,groundtruth,30000,tol)\n"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Total loss = 534.272888 error = 3.871217 in epoch : 1000\n","Total loss = 264.175201 error = 3.732765 in epoch : 2000\n","Total loss = 170.124268 error = 3.723510 in epoch : 3000\n","Total loss = 146.126556 error = 3.677189 in epoch : 4000\n","Total loss = 133.573563 error = 3.663679 in epoch : 5000\n","Total loss = 147.329361 error = 3.608705 in epoch : 6000\n","Total loss = 115.653885 error = 3.475900 in epoch : 7000\n","Total loss = 109.814362 error = 3.395796 in epoch : 8000\n","Total loss = 106.222816 error = 3.338623 in epoch : 9000\n","Total loss = 109.440346 error = 3.266931 in epoch : 10000\n","Total loss = 101.342773 error = 3.258727 in epoch : 11000\n","Total loss = 99.626396 error = 3.237607 in epoch : 12000\n","Total loss = 97.917618 error = 3.206370 in epoch : 13000\n","Total loss = 96.421371 error = 3.187701 in epoch : 14000\n","Total loss = 95.870010 error = 3.159844 in epoch : 15000\n","Total loss = 93.813484 error = 3.155493 in epoch : 16000\n","Total loss = 92.737236 error = 3.145335 in epoch : 17000\n","Total loss = 91.672256 error = 3.131605 in epoch : 18000\n","Total loss = 90.718102 error = 3.124157 in epoch : 19000\n","Total loss = 89.766960 error = 3.113768 in epoch : 20000\n","Total loss = 88.881386 error = 3.105857 in epoch : 21000\n","Total loss = 88.041451 error = 3.098696 in epoch : 22000\n","Total loss = 87.239410 error = 3.092647 in epoch : 23000\n","Total loss = 86.487160 error = 3.086934 in epoch : 24000\n","Total loss = 85.784424 error = 3.082020 in epoch : 25000\n","Total loss = 85.118866 error = 3.078534 in epoch : 26000\n","Total loss = 84.485977 error = 3.075164 in epoch : 27000\n","Total loss = 83.894196 error = 3.072292 in epoch : 28000\n","Total loss = 83.327209 error = 3.068446 in epoch : 29000\n","Total loss = 82.813141 error = 3.064127 in epoch : 30000\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"_SR6h7LCwzvb","executionInfo":{"status":"ok","timestamp":1622563970822,"user_tz":-120,"elapsed":174909,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"dfbbb15d-ace2-4c6a-f47c-55364ef872c0"},"source":["epoc2,_,_,_,pinn_loss_total_2,error_train_2 = train_one(mynet_one2,optimizer_one2,scheduler2,tensor_xx_init,tensor_tt_init,tensor_T_init,tensor_xx_cl,tensor_tt_cl, \\\n","                                                  tensor_T_cl,tensor_xx_inter,tensor_tt_inter,tensor_f_inter,groundtruth,30000,tol)"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Total loss = 299.568176 error = 3.924239 in epoch : 1000\n","Total loss = 217.764893 error = 3.477959 in epoch : 2000\n","Total loss = 186.071930 error = 3.324936 in epoch : 3000\n","Total loss = 156.243073 error = 3.133339 in epoch : 4000\n","Total loss = 99.871490 error = 2.201640 in epoch : 5000\n","Total loss = 100.315727 error = 1.999129 in epoch : 6000\n","Total loss = 82.704742 error = 1.921749 in epoch : 7000\n","Total loss = 68.655045 error = 1.603598 in epoch : 8000\n","Total loss = 24.917154 error = 0.747127 in epoch : 9000\n","Total loss = 17.932831 error = 0.574218 in epoch : 10000\n","Total loss = 6.236518 error = 0.480158 in epoch : 11000\n","Total loss = 4.554635 error = 0.404554 in epoch : 12000\n","Total loss = 3.659131 error = 0.351042 in epoch : 13000\n","Total loss = 3.208786 error = 0.315999 in epoch : 14000\n","Total loss = 3.155673 error = 0.293670 in epoch : 15000\n","Total loss = 2.502282 error = 0.265589 in epoch : 16000\n","Total loss = 2.782394 error = 0.247061 in epoch : 17000\n","Total loss = 2.081315 error = 0.233876 in epoch : 18000\n","Total loss = 1.998950 error = 0.220183 in epoch : 19000\n","Total loss = 1.792910 error = 0.211146 in epoch : 20000\n","Total loss = 1.657425 error = 0.200410 in epoch : 21000\n","Total loss = 1.544608 error = 0.191047 in epoch : 22000\n","Total loss = 1.444470 error = 0.182772 in epoch : 23000\n","Total loss = 1.358746 error = 0.175084 in epoch : 24000\n","Total loss = 1.281240 error = 0.168140 in epoch : 25000\n","Total loss = 1.216208 error = 0.161692 in epoch : 26000\n","Total loss = 1.155202 error = 0.155751 in epoch : 27000\n","Total loss = 1.102866 error = 0.150236 in epoch : 28000\n","Total loss = 1.056462 error = 0.145213 in epoch : 29000\n","Total loss = 1.014196 error = 0.140515 in epoch : 30000\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"jDg0LjO2tTe9"},"source":["### Plot RMSE and Loss "]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":298},"id":"OTsx1khJ-BPw","executionInfo":{"status":"ok","timestamp":1622563971667,"user_tz":-120,"elapsed":865,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"51de29cd-8a05-4651-e009-d9f3d4a21ae6"},"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 10')\n","plt.semilogy(pinn_loss_total_2,color='green', label = 'PINN 15')\n","plt.legend()"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7fd610747f10>"]},"metadata":{"tags":[]},"execution_count":13},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"jy_CDp9yo8c_","executionInfo":{"status":"ok","timestamp":1622563972155,"user_tz":-120,"elapsed":494,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"39e4d3c1-e237-46d1-9b12-362158d913b1"},"source":["plt.title('RMSE')\n","plt.semilogy(error,label = 'MPINN',linestyle='dashed',color='red')\n","plt.semilogy(error_train,color = 'black',label='PINN 10')\n","plt.semilogy(error_train_2,color = 'green',label='PINN 15')\n","plt.legend()"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7fd610755090>"]},"metadata":{"tags":[]},"execution_count":14},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAXcAAAEICAYAAACktLTqAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3dd3hUxfrA8e+kERJKKKGDSA1NI0QBKXpVFFCwF7CAKKjARRQ70lQUC4pcEIGrgOhFLIA/rBcLCleKIKH3gBJKgFAChJA2vz/O9t0ku8luNmfzfp4nz56d0+aQ8O7ZOTPvKK01QgghQktYsCsghBDC/yS4CyFECJLgLoQQIUiCuxBChCAJ7kIIEYIkuAshRAiS4C6EECFIgrsIeUqp/Uqp80qps0qpI0qpuUqpSpZ1c5VSWil1s8s+71jKB1reRymlJiulUi3H2a+UmlLAOaw/00r1QoVwIMFdlBd9tNaVgETgMuB5h3W7gAesb5RSEcBdwF6HbZ4HkoArgMrA1cCfns7h8DPc71chhJcigl0BIUqT1vqIUuoHjCBvtRS4XylVTWt9EugJbMII4laXA4u11ocs7/dbfoQok+TOXZQrSqkGQC9gj0NxFvAVcI/l/QPARy67rgaeVEoNVUq1U0qpgFdWiBKQ4C7KiyVKqTPAAeAoMM5l/UfAA0qpOOAqYInL+teA14F7gXXAQaXUAA/nOOXwM9jvVyGElyS4i/LiFq21ta08AajpuFJrvRKIB0YDX2utz7usz9NaT9dadwHigInAh0qpVi7niHP4mR3A6xGiUBLcRbmitf4VmAu85WH1x8Ao3JtkXI9xXms9HTgJtPZ3HYXwB3mgKsqjKcB+pdSlLuVTgRXAb647KKVGAsnAGiAHo3mmMrAhsFUVongkuItyR2t9TCn1ETAWOONQfgL4qYDdMoHJQDNAY3SfvF1rneKwzVKlVJ7D+2Va61v9WnkhvKRksg4hhAg90uYuhBAhSIK7EEKEIAnuQggRgiS4CyFECCoTvWVq1qypGzduHOxqCCGEqaxfv/641jre0zq/B3elVBOMUX5VtdZ3eLNP48aNWbdunb+rIoQQIU0p9VdB67xqllFKfaiUOqqU2uJS3lMptVMptUcp9RyA1jpFa/1QyaoshBCiJLxtc5+LkQbVRikVDkzHyLDXGuinlJKh2EIIUQZ4Fdy11r8BJ1yKrwD2WO7Us4FPgZvddi6AUmqIUmqdUmrdsWPHvK6wEEKIopWkzb0+RvpUq1Sgo1KqBkbGvMuUUs9rrV/ztLPWehYwCyApKUmGyQpRzuTk5JCamkpWVlawq1LmRUdH06BBAyIjI73ex+8PVLXW6cCj/j6uECK0pKamUrlyZRo3bozMfVIwrTXp6emkpqZy8cUXe71fSfq5HwQaOrxvYCkTQogiZWVlUaNGDQnsRVBKUaNGDZ+/4ZQkuP8BNFdKXayUisKYouz/SnA8IUQ5I4HdO8X5d/K2K+QCYBXQUimVqpR6SGudCwwHfgC2A59prbf6cnKlVB+l1KzTp0/7Wm+b/+79L3tO7Cl6QyGEKEe87S3TT2tdV2sdqbVuoLX+wFL+rda6hda6qdZ6oq8n11ov1VoPqVq1qq+72tzw8Q30/7J/sfcXQpRfSinuu+8+2/vc3Fzi4+O56aabAJg7dy7x8fEkJibSunVrZs+ebSsfPnw4AOPHjycmJoajR4/ajlOpUiWnc4waNcr2/q233mL8+PGBvCwgRHLL/HHoj2BXQQhhQrGxsWzZsoXz540pc5ctW0b9+vWdtrn77rtJTk5m+fLlvPDCC6Slpbkdp2bNmkyePNnjOSpUqMCiRYs4fvy4/y+gEKYO7vk6P9hVEEKYXO/evfnmm28AWLBgAf369fO4Xa1atWjatCl//eU+4n/QoEEsXLiQEydchwNBREQEQ4YM4Z133vFvxYtg6uCelSv9Y4UIGVdf7f7z3nvGusxMz+vnzjXWHz/uvs5L99xzD59++ilZWVls2rSJjh07etwuJSWFlJQUmjVr5rauUqVKDBo0iHfffdfjvsOGDeOTTz6hJM8XfVUmskIW1/mc88GughDC5C655BL279/PggUL6N27t9v6hQsXsnLlSipUqMDMmTOpXr26x+OMGDGCxMREnnrqKbd1VapU4YEHHmDq1KlUrFjR79fgSVCDu1KqD9DH0yehN+TOXYgQsnx5wetiYgpfX7Nm4euL0LdvX5566imWL19Oenq607q7776badOmFXmMuLg4+vfvz/Tp0z2uHzlyJO3bt+fBBx8sdj19EdRmmZL2lsnNz/VzjYQQ5dGgQYMYN24c7dq1K9FxnnzySWbOnElurntsql69OnfddRcffPBBic7hLVO3uZ/PlWYZIUTJNWjQgBEjRpT4ODVr1uTWW2/lwoULHtePGjWq1HrNKK2Dn7MrKSlJF2eyjlsW3MxXu4xBsXpc8K9DCOG97du306pVq2BXwzQ8/XsppdZrrZM8bW/qO/fVB9cEuwpCCFEmmTq4ky/93IUQwpOgBveS5pbRZ8/4uUZCCBEaTN1b5pyHJ9JCCCFM3iyTgzxEFUIIT0wd3JFU0EII4ZGpg3tsln0Yb15eXhBrIoQwo/DwcBITE2nbti133nknmZmZgD1l7/79+1FK8a9//cu2z/Dhw5lryWkzcOBA6tevb+vXfvz4cRo3buzxXIMGDaJWrVq0bdvWqfzEiRP06NGD5s2b06NHD06ePOmXazN1cG96tJGxkEupJuQRQoSGihUrkpyczJYtW4iKiuL9999326ZWrVq8++67ZGdnezxGeHg4H374YZHnGjhwIN9//71b+aRJk7j22mvZvXs31157LZMmTfL9QjwwdXAPy7E8UA2Dq2vUAJmySwhRTN26dWPPHvdZ3eLj47n22muZN2+ex/1GjhzJO++84zHlgKPu3bt7TDr21VdfMWDAAAAGDBjAkiVLilF7d6bOCpmfm2MshMHm4FZFCFECI0eOJDk52a/HTExMZMqUKV5tm5uby3fffUfPnj09rn/22Wfp1asXgwYNclvXqFEjunbtyvz58+nTp4/P9UxLS6Nu3boA1KlTx+NkIMVh6n7ueZ4GMT3/fAlrJYQoL86fP09iYiJJSUk0atSIhx56yON2TZo0oWPHjvznP//xuP7555/nzTffJL+EAyuVUn6bNDyod+5a66XA0qSkpMHF2T8v30NXyEmT4LXXSlgzIURp8vYO29+sbe7eeOGFF7jjjju46qqr3NY1b96cxMREPvvsM5/rULt2bQ4fPkzdunU5fPgwtWrV8vkYnpi6zT2voGn2fv+9dCsihAh5CQkJtG7dmqVLl3pcP3r0aN566y2fj9u3b19be/68efO4+eabS1RPK1MHdx1RwBePLl1KtyJCiHJh9OjRpKamelzXpk0b2rdvX+C+/fr1o3PnzuzcuZMGDRrY8ro/99xzLFu2jObNm/Pjjz/y3HPP+aWupk752+reVuxoscN4Mx70X3/BRRcZ78+cAUtfVSFE2SMpf31TrlL+5rs2yzRqZF9+883SrYwQQpQhpg7ul9aoaX/TCFanrgZrP9W1a4NTKSGEKANMHdxjI8LtbwZB5w86Q9Omxvvvv4cCRpQJIUSoM3U/9yKTQi5YULzjCiGEyZk6n3t+QdH9mmsAyBw4kIyMjOJWTwghTMvUzTIF+vFHAGKBqlWr+m04rxBCmIW5g3tBXR1dhu/WqVOnFCojhDCbspDyd/z48dSvX5/ExEQSExP59ttv/XJtpg7uula8e5nWnD59msalXx0hhMmUhZS/AE888QTJyckkJyfTu3dv3y6iAKYO7p5cetWlxMXF8ZdLuUzmIYQoTLBS/gaKqVP+sm8fxDkXbY7cDOGASyzfvn2729chIUTZMPL7kSQf8XPK3zqJTOlZ9lP+AkybNo2PPvqIpKQkJk+eTLVq1Yp1HEemvnPXntJrdgfGAOHwtUPx0aNHS6lWQgizKAspfx977DH27t1LcnIydevWZdSoUT4fwxNz37kXlhfnMWj/XW1e2pvGWGDr1q1cY+kiKYQoW7y9w/a3spLy12rw4MHcdNNNPh/DE1PfuReqJtS7P42x44GL8NsTaCFE+RSolL+HDx+2LS9evNhvzcemDu5e57N8EL5P9PyU2lvbt29ny5YtXm2rtSYnJ6dE5xNClD2BSPn7zDPP0K5dOy655BJ++eUX3nnnHb/UNagpf5VSfYA+zZo1G7x7926f979v9A18EvVfn/b5tv+39GreC4Bz585Rr149MjIyaNGiBZMnT6Z+/fo0atSIadOmcccdd7Bjxw5uv/1229RXOTk55ObmEh0dzalTp+jSpQvJyclERkbazvHmm2/yzDPPkJ6e7vR0/LPPPiMyMpJbb73V52sVItRIyl/f+Jry19T53O+dci//Oe35AUfXs11ZWWmlx3Wft/2cO++4k6ioKI99V5VSOP67XLhwgQoVKjhto7W2BfzLLruMGTNm0KFDByIiImzl7733HnFxcfTr1892XOu+rpYuXUqPHj2Ijo4u6rKFCAkS3H1TrvK5F+aJK59gTPcxjFvuvu7OLXdCGAUOSnANvq6BHYw+q1YbNmygU6dOTnfvAEOHDqV///7s3LmzwHpOmDCBX375hb59+9ra2jIzMxk6dCjFTqgmhCj3zB3cU1I8ly+Bq7pfxUv/eInxcbdwZDzwqcs2Y4FLin/qFStWeCz3NHN5QkICffv2ddpm2LBhKKUYP368rRfP3r17OXToEK+//jozZszgmWeeAYzJg5VSnD17lg0bNhS/0kKUMWWh5cAMivPvZOrgrj1MkH1+9Hn0Bk2NGjWMgv37qQ2wy8MBbrP8tAcqF3yed999161s8eLFHrft2LGjx/K///7b6f3ChQs9ble/fn1eeuklAGbNmoVSiieeeAKAypUr0759e5RSbN68GaUUSilefPFFwPgDuOaaawr9piBEWREdHU16eroE+CJorUlPT/e5ydbUbe79/9mRBTWdZ1zS41yuZ98+aNKECkA2QBvgzsKP+0TTJ3hnzDs0qNiA1JRU/tz3J+3rGU/Bv/jiC2bMmMGPP/5IRESEU1qDMWPG8NJLL7ndvR88eJB69erZyvPy8ggLCyM7O9utyef999/n0Ucf9fafwEm7du3YvHmzU5nWmk8//ZRly5YxefJk4uKMIb2eniMIUZpycnJITU0lKysr2FUp86Kjo2nQoIFb029hbe6mHsTk1cfSxRcDcBCIB9gKbAPGFbzLO3vfgYGQitHlqf2s9nAV0BQmnZjEfa/cR05eDiv2ruDKe65k+5ztJCQkuB1nzpw51K1bl3r16jmVh4UZX5iioqLQWpOSkkLTpk25++67eeSRR4iOjmbgwIFMnDiRF154gW7durFy5Up69uxpSzy0cOFC7r77bqfjugZ2MLLbnTt3DoAPP/yQG2+8kUaNGjFjxgwAIiIiGDNmDGPHjmXatGnk5eUxcOBAHHPs5+fn2+oshL9ERkZyseX/p/A/U9+59xvekU/ji7hzB3sKYK3Jz8/n3LlzxFaKJTMnk47/7si2Y9uKU20n/dv155PbPuHI2SOMfXEss9+dTWpqKvXr17dt8+uvv6KUcnoYa3Xy5Eni4uJsd/f79u0r8g8/KyuLU6dOsWrVKm699VYOHTrkdD6AYcOGMX369GJdU6tWrdi+fbvtfUpKCnXr1iUpKYmJEyeyYcMGxo8fD8CJEyeoXr06Wmt27NghvSCEKAUh2xWy3+jr+TRqmVNZUcG9MCv+WkFmTiZbj21l1H9Llt8hKiyKbcO20bR60xIdxx/27dvHtGnTSEtLY/r06cydO5eRI0c6bXPllVfy+++/+/W88+bNY8CAAQCsWrWKihUrMn78eNLT03n22WepWrUqXbt2Zf/+/Rw9epR27dqRn59PbGysX+shRKgK2eB+z9v3sPCM84PJQoN7RgZULuTJqQfZednsOL6DhJoJzFw3kxHfj/Bp/7a12rLx0Y2EqbLVrLFjxw5atGjh1NyyaNEifv75Zx555BGGDRvGokWLaNKkCWfOnAGMfvsrV64sMHmSP/Xo0YNly5w/uMeOHWt72AxQt25dpk+fzm233UZcXBynTp3igw8+IDExkc6dO7Ny5UoyMjK49NJLqVKlCmvXrqVz587s2rWLhIQElFLk5+fbHkwLYTahG9zfuouF5z53Kis0uN94I3z9tfv6YlITvAsIn93xGXe2KeIpromcOXOGmJgYsrKyiI2NRWvN119/TXR0NDExMXTt2pWff/6Zhg0bMnnyZN5//32WLFlCTk4Od97p/O9w//33M3/+/KBcR4MGDWxDyVu0aEGNGjVYtWqV23b9+/d3+0AbPXo0ixcvZtu2bbzxxhu2D4pnn33Wtk18fDyzZs1CW5oD09LSGDlyJMuXLyc6Opo5c+bQqFEjEhISaNOmDZGRkbbnL+Hh4cTExHDhwgVycnKcHsgLYRW6wX3Y5Sys5bxfocEdimya8UV6ZjqpGanUrlSbjAsZ1KlUh6qTPE/2vW3oNlrFSzt0YS5cuEB+fj4VK1YEYP369bZMe7fddhsRERHMmjWLzp0788knn3DjjTdSpUoVOnToQMOGDTlw4ADPPvssHTp04K677rI1NbVu3Zpbb72ViRMnOp3vwQcfZM6cOQD06tWLnJwcfrTMv+uoadOm7N2716ksPDy81CeAiY6OtqW9AIiNjbV987J+u7rooouIiIggPDyc8PBwlFKEhYW5vXoqszbL3X777URERNiO4/jqWpadnc2yZcu47rrriIqKsn0Lys7O5siRIxw4cIDrrruO6Oho28jvQ4cOcfDgQa6++mrb9o4/J06cYPPmzXTo0IG6desWWF9/vHq7jbVTges+rv+env59w8LCCA8Pty1bf2fW5aioqGL/TYRscL972OV85k1wP3oUateGG26AAqa58pe0s2nMSZ7D8z8977Yuf2y+3H2ZlDXdxPnz54mKiiI8PJzTp0+7TQKzYsUKNm7cSGRkJBEREXTv3h2lFOHh4aSnp3PNNdewdOlS8vLyuPnmmwG47777uO6668jIyGDEiBHccccdnDlzhuuvv57MzEwmT57MiBEjyMrK4vz58yxfvpzNmzfbxj8AtmRTDzzwALm5ueTl5ZGXl4fW2vbNwfrquOz4umLFCi5cuEDr1q3Jy8sjNzfXdizHV8dlx1HeFSpUsJ1Pa13kzEQCmjVrRnHyalmFbHC/a1gSn9da71TmMbivWweXX27ZoHSuV2vNmoNrGP7tcNYfNuoowV2UJ3l5eSiluHDhgu1DRClFXl4emZmZhIWFOX0YWGNRfn4+GRkZtg+niIgIjx9GJX31dlvHrsDe7Ku1dvtgzcvLsx3L8QO2WrVqxR7XAmW4n7tDVsjAnigIszAppejUoBPrhqyztc0/8vUjzOozq9TrIkQwhIeHA9ia2RxVqVKltKtT7gS1C4fWeqnWeojjgJmAaNAgsMf30uw/Zwe7CkKIcqJs9c/zkY6LK3ojsI1SLQu2Ht0a7CoIIcoBUwd3vJ0hPMiDYqb1mmZb/ud3/wxiTYQQ5YW5g7vlafySPosAIwWAR0HOizLsimG25V/2/xLEmgghygtTB3f9918AtKIWx54+xtyb5wa3Ql5663ffJ9EVQghfmDq4W9NCKqBmTE0iwyML3byseHrZ08GughAixJk7uFuYoe94XLSXD3+FEMIPTB7cizEg6eBB/1fDC3e2ds6pcvTcUfp/2Z+dx2XWJCGE/5l6so5862hTX+7cT58Gl5znpWFKzylUiqrEO6uNYeK136oNwB+H/uCre76idXzrUq+TECJ0mfvO3TJPalhsJe/3CdLIuJjIGN6+4W238j0n9tDmvTb8Z3Pg0+gKIcoPcwf3OMvIVl/6se/YEZi6lNC9i+4NdhWEECHE1MFdWzPS+ZJ9zs+zDfnqlwG/8OVdX1IpyvO3jfsX38+i7YtKuVZCiFBj6jZ3DhyAuhB2OsP7fbp0CVx9vHB146sBoznm2R+fdVp37NwxPt70MR9v+hiAFQ+uoGujrqVdRSFECDD1nXuxvP56sGsAQLta7dzK6r1dz+l9tzndSqs6QogQY+rgrvGht0x0tPG6ZUvgKuSDFjVauJUl1EzwuO0tn96CmqDo8mEXlu1dRsrJFAC+3vU1C7cs9LiPEKJ8M3Vwt1Le5I45fNj5NciaVm/K7n/u5pkrnwFg3FXjWD9kvdt2/7fz//hq51cA/H7gd67/+HqaTm0KQJ8Ffbjny3s4cPoA+07uA+B8znkmrZxEbr7MgiNEeWbuNnfrGCZvurl7mx64FDWr3oxnuz7L/tP7GdlpJFHh7nMp3vzpzUUep9GURoAxC9XLv73Maytfo2ZMTR5u/7Df6yyEMAdz37nXrAmAivGhK2QJJqMNhOoVq7PwjoUe0xNUCK/A0n5LPe7X8d8dPZZbJwSZsW6G/yophDCdoAZ3pVQfpdSs06dPF2t/XaWysWBtT/eGw4S+ZdGOYTtYdJfRFfK1a1/jphY3edzO2u7uSE1QHM88DsCfh/8EICcvh8ycTFanriZf5weo1kKIssbc0+xduACAyvMyaPXtC4mJxTtXKWlZsyW3trqVNQ+v4fFOjwMw86aZbtsde/pYkce68T83EvVKFLGvxtL5g848+NWDnM857/c6CyHKHnM3y6SmAqDOnfVu+8qVjdwyJnBF/SsIU8avZ0iHIRx88iD3X3I/ALVia3ncR49zTqS2OW2z0/uPNn5EzKsxAaitEKKsMXVw9zkn5GOPwZQpgahKwNWrXI+Pbv2I9GfS2TtiL4BtlGvVCvZvPtWijakHFYq/Rv7l8Vgf/PkBaoLi9wPBHa0rhAickAjuyqvuMkBGBtx8c9DS/vpD9YrVbUE97ak0zj5/lrSn0jg/2mhueaTDIwC8eu2rKKU49ewp2sS3cTrGw0uNXjRdPgzuaF0hROCYOrhbeT1Zx8SJxuvy5QGrS2mKiYwhNiqWChEViI4wHiqPuWoML3R9gSc6PQFA1eiqrBy0EoBXr3mVJzs96XSMQ2cOoXUx8uILIco0U/dz1742zJy3PEws4z1mSiImMoaJ1050KouLjnNqj/9m9zfsTDcmCan/dn1m3TSLwR0Gl2o9hRCBZe479/h4AMK8Tfk7bx60awedOgWwUmVfr2a9nN6//r+ykW9HCOE/5g7ulSxpcytU8G77tm1h0yZo1SpwdTKBSddNon3d9jSqaoxs3Xtyb5BrJITwN3MHd2szi7f53LWGuXPh6NGAVckMKkRUYP2Q9YzsONJWJu3uQoQWUwd3bUkCpjK9HJhz8iQ8+CA89VQAa2UeT3R+wrb8+PePB7EmQgh/M3Vwt/K6t4w1edj8+YGrjMm8/I+XAfjX2n8FuSZCCH8yeXD3sSnBm9TA5cyL3V8EoEqF4EwcLoQIDFNHO9sgpjAv79yFR69e8yoZFzI4dq7ofDVCCHMwdXC38nqEqvCo+0XdAViVuirINRFC+Iu5g3stSwKtihWDWw+TS6yTSJgKY/0h95mghBDmZOrgrmOMDIcq0ocJODp3DlBtzCs2KpaEmgn8eeTPYFdFCOEnpg7uZGYCoPLyvN8nMjJAlTG3DnU7yJ27ECHE3ME9LQ0AZZm0wyt16xqvK1cGoELm1bZWWw6fPcwX274IdlWEEH5g7uBeHJZ8NHTrFtx6lDHWnjJ3fn5nkGsihPAHUwd3n7NCAvTrZ19es8Z/lTG5pHpJwa6CEMKPTB3crcLCw73fuFo1+/LGjf6vjEl1qNch2FUQQvhRSAR3n1hTEAAUd2LuENSserNgV0EI4UemDu66dm1joUK09ztVr25fPuvlxNrlhHVC7r9P/x3kmgghSsrUwd06eCnMl+6NjrnfExP9XCFzW3D7AgA2p20Ock2EECVl7uBuvfP2Np+7qxEj/FeXENCzWU8UivWHpb+7EGZn6uCef8wy6UZOTvEO8Pvv/qtMCKhSoQqt4lux5qD0IhLC7Ewd3K2sbcWi5DrW78ia1DXk6/xgV0UIUQLmjooyM5zfdW3UlfTz6ew4viPYVRFClICpg7u2ZPpVMgmH33RrZIzcXfHXiiDXRAhREn6PikqpWKXUPKXUbKXUvf4+fgHnLI3TlAvNqjejTqU6/Pb3b8GuihCiBLwK7kqpD5VSR5VSW1zKeyqldiql9iilnrMU3wZ8obUeDPT1c32d1aljvEb5kPJXFEopRbdG3eTOXQiT8/bOfS7Q07FAKRUOTAd6Aa2Bfkqp1kAD4IBlMx9y8RaDpc+68iX9gCul4Kuv/FSh0HDVRVdxIOMAu9N3B7sqQohi8iq4a61/A064FF8B7NFap2its4FPgZuBVIwAX+jxlVJDlFLrlFLrjh0r3tyd+swZY8GXfO6ePPww3HYb9OxZ9LblQK/mvQD4bs93Qa6JEKK4StLmXh/7HToYQb0+sAi4XSk1A1ha0M5a61la6yStdVK8NQ2vr44fB0DllbDb3vHjsHgx/PBDyY4TIppUa0LLGi35dve3wa6KEKKY/P5AVWt9Tmv9oNb6Ma31J/4+vifyQNX/ejXrxQ97f6DH/B7BrooQohhKEtwPAg0d3jewlJWaYuVzh9KbhSkvz/btwmx6N+8NwI8pPwa5JkKI4ihJcP8DaK6UulgpFQXcA/yff6rlG5/yuQN06QL//rf9faNG/q2Q1ahRxsxPp08H5vgB1P2i7sGughCiBLztCrkAWAW0VEqlKqUe0lrnAsOBH4DtwGda662+nFwp1UcpNet0MIKfY0D/O0Apbr+wzEdqffBrIhUi7Nkz086mBbEmQoji8La3TD+tdV2tdaTWuoHW+gNL+bda6xZa66Za64m+nlxrvVRrPaRqMSfN0PXqGQsREb7vfM01MHNmsc5b3rR5r02wqyCE8JG5x+1HGXncw8KK0c89PBzOnfNzhVzMng333Qc1agT2PAGS/WI2AOnn03noq4eCXBshhC/MHdxPZxiv+cXsCvnkk/6riye9esH8+bZJRcwmMjySYZcPA+DD5A+DXBshhC9MHdz1Ccu4Kh2g9JDr1sHSArvqF23ePGMEbKC/IQTQgEsHBLsKQohiKEZjdRmijKAesH7ul19uvKaacyQAACAASURBVBb3w2PgQOP1zz+hWze/VKm0JdVLsi3n63zJnS+ESQT1f6q/essUO7hHFzGx9tVXgy/zsxbExCmJHf9tb/n0liDWRAjhi6BGnRL3lrGmHShucL/yysLX160LjRsX79iOTp0q+TGC6I/BfwCwdNdSth71qberECJIzHtLCZCZWbL9O3RwL0tPty9/8w3s3m38XLhglGkN2dm+JSszYT93R45NM21ntCUzJ5MNhzcEsUZCiKKYOrjHWINzcZs9/vEP9zLHdAEZlt44LVrADsu0c2lpRqrh2bOLd06Tah3f2rY8cMlA2s9qT3pmeiF7CCGCydTB/YpOnUp2AE/ZKGNi7Mv33Wdf3rbNeLUG/FWrij5+YqLx2qxZ8epXhmwdam+O+Xzb5wBkXMgIVnWEEEUwdXC/KO6ikuVA8dRWb21+cZWTY7xauzVu2lT08YcONV6tM0aZXM6YHC6pfYnt/cq/SykBmxDCZ6buLTPoskH8OvDX4lfg0CH3Msc78o8/ti9bu0P60i1ywQLj1cT93B1FhEUw8yZ7yobRP48OYm2EEIUxdW+ZEvPULJOba7y63tW7joL1pofOL78Yr+mh0zbdqYG9KexAxgEOnfHwASmECDpTN8uUWJUq7mWVKnm+O7e2uVeqZLxa29PBeMj6zTf+r5+vtIa33oLDh0vtlPXfrg8YA5xe/vVlTp4/WWrnFkIUrHwHd0/9z++6y3Nwb2CZFtb6gXDFFfZ1derATTfBwQLmKskopQeP27fD00/DnXcG9DR6nOZfvf5le382+yzf7f6OscvHMuL7EQE9txDCO+U7uEdFeS73FNxjY43X+Hg4dsyeWsBRgwZw/rx7eUn743vLmvq4du2An2r4FcNty93mdCP9vNH0tOXoloCfWwhRtPId3JOS4PXXvdt28GCYMMEIoPHxBWd6LKi3TWmwPru47rpSOV3aU2kMuHQAG49sZMASI8FY8pHkUjm3EKJw5Tu4AzzzjHtZQT1iCpp71XGyEOvy1Kn2shYtvK+P1jBxIuzb574uJ8dIZvbTT94fL4BqxdZi7i1zmXvLXKfyX/f/ig5Upk4hhFckuHtS0JysPxYwWbS1hw3Yg/vcufayWrW8P/eBA/Dii3Djje7rUlONNMQPP+x5X2uPnlKetvCBSx+gYRX7XOlXz7uaJTuWAKAmKG7/7PZSrY8QwuT93APG10Rk1vlYjx0zUhMAbHDIvbLFi3borCzj1RqgXdvpd+2CI0eM5YI+LKwfSp56AQXYzuE7nd7f9tlttuVF2xeVdnWEKPfKdz/3gvg6YbZ1+/h457t4q3Hj7Mtau2+zaJHRhp+cbE9/4Hrn3rKlPYvlvfd6rof1A8F19KzW0KkTfPll0ddSTBUjK6LHaZpXb24rkz7wQgSPNMsADHCZbchTe7e3PAV3a/vz4MFGkrPISKP5xcqa+Cw313goOmMGPPIIDB8Ov/1mrGvTxpi2b/Ro+yQirs6eNV5dnw1oDWvWBLyLJMCO4Ttsy1fMvqKQLYUQgSTBHZzbx8GYpKMoCQmeyzdudC9LsqTM3b7dXmbNPqm1vQknP98I9BdfbAT56dPhqqvs++Tmwg8/wP79RdfPE9eHnJMnG88IrB8KfhCmwtDjNMmPJKOxn2/Mz2P8dg4hRNEkuPvCsS2+oAB70jJCs7U9RS6XXuq+XVyc8free/DSS8by1KnGw9CePWGmJYeLtf1861ZYtsx4oFrQua0zS7VpU9SVGFavNvLSZ2d7t70PLq1zKcsHLLe9f2XFK34/hxCiYBLcrdauLXobxztf6wNQVzEx8NBD9nQF4HkkrLX55q+/7GWHDtnvov/zH+MufoSHEZ9z5ng+d+XKxmt3l0yZ1g+lJ55wLl+xwngNUN/85jWaO72/bOZlaK3JuJDBuezQSKYmRFklwd3q8suN4O3YP704WrSADz90LvM0avXAASPVwZtv2ssuvth5m3vugXbtCj7Xjh2weLFxnMxMe1pi1yBu9c47zu8DNbG4Az1OM6T9EMAY4DTiuxFUnVSVSq9V4kJuEAd8CRHiJLi7+uc/fdvetUnD05R6hw4Zgfd//7OX1awJn3/uvN399zu/P3DAfiffsqW9eccalOfPh9tuM47zj3/Yp/6zBnkr14yWrgI84Ghmn5nkjc3j6SufZtof02zlzf/lfGc/6KtB3PPFPQGtixDlhfRz96RVK++2y86GN95wLvP0QDUjAz75xLnMml3SkeMsUKmpRrOJtZvlzp2wZ4+xvGuX8free/bte/QweuGAMbG3N6wjZx1H2AZImArjjR5vMLWn/ZvRgYwDTtvMSZ7Dwq0LA14XIcoD6efuyfffe7dddjaMcekF8tpr7tsdPGj0cnHkqc3+ww/tQd96F/6Kw4NI10k/XNvyrXf5jil/z551PoYjazdLb3z9tb2NvgT+2dH5m9GmtE2cyz7Hir9KfmwhhJ00y3ji2qxREE+9TJo0cS/7+Wejj7qjtDSjL7ujmTPdR5dagzwUnsZg4ULPD25ffBHGjy94P4D16wtfD9Cnj/uD2mLS4+zNQJe+fyk136xJ97n+ObYQwiDB3RNvh+8X1GPGkzCXf+pffjHa3X1x9GjB61JT3c8Bnp8BlAE7hu1gxYMruDjuYrJyffh3FEJ4RYK7JzVqeLfdCy+4lxWUdMx1dqRVq4zsj658ef7Qv799OTHRnnPeUZcuRR+noLz2AdSyZku6NurKqodWFb2xEMJnEtw9Kap3idW8ee5la9Z43tY6ItXKcZCTVcWKvk2m7dgstHq15xzzV1wBI0cayw8+6Pk43p4zAF0na1dyn1jkyNkjfj+PEOWNBHdPIiJg7Nji7es4KMn1mI48fQi4tssX5YsvnN97GoyUk2MfNes4+OnFF+3L3s4UFaAuk7ljcnn/xvdt7+tOrsu+k/uYumYq/1rzr0L2FEIUJPB94MxqwgRjlKlrAC0u1/ZyTw9HC5rdyVuOzTIpKbB3L0ybBv/3f+7b/vqrfdk6stVq1CioVs35AyCAwsPCeSTpEe5qcxdNpjbhVNYpkmYnceL8CcC9h40QomiqLMyYk5SUpNetWxfsanj26KP2PC+lYd8+95GqWrs3iXgqO3AAGjakUNbft+O+X35pDIaysq5z/NvwVBYge07soe+Cvmw/biRaO/3caapUqMKnWz5l/qb5fNP/m4DXQQgzUEqt11oneVonzTJF6dq1dM/nehcNsHmzd/u6DpTyluu3iqQk6N27eMfyg2bVmzk9aK06qSqHzxym35f9+Hb3t5InXggvSHAvStOm/jlOtWrebffoo+5ll1zi3b4nTnhfH0euTUTr1sG33xbvWH5SNboqbeLt2S0TZybaluu/XZ987eVDbyHKKUk/UJROneDZZ43eKK68mT7PyvpQsyjetvF76rniqSukN6ypgsuYLUO3oMdptg7dSnxMvNO67Lxst/ens8rw35EQpUzSDxRFKZg0CTp2dC5v06ZUsir6JCWlePsdKdtdD1vHt2btYOeUzBUnVuT9dfYeNjd8fANxr8eVdtWEKLOkWcYXnTvblwtLxetvntIKeOKp3703XFMBl0ExkTGkPZXmVPbYN4+Rm5/LvpP7WL5/eXAqJkQZJcHdF44POz/91Pf0Ad7wNDrW0zcbx0m3fbFzp3uZNdukJykpZeYbSq3YWvRq5jwWoMOsDjSZas/nUxZ6fwlRFkhw94XrDEgFpRrw1MOmtvtITI++/tq77YpKBlaQezzkSy+sf30Za7L59t5v0eM0r1/3Orck3MLhM85pHXaf2B2kmglRtkhw90W9ekb6XquCHkQ6ZoasX9+YiDotzfO2rurUKX79vJGc7H4nnpFR8PZl9E74mS7PsPjuxewYvsOpvOW0lk5372ezz0rPGlEuSXD3Vb16xoxIM2cWPGz/o4/sywsXwpNPen/8wjI/BopjWmGwd9vMzfU+uKekwJAhvvUg8oPqFavz20DnvPRd53RFTVCoCYrKr1Um4iUZiC3KHwnuxZGcbASygtLpDh5sX7ZmXHzoIe+OHYQMjW6s3TZXry48uP/9N/z0k7G8ZAnMnu0+f2wp6HZRN7640+hC+m7Pd9l2bJvTek3Z/PYhRCBJcC8Ja6KuuDh7kBs6FGbNsm9jnTrPdeq7gia+KO7DyylTnB/GNmzoORGZ1va6OkpJMT6sDjmM/oyPhwoVCj5nq1Zw3XX24wbR7a1vR4/TjOg4gr9H/u22/sDpA6xOXc2CzQtYsHkBaWe9bCYTwqTk+2pJNGpkvL73HlxzjbHsejdvfega59IHe/hwz9PceZuhEYwc7snJRrPPjTcaMz5Zk4Tt3298UFSv7t6V0lpXRwWNxG3btuDze6prGehZU7lCZfLH5vP5ts+5+4u7AbhoykVud/COM0IJEWrkzr0kYmONO9Z+/exl8+cbr9Z2a+vQ/uuvt2/z2GNGMPbEl+D+4otG75c334RmzeyBPTbWmJVJqeL3qgEjEZlre/w2hyaPgQOLf+wAU0pxR+s7ABhxxQgGJA7wuF1ufi6pGamcuXBGZoQSIUXu3APlzjuN5hlrN8N27Yzg27cv3H+/vbnG0dCh7t0ru3Ur+Bz5+bBhA0RGwrJl9nLHyTfuv9/4huGY9dFbPXrA1KnOZT/9ZJ9oZO5ce7kvzTLJydCyZclTHBchTIU53Z3PTZ7rtL7OW3VIO+fcPCN38yJUyJ27Pz3yCHz1lbE8fbrR88UxgPXpYzTbWEe6/vabsd1uS9/s/v2Ndm5H//iH+3meeMJ4vesuY1BSfr7RJGPl+MFx9Cj8739F111re90djRjh/N412IMx8cgddxjfEoYPd66na/ri9HS47LKCZ4UKID1Oc/xp+4xYroFdiFAid+7+9L491wkREe6BGqBSJftyt272O3PrnW96un39yZPuDzQffhhuusnz+evVMx6IOs769PrrznfYnlg/bPr2hbNnnevoyjqadckSe9m33xqTm7Rr5zxqd8oU9/3PnjVef/+98DoFSI2YGiy7fxmdGnQiX+dTdZLz6N/h3w4nNjKWN35/g3dueIeRnUYGpZ5ClJRkhSxrHB+8xsW5N13Mnm1/INq3r738lluMpiCAzz6zl3vTXOL4AeJNZkml4NZb7e/j4+GVV+D22z1/oLnu6229AuS6JtdRKaoSVSpUIW9sHovvXmxbN/2P6bzx+xsAPPHDE6gJRn1z8nLIzc8NSn2FKA7JClnWhIcbo1n37St6288/Nybe1tqYYKNFC6P74w032Le54oqij9O8uefy7Gy48sqi99+7F8aMMZY9zeO6fTsctqQJqFMHPv4Y/vvfoo9bCsJUGLck3ELyI8mkjEhh+7Dtbtv0/7I/Ua9EEflyJGqCYsHmBUGoqRC+kWn2zGLtWjh92njI6QutYeNGo53b+h6M5wPW/viLFxt3/laOd9dPPw1vveX7OR2P41pexuXm5xL5cmSh2+hxmgOnD/DayteY3ns6qgx0ARXlj0yzFwquuML3wA5GgLX2Vb/8cnu547ywhTWLufaJ19rzQ1VHBY3cBaMnT8uWQRnJ6q2IsAj0OM2hJw/x4/0/svkx92kOH/v6MRpNacSMdTOYuX6mZKMUZY4E9/IgIsIIymvXel6/a1fB+1oHajn65z8L7+NepYrRXORJRoZxvtGjC97fKi3Nt37/fla3cl2ubXItbWu1ZXaf2YzpPsa27qNN9vxBj33zGGEvhdkC/PpD66XPvAg6Ce6i8L70EQV0qHJNf+yqoAer1l4y3tzp1qnj/PwgiB5u/zAv/eMl9DiNHqc5POqw2zYVJ1ak74K+JM1OouLEiry24rUg1FQIgwT38uwOYwRnoYOJvJl025dujdZzOqZATk01vlX89JN7n/xmzbw/dimqUqEKGc9l8HjHx7myofHQuftF3Vm6a6ltmxd+foF7F91LTl4OM/6YIbNFiVIlD1TLs5MnjbbvJ58sOCfM779Dly72945/L9Z98vPh7bfhqacKP99PP8G117ofq3Vro0eNa3kZ6Dbpqz8O/sEV/3buoVQ5qjJnsu3PIfY/vp+L4i4q7aqJECQPVIVn1arBqFGFJ/tq08beNNOzp+dtlLIH52rVjFQInh6qOgZ2R7tDZ/aky+tfTt7YPM48f4b3er/H4rsX07t5b6dtGr/bmLdXvW3LOT9r/Szy8vMKOKIQxSN37qL4tm+HrVuNppbate0TjRTUFdLVtm1G2uDISGNikPh46NTJngCtpHfuWZaHmgXNmFWKrvzgSlalrip0m9PPnWb5/uXc/OnN7B2xlybVmhS6vRCF3blLcBf+8e9/G5OUPP64Pe2AN32/mzd3v3PPzzf2dQ3uN9xgDH767Te4+mpjspD69Qs+tjWoZ5W9nis7j+8kYXqCU1m4CidP2+/gc8fkkqfzWHVgFVc1vqq0qyhMoLDgLrllhH88/LARfBs0sJfFxjpnqMzPN1IRO/LUJJOX57mXjnVU69KlxrF27So8uHsaLVtGtKzZ0paBcs6GOZzKOsWxzGO8ttLew6bmmzU5lWXk4q8WXY1ODTrx5V1fUjEysNk0RWiQ4C78p2FD5/enTxuBOi3NyJOjlJFc7dFHCz9OZKRz/ntX1m6WtWt7Xp+XB4sWwVVXGR8CZdyDl9kzZD6WZAyOGpo0lPO555mTbHQ5PZl1ku/2fEfMqzHMu2Uel9S+hKoVqvLzvp+5p+09xEZ5kRNIlCvSLCNK15Ej9ikHtYb//AfuvbfwfR57zEiXkJhovO/f39hvzRpj5K41gFu/FUybZgy0sioDf+PFlZOXQ9QrRc+r+9fIvzh05hDtarWTQF+OSJu7KFvS0ozUwI4Tkyxf7jl3fWFGjTLy3kRHG00wu3cb/eLfeAOefda+XRn4G/eXfJ3PxiMbaT+rfaHbxcfEk/ZUmuS8CXHSFVKULbVru884dfXVMG+ekatea/jmm6KPM3mykXrY2rbevLnx8LSwdAqejjHA8xR8ZVGYCuOyupfZRsremnArC+9YyFs9nJO7Hcs8RpOpTWzdLdUExdKdSws4qghFcucuyq5cS/70jAyj/XzLluIdp7C/8QcegJUrISXFufzCBeOZgXUOXJOwNuPERsbSo2kPluxY4rS+V7NefLfnOwCm957O0MuHBqOawk/kzl2YU0SE8VO9OmzeDKdOGdksrVkuvWXtVvnGG7BwoZEC2dpOv3ate+78zExjSsSCHtiWYZHhkehxmrMvnGXx3Yv5e+TfvPyPl23r95/ab1se9u0w1ATFyO9HoiYoHv36UeZvnB+EWotAkDt3YX5795Y8B81bbxl38Vo7B3Xr/4+vvzYe6Dp29TSpx797nKlrC0/bPOHqCYxbPo5zL5wjJtLDZO6iTCizD1SVUn2APs2aNRu8O4SGoIsg0xqef97oD79tm9FF88CB4h1r8GBjhqunn4bGjSE52fg24c10hCbhTY+cqxtfzajOo1jx1wpevuZlosKL7sEjAq/MBncruXMXpUZr+OEHI21CUYnOfBEdbRzzr7+MNAzXX2+M2n3qKc8jdc+eNcq9+ZA4etSYOL1VK//VtwgpJ1NoOrVpoduM7jaa3s17Uyu2Fs2ql83snaFOgrsQ3sjPNxKerV1rdLPc7D4Dk19cdhls2GAs//e/Rpv/4MEFp2uoWtV4qBzE/6tZuVks37+cXp/0KnS7f/f5Nx0bdKRZ9WZERwQ/p0+ok+AuhD9obfSlj401JvmeOhUOHQrc+apVM9IyO7rlFiO52okTxmCuatUgJsaY/SrSMu9rKfVtTzubxtJdSxm8dHCh2310y0dc1fgqGlYxRjBL33v/keAuRGnKzjba5fPyjFG0qamwfr3RrfKZZ6BXL/juu+DU7Ycf7LNbjR8P9erBbbcZzyQOHzbSMp89C5Uq2adndB2TUIB8nc+eE3tYtncZw78bXui2z3V5jiEdhtA4rrEE+xKQ4C6EWVy4YDQNnThhjOT93/+MZptZs4y0Da+8AhMmGBkxS1OnTrB6deHbLF4Mzz0HO3dCjRrwyy/kfPcNmxdO5X+XxDGi8Xa3XaqFV+Jk3lkA+jbpxeR2T9GkRjPC4qpB5crGh4s14ZwvHwJal9o3mGCS4C5EeWJNmXzsmJFnp2JF4y69Th148UUYMgTuvx/mW/q0z5pllBXmkUeMMQa+aN8e/vzTrTijAuysAX92acL6rBRmd3BeXyUL2h+G5Rcb77dMh4TjEO4aqkaPNhLRpacb7yMijG9JvXrZn2m8+66RhrphQ2OcxOWXw5IlRpPa9OnGtxUwjvHDD7BggZEKo00bGDbM+Jbz7ruwY4fx7OOaa6BfP2O/3383PogbNDCS2SUmGv/2qakQFWX8u4eFGcvR0cagPKWcM6OW8ANIgrsQwn+0NgKVtelp/36jV9CiRUbqh5QU4wFwly7w/fdG/v1Tp+D22+FBewZM9u6FpkaPnFPRsPrtJzk4+23+rAt/1Dd+rGKzof2JCpzPu8C6+vD7v6Fd/5FUemOKc90++cQ5Ed2UKTBypPM2x465T+C+erXxrWP5cnvZww8bAf6yy5y3XbbMqLtrdtPjx43g7jqqecQIeP11uPJK+4eO1aZN0K4dxSXBXQhhOqeyTrHnxB62HdvGukPr+OPQH6xOtTcNKRTNqjcjsU6i7efS2pdSt3JdwlSYvWnmwgUj6GZnG3fNlSsbd+onThiBvnJlY9RzerqRiiItzeh++sADxoPqV1+FPXuMprArrzS+/Zw/b2Qr3bzZeCZRo4YxR3BWFnTrZswzsGmT8SHXubPxreDGG+HXX50vcs4cGDiw2P9GEtyFECEhJy+HzUc3czDjIBuObGBj2kY2HtnI3pN73bYd1XkUbeLb0K52O9rEtwnJSU4kuAshQlrGhQw2HN7AHZ/fwfHM49SvXJ/jmce5kOc+G9fY7mNpW6stbWq1oXn15kSGRwahxv4hwV0IUe7k5eeRcjKFTWmbWHdoHZP+Nwkw0ibnayNxXGRYJAk1E2hTqw1t442A37ZWWy6Ou5jwMO+6gAaTBHchhLA4n3Oenek72XJ0C1uObmHrsa1sObrFKWNmxYiKtIpvZdzhxxsBv22ttjSs0rBM9cuX4C6EEEU4m32Wbce2sfWoEey3HNvC1qNbOXjmoG2bylGVaVOrDa1rtqZ1fGva1GpDQs0EGlVtZDzELWUS3IUQophOnj/JtmPbnO7ytx3bRtq5NNs20RHRtKjRgoSaCSTUSKBVfCsSaibQokaLgKZMluAuhBB+lp6ZztZjW9lxfAe70nexM30n249tZ9+pfbY2fYWicVxjWtZsScsaLY3gXzOB1vGtiY+JL3ETT2HBPaJERxZCiHKqRkwNul/Une4XdXcqz8rNYs+JPWw/tp2tx7ayM30nO47v4Le/fiMzJ9O2XdUKVencsDPf3RuYPEMS3IUQwo+iI6JtD2Dv5E5beb7OJzUjlR3Hd7D92HZ2pe8KaI8cCe5CCFEKwlQYjao2olHVRlzf9PrAny/gZxBCCFHqJLgLIUQIkuAuhBAhSIK7EEKEIAnuQggRgiS4CyFECJLgLoQQIUiCuxBChKAykVtGKXUM+KuYu9cEjvuxOsEk11L2hMp1QOhcS6hcB5T8Wi7SWsd7WlEmgntJKKXWFZQ4x2zkWsqeULkOCJ1rCZXrgMBeizTLCCFECJLgLoQQISgUgvusYFfAj+Rayp5QuQ4InWsJleuAAF6L6dvchRBCuAuFO3chhBAuJLgLIUQIMnVwV0r1VErtVErtUUo9F+z6eKKU2q+U2qyUSlZKrbOUVVdKLVNK7ba8VrOUK6XUVMv1bFJKtXc4zgDL9ruVUgNKqe4fKqWOKqW2OJT5re5KqQ6Wf5s9ln1LNqGk79cyXil10PK7SVZK9XZY97ylXjuVUjc4lHv8m1NKXayUWmMpX6iUigrQdTRUSv2ilNqmlNqqlHrcUm6q30sh12HG30m0UmqtUmqj5VomFHZ+pVQFy/s9lvWNi3uNhdJam/IHCAf2Ak2AKGAj0DrY9fJQz/1ATZeyN4DnLMvPAa9blnsD3wEK6ASssZRXB1Isr9Usy9VKoe7dgfbAlkDUHVhr2VZZ9u1VytcyHnjKw7atLX9PFYCLLX9n4YX9zQGfAfdYlt8HHgvQddQF2luWKwO7LPU11e+lkOsw4+9EAZUsy5HAGsu/n8fzA0OB9y3L9wALi3uNhf2Y+c79CmCP1jpFa50NfArcHOQ6eetmYJ5leR5wi0P5R9qwGohTStUFbgCWaa1PaK1PAsuAnoGupNb6N+BEIOpuWVdFa71aG3/ZHzkcq7SupSA3A59qrS9orfcBezD+3jz+zVnubK8BvrDs7/jv4lda68Na6z8ty2eA7UB9TPZ7KeQ6ClKWfydaa33W8jbS8qMLOb/j7+oL4FpLfX26xqLqZebgXh844PA+lcL/OIJFA/9VSq1XSg2xlNXWWh+2LB8BaluWC7qmsnSt/qp7fcuya3lpG25prvjQ2pSB79dSAziltc51KQ8oy9f5yzDuFE37e3G5DjDh70QpFa6USgaOYnxQ7i3k/LY6W9afttTXr///zRzczaKr1ro90AsYppTq7rjScndkyv6oZq67xQygKZAIHAYmB7c63lNKVQK+BEZqrTMc15np9+LhOkz5O9Fa52mtE4EGGHfaCUGukqmD+0GgocP7BpayMkVrfdDyehRYjPGLT7N8/cXyetSyeUHXVJau1V91P2hZdi0vNVrrNMt/ynxgNsbvBny/lnSM5o4Il/KAUEpFYgTET7TWiyzFpvu9eLoOs/5OrLTWp4BfgM6FnN9WZ8v6qpb6+vf/fyAeMJTGDxCB8RDoYuwPGdoEu14udYwFKjss/47RVv4mzg+/3rAs34jzw6+1lvLqwD6MB1/VLMvVS+kaGuP8ENJvdcf9wV3vUr6Wug7LT2C0dwK0wfnBVgrGQ60C/+aAz3F+eDY0QNegMNrBiTqd2wAAAQFJREFUp7iUm+r3Ush1mPF3Eg/EWZYrAiuAmwo6PzAM5weqnxX3GgutVyD/MwX6B6MnwC6M9q3Rwa6Ph/o1sfwiNgJbrXXEaF/7CdgN/Ojwn0oB0y3XsxlIcjjWIIwHLHuAB0up/gswvhrnYLTzPeTPugNJwBbLPtOwjJguxWuZb6nrJuD/XALLaEu9duLQW6SgvznL73qt5Ro/ByoE6Dq6YjS5bAKSLT+9zfZ7KeQ6zPg7uQTYYKnzFmBsYecHoi3v91jWNynuNRb2I+kHhBAiBJm5zV0IIUQBJLgLIUQIkuAuhBAhSIK7EEKEIAnuQggRgiS4CyFECJLgLoQQIej/AT3KCo8D9j1AAAAAAElFTkSuQmCC\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"code","metadata":{"id":"w9fAFvi_lBNg","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1622563972748,"user_tz":-120,"elapsed":603,"user":{"displayName":"Valentin Mercier","photoUrl":"","userId":"08411223227635876166"}},"outputId":"ecba89ec-19af-4a88-e275-8c63f570329b"},"source":["# Plot RMSE vs operations\n","xx=np.array(range(0,30000))\n","vecx2=3*nx**2*15*xx\n","vecx=3*nx**2*10*xx\n","plt.semilogy(vecx,error_train,color = 'black',label='PINN 10')\n","plt.semilogy(vecx2,error_train_2,color = 'green',label='PINN 15')\n","\n","\n","s=0\n","yy=xx\n","for i in range(0,30000-1):\n","  if i%5==0:\n","    add=nxH**2*5+nx**2*10\n","  else:\n","    add=nx**2*10\n","  yy[i+1]=yy[i]+add\n","  \n","  \n","yy=3*yy\n","print(yy)\n","plt.semilogy(yy,error[:30000],label = 'MPINN',color='red')\n","plt.xlabel('operations')\n","plt.ylabel('RMSE')\n","plt.legend()"],"execution_count":null,"outputs":[{"output_type":"stream","text":["[        0     20520     35040 ... 471556440 471570960 471585480]\n"],"name":"stdout"},{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7fd61050df90>"]},"metadata":{"tags":[]},"execution_count":15},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]}]}