{"metadata":{"kernelspec":{"language":"python","display_name":"Python 3","name":"python3"},"language_info":{"name":"python","version":"3.10.10","mimetype":"text/x-python","codemirror_mode":{"name":"ipython","version":3},"pygments_lexer":"ipython3","nbconvert_exporter":"python","file_extension":".py"}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"import numpy as np \n#import sdeint\nfrom sklearn.metrics import mean_squared_error\nimport time\n\nimport statsmodels.api as sm\nfrom torch.autograd import Variable\nimport seaborn as sns\nimport torch\n\nimport matplotlib.pyplot as plt\n\n\nimport torch\nfrom torch import nn","metadata":{"_uuid":"8f2839f25d086af736a60e9eeb907d3b93b6e0e5","_cell_guid":"b1076dfc-b9ad-4769-8c92-a6c4dae69d19","execution":{"iopub.status.busy":"2023-05-21T07:06:14.967198Z","iopub.execute_input":"2023-05-21T07:06:14.967660Z","iopub.status.idle":"2023-05-21T07:06:14.974892Z","shell.execute_reply.started":"2023-05-21T07:06:14.967623Z","shell.execute_reply":"2023-05-21T07:06:14.973678Z"},"trusted":true},"execution_count":17,"outputs":[]},{"cell_type":"code","source":"class CFG:\n   \n    d = 1\n\n    a = 0.2\n    \n    x0 = 0\n    \n    M= 1001\n    h = 0.01\n    \n    \n    N = 5\n    \n    epoch=301\n    optim = ['SGD','Adam'][1]\n    lr = 0.002\n    seed = 44\n    hidden_size =108#108\n    \n    \n    lambda1 =1\n    lambda2 =1\n    print_step = 100\n    gap = 100\n","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:15.134956Z","iopub.execute_input":"2023-05-21T07:06:15.135372Z","iopub.status.idle":"2023-05-21T07:06:15.142260Z","shell.execute_reply.started":"2023-05-21T07:06:15.135337Z","shell.execute_reply":"2023-05-21T07:06:15.141099Z"},"trusted":true},"execution_count":18,"outputs":[]},{"cell_type":"code","source":"def seed_torch(seed):\n    torch.manual_seed(seed)\n    torch.cuda.manual_seed(seed)\n    torch.backends.cudnn.deterministic = True\nseed_torch(seed = CFG.seed)\n\ndef deltaW(N, m, h, seed,generator=None):\n    if generator is None:\n        generator = np.random.default_rng(seed=seed)\n    return generator.normal(0.0, np.sqrt(h), (N, m))\n\ndef get_wt(CFG,seed=1):\n    n,h,N,d = CFG.M,CFG.h,CFG.N,CFG.d\n    ts = np.array([i*h for i in range(n)])\n    w_t_increments = np.array([deltaW(N=n-1, m=d, h=h, generator=None,seed=int(i+seed*100)) for i in range(N)])\n    w_t = np.array([np.insert(np.cumsum(i.T),0,np.zeros(1)) for i in w_t_increments])\n    return w_t,ts,w_t_increments","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:15.290000Z","iopub.execute_input":"2023-05-21T07:06:15.291228Z","iopub.status.idle":"2023-05-21T07:06:15.302747Z","shell.execute_reply.started":"2023-05-21T07:06:15.291183Z","shell.execute_reply":"2023-05-21T07:06:15.301436Z"},"trusted":true},"execution_count":19,"outputs":[]},{"cell_type":"code","source":"import torch\n\n\ndef p(x):\n    return torch.exp(-(x-1)**2/2)\n\nx = torch.linspace(-5,5,100)\ny= p(x)\n\n\ndef gradients(u, x, order=1):  \n    if order == 1:  \n        return torch.autograd.grad(u, x,grad_outputs=torch.ones_like(u),  create_graph=True,only_inputs=True,)[0]  \n    else:  \n        return gradients(gradients(u, x), x,order=order-1)\n\n\ndef f(x):\n    x= torch.tensor(x).requires_grad_(True)\n    return (1/2)*gradients(torch.log(p(x)),x).detach().numpy()\n\ndef getFL(see):\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    F=[]\n    L=[]\n    x0 = CFG.x0\n\n    xt = np.zeros((CFG.N, CFG.M))\n    xt[:,0] = CFG.x0   \n\n    for i in range(CFG.M-1):\n        \n        xt[:,i+1] = xt[:,i] + f(xt[:,i])*CFG.h + w_t_increments[:,i].reshape(-1)\n        F.append(f(xt[:,i]))\n        L.append(xt[:,i]**0)\n    \n    F.append(f(xt[:,-1]))\n    L.append(xt[:,-1]**0)\n    \n    F = np.array(F).T\n    L = np.array(L).T\n    return xt,F,L\n","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:15.470395Z","iopub.execute_input":"2023-05-21T07:06:15.471778Z","iopub.status.idle":"2023-05-21T07:06:15.485578Z","shell.execute_reply.started":"2023-05-21T07:06:15.471732Z","shell.execute_reply":"2023-05-21T07:06:15.484264Z"},"trusted":true},"execution_count":20,"outputs":[]},{"cell_type":"code","source":"w_t,ts,w_t_increments = get_wt(CFG,seed=12)\nxt,F,L = getFL(12)","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:15.626455Z","iopub.execute_input":"2023-05-21T07:06:15.627818Z","iopub.status.idle":"2023-05-21T07:06:15.989467Z","shell.execute_reply.started":"2023-05-21T07:06:15.627768Z","shell.execute_reply":"2023-05-21T07:06:15.988321Z"},"trusted":true},"execution_count":21,"outputs":[]},{"cell_type":"code","source":"sns.set_style(\"darkgrid\") \nsns.distplot(xt[:,-1]\n             ,bins=20\n             ,kde_kws={'color':'g','linestyle':'-','linewidth':3,'alpha':0.7}\n            )\n\nplt.plot(x,y*(1/np.sqrt(2*3.14159926)))","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:15.991432Z","iopub.execute_input":"2023-05-21T07:06:15.991868Z","iopub.status.idle":"2023-05-21T07:06:16.331367Z","shell.execute_reply.started":"2023-05-21T07:06:15.991827Z","shell.execute_reply":"2023-05-21T07:06:16.330206Z"},"trusted":true},"execution_count":22,"outputs":[{"name":"stderr","text":"/tmp/ipykernel_34/4157036868.py:2: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(xt[:,-1]\n","output_type":"stream"},{"execution_count":22,"output_type":"execute_result","data":{"text/plain":"[<matplotlib.lines.Line2D at 0x7a092cc78040>]"},"metadata":{}},{"output_type":"display_data","data":{"text/plain":"<Figure size 640x480 with 1 Axes>","image/png":"iVBORw0KGgoAAAANSUhEUgAAAjcAAAGdCAYAAADuR1K7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABBNklEQVR4nO3dd3yV5f3/8fd9VtbJTkgMe4a9nCBKRaTOKqJWK+KgVau2perPVW0LVUEcrVb9lqqMuqhWcOGuCxEUFcqQJRsSQgYh4yQ56/79EYiEBEhOxjm583o+HnkcznWvz32dA7xz39d934ZpmqYAAAAswhbuAgAAAJoT4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFgK4QYAAFiKI9wFhEthYana04MnDENKTY1vd/vdFPRZaOi3xqPPQkO/haat9tvBuhui3YYb01Sb+lCbS3vd76agz0JDvzUefRYa+i00Vu43TksBAABLIdwAAABLCetpqVmzZumDDz7Qli1bFB0drWHDhun2229Xjx49jrjMggULdPfdd9dqc7lcWr16dUuXCwAA2oCwhpuvv/5aV155pQYNGqRAIKDHHntMkydP1qJFixQbG3vE5dxut957772a94ZhtEa5AACgDQhruHnuuedqvZ8xY4ZGjBihtWvX6sQTTzzicoZhKD09vaXLAwAAbVBEXS1VWloqSUpMTDzqfB6PR2eccYaCwaD69++vW2+9Vb17927UttrbwZ6D+9ve9rsp6LPQ0G+NR5+Fhn4LTVvtt8bUa5hmZFwIFgwG9etf/1olJSV6+eWXjzjfihUrtH37dmVnZ6u0tFSzZ8/W8uXLtWjRImVmZrZixQAAIBJFTLj505/+pMWLF+ull15qVEjx+Xw699xzdd5552nKlCkNXq6t3byoqdrqTZvCiT4LDf3WePRZaOi30LTVfmtzN/GbNm2aPv30U73wwguNPvridDrVr18/7dixo1HLWfnmRUfTXve7Keiz0NBvjUefhYZ+C42V+y2s97kxTVPTpk3Thx9+qHnz5qlz586NXkcgENDGjRsZYAwAACSF+cjN1KlT9fbbb+vpp59WXFyc8vPzJUnx8fGKjo6WJN1xxx3KyMjQbbfdJkl68sknNXToUHXt2lUlJSV67rnnlJOTo0svvTRs+wEAACJHWMPNwYHDV111Va326dOn6+KLL5Yk5ebmymb78QBTSUmJ7rvvPuXn5ysxMVEDBgzQ/Pnz1atXr9YrHAAARKyIGVDc2goK2tZAqqYyDCktLb7d7XdT0Gehod8ajz4LDf0WmrbabwfrboiIGFAMAK3lSHc0b6e/5wGWRLgB0G74JJVV+eud5nbZ5WzdcgC0EMINgHbBMAyVVfn17fZ98voDtaa5HHYd3zVZKVEOjuAAFkC4AdCueP0BVfqC4S4DQAsK631uAAAAmhvhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWEpYw82sWbM0YcIEDRs2TCNGjNBNN92kLVu2HHO5d999V2effbYGDRqkCy64QJ999lkrVAsAANqCsIabr7/+WldeeaVeeeUVzZkzR36/X5MnT5bH4zniMt99951uu+02XXLJJXr99dd15pln6uabb9bGjRtbsXIAABCpwhpunnvuOV188cXq3bu3+vbtqxkzZignJ0dr16494jL/+te/dNppp+mXv/ylevbsqSlTpqh///564YUXWrFyAAAQqRzhLuBQpaWlkqTExMQjzrNy5Updc801tdpGjRqljz76qFHbMoxGl9emHdzf9rbfTUGfhSZS+80wpIMl1VeaofDVHKl9Funot9C01X5rTL0RE26CwaAefPBBDR8+XH369DnifAUFBUpLS6vVlpqaqoKCgkZtLzU1PqQ627r2ut9NQZ+FJhL7rWKfR+64aDn9wVrtUQ6bYmJdSk2ODVNl1SKxz9oC+i00Vu63iAk3U6dO1aZNm/TSSy+1yvYKC0tlmq2yqYhgGNVf5Pa2301Bn4UmUvvNMAxVVPpVVl6pKl/tcONz2lTh8aowGJQZhqIjtc8iHf0WmrbabwfrboiICDfTpk3Tp59+qhdeeEGZmZlHnTctLa3OUZrCwsI6R3OOxTTVpj7U5tJe97sp6LPQRGK/mYe9Hj4t3DWHe/ttFf0WGiv3W1gHFJumqWnTpunDDz/UvHnz1Llz52MuM3ToUC1btqxW25dffqmhQ4e2UJUAAKAtCWu4mTp1qt588009+uijiouLU35+vvLz81VZWVkzzx133KFHH3205v2kSZO0ePFizZ49W5s3b9bf//53rVmzRhMnTgzHLgAAgAgT1tNSL7/8siTpqquuqtU+ffp0XXzxxZKk3Nxc2Ww/ZrDhw4frkUce0d/+9jc99thj6tatm5566qmjDkIGAADtR1jDzYYNG445z/PPP1+n7ZxzztE555zTEiUBAIA2jmdLAQAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASwlruFm+fLluvPFGjRo1StnZ2froo4+OOv9XX32l7OzsOj/5+fmtVDEAAIh0jnBu3OPxKDs7WxMmTNAtt9zS4OXee+89ud3umvepqaktUR4AAGiDwhpuRo8erdGjRzd6udTUVCUkJLRARQAAoK0La7gJ1UUXXSSv16vevXvrlltu0fHHH9/odRhGCxQWwQ7ub3vb76agz0ITqf1mGNLBkuorzVD4ao7UPot0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QDsS9vvcnHvuuSoqKtITTzyh/Px89evXT88++2zNaabc3FzZbD9msOHDh+uRRx7R3/72Nz322GPq1q2bnnrqKe5xAwAAJEXAfW4AAACaU9hPSwEAADQnwg0AALAUwg0AALAUwg0AALAUwk075vV6deGFFyo7O1vr1q0LdzkRbdeuXbrnnns0ZswYDR48WGPHjtUTTzwhr9cb7tIiyosvvqgxY8Zo0KBBuvTSS7Vq1apwlxTRZs2apQkTJmjYsGEaMWKEbrrppiM+egb1++c//6ns7Gw98MAD4S4l4uXl5en222/XySefrMGDB+uCCy7Q6tWrw11WiyDctGMzZ85Uhw48y6QhtmzZItM0NW3aNC1atEh333235s+fr7/+9a/hLi1ivPPOO5o+fbpuvvlmLVy4UH379tXkyZPr3IEcP/r666915ZVX6pVXXtGcOXPk9/s1efJkeTyecJfWJqxatUrz589XdnZ2uEuJePv379cVV1whp9OpZ555RosWLdKdd96pxMTEcJfWMky0S59++ql59tlnm5s2bTL79Oljfv/99+Euqc155plnzDFjxoS7jIhxySWXmFOnTq15HwgEzFGjRpmzZs0KY1VtS2FhodmnTx/z66+/DncpEa+srMwcN26cuWTJEnPixInm/fffH+6SItrDDz9sXnHFFeEuo9Vw5KYdKigo0H333aeZM2cqOjo63OW0WaWlpdb9raeRvF6v1q5dq5EjR9a02Ww2jRw5UitWrAhjZW1LaWmpJPG9aoBp06Zp9OjRtb5zOLKPP/5YAwcO1G9/+1uNGDFCF110kV555ZVwl9ViCDftjGmauuuuu3T55Zdr0KBB4S6nzdq+fbteeOEFXX755eEuJSLs27dPgUBAqamptdpTU1PrPOgW9QsGg3rwwQc1fPhw7rh+DIsWLdL333+v2267LdyltBk7d+7Uyy+/rG7duum5557TFVdcofvvv18LFy4Md2ktIuyPX0DzeOSRR/TMM88cdZ533nlHS5YsUXl5uW644YZWqiyyNbTfevbsWfM+Ly9Pv/zlL3X22Wfrsssua+kS0U5MnTpVmzZt0ksvvRTuUiJabm6uHnjgAc2ePVtRUVHhLqfNME1TAwcO1K233ipJ6t+/vzZt2qT58+dr/PjxYa6u+RFuLOK666475he0c+fOWrZsmVauXFnnqM2ECRN0wQUX6KGHHmrJMiNOQ/vtoLy8PE2aNEnDhg3TX/7yl5Yur81ITk6W3W6vM3i4sLCw5jlxOLJp06bp008/1QsvvKDMzMxwlxPR1q5dq8LCwpqHK0tSIBDQ8uXL9eKLL2r16tWy2+1hrDAypaen1/olTZJ69Oih999/P0wVtSzCjUWkpKQoJSXlmPPde++9mjJlSs37vXv3avLkyfrrX/+qIUOGtGCFkamh/Sb9GGwGDBig6dOn13qga3vncrk0YMAALV26VGPHjpVUfZpl6dKlmjhxYpiri1ymaeovf/mLPvzwQz3//PO1gjTqd8opp+itt96q1Xb33XerR48e+tWvfkWwOYLhw4dr69attdq2bdumjh07hqmilkW4aWeysrJqvY+NjZUkdenShd8YjyIvL09XXXWVsrKydOedd6qoqKhmWnp6ehgrixzXXnut7rzzTg0cOFCDBw/WvHnzVFFRUes3bNQ2depUvf3223r66acVFxen/Px8SVJ8fDyD/Y/A7XbXGZMUGxurpKQkxiodxdVXX60rrrhC//jHP3TOOedo1apVeuWVVzRt2rRwl9YiCDdAAyxZskTbt2/X9u3bdfrpp9eatmHDhjBVFVnOPfdcFRUV6YknnlB+fr769eunZ599ltNSR/Hyyy9Lkq666qpa7dOnTycUolkNHjxYTz75pB577DE99dRT6tSpk+655x797Gc/C3dpLcIwTdMMdxEAAADNhUEDAADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUv4/7FktjVIn3WIAAAAASUVORK5CYII="},"metadata":{}}]},{"cell_type":"code","source":"class Pde_model(nn.Module):\n    def __init__(self):\n        super(Pde_model, self).__init__()\n        self.hidden_layer1 = torch.nn.Linear(2, CFG.hidden_size)\n        self.hidden_layer2 = torch.nn.Linear(CFG.hidden_size, CFG.hidden_size)\n        self.output_layer = torch.nn.Linear(CFG.hidden_size, 1)\n        self.tanh = nn.Tanh()\n    def forward(self, t,x):\n        x = torch.cat([x,t],dim=1)\n        x = self.hidden_layer1(x)\n        x = self.hidden_layer2(x)\n        x =  self.tanh(x)\n        x = self.hidden_layer2(x)\n        x = self.hidden_layer2(x)\n        x =  self.tanh(x)\n        x = self.output_layer(x)\n        return x\n\n\ndef get_optimizer(model):\n    if CFG.optim == 'SGD':\n        optimizer = torch.optim.SGD(model.parameters(), lr=CFG.lr)\n    if CFG.optim == 'Adam':\n        optimizer = torch.optim.Adam(model.parameters(), lr=CFG.lr, amsgrad = False)\n    return optimizer\n\nclass loss_pde(nn.Module):\n    def __init__(self, **kwargs):\n        super(loss_pde, self).__init__(**kwargs)\n        self.loss_list = []\n    def forward(self,t,xt_l,f,l,model,epoch):\n        loss1=0\n        loss_sum= 0 \n        for i in range(1,xt_l.shape[1]-1):\n            x= xt_l[:,i].view(CFG.N,1)\n            ti = torch.cat([t[i].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n            \n            u = model(ti,x)\n            ut = gradients(u,ti,1)\n            ux =  gradients(u,x,1)\n            uxx =  gradients(u,x,2)\n            fi = f[:,i]\n            li = l[:,i]\n            if i == 0 :\n                loss_sum = (ut+fi*ux+1/2*li**2*uxx)**2\n            else:\n                loss_sum= loss_sum+ (ut+fi*ux+1/2*li**2*uxx)**2\n                    \n        T = torch.cat([t[-1].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n        XT = xt_l[:,-1].view(CFG.N,1)\n        uT = model(T,XT)\n        loss1 = (uT - XT)**2\n       \n        \n        if epoch % 100== 0:\n            print('loss pde ',torch.mean(loss_sum).item())\n            print('loss bound',torch.mean(loss1).item())\n\n            self.loss_list.append(torch.mean(loss_sum).item()+100*torch.mean(loss1).item())\n        return 1*torch.mean(loss_sum)+1*torch.mean(loss1)\n    \n\ndef getFL(see):\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    F=[]\n    L=[]\n    x0 = CFG.x0\n\n    xt = np.zeros((CFG.N, CFG.M))\n    xt[:,0] = CFG.x0   \n\n    for i in range(CFG.M-1):\n        xt[:,i+1] = xt[:,i] + f(xt[:,i])*CFG.h + w_t_increments[:,i].reshape(-1)\n        F.append(f(xt[:,i]))\n        L.append(xt[:,i]**0)\n    F.append(f(xt[:,-1]))\n    L.append(xt[:,-1]**0)\n    F = np.array(F).T\n    L = np.array(L).T\n    return xt,F,L\n\ndef train(xt,F,L,see):\n    XT = torch.tensor(xt[:,::CFG.gap].astype(np.float32)).requires_grad_(True)#.cuda()#outputs\n    F = torch.tensor(F[:,::CFG.gap].astype(np.float32)).requires_grad_(False)#.cuda()\n    L = torch.tensor(L[:,::CFG.gap].astype(np.float32)).requires_grad_(False)#.cuda()\n    w_t,ts,w_t_increments = get_wt(CFG,seed=see)\n    w_t_increments = torch.tensor(w_t_increments.astype(np.float32)).requires_grad_(False)\n    t = torch.tensor(ts[::CFG.gap].astype(np.float32)).reshape(int((CFG.M-1)/CFG.gap)+1,1).requires_grad_(True)#[:,::CFG.gap]\n    t0 = torch.cat([t[0].view(-1) for K in range(CFG.N)],dim = 0).view(CFG.N,1)\n    par = np.array([CFG.x0 for i in range(CFG.N)])\n    par = torch.tensor(par.astype(np.float32)).reshape(CFG.N,1).requires_grad_(True)\n    model = Pde_model()\n    optimizer_list = [get_optimizer(model)]\n    loss = loss_pde()\n    ex=[]\n    for epoch in range(CFG.epoch):\n        optimizer_list[-1].zero_grad()\n        loss_2 = loss(t,XT,F,L,model,epoch)\n        loss_2.backward()\n        optimizer_list[-1].step()\n        if epoch % 100== 0:\n            EX= model(t0,par)\n            print('EX:',torch.mean((XT[:,-1])).item())\n            ex.append(EX[0].item())\n            print('Epoch:{}/{}\\t PDE_loss={:.4f}\\t EX={:.4f}\\t'.format(CFG.epoch,epoch ,loss_2.item(),EX[0].item()))\n    EX=  ex[np.argmin(np.array(loss.loss_list))]\n    return EX,torch.mean((XT[:,-1])).item()","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:16.344222Z","iopub.execute_input":"2023-05-21T07:06:16.345189Z","iopub.status.idle":"2023-05-21T07:06:16.383260Z","shell.execute_reply.started":"2023-05-21T07:06:16.345088Z","shell.execute_reply":"2023-05-21T07:06:16.381883Z"},"trusted":true},"execution_count":23,"outputs":[]},{"cell_type":"code","source":"gets = []\nmc= []\nfor i in range(50):\n\n    print('————————')\n    print(i)\n    see = i\n    xt,F,L = getFL(see)\n\n    ex,ex_mcmc = train(xt,F,L,see)\n    print(ex)\n    gets.append(ex)\n    mc.append(ex_mcmc)\n    print('————————')\n    ","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:06:16.841388Z","iopub.execute_input":"2023-05-21T07:06:16.841814Z","iopub.status.idle":"2023-05-21T07:06:25.692004Z","shell.execute_reply.started":"2023-05-21T07:06:16.841781Z","shell.execute_reply":"2023-05-21T07:06:25.690595Z"},"trusted":true},"execution_count":24,"outputs":[{"name":"stdout","text":"————————\n0\nloss pde  0.0006063146283850074\nloss bound 1.4842489957809448\nEX: 0.4072267413139343\nEpoch:301/0\t PDE_loss=1.4849\t EX=0.1180\t\nloss pde  0.10161954164505005\nloss bound 0.05333876609802246\nEX: 0.4072267413139343\nEpoch:301/100\t PDE_loss=0.1550\t EX=0.6024\t\nloss pde  0.069752998650074\nloss bound 0.010583730414509773\nEX: 0.4072267413139343\nEpoch:301/200\t PDE_loss=0.0803\t EX=0.5928\t\nloss pde  0.05139390006661415\nloss bound 0.006141742691397667\n","output_type":"stream"},{"traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)","Cell \u001b[0;32mIn[24], line 10\u001b[0m\n\u001b[1;32m      7\u001b[0m see \u001b[38;5;241m=\u001b[39m i\n\u001b[1;32m      8\u001b[0m xt,F,L \u001b[38;5;241m=\u001b[39m getFL(see)\n\u001b[0;32m---> 10\u001b[0m ex,ex_mcmc \u001b[38;5;241m=\u001b[39m \u001b[43mtrain\u001b[49m\u001b[43m(\u001b[49m\u001b[43mxt\u001b[49m\u001b[43m,\u001b[49m\u001b[43mF\u001b[49m\u001b[43m,\u001b[49m\u001b[43mL\u001b[49m\u001b[43m,\u001b[49m\u001b[43msee\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28mprint\u001b[39m(ex)\n\u001b[1;32m     12\u001b[0m gets\u001b[38;5;241m.\u001b[39mappend(ex)\n","Cell \u001b[0;32mIn[23], line 99\u001b[0m, in \u001b[0;36mtrain\u001b[0;34m(xt, F, L, see)\u001b[0m\n\u001b[1;32m     97\u001b[0m optimizer_list[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mzero_grad()\n\u001b[1;32m     98\u001b[0m loss_2 \u001b[38;5;241m=\u001b[39m loss(t,XT,F,L,model,epoch)\n\u001b[0;32m---> 99\u001b[0m \u001b[43mloss_2\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    100\u001b[0m optimizer_list[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m.\u001b[39mstep()\n\u001b[1;32m    101\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m epoch \u001b[38;5;241m%\u001b[39m \u001b[38;5;241m100\u001b[39m\u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m:\n","File \u001b[0;32m/opt/conda/lib/python3.10/site-packages/torch/_tensor.py:487\u001b[0m, in \u001b[0;36mTensor.backward\u001b[0;34m(self, gradient, retain_graph, create_graph, inputs)\u001b[0m\n\u001b[1;32m    477\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m has_torch_function_unary(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    478\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(\n\u001b[1;32m    479\u001b[0m         Tensor\u001b[38;5;241m.\u001b[39mbackward,\n\u001b[1;32m    480\u001b[0m         (\u001b[38;5;28mself\u001b[39m,),\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    485\u001b[0m         inputs\u001b[38;5;241m=\u001b[39minputs,\n\u001b[1;32m    486\u001b[0m     )\n\u001b[0;32m--> 487\u001b[0m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mautograd\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    488\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgradient\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minputs\u001b[49m\n\u001b[1;32m    489\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n","File \u001b[0;32m/opt/conda/lib/python3.10/site-packages/torch/autograd/__init__.py:200\u001b[0m, in \u001b[0;36mbackward\u001b[0;34m(tensors, grad_tensors, retain_graph, create_graph, grad_variables, inputs)\u001b[0m\n\u001b[1;32m    195\u001b[0m     retain_graph \u001b[38;5;241m=\u001b[39m create_graph\n\u001b[1;32m    197\u001b[0m \u001b[38;5;66;03m# The reason we repeat same the comment below is that\u001b[39;00m\n\u001b[1;32m    198\u001b[0m \u001b[38;5;66;03m# some Python versions print out the first line of a multi-line function\u001b[39;00m\n\u001b[1;32m    199\u001b[0m \u001b[38;5;66;03m# calls in the traceback and some print out the last line\u001b[39;00m\n\u001b[0;32m--> 200\u001b[0m \u001b[43mVariable\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_execution_engine\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrun_backward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m  \u001b[49m\u001b[38;5;66;43;03m# Calls into the C++ engine to run the backward pass\u001b[39;49;00m\n\u001b[1;32m    201\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtensors\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgrad_tensors_\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    202\u001b[0m \u001b[43m    \u001b[49m\u001b[43mallow_unreachable\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43maccumulate_grad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n","\u001b[0;31mKeyboardInterrupt\u001b[0m: "],"ename":"KeyboardInterrupt","evalue":"","output_type":"error"}]},{"cell_type":"markdown","source":"gets = [0.5040452480316162,\n 1.0006117820739746,\n 0.5194120407104492,\n 1.0608725547790527,\n 0.9536173343658447,\n 1.1669297218322754,\n 1.1237891912460327,\n 1.081183671951294,\n 1.484188199043274,\n 0.8524646759033203,\n 0.38811734318733215,\n 1.096692442893982,\n 1.0703413486480713,\n 0.6480696797370911,\n 0.9409201741218567,\n 0.8492151498794556,\n 0.9226465821266174,\n 1.0413193702697754,\n 0.8815960884094238,\n 0.9063315987586975,\n -0.3058653771877289,\n 0.8779784440994263,\n 1.112849235534668,\n 1.1847292184829712,\n -0.06060464680194855,\n 1.2826008796691895,\n 1.3401854038238525,\n 1.139715313911438,\n 0.8862456679344177,\n 1.1160441637039185,\n 0.42988818883895874,\n 0.47275060415267944,\n 0.626828134059906,\n 0.84818434715271,\n 1.1829086542129517,\n 0.6303291916847229,\n 0.5806402564048767,\n 1.2531616687774658,\n 0.7980332374572754,\n 1.1377191543579102,\n 1.0188692808151245,\n 1.04985773563385,\n 0.7419564723968506,\n 1.1550623178482056,\n 0.7451250553131104,\n 0.6719911694526672,\n 1.536141037940979,\n 1.6307704448699951,\n 0.7976316213607788,\n 1.532058596611023]","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:03:03.139491Z","iopub.execute_input":"2023-05-21T07:03:03.139921Z","iopub.status.idle":"2023-05-21T07:03:03.153850Z","shell.execute_reply.started":"2023-05-21T07:03:03.139886Z","shell.execute_reply":"2023-05-21T07:03:03.152164Z"}}},{"cell_type":"markdown","source":"mc =[0.4072267413139343,\n 0.7905125617980957,\n 0.14119596779346466,\n 0.8235048055648804,\n 0.8144673109054565,\n 1.3551297187805176,\n 1.098264455795288,\n 0.8126041293144226,\n 0.7994998693466187,\n 0.5472996830940247,\n 0.4792327880859375,\n 0.4681820869445801,\n 1.4748157262802124,\n 0.7485493421554565,\n 0.5000365376472473,\n 0.47936487197875977,\n 0.8503457307815552,\n 0.9543734788894653,\n 1.0040271282196045,\n 0.9011006355285645,\n -0.33075255155563354,\n 0.7004958391189575,\n 1.7973620891571045,\n 1.0415047407150269,\n -0.038519859313964844,\n 0.9927854537963867,\n 1.5612447261810303,\n 0.8769102096557617,\n 0.8196353912353516,\n 1.0094460248947144,\n 0.6708841919898987,\n 0.7018336653709412,\n 0.24742965400218964,\n 0.6030243039131165,\n 1.3946119546890259,\n 0.6475545763969421,\n 0.5728421211242676,\n 0.8419492840766907,\n 1.0349677801132202,\n 1.2212506532669067,\n 0.9936771392822266,\n 1.4519237279891968,\n 0.8844783902168274,\n 1.529846429824829,\n 0.45020461082458496,\n 0.49223384261131287,\n 1.1970343589782715,\n 2.162999153137207,\n 0.9228331446647644,\n 1.6541998386383057]","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:03:04.172506Z","iopub.execute_input":"2023-05-21T07:03:04.173248Z","iopub.status.idle":"2023-05-21T07:03:04.183885Z","shell.execute_reply.started":"2023-05-21T07:03:04.173202Z","shell.execute_reply":"2023-05-21T07:03:04.182663Z"}}},{"cell_type":"code","source":"sns.set_style(\"darkgrid\") \n\nsns.distplot(np.array(gets)\n             ,bins=10,label='LDM+FCM')\n\n#plt.plot(0.64)\nplt.axvline(1,c='r',ls='-.',label='Real expectations')\n\nsns.distplot(np.array(mc)\n             ,bins=10,\n             label='Langevin MCMC'\n            )\nplt.legend()\n\n#plt.savefig('mc1.png', bbox_inches='tight')","metadata":{"execution":{"iopub.status.busy":"2023-05-21T07:03:04.590189Z","iopub.execute_input":"2023-05-21T07:03:04.590598Z","iopub.status.idle":"2023-05-21T07:03:05.102920Z","shell.execute_reply.started":"2023-05-21T07:03:04.590566Z","shell.execute_reply":"2023-05-21T07:03:05.101747Z"},"trusted":true},"execution_count":15,"outputs":[{"name":"stderr","text":"/tmp/ipykernel_34/137145157.py:3: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(np.array(gets)\n/tmp/ipykernel_34/137145157.py:9: UserWarning: \n\n`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n\nPlease adapt your code to use either `displot` (a figure-level function with\nsimilar flexibility) or `histplot` (an axes-level function for histograms).\n\nFor a guide to updating your code to use the new functions, please see\nhttps://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n\n  sns.distplot(np.array(mc)\n","output_type":"stream"},{"execution_count":15,"output_type":"execute_result","data":{"text/plain":"<matplotlib.legend.Legend at 0x7a092cdae1a0>"},"metadata":{}},{"output_type":"display_data","data":{"text/plain":"<Figure size 640x480 with 1 Axes>","image/png":"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ys1StHVlKA0VaOvLURrLnd9r7M0oOFCaK6G5ssdhqBo9qlYPih60BlRFAa2BppQXsRjneiDRH7hTR/m0uKmpqcFut7c7/BQREcG3337b4TqVlZVERka2a19Z6V4nhYeHuBesK9vK+LvHttkVLTD89mOyV/bYlidfOwiGoWNbv6M3P/w49I7n0fel9uLeOmcYnuhy2yA885p0leudr4snjR/Z+blzPdVV3Hft26f+F4CUbmy7K66+pzz9mv94v73Zn3cyjHD9veyN/QYDD91+9Ia+fveolt/NITB8hNf2qaHjW+l48n+J7uhrk29CCCGEED3i0+ImLCwMrVZLVVXb66tUVVW1m51pFRkZ2W6Wpqv2QgghhLi3+LS4MRgMJCQkUFBQ4FzmcDgoKCggJaXjCePk5GQKCwvbLDt27BjJycm9GaoQQggh+gmfH5ZavHgxeXl55OfnU1paypo1azCbzTz++OMArFq1itzcXGf7jIwMjhw5wtatWyktLWXDhg0UFRWxcOFCX6UghBBCiD7E5x8Fnz17NtXV1axfvx6TycT48ePZsmWL8zBTRUUFivJDDZaamkpOTg7vvvsu77zzDqNHj2bjxo33xjVuhBBCCHFXGlXtMx9sE0IIIYToMZ8flhJCCCGE8CQpboQQQggxoEhxI4QQQogBRYobIYQQQgwoUty44YMPPmDBggUkJSUxebJrNz5QVZX33nuPtLQ0Jk6cyKJFi7h8+XLvBuohN2/eZOXKlaSmpjJ58mR+//vf09jY2OU6zz77LEajsc3jtdde81LE7tm1axc/+9nPSExMZP78+Zw5c6bL9vv27SM9PZ3ExER++ctf8vnnn3spUs9wJ989e/a068fERN9car87vvjiC37zm9+QlpaG0Wh06d5zx48fZ+7cuUyYMIGf//zn7NmzxwuReoa7+R4/frxd/xqNRkwmk5ci7r5NmzbxxBNPkJKSwrRp01i2bFmnt+v5sf46fruTb38fv54gxY0brFYr6enpPP300y6vs3nzZj766CPWrFlDXl4eAQEBZGZmcuvWrV6M1DNefvllLl68yLZt2/jzn//Ml19+6VKh8uSTT3L06FHnY9WqVV6I1j179+4lOzub5cuXk5+fz7hx48jMzGx3texWJ0+eZOXKlcybN49//vOfPPTQQyxfvpySkhIvR9497uYLEBwc3KYf//Of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"},"metadata":{}}]},{"cell_type":"code","source":"","metadata":{},"execution_count":null,"outputs":[]}]}