数学建模社区-数学中国
标题:
通过数值积分和符号积分计算函数的定积分
[打印本页]
作者:
2744557306
时间:
2024-9-30 09:52
标题:
通过数值积分和符号积分计算函数的定积分
MATLAB代码展示了如何通过数值积分和符号积分计算函数的定积分,并对不同步长的数值积分结果进行比较。以下是逐步解析:
! A# [9 R* B7 [
4 O1 q/ {) \, O5 F; z1 m+ s: k, C
### 1. 创建自变量和函数
3 C% H9 C$ L: l5 R9 Y
```matlab
7 W) ~3 Z1 E1 N7 L2 K9 g
x = [0:0.01:3*pi/2, 3*pi/2]; % 包含 3π/2 这一点
3 G, S( {# [& Q, |0 c
y = cos(15*x);
, |6 ?7 E% f! x5 q
plot(x, y) % 绘制 y = cos(15*x) 的图形
8 M" {5 p, V- I! l, k
```
/ g8 ^" m0 c. {& w1 ]: ]" Y( C
- `x` 创建了一个从 0 到 \( \frac{3\pi}{2} \) 的向量,并确保 \( \frac{3\pi}{2} \) 这个点被包含在内。
! B2 S4 |# y" s( K
- `y` 计算了在 `x` 每个点上的 `cos(15*x)` 值。
6 t2 ~% Q5 D- ] ?( h# l$ d2 Z( d
- 使用 `plot(x, y)` 绘制了函数 `y = cos(15*x)` 的图形。
5 l7 r" Q1 Z( G* z
1 G* z( d+ ?8 f
### 2. 计算理论值
" z# r7 B4 w; R( t' t7 ?) H. A; D0 d
```matlab
0 G/ W/ `7 \9 T2 f; c
syms x, A = int(cos(15*x), 0, 3*pi/2); % 使用符号积分求取定积分
6 Q# {/ T2 z# o* N/ v. A
```
# ^- Y" B# g5 y, P" t* g, l
- `syms x` 定义符号变量 `x`。
! [- U c2 Z& r% o6 j* C) C' n
- `int(cos(15*x), 0, 3*pi/2)` 计算 `cos(15*x)` 从 0 到 \( \frac{3\pi}{2} \) 的定积分 `A`,这个结果为理论值。
, b( P. V3 F/ _
9 N* x2 s! L3 `6 n8 s
### 3. 定义步长并进行数值积分
& O. _) ^+ r# c/ X& J8 f1 h( H
```matlab
/ V6 w3 k0 j! k% m" R A. N
h0 = [0.1, 0.01, 0.001, 0.0001, 0.00001, 0.000001];
4 G0 f7 x3 ]/ i6 g" r5 D
v = [];
4 ^8 \3 s4 T0 i+ d
for h = h0,
4 @/ P3 [& [8 L y; n
x = [0:h:3*pi/2, 3*pi/2];
% [1 b/ P) V% m
y = cos(15*x);
8 j3 P8 F+ k- c
I = trapz(x, y); % 使用梯形法进行数值积分
! [/ |, _* `; t) N1 X/ K2 Y
v = [v; h, I, 1/15 - I]; % 将步长、数值积分结果和错误存储到 v 中
# |/ ?2 o( ~0 w# i2 l& B1 O- ]0 b2 D; C
end
1 S4 \4 M. ?& h( ?
```
' H' h9 K& |9 P4 p# d2 K* _9 s
- `h0` 是一个数组,包含了不同的步长值,用于进行数值积分。
: Z* q8 y+ H3 n2 k: B2 R# N
- `v = []` 初始化一个空数组 `v`,用于存储每种步长的结果。
' |/ N( z) S6 C$ Y9 i* T* y$ T/ q1 t, H
- 对于每个步长 `h`,代码:
. U( c9 {* \1 X% w( k
- 创建新的 `x` 向量,从 0 到 \( \frac{3\pi}{2} \),步长为 `h`,并确保包含 \( \frac{3\pi}{2} \)。
: ]3 i$ R4 H4 v0 n+ d9 Z2 ~
- 计算 `y = cos(15*x)`。
* K# d7 `* h* P% l2 I; s
- 使用 `trapz(x, y)` 进行数值积分,得到的结果存储在 `I` 中。
9 ]5 q" M1 S2 J' l C/ y
- 将当前步长 `h`、计算得到的数值积分 `I` 和与理论值 \( \frac{1}{15} \) 的误差 \( 1/15 - I \) 存储到 `v` 中。
/ M. u4 B: T7 x% s& Q4 S' v
% c3 O, r2 d+ ]8 I7 N+ y
### 总结
+ t4 ?! g0 I7 H _
这段代码通过图形显示、符号积分和数值积分来综合比较结果,展示了函数 `y = cos(15*x)` 的行为。通过不同的步长进行数值积分,并对结果与理论值进行比较,可以分析数值积分的精度随步长变化的情况。这是一种在数值分析中检验数值方法有效性的常见手段。
2 V9 q: t! a, r" m: Z
1 V- u+ o! G" T+ o9 g# H5 n; a
2 { j" g, v) l& d' c
3 z# u2 M9 V, U/ m* @
examp3_29.m
2024-9-30 09:51 上传
点击文件名下载附件
下载积分: 体力 -2 点
289 Bytes, 下载次数: 0, 下载积分: 体力 -2 点
售价:
2 点体力
[
记录
] [
购买
]
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5