我有一个节点网络,可以在其中传递结构化数据。对于我的子问题,我们有这样一个分支-节点的线性序列:
nodes = [source, n1, n2, n3, n4]
第一个节点是生成器,每个其他节点从输入节点获取值并提供输出值。当前实现是从管道中获取(get())数据并将其放入管道(put()),每个节点都有单独的线程(这样做是有原因的)。我想将其更改为使用 yield
迭代器。
如果我们将节点视为可调用对象,我希望按以下方式进行评估:
for result in n4(n3(n2(n1(source()))):
print result
我想象评估上下文的构建方式如下所示:
context = src
for node in nodes[1:]:
context = pipe(context, node)
for result in context:
print result
局限性:
我仍然希望能够单独使用节点 - 不是嵌套的,通过其他方式传输数据,因为节点可能在不同的线程中。例如:[source,n1,n2]
在一个线程中(可能是嵌套的),[n3,n4]
在另一个线程中(可能是嵌套的),数据在n2
和n3
之间传输。情况:可能存在非线性节点图,我想以这种方式分组分支。
node
必须是一个类来保存计算状态。
context
的实现和pipe(context,node)
的实现应该如何?或者如果可以用不同的方式解决它,你有什么建议?
Python 3.3中的yield from
(PEP380)能否在我的案例中有所帮助?
nodes = [...]
。 - Stiivireduce
和partial
存在于标准库中。你很可能可以轻松地编写自己的compose
版本。 - Marcin