基于Python实现的有限元方程求解程序附源码

news2025/1/11 14:54:20

问题描述

根据已知下列非齐次两点边值问题(1.2.28)

{ L u = − d d x ( p d u   d x ) + q u = f , a < x < b , u ( a ) = α , u ′ ( b ) = β , \begin{cases} \boldsymbol{L} u=-\frac{\mathrm{d}}{\mathrm{d} x}\left(p \frac{\mathrm{d} u}{\mathrm{~d} x}\right)+q u=f, a < x < b, \\ u(a)=\alpha, u^{\prime}(b)=\beta, \end{cases} {Lu=dxd(p dxdu)+qu=f,a<x<b,u(a)=α,u(b)=β,

与下列变分问题等价:求𝑢 ∈ 𝐻^1, 𝑢(𝑎) = 𝛼,使

J ( u ∗ ) = min ⁡ u ∈ H 1 u ( a ) = α J ( u ) J(u_{*})=\min\limits_{u \in H^1 \atop u(a) = \alpha} J(u) J(u)=u(a)=αuH1minJ(u)
其中
J ( u ) = 1 2 a ( u , u ) − ( f , u ) − p ( b ) β u ( b ) \begin{array}{c} J(u)=\frac{1}{2} a(u, u)-(f, u)-p(b) \beta u(b) \end{array} J(u)=21a(u,u)(f,u)p(b)βu(b)
a ( u , v ) = ∫ a b ( p d u d x d v d x + q u v ) d x , ( g , u ) = ∫ a b g u d x . a(u, v)=\int_{a}^{b}\left(p \frac{d u}{d x} \frac{d v}{d x}+q u v\right) d x,\quad(g, u)=\int_{a}^{b} g u d x . \\ a(u,v)=ab(pdxdudxdv+quv)dx,(g,u)=abgudx.
设 [ a , b ] = [ − 1 , 1 ] , p ( x ) ≡ − ( π 2 − 1 ) − 1 , q ( x ) ≡ 1 , α = 0 , β = − π e , 以及 \text{设} [a, b]=[-1,1], p(x) \equiv-\left(\pi^{2}-1\right)^{-1}, q(x) \equiv 1, \alpha=0, \beta=-\pi e , \text{以及} \\ [a,b]=[1,1],p(x)(π21)1,q(x)1,α=0,β=πe,以及
f ( x ) = 2 π π 2 − 1 ⋅ cos ⁡ ( π x ) ⋅ e x f(x)=\frac{2 \pi}{\pi^{2}-1} \cdot \cos (\pi x) \cdot e^{x} f(x)=π212πcos(πx)ex

任务1:请认真阅读并完成以下子任务

  • 分别取 h = 0.20 , 0.10 , 0.05 , 0.02 ℎ = 0.20, 0.10, 0.05, 0.02 h=0.20,0.10,0.05,0.02 时, 将求解域
  • 分别使用高斯消去法雅可比迭代法(迭代 30 次),求解上述有限元方程
  • 计算得到有限元解绘制有限元解 的函数图像.

任务2:已知 u ( x ) = sin ⁡ ( π x ) ⋅ e x u(x)=\sin(\pi x) \cdot e^x u(x)=sin(πx)ex 是上述边值问题的解析解,针对不同的步长 h h h 线性方程组解法得到的数值解 u h u_h uh ,绘制误差函数 ( u h − u ) (u_h − u) (uhu) 的函数图像,且进行观察分析。

任务1

划分求解域

[ a , b ] = [ − 1 , 1 ] , h = 0.2 , 0.1 , 0.05 , 0.02 , n = 10 , 20 , 40 , 100 [a, b] = [-1, 1], h = 0.2, 0.1, 0.05, 0.02, n = 10, 20, 40, 100 [a,b]=[1,1],h=0.2,0.1,0.05,0.02,n=10,20,40,100

  • h = 0.2 , n = 10 , x = [ − 1 , − 0.8 , ⋯   , 0.8 , 1 ] h = 0.2, \quad n = 10,\quad x=[-1, -0.8, \cdots, 0.8, 1] h=0.2,n=10,x=[1,0.8,,0.8,1]

  • h = 0.1 , n = 20 , x = [ − 1 , − 0.9 , ⋯   , 0.9 , 1 ] h = 0.1, \quad n = 20, \quad x=[-1, -0.9, \cdots, 0.9, 1] h=0.1,n=20,x=[1,0.9,,0.9,1]

  • h = 0.05 , n = 40 , x = [ − 1 , − 0.95 , ⋯   , 0.95 , 1 ] h = 0.05, \quad n = 40, \quad x=[-1, -0.95, \cdots, 0.95, 1] h=0.05,n=40,x=[1,0.95,,0.95,1]

  • h = 0.02 , n = 100 , x = [ − 1 , − 0.98 , ⋯   , 0.98 , 1 ] h = 0.02,\quad n = 100, \quad x=[-1, -0.98, \cdots, 0.98, 1] h=0.02,n=100,x=[1,0.98,,0.98,1]

    分析并构建Ritz-Galerkin方程

  • 基函数构造,设计 φ 0 ( x ) \varphi_0(x) φ0(x)

φ i ( x ) = { 1 + x − x i h i , x i − 1 ≤ x ≤ x i 1 − x − x i h i + 1 , x i ≤ x ≤ x i + 1 0 , otherwise \varphi_i(x) = \begin{cases} 1+\frac{x-x_i}{h_i}, x_{i-1} \leq x \leq x_i \\ 1-\frac{x-x_i}{h_{i+1}}, x_i \leq x \leq x_{i + 1} \\ 0, \text{otherwise} \\ \end{cases} φi(x)= 1+hixxi,xi1xxi1hi+1xxi,xixxi+10,otherwise

  • 左边值条件齐次: u ( a ) = α = 0 u(a)=\alpha=0 u(a)=α=0 ,右边值条件非齐次: u ′ ( b ) = β u'(b)=\beta u(b)=β
  • 则增加基函数:

φ 0 ( x ) = { 1 − x − x 0 h 1 , x 0 ≤ x ≤ x 1 0 , otherwise \varphi_0(x) = \begin{cases} 1-\frac{x-x_0}{h_1}, x_0 \leq x \leq x_1\\ 0, \text{otherwise} \\ \end{cases} φ0(x)={1h1xx0,x0xx10,otherwise

  • 满足 u ∈ H 1 , u ( a ) = α u\in H^1, u(a)=\alpha uH1,u(a)=α 的试探函数可以写成:

u h ( x ) = ∑ i = 0 n σ i φ i ( x ) = α φ 0 ( x ) + ∑ i = 1 n σ i φ i ( x ) = ∑ i = 1 n σ i φ i ( x ) , ( σ 0 = α ) u_h(x)= \sum_{i=0}^n \sigma_i \varphi_i(x) = \alpha \varphi_0 (x) + \sum_{i=1}^{n} \sigma_i \varphi_i(x)=\sum_{i=1}^{n} \sigma_i \varphi_i(x), \quad(\sigma_0 = \alpha) uh(x)=i=0nσiφi(x)=αφ0(x)+i=1nσiφi(x)=i=1nσiφi(x),(σ0=α)

  • 于是:

J ( u h ) = 1 2 a ( u h , u h ) − ( f , u h ) − p ( b ) β ( b ) u h ( b ) = ∑ i = 1 n ∑ j = 1 n σ i σ j a ( φ i ( x ) , φ j ( x ) ) 2 − ∑ i = 1 n σ i ( f , φ i ( x ) ) − ∑ i = 1 n σ i p ( b ) β φ i ( b ) \begin{aligned} J(u_h)=&\frac{1}{2} a(u_h, u_h) - (f, u_h) -p(b)\beta(b) u_h(b)\\ =&\sum_{i=1}^n \sum_{j=1}^n \sigma_i \sigma_j \frac{a(\varphi_i(x), \varphi_j(x))}{2} -\sum_{i=1}^n \sigma_i (f, \varphi_i(x)) - \sum_{i=1}^n \sigma_i p(b) \beta \varphi_i(b) \\ \end{aligned} J(uh)==21a(uh,uh)(f,uh)p(b)β(b)uh(b)i=1nj=1nσiσj2a(φi(x),φj(x))i=1nσi(f,φi(x))i=1nσip(b)βφi(b)

  • Ritz-Galerkin方程:

∂ J ( u h ) ∂ σ i = ∑ i = 1 n σ i a ( φ i , φ j ) − ( f , φ j ) − p ( b ) β φ j ( b ) = 0 , j = 1 , 2 , ⋯   , n ⇒ ∑ i = 1 n σ i a ( φ i , φ j ) = ( f , φ j ) + p ( b ) β φ j ( b ) , j = 1 , 2 , ⋯   , n \begin{aligned} &\frac{\partial J(u_h)}{\partial \sigma_i}=\sum_{i=1}^n \sigma_i a(\varphi_i, \varphi_j)-(f, \varphi_j)-p(b) \beta \varphi_j(b)=0, \quad j=1, 2, \cdots, n \\ &\Rightarrow \sum_{i=1}^n \sigma_i a(\varphi_i, \varphi_j)=(f, \varphi_j)+p(b) \beta \varphi_j(b), \quad j=1, 2, \cdots, n \\ \end{aligned} σiJ(uh)=i=1nσia(φi,φj)(f,φj)p(b)βφj(b)=0,j=1,2,,ni=1nσia(φi,φj)=(f,φj)+p(b)βφj(b),j=1,2,,n

  • 编程构建Ritz-Galerkin方程并求解,核心代码: femsolver.py

有限元解的函数图像

  • 高斯消去法求解结果

    • 在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
  • 雅可比迭代法求解结果

    • 在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述

任务2:绘制误差函数图像

  • 高斯消去法求解结果
    -在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 雅可比迭代法求解结果
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

结果分析

  • 从高斯消去法求解的结果来看, u h u_h uh函数近似估计精确解的效果很好,节点处的数值解与精确解的值几乎是重合的,而且随着h的减小误差也不断减少,当h=0.01时,误差的尺度为1e-5至1e-4,基本可以忽略不计。
  • 从雅可比迭代法求解的结果来看, u h u_h uh函数近似估计精确解的效果不太好,节点处的数值解与精确解的值之间误差较大,而且随着h的减少,误差下降到一定程度(1e-2至1e-1)后不再下降。经过程序检验发现造成雅可比迭代不收敛的原因在于对有限元方程构建的总刚度矩阵是一个非对角占优矩阵,即不满足雅可比迭代的收敛要求,所以通过雅可比迭代法求解线性方程组 K U = F KU=F KU=F 无法得到收敛的数值解。

程序源码

https://download.csdn.net/download/DeepLearning_/88201562

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

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

相关文章

markdown命令模板

markdown快速入门(typora) 1、代码块 //代码块语 public static void main(String[] args){}//linux下spring项目的启动命令 # java -jar blog start ## 2、标题&#xff1a;java # 一级标题 ## 二级标题 ### 三级标题 #### 四级标题 ##### 五级标题 ###### 六级标题3、字体 …

STM32 LL库+STM32CubeMX--点亮板载LED

一、前期准备 硬件&#xff1a;STM32F103C8T6开发板调试工具&#xff1a;DAPLink(本次使用)或USB-TTL开发环境&#xff1a;STM32CubeMX、Keil、Vscode(可选)板载LED&#xff1a;PC13(低电平点亮) 二、STM32CubeMX配置 1.选择芯片型号&#xff1a; 2.配置外设时钟&#xff1a…

步入React正殿 - 事件处理

目录 扩展学习资料 React事件和DOM事件 和传统DOM事件处理异同 this关键字的处理 this关键字 在JSX中使用bind方法 在构造函数中使用bind方法 使用箭头函数【推荐】 向事件处理程序传递参数【不跨组件】 向父组件传递参数 /src/App.js /src/components/listItem.jsx…

【MySQL--->数据库基础】

文章目录 [TOC](文章目录) 一、基本概念二、实际应用中的数据库三、mysql的架构四、mysql语句分类五、存储引擎查看 一、基本概念 mysql本质是一个CS模式的网络服务,mysql是客户端,mysqld是服务端,提供高效的数据存取方案.数据库系统简单来说是一个数据集合加上管理这个数据集…

Java旋转数组中的最小数字(图文详解版)

目录 1.题目描述 2.题解 分析 具体实现 方法一&#xff08;遍历&#xff09;&#xff1a; 方法二&#xff08;排序&#xff09;&#xff1a; 方法三&#xff08;二分查找&#xff09;&#xff1a; 1.题目描述 有一个长度为 n 的非降序数组&#xff0c;比如[1,2,3,4,5]&a…

【LeetCode 75】第二十六题(394)字符串解码

目录 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 代码运行结果&#xff1a; 题目&#xff1a; 示例&#xff1a; 分析&#xff1a; 给我们字符串&#xff0c;让我们解码&#xff0c;那么该怎么解码呢&#xff0c;被括号【】包裹起来的字符串需要扩展成括号左边第…

一百五十一、Kettle——Linux上安装的kettle8.2开启carte服务以及配置子服务器

一、目的 kettle8.2在Linux上安装好可以启动界面、并且可以连接MySQL、Hive、ClickHouse等数据库后&#xff0c;准备在Linux上启动kettle的carte服务 二、实施步骤 &#xff08;一&#xff09;carte服务文件路径 kettle的Linux运行的carte服务文件是carte.sh &#xff08;二…

grafana部署

一、前言 grafana是一款用于将prometheus收集的数据通过ui展示出来的组件&#xff0c;可以直观的看到每个数据的情况和指标&#xff0c;grafana有很多的ui展示模板可以使用 二、部署 这里我使用docker部署 先查找一下镜像 docker search grafana 创建存放grafana数据的目录…

C++初阶之一篇文章教会你list(理解和使用)

list&#xff08;理解和使用&#xff09; 什么是list特点和优势基本操作示例用法与其他序列式容器&#xff08;如 std::vector 和 std::deque&#xff09;相比&#xff0c;std::list 显著的区别和优势成员类型 list构造函数1. default (1)2. fill (2)3.range (3)4. copy (4) li…

无涯教程-Perl - opendir函数

描述 此函数使用readdir函数打开目录EXPR,并将其与DIRHANDLE关联以进行处理。 语法 以下是此函数的简单语法- opendir DIRHANDLE, EXPR返回值 如果成功,此函数将返回true。 例 以下是显示其基本用法的示例代码- #!/usr/bin/perl -w$dirname"/tmp";opendir ( …

MySQL~事务的四大特性和隔离级别

事务的四大特性 1.原子性&#xff1a;一个事务&#xff08;transaction&#xff09;中的所有操作&#xff0c;要么全部完成&#xff0c;要么全部不完成。事务在执行过程中发生错误&#xff0c;会被回滚&#xff08;Rollback&#xff09;到事务开始前的状态&#xff0c;就像这个…

MySQL环境与配置

安装MySQL https://www.mysql.com/ 进入下载官网后 下载完成后运行安装包下载完成后运行安装包 选择完路径后一直点下一步 然后运行MySQL 设置密码 这里如安装失败请右键我的电脑点击属性&#xff0c;检查电脑名和组名是否为英文 启动与停止MySQL mysql安装完毕后默认是运行…

【C语言】进阶指针,超详解,含丰富代码示例

文章目录 前言指针进阶的重点内容1.字符指针2.数组指针3.指针数组4.函数指针5.函数指针数组6. 指向函数指针数组的指针 总结 这里是初阶的链接&#xff0c;方便大家对照查看&#xff01;&#xff01;&#xff01;添加链接描述 前言 大家好呀&#xff0c;今天和大家将指针进阶…

SpringBoot在线失物招领系统

一个基于SpringBootSemanticUI的pc Web在线失物招领系统 http://localhost:8080/swzl/index 主页 http://localhost:8080/swzl/login 登录页 用户表user admin字段为true是管理员 false用户 springboot2.3 springmvc mybatis html ajax idea 或eclipse maven mys…

9.3.2.1网络原理(UDP)

1.UDP的基本特点:无连接,不可靠传输,面向数据报,全双工. 2.1~1024的端口号有特定的含义,不建议使用.比如21:ftp,22:ssh,80:http,443:https. 3.CRC校验算法:循环冗余校验和,把UDP报中的每个字节都依次进行累加,把累加的结果,放到两个字节的变量中,溢出也无所谓,因为都加了一遍.…

机器学习笔记 - 关于向量嵌入​embedding在机器学习中的使用

向量嵌入概述 向量嵌入是机器学习中最有趣和最有用的概念之一。它们是许多 NLP、推荐和搜索算法的核心。如果您曾经使用过推荐引擎、语音助手、语言翻译器等工具,您就会遇到过依赖嵌入的系统。 与大多数软件算法一样,机器学习算法也需要使用数字。有时,我们的数据集包含数值…

Centos操作系统新安装的Python3中安装mysqlclient库

问题简介&#xff1a; mysqlclient 是python中的一个连接MySQL数据库的重要的三方库&#xff0c;但是在centos中使用pip3 install mysqlclient 方法安装一直报错&#xff0c;经过两天时间的排查,终于找到了解决问题的方法。 [rootd3acd2b8211d /]# pip3 install mysqlclient Co…

聊聊51单片机

目录 1.介绍 2.发展 3.应用领域 4.发展前景 1.介绍 51单片机&#xff08;AT89C51&#xff09;是一种常见的8位微控制器&#xff0c;属于Intel MCS-51系列。它是一种低功耗、高性能的单片机&#xff0c;广泛应用于嵌入式系统中。 51单片机具有很多特点和功能&#xff0c;例如…

用js快速生成一个简单的css原子库 例如: .mr-18 .pl-18

第三方css原子库的缺点 比如 tailwindcss&#xff0c;有学习成本最开始写的时候效率可能还没有我们自己手写效率高&#xff0c;需要配置&#xff0c;会有原始样式被覆盖的问题&#xff1b;总之就是一个字重 自己搓的优点 学习成本低灵活不会有副作用 <!DOCTYPE html>…

eclipse 导入项目js报错问题

eclipse 导入项目后会出现项目中的js文件报错&#xff08;红叉&#xff09;&#xff0c;如下图所示&#xff0c;有时候报错的文件很多&#xff0c;需要集中处理。 解决办法&#xff1a; 右键项目名称》Properties》MyEclipse》JavaScript》Include Path&#xff0c;在右侧选择“…