matlab 定步长积分,数值积分:基于牛顿-柯茨公式的定步长和自适应积分方法 [MATLAB]...

这篇博客介绍了MATLAB中使用牛顿-柯茨公式进行定步长积分以及实现自适应分段积分的方法。提供了可以直接使用的MATLAB函数,包括中点、梯形和辛普森法则,并展示了如何根据误差估算进行积分段的调整以提高精度。
摘要由CSDN通过智能技术生成

#先上代码后补笔记#

#可以直接复制粘贴使用的MATLAB函数!#

1. 定步长牛顿-柯茨积分公式

function [ integration ] = CompoInt( func, left, right, step, mode )

% 分段积分牛顿-柯茨公式;

% 输入5个参数:被积函数(FUNCTIONHANDLE)'func',积分上下界'left'/'right',步长'step',

% 模式mode共三种('midpoint','trapezoid','simpson');

% 返回积分值;

switch mode

% 仅仅是公式不同

case 'midpoint'

node = left; integration = 0;

while (node + step <= right) % 按照给定步长开始分段积分

pieceInt = step*(func(node + step/2)); % 使用中点积分公式

integration = integration + pieceInt; node = node + step;

end

if (node < right) % 补齐最后一段积分

pieceInt = (right - node)*(func((node + right)/2));

integration = integration + pieceInt;

end

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值