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