Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
508a9742
提交
508a9742
authored
6月 29, 2011
作者:
Pascal Lamblin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Auto indentation fixes.
上级
d6f4ec71
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
11 行增加
和
12 行删除
+11
-12
optdb.py
theano/gof/optdb.py
+11
-12
没有找到文件。
theano/gof/optdb.py
浏览文件 @
508a9742
import
sys
,
StringIO
import
sys
,
StringIO
if
sys
.
version_info
[:
2
]
>=
(
2
,
5
):
if
sys
.
version_info
[:
2
]
>=
(
2
,
5
):
from
collections
import
defaultdict
from
collections
import
defaultdict
else
:
else
:
from
python25
import
defaultdict
from
python25
import
defaultdict
import
opt
import
opt
from
theano.configparser
import
TheanoConfigParser
,
AddConfigVar
,
FloatParam
from
theano.configparser
import
TheanoConfigParser
,
AddConfigVar
,
FloatParam
...
@@ -23,7 +23,7 @@ class DB(object):
...
@@ -23,7 +23,7 @@ class DB(object):
def
__init__
(
self
):
def
__init__
(
self
):
self
.
__db__
=
defaultdict
(
set
)
self
.
__db__
=
defaultdict
(
set
)
self
.
_names
=
set
()
self
.
_names
=
set
()
self
.
name
=
None
#will be reset by register
self
.
name
=
None
#will be reset by register
#(via obj.name by the thing doing the registering)
#(via obj.name by the thing doing the registering)
def
register
(
self
,
name
,
obj
,
*
tags
):
def
register
(
self
,
name
,
obj
,
*
tags
):
...
@@ -34,13 +34,13 @@ class DB(object):
...
@@ -34,13 +34,13 @@ class DB(object):
raise
TypeError
(
'Object cannot be registered in OptDB'
,
obj
)
raise
TypeError
(
'Object cannot be registered in OptDB'
,
obj
)
if
name
in
self
.
__db__
:
if
name
in
self
.
__db__
:
raise
ValueError
(
'The name of the object cannot be an existing tag or the name of another existing object.'
,
obj
,
name
)
raise
ValueError
(
'The name of the object cannot be an existing tag or the name of another existing object.'
,
obj
,
name
)
# This restriction is there because in many place we suppose that
# This restriction is there because in many place we suppose that
# something in the DB is there only once.
# something in the DB is there only once.
if
getattr
(
obj
,
'name'
,
""
)
in
self
.
__db__
:
if
getattr
(
obj
,
'name'
,
""
)
in
self
.
__db__
:
raise
ValueError
(
'''You can
\'
t register the same optimization
raise
ValueError
(
'''You can
\'
t register the same optimization
multiple time in a DB. Tryed to register "
%
s" again under the new name "
%
s".
multiple time in a DB. Tryed to register "
%
s" again under the new name "
%
s".
Use theano.gof.ProxyDB to work around that'''
%
(
obj
.
name
,
name
))
Use theano.gof.ProxyDB to work around that'''
%
(
obj
.
name
,
name
))
if
self
.
name
is
not
None
:
if
self
.
name
is
not
None
:
tags
=
tags
+
(
self
.
name
,)
tags
=
tags
+
(
self
.
name
,)
obj
.
name
=
name
obj
.
name
=
name
...
@@ -48,7 +48,7 @@ multiple time in a DB. Tryed to register "%s" again under the new name "%s".
...
@@ -48,7 +48,7 @@ multiple time in a DB. Tryed to register "%s" again under the new name "%s".
self
.
_names
.
add
(
name
)
self
.
_names
.
add
(
name
)
self
.
add_tags
(
name
,
*
tags
)
self
.
add_tags
(
name
,
*
tags
)
def
add_tags
(
self
,
name
,
*
tags
):
def
add_tags
(
self
,
name
,
*
tags
):
obj
=
self
.
__db__
[
name
]
obj
=
self
.
__db__
[
name
]
assert
len
(
obj
)
==
1
assert
len
(
obj
)
==
1
...
@@ -158,14 +158,14 @@ class EquilibriumDB(DB):
...
@@ -158,14 +158,14 @@ class EquilibriumDB(DB):
Canonicalize, Stabilize, and Specialize are all equilibrium optimizations.
Canonicalize, Stabilize, and Specialize are all equilibrium optimizations.
.. note::
.. note::
We can put LocalOptimizer and Optimizer as EquilibriumOptimizer suppor both.
We can put LocalOptimizer and Optimizer as EquilibriumOptimizer suppor both.
"""
"""
def
query
(
self
,
*
tags
,
**
kwtags
):
def
query
(
self
,
*
tags
,
**
kwtags
):
opts
=
super
(
EquilibriumDB
,
self
)
.
query
(
*
tags
,
**
kwtags
)
opts
=
super
(
EquilibriumDB
,
self
)
.
query
(
*
tags
,
**
kwtags
)
return
opt
.
EquilibriumOptimizer
(
opts
,
return
opt
.
EquilibriumOptimizer
(
opts
,
max_depth
=
5
,
max_depth
=
5
,
max_use_ratio
=
11
,
#upgraded to 11 to don't generated useless output in test.
max_use_ratio
=
11
,
#upgraded to 11 to don't generated useless output in test.
failure_callback
=
opt
.
NavigatorOptimizer
.
warn_inplace
)
failure_callback
=
opt
.
NavigatorOptimizer
.
warn_inplace
)
...
@@ -206,7 +206,7 @@ class SequenceDB(DB):
...
@@ -206,7 +206,7 @@ class SequenceDB(DB):
#the call to super should have raise an error with a good message
#the call to super should have raise an error with a good message
assert
len
(
tags
)
==
1
assert
len
(
tags
)
==
1
if
getattr
(
tags
[
0
],
'position_cutoff'
,
None
):
if
getattr
(
tags
[
0
],
'position_cutoff'
,
None
):
position_cutoff
=
tags
[
0
]
.
position_cutoff
position_cutoff
=
tags
[
0
]
.
position_cutoff
opts
=
[
o
for
o
in
opts
if
self
.
__position__
[
o
.
name
]
<
position_cutoff
]
opts
=
[
o
for
o
in
opts
if
self
.
__position__
[
o
.
name
]
<
position_cutoff
]
opts
.
sort
(
key
=
lambda
obj
:
self
.
__position__
[
obj
.
name
])
opts
.
sort
(
key
=
lambda
obj
:
self
.
__position__
[
obj
.
name
])
...
@@ -216,7 +216,7 @@ class SequenceDB(DB):
...
@@ -216,7 +216,7 @@ class SequenceDB(DB):
print
>>
stream
,
"SequenceDB (id
%
i)"
%
id
(
self
)
print
>>
stream
,
"SequenceDB (id
%
i)"
%
id
(
self
)
positions
=
self
.
__position__
.
items
()
positions
=
self
.
__position__
.
items
()
def
c
(
a
,
b
):
def
c
(
a
,
b
):
return
cmp
(
a
[
1
],
b
[
1
])
return
cmp
(
a
[
1
],
b
[
1
])
positions
.
sort
(
c
)
positions
.
sort
(
c
)
print
>>
stream
,
" position"
,
positions
print
>>
stream
,
" position"
,
positions
...
@@ -240,4 +240,3 @@ class ProxyDB(DB):
...
@@ -240,4 +240,3 @@ class ProxyDB(DB):
def
query
(
self
,
*
tags
,
**
kwtags
):
def
query
(
self
,
*
tags
,
**
kwtags
):
return
self
.
db
.
query
(
*
tags
,
**
kwtags
)
return
self
.
db
.
query
(
*
tags
,
**
kwtags
)
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论