函数f(x)用采样间隔Δx=π/5进行采样,使用向前差商、向后差商和中心差商三种公式来近似一阶导数。

书中代码:

%% ------------------------------------------------------------------------------
%% Output Info about this m-file
fprintf('\n****************************************************************\n');
fprintf('\n <FDTD 4 ElectroMagnetics with MATLAB Simulations> \n');
fprintf('\n Figure 1.2 \n\n'); time_stamp = datestr(now, 31);
[wkd1, wkd2] = weekday(today, 'long');
fprintf(' Now is %20s, and it is %7s \n\n', time_stamp, wkd2);
%% ------------------------------------------------------------------------------ % Create exact function and its derivative
N_exact = 301; % number of sample points for exact function
x_exact = linspace(0, 6*pi, N_exact);
f_exact = sin(x_exact) .* exp(-0.3*x_exact);
f_derivative_exact = cos(x_exact) .* exp(-0.3*x_exact) - 0.3*sin(x_exact).*exp(-0.3*x_exact); % plot exact function
figure('NumberTitle', 'off', 'Name', 'Figure 1.2.a');
set(gcf,'Color','white'); plot(x_exact, f_exact, 'k-', 'linewidth', 1.5);
set(gca, 'fontsize', 12, 'fontweight', 'demi');
axis([0 6*pi -1 1]); grid on;
xlabel('$x$', 'interpreter', 'latex', 'fontsize', 16);
ylabel('$f(x)$', 'interpreter', 'latex', 'fontsize', 16);
title('Exact function'); % create exact function for pi/5 sampleing peroid and
% its finite difference derivatives
N_a = 31; % number of points for pi/5 sampling period
x_a = linspace(0, 6*pi, N_a); % [0, 6pi], row vector with 31 points
f_a = sin(x_a) .* exp(-0.3*x_a);
f_derivative_a = cos(x_a) .* exp(-0.3*x_a) - 0.3*sin(x_a) .* exp(-0.3*x_a); dx_a = pi/5;
f_derivative_forward_a = zeros(1, N_a); % 1×31 zero matrix
f_derivative_backward_a = zeros(1, N_a);
f_derivative_central_a = zeros(1, N_a); f_derivative_forward_a(1:N_a-1) = (f_a(2:N_a)-f_a(1:N_a-1))/dx_a;
f_derivative_backward_a(2:N_a) = (f_a(2:N_a)-f_a(1:N_a-1))/dx_a;
f_derivative_central_a(2:N_a-1) = (f_a(3:N_a)-f_a(1:N_a-2))/(2*dx_a); % create exact function for pi/10 sampleing peroid and
% its finite difference derivatives
N_b = 61; % number of points for pi/10 sampling period
x_b = linspace(0, 6*pi, N_b);
f_b = sin(x_b) .* exp(-0.3*x_b);
f_derivative_b = cos(x_b) .* exp(-0.3*x_b) - 0.3*sin(x_b) .* exp(-0.3*x_b); dx_b = pi/10;
f_derivative_forward_b = zeros(1, N_b);
f_derivative_backward_b = zeros(1, N_b);
f_derivative_central_b = zeros(1, N_b);
f_derivative_forward_b(1:N_b-1) = (f_b(2:N_b)-f_b(1:N_b-1))/dx_b;
f_derivative_backward_b(2:N_b) = (f_b(2:N_b)-f_b(1:N_b-1))/dx_b;
f_derivative_central_b(2:N_b-1) = (f_b(3:N_b)-f_b(1:N_b-2))/(2*dx_b); % plot exact derivative of the function and its finite difference
% derivatives using pi/5 sampling period
figure('NumberTitle', 'off', 'Name', 'Figure 1.2.b');
set(gcf,'Color','white'); plot(x_exact, f_derivative_exact, 'k', ...
x_a(1:N_a-1), f_derivative_forward_a(1:N_a-1), 'b--', ...
x_a(2:N_a), f_derivative_backward_a(2:N_a), 'r-.', ...
x_a(2:N_a-1), f_derivative_central_a(2:N_a-1), ':ms', ...
'markersize', 4, 'linewidth', 1.5);
set(gca, 'fontsize', 12, 'fontweight', 'demi');
axis([0 6*pi -1 1]); grid on;
legend('exact', 'forward difference', 'backward difference', 'central difference');
xlabel('$x$', 'interpreter', 'latex', 'fontsize', 16);
ylabel('$f''(x)$', 'interpreter', 'latex', 'fontsize', 16);
text(pi, 0.6, '$\Delta x = \pi/5$', 'interpreter', 'latex', 'fontsize', 16, 'backgroundcolor', ...
'w', 'edgecolor', 'k'); % plot error for finite difference derivatives
% using pi/5 sampling period
error_forward_a = f_derivative_a - f_derivative_forward_a;
error_backward_a = f_derivative_a - f_derivative_backward_a;
error_central_a = f_derivative_a - f_derivative_central_a; figure('NumberTitle', 'off', 'Name', 'Figure 1.2.c');
set(gcf,'Color','white');
plot(x_a(1:N_a-1), error_forward_a(1:N_a-1), 'b--', ...
x_a(2:N_a), error_backward_a(2:N_a), 'r--', ...
x_a(2:N_a-1), error_central_a(2:N_a-1), ':ms', ...
'markersize', 4, 'linewidth', 1.5);
set(gca, 'fontsize', 12, 'fontweight', 'demi');
axis([0 6*pi -0.2 0.2]); grid on;
legend('forward difference', 'backward difference', 'central difference');
xlabel('$x$', 'interpreter', 'latex', 'fontsize', 16);
ylabel('error $[f''(x)]$' , 'interpreter', 'latex', 'fontsize', 16);
text(pi, 0.15, '$\Delta x = \pi/5$', 'interpreter', 'latex', 'fontsize', 16, ...
'backgroundcolor', 'w', 'edgecolor', 'k'); % plot error for finite difference derivatives
% using pi/10 sampling period
error_forward_b = f_derivative_b - f_derivative_forward_b;
error_backward_b = f_derivative_b - f_derivative_backward_b;
error_central_b = f_derivative_b - f_derivative_central_b; figure('NumberTitle', 'off', 'Name', 'Figure 1.2.d');
set(gcf,'Color','white');
plot(x_b(1:N_b-1), error_forward_b(1:N_b-1), 'b--', ...
x_b(2:N_b), error_backward_b(2:N_b), 'r-.', ...
x_b(2:N_b-1), error_central_b(2:N_b-1), ':ms', ...
'markersize', 4, 'linewidth', 1.5);
set(gca, 'fontsize', 12, 'fontweight', 'demi');
axis([0 6*pi -0.2 0.2]); grid on;
legend('forward difference', 'backward difference', 'central difference');
xlabel('$x$', 'interpreter', 'latex', 'fontsize', 16);
ylabel('error $[f''(x)]$' , 'interpreter', 'latex', 'fontsize', 16);
text(pi, 0.15, '$\Delta x = \pi/10$' , 'interpreter', ...
'latex', 'fontsize', 16, 'backgroundcolor', 'w', 'edgecolor', 'k' );

  运行结果:

上图是函数图形,看出振幅是指数衰减的。下图是一阶导数的精确值(公式计算)和三种差商近似结果。中心差商近似结果接近

精确值。

下图是在Δx=π/5采样间隔下,三种差商近似与精确值之间的误差对比。可以看出中心差商近似的误差最小。

下图是Δx=π/10采样间隔下,三种差商近似与精确值之间的误差对比。可以看出中心差商近似的误差最小。另外由于向前差商和

向后差商近似是1阶精度,中心差商近似是2阶精度,所以采样间隔由π/5变成π/10后,向前差商和向后差商近似误差变为原来的二分之一,

而中心差商近似误差变为原来的四分之一。

《FDTD electromagnetic field using MATLAB》读书笔记 Figure 1.2的更多相关文章

  1. 《FDTD electromagnetic field using MATLAB》读书笔记之 Figure 1.14

    背景: 基于公式1.42(Ez分量).1.43(Hy分量)的1D FDTD实现. 计算电场和磁场分量,该分量由z方向的电流片Jz产生,Jz位于两个理想导体极板中间,两个极板平行且向y和z方向无限延伸. ...

  2. 《FDTD electromagnetic field using MATLAB》读书笔记之一阶、二阶偏导数差商近似

  3. 《FDTD electromagnetic field using MATLAB 》读书笔记001-差商种类

    有限差分就是用差商代替微商,有3钟: 1.向前差商 2.向后差商 3.中心差商 上面三张途中虚线就是函数在x的精确微商(偏导数),直线就是用来代替精确 微商的差商格式.

  4. Matlab学习笔记 figure函数

    Matlab学习笔记 figure函数 matlab中的 figure 命令,能够创建一个用来显示图形输出的一个窗口对象.每一个这样的窗口都有一些属性,例如窗口的尺寸.位置,等等.下面一一介绍它们. ...

  5. TJI读书笔记17-字符串

    TJI读书笔记17-字符串 不可变的String 重载”+”和StringBuilder toString()方法的一个坑 String上的操作 格式化输出 Formatter类 字符串操作可能是计算 ...

  6. WPF,Silverlight与XAML读书笔记第四十三 - 多媒体支持之文本与文档

    说明:本系列基本上是<WPF揭秘>的读书笔记.在结构安排与文章内容上参照<WPF揭秘>的编排,对内容进行了总结并加入一些个人理解. Glyphs对象(WPF,Silverlig ...

  7. 《Linux内核设计与实现》 Chapter4 读书笔记

    <Linux内核设计与实现> Chapter4 读书笔记 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间,进程调度程序可看做在可运行态进程之间分配有限的处理器时间资源的内核子 ...

  8. ANTLR3完全参考指南读书笔记[06]

    前言 这段时间在公司忙的跟狗似的,但忙的是没多少技术含量的活儿. 终于将AST IR和tree grammar过了一遍,计划明天写完这部分的读书笔记.   内容 1 内部表示AST构建 2 树文法   ...

  9. 认识CLR [《CLR via C#》读书笔记]

    认识CLR [<CLR via C#>读书笔记] <CLR via C#>读书笔记 什么是CLR CLR的基本概念 通用语言运行平台(Common Language Runti ...

随机推荐

  1. 2018 Multi-University Training Contest 10 Solution

    A - Problem A.Alkane 留坑. B - Problem B. Beads 留坑. C - Problem C. Calculate 留坑. D - Problem D. Permut ...

  2. uva1291

    这题说的给了 一 个 图,每次 按照他给的顺序 跳格子 给了 每种 格子之间的 转换 代价 求最后 转换代价 dp[i][j] 表示 左脚在i 右脚 在j 的最小代价 然后用滚动数组 ,就可以不断说的 ...

  3. python 手动遍历迭代器

    想遍历一个可迭代对象中的所有元素,但是却不想使用for 循环 为了手动的遍历可迭代对象,使用next() 函数并在代码中捕获StopIteration 异常.比如,下面的例子手动读取一个文件中的所有行 ...

  4. python: 基本的日期与时间转换

    需要执行简单的时间转换,比如天到秒,小时到分钟等的转换. 为了执行不同时间单位的转换和计算,请使用datetime 模块.比如,为了表示一个时间段,可以创建一个timedelta 实例,就像下面这样: ...

  5. ArrayBuffer:类型化数组

    类型化数组是JavaScript操作二进制数据的一个接口. 这要从WebGL项目的诞生说起,所谓WebGL,就是指浏览器与显卡之间的通信接口,为了满足JavaScript与显卡之间大量的.实时的数据交 ...

  6. STM32|4-20mA输出电路(转)

    源:STM32|4-20mA输出电路 STM32+运算放大器实现VI转换,4mA-20mA发送器

  7. Python笔记 #09# Basic plots with matplotlib

    源:DataCamp 气泡的大小表示人口的多少,横坐标表示人均GDP(美元),纵坐标表示预期寿命.-- 作者:Hans Rosling Python 中有许许多多用于可视化的包,而 matplotli ...

  8. Python3.x:os._exit(), sys.exit(), exit() 的区别

    Python3.x:os._exit(), sys.exit(), exit() 的区别 一.sys.exit() 说明:退出程序引发SystemExit异常, 可以捕获异常执行些清理工作.一般主程序 ...

  9. 已知圆上三个点坐标,求圆半径 r 和 圆心坐标

    问题: 已知圆上三个点坐标分别为(x1,y1).(x2,y2).(x3,y3) 求圆半径R和圆心坐标(X,Y) X,Y,R为未知数,x1,y1,x2,y2,x3,y3为常数 则由圆公式:(x1-X)² ...

  10. Web漏洞挖掘之网络信息探测

    我们在搜集目标系统信息的时候主要需要搜集的是:目标服务器系统信息(IP,服务器所用系统等):目标网站子域名:目标网站(服务器)的开放端口:目标域名信息.目标网站内容管理系统(CMS)等. 一.子域名搜 ...