Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
872c8166
提交
872c8166
authored
3月 06, 2013
作者:
Pascal Lamblin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add Python bitwidth in config.compile_dir.
Also move local_bitwidth to gof/compiledir, import it directly in theano.gof, and use the latter path.
上级
3b6922d3
显示空白字符变更
内嵌
并排
正在显示
9 个修改的文件
包含
46 行增加
和
38 行删除
+46
-38
config.txt
doc/library/config.txt
+1
-1
test_pfunc.py
theano/compile/tests/test_pfunc.py
+1
-1
test_shared.py
theano/compile/tests/test_shared.py
+1
-1
__init__.py
theano/gof/__init__.py
+3
-1
cmodule.py
theano/gof/cmodule.py
+1
-24
compiledir.py
theano/gof/compiledir.py
+31
-3
nvcc_compiler.py
theano/sandbox/cuda/nvcc_compiler.py
+2
-1
extra_ops.py
theano/tensor/extra_ops.py
+3
-3
test_extra_ops.py
theano/tensor/tests/test_extra_ops.py
+3
-3
没有找到文件。
doc/library/config.txt
浏览文件 @
872c8166
...
@@ -364,7 +364,7 @@ import theano and print the config variable, as in:
...
@@ -364,7 +364,7 @@ import theano and print the config variable, as in:
.. attribute:: compiledir_format
.. attribute:: compiledir_format
Default: "compiledir_%(platform)s-%(processor)s-%(python_version)s"
Default: "compiledir_%(platform)s-%(processor)s-%(python_version)s
-%(python_bitwidth)s
"
This is a Python format string that specifies the subdirectory
This is a Python format string that specifies the subdirectory
of ``config.base_compiledir`` in which to store platform-dependent
of ``config.base_compiledir`` in which to store platform-dependent
...
...
theano/compile/tests/test_pfunc.py
浏览文件 @
872c8166
...
@@ -548,7 +548,7 @@ class Test_pfunc(unittest.TestCase):
...
@@ -548,7 +548,7 @@ class Test_pfunc(unittest.TestCase):
def
test_default_updates_input
(
self
):
def
test_default_updates_input
(
self
):
x
=
shared
(
0
)
x
=
shared
(
0
)
y
=
shared
(
1
)
y
=
shared
(
1
)
if
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
==
32
:
if
theano
.
gof
.
python_int_bitwidth
()
==
32
:
a
=
iscalar
(
'a'
)
a
=
iscalar
(
'a'
)
else
:
else
:
a
=
lscalar
(
'a'
)
a
=
lscalar
(
'a'
)
...
...
theano/compile/tests/test_shared.py
浏览文件 @
872c8166
...
@@ -18,7 +18,7 @@ class Test_SharedVariable(unittest.TestCase):
...
@@ -18,7 +18,7 @@ class Test_SharedVariable(unittest.TestCase):
assert
shared
(
7
,
dtype
=
'float64'
)
.
type
==
Scalar
(
'float64'
)
assert
shared
(
7
,
dtype
=
'float64'
)
.
type
==
Scalar
(
'float64'
)
else
:
else
:
if
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
==
32
:
if
theano
.
gof
.
python_int_bitwidth
()
==
32
:
assert
shared
(
7
)
.
type
==
theano
.
tensor
.
iscalar
,
shared
(
7
)
.
type
assert
shared
(
7
)
.
type
==
theano
.
tensor
.
iscalar
,
shared
(
7
)
.
type
else
:
else
:
assert
shared
(
7
)
.
type
==
theano
.
tensor
.
lscalar
,
shared
(
7
)
.
type
assert
shared
(
7
)
.
type
==
theano
.
tensor
.
lscalar
,
shared
(
7
)
.
type
...
...
theano/gof/__init__.py
浏览文件 @
872c8166
...
@@ -38,7 +38,9 @@ e-mail thread "What is gof?"
...
@@ -38,7 +38,9 @@ e-mail thread "What is gof?"
from
theano.gof.cc
import
\
from
theano.gof.cc
import
\
CLinker
,
OpWiseCLinker
,
DualLinker
CLinker
,
OpWiseCLinker
,
DualLinker
import
theano.gof.compiledir
# adds config vars
# Also adds config vars
from
theano.gof.compiledir
import
\
local_bitwidth
,
python_int_bitwidth
from
theano.gof.fg
import
\
from
theano.gof.fg
import
\
InconsistencyError
,
MissingInputError
,
FunctionGraph
InconsistencyError
,
MissingInputError
,
FunctionGraph
...
...
theano/gof/cmodule.py
浏览文件 @
872c8166
...
@@ -27,7 +27,7 @@ from theano.misc.windows import call_subprocess_Popen
...
@@ -27,7 +27,7 @@ from theano.misc.windows import call_subprocess_Popen
# we will abuse the lockfile mechanism when reading and writing the registry
# we will abuse the lockfile mechanism when reading and writing the registry
from
theano.gof
import
compilelock
from
theano.gof
import
compilelock
from
theano.gof.compiledir
import
gcc_version_str
from
theano.gof.compiledir
import
gcc_version_str
,
local_bitwidth
from
theano.configparser
import
AddConfigVar
,
BoolParam
from
theano.configparser
import
AddConfigVar
,
BoolParam
...
@@ -55,29 +55,6 @@ AddConfigVar('cmodule.compilation_warning',
...
@@ -55,29 +55,6 @@ AddConfigVar('cmodule.compilation_warning',
BoolParam
(
False
))
BoolParam
(
False
))
def
local_bitwidth
():
"""
Return 32 for 32bit arch, 64 for 64bit arch
By "architecture", we mean the size of memory pointers (size_t in C),
*not* the size of long int, as it can be different.
"""
# Note that according to Python documentation, `platform.architecture()` is
# not reliable on OS X with universal binaries.
# Also, sys.maxsize does not exist in Python < 2.6.
# 'P' denotes a void*, and the size is expressed in bytes.
return
struct
.
calcsize
(
'P'
)
*
8
def
python_int_bitwidth
():
"""
Return the bit width of Python int (C long int).
Note that it can be different from the size of a memory pointer.
"""
# 'l' denotes a C long int, and the size is expressed in bytes.
return
struct
.
calcsize
(
'l'
)
*
8
_logger
=
logging
.
getLogger
(
"theano.gof.cmodule"
)
_logger
=
logging
.
getLogger
(
"theano.gof.cmodule"
)
_logger
.
setLevel
(
logging
.
WARNING
)
_logger
.
setLevel
(
logging
.
WARNING
)
...
...
theano/gof/compiledir.py
浏览文件 @
872c8166
...
@@ -4,6 +4,7 @@ import os
...
@@ -4,6 +4,7 @@ import os
import
platform
import
platform
import
re
import
re
import
shutil
import
shutil
import
struct
import
subprocess
import
subprocess
import
sys
import
sys
import
textwrap
import
textwrap
...
@@ -32,16 +33,43 @@ except OSError:
...
@@ -32,16 +33,43 @@ except OSError:
del
p
del
p
del
dummy_err
del
dummy_err
compiledir_format_dict
=
{
"platform"
:
platform
.
platform
(),
def
local_bitwidth
():
"""
Return 32 for 32bit arch, 64 for 64bit arch
By "architecture", we mean the size of memory pointers (size_t in C),
*not* the size of long int, as it can be different.
"""
# Note that according to Python documentation, `platform.architecture()` is
# not reliable on OS X with universal binaries.
# Also, sys.maxsize does not exist in Python < 2.6.
# 'P' denotes a void*, and the size is expressed in bytes.
return
struct
.
calcsize
(
'P'
)
*
8
def
python_int_bitwidth
():
"""
Return the bit width of Python int (C long int).
Note that it can be different from the size of a memory pointer.
"""
# 'l' denotes a C long int, and the size is expressed in bytes.
return
struct
.
calcsize
(
'l'
)
*
8
compiledir_format_dict
=
{
"platform"
:
platform
.
platform
(),
"processor"
:
platform
.
processor
(),
"processor"
:
platform
.
processor
(),
"python_version"
:
platform
.
python_version
(),
"python_version"
:
platform
.
python_version
(),
"python_bitwidth"
:
local_bitwidth
(),
"theano_version"
:
theano
.
__version__
,
"theano_version"
:
theano
.
__version__
,
"numpy_version"
:
numpy
.
__version__
,
"numpy_version"
:
numpy
.
__version__
,
"gxx_version"
:
gcc_version_str
.
replace
(
" "
,
"_"
),
"gxx_version"
:
gcc_version_str
.
replace
(
" "
,
"_"
),
}
}
compiledir_format_keys
=
", "
.
join
(
sorted
(
compiledir_format_dict
.
keys
()))
compiledir_format_keys
=
", "
.
join
(
sorted
(
compiledir_format_dict
.
keys
()))
default_compiledir_format
=
\
default_compiledir_format
=
(
"compiledir_
%(platform)
s-
%(processor)
s-"
"compiledir_
%(platform)
s-
%(processor)
s-
%(python_version)
s"
"
%(python_version)
s-
%(python_bitwidth)
s"
)
AddConfigVar
(
"compiledir_format"
,
AddConfigVar
(
"compiledir_format"
,
textwrap
.
fill
(
textwrap
.
dedent
(
"""
\
textwrap
.
fill
(
textwrap
.
dedent
(
"""
\
...
...
theano/sandbox/cuda/nvcc_compiler.py
浏览文件 @
872c8166
...
@@ -10,10 +10,11 @@ import warnings
...
@@ -10,10 +10,11 @@ import warnings
import
numpy
import
numpy
import
theano
import
theano
from
theano.gof
import
local_bitwidth
from
theano.gof.cc
import
hash_from_file
from
theano.gof.cc
import
hash_from_file
from
theano.gof.cmodule
import
(
std_libs
,
std_lib_dirs
,
from
theano.gof.cmodule
import
(
std_libs
,
std_lib_dirs
,
std_include_dirs
,
dlimport
,
std_include_dirs
,
dlimport
,
get_lib_extension
,
local_bitwidth
)
get_lib_extension
)
from
theano.gof.python25
import
any
from
theano.gof.python25
import
any
from
theano.misc.windows
import
call_subprocess_Popen
from
theano.misc.windows
import
call_subprocess_Popen
...
...
theano/tensor/extra_ops.py
浏览文件 @
872c8166
...
@@ -114,12 +114,12 @@ class BinCountOp(theano.Op):
...
@@ -114,12 +114,12 @@ class BinCountOp(theano.Op):
# Some dtypes are not supported by numpy's implementation of bincount.
# Some dtypes are not supported by numpy's implementation of bincount.
# Until another one is available, we should fail at graph construction
# Until another one is available, we should fail at graph construction
# time, not wait for execution.
# time, not wait for execution.
int_bitwidth
=
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
int_bitwidth
=
theano
.
gof
.
python_int_bitwidth
()
if
int_bitwidth
==
64
:
if
int_bitwidth
==
64
:
numpy_unsupported_dtypes
=
(
'uint64'
,)
numpy_unsupported_dtypes
=
(
'uint64'
,)
if
int_bitwidth
==
32
:
if
int_bitwidth
==
32
:
numpy_unsupported_dtypes
=
(
'uint32'
,
'int64'
,
'uint64'
)
numpy_unsupported_dtypes
=
(
'uint32'
,
'int64'
,
'uint64'
)
intp_bitwidth
=
theano
.
gof
.
cmodule
.
local_bitwidth
()
intp_bitwidth
=
theano
.
gof
.
local_bitwidth
()
if
intp_bitwidth
==
32
:
if
intp_bitwidth
==
32
:
out_type
=
basic
.
ivector
()
out_type
=
basic
.
ivector
()
elif
intp_bitwidth
==
64
:
elif
intp_bitwidth
==
64
:
...
@@ -246,7 +246,7 @@ class RepeatOp(theano.Op):
...
@@ -246,7 +246,7 @@ class RepeatOp(theano.Op):
# Some dtypes are not supported by numpy's implementation of repeat.
# Some dtypes are not supported by numpy's implementation of repeat.
# Until another one is available, we should fail at graph construction
# Until another one is available, we should fail at graph construction
# time, not wait for execution.
# time, not wait for execution.
int_bitwidth
=
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
int_bitwidth
=
theano
.
gof
.
python_int_bitwidth
()
if
int_bitwidth
==
64
:
if
int_bitwidth
==
64
:
numpy_unsupported_dtypes
=
(
'uint64'
,)
numpy_unsupported_dtypes
=
(
'uint64'
,)
if
int_bitwidth
==
32
:
if
int_bitwidth
==
32
:
...
...
theano/tensor/tests/test_extra_ops.py
浏览文件 @
872c8166
...
@@ -25,7 +25,7 @@ class TestBinCountOp(utt.InferShapeTester):
...
@@ -25,7 +25,7 @@ class TestBinCountOp(utt.InferShapeTester):
'uint8'
,
'uint16'
,
'uint32'
,
'uint64'
):
'uint8'
,
'uint16'
,
'uint32'
,
'uint64'
):
# uint64 always fails
# uint64 always fails
# int64 and uint32 also fail if python int are 32-bit
# int64 and uint32 also fail if python int are 32-bit
int_bitwidth
=
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
int_bitwidth
=
theano
.
gof
.
python_int_bitwidth
()
if
int_bitwidth
==
64
:
if
int_bitwidth
==
64
:
numpy_unsupported_dtypes
=
(
'uint64'
,)
numpy_unsupported_dtypes
=
(
'uint64'
,)
if
int_bitwidth
==
32
:
if
int_bitwidth
==
32
:
...
@@ -57,7 +57,7 @@ class TestBinCountOp(utt.InferShapeTester):
...
@@ -57,7 +57,7 @@ class TestBinCountOp(utt.InferShapeTester):
for
dtype
in
tensor
.
discrete_dtypes
:
for
dtype
in
tensor
.
discrete_dtypes
:
# uint64 always fails
# uint64 always fails
# int64 and uint32 also fail if python int are 32-bit
# int64 and uint32 also fail if python int are 32-bit
int_bitwidth
=
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
int_bitwidth
=
theano
.
gof
.
python_int_bitwidth
()
if
int_bitwidth
==
64
:
if
int_bitwidth
==
64
:
numpy_unsupported_dtypes
=
(
'uint64'
,)
numpy_unsupported_dtypes
=
(
'uint64'
,)
if
int_bitwidth
==
32
:
if
int_bitwidth
==
32
:
...
@@ -203,7 +203,7 @@ class TestRepeatOp(utt.InferShapeTester):
...
@@ -203,7 +203,7 @@ class TestRepeatOp(utt.InferShapeTester):
self
.
op
=
RepeatOp
()
self
.
op
=
RepeatOp
()
# uint64 always fails
# uint64 always fails
# int64 and uint32 also fail if python int are 32-bit
# int64 and uint32 also fail if python int are 32-bit
int_bitwidth
=
theano
.
gof
.
cmodule
.
python_int_bitwidth
()
int_bitwidth
=
theano
.
gof
.
python_int_bitwidth
()
if
int_bitwidth
==
64
:
if
int_bitwidth
==
64
:
self
.
numpy_unsupported_dtypes
=
(
'uint64'
,)
self
.
numpy_unsupported_dtypes
=
(
'uint64'
,)
if
int_bitwidth
==
32
:
if
int_bitwidth
==
32
:
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论