您可以通过传递一个简单的生成器表达式来求和:
def sigma(funcs, x):
return sum(f(x) for f in funcs)
phi = [lambda x: x**2, lambda x: x]
y = sigma(phi, x)
顺便说一句,将lambda用于命名函数被认为是不好的风格,应该用于匿名函数.
如果您想要一个不需要每次调用都传递phi的函数,则有两种方法可以实现.最简单的方法是在函数中简单地使用phi.例如,
def sigma(x):
return sum(f(x) for f in phi)
但是,这有两个缺点.如果phi不在您称为sigma的范围内,则该方法将无效.您可以通过将phi设置为全局变量来解决此问题,但这可能并不方便,最好不要使用全局变量.另一个缺点是,它使用的是phi的当前内容,而不是定义sigma时的内容,因此,如果修改phi的内容,这些更改将反映在sigma中,这可能是可取的,也可能是不希望的.
另一种选择是使用closure创建函数.这样我们就不会受到范围问题的影响:您可以在看不见原始函数列表的范围内调用结果求和函数.我们还可以创建功能列表的副本,因此它不会受到传入功能列表更改的影响.
def make_adder(funcs):
# Copy the function list
funcs = funcs[:]
def sigma(x):
return sum(f(x) for f in funcs)
return sigma
phi = [lambda x: x**2, lambda x: x]
sigma = make_adder(phi)
y = sigma(x)
另一个选择是使用我的原始sigma并将其和phi函数传递给functools.partial,例如
from functools import partial
sig = partial(sigma, phi)
y = sig(x)