adaptive_integrator< Function > Class Template Reference

#include <adaptive.h>

Inheritance diagram for adaptive_integrator< Function >:

iterative_method

List of all members.

Public Member Functions

 adaptive_integrator (Function &f, unsigned int iterations=100, double relative_error=1.0e-15)
 ~adaptive_integrator ()
double integrate (double a, double b)


Detailed Description

template<class Function>
class adaptive_integrator< Function >

An implementation of adaptive quadrature.

For example, to evaluate definite integrals for sine, first a Simpson's integrator is created providing a target function functor:

typdef double Function(double);

num::adpative_integrator<Function> integrator(std::sin);

Then, evaluating definite integrals is accomplished using the integrate method:

// integrate sine from 0 to Pi.

double two = integrator.integrate(0.0, num::PI);

integrate sine from Pi/2 to 2 Pi.
double one = integrator.integrate(num::PI / 2.0, num::PI);

References:

  1. "Adaptive Quadrature." http://www.cse.uiuc.edu/eot/modules/integration/adaptivq/

Constructor & Destructor Documentation

template<class Function>
adaptive_integrator< Function >::adaptive_integrator ( Function &  f,
unsigned int  iterations = 100,
double  relative_error = 1.0e-15 
) [inline]

Create an integrator for the given function.

Parameters:
f the function functor.
iterations the maximum number of iterations.
relative_error the maximum allowable relative error.

template<class Function>
adaptive_integrator< Function >::~adaptive_integrator (  )  [inline]

Destructor.


Member Function Documentation

template<class Function>
double adaptive_integrator< Function >::integrate ( double  a,
double  b 
) [inline]

Evaluate the definite integral from a to b.

Parameters:
a the lower limit of integration.
b the upper limit of integration.
Returns:
the definite integral from a to b.


The documentation for this class was generated from the following file:
Generated on Wed Nov 21 22:22:15 2007 for numerics4c++ by  doxygen 1.5.3