提交 05573157 authored 作者: sentient07's avatar sentient07

Applying all possible optimizers to a node

上级 e8bf9c1f
...@@ -1267,18 +1267,27 @@ class LocalOptGroup(LocalOptimizer): ...@@ -1267,18 +1267,27 @@ class LocalOptGroup(LocalOptimizer):
def transform(self, node): def transform(self, node):
repl = False repl = False
counter = 0 counter = 0
for opt in self.opts: def apply_mult_opts(opt_list, node, single_opts=True):
repl = opt.transform(node) repl = False
if repl: assert isinstance(opt_list, tuple)
counter += 1 if len(opt_list) == 0:
if self.apply_all_opts: return
assert len(repl) == 1 for opt in opt_list:
node = repl[0].owner repl = opt.transform(node)
if not repl:
continue continue
return repl else:
if counter >=2: if single_opts or not repl[0].owner:
print("No of times the node is optimized : " + str(counter)) return repl
return repl assert len(repl) == 1
# Ensuring not the input of graph
assert repl[0].owner
new_node = repl[0].owner
apply_mult_opts(opt_list, repl[0].owner, False)
return repl
return apply_mult_opts(self.opts, node, self.apply_all_opts)
def print_summary(self, stream=sys.stdout, level=0, depth=-1): def print_summary(self, stream=sys.stdout, level=0, depth=-1):
print("%s%s id=%i" % ( print("%s%s id=%i" % (
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论