通过数值积分和符号积分计算函数的定积分
MATLAB代码展示了如何通过数值积分和符号积分计算函数的定积分,并对不同步长的数值积分结果进行比较。以下是逐步解析:### 1. 创建自变量和函数
```matlab
x = ; % 包含 3π/2 这一点
y = cos(15*x);
plot(x, y) % 绘制 y = cos(15*x) 的图形
```
- `x` 创建了一个从 0 到 \( \frac{3\pi}{2} \) 的向量,并确保 \( \frac{3\pi}{2} \) 这个点被包含在内。
- `y` 计算了在 `x` 每个点上的 `cos(15*x)` 值。
- 使用 `plot(x, y)` 绘制了函数 `y = cos(15*x)` 的图形。
### 2. 计算理论值
```matlab
syms x, A = int(cos(15*x), 0, 3*pi/2); % 使用符号积分求取定积分
```
- `syms x` 定义符号变量 `x`。
- `int(cos(15*x), 0, 3*pi/2)` 计算 `cos(15*x)` 从 0 到 \( \frac{3\pi}{2} \) 的定积分 `A`,这个结果为理论值。
### 3. 定义步长并进行数值积分
```matlab
h0 = ;
v = [];
for h = h0,
x = ;
y = cos(15*x);
I = trapz(x, y); % 使用梯形法进行数值积分
v = ; % 将步长、数值积分结果和错误存储到 v 中
end
```
- `h0` 是一个数组,包含了不同的步长值,用于进行数值积分。
- `v = []` 初始化一个空数组 `v`,用于存储每种步长的结果。
- 对于每个步长 `h`,代码:
- 创建新的 `x` 向量,从 0 到 \( \frac{3\pi}{2} \),步长为 `h`,并确保包含 \( \frac{3\pi}{2} \)。
- 计算 `y = cos(15*x)`。
- 使用 `trapz(x, y)` 进行数值积分,得到的结果存储在 `I` 中。
- 将当前步长 `h`、计算得到的数值积分 `I` 和与理论值 \( \frac{1}{15} \) 的误差 \( 1/15 - I \) 存储到 `v` 中。
### 总结
这段代码通过图形显示、符号积分和数值积分来综合比较结果,展示了函数 `y = cos(15*x)` 的行为。通过不同的步长进行数值积分,并对结果与理论值进行比较,可以分析数值积分的精度随步长变化的情况。这是一种在数值分析中检验数值方法有效性的常见手段。
页:
[1]