Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
87f5f609
提交
87f5f609
authored
1月 20, 2016
作者:
Frédéric Bastien
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #3478 from piotrfrankowski/with_statement
Issue #3429 - refactor some code to python 'with' statement
上级
4225e32d
3b9975eb
隐藏空白字符变更
内嵌
并排
正在显示
17 个修改的文件
包含
157 行增加
和
187 行删除
+157
-187
function_module.py
theano/compile/function_module.py
+11
-17
test_function.py
theano/compile/tests/test_function.py
+2
-3
d3viz.py
theano/d3viz/d3viz.py
+2
-3
callcache.py
theano/gof/callcache.py
+4
-6
cmodule.py
theano/gof/cmodule.py
+6
-7
compiledir.py
theano/gof/compiledir.py
+2
-7
compilelock.py
theano/gof/compilelock.py
+2
-3
buildbot_filter.py
theano/misc/buildbot_filter.py
+2
-1
check_duplicate_key.py
theano/misc/check_duplicate_key.py
+4
-6
check_whitespace.py
theano/misc/hooks/check_whitespace.py
+8
-12
reindent.py
theano/misc/hooks/reindent.py
+2
-3
nvcc_compiler.py
theano/sandbox/cuda/nvcc_compiler.py
+3
-4
scan_perform_ext.py
theano/scan_module/scan_perform_ext.py
+4
-2
test_scan.py
theano/scan_module/tests/test_scan.py
+2
-8
test_opt.py
theano/tensor/tests/test_opt.py
+1
-4
run_tests_in_batch.py
theano/tests/run_tests_in_batch.py
+92
-90
test_flake8.py
theano/tests/test_flake8.py
+10
-11
没有找到文件。
theano/compile/function_module.py
浏览文件 @
87f5f609
...
@@ -1214,22 +1214,17 @@ class FunctionMaker(object):
...
@@ -1214,22 +1214,17 @@ class FunctionMaker(object):
print
(
'graph_db already exists'
)
print
(
'graph_db already exists'
)
else
:
else
:
# create graph_db
# create graph_db
f
=
open
(
graph_db_file
,
'wb'
)
with
open
(
graph_db_file
,
'wb'
)
as
f
:
print
(
'create new graph_db in
%
s'
%
graph_db_file
)
print
(
'create new graph_db in
%
s'
%
graph_db_file
)
# file needs to be open and closed for every pickle
f
.
close
()
# load the graph_db dictionary
# load the graph_db dictionary
try
:
try
:
f
=
open
(
graph_db_file
,
'rb'
)
with
open
(
graph_db_file
,
'rb'
)
as
f
:
# Temporary hack to allow
# Temporary hack to allow
# theano.scan_module.tests.test_scan.T_Scan to
# theano.scan_module.tests.test_scan.T_Scan to
# finish. Should be changed in definitive version.
# finish. Should be changed in definitive version.
tmp
=
theano
.
config
.
unpickle_function
tmp
=
theano
.
config
.
unpickle_function
theano
.
config
.
unpickle_function
=
False
theano
.
config
.
unpickle_function
=
False
graph_db
=
pickle
.
load
(
f
)
graph_db
=
pickle
.
load
(
f
)
# hack end
f
.
close
()
print
(
'graph_db loaded and it is not empty'
)
print
(
'graph_db loaded and it is not empty'
)
except
EOFError
as
e
:
except
EOFError
as
e
:
# the file has nothing in it
# the file has nothing in it
...
@@ -1358,9 +1353,8 @@ class FunctionMaker(object):
...
@@ -1358,9 +1353,8 @@ class FunctionMaker(object):
before_opt
=
self
.
fgraph
.
clone
(
check_integrity
=
False
)
before_opt
=
self
.
fgraph
.
clone
(
check_integrity
=
False
)
optimizer_profile
=
optimizer
(
self
.
fgraph
)
optimizer_profile
=
optimizer
(
self
.
fgraph
)
graph_db
.
update
({
before_opt
:
self
.
fgraph
})
graph_db
.
update
({
before_opt
:
self
.
fgraph
})
f
=
open
(
graph_db_file
,
'wb'
)
with
open
(
graph_db_file
,
'wb'
)
as
f
:
pickle
.
dump
(
graph_db
,
f
,
-
1
)
pickle
.
dump
(
graph_db
,
f
,
-
1
)
f
.
close
()
print
(
'new graph saved into graph_db'
)
print
(
'new graph saved into graph_db'
)
release_lock
()
release_lock
()
return
optimizer_profile
return
optimizer_profile
...
...
theano/compile/tests/test_function.py
浏览文件 @
87f5f609
...
@@ -18,9 +18,8 @@ def test_function_dump():
...
@@ -18,9 +18,8 @@ def test_function_dump():
tmpdir
=
tempfile
.
mkdtemp
()
tmpdir
=
tempfile
.
mkdtemp
()
fname
=
os
.
path
.
join
(
tmpdir
,
'test_function_dump.pkl'
)
fname
=
os
.
path
.
join
(
tmpdir
,
'test_function_dump.pkl'
)
theano
.
function_dump
(
fname
,
[
v
],
v
+
1
)
theano
.
function_dump
(
fname
,
[
v
],
v
+
1
)
f
=
open
(
fname
,
'rb'
)
with
open
(
fname
,
'rb'
)
as
f
:
l
=
pickle
.
load
(
f
)
l
=
pickle
.
load
(
f
)
f
.
close
()
finally
:
finally
:
if
tmpdir
is
not
None
:
if
tmpdir
is
not
None
:
shutil
.
rmtree
(
tmpdir
)
shutil
.
rmtree
(
tmpdir
)
...
...
theano/d3viz/d3viz.py
浏览文件 @
87f5f609
...
@@ -86,9 +86,8 @@ def d3viz(fct, outfile, copy_deps=True, *args, **kwargs):
...
@@ -86,9 +86,8 @@ def d3viz(fct, outfile, copy_deps=True, *args, **kwargs):
# Read template HTML file
# Read template HTML file
template_file
=
os
.
path
.
join
(
__path__
,
'html'
,
'template.html'
)
template_file
=
os
.
path
.
join
(
__path__
,
'html'
,
'template.html'
)
f
=
open
(
template_file
)
with
open
(
template_file
)
as
f
:
template
=
f
.
read
()
template
=
f
.
read
()
f
.
close
()
# Copy dependencies to output directory
# Copy dependencies to output directory
src_deps
=
__path__
src_deps
=
__path__
...
...
theano/gof/callcache.py
浏览文件 @
87f5f609
...
@@ -10,18 +10,16 @@ class CallCache(object):
...
@@ -10,18 +10,16 @@ class CallCache(object):
try
:
try
:
if
filename
is
None
:
if
filename
is
None
:
raise
IOError
(
'bad filename'
)
# just goes to except
raise
IOError
(
'bad filename'
)
# just goes to except
f
=
open
(
filename
,
'r'
)
with
open
(
filename
,
'r'
)
as
f
:
self
.
cache
=
pickle
.
load
(
f
)
self
.
cache
=
pickle
.
load
(
f
)
f
.
close
()
except
IOError
:
except
IOError
:
self
.
cache
=
{}
self
.
cache
=
{}
def
persist
(
self
,
filename
=
None
):
def
persist
(
self
,
filename
=
None
):
if
filename
is
None
:
if
filename
is
None
:
filename
=
self
.
filename
filename
=
self
.
filename
f
=
open
(
filename
,
'w'
)
with
open
(
filename
,
'w'
)
as
f
:
pickle
.
dump
(
self
.
cache
,
f
)
pickle
.
dump
(
self
.
cache
,
f
)
f
.
close
()
def
call
(
self
,
fn
,
args
=
(),
key
=
None
):
def
call
(
self
,
fn
,
args
=
(),
key
=
None
):
if
key
is
None
:
if
key
is
None
:
...
...
theano/gof/cmodule.py
浏览文件 @
87f5f609
...
@@ -2143,15 +2143,14 @@ class GCC_compiler(Compiler):
...
@@ -2143,15 +2143,14 @@ class GCC_compiler(Compiler):
lib_dirs
=
std_lib_dirs
()
+
lib_dirs
lib_dirs
=
std_lib_dirs
()
+
lib_dirs
cppfilename
=
os
.
path
.
join
(
location
,
'mod.cpp'
)
cppfilename
=
os
.
path
.
join
(
location
,
'mod.cpp'
)
cppfile
=
open
(
cppfilename
,
'w'
)
with
open
(
cppfilename
,
'w'
)
as
cppfile
:
_logger
.
debug
(
'Writing module C++ code to
%
s'
,
cppfilename
)
_logger
.
debug
(
'Writing module C++ code to
%
s'
,
cppfilename
)
cppfile
.
write
(
src_code
)
cppfile
.
write
(
src_code
)
# Avoid gcc warning "no newline at end of file".
# Avoid gcc warning "no newline at end of file".
if
not
src_code
.
endswith
(
'
\n
'
):
if
not
src_code
.
endswith
(
'
\n
'
):
cppfile
.
write
(
'
\n
'
)
cppfile
.
write
(
'
\n
'
)
cppfile
.
close
()
lib_filename
=
os
.
path
.
join
(
lib_filename
=
os
.
path
.
join
(
location
,
location
,
...
...
theano/gof/compiledir.py
浏览文件 @
87f5f609
...
@@ -361,11 +361,9 @@ def print_compiledir_content():
...
@@ -361,11 +361,9 @@ def print_compiledir_content():
total_key_sizes
=
0
total_key_sizes
=
0
nb_keys
=
{}
nb_keys
=
{}
for
dir
in
os
.
listdir
(
compiledir
):
for
dir
in
os
.
listdir
(
compiledir
):
file
=
None
file
name
=
os
.
path
.
join
(
compiledir
,
dir
,
"key.pkl"
)
try
:
with
open
(
filename
,
'rb'
)
as
file
:
try
:
try
:
filename
=
os
.
path
.
join
(
compiledir
,
dir
,
"key.pkl"
)
file
=
open
(
filename
,
'rb'
)
keydata
=
pickle
.
load
(
file
)
keydata
=
pickle
.
load
(
file
)
ops
=
list
(
set
([
x
for
x
in
flatten
(
keydata
.
keys
)
ops
=
list
(
set
([
x
for
x
in
flatten
(
keydata
.
keys
)
if
isinstance
(
x
,
theano
.
gof
.
Op
)]))
if
isinstance
(
x
,
theano
.
gof
.
Op
)]))
...
@@ -387,9 +385,6 @@ def print_compiledir_content():
...
@@ -387,9 +385,6 @@ def print_compiledir_content():
nb_keys
[
len
(
keydata
.
keys
)]
+=
1
nb_keys
[
len
(
keydata
.
keys
)]
+=
1
except
IOError
:
except
IOError
:
pass
pass
finally
:
if
file
is
not
None
:
file
.
close
()
print
(
"List of
%
d compiled individual ops in this theano cache
%
s:"
%
(
print
(
"List of
%
d compiled individual ops in this theano cache
%
s:"
%
(
len
(
table
),
compiledir
))
len
(
table
),
compiledir
))
...
...
theano/gof/compilelock.py
浏览文件 @
87f5f609
...
@@ -339,9 +339,8 @@ def refresh_lock(lock_file):
...
@@ -339,9 +339,8 @@ def refresh_lock(lock_file):
''
.
join
([
str
(
random
.
randint
(
0
,
9
))
for
i
in
range
(
10
)]),
''
.
join
([
str
(
random
.
randint
(
0
,
9
))
for
i
in
range
(
10
)]),
hostname
)
hostname
)
try
:
try
:
lock_write
=
open
(
lock_file
,
'w'
)
with
open
(
lock_file
,
'w'
)
as
lock_write
:
lock_write
.
write
(
unique_id
+
'
\n
'
)
lock_write
.
write
(
unique_id
+
'
\n
'
)
lock_write
.
close
()
except
Exception
:
except
Exception
:
# In some strange case, this happen. To prevent all tests
# In some strange case, this happen. To prevent all tests
# from failing, we release the lock, but as there is a
# from failing, we release the lock, but as there is a
...
...
theano/misc/buildbot_filter.py
浏览文件 @
87f5f609
...
@@ -24,6 +24,7 @@ if __name__ == "__main__":
...
@@ -24,6 +24,7 @@ if __name__ == "__main__":
import
pdb
import
pdb
pdb
.
set_trace
()
pdb
.
set_trace
()
if
len
(
sys
.
argv
)
>
1
:
if
len
(
sys
.
argv
)
>
1
:
print
(
filter_output
(
open
(
sys
.
argv
[
1
])))
with
open
(
sys
.
argv
[
1
])
as
f
:
print
(
filter_output
(
f
))
else
:
else
:
print
(
filter_output
(
sys
.
stdin
))
print
(
filter_output
(
sys
.
stdin
))
theano/misc/check_duplicate_key.py
浏览文件 @
87f5f609
...
@@ -23,9 +23,8 @@ for dir in dirs:
...
@@ -23,9 +23,8 @@ for dir in dirs:
key
=
None
key
=
None
try
:
try
:
f
=
open
(
os
.
path
.
join
(
dir
,
"key.pkl"
))
with
open
(
os
.
path
.
join
(
dir
,
"key.pkl"
))
as
f
:
key
=
f
.
read
()
key
=
f
.
read
()
f
.
close
()
keys
.
setdefault
(
key
,
0
)
keys
.
setdefault
(
key
,
0
)
keys
[
key
]
+=
1
keys
[
key
]
+=
1
del
f
del
f
...
@@ -36,9 +35,8 @@ for dir in dirs:
...
@@ -36,9 +35,8 @@ for dir in dirs:
path
=
os
.
path
.
join
(
dir
,
"mod.cpp"
)
path
=
os
.
path
.
join
(
dir
,
"mod.cpp"
)
if
not
os
.
path
.
exists
(
path
):
if
not
os
.
path
.
exists
(
path
):
path
=
os
.
path
.
join
(
dir
,
"mod.cu"
)
path
=
os
.
path
.
join
(
dir
,
"mod.cu"
)
f
=
open
(
path
)
with
open
(
path
)
as
f
:
mod
=
f
.
read
()
mod
=
f
.
read
()
f
.
close
()
mods
.
setdefault
(
mod
,
())
mods
.
setdefault
(
mod
,
())
mods
[
mod
]
+=
(
key
,)
mods
[
mod
]
+=
(
key
,)
del
mod
del
mod
...
...
theano/misc/hooks/check_whitespace.py
浏览文件 @
87f5f609
...
@@ -145,31 +145,27 @@ def get_file_contents(filename, revision="tip"):
...
@@ -145,31 +145,27 @@ def get_file_contents(filename, revision="tip"):
def
save_commit_message
(
filename
):
def
save_commit_message
(
filename
):
commit_message
=
run_mercurial_command
(
"tip --template '{desc}'"
)
commit_message
=
run_mercurial_command
(
"tip --template '{desc}'"
)
save_file
=
open
(
filename
,
"w"
)
with
open
(
filename
,
"w"
)
as
save_file
:
save_file
.
write
(
commit_message
)
save_file
.
write
(
commit_message
)
save_file
.
close
()
def
save_diffs
(
diffs
,
filename
):
def
save_diffs
(
diffs
,
filename
):
diff
=
"
\n\n
"
.
join
(
diffs
)
diff
=
"
\n\n
"
.
join
(
diffs
)
diff_file
=
open
(
filename
,
"w"
)
with
open
(
filename
,
"w"
)
as
diff_file
:
diff_file
.
write
(
diff
)
diff_file
.
write
(
diff
)
diff_file
.
close
()
def
should_skip_commit
():
def
should_skip_commit
():
if
not
os
.
path
.
exists
(
SKIP_WHITESPACE_CHECK_FILENAME
):
if
not
os
.
path
.
exists
(
SKIP_WHITESPACE_CHECK_FILENAME
):
return
False
return
False
whitespace_check_file
=
open
(
SKIP_WHITESPACE_CHECK_FILENAME
,
"r"
)
with
open
(
SKIP_WHITESPACE_CHECK_FILENAME
,
"r"
)
as
whitespace_check_file
:
whitespace_check_changeset
=
whitespace_check_file
.
read
()
whitespace_check_changeset
=
whitespace_check_file
.
read
()
whitespace_check_file
.
close
()
return
whitespace_check_changeset
==
parent_commit
()
return
whitespace_check_changeset
==
parent_commit
()
def
save_skip_next_commit
():
def
save_skip_next_commit
():
whitespace_check_file
=
open
(
SKIP_WHITESPACE_CHECK_FILENAME
,
"w"
)
with
open
(
SKIP_WHITESPACE_CHECK_FILENAME
,
"w"
)
as
whitespace_check_file
:
whitespace_check_file
.
write
(
parent_commit
())
whitespace_check_file
.
write
(
parent_commit
())
whitespace_check_file
.
close
()
def
main
(
argv
=
None
):
def
main
(
argv
=
None
):
...
...
theano/misc/hooks/reindent.py
浏览文件 @
87f5f609
...
@@ -132,9 +132,8 @@ def check(file):
...
@@ -132,9 +132,8 @@ def check(file):
shutil
.
copyfile
(
file
,
bak
)
shutil
.
copyfile
(
file
,
bak
)
if
verbose
:
if
verbose
:
print
(
"backed up"
,
file
,
"to"
,
bak
)
print
(
"backed up"
,
file
,
"to"
,
bak
)
f
=
open
(
file
,
"w"
)
with
open
(
file
,
"w"
)
as
f
:
r
.
write
(
f
)
r
.
write
(
f
)
f
.
close
()
if
verbose
:
if
verbose
:
print
(
"wrote new"
,
file
)
print
(
"wrote new"
,
file
)
return
True
return
True
...
...
theano/sandbox/cuda/nvcc_compiler.py
浏览文件 @
87f5f609
...
@@ -233,12 +233,11 @@ class NVCC_compiler(Compiler):
...
@@ -233,12 +233,11 @@ class NVCC_compiler(Compiler):
lib_dirs
.
append
(
python_lib
)
lib_dirs
.
append
(
python_lib
)
cppfilename
=
os
.
path
.
join
(
location
,
'mod.cu'
)
cppfilename
=
os
.
path
.
join
(
location
,
'mod.cu'
)
cppfile
=
open
(
cppfilename
,
'w'
)
with
open
(
cppfilename
,
'w'
)
as
cppfile
:
_logger
.
debug
(
'Writing module C++ code to
%
s'
,
cppfilename
)
_logger
.
debug
(
'Writing module C++ code to
%
s'
,
cppfilename
)
cppfile
.
write
(
src_code
)
cppfile
.
write
(
src_code
)
cppfile
.
close
()
lib_filename
=
os
.
path
.
join
(
location
,
'
%
s.
%
s'
%
lib_filename
=
os
.
path
.
join
(
location
,
'
%
s.
%
s'
%
(
module_name
,
get_lib_extension
()))
(
module_name
,
get_lib_extension
()))
...
...
theano/scan_module/scan_perform_ext.py
浏览文件 @
87f5f609
...
@@ -75,7 +75,8 @@ except ImportError:
...
@@ -75,7 +75,8 @@ except ImportError:
)
)
raise
ImportError
(
"The file lazylinker_c.c is not available."
)
raise
ImportError
(
"The file lazylinker_c.c is not available."
)
code
=
open
(
cfile
)
.
read
()
with
open
(
cfile
)
as
f
:
code
=
f
.
read
()
loc
=
os
.
path
.
join
(
config
.
compiledir
,
dirname
)
loc
=
os
.
path
.
join
(
config
.
compiledir
,
dirname
)
if
not
os
.
path
.
exists
(
loc
):
if
not
os
.
path
.
exists
(
loc
):
try
:
try
:
...
@@ -113,7 +114,8 @@ except ImportError:
...
@@ -113,7 +114,8 @@ except ImportError:
hide_symbols
=
False
)
hide_symbols
=
False
)
# Save version into the __init__.py file.
# Save version into the __init__.py file.
init_py
=
os
.
path
.
join
(
loc
,
'__init__.py'
)
init_py
=
os
.
path
.
join
(
loc
,
'__init__.py'
)
open
(
init_py
,
'w'
)
.
write
(
'_version =
%
s
\n
'
%
version
)
with
open
(
init_py
,
'w'
)
as
f
:
f
.
write
(
'_version =
%
s
\n
'
%
version
)
# If we just compiled the module for the first time, then it was
# If we just compiled the module for the first time, then it was
# imported at the same time: we need to make sure we do not
# imported at the same time: we need to make sure we do not
# reload the now outdated __init__.pyc below.
# reload the now outdated __init__.pyc below.
...
...
theano/scan_module/tests/test_scan.py
浏览文件 @
87f5f609
...
@@ -250,16 +250,10 @@ class T_Scan(unittest.TestCase):
...
@@ -250,16 +250,10 @@ class T_Scan(unittest.TestCase):
tmpdir
=
mkdtemp
()
tmpdir
=
mkdtemp
()
os
.
chdir
(
tmpdir
)
os
.
chdir
(
tmpdir
)
f_out
=
open
(
'tmp_scan_test_pickle.pkl'
,
'wb'
)
with
open
(
'tmp_scan_test_pickle.pkl'
,
'wb'
)
as
f_out
:
try
:
pickle
.
dump
(
_my_f
,
f_out
,
protocol
=-
1
)
pickle
.
dump
(
_my_f
,
f_out
,
protocol
=-
1
)
finally
:
with
open
(
'tmp_scan_test_pickle.pkl'
,
'rb'
)
as
f_in
:
f_out
.
close
()
f_in
=
open
(
'tmp_scan_test_pickle.pkl'
,
'rb'
)
try
:
my_f
=
pickle
.
load
(
f_in
)
my_f
=
pickle
.
load
(
f_in
)
finally
:
f_in
.
close
()
finally
:
finally
:
# Get back to the original dir, and delete the temporary one.
# Get back to the original dir, and delete the temporary one.
os
.
chdir
(
origdir
)
os
.
chdir
(
origdir
)
...
...
theano/tensor/tests/test_opt.py
浏览文件 @
87f5f609
...
@@ -3852,16 +3852,13 @@ class test_shapeoptimizer(unittest.TestCase):
...
@@ -3852,16 +3852,13 @@ class test_shapeoptimizer(unittest.TestCase):
# Due to incompatibilities between python 2 and 3 in the format
# Due to incompatibilities between python 2 and 3 in the format
# of pickled numpy ndarray, we have to force an encoding
# of pickled numpy ndarray, we have to force an encoding
from
theano.misc.pkl_utils
import
CompatUnpickler
from
theano.misc.pkl_utils
import
CompatUnpickler
pkl_file
=
open
(
pkl_filename
,
"rb"
)
with
open
(
pkl_filename
,
"rb"
)
as
pkl_file
:
try
:
if
PY3
:
if
PY3
:
u
=
CompatUnpickler
(
pkl_file
,
encoding
=
"latin1"
)
u
=
CompatUnpickler
(
pkl_file
,
encoding
=
"latin1"
)
else
:
else
:
u
=
CompatUnpickler
(
pkl_file
)
u
=
CompatUnpickler
(
pkl_file
)
fn_args
=
u
.
load
()
fn_args
=
u
.
load
()
theano
.
function
(
**
fn_args
)
theano
.
function
(
**
fn_args
)
finally
:
pkl_file
.
close
()
class
test_assert
(
utt
.
InferShapeTester
):
class
test_assert
(
utt
.
InferShapeTester
):
...
...
theano/tests/run_tests_in_batch.py
浏览文件 @
87f5f609
...
@@ -265,99 +265,101 @@ def run(stdout, stderr, argv, theano_nose, batch_size, time_profile,
...
@@ -265,99 +265,101 @@ def run(stdout, stderr, argv, theano_nose, batch_size, time_profile,
fields
=
(
'Fields: computation time; nosetests sequential id;'
fields
=
(
'Fields: computation time; nosetests sequential id;'
' test name; parent class (if any); outcome
\n\n
'
)
' test name; parent class (if any); outcome
\n\n
'
)
path_nosort
=
os
.
path
.
join
(
sav_dir
,
'timeprof_nosort'
)
path_nosort
=
os
.
path
.
join
(
sav_dir
,
'timeprof_nosort'
)
f_nosort
=
open
(
path_nosort
,
'w'
)
# probably this part can be extracted for function with many args
f_nosort
.
write
(
'TIME-PROFILING OF THEANO
\'
S NOSETESTS'
with
open
(
path_nosort
,
'w'
)
as
f_nosort
:
' (by sequential id)
\n\n
'
+
stamp
+
fields
)
# begin of saving nosort
f_nosort
.
flush
()
f_nosort
.
write
(
'TIME-PROFILING OF THEANO
\'
S NOSETESTS'
for
test_floor
in
xrange
(
1
,
n_tests
+
1
,
batch_size
):
' (by sequential id)
\n\n
'
+
stamp
+
fields
)
for
test_id
in
xrange
(
test_floor
,
min
(
test_floor
+
batch_size
,
f_nosort
.
flush
()
n_tests
+
1
)):
for
test_floor
in
xrange
(
1
,
n_tests
+
1
,
batch_size
):
# Print the test we will start in the raw log to help
for
test_id
in
xrange
(
test_floor
,
min
(
test_floor
+
batch_size
,
# debug tests that are too long.
n_tests
+
1
)):
f_rawlog
.
write
(
"
\n
%
s Will run test #
%
d
%
s
\n
"
%
(
# Print the test we will start in the raw log to help
time
.
ctime
(),
test_id
,
data
[
"ids"
][
test_id
]))
# debug tests that are too long.
f_rawlog
.
flush
()
f_rawlog
.
write
(
"
\n
%
s Will run test #
%
d
%
s
\n
"
%
(
time
.
ctime
(),
test_id
,
data
[
"ids"
][
test_id
]))
p_out
=
output_subprocess_Popen
(
f_rawlog
.
flush
()
([
python
,
theano_nose
,
'-v'
,
'--with-id'
]
+
[
str
(
test_id
)]
+
argv
+
p_out
=
output_subprocess_Popen
(
[
'--disabdocstring'
]))
([
python
,
theano_nose
,
'-v'
,
'--with-id'
]
# the previous option calls a custom Nosetests plugin
+
[
str
(
test_id
)]
+
argv
+
# precluding automatic sustitution of doc. string for
[
'--disabdocstring'
]))
# test name in display
# the previous option calls a custom Nosetests plugin
# (see class 'DisabDocString' in file theano-nose)
# precluding automatic sustitution of doc. string for
# test name in display
# recovering and processing data from pipe
# (see class 'DisabDocString' in file theano-nose)
err
=
p_out
[
1
]
# print the raw log
# recovering and processing data from pipe
f_rawlog
.
write
(
err
)
err
=
p_out
[
1
]
f_rawlog
.
flush
()
# print the raw log
f_rawlog
.
write
(
err
)
# parsing the output
f_rawlog
.
flush
()
l_err
=
err
.
split
()
try
:
# parsing the output
pos_id
=
getIndexOfFirst
(
l_err
,
'#'
)
l_err
=
err
.
split
()
prof_id
=
l_err
[
pos_id
]
try
:
pos_dot
=
getIndexOfFirst
(
l_err
,
'...'
)
pos_id
=
getIndexOfFirst
(
l_err
,
'#'
)
prof_test
=
''
prof_id
=
l_err
[
pos_id
]
for
s
in
l_err
[
pos_id
+
1
:
pos_dot
]:
pos_dot
=
getIndexOfFirst
(
l_err
,
'...'
)
prof_test
+=
s
+
' '
prof_test
=
''
if
'OK'
in
err
:
for
s
in
l_err
[
pos_id
+
1
:
pos_dot
]:
pos_ok
=
getIndexOfLast
(
l_err
,
'OK'
)
prof_test
+=
s
+
' '
if
len
(
l_err
)
==
pos_ok
+
1
:
if
'OK'
in
err
:
prof_time
=
float
(
l_err
[
pos_ok
-
1
][
0
:
-
1
])
pos_ok
=
getIndexOfLast
(
l_err
,
'OK'
)
prof_pass
=
'OK'
if
len
(
l_err
)
==
pos_ok
+
1
:
elif
'SKIP'
in
l_err
[
pos_ok
+
1
]:
prof_time
=
float
(
l_err
[
pos_ok
-
1
][
0
:
-
1
])
prof_time
=
0.
prof_pass
=
'OK'
prof_pass
=
'SKIPPED TEST'
elif
'SKIP'
in
l_err
[
pos_ok
+
1
]:
elif
'KNOWNFAIL'
in
l_err
[
pos_ok
+
1
]:
prof_time
=
0.
prof_time
=
float
(
l_err
[
pos_ok
-
1
][
0
:
-
1
])
prof_pass
=
'SKIPPED TEST'
prof_pass
=
'OK'
elif
'KNOWNFAIL'
in
l_err
[
pos_ok
+
1
]:
prof_time
=
float
(
l_err
[
pos_ok
-
1
][
0
:
-
1
])
prof_pass
=
'OK'
else
:
prof_time
=
0.
prof_pass
=
'FAILED TEST'
else
:
else
:
prof_time
=
0.
prof_time
=
0.
prof_pass
=
'FAILED TEST'
prof_pass
=
'FAILED TEST'
else
:
except
Exception
:
prof_time
=
0.
prof_time
=
0
prof_pass
=
'FAILED TEST'
prof_id
=
'#'
+
str
(
test_id
)
except
Exception
:
prof_test
=
(
'FAILED PARSING, see raw log for details'
prof_time
=
0
' on test'
)
prof_id
=
'#'
+
str
(
test_id
)
prof_pass
=
''
prof_test
=
(
'FAILED PARSING, see raw log for details'
prof_tuple
=
(
prof_time
,
prof_id
,
prof_test
,
prof_pass
)
' on test'
)
prof_pass
=
''
# appending tuple to master list
prof_tuple
=
(
prof_time
,
prof_id
,
prof_test
,
prof_pass
)
prof_master_nosort
.
append
(
prof_tuple
)
# appending tuple to master list
# write the no sort file
prof_master_nosort
.
append
(
prof_tuple
)
s_nosort
=
((
str
(
prof_tuple
[
0
])
+
's'
)
.
ljust
(
10
)
+
" "
+
prof_tuple
[
1
]
.
ljust
(
7
)
+
" "
+
# write the no sort file
prof_tuple
[
2
]
+
prof_tuple
[
3
]
+
s_nosort
=
((
str
(
prof_tuple
[
0
])
+
's'
)
.
ljust
(
10
)
+
"
\n
"
)
" "
+
prof_tuple
[
1
]
.
ljust
(
7
)
+
" "
+
f_nosort
.
write
(
s_nosort
)
prof_tuple
[
2
]
+
prof_tuple
[
3
]
+
f_nosort
.
flush
()
"
\n
"
)
f_nosort
.
write
(
s_nosort
)
print
(
'
%
s
%%
time-profiled'
%
((
test_id
*
100
)
//
n_tests
))
f_nosort
.
flush
()
f_rawlog
.
close
()
print
(
'
%
s
%%
time-profiled'
%
((
test_id
*
100
)
//
n_tests
))
# sorting tests according to running-time
f_rawlog
.
close
()
prof_master_sort
=
sorted
(
prof_master_nosort
,
key
=
lambda
test
:
test
[
0
],
reverse
=
True
)
# sorting tests according to running-time
prof_master_sort
=
sorted
(
prof_master_nosort
,
# saving results to readable files
key
=
lambda
test
:
test
[
0
],
reverse
=
True
)
path_sort
=
os
.
path
.
join
(
sav_dir
,
'timeprof_sort'
)
with
open
(
path_sort
,
'w'
)
as
f_sort
:
# saving results to readable files
f_sort
.
write
(
'TIME-PROFILING OF THEANO
\'
S NOSETESTS'
path_sort
=
os
.
path
.
join
(
sav_dir
,
'timeprof_sort'
)
' (sorted by computation time)
\n\n
'
+
stamp
+
fields
)
f_sort
=
open
(
path_sort
,
'w'
)
for
i
in
xrange
(
len
(
prof_master_nosort
)):
f_sort
.
write
(
'TIME-PROFILING OF THEANO
\'
S NOSETESTS'
s_sort
=
((
str
(
prof_master_sort
[
i
][
0
])
+
's'
)
.
ljust
(
10
)
+
' (sorted by computation time)
\n\n
'
+
stamp
+
fields
)
" "
+
prof_master_sort
[
i
][
1
]
.
ljust
(
7
)
+
" "
+
for
i
in
xrange
(
len
(
prof_master_nosort
)):
prof_master_sort
[
i
][
2
]
+
prof_master_sort
[
i
][
3
]
+
s_sort
=
((
str
(
prof_master_sort
[
i
][
0
])
+
's'
)
.
ljust
(
10
)
+
"
\n
"
)
" "
+
prof_master_sort
[
i
][
1
]
.
ljust
(
7
)
+
" "
+
f_sort
.
write
(
s_sort
)
prof_master_sort
[
i
][
2
]
+
prof_master_sort
[
i
][
3
]
+
"
\n
"
)
# end of saving nosort
f_sort
.
write
(
s_sort
)
f_nosort
.
close
()
f_sort
.
close
()
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
sys
.
exit
(
main
())
sys
.
exit
(
main
())
theano/tests/test_flake8.py
浏览文件 @
87f5f609
...
@@ -249,17 +249,16 @@ def check_all_files(dir_path=theano.__path__[0], pattern='*.py'):
...
@@ -249,17 +249,16 @@ def check_all_files(dir_path=theano.__path__[0], pattern='*.py'):
the "whitelist_flake8" in this file.
the "whitelist_flake8" in this file.
"""
"""
f_txt
=
open
(
'theano_filelist.txt'
,
'a'
)
with
open
(
'theano_filelist.txt'
,
'a'
)
as
f_txt
:
for
(
dir
,
_
,
files
)
in
os
.
walk
(
dir_path
):
for
(
dir
,
_
,
files
)
in
os
.
walk
(
dir_path
):
for
f
in
files
:
for
f
in
files
:
if
fnmatch
(
f
,
pattern
):
if
fnmatch
(
f
,
pattern
):
error_num
=
flake8
.
main
.
check_file
(
os
.
path
.
join
(
dir
,
f
),
error_num
=
flake8
.
main
.
check_file
(
os
.
path
.
join
(
dir
,
f
),
ignore
=
ignore
)
ignore
=
ignore
)
if
error_num
>
0
:
if
error_num
>
0
:
path
=
os
.
path
.
relpath
(
os
.
path
.
join
(
dir
,
f
),
path
=
os
.
path
.
relpath
(
os
.
path
.
join
(
dir
,
f
),
theano
.
__path__
[
0
])
theano
.
__path__
[
0
])
f_txt
.
write
(
'"'
+
path
+
'",
\n
'
)
f_txt
.
write
(
'"'
+
path
+
'",
\n
'
)
f_txt
.
close
()
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论