QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1197|回复: 0
打印 上一主题 下一主题

比较通过符号计算得到的导数和通过数值差分方法计算得到的导数的结果

[复制链接]
字体大小: 正常 放大

1176

主题

4

听众

2887

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-9-26 17:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
h=0.05; x=0:h:pi; syms x1; y=sin(x1)/(x1^2+4*x1+3);
8 W; I" q$ D/ o) P5 s! jyy1=diff(y); f1=subs(yy1,x1,x);   % 求各阶导数的解析解与对照数据
3 F1 l" n5 I+ \3 B  ~% I. ^. ]yy2=diff(yy1); f2=subs(yy2,x1,x); yy3=diff(yy2); f3=subs(yy3,x1,x);/ n1 Z$ J+ X8 h3 g  B0 V' t+ ?
yy4=diff(yy3); f4=subs(yy4,x1,x);* ]3 p, T% J" M2 v3 X

9 c% g9 C  e1 k* f3 Ny=sin(x)./(x.^2+4*x+3);   % 生成已知数据点* v# ^5 T. }3 D. E* c/ _* X; ~  C
[y1,dx1]=diff_ctr(y,h,1); subplot(221),plot(x,f1,dx1,y1,':');% ]2 }2 p. @% a) Y
[y2,dx2]=diff_ctr(y,h,2); subplot(222),plot(x,f2,dx2,y2,':')* V0 z$ _6 r- r: D/ G$ P
[y3,dx3]=diff_ctr(y,h,3); subplot(223),plot(x,f3,dx3,y3,':');  q9 g* }% _0 c( U9 Z6 D6 S
[y4,dx4]=diff_ctr(y,h,4); subplot(224),plot(x,f4,dx4,y4,':')
* H- q/ D6 ]7 B. F
$ [2 v$ r5 ?. c0 ?3 u% q& Ynorm((y4-f4(4:60))./f4(4:60)): d# Z3 _* p) h8 W! m6 L# ]4 u
这段MATLAB代码旨在比较通过符号计算得到的导数和通过数值差分方法计算得到的导数的结果。以下是对代码的逐步解析:
. k- K. V' d1 J/ O* j7 v/ U; q- Z3 a' n# c% ]
/ D+ B1 Q! E/ }! X. ~
### 1. 定义和设置
- _& J% }6 N* D* R- }4 f1 z5 ~```matlab, M7 p3 K& z; w3 {- n9 N
h = 0.05; 4 j3 `0 ]6 n' g4 g4 [
x = 0:h:pi; " ?- y: {' v: i
syms x1;
: c$ C0 O6 ^( Ay = sin(x1) / (x1^2 + 4*x1 + 3);
# N: c3 A! T8 j0 l* ~```
+ B- b6 v+ W7 H+ P- `h = 0.05;` 定义了一个小步长 `h`,用于生成数据点。
3 W7 s1 Y# t" Y- S3 _: J- `x = 0:h:pi;` 生成从0到π的等间距点。9 d$ b: ~8 u, B, o! \
- `syms x1;` 定义了一个符号变量 `x1`。
2 _' D0 N& ?# q4 y$ l- `y = sin(x1) / (x1^2 + 4*x1 + 3);` 定义了符号函数 `y`,这是一个关于 `x1` 的函数。
4 B( A5 F9 o- G; Z6 B; k) H+ O1 U. J* Y$ h) _. z) ?! c

% @* F  r! V+ t$ a/ {+ S+ `4 O### 2. 计算导数
7 U" P% X- b% K$ ^7 F3 z9 V```matlab8 ]" u' b! a9 [
yy1 = diff(y);
% K* F) D8 J! v+ f4 c% I! A8 u' L8 ^f1 = subs(yy1, x1, x);
1 U" `2 g; V& v; i. Z6 A```0 ^$ X+ ?$ m* p5 |% i
- `yy1 = diff(y);` 计算函数 `y` 的第一阶导数。
5 H" c3 _4 N/ P8 H- `f1 = subs(yy1, x1, x);` 使用 `subs` 将导数中的符号变量 `x1` 替换为具体的 `x` 值,得到导数的值,储存在 `f1` 中。/ b  S/ w) U2 E& `8 K

" y& ^; x  P0 y& ~/ S" w$ I

. J- b6 `; g# A- f& S7 i% J对后续导数的计算重复相同的操作:* @4 b. ]9 Z5 N; k1 E
```matlab8 s7 v- d5 e. L- O. p% k9 \
yy2 = diff(yy1); - \3 d/ ^9 G2 ]) ]
f2 = subs(yy2, x1, x);
6 [3 @2 u1 u- m7 }% iyy3 = diff(yy2);
0 l+ l, [( v6 O, h* D4 r' _4 _f3 = subs(yy3, x1, x);
9 ^" v& V, G* T. H" j) [- W. Iyy4 = diff(yy3);
, x' S: ^8 v! @2 R. b$ Mf4 = subs(yy4, x1, x);9 Z' O. K. G+ P0 p2 @
```
5 X1 e. w& N2 \- 上述代码计算了 `y` 的第二、第三和第四阶导数,并相应地进行了替换得到了 `f2`、`f3` 和 `f4`。' ^( @6 {. P/ \6 n- i% B4 q1 G

0 b  L* o7 }% T
  p4 O% V# h$ M  W7 o
### 3. 生成已知数据点
8 g8 B3 w, Y! F6 H' \2 B+ E) M- o; Z```matlab
3 g$ c# F# a" z1 k/ u  ]1 [y = sin(x) ./ (x.^2 + 4*x + 3); 0 ~  ~; _/ p9 \1 D% J
```
+ V* o. ]/ t5 j( W! H6 s& p* N# \- 计算 `y` 的值,将 `x` 中的每个元素代入,生成已知数据点。
2 g& B& f' n+ j+ I- U
, l. k0 b. {5 ~8 r
1 `9 |( Y4 x6 u; e1 M2 t
### 4. 使用差分方法计算导数
2 R/ k$ l9 z% D, R% g8 Q以下是使用数值方法计算导数的步骤,假设 `diff_ctr` 函数已经定义并实现:) c" `2 u3 q6 g" n# h
) q9 x0 S, U3 s/ B+ w! b8 w" ?9 {

- ~0 `1 d6 L* c( X```matlab
- p/ _. o' @, Z. P3 q" f[y1, dx1] = diff_ctr(y, h, 1); 0 O" W# H: x& w( V3 ?
subplot(221), plot(x, f1, dx1, y1, ':');2 V2 M: w. _7 ?0 o0 n2 Q
[y2, dx2] = diff_ctr(y, h, 2);
( P& A" a2 T& jsubplot(222), plot(x, f2, dx2, y2, ':');; R+ m$ n6 D$ L
[y3, dx3] = diff_ctr(y, h, 3); . W2 j- a' r/ r* W9 Y
subplot(223), plot(x, f3, dx3, y3, ':');
/ r, W; r2 i6 @1 R# \. X[y4, dx4] = diff_ctr(y, h, 4);
" E8 E: T; ^0 f' B3 Wsubplot(224), plot(x, f4, dx4, y4, ':');
$ P9 V4 |1 a8 Y  E4 A* W1 ^, q```
" l9 V9 I" n2 G; [* |9 b0 i- `diff_ctr(y, h, n)` 函数可能是一个自定义的函数,用来通过中心差分方法计算函数 `y` 的 `n` 阶导数。
$ F+ z  B- a% A$ C& d- `subplot` 和 `plot` 用于可视化结果,将每个计算的导数和数值差分结果绘制在不同的子图中。
( P: ~9 e& s/ L0 F, J+ s; L8 Y' w. K* G* E0 A

. y! T' g. U5 p### 5. 计算误差的规范化
* j0 v( u0 T$ l' c% D```matlab
) e% u) ]  y0 A5 M* T# ?! pnorm((y4 - f4(4:60)) ./ f4(4:60))
) F3 D/ D7 @+ l/ j! v+ h```
2 F2 N; o" ]' ?1 h- `norm(...)` 用于计算向量的范数,这里比较后处理的数值导数 `y4` 和符号计算的导数 `f4(4:60)`,以计算相对误差。2 c  F, I% P" @" g. K1 J
- 通过这种方法,用户可以评估数值计算的精度。
+ k/ x, n8 J. z3 B- H( ]3 l: C- d  U1 _, ~4 ]( p

: Q2 O: I5 O1 v### 总结
# D* O0 L* S: i1 G: g. b' z# h% J& t这段代码的主要目标是通过符号计算和中心差分法计算函数的导数,并绘制出它们的比较图。最终的规范化误差提供了一种衡量数值方法精度的手段。这种方法对理解和验证数值微分的重要性以及与解析解的比较相当有用。
6 s( o/ I$ l3 X0 Q. r: o- V/ H2 O/ k3 S& s/ c

: G+ c3 D! K, x: z3 t$ c" i) \+ D' o1 D' L2 `6 A" A

7 v7 l  G5 D6 O8 w& M& b8 I6 \7 f5 ^; \9 j9 m# _5 r9 E) ^
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2025-11-5 14:21 , Processed in 0.405641 second(s), 51 queries .

回顶部