Matlab:高阶常微分三种边界条件的特殊解法(隐式Euler)

函数文件1:
function b=F(f,x0,u,h)
b(1,1)=x0(1)-h*x0(2)-u(1);
b(2,1)=x0(2)+h*x0(1)^2-u(2)-h*f;
函数文件2:
function g=Jacobian(x0,u,h)
g(1,1)=1;
g(1,2)=-h;
g(2,1)=2*h*x0(1);
g(2,2)=1;
函数文件3:
function x=newton_Iterative_method(f,u,h)
% u:上一节点的数值解或者初值
% x0 每次迭代的上一节点的数值
% x1 每次的迭代数值
% tol 允许误差
% f 右端函数
x0=u;
tol=1e-11;
x1=x0-Jacobian(x0,u,h)\F(f,x0,u,h);
while (norm(x1-x0,inf)>tol)
%数值解的2范数是否在误差范围内
x0=x1;
x1=x0-Jacobian(x0,u,h)\F(f,x0,u,h);
end
x=x1;%不动点
脚本文件:
tic;
clear all
clc
N=100;
h=1/N;
x=0:h:1;
y=inline('x.^2.*sin(x).^2+2*cos(x)-x.*sin(x)');
fun1=inline('x.*sin(x)');
Accurate=fun1(x);
f=y(x);
Numerical=zeros(2,N+1);
for i=1:N
Numerical(1:2,i+1)=newton_Iterative_method(f(i+1),Numerical(1:2,i),h);
end
error=Numerical(1,:)-Accurate;
subplot(1,3,1)
plot(x,Accurate);
xlabel('x');
ylabel('Accurate');
grid on
subplot(1,3,2)
plot(x,Numerical(1,:));
xlabel('x');
ylabel('Numerical');
grid on
subplot(1,3,3)
plot(x,error);
xlabel('x');
ylabel('error');
grid on
toc;
效果图:

Matlab:高阶常微分三种边界条件的特殊解法(隐式Euler)的更多相关文章
- Matlab:高阶常微分三种边界条件的特殊解法(中心差分法,高精度导数边界处理)
		函数文件1: function b=F(f,x0,h,N) % b(1,1)=x0(1)-h*x0(2)-u(1); % b(2,1)=x0(2)+h*x0(1)^2-u(2)-h*f; b=zero ... 
- 学好Spark/Kafka必须要掌握的Scala技术点(三)高阶函数、方法、柯里化、隐式转换
		5. 高阶函数 Scala中的高阶函数包含:作为值的函数.匿名函数.闭包.柯里化等,可以把函数作为参数传递给方法或函数. 5.1 作为值的函数 定义函数时格式: val 变量名 = (输入参数类型和个 ... 
- Matlab:非线性高阶常微分方程的几种解法
		一.隐式Euler: 函数文件1: function b=F(t,x0,u,h) b(,)=x0()-h*x0()-u(); b(,)=x0()+*h*x0()/t+*h*(*exp(x0())+ex ... 
- Matlab中数组元素引用——三种方法
		Matlab中数组元素引用——三种方法 1.Matlab中数组元素引用有三种方法 1 2 3 1.下标法(subscripts) 2.索引法(index) 3.布尔法(Boolean) 注意:在使 ... 
- MATLAB 显示输出数据的三种方式
		MATLAB 显示输出数据的三种方式 ,转载 https://blog.csdn.net/qq_35318838/article/details/78780412 1.改变数据格式 当数据重复再命令行 ... 
- 如何使用MATLAB对图片的RGB三种颜色进行提取
		参考: https://jingyan.baidu.com/article/456c463b41de5f0a5831448e.html matlab在图像处理方面,具有很强大的应用.下面将分享如何使用 ... 
- c++ operator操作符的两种用法:重载和隐式类型转换,string转其他基本数据类型的简洁实现string_cast
		C++中的operator主要有两个作用,一是操作符的重载,一是自定义对象类型的隐式转换.对于操作符的重载,许多人都不陌生,但是估计不少人都不太熟悉operator的第二种用法,即自定义对象类型的隐式 ... 
- matlab 高阶(三)—— 插值(fft、)
		1. FFT 插值 y = interpft(x,n) y = [0, .5, 1., 1.5, 2., 1.5, 1., .5, 0, -.5, -1, -1.5, -2., -1.5, -1., ... 
- java高并发锁的三种实现
		提到锁大家会想到Synchronized同步关键字,使用它确实可以解决一切并发问题,但是对于体统吞吐量要求更高,在这里提供了几个小技巧.帮助大家减少锁粒度.提高系统的并发能力 一.乐观锁 试用场景:读 ... 
随机推荐
- TZOJ :2731: 存钱计划(二)
			描述 在TZC,WY存了钱,现在他要去买东西了.店很多,标记为1,2,3,4,5,6....但有的店之间有大路相连,而有的没有路.现在要由一个店到另一个店买东西,中途最少要经过多少个其它的店铺呢? 如 ... 
- 自动重置Language level 5 与 Java Complier 1.5
			Intellij IDEA用Maven来构建项目,若pom.xml没有指定版本,总是默认Language level 5 与 Java Compiler 1.5. 以下是两种修改方式: 1. 手动进行 ... 
- python框架之Django(9)-CSRF
			准备 现有如下模板和视图: <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ... 
- xampp lampp 改变网页root目录的方法
			This is an old question but I haven't seen it properly answered yet. Here is what you need to do: In ... 
- 【Algorithm】-NO.140.Algorithm.1.Algorithm.1.001-【空间复杂度 时间复杂度 o(1), o(n), o(logn), o(nlogn)】-
			Style:Mac Series:Java Since:2018-09-10 End:2018-09-10 Total Hours:1 Degree Of Diffculty:5 Degree Of ... 
- nginx----------linux下nginx环境搭建遇到的一些问题汇总(多域名配置,配置文件修改问题)
			一.启动 cd usr/local/nginx/sbin ./nginx 二.重启 更改配置重启nginx kill -HUP 主进程号或进程号文件路径 或者使用 cd /usr/local/ngin ... 
- linux下git服务器安装
			git服务器配置http://www.cnblogs.com/dee0912/p/5815267.html git教程https://www.liaoxuefeng.com/wiki/00137395 ... 
- 在 CentOS7 上安装 Zookeeper服务
			1.创建 /usr/local/services/zookeeper 文件夹: mkdir -p /usr/local/services/zookeeper 2.进入到 /usr/local/serv ... 
- 删除本地git的远程分支和远程删除git服务器的分支
			在项目中使用git管理代码后,有些时候会创建很多不同名称的分支,以此区分各个分支代码功能. 而随着代码的合并,以前的分支就可能不再需要保存了,所以就要对没有用的分支进行删除,包括紧急回滚时从中抽取某一 ... 
- CSS——对position定位和margin-top的理解
			一.常见定位方式 1.positon:absolute (脱离文档流) 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位 (这里的父元素是指定位方式为relative和abso ... 
