Я использовал функцию eval для оценки функции. код написан ниже:
import numpy as np
import sympy
from sympy import Symbol, Add
s = sympy.Symbol('s')
x = [ s, s+1, 10*s**2, 5]
a = [1 + 1j, 2 , 3 , 4 , 5]
fun = Add(*x) # Create a function by adding all terms. * is to unpack all the values
def F(fun, v):
return fun.evalf(subs = {s: v}) # Evaluate the function at s=v
f_dis = [F(fun, v) for v in a]
print (f_dis)
fit3 = np.asanyarray(f_dis)
print ("fit3 = ", fit3)
realpart = fit3.real[0]
print ("real = ", realpart)
результат f_dis
есть
[8.0 + 22.0*I, 50.0000000000000, 102.000000000000, 174.000000000000, 266.000000000000]
Дело в том, что код показывает 8.0 + 22.0*I
как реальную часть первого элемента, а не только 8
.
Что мне делать, чтобы решить эту проблему?
Спасибо.
Вы можете использовать re
из Sympy
, чтобы получить только реальную часть оцениваемого выражения.
import numpy as np
from sympy import Symbol, Add, re
s = Symbol('s')
x = [ s, s+1, 10*s**2, 5]
a = [1 + 1j, 2 , 3 , 4 , 5]
fun = Add(*x) # Create a function by adding all terms. * is to unpack all the values
def F(fun, v):
return fun.evalf(subs = {s: v}) # Evaluate the function at s=v
f_dis = [re(F(fun, v)) for v in a] # <---- Use re() here
print (f_dis)
# [8.00000000000000, 50.0000000000000, 102.000000000000, 174.000000000000, 266.000000000000]