PINN解偏微分方程实例4

2024-06-24 00:52

本文主要是介绍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()

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

这篇关于PINN解偏微分方程实例4的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088743

相关文章

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Spring 中使用反射创建 Bean 实例的几种方式

《Spring中使用反射创建Bean实例的几种方式》文章介绍了在Spring框架中如何使用反射来创建Bean实例,包括使用Class.newInstance()、Constructor.newI... 目录1. 使用 Class.newInstance() (仅限无参构造函数):2. 使用 Construc

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例