Matlab:导数边界值的有限元(Ritz)法




tic;
% this method is transform from Ritz method
%is used for solving two point BVP
%this code was writen by HU.D.dong in February 11th 2017
%MATLAB 7.0
clear
clc
N=50;
h=1/N;
X=0:h:1;
f=inline('pi^2/2*sin(pi/2*x)');
%以下是右端向量;
for i=2:N
fun1=@(x) f(X(i-1)+h*x).*x+f(X(i)+h*x).*(1-x);
fi(i-1,1)=h*quad(fun1,0,1);
end
funN=@(x) f(X(N-1)+h*x).*x;
fi(N,1)=h*quad(funN,0,1);
%以下是stiff矩阵;
a11=1/h+pi^2*h/12;
aii=2*a11;
aij=-1/h+pi^2*h/24;
A=diag(aii*ones(N,1),0)+diag(aij*ones(N-1,1),1)+diag(aij*ones(N-1,1),-1);
A(N,N)=a11;
numerical_solution=A\fi;
numerical_solution=[0;numerical_solution];
%以下是真解;
for i=1:length(X)
Accurate_solution(i,1)=sin((pi*X(i))/2)/2 - cos((pi*X(i))/2)/2 + exp((pi*X(i))/2)*((exp(-(pi*X(i))/2)*cos((pi*X(i))/2))/2 + (exp(-(pi*X(i))/2)*sin((pi*X(i))/2))/2);
end
grid on;
subplot(1,2,1);
plot(X,numerical_solution,'ro-',X,Accurate_solution,'b^:');
title('Numerical solutions vs Accurate solutions');
legend('Numerical_solution','Accurate_solution');
subplot(1,2,2);
plot(X,numerical_solution-Accurate_solution,'b x');
legend('error_solution');
title('error');
toc;
效果图:

Matlab:导数边界值的有限元(Ritz)法的更多相关文章
- Matlab:导数边界值的有限元(Galerkin)法
		
tic; % this method is transform from Galerkin method %also call it as finit method %is used for solv ...
 - Matlab-7:偏微分方程数值解法-李荣华-有限元解导数边界值的常微分(Galerkin方法)
		
p47.(实习题-李荣华)用线性元求下列边值问题的数值解 tic; % this method is transform from Galerkin method %also call it as f ...
 - 【Matlab】运动目标检测之“光流法”
		
光流(optical flow) 1950年,Gibson首先提出了光流的概念,所谓光流就是指图像表现运动的速度.物体在运动的时候之所以能被人眼发现,就是因为当物体运动时,会在人的视网膜上形成一系列的 ...
 - Matlab查看数值不用科学计数法显示
		
如图: 运行结果显示的是科学计数法的数据 输入命令“format long g” --> Enter --> 输入需要转换的数据 即可显示.
 - matlab规定小数点保留4位且非科学计数法格式存储txt
		
matlab 不保存为科学计数法 http://blog.sciencenet.cn/blog-472136-402727.html 经常在表示matlab值时,它总会把一些小于1的大于1000的数使 ...
 - 层次分析法、模糊综合评测法实例分析(涵盖各个过程讲解、原创实例示范、MATLAB源码公布)
		
目录 一.先定个小目标 二.层次分析法部分 2.1 思路总括 2.2 构造两两比较矩阵 2.3 权重计算方法 2.3.1 算术平均法求权重 2.3.2 几何平均法求权重 2.3.3 特征值法求权重 2 ...
 - <读书笔记>软件调试之道 :问题的核心-重现问题
		
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记. 重现第一,提问第二 问题重现是实证过程的最强大武器,如果不能重现问题,你也无法证明修复了它 ...
 - Testing - 测试基础 - 方法
		
选择和使用测试方法和工具 按照测试需求用途(或测试技巧)选择 在软件开发生命周期和软件测试流程中适当地选择 按照测试人员实际技能选择 选择可提供的和可执行的 测试方法 类别及技巧 目标 使用方法 举例 ...
 - [liu yanling]软件测试技巧
		
1.添加.修改功能 (1)是否支持tab键 (2)是否支持enter键 (3)不符合要求的地方是否有错误提示 (4)保存后,是否也插入到数据库中 (5)字段唯一的,是否可以重复添加 (6)对编辑页列表 ...
 
随机推荐
- dict()的另一种用法
			
先了解两个内容: 定义字典的两种方法: d1 = { ‘name’ :‘zzl’} #方法一 d2 = dict( name = 'zzl' ) #方法二 2. __dict__()方法不记录类的属性 ...
 - python线程、协程、I/O多路复用
			
目录: 并发多线程 协程 I/O多路复用(未完成,待续) 一.并发多线程 1.线程简述: 一条流水线的执行过程是一个线程,一条流水线必须属于一个车间,一个车间的运行过程就是一个进程(一个进程内至少一个 ...
 - pandas处理时间序列(2):DatetimeIndex、索引和选择、含有重复索引的时间序列、日期范围与频率和移位、时间区间和区间算术
			
一.时间序列基础 1. 时间戳索引DatetimeIndex 生成20个DatetimeIndex from datetime import datetime dates = pd.date_rang ...
 - node (02 CommonJs 和 Nodejs 中自定义模块)顺便讲讲module.exports和exports的区别 dependencies 与 devDependencies 之间的区别
			
CommonJS 规范的提出,主要是为了弥补当前 JavaScript 没有标准的缺陷.它的终极目标就是:提供一个类似 Python,Ruby 和 Java 语言的标准库,而不只是停留在小脚本程序的阶 ...
 - hive 基础
			
Apache的顶级项目,(java) 2008年Facebook公司开源给Apache基金会 官网:http://hive.apache.org/ hive 将SQL转换成MapReduce程序,并将 ...
 - ArrayList 除重
			
看到一段简洁的 ArrayList 除重代码: protected final <T> List<T> removeDuplicates(List<T> list) ...
 - AUTEL MaxiSYS Pro MS908P Diagnostic System with WiFi Update Online
			
The MaxiSYS? Pro has been designed to be the go-to tool for the professional technician who performs ...
 - Android项目第一天,下载安装Android Studio和“我的第一个安卓项目”
			
一.AS的下载我是在AS官方网站进行下载的最新版本,如图所示 二.AS的安装过程 点击你下载的安装包安装即可,傻瓜式一站到底. 到这一步时选择第二个按钮, 随后出现如下界面 这个窗口是提示我们设置代理 ...
 - springboot之jar包部署步骤
			
eclipse中: 1.单击整个项目 run as - maven clean - maven install 2.找到项目所在的路径 找到所有的jar包 3.把jar包放到linux对应的文件夹 l ...
 - Maven Web Project设置Webcontent路径
			
1,新建maven-archetype-webapp 2,右键项目-->Properties-->选中Project Facets中的Runtimes标签,然后Java版本改为1.8,Dy ...