Here's a MATLAB function that implements the repeated Simpson's rule for approximating the integral of a function and also calculates the error estimate:
main.m637 chars24 linesHere, f is the function to integrate, a and b are the limits of integration, and n is the number of intervals to use (which must be even). The function uses the formula for Simpson's rule to approximate the integral over each pair of adjacent intervals, and then sums up the results. To calculate the error estimate, we use the estimate from the error term for Simpson's rule, which is based on the fourth derivative of the function being integrated. We approximate this derivative by taking the maximum absolute value of the fourth derivative over the interval of integration. Note that this implementation assumes that the fourth derivative exists and is continuous over the interval of integration.
gistlibby LogSnag