Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
fa74d7e3
提交
fa74d7e3
authored
5月 22, 2021
作者:
Brandon T. Willard
提交者:
Brandon T. Willard
5月 22, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Rename aesara.graph.toolbox to aesara.graph.features
上级
4403e131
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
24 个修改的文件
包含
32 行增加
和
35 行删除
+32
-35
debugmode.py
aesara/compile/debugmode.py
+1
-1
types.py
aesara/compile/function/types.py
+1
-1
opt.py
aesara/gpuarray/opt.py
+3
-3
destroyhandler.py
aesara/graph/destroyhandler.py
+1
-1
features.py
aesara/graph/features.py
+0
-0
fg.py
aesara/graph/fg.py
+3
-7
opt.py
aesara/graph/opt.py
+1
-1
toolbox.py
aesara/graph/toolbox.py
+0
-0
ifelse.py
aesara/ifelse.py
+1
-1
op.py
aesara/scan/op.py
+1
-1
opt.py
aesara/scan/opt.py
+1
-1
basic_opt.py
aesara/tensor/basic_opt.py
+3
-3
blas.py
aesara/tensor/blas.py
+1
-1
optimization.txt
doc/extending/optimization.txt
+3
-3
features.txt
doc/library/graph/features.txt
+3
-3
fgraph.txt
doc/library/graph/fgraph.txt
+1
-1
index.txt
doc/library/graph/index.txt
+1
-1
setup.cfg
setup.cfg
+1
-0
test_debugmode.py
tests/compile/test_debugmode.py
+1
-1
test_mode.py
tests/compile/test_mode.py
+1
-1
test_destroyhandler.py
tests/graph/test_destroyhandler.py
+1
-1
test_features.py
tests/graph/test_features.py
+1
-1
test_math_opt.py
tests/tensor/test_math_opt.py
+1
-1
test_subtensor.py
tests/tensor/test_subtensor.py
+1
-1
没有找到文件。
aesara/compile/debugmode.py
浏览文件 @
fa74d7e3
...
...
@@ -30,9 +30,9 @@ from aesara.compile.ops import OutputGuard, _output_guard
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Variable
,
graph_inputs
,
io_toposort
from
aesara.graph.destroyhandler
import
DestroyHandler
from
aesara.graph.features
import
BadOptimization
from
aesara.graph.fg
import
InconsistencyError
from
aesara.graph.op
import
COp
,
Op
,
ops_with_inner_function
from
aesara.graph.toolbox
import
BadOptimization
from
aesara.graph.utils
import
MethodNotDefined
from
aesara.link.basic
import
Container
,
LocalLinker
from
aesara.link.utils
import
map_storage
,
raise_with_op
...
...
aesara/compile/function/types.py
浏览文件 @
fa74d7e3
...
...
@@ -30,9 +30,9 @@ from aesara.graph.basic import (
vars_between
,
)
from
aesara.graph.destroyhandler
import
DestroyHandler
from
aesara.graph.features
import
PreserveVariableAttributes
,
is_same_graph
from
aesara.graph.fg
import
FunctionGraph
,
InconsistencyError
from
aesara.graph.op
import
ops_with_inner_function
from
aesara.graph.toolbox
import
PreserveVariableAttributes
,
is_same_graph
from
aesara.graph.utils
import
get_variable_trace_string
from
aesara.link.basic
import
Container
from
aesara.link.utils
import
raise_with_op
...
...
aesara/gpuarray/opt.py
浏览文件 @
fa74d7e3
...
...
@@ -149,7 +149,7 @@ from aesara.gpuarray.type import (
get_context
,
move_to_gpu
,
)
from
aesara.graph
import
toolbox
from
aesara.graph
import
features
from
aesara.graph.basic
import
Constant
,
Variable
,
applys_between
,
clone_replace
from
aesara.graph.fg
import
FunctionGraph
from
aesara.graph.opt
import
(
...
...
@@ -244,7 +244,7 @@ class InputToGpuOptimizer(GlobalOptimizer):
"""
def
add_requirements
(
self
,
fgraph
):
fgraph
.
attach_feature
(
toolbox
.
ReplaceValidate
())
fgraph
.
attach_feature
(
features
.
ReplaceValidate
())
def
apply
(
self
,
fgraph
):
for
input
in
fgraph
.
inputs
:
...
...
@@ -305,7 +305,7 @@ class GraphToGPU(GlobalOptimizer):
self
.
local_optimizers_map
=
local_optimizers_map
def
add_requirements
(
self
,
fgraph
):
fgraph
.
attach_feature
(
toolbox
.
ReplaceValidate
())
fgraph
.
attach_feature
(
features
.
ReplaceValidate
())
def
apply
(
self
,
fgraph
):
mapping
=
{}
...
...
aesara/graph/destroyhandler.py
浏览文件 @
fa74d7e3
...
...
@@ -9,8 +9,8 @@ from collections import OrderedDict, deque
import
aesara
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Constant
from
aesara.graph.features
import
AlreadyThere
,
Bookkeeper
from
aesara.graph.fg
import
InconsistencyError
from
aesara.graph.toolbox
import
AlreadyThere
,
Bookkeeper
from
aesara.misc.ordered_set
import
OrderedSet
...
...
aesara/graph/features.py
0 → 100644
浏览文件 @
fa74d7e3
差异被折叠。
点击展开。
aesara/graph/fg.py
浏览文件 @
fa74d7e3
...
...
@@ -8,7 +8,7 @@ from aesara.configdefaults import config
from
aesara.graph.basic
import
Apply
,
Constant
,
Variable
,
applys_between
from
aesara.graph.basic
import
as_string
as
graph_as_string
from
aesara.graph.basic
import
clone_get_equiv
,
graph_inputs
,
io_toposort
,
vars_between
from
aesara.graph.
toolbox
import
AlreadyThere
,
Feature
,
ReplaceValidate
from
aesara.graph.
features
import
AlreadyThere
,
Feature
,
ReplaceValidate
from
aesara.graph.utils
import
MetaObject
,
TestValueError
,
get_variable_trace_string
from
aesara.misc.ordered_set
import
OrderedSet
...
...
@@ -548,16 +548,12 @@ class FunctionGraph(MetaObject):
)
def
replace_all
(
self
,
pairs
:
List
[
Tuple
[
Variable
,
Variable
]],
**
kwargs
)
->
NoReturn
:
"""Replace variables in the `
FunctionGraph` according to `(var, new_var)
` pairs in a list."""
"""Replace variables in the `
`FunctionGraph`` according to ``(var, new_var)`
` pairs in a list."""
for
var
,
new_var
in
pairs
:
self
.
replace
(
var
,
new_var
,
**
kwargs
)
def
attach_feature
(
self
,
feature
:
Feature
)
->
NoReturn
:
"""
Adds a graph.toolbox.Feature to this function_graph and triggers its
on_attach callback.
"""
"""Add a ``graph.features.Feature`` to this function graph and trigger its on_attach callback."""
# Filter out literally identical `Feature`s
if
feature
in
self
.
_features
:
return
# the feature is already present
...
...
aesara/graph/opt.py
浏览文件 @
fa74d7e3
...
...
@@ -31,9 +31,9 @@ from aesara.graph.basic import (
io_toposort
,
nodes_constructed
,
)
from
aesara.graph.features
import
Feature
,
NodeFinder
from
aesara.graph.fg
import
InconsistencyError
from
aesara.graph.op
import
Op
from
aesara.graph.toolbox
import
Feature
,
NodeFinder
from
aesara.graph.utils
import
AssocList
from
aesara.misc.ordered_set
import
OrderedSet
from
aesara.utils
import
flatten
...
...
aesara/graph/toolbox.py
浏览文件 @
fa74d7e3
差异被折叠。
点击展开。
aesara/ifelse.py
浏览文件 @
fa74d7e3
...
...
@@ -600,7 +600,7 @@ class CondMerge(GlobalOptimizer):
""" Graph Optimizer that merges different cond ops """
def
add_requirements
(
self
,
fgraph
):
from
aesara.graph.
toolbox
import
ReplaceValidate
from
aesara.graph.
features
import
ReplaceValidate
fgraph
.
add_feature
(
ReplaceValidate
())
...
...
aesara/scan/op.py
浏览文件 @
fa74d7e3
...
...
@@ -70,9 +70,9 @@ from aesara.graph.basic import (
graph_inputs
,
io_connection_pattern
,
)
from
aesara.graph.features
import
NoOutputFromInplace
from
aesara.graph.fg
import
MissingInputError
from
aesara.graph.op
import
Op
,
ops_with_inner_function
from
aesara.graph.toolbox
import
NoOutputFromInplace
from
aesara.link.c.basic
import
CLinker
from
aesara.link.c.exceptions
import
MissingGXX
from
aesara.link.utils
import
raise_with_op
...
...
aesara/scan/opt.py
浏览文件 @
fa74d7e3
...
...
@@ -73,11 +73,11 @@ from aesara.graph.basic import (
is_in_ancestors
,
)
from
aesara.graph.destroyhandler
import
DestroyHandler
from
aesara.graph.features
import
ReplaceValidate
from
aesara.graph.fg
import
InconsistencyError
from
aesara.graph.op
import
compute_test_value
from
aesara.graph.opt
import
GlobalOptimizer
,
in2out
,
local_optimizer
from
aesara.graph.optdb
import
EquilibriumDB
,
SequenceDB
from
aesara.graph.toolbox
import
ReplaceValidate
from
aesara.scan.op
import
Scan
from
aesara.scan.utils
import
(
compress_outs
,
...
...
aesara/tensor/basic_opt.py
浏览文件 @
fa74d7e3
...
...
@@ -18,7 +18,7 @@ from aesara import compile
from
aesara.assert_op
import
Assert
,
assert_op
from
aesara.compile.ops
import
ViewOp
from
aesara.configdefaults
import
config
from
aesara.graph
import
toolbox
from
aesara.graph
import
features
from
aesara.graph.basic
import
(
Constant
,
Variable
,
...
...
@@ -797,7 +797,7 @@ class MakeVectorPrinter:
pprint
.
assign
(
MakeVector
,
MakeVectorPrinter
())
class
ShapeFeature
(
toolbox
.
Feature
):
class
ShapeFeature
(
features
.
Feature
):
"""Graph optimizer for removing all calls to shape().
This optimizer replaces all Shapes and Subtensors of Shapes with
...
...
@@ -4674,7 +4674,7 @@ class FusionOptimizer(GlobalOptimizer):
self
.
optimizer
=
local_optimizer
def
add_requirements
(
self
,
fgraph
):
fgraph
.
attach_feature
(
toolbox
.
ReplaceValidate
())
fgraph
.
attach_feature
(
features
.
ReplaceValidate
())
def
apply
(
self
,
fgraph
):
did_something
=
True
...
...
aesara/tensor/blas.py
浏览文件 @
fa74d7e3
...
...
@@ -146,6 +146,7 @@ import aesara.scalar
from
aesara.compile.mode
import
optdb
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Apply
,
view_roots
from
aesara.graph.features
import
ReplacementDidNotRemoveError
,
ReplaceValidate
from
aesara.graph.fg
import
InconsistencyError
from
aesara.graph.op
import
COp
,
Op
from
aesara.graph.opt
import
(
...
...
@@ -157,7 +158,6 @@ from aesara.graph.opt import (
)
from
aesara.graph.optdb
import
SequenceDB
from
aesara.graph.params_type
import
ParamsType
from
aesara.graph.toolbox
import
ReplacementDidNotRemoveError
,
ReplaceValidate
from
aesara.graph.utils
import
MethodNotDefined
,
TestValueError
from
aesara.printing
import
FunctionPrinter
,
debugprint
,
pprint
from
aesara.scalar
import
bool
as
bool_t
...
...
doc/extending/optimization.txt
浏览文件 @
fa74d7e3
...
...
@@ -123,7 +123,7 @@ simplification described above:
import aesara
from aesara.graph.opt import GlobalOptimizer
from aesara.graph.
toolbox
import ReplaceValidate
from aesara.graph.
features
import ReplaceValidate
class Simplify(GlobalOptimizer):
def add_requirements(self, fgraph):
...
...
@@ -149,12 +149,12 @@ simplification described above:
Here's how it works: first, in ``add_requirements``, we add the
``ReplaceValidate`` :ref:`libdoc_graph_fgraphfeature` located in
:ref:`libdoc_graph_
toolbox
`. This feature adds the ``replace_validate``
:ref:`libdoc_graph_
features
`. This feature adds the ``replace_validate``
method to ``fgraph``, which is an enhanced version of ``replace`` that
does additional checks to ensure that we are not messing up the
computation graph (note: if ``ReplaceValidate`` was already added by
another optimizer, ``extend`` will do nothing). In a nutshell,
``
toolbox
.ReplaceValidate`` grants access to ``fgraph.replace_validate``,
``
features
.ReplaceValidate`` grants access to ``fgraph.replace_validate``,
and ``fgraph.replace_validate`` allows us to replace a Variable with
another while respecting certain validation constraints. You can
browse the list of :ref:`libdoc_graph_fgraphfeaturelist` and see if some of
...
...
doc/library/graph/
toolbox
.txt
→
doc/library/graph/
features
.txt
浏览文件 @
fa74d7e3
.. _libdoc_graph_
toolbox
:
.. _libdoc_graph_
features
:
================================================
:mod:`
toolbox
` -- [doc TODO]
:mod:`
features
` -- [doc TODO]
================================================
.. module:: aesara.graph.
toolbox
.. module:: aesara.graph.
features
:platform: Unix, Windows
:synopsis: Aesara Internals
.. moduleauthor:: LISA
...
...
doc/library/graph/fgraph.txt
浏览文件 @
fa74d7e3
...
...
@@ -33,7 +33,7 @@ FunctionGraph
FunctionGraph Features
----------------------
.. autoclass:: aesara.graph.
toolbox
.Feature
.. autoclass:: aesara.graph.
features
.Feature
:members:
.. _libdoc_graph_fgraphfeaturelist:
...
...
doc/library/graph/index.txt
浏览文件 @
fa74d7e3
...
...
@@ -15,7 +15,7 @@
graph
fgraph
toolbox
features
op
type
params_type
...
...
setup.cfg
浏览文件 @
fa74d7e3
...
...
@@ -4,6 +4,7 @@ ignore = E203,E231,E501,E741,W503,W504,C901
max-line-length = 88
per-file-ignores =
**/__init__.py:F401,E402,F403
aesara/graph/toolbox.py:E402,F403,F401
aesara/link/jax/jax_dispatch.py:E402,F403,F401
aesara/link/jax/jax_linker.py:E402,F403,F401
aesara/sparse/sandbox/sp2.py:F401
...
...
tests/compile/test_debugmode.py
浏览文件 @
fa74d7e3
...
...
@@ -15,10 +15,10 @@ from aesara.compile.debugmode import (
)
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Apply
,
Variable
from
aesara.graph.features
import
BadOptimization
from
aesara.graph.op
import
COp
,
Op
from
aesara.graph.opt
import
local_optimizer
from
aesara.graph.optdb
import
EquilibriumDB
from
aesara.graph.toolbox
import
BadOptimization
from
aesara.tensor.math
import
add
,
dot
,
log
from
aesara.tensor.type
import
TensorType
,
dvector
,
fmatrix
,
fvector
,
vector
from
tests
import
unittest_tools
as
utt
...
...
tests/compile/test_mode.py
浏览文件 @
fa74d7e3
...
...
@@ -2,7 +2,7 @@ import pytest
import
aesara
from
aesara.compile.mode
import
AddFeatureOptimizer
,
Mode
from
aesara.graph.
toolbox
import
NoOutputFromInplace
from
aesara.graph.
features
import
NoOutputFromInplace
from
aesara.tensor.math
import
dot
,
tanh
from
aesara.tensor.type
import
matrix
...
...
tests/graph/test_destroyhandler.py
浏览文件 @
fa74d7e3
...
...
@@ -5,6 +5,7 @@ import pytest
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Apply
,
Constant
,
Variable
,
clone
from
aesara.graph.destroyhandler
import
DestroyHandler
from
aesara.graph.features
import
ReplaceValidate
from
aesara.graph.fg
import
FunctionGraph
,
InconsistencyError
from
aesara.graph.op
import
Op
from
aesara.graph.opt
import
(
...
...
@@ -14,7 +15,6 @@ from aesara.graph.opt import (
PatternSub
,
TopoOptimizer
,
)
from
aesara.graph.toolbox
import
ReplaceValidate
from
aesara.graph.type
import
Type
from
tests.unittest_tools
import
assertFailure_fast
...
...
tests/graph/test_
toolbox
.py
→
tests/graph/test_
features
.py
浏览文件 @
fa74d7e3
from
aesara.graph.basic
import
Apply
,
Variable
from
aesara.graph.features
import
NodeFinder
,
is_same_graph
from
aesara.graph.fg
import
FunctionGraph
from
aesara.graph.op
import
Op
from
aesara.graph.toolbox
import
NodeFinder
,
is_same_graph
from
aesara.graph.type
import
Type
from
aesara.tensor.math
import
neg
from
aesara.tensor.type
import
vectors
...
...
tests/tensor/test_math_opt.py
浏览文件 @
fa74d7e3
...
...
@@ -17,10 +17,10 @@ from aesara.compile.mode import Mode, get_default_mode, get_mode
from
aesara.compile.ops
import
DeepCopyOp
,
deep_copy_op
from
aesara.configdefaults
import
config
from
aesara.graph.basic
import
Constant
from
aesara.graph.features
import
is_same_graph
from
aesara.graph.fg
import
FunctionGraph
from
aesara.graph.opt
import
LocalOptGroup
,
TopoOptimizer
,
check_stack_trace
,
out2in
from
aesara.graph.optdb
import
Query
from
aesara.graph.toolbox
import
is_same_graph
from
aesara.misc.safe_asarray
import
_asarray
from
aesara.tensor
import
inplace
from
aesara.tensor.basic
import
Alloc
,
join
,
switch
...
...
tests/tensor/test_subtensor.py
浏览文件 @
fa74d7e3
...
...
@@ -12,8 +12,8 @@ import aesara.tensor.basic as aet
from
aesara.compile
import
DeepCopyOp
,
shared
from
aesara.compile.io
import
In
from
aesara.configdefaults
import
config
from
aesara.graph.features
import
is_same_graph
from
aesara.graph.op
import
get_test_value
from
aesara.graph.toolbox
import
is_same_graph
from
aesara.tensor.elemwise
import
DimShuffle
from
aesara.tensor.math
import
exp
,
isinf
from
aesara.tensor.math
import
sum
as
aet_sum
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论