【发布时间】:2011-05-25 17:58:00
【问题描述】:
我正在尝试使用我在 lambda 中使用 sympy.Eq(func, var) 生成的等式。它似乎正在返回一个“添加”对象列表,我不确定如何使用。在使用eval 之前,我尝试将类型转换为str,并尝试了from sympy import I,我认为这与问题有关。
这是代码和错误消息:
py solid.py -v y = (x-1.0)(x-3.0)*2 1.0 3.0 -axis y --方法盘
这是一个运行示例:
import sys
import argparse
import math
from scipy import integrate
from sympy import Symbol, Eq, solve, I
import numpy
import pylab
parser = argparse.ArgumentParser(description='Find the volume of the solid of rotation defined. Use * for multiplication and ** to raise a power. Bounds are set equal to the implicit variable. Trailing .0\'s must be used for constants, and parentheses must be escaped ( e.g. \(x-2\) ). Answers are accurate to 6 decimals')
parser.add_argument('var', choices='xy', help='x|y')
parser.add_argument('=', metavar='=', choices='=')
parser.add_argument('equation', help='continous function')
parser.add_argument('a', type=float, help='bound \'a\'')
parser.add_argument('b', type=float, help='bound \'b\'')
parser.add_argument('-axis', choices='xy', help='axis of revolution (default == x)')
parser.add_argument('-m', choices='ds', help='method (disk/shell)')
parser.add_argument('-g', action='store_true', help='show graph')
parser.add_argument('-v', action='store_true', help='verbose (for debugging)')
args = parser.parse_args()
y = Symbol('y')
x = Symbol('x')
def solve_for_implicit(func, var):
if var == 'x':
equation = Eq(eval(func), x)
func = solve(equation, y)
else:
equation = Eq(eval(func), y)
func = solve(equation, x)
return func
def volume(var, func, a, b, axis=None, method=None):
if axis == None: axis = 'x'
if method == 's': method = 'shell'
if method == 'd': method = 'disk'
if var == axis and axis == 'x':
if args.v: print 'x = y about x'
if not method == 'disk':
pass
else:
pass
elif var == axis and axis == 'y':
# SHELL METHOD
if args.v: print 'y = x about y'
if not method == 'disk':
# this is what should be used for y = x about y
if args.v: print 'using SHELL method'
func = eval('lambda x: ' + 'x*(' + func + ')')
integral = integrate.quad(func, a, b)
if args.v: print 'integral from', a, 'to', b, '=', integral[0]
answer = 2 * math.pi * integral[0]
if args.v: print '2*pi*', integral[0], '=', answer
else:
func = solve_for_implicit(func, var)
print func[0]
func = eval('lambda y: ' + '(' + str(func[0]) + ')**2')
integral = integrate.quad(func, a, b)
if args.v: print 'integral=', integral[0]
answer = math.pi * integral[0]
elif not var == axis and axis == 'y':
# DISK METHOD
if args.v: print 'x = y about y -- '
if not method == 'shell':
pass
else:
pass
elif not var == axis and axis == 'x':
# DISK
if args.v: print 'y = x about x --',
if not method == 'shell':
pass
else:
pass
return answer
print volume(args.var, args.equation, args.a, args.b, args.axis, args.m)
if args.g: graph(args.equation, args.a, args.b)
回溯(最近一次通话最后一次):
文件“solid.py”,第 136 行,在 打印量(args.var,args.equation,args.a,args.b, args.axis,args.m)文件“solid.py”, 第 75 行,体积 func = eval('lambda y: ' + '(' + func[0] + ')**2') 类型错误:不能 连接 'str' 和 'Add' 对象
当我首先尝试将其类型转换为 str() 时,我得到了这个:
文件“solid.py”,第 136 行,在 打印量(args.var,args.equation,args.a,args.b, args.axis,args.m)文件“solid.py”, 第 76 行,体积 积分 = 积分.quad(func, a, b) 文件 “/usr/lib/python2.6/dist-packages/scipy/integrate/quadpack.py”, 第 185 行,四边形 retval = _quad(func,a,b,args,full_output,epsabs,epsrel,limit,points) 文件 “/usr/lib/python2.6/dist-packages/scipy/integrate/quadpack.py”, 第 249 行,在 _quad return _quadpack._qagse(func,a,b,args,full_output,epsabs,epsrel,limit) quadpack.error:提供的功能确实 没有返回一个有效的浮点数。
另外,print func[0] 给出:
2.33333333333333 + (0.296296296296298 - y/2 + (-0.0877914951989024 + (0.592592592592595 - y)2/4)(1/2))(1/3)*(1/2 - 我*3(1/2)/2) + 0.444444444444444/((1/2 - I*3*(1/2)/2)(0.296296296296298 - y/2 + (-0.0877914951989024 + (0.592592592592595 - y)2/4)(1/2))**(1/3))
感谢大家的帮助,之前没有提供完整的脚本很抱歉。
【问题讨论】:
-
func 是一个 lambda,例如
lambda x: x**2 -
这一切都不合拍。 func 不能是函数。当您仅使用 str(...) 获得第二个错误消息时,不应出现第一个错误消息。请发布一个重现错误的最小可运行示例。你为什么要使用 eval 顺便说一句。?对我来说似乎完全没有必要,让一切都变得完全不可读。
func = lambda y: float(func[0])**2应该可以胜任。 -
添加了一个可运行的示例,我使用 eval 因为我并不总是通过
sympy.Eq(func, var)运行我的输入 -
这仍然不是一个最小的可运行示例。它没有运行(模块级别上没有调用卷的代码)我仍然无法弄清楚 func 是什么,它确实依赖于其他一些非标准库,除了我没有的 sympy (argparse)。关于 eval,也许你应该看看
sympy.sympify如果这没有帮助我不明白你的意思。