{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"MPINN_1D.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 ADAM 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":1633425745629,"user_tz":-120,"elapsed":3832,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"aca78a43-51b2-4f55-933a-13a1dacd95a7"},"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 = 30\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":1,"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":1633425745630,"user_tz":-120,"elapsed":7,"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":2,"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":1633425745630,"user_tz":-120,"elapsed":5,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["#physical value \n","alpha = 3\n","# discretization numbers\n","nx = 40\n","nxH = 40 \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":3,"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":1633425754146,"user_tz":-120,"elapsed":8520,"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":4,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"x8OSjC6KtTe4"},"source":["### Network training function"]},{"cell_type":"code","metadata":{"id":"Mytvfjkzr9du","executionInfo":{"status":"ok","timestamp":1633425754147,"user_tz":-120,"elapsed":6,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}}},"source":["def train_one(model,optimizer,scheduler,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","        scheduler : Pytorch scheduler : 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","        #Train \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","\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_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":5,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"z5DtKYsi00RJ"},"source":["### Residual computation fonction"]},{"cell_type":"code","metadata":{"id":"yslsmOINtTe6","executionInfo":{"status":"ok","timestamp":1633425754148,"user_tz":-120,"elapsed":6,"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":6,"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":1633425985895,"user_tz":-120,"elapsed":231752,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"eb3c1fb7-7138-4620-aec8-22e0cfd1e1a2"},"source":["#Create network for the fine and the coarse resolution \n","nh=200\n","nH=100\n","modelh = PINN(1,nh) \n","modelh = modelh.to(device)\n","modelH = PINN(1,nH) \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=150, gamma=0.9)#300,0.05\n","schedulerH = StepLR(optimizerH, step_size=150, gamma=0.9)\n","\n","#first training epocs\n","stampo=[]\n","tol=1e-6\n","nit=5\n","epocs = 5000\n","\n","epoc_h,_,_,local_loss_total_h,error_h = train_one(modelh,optimizerh,schedulerh,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=5\n","nitc=5\n","ncicleV=3000\n","for i in range(1,ncicleV+1):\n","    _,_,_,local_loss_total_H,error_H = train_one(modelH,optimizerH,schedulerH,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,schedulerh,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%500 == 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":7,"outputs":[{"output_type":"stream","name":"stdout","text":["Loss value after first training 4403.79248046875\n","Loss value at Vcycle number 500 : 0.005806652829051018\n","Error value at Vcycle number 500 : 0.00287073738175706\n","Loss value at Vcycle number 1000 : 0.0015523368492722511\n","Error value at Vcycle number 1000 : 0.00023793358867354143\n","Loss value at Vcycle number 1500 : 0.0010763347381725907\n","Error value at Vcycle number 1500 : 0.00022889654444424525\n","Loss value at Vcycle number 2000 : 0.000903602282050997\n","Error value at Vcycle number 2000 : 0.00023823113540631655\n","Loss value at Vcycle number 2500 : 0.0008237428846769035\n","Error value at Vcycle number 2500 : 0.00022758049241210934\n","Loss value at Vcycle number 3000 : 0.0007835066644474864\n","Error value at Vcycle number 3000 : 0.00023898419289962688\n"]}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":298},"id":"dIoZTMQ5ZCwQ","executionInfo":{"status":"ok","timestamp":1633425987282,"user_tz":-120,"elapsed":1397,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"a645b810-1f14-497d-b601-cef41f5e33e7"},"source":["plt.title('Loss function')\n","plt.semilogy(losses_total,color='red',label = 'MPINN',linestyle='dashed')\n","plt.legend()"],"execution_count":8,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7f1e22e7e8d0>"]},"metadata":{},"execution_count":8},{"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":1633425987284,"user_tz":-120,"elapsed":8,"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(1,nh) \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=150, gamma=0.9)\n","\n","mynet_one2 = PINN(1,nh+nH) \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=150, gamma=0.9)"],"execution_count":9,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"LOTlP9r2q_tm","scrolled":false,"executionInfo":{"status":"ok","timestamp":1633426072634,"user_tz":-120,"elapsed":85355,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"41067efb-4e75-4576-da14-b5d8b6eaf095"},"source":["\n","epoc,_,_,pinn_loss_total,error_train = train_one(mynet_one,optimizer_one,scheduler,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,15000,tol)\n"],"execution_count":10,"outputs":[{"output_type":"stream","name":"stdout","text":["Total loss = 91.782127 error = 4.385521 in epoch : 1000\n","Total loss = 12.823898 error = 1.224278 in epoch : 2000\n","Total loss = 0.434647 error = 0.258774 in epoch : 3000\n","Total loss = 0.084780 error = 0.111127 in epoch : 4000\n","Total loss = 0.024837 error = 0.059374 in epoch : 5000\n","Total loss = 0.009416 error = 0.036463 in epoch : 6000\n","Total loss = 0.004334 error = 0.024816 in epoch : 7000\n","Total loss = 0.002310 error = 0.018249 in epoch : 8000\n","Total loss = 0.001386 error = 0.014279 in epoch : 9000\n","Total loss = 0.000915 error = 0.011750 in epoch : 10000\n","Total loss = 0.000653 error = 0.010068 in epoch : 11000\n","Total loss = 0.000496 error = 0.008906 in epoch : 12000\n","Total loss = 0.000398 error = 0.008100 in epoch : 13000\n","Total loss = 0.000334 error = 0.007521 in epoch : 14000\n","Total loss = 0.000290 error = 0.007087 in epoch : 15000\n"]}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"_SR6h7LCwzvb","executionInfo":{"status":"ok","timestamp":1633426158244,"user_tz":-120,"elapsed":85630,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"5667a0d3-7288-4adf-943e-d486cf5ece78"},"source":["epoc2,_,_,pinn_loss_total_2,error_train_2 = train_one(mynet_one2,optimizer_one2,scheduler2,tensor_x,tensor_xt,tensor_x_bc,tensor_u_bc,tensor_f,groundtruth,15000,tol)"],"execution_count":11,"outputs":[{"output_type":"stream","name":"stdout","text":["Total loss = 64.654373 error = 3.014182 in epoch : 1000\n","Total loss = 55.498360 error = 3.286618 in epoch : 2000\n","Total loss = 2.470839 error = 0.614122 in epoch : 3000\n","Total loss = 0.033262 error = 0.020909 in epoch : 4000\n","Total loss = 0.015645 error = 0.004882 in epoch : 5000\n","Total loss = 0.011303 error = 0.002800 in epoch : 6000\n","Total loss = 0.009090 error = 0.002212 in epoch : 7000\n","Total loss = 0.007676 error = 0.001993 in epoch : 8000\n","Total loss = 0.006695 error = 0.001914 in epoch : 9000\n","Total loss = 0.005985 error = 0.001884 in epoch : 10000\n","Total loss = 0.005456 error = 0.001873 in epoch : 11000\n","Total loss = 0.005054 error = 0.001870 in epoch : 12000\n","Total loss = 0.004745 error = 0.001877 in epoch : 13000\n","Total loss = 0.004504 error = 0.001877 in epoch : 14000\n","Total loss = 0.004316 error = 0.001862 in epoch : 15000\n"]}]},{"cell_type":"markdown","metadata":{"id":"jDg0LjO2tTe9"},"source":["### Plot RMSE and Loss "]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":0},"id":"476apy8ZzjN4","executionInfo":{"status":"ok","timestamp":1633426158566,"user_tz":-120,"elapsed":344,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"d098b80b-aa59-4446-93c9-0aad83e1337a"},"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":12,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7f1e22224850>"]},"metadata":{},"execution_count":12},{"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":1633426159645,"user_tz":-120,"elapsed":1084,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"d4a46c45-b3a0-4964-815f-38179d02dfa8"},"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 = 'PINN h+H')\n","plt.legend()\n","\n","print(losses_total[-1])\n","print(pinn_loss_total[-1])\n","print(pinn_loss_total_2[-1])"],"execution_count":13,"outputs":[{"output_type":"stream","name":"stdout","text":["0.0007834081188775599\n","0.00029009225545451045\n","0.004315985832363367\n"]},{"output_type":"display_data","data":{"image/png":"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PxAdHc2sWbOoX7++2/XcfffdJCYm8uCDD5aoq1OnDjfffDOvvPIKsbGxAf8OvqrwJ22NMXMreptKKRv69lvPdTVqlF7fsGHp9WW46qqrePDBB/n2229JT08vUnf99dfz6quvlrmOevXqceONNzJjxgy39ffeey89e/bklltu8TnOQAvGXTr7gRYu0wmOMq9pb5lKqWAaN24cTz75JN26dfNrPffffz+zZs0iNze3RF39+vUZNWoUs2fP9msbgRSMhP8L0EFE2ohIFHAD8El5ViAiI0Tkdbu1fymlqoaEhATuvvtuv9fTsGFDrrnmGs6ePeu2/oEHHrDV3Tp+9aUjIguwLsY2BA4DTxpjZovIMOAlIByYY4x5xpf1+9qXjkyxnj4zT9q3nyClqpstW7bQuXPnUIdR5bjbr5760vGrDd8Y4/Z+JmPMEmCJr+sNVG+ZG1M3cm6jc/1ah1JKVRW27FohUG34L690f8uUUkpVR7ZM+IFqw881JS+kKKVUdWXLhB+oM/y56+YGJiCllKoCbJnw9S4dpZQKPFsmfL0PXymlAs+WCV8ppYIhPDycxMREzj33XP7v//6P06dPA4XdG+/evRsR4R//+EfBMnfeeSdzHX34jB07lubNmxfcd3/kyBFat25dYju7d+/m3HPtd4egLRO+NukopYIhNjaWdevWsXHjRqKiopg5c2aJeRo1asTLL79Mdna223WEh4czZ86cYIcaFLZM+Nqko5QKtr59+5KcnFyiPD4+nv79+zNv3jy3y9177728+OKLbrtTcJWXl8ett95K165dGTRoUEEf/KFU4Z2nVYgcINIaNcboezSVspl7772XdevWBXSdiYmJvPTSS17Nm5uby+eff86QIUPc1v/5z39m6NChjBs3rkRdy5YtueSSS3j77bcZMWKEx21s376dBQsW8MYbbzBq1Cg+/PDDIm/bCgVbnuH7bWHh6Nk8931cKKWqn6ysLBITE0lKSqJly5aMHz/e7Xxt27alV69evPvuu27rH3nkEaZNm0Z+vtte3gFo06YNiYmJAJx//vns3r3b7/j9VTXP8F365szN14evlLIbb8/EA83Zhu+NRx99lOuuu47LLiv5fuwOHTqQmJjIBx94fmNrdHR0wXh4eLgtmnRseYbv90Vblz7TcvJyAhOUUqpaOeecc+jSpQuffvqp2/rHHnuMF154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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":0},"id":"jy_CDp9yo8c_","executionInfo":{"status":"ok","timestamp":1633426160512,"user_tz":-120,"elapsed":871,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"0a82d64b-464d-4a5d-c1d8-302a33e5717e"},"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='PINN h+H')\n","plt.legend()\n","\n","print(error[-1])\n","print(error_train[-1])\n","print(error_train_2[-1])"],"execution_count":14,"outputs":[{"output_type":"stream","name":"stdout","text":["0.00023898419289962688\n","0.007087350759538272\n","0.0018618270149769107\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":{"colab":{"base_uri":"https://localhost:8080/","height":0},"id":"qHNAXwtaq6Ts","executionInfo":{"status":"ok","timestamp":1633426161297,"user_tz":-120,"elapsed":794,"user":{"displayName":"Elisa Riccietti","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"16962102716787738338"}},"outputId":"a9cb5354-8c67-4870-b4eb-875893885b3c"},"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":15,"outputs":[{"output_type":"stream","name":"stdout","text":["15000\n","15000\n","[        0     36000     60000 ... 395928000 395952000 395976000]\n"]},{"output_type":"execute_result","data":{"text/plain":["<matplotlib.legend.Legend at 0x7f1e21e69f10>"]},"metadata":{},"execution_count":15},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"}}]}]}