0

mpmath.quad を使用して、sympy によって単純化された関数の整数値を評価したいと考えています。

次に、次のコードを使用しました

from sympy import *
import mpmath as mp
r = symbols("r")
f = 4**(-r)*r*(0.115391565000863*2**r + 693.147180559945)*exp(-0.000332949677174323*2**r)
mp.quad(lambda r:f,[0,1])

しかし、このエラーメッセージが表示されます

    ---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-8-715cd610bbdb> in <module>()
      3 r = symbols("r")
      4 f = 4**(-r)*r*(0.115391565000863*2**r + 693.147180559945)*exp(-0.000332949677174323*2**r)
----> 5 mp.quad(lambda r:f,[0,1])

5 frames

/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py in _convert_fallback(ctx, x, strings)
    632             else:
    633                 raise ValueError("can only create mpf from zero-width interval")
--> 634         raise TypeError("cannot create mpf from " + repr(x))
    635 
    636     def mpmathify(ctx, *args, **kwargs):

TypeError: cannot create mpf from 4**(-r)*r*(0.115391565000863*2**r + 693.147180559945)*exp(-0.000332949677174323*2**r)

別の簡単な機能を試す

from sympy import *
import mpmath as mp
x = symbols("x")
f = x*2
mp.quad(lambda x:f,[1,2])

同じエラーメッセージも表示されます

TypeError: cannot create mpf from 2*x

このエラーメッセージの原因と、クワッド関数を正しく使用する方法を誰かが知っていますか?

4

1 に答える 1