PINN解偏微分方程实例4

PINN解偏微分方程实例4

  • 一、正问题
    • 1. Diffusion equation
    • 2. Burgers’ equation
    • 3. Allen–Cahn equation
    • 4. Wave equation
  • 二、反问题
    • 1. Burgers’ equation
    • 3. 部分代码示例

  本文使用 PINN解偏微分方程实例1中展示的代码求解了以四个具体的偏微分方程,包括Diffusion,Burgers, Allen–Cahn和Wave方程,另外重新写了一个求解反问题的代码,以burger方程为例。

一、正问题

1. Diffusion equation

一维扩散方程:
∂ u ∂ t = ∂ 2 u ∂ x 2 + e − t ( − sin ⁡ ( π x ) + π 2 sin ⁡ ( π x ) ) , x ∈ [ − 1 , 1 ] , t ∈ [ 0 , 1 ] u ( x , 0 ) = sin ⁡ ( π x ) u ( − 1 , t ) = u ( 1 , t ) = 0 \begin{array}{l} \frac{\partial u}{\partial t}=\frac{\partial^{2} u}{\partial x^{2}}+e^{-t}\left(-\sin (\pi x)+\pi^{2} \sin (\pi x)\right), \quad x \in[-1,1], t \in[0,1] \\ u(x, 0)=\sin (\pi x) \\ u(-1, t)=u(1, t)=0 \end{array} tu=x22u+et(sin(πx)+π2sin(πx)),x[1,1],t[0,1]u(x,0)=sin(πx)u(1,t)=u(1,t)=0
其中 u u u 是扩散物质的浓度。精确解是 u ( x , t ) = s i n ( π x ) e − t u(x,t)=sin(\pi x)e^{-t} u(x,t)=sin(πx)et 表示。

请添加图片描述

2. Burgers’ equation

Burgers方程的定义为:
∂ u ∂ t + u ∂ u ∂ x = v ∂ 2 u ∂ x 2 , x ∈ [ − 1 , 1 ] , t ∈ [ 0 , 1 ] , u ( x , 0 ) = − sin ⁡ ( π x ) , u ( − 1 , t ) = u ( 1 , t ) = 0 , \begin{array}{l} \frac{\partial u}{\partial t}+u \frac{\partial u}{\partial x}=v \frac{\partial^{2} u}{\partial x^{2}}, \quad x \in[-1,1], t \in[0,1], \\ u(x, 0)=-\sin (\pi x), \\ u(-1, t)=u(1, t)=0, \end{array} tu+uxu=vx22u,x[1,1],t[0,1],u(x,0)=sin(πx),u(1,t)=u(1,t)=0,
其中, u u u 为流速, ν ν ν 为流体的粘度。在本文中, ν ν ν 设为 0.01 / π 0.01/\pi 0.01/π
请添加图片描述

3. Allen–Cahn equation

Allen–Cahn方程的形式如下:
∂ u ∂ t = D ∂ 2 u ∂ x 2 + 5 ( u − u 3 ) , x ∈ [ − 1 , 1 ] , t ∈ [ 0 , 1 ] , u ( x , 0 ) = x 2 cos ⁡ ( π x ) , u ( − 1 , t ) = u ( 1 , t ) = − 1 , \begin{array}{l} \frac{\partial u}{\partial t}=D \frac{\partial^{2} u}{\partial x^{2}}+5\left(u-u^{3}\right), \quad x \in[-1,1], t \in[0,1], \\ u(x, 0)=x^{2} \cos (\pi x), \\ u(-1, t)=u(1, t)=-1, \end{array} tu=Dx22u+5(uu3),x[1,1],t[0,1],u(x,0)=x2cos(πx),u(1,t)=u(1,t)=1,
其中,扩散系数 D = 0.001 D=0.001 D=0.001 .

请添加图片描述

4. Wave equation

一维波动方程如下:
∂ 2 u ∂ t 2 − 4 ∂ 2 u ∂ x 2 = 0 , x ∈ [ 0 , 1 ] , t ∈ [ 0 , 1 ] , u ( 0 , t ) = u ( 1 , t ) = 0 , t ∈ [ 0 , 1 ] , u ( x , 0 ) = sin ⁡ ( π x ) + 1 2 sin ⁡ ( 4 π x ) , x ∈ [ 0 , 1 ] , ∂ u ∂ t ( x , 0 ) = 0 , x ∈ [ 0 , 1 ] , \begin{array}{l} \frac{\partial^{2} u}{\partial t^{2}}-4 \frac{\partial^{2} u}{\partial x^{2}}=0, \quad x \in[0,1], t \in[0,1], \\ u(0, t)=u(1, t)=0, \quad t \in[0,1], \\ u(x, 0)=\sin (\pi x)+\frac{1}{2} \sin (4 \pi x), \quad x \in[0,1], \\ \frac{\partial u}{\partial t}(x, 0)=0, \quad x \in[0,1], \end{array} t22u4x22u=0,x[0,1],t[0,1],u(0,t)=u(1,t)=0,t[0,1],u(x,0)=sin(πx)+21sin(4πx),x[0,1],tu(x,0)=0,x[0,1],
精确解为:
u ( x , t ) = sin ⁡ ( π x ) cos ⁡ ( 2 π t ) + 1 2 sin ⁡ ( 4 π x ) cos ⁡ ( 8 π t ) . u(x, t)=\sin (\pi x) \cos (2 \pi t)+\frac{1}{2} \sin (4 \pi x) \cos (8 \pi t) . u(x,t)=sin(πx)cos(2πt)+21sin(4πx)cos(8πt).

二、反问题

1. Burgers’ equation

Burgers方程的定义为:
∂ u ∂ t + u ∂ u ∂ x = v ∂ 2 u ∂ x 2 , x ∈ [ − 1 , 1 ] , t ∈ [ 0 , 1 ] , u ( x , 0 ) = − sin ⁡ ( π x ) , u ( − 1 , t ) = u ( 1 , t ) = 0 , \begin{array}{l} \frac{\partial u}{\partial t}+u \frac{\partial u}{\partial x}=v \frac{\partial^{2} u}{\partial x^{2}}, \quad x \in[-1,1], t \in[0,1], \\ u(x, 0)=-\sin (\pi x), \\ u(-1, t)=u(1, t)=0, \end{array} tu+uxu=vx22u,x[1,1],t[0,1],u(x,0)=sin(πx),u(1,t)=u(1,t)=0,
其中, u u u 为流速, ν ν ν 为流体的粘度。
  这里假设 v v v 未知,我们同时求解方程的解和v的值。

在这里插入图片描述

3. 部分代码示例

import torch
import numpy as np
import matplotlib.pyplot as pltsin = torch.sin
cos = torch.cos
exp = torch.exp
pi = torch.piepochs = 50000    # 训练代数,要为1000的整数倍
h = 100    # 画图网格密度
N = 30    # 内点配置点数
N1 = 10    # 边界点配置点数
N2 = 5000    # 数据点# error
L2_error = []
L2_error_data = []
L2_error_eq = []
# Training
u = MLP()
opt = torch.optim.Adam(params=u.parameters())
xt, u_real = test_data(x_inf=-1, x_sup=1, t_inf=0, t_sup=1, h=h)
print("**************** equation+data ********************")
for i in range(epochs):opt.zero_grad()l = l_interior(u) \+ l_down(u) \+ l_left(u) \+ l_right(u) \+ l_data(u)l.backward()opt.step()if (i+1) % 1000 == 0 or i == 0:u_pred = u(xt)error = l2_relative_error(u_real, u_pred.detach().numpy())L2_error.append(error)print("L2相对误差: ", error)u1 = MLP()
opt = torch.optim.Adam(params=u1.parameters())
print("**************** data ********************")
for i in range(epochs):opt.zero_grad()l = l_data(u1)l.backward()opt.step()if (i+1) % 1000 == 0 or i == 0:u_pred = u1(xt)error = l2_relative_error(u_real, u_pred.detach().numpy())L2_error_data.append(error)print("L2相对误差: ", error)u2 = MLP()
opt = torch.optim.Adam(params=u2.parameters())
print("**************** equation ********************")
for i in range(epochs):opt.zero_grad()l = l_interior(u2) \+ l_down(u2) \+ l_left(u2) \+ l_right(u2)l.backward()opt.step()if (i+1) % 1000 == 0 or i == 0:u_pred = u2(xt)error = l2_relative_error(u_real, u_pred.detach().numpy())L2_error_eq.append(error)print("L2相对误差: ", error)print("********************************")
print("PINN相对误差为: ", L2_error[-1])
print("equation相对误差为: ", L2_error_eq[-1])
print("data相对误差为: ", L2_error_data[-1])
print("********************************")x = range(int(epochs / 1000 + 1))
plt.plot(x, L2_error, c='red', label='pinn')
plt.plot(x, L2_error_data, c='blue', label='only data')
plt.plot(x, L2_error_eq, c='yellow', label='only equation')
plt.scatter(x, L2_error, c='red')
plt.scatter(x, L2_error_data, c='blue')
plt.scatter(x, L2_error_eq, c='yellow')
plt.yscale('log')
plt.legend()
plt.show()

完整代码目录如下:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/32898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第T2周:彩色图片分类

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 👉 要求: 学习如何编写一个完整的深度学习程序了解分类彩色图片会灰度图片有什么区别测试集accuracy到达72% 🦾我的环境&am…

测试测量-DMM直流精度

测试测量-DMM直流精度 最近去面试,发现了自己许多不足,比如我从未考虑过万用表准或者不准,或者万用表有多准? 在过去的实验室中,常用的DMM有KEYSIGHT 34401A以及 KEITHLEY THD2015,就以这两台为例&#x…

Leetcode 3195. Find the Minimum Area to Cover All Ones I

Leetcode 3195. Find the Minimum Area to Cover All Ones I 1. 解题思路2. 代码实现 题目链接:3195. Find the Minimum Area to Cover All Ones I 1. 解题思路 这一题还是挺简单的,只要找到所有1所在的元素的上下左右4个边界,作为目标矩形…

线程C++

#include <thread> #include <chrono> #include <cmath> #include <mutex> #include <iostream> using namespace std;mutex mtx; void threadCommunicat() {int ans 0;while (ans<3){mtx.lock();//上锁cout << "ans" <…

预制直埋聚氨酯保温管

&#x1f600;宝子们&#xff0c;今天来给大家介绍一下预制聚氨酯直埋保温管&#x1f389;&#xff01; 它可是个好东西&#x1f44d;&#xff0c;具有超强的保温性能&#x1f9ca;&#xff0c;能够有效保持管道内的温度&#x1f60e;。 而且它还很耐用&#x1f4aa;&#xff0…

解析Java中1000个常用类:AbstractSet类,你学会了吗?

推荐一个我自己写的小报童专栏导航网站: http://xbt100.top 收录了生财有术项目精选、AI海外赚钱、纯银的产品分析等专栏,陆续会收录更多的专栏,欢迎体验~复制URL可直达。 以下是正文。 在 Java 集合框架中,AbstractSet 是一个重要的抽象类,为实现自定义的集合(Set)提…

【Python】处理 scikit-learn 中的 SettingWithCopyWarning

那年夏天我和你躲在 这一大片宁静的海 直到后来我们都还在 对这个世界充满期待 今年冬天你已经不在 我的心空出了一块 很高兴遇见你 让我终究明白 回忆比真实精彩 &#x1f3b5; 王心凌《那年夏天宁静的海》 这不是一个错误&#xff0c;而是一个 SettingW…

用 idea 启动多个实例

在学习负载均衡的时候&#xff0c;要模拟多个实例均提供一个服务&#xff0c;我们要如何用 idea 启动多个实例呢&#xff1f; 如下图&#xff0c;我们已经启动了一个 ProductService 服务&#xff0c;现在想再启动两个相同的服务 1. 选中要启动的服务,右键选择 Copy Configura…

用Java获取键盘输入数的个十百位数

这段Java代码是一个简单的程序&#xff0c;用于接收用户输入的一个三位数&#xff0c;并将其分解为个位、十位和百位数字&#xff0c;然后分别打印出来。下面是代码的详细解释&#xff1a; 导入所需类库: import java.util.Scanner;&#xff1a;导入Scanner类&#xff0c;用于从…

opencv学习笔记(3)

绘制直线 line(img, 开始点&#xff0c;结束点&#xff0c;颜色&#xff0c;线宽&#xff0c;线型(默认为8)) import cv2 import numpy as npimg np.zeros((640, 480, 3), np.uint8)#画线&#xff0c;坐标点为(x, y) cv2.line(img, (10, 20), (10, 220), (0, 0, 255), 5, 4)…

【经典算法】LeetCode 22括号生成(Java/C/Python3/Go实现含注释说明,中等)

作者主页&#xff1a; &#x1f517;进朱者赤的博客 精选专栏&#xff1a;&#x1f517;经典算法 作者简介&#xff1a;阿里非典型程序员一枚 &#xff0c;记录在大厂的打怪升级之路。 一起学习Java、大数据、数据结构算法&#xff08;公众号同名&#xff09; ❤️觉得文章还…

urllib3版本与系统openssl版本不兼容

urllib3版本与系统openssl版本不兼容 报错信息 ImportError: urllib3 v2.0 only supports OpenSSL 1.1.1, currently the ssl 解决办法 安装urllib3的1.x.xx版本&#xff0c;如&#xff1a; pip install urllib31.25.11

UsersGUI.java用户界面

完成效果图&#xff1a; 点击阅读按钮&#xff1a; 点击删除按钮&#xff1a; 点击新建按钮&#xff1a; Code /* This GUI application allows users to manage their diaries: ​ Read: Users can read existing diaries. Create: Users can create new diaries. Delete: Us…

ARC学习(3)基本编程模型认识(三)

笔者来介绍arc的编程模型的中断流程和异常流程 1、中断介绍 主要介绍一下中断进入的流程&#xff0c;包括需要配置的寄存器等信息。 中断号&#xff1a;16-255&#xff0c;总共240个中断。触发类型&#xff1a;脉冲或者电平触发中断优先级&#xff1a;16个&#xff0c;0最大&…

【git1】指令,commit,免密

文章目录 1.常用指令&#xff1a;git branch查看本地分支&#xff0c; -r查看远程分支&#xff0c; -a查看本地和远程&#xff0c;-v查看各分支最后一次提交, -D删除分支2.commit规范&#xff1a;git commit进入vi界面&#xff08;进入前要git config core.editor vim设一下vi模…

DVWA-XSS(Stored)-httponly分析

拿DVWA的XSS为例子 httponly是微软对cookie做的扩展。这个主要是解决用户的cookie可能被盗用的问题。 接DVWA的分析&#xff0c;发现其实Impossible的cookie都是设置的httponly1&#xff0c;samesite1. 这两个参数的意思参考Set-Cookie HttpOnly:阻止 JavaScript 通过 Documen…

Java项目:基于SSM框架实现的精品酒销售管理系统分前后台【ssm+B/S架构+源码+数据库+毕业论文】

一、项目简介 本项目是一套基于SSM框架实现的精品酒销售管理系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面美观、操作简单、功…

文本三剑客—sed命令

sed命令 一、概念 sed是一种流编辑器&#xff0c;一次处理一行内容。 处理方式&#xff1a;一行一行处理&#xff0c;处理完当前行&#xff0c;才会处理下一行&#xff0c;直到文件末尾。 如果只是展示&#xff0c;会放在缓冲区&#xff08;模式空间&#xff09;&#xff0…

微信公众号 H5授权登录实现(最详细)

一、微信公众号 &#xff08;一&#xff09;基础信息 微信授权类型 自己的网站、APP等第三方&#xff0c;要实现接入微信授权登录&#xff0c;有多种方式&#xff1a;微信公众号&#xff08;网页&#xff09;、微信小程序、微信开放平台&#xff08;APP&#xff09;等等。 【…

面试:关于word2vec的相关知识点Hierarchical Softmax和NegativeSampling

1、为什么需要Hierarchical Softmax和Negative Sampling 从输入层到隐含层需要一个维度为NK的权重矩阵&#xff0c;从隐含层到输出层又需要一个维度为KN的权重矩阵&#xff0c;学习权重可以用反向传播算法实现&#xff0c;每次迭代时将权重沿梯度更优的方向进行一小步更新。但…