Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
96220be7
提交
96220be7
authored
2月 06, 2012
作者:
nouiz
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #421 from goodfeli/fix_defaults
Fix defaults
上级
bb58f1a6
64fecf12
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
47 行增加
和
10 行删除
+47
-10
function_module.py
theano/compile/function_module.py
+33
-5
io.py
theano/compile/io.py
+6
-1
pfunc.py
theano/compile/pfunc.py
+8
-4
没有找到文件。
theano/compile/function_module.py
浏览文件 @
96220be7
...
@@ -16,7 +16,6 @@ from theano import gof
...
@@ -16,7 +16,6 @@ from theano import gof
from
theano.gof.python25
import
partial
from
theano.gof.python25
import
partial
import
mode
as
mode_module
import
mode
as
mode_module
from
io
import
In
,
SymbolicInput
,
SymbolicInputKit
,
SymbolicOutput
from
io
import
In
,
SymbolicInput
,
SymbolicInputKit
,
SymbolicOutput
from
theano.configdefaults
import
config
import
logging
import
logging
_logger
=
logging
.
getLogger
(
'theano.compile.function_module'
)
_logger
=
logging
.
getLogger
(
'theano.compile.function_module'
)
...
@@ -346,6 +345,7 @@ class Function(object):
...
@@ -346,6 +345,7 @@ class Function(object):
Initialize attributes. create finder, inv_finder.
Initialize attributes. create finder, inv_finder.
"""
"""
self
.
fn
=
fn
self
.
fn
=
fn
self
.
input_storage
=
input_storage
self
.
input_storage
=
input_storage
self
.
output_storage
=
output_storage
self
.
output_storage
=
output_storage
...
@@ -1082,6 +1082,7 @@ class FunctionMaker(object):
...
@@ -1082,6 +1082,7 @@ class FunctionMaker(object):
acts as initialization.
acts as initialization.
trustme -> disables some exceptions, used internally
trustme -> disables some exceptions, used internally
"""
"""
if
input_storage
is
None
:
if
input_storage
is
None
:
input_storage
=
[
None
]
*
len
(
self
.
inputs
)
input_storage
=
[
None
]
*
len
(
self
.
inputs
)
input_storage_lists
=
[]
# list of independent one-element lists, will be passed to the linker
input_storage_lists
=
[]
# list of independent one-element lists, will be passed to the linker
...
@@ -1090,6 +1091,7 @@ class FunctionMaker(object):
...
@@ -1090,6 +1091,7 @@ class FunctionMaker(object):
# The following loop is to fill in the input_storage_lists and defaults lists.
# The following loop is to fill in the input_storage_lists and defaults lists.
assert
len
(
self
.
indices
)
==
len
(
input_storage
)
assert
len
(
self
.
indices
)
==
len
(
input_storage
)
for
i
,
((
input
,
indices
,
subinputs
),
input_storage_i
)
in
enumerate
(
zip
(
self
.
indices
,
input_storage
)):
for
i
,
((
input
,
indices
,
subinputs
),
input_storage_i
)
in
enumerate
(
zip
(
self
.
indices
,
input_storage
)):
# Replace any default value given as a variable by its container.
# Replace any default value given as a variable by its container.
# Note that this makes sense only in the context of shared variables,
# Note that this makes sense only in the context of shared variables,
# but for now we avoid dealing directly with them to avoid dependency
# but for now we avoid dealing directly with them to avoid dependency
...
@@ -1104,13 +1106,38 @@ class FunctionMaker(object):
...
@@ -1104,13 +1106,38 @@ class FunctionMaker(object):
if
indices
is
not
None
:
if
indices
is
not
None
:
raise
TypeError
(
"Cannot take a Container instance as default for a SymbolicInputKit."
)
raise
TypeError
(
"Cannot take a Container instance as default for a SymbolicInputKit."
)
input_storage_lists
.
append
(
input_storage_i
.
storage
)
input_storage_lists
.
append
(
input_storage_i
.
storage
)
defaults
.
append
((
self
.
required
[
i
],
self
.
refeed
[
i
],
storage
=
input_storage
[
i
]
.
storage
[
0
]
input_storage_i
.
storage
[
0
]))
else
:
else
:
# Normal case: one new, independent storage unit
# Normal case: one new, independent storage unit
input_storage_lists
.
append
([
input_storage_i
])
input_storage_lists
.
append
([
input_storage_i
])
defaults
.
append
((
self
.
required
[
i
],
self
.
refeed
[
i
],
input_storage_i
))
storage
=
input_storage_i
required
=
self
.
required
[
i
]
refeed
=
self
.
refeed
[
i
]
#sanity check-- if an input is required it should not need to be refed
assert
not
(
required
and
refeed
)
#shared variables need neither be input by the user nor refed
if
input
.
shared
:
assert
not
required
assert
not
refeed
storage
=
None
#if an input is required, it never need be refed
if
required
:
storage
=
None
#make sure that we only store a value if we actually need it
if
storage
is
not
None
:
assert
refeed
or
not
required
defaults
.
append
((
required
,
refeed
,
storage
))
# Get a function instance
# Get a function instance
...
@@ -1125,6 +1152,7 @@ class FunctionMaker(object):
...
@@ -1125,6 +1152,7 @@ class FunctionMaker(object):
self
.
profile
.
linker_time
+=
linker_time
self
.
profile
.
linker_time
+=
linker_time
_fn
.
time_thunks
=
self
.
profile
.
flag_time_thunks
_fn
.
time_thunks
=
self
.
profile
.
flag_time_thunks
fn
=
self
.
function_builder
(
_fn
,
_i
,
_o
,
self
.
indices
,
self
.
outputs
,
fn
=
self
.
function_builder
(
_fn
,
_i
,
_o
,
self
.
indices
,
self
.
outputs
,
defaults
,
self
.
unpack_single
,
self
.
return_none
,
self
)
defaults
,
self
.
unpack_single
,
self
.
return_none
,
self
)
fn
.
profile
=
self
.
profile
fn
.
profile
=
self
.
profile
...
...
theano/compile/io.py
浏览文件 @
96220be7
...
@@ -194,7 +194,12 @@ class In(SymbolicInput):
...
@@ -194,7 +194,12 @@ class In(SymbolicInput):
# try to keep it synchronized.
# try to keep it synchronized.
def
__init__
(
self
,
variable
,
name
=
None
,
value
=
None
,
update
=
None
,
def
__init__
(
self
,
variable
,
name
=
None
,
value
=
None
,
update
=
None
,
mutable
=
None
,
strict
=
False
,
allow_downcast
=
None
,
autoname
=
True
,
mutable
=
None
,
strict
=
False
,
allow_downcast
=
None
,
autoname
=
True
,
implicit
=
None
,
borrow
=
None
):
implicit
=
None
,
borrow
=
None
,
shared
=
False
):
#if shared, an input's value comes from its persistent storage, not from a default stored
#in the function or from the caller
self
.
shared
=
shared
# mutable implies the output can be both aliased to the input and that the input can be
# mutable implies the output can be both aliased to the input and that the input can be
# destroyed. borrow simply implies the output can be aliased to the input. Thus
# destroyed. borrow simply implies the output can be aliased to the input. Thus
...
...
theano/compile/pfunc.py
浏览文件 @
96220be7
...
@@ -427,14 +427,18 @@ def pfunc(params, outputs=None, mode=None, updates=[], givens=[],
...
@@ -427,14 +427,18 @@ def pfunc(params, outputs=None, mode=None, updates=[], givens=[],
i
.
variable
=
iv
i
.
variable
=
iv
for
sv
in
shared_inputs
:
for
sv
in
shared_inputs
:
#pass value of None here
#value will be stored in the resulting functions' defaults list
#but since the value of shared variables never needs to be refed, it is not needed
if
sv
in
update_d
:
if
sv
in
update_d
:
si
=
In
(
variable
=
sv
,
value
=
sv
.
container
,
mutable
=
True
,
si
=
In
(
variable
=
sv
,
value
=
sv
.
container
,
mutable
=
True
,
borrow
=
True
,
update
=
update_d
[
sv
])
borrow
=
True
,
update
=
update_d
[
sv
]
,
shared
=
True
)
else
:
else
:
si
=
In
(
variable
=
sv
,
value
=
sv
.
container
,
si
=
In
(
variable
=
sv
,
value
=
sv
.
container
,
mutable
=
False
,
borrow
=
True
)
mutable
=
False
,
borrow
=
True
,
shared
=
True
)
inputs
.
append
(
si
)
inputs
.
append
(
si
)
return
orig_function
(
inputs
,
cloned_outputs
,
mode
,
return
orig_function
(
inputs
,
cloned_outputs
,
mode
,
accept_inplace
=
accept_inplace
,
name
=
name
,
profile
=
profile
)
accept_inplace
=
accept_inplace
,
name
=
name
,
profile
=
profile
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论