scipy.integrate.romberg#
- scipy.integrate.romberg(function, a, b, args=(), tol=1.48e-08, rtol=1.48e-08, show=False, divmax=10, vec_func=False)[source]#
- Romberg integration of a callable function or method. - Returns the integral of function (a function of one variable) over the interval (a, b). - If show is 1, the triangular array of the intermediate results will be printed. If vec_func is True (default is False), then function is assumed to support vector arguments. - Parameters
- functioncallable
- Function to be integrated. 
- afloat
- Lower limit of integration. 
- bfloat
- Upper limit of integration. 
 
- Returns
- resultsfloat
- Result of the integration. 
 
- Other Parameters
- argstuple, optional
- Extra arguments to pass to function. Each element of args will be passed as a single argument to func. Default is to pass no extra arguments. 
- tol, rtolfloat, optional
- The desired absolute and relative tolerances. Defaults are 1.48e-8. 
- showbool, optional
- Whether to print the results. Default is False. 
- divmaxint, optional
- Maximum order of extrapolation. Default is 10. 
- vec_funcbool, optional
- Whether func handles arrays as arguments (i.e., whether it is a “vector” function). Default is False. 
 
 - See also - fixed_quad
- Fixed-order Gaussian quadrature. 
- quad
- Adaptive quadrature using QUADPACK. 
- dblquad
- Double integrals. 
- tplquad
- Triple integrals. 
- romb
- Integrators for sampled data. 
- simpson
- Integrators for sampled data. 
- cumulative_trapezoid
- Cumulative integration for sampled data. 
- ode
- ODE integrator. 
- odeint
- ODE integrator. 
 - References - 1
- ‘Romberg’s method’ https://en.wikipedia.org/wiki/Romberg%27s_method 
 - Examples - Integrate a gaussian from 0 to 1 and compare to the error function. - >>> from scipy import integrate >>> from scipy.special import erf >>> gaussian = lambda x: 1/np.sqrt(np.pi) * np.exp(-x**2) >>> result = integrate.romberg(gaussian, 0, 1, show=True) Romberg integration of <function vfunc at ...> from [0, 1] - Steps StepSize Results 1 1.000000 0.385872 2 0.500000 0.412631 0.421551 4 0.250000 0.419184 0.421368 0.421356 8 0.125000 0.420810 0.421352 0.421350 0.421350 16 0.062500 0.421215 0.421350 0.421350 0.421350 0.421350 32 0.031250 0.421317 0.421350 0.421350 0.421350 0.421350 0.421350 - The final result is 0.421350396475 after 33 function evaluations. - >>> print("%g %g" % (2*result, erf(1))) 0.842701 0.842701