Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
cbf1a8e8
提交
cbf1a8e8
authored
2月 07, 2014
作者:
abergeron
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1725 from nouiz/doc
Doc
上级
5420caac
5d808022
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
27 行增加
和
86 行删除
+27
-86
install.txt
doc/install.txt
+5
-0
index.txt
doc/library/gof/index.txt
+1
-3
utils.txt
doc/library/gof/utils.txt
+17
-0
utils.py
theano/gof/utils.py
+4
-83
没有找到文件。
doc/install.txt
浏览文件 @
cbf1a8e8
...
...
@@ -242,6 +242,11 @@ From here, the easiest way to get started is (this requires setuptools_ or distr
cd Theano
python setup.py develop
.. note::
"python setup.py develop ..." don't work on Python 3 as it don't call
the converter from Python2 code to Python 3 code.
This will install a ``.pth`` file in your ``site-packages`` directory that
tells Python where to look for your Theano installation (i.e. in the
directory your just checked out of Github). Using ``develop`` mode is
...
...
doc/library/gof/index.txt
浏览文件 @
cbf1a8e8
...
...
@@ -16,6 +16,4 @@
fgraph
toolbox
type
utils
doc/library/gof/utils.txt
0 → 100644
浏览文件 @
cbf1a8e8
.. _libdoc_gof_utils:
==========================================================
:mod:`utils` -- Utilities functions operating on the graph
==========================================================
.. module:: utils
:platform: Unix, Windows
:synopsis: Utilities functions operating on the graph
.. moduleauthor:: LISA
---------
Reference
---------
.. automodule:: theano.gof.utils
:members:
theano/gof/utils.py
浏览文件 @
cbf1a8e8
...
...
@@ -16,12 +16,6 @@ def add_tag_trace(thing):
return
thing
def
hashgen
():
hashgen
.
next
+=
1
return
hashgen
.
next
hashgen
.
next
=
0
def
hashtype
(
self
):
t
=
type
(
self
)
return
hash
(
t
.
__name__
)
^
hash
(
t
.
__module__
)
...
...
@@ -133,7 +127,7 @@ def uniq(seq):
def
difference
(
seq1
,
seq2
):
"""
Returns all elements in seq1 which are not in seq2: i.e
seq1
\
seq2
Returns all elements in seq1 which are not in seq2: i.e
``seq1
\
seq2``
"""
try
:
# try to use O(const * len(seq1)) algo
...
...
@@ -148,52 +142,6 @@ def difference(seq1, seq2):
return
[
x
for
x
in
seq1
if
x
not
in
seq2
]
def
partition
(
f
,
seq
):
seqt
=
[]
seqf
=
[]
for
elem
in
seq
:
if
f
(
elem
):
seqt
.
append
(
elem
)
else
:
seqf
.
append
(
elem
)
return
seqt
,
seqf
def
attr_checker
(
*
attrs
):
def
f
(
candidate
):
for
attr
in
attrs
:
if
not
hasattr
(
candidate
,
attr
):
return
False
return
True
f
.
__doc__
=
(
"Checks that the candidate has the following attributes:
%
s"
%
", "
.
join
([
"'
%
s'"
%
attr
for
attr
in
attrs
]))
return
f
def
all_bases
(
cls
,
accept
):
rval
=
set
([
cls
])
for
base
in
cls
.
__bases__
:
rval
.
update
(
all_bases
(
base
,
accept
))
return
[
cls
for
cls
in
rval
if
accept
(
cls
)]
def
all_bases_collect
(
cls
,
raw_name
):
rval
=
set
()
name
=
"__
%
s__"
%
raw_name
if
name
in
cls
.
__dict__
:
# don't use hasattr
rval
.
add
(
getattr
(
cls
,
name
))
cut
=
"__
%
s_override__"
%
raw_name
if
not
cls
.
__dict__
.
get
(
cut
,
False
):
for
base
in
cls
.
__bases__
:
rval
.
update
(
all_bases_collect
(
base
,
raw_name
))
return
rval
def
camelcase_to_separated
(
string
,
sep
=
"_"
):
return
re
.
sub
(
'(.)([A-Z])'
,
'
\\
1
%
s
\\
2'
%
sep
,
string
)
.
lower
()
def
to_return_values
(
values
):
if
len
(
values
)
==
1
:
return
values
[
0
]
...
...
@@ -208,21 +156,6 @@ def from_return_values(values):
return
[
values
]
class
ClsInit
(
type
):
"""Class initializer for L{Op} subclasses"""
def
__init__
(
cls
,
name
,
bases
,
dct
):
"""
Validate and initialize the L{Op} subclass 'cls'
This function:
- changes class attributes input_names and output_names to be lists
if they are single strings.
"""
type
.
__init__
(
cls
,
name
,
bases
,
dct
)
cls
.
__clsinit__
(
cls
,
name
,
bases
,
dct
)
def
toposort
(
prereqs_d
):
"""
Sorts prereqs_d.keys() topologically.
...
...
@@ -261,21 +194,6 @@ def toposort(prereqs_d):
return
seq
def
print_for_dot
(
self
):
#TODO: popen2("dot -Tpng | display") and actually make the graph window
#pop up
print
(
"digraph unix { size = '6,6'; node [color = lightblue2;"
"style = filled];"
)
for
op
in
self
.
order
:
for
input
in
op
.
inputs
:
if
input
.
owner
:
print
' '
.
join
((
input
.
owner
.
__class__
.
__name__
+
str
(
abs
(
id
(
input
.
owner
))),
" -> "
,
op
.
__class__
.
__name__
+
str
(
abs
(
id
(
op
))),
";"
))
class
Keyword
:
def
__init__
(
self
,
name
,
nonzero
=
True
):
...
...
@@ -374,6 +292,9 @@ def type_guard(type1):
def
flatten
(
a
):
"""
Recursively flatten tuple, list and set in a list.
"""
if
isinstance
(
a
,
(
tuple
,
list
,
set
)):
l
=
[]
for
item
in
a
:
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论