Numpy 累积simpson积分与scipy

Numpy 累积simpson积分与scipy,numpy,scipy,numerical-integration,Numpy,Scipy,Numerical Integration,我有一些代码使用scipy.integration.cumtrapz计算采样信号的反导数。我想用辛普森法则代替梯形。然而,scipy.integration.simps似乎没有累积对应项。。。我错过什么了吗?有没有一种简单的方法可以通过“scipy.integration.simps”获得累积积分?您可以自己编写: def cumsimp(func,a,b,num): #Integrate func from a to b using num intervals. num*=2

我有一些代码使用scipy.integration.cumtrapz计算采样信号的反导数。我想用辛普森法则代替梯形。然而,scipy.integration.simps似乎没有累积对应项。。。我错过什么了吗?有没有一种简单的方法可以通过“scipy.integration.simps”获得累积积分?

您可以自己编写:

def cumsimp(func,a,b,num):
    #Integrate func from a to b using num intervals.

    num*=2
    a=float(a)
    b=float(b)
    h=(b-a)/num

    output=4*func(a+h*np.arange(1,num,2))
    tmp=func(a+h*np.arange(2,num-1,2))
    output[1:]+=tmp
    output[:-1]+=tmp 
    output[0]+=func(a)
    output[-1]+=func(b)
    return np.cumsum(output*h/3)

def integ1(x):
    return x

def integ2(x):
    return x**2

def integ0(x):
    return np.ones(np.asarray(x).shape)*5
首先看一个常数函数的和和和导数

print cumsimp(integ0,0,10,5)
[ 10.  20.  30.  40.  50.]

print np.diff(cumsimp(integ0,0,10,5))
[ 10.  10.  10.  10.]
现在,请查看几个简单的示例:

print cumsimp(integ1,0,10,5)
[  2.   8.  18.  32.  50.]

print cumsimp(integ2,0,10,5)
[   2.66666667   21.33333333   72.          170.66666667  333.33333333]
在这里,显式编写被积函数要比在此上下文中复制scipy的辛普森规则函数容易得多。如果提供单个阵列,则很难执行拾取间隔,您是否:

  • 对辛普森规则的边使用其他每一个值,其余的值作为中心
  • 将阵列用作边并插值中心值

对于如何求和间隔,还有一些选项。这些并发症可能是它没有在scipy中编码的原因

你的问题很久以前就得到了回答,但我最近遇到了同样的问题。我写了一些函数来计算等距点的累积积分;该代码可在上找到。插值多项式的阶数范围为1(梯形规则)到7。正如Daniel在前面的回答中所指出的,必须对间隔的求和方式做出一些选择,尤其是在边界处;因此,根据您使用的软件包,结果可能会明显不同。还要注意,对于高阶多项式,数值积分可能会受到龙格现象(意外振荡)的影响

以下是一个例子:

import numpy as np
from scipy import integrate as sp_integrate
from gradiompy import integrate as gp_integrate

# Definition of the function (polynomial of degree 7)
x = np.linspace(-3,3,num=15)
dx = x[1]-x[0]
y = 8*x + 3*x**2 + x**3 - 2*x**5 + x**6 - 1/5*x**7
y_int = 4*x**2 + x**3 + 1/4*x**4 - 1/3*x**6 + 1/7*x**7 - 1/40*x**8

# Cumulative integral using scipy
y_int_trapz = y_int [0] + sp_integrate.cumulative_trapezoid(y,dx=dx,initial=0)
print('Integration error using scipy.integrate:')
print('  trapezoid = %9.5f' % np.linalg.norm(y_int_trapz-y_int))

# Cumulative integral using gradiompy
y_int_trapz = gp_integrate.cumulative_trapezoid(y,dx=dx,initial=y_int[0])
y_int_simps = gp_integrate.cumulative_simpson(y,dx=dx,initial=y_int[0])
print('\nIntegration error using gradiompy.integrate:')
print('  trapezoid = %9.5f' % np.linalg.norm(y_int_trapz-y_int))
print('  simpson   = %9.5f' % np.linalg.norm(y_int_simps-y_int))

# Higher order cumulative integrals
for order in range(5,8,2):
    y_int_composite = gp_integrate.cumulative_composite(y,dx,order=order,initial=y_int[0])
    print('  order %i   = %9.5f' % (order,np.linalg.norm(y_int_composite-y_int)))
    
# Display the values of the cumulative integral
print('\nCumulative integral (with initial offset):\n',y_int_composite)
您应该得到以下结果:

'''
Integration error using scipy.integrate:
  trapezoid = 176.10502

Integration error using gradiompy.integrate:
  trapezoid = 176.10502
  simpson   =   2.52551
  order 5   =   0.48758
  order 7   =   0.00000

Cumulative integral (with initial offset):
 [-6.90203571e+02 -2.29979407e+02 -5.92267425e+01 -7.66415188e+00
  2.64794452e+00  2.25594840e+00  6.61937372e-01  1.14797061e-13
  8.20130517e-01  3.61254267e+00  8.55804341e+00  1.48428883e+01
  1.97293221e+01  1.64257877e+01 -1.13464286e+01]
'''