数学建模社区-数学中国
标题:
通过数值积分和符号积分计算函数的定积分
[打印本页]
作者:
2744557306
时间:
2024-9-30 09:52
标题:
通过数值积分和符号积分计算函数的定积分
MATLAB代码展示了如何通过数值积分和符号积分计算函数的定积分,并对不同步长的数值积分结果进行比较。以下是逐步解析:
9 W& ?6 i# Y/ ?6 V" F l% B. Y' Q
8 f3 S' g) Z" O% P- K I" m
### 1. 创建自变量和函数
# n% ? x z D: A5 f3 A- d
```matlab
+ u+ e. a! j9 n" G; o
x = [0:0.01:3*pi/2, 3*pi/2]; % 包含 3π/2 这一点
: s# n5 |& o) x' G
y = cos(15*x);
O, \6 }7 m% K) J% O K
plot(x, y) % 绘制 y = cos(15*x) 的图形
# O5 Z g, W1 j) f9 ?: T5 u: ~! d
```
9 A5 B0 q1 D& C7 ]- i* k
- `x` 创建了一个从 0 到 \( \frac{3\pi}{2} \) 的向量,并确保 \( \frac{3\pi}{2} \) 这个点被包含在内。
) ^! w8 f% C0 J J
- `y` 计算了在 `x` 每个点上的 `cos(15*x)` 值。
) x+ B' M& z8 `2 o$ X
- 使用 `plot(x, y)` 绘制了函数 `y = cos(15*x)` 的图形。
o6 E) P- p: A$ J3 ~" L- k- E
. J: |; P Y8 @4 @9 {+ Q4 G
### 2. 计算理论值
! Z% h' _- X4 d0 _0 s
```matlab
z+ O! i. @( h3 ]5 l
syms x, A = int(cos(15*x), 0, 3*pi/2); % 使用符号积分求取定积分
9 S: e! x0 W+ ]$ ~8 t0 K) `
```
& ]) p: O& S' t" C
- `syms x` 定义符号变量 `x`。
2 ~9 G9 M) p3 r- J/ R
- `int(cos(15*x), 0, 3*pi/2)` 计算 `cos(15*x)` 从 0 到 \( \frac{3\pi}{2} \) 的定积分 `A`,这个结果为理论值。
% z1 ^' v6 e2 z$ z" H6 X
9 h0 h6 D7 n/ s& R
### 3. 定义步长并进行数值积分
1 p4 C8 V4 Z: q4 i# V8 E3 N
```matlab
5 M" @6 |5 E* x& N, ] i
h0 = [0.1, 0.01, 0.001, 0.0001, 0.00001, 0.000001];
+ {3 E5 ?2 X4 j: U- U
v = [];
" A8 Z! ~ [7 p6 M, \
for h = h0,
9 u4 P* q: |2 @( P% g" P
x = [0:h:3*pi/2, 3*pi/2];
7 C0 O" ^: p' ]) b, {
y = cos(15*x);
1 t9 k) L7 H) T3 N
I = trapz(x, y); % 使用梯形法进行数值积分
" K6 G. w t+ k _, N6 Q
v = [v; h, I, 1/15 - I]; % 将步长、数值积分结果和错误存储到 v 中
, N2 C* i3 }+ [
end
( z& y( Y* }: G# W5 U( c
```
! u' K7 k% V( o: j. Z" o9 }; l0 ^
- `h0` 是一个数组,包含了不同的步长值,用于进行数值积分。
; c/ {; w6 |9 b( [+ u
- `v = []` 初始化一个空数组 `v`,用于存储每种步长的结果。
& J, b3 D5 }" Q& i6 d* e
- 对于每个步长 `h`,代码:
8 Z3 O. A( w" a2 k+ @
- 创建新的 `x` 向量,从 0 到 \( \frac{3\pi}{2} \),步长为 `h`,并确保包含 \( \frac{3\pi}{2} \)。
& C2 v$ F% b& E
- 计算 `y = cos(15*x)`。
3 F6 ^" H) @+ l( {' _
- 使用 `trapz(x, y)` 进行数值积分,得到的结果存储在 `I` 中。
$ u7 `' `1 p: v2 F6 H1 u
- 将当前步长 `h`、计算得到的数值积分 `I` 和与理论值 \( \frac{1}{15} \) 的误差 \( 1/15 - I \) 存储到 `v` 中。
4 o- W" b' A, M' u" @4 ^4 f s. _
5 P5 S% D/ ?, m8 z
### 总结
) ?+ ~( ~, q4 {5 ~
这段代码通过图形显示、符号积分和数值积分来综合比较结果,展示了函数 `y = cos(15*x)` 的行为。通过不同的步长进行数值积分,并对结果与理论值进行比较,可以分析数值积分的精度随步长变化的情况。这是一种在数值分析中检验数值方法有效性的常见手段。
8 w3 L2 S3 ?# q8 L9 o9 T8 P9 h
0 c/ ^# f- R; R. G
2 }2 x1 a4 B( L$ @% ]
* L; n5 |8 a0 h& {
examp3_29.m
2024-9-30 09:51 上传
点击文件名下载附件
下载积分: 体力 -2 点
289 Bytes, 下载次数: 0, 下载积分: 体力 -2 点
售价:
2 点体力
[
记录
] [
购买
]
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5