bvp4c--语法

简介: bvp4c--语法   1. bvp4c: sol = bvp4c(odefun,bcfun,solinit) sol = bvp4c(odefun,bcfun,solinit,options) sol = bvp4c(odefun,bcfun,solinit,options,p1,p2.

bvp4c--语法  

1. bvp4c

sol = bvp4c(odefun,bcfun,solinit)

sol = bvp4c(odefun,bcfun,solinit,options)

sol = bvp4c(odefun,bcfun,solinit,options,p1,p2...)

sol返回如下值

sol.x  bvp4c选择的网格

sol.y   在网格点sol.x的 y(x)的接近值

sol.yp 在网格点sol.x的 y'(x)的接近值

sol.parameters 未知参数的值

sol.solver   'bvp4c'

2.odefun 为微分方程

dydx = odefun(x,y)
dydx = odefun(x,y,p1,p2,...)
dydx = odefun(x,y,parameters)
dydx = odefun(x,y,parameters,p1,p2,...)

parameters 为未知参数向量,p1和p2...为已知参数向量

dydx为列向量

3. bcfun 计算边界条件的残留值bc(  y(a),y(b)  ),输出列向量

res = bcfun(ya,yb)
res = bcfun(ya,yb,p1,p2,...)
res = bcfun(ya,yb,parameters)
res = bcfun(ya,yb,parameters,p1,p2,...)

4. solinit

solinit的结构如下:

x  初始网格的节点(相当于自变量的节点),边界条件满足a=solinit.x(1) 和 b=solint.x(end)

y  解的初始假设,solinit.y(:,i) 为自变量solinit.x(i)对应的解的估计值

parameters 可选,未知参数的初始估计向量,对于存在未知参数的情况,必须提供

sol.y(1,1).............. sol.y(1,i)............. sol.y(1,end)

...

sol.y(m,1).............. sol.y(m,i)............. sol.y(m,end)

sol.x(1)   ................sol.x(i)  .................sol.x(end)

solinit的赋值语句为bvpinit,语法如下

solinit = bvpinit(x,v)
solinit = bvpinit(x,v,parameters)
solinit = bvpinit(sol,[anew bnew])
solinit = bvpinit(sol,[anew bnew],parameters)

x为初始网格向量,对于边界区间[a,b]需满足 x(1)=a, x(end)=b, 一般情况下可用 x=linspace(a,b,10)

v为解的估计,可以是一个向量,也可以是一个函数

v为向量的情况,v(i)代表的就是 y(i,:),也就是不管自变量为多少y(i)都是这个值,向量的维数等于因变量个数

v为函数的情况,对于给定一个网格,函数必须返回一个向量y(1),y(2),y(3)...y(m)

y=guess(x) 代表的是 y(:,j)=guess( x(j) )

solinit = bvpinit(sol,[anew bnew])

由[a,b]上的解sol,得到[anew,bnew]的解的初始估计,so either anew <= a < b <= bnew or anew >= a > b >= bnew

 5.deval 评估 自变量=xint时候的解

sxinit= deval(sol.xint)

6. options的设置 bvpset语句

options = bvpset('name1',value1,'name2',value2,...)
options = bvpset(oldopts'name1',value1,...)
options = bvpset(oldopts,newopts)

name               value

RelTol             正标量  默认为1e-3  相对精度

AbsTol            正标量 默认为1e-6  绝对精度

Vectorized      on或者off  将ode函数F([x1 x2 ...],[y1 y2 ...]),写成[F(x1,y1) F(x2,y2) ...]. 的形式,能减少函数评估的次数,降低运行时间

SingularTerm   矩阵    方程的奇异项, 如 y'=Sy/x + f(x,y,p)  x=[0,b] ,则设置常数矩阵S

FJacobian       函数、矩阵或元胞数组  提供odefun的解析偏导数 对于y'=f(x,y),则提供f对y的偏导数,若偏导数都为常数项,则用元胞数组的形式给出;若有未知参数,还需计算对未知参数的偏导数

BCJacobian    函数、元胞数组     提供边界函数bcfun的解析偏导数 bc(ya,yb)=0 则计算bc对ya,yb 的偏导数,若有未知参数p还需计算未知参数的偏导数:[DBCDYA,DBCDYB,DBCDP] = BCJAC(YA,YB,P)

Nmax              正整数    网格的最大值

Stats              on 或者off  显示计算过程的统计数据

 

 算法原理:

bvp4c is a finite difference code that implements the three-stage Lobatto IIIa formula. This is a collocation formula and the collocation polynomial provides a C1-continuous solution that is fourth order accurate uniformly in [a,b]. Mesh selection and error control are based on the residual of the continuous solution.

 1 % bvp4c_fun.m
 2 % 求解微分方程边值问题
 3 S=[ 0 0
 4     0 -2];
 5 options=bvpset('SingularTerm',S);
 6 % 得到微分方程的初场
 7 guess=[sqrt(3)/2;0];
 8 solinit=bvpinit(linspace(0,1,5),guess);
 9 sol=bvp4c(@emdenode,@emdenbc,solinit,options);
10 % 根据分析解计算
11 x=linspace(0,1);
12 truy=1./sqrt(1+(x.^2)/3);
13 % 绘制图形结果
14 plot(x,truy,'b-');
15 hold on;
16 plot(sol.x,sol.y(1,:),'ro');
17 legend('analytical','computed');
18 xlabel('x'),ylabel('y');
19 hold off;
View Code

 

相关文章
|
SQL Oracle 关系型数据库
sqoop的导入导出以及where条件过滤数据导出
sqoop的导入导出以及where条件过滤数据导出
|
网络协议 关系型数据库 MySQL
Linux (centos8)安装 MySQL 8 数据库(图文详细教程)
今天2021年4月23日。我买了阿里云centos服务器,安装mysql8.0,做一笔记,以供大家使用。 本教程手把手教你如何在 Linux 安装 MySQL 数据库,以 CentOS 8为例。
3738 0
Linux (centos8)安装 MySQL 8 数据库(图文详细教程)
|
7月前
|
机器学习/深度学习 数据可视化 算法
YOLOv9改进目录一览 | 涉及卷积层、轻量化、注意力、损失函数、Backbone、SPPF、Neck、检测头等全方位改进
YOLOv9改进目录一览 | 涉及卷积层、轻量化、注意力、损失函数、Backbone、SPPF、Neck、检测头等全方位改进
609 5
YOLOv9改进目录一览 | 涉及卷积层、轻量化、注意力、损失函数、Backbone、SPPF、Neck、检测头等全方位改进
|
供应链 安全 大数据
区块链与大数据:重构未来世界的密码
在科技飞速发展的时代,大数据被誉为“未来的石油”,区块链则被称为“信任的机器”。两者结合,将如何重塑世界?本文解析区块链与大数据的核心特性——区块链的去中心化、安全透明与大数据的海量、多样、实时价值;展示其在金融、供应链、医疗、交通等领域的应用场景;并展望未来跨界融合、信任重构、智能化发展以及隐私保护的趋势,预示着一个高效可信的新时代的到来。
810 1
|
存储 安全 文件存储
云上文件存储:重塑数据存储与管理的新纪元
绿色节能:随着全球对环境保护和可持续发展的重视,未来的云上文件存储将更加注重绿色节能。云服务商将采用更加高效的硬件设备和节能技术降低能耗;同时还将通过优化存储资源的利用率和减少数据传输量等方式进一步降低能耗和碳排放。 强化安全性:面对日益严峻的网络安全威胁和数据保护需求,未来的云上文件存储将进一步加强安全性保障。云服务商将采用更加先进的加密技术和安全防护措施确保数据的安全性和隐私性;同时还将建立完善的安全管理体系和应急响应机制以应对各种安全事件和突发事件。 结语 云上文件存储作为数据存储与管理的新趋势,正以其独特的优势和应用价值引领着数据存储行业的变革。随着技术的不断进步和应用场景
305 0
|
传感器 大数据 数据处理
大数据处理中的流计算技术:实现实时数据处理与分析
【7月更文挑战第30天】随着分布式系统、云原生技术、数据安全与隐私保护技术的不断发展,流计算技术将在更多领域得到应用和推广,为大数据处理和分析提供更加高效、智能的解决方案。
1047 3
|
设计模式
代码审查:质量控制的核心防线
【6月更文挑战第20天】代码审查确保软件质量的关键环节。它促进错误发现、代码质量提升、团队沟通及责任感培养。最佳实践包括选择审查方式、明确目标、及时反馈及避免过度审查。实施时需建立流程,用工具辅助,培养审查文化,并持续改进。
301 10
|
算法 安全 Java
Java中MD5加密算法的原理与实现详解
Java中MD5加密算法的原理与实现详解
|
物联网 SDN 网络虚拟化
VXLAN:彻底改变网络虚拟化
【7月更文挑战第3天】
898 0
VXLAN:彻底改变网络虚拟化
|
监控 算法 Linux
Linux下工具tc详细讲解及限制IP和端口实例
TC (Traffic Control) 是Linux内核中提供的一个用于控制和管理网络流量的强大工具,它允许用户实现QoS(Quality of Service)策略,包括带宽限制、优先级控制、延迟保证等。TC基于内核的队列 discipline (qdisc) 和流量类别(class) 体系结构,允许对进入或离开网络接口的数据流进行复杂的整形和过滤。
892 0