Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
pytensor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
testgroup
pytensor
Commits
fe7b8e98
提交
fe7b8e98
authored
1月 08, 2014
作者:
AlOa
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Differents make_loop functions for CAReduce and Elemwise
上级
95af7fce
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
66 行增加
和
36 行删除
+66
-36
elemwise.py
theano/tensor/elemwise.py
+3
-3
elemwise_cgen.py
theano/tensor/elemwise_cgen.py
+63
-33
没有找到文件。
theano/tensor/elemwise.py
浏览文件 @
fe7b8e98
...
@@ -1091,7 +1091,7 @@ class Elemwise(OpenMPOp):
...
@@ -1091,7 +1091,7 @@ class Elemwise(OpenMPOp):
loop_orders
=
loop_orders
,
loop_orders
=
loop_orders
,
dtypes
=
dtypes
,
dtypes
=
dtypes
,
loop_tasks
=
all_code
,
loop_tasks
=
all_code
,
sub
=
sub
,
reduce
=
False
,
openmp
=
self
.
openmp
)
sub
=
sub
,
openmp
=
self
.
openmp
)
else
:
else
:
loop
=
cgen
.
make_reordered_loop
(
loop
=
cgen
.
make_reordered_loop
(
init_loop_orders
=
loop_orders
,
init_loop_orders
=
loop_orders
,
...
@@ -1582,9 +1582,9 @@ for(int i=0;i<PyArray_NDIM(%(iname)s);i++){
...
@@ -1582,9 +1582,9 @@ for(int i=0;i<PyArray_NDIM(%(iname)s);i++){
+
[(
""
,
code1
),
""
])
+
[(
""
,
code1
),
""
])
else
:
else
:
all_code
=
[
task0_decl
+
code1
]
all_code
=
[
task0_decl
+
code1
]
loop
=
cgen
.
make_loop
(
loop
=
cgen
.
make_loop
_careduce
(
[
order
,
range
(
nnested
)
+
[
'x'
]
*
len
(
axis
)],
[
order
,
range
(
nnested
)
+
[
'x'
]
*
len
(
axis
)],
[
idtype
,
adtype
],
all_code
,
sub
,
reduce
=
True
)
[
idtype
,
adtype
],
all_code
,
sub
)
end
=
""
end
=
""
if
adtype
!=
odtype
:
if
adtype
!=
odtype
:
...
...
theano/tensor/elemwise_cgen.py
浏览文件 @
fe7b8e98
...
@@ -171,8 +171,7 @@ def make_alloc(loop_orders, dtype, sub, fortran='0'):
...
@@ -171,8 +171,7 @@ def make_alloc(loop_orders, dtype, sub, fortran='0'):
}
}
"""
%
dict
(
locals
(),
**
sub
)
"""
%
dict
(
locals
(),
**
sub
)
def
make_loop
(
loop_orders
,
dtypes
,
loop_tasks
,
sub
,
openmp
=
None
):
def
make_loop
(
loop_orders
,
dtypes
,
loop_tasks
,
sub
,
reduce
=
False
,
openmp
=
None
):
"""
"""
Make a nested loop over several arrays and associate specific code
Make a nested loop over several arrays and associate specific code
to each level of nesting.
to each level of nesting.
...
@@ -197,12 +196,8 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
...
@@ -197,12 +196,8 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
@param sub: Maps 'lv#' to a suitable variable name.
@param sub: Maps 'lv#' to a suitable variable name.
The 'lvi' variable corresponds to the ith element of loop_orders.
The 'lvi' variable corresponds to the ith element of loop_orders.
@type reduce: boolean
@param reduce: true if this function is called from CAReduce
false if it is called from Elemwise,because in elemnwise to use
openmp the code must be rearranged
"""
"""
def
loop_over
_elemwise
(
preloop
,
code
,
indices
,
i
):
def
loop_over
(
preloop
,
code
,
indices
,
i
):
iterv
=
'ITER_
%
i'
%
i
iterv
=
'ITER_
%
i'
%
i
update
=
""
update
=
""
suitable_n
=
"1"
suitable_n
=
"1"
...
@@ -226,23 +221,6 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
...
@@ -226,23 +221,6 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
}
}
"""
%
locals
()
"""
%
locals
()
def
loop_over_reduce
(
preloop
,
code
,
indices
,
i
):
iterv
=
'ITER_
%
i'
%
i
update
=
""
suitable_n
=
"1"
for
j
,
index
in
enumerate
(
indices
):
var
=
sub
[
'lv
%
i'
%
j
]
update
+=
"
%(var)
s_iter +=
%(var)
s_jump
%(index)
s_
%(i)
s;
\n
"
%
locals
()
if
index
!=
'x'
:
suitable_n
=
"
%(var)
s_n
%(index)
s"
%
locals
()
return
"""
%(preloop)
s
for (int
%(iterv)
s =
%(suitable_n)
s;
%(iterv)
s;
%(iterv)
s--) {
%(code)
s
%(update)
s
}
"""
%
locals
()
preloops
=
{}
preloops
=
{}
for
i
,
(
loop_order
,
dtype
)
in
enumerate
(
zip
(
loop_orders
,
dtypes
)):
for
i
,
(
loop_order
,
dtype
)
in
enumerate
(
zip
(
loop_orders
,
dtypes
)):
for
j
,
index
in
enumerate
(
loop_order
):
for
j
,
index
in
enumerate
(
loop_order
):
...
@@ -255,12 +233,8 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
...
@@ -255,12 +233,8 @@ def make_loop(loop_orders, dtypes, loop_tasks, sub, reduce=False, openmp=None):
preloops
[
0
]
+=
(
"
%%
(lv
%(i)
s)s_iter = (
%(dtype)
s*)(PyArray_DATA(
%%
(lv
%(i)
s)s));
\n
"
%
locals
())
%
sub
preloops
[
0
]
+=
(
"
%%
(lv
%(i)
s)s_iter = (
%(dtype)
s*)(PyArray_DATA(
%%
(lv
%(i)
s)s));
\n
"
%
locals
())
%
sub
s
=
""
s
=
""
if
reduce
:
loop_over
=
loop_over_reduce
else
:
loop_over
=
loop_over_elemwise
for
i
,
(
pre_task
,
task
),
indices
in
reversed
(
zip
(
xrange
(
len
(
loop_tasks
)
-
1
),
loop_tasks
,
zip
(
*
loop_orders
))):
for
i
,
(
pre_task
,
task
),
indices
in
reversed
(
zip
(
xrange
(
len
(
loop_tasks
)
-
1
),
loop_tasks
,
zip
(
*
loop_orders
))):
s
=
loop_over
(
preloops
.
get
(
i
,
""
)
+
pre_task
,
s
+
task
,
indices
,
i
)
s
=
loop_over
(
preloops
.
get
(
i
,
""
)
+
pre_task
,
s
+
task
,
indices
,
i
)
s
+=
loop_tasks
[
-
1
]
s
+=
loop_tasks
[
-
1
]
...
@@ -477,21 +451,77 @@ def make_reordered_loop(init_loop_orders, olv_index, dtypes, inner_task, sub, op
...
@@ -477,21 +451,77 @@ def make_reordered_loop(init_loop_orders, olv_index, dtypes, inner_task, sub, op
### DimShuffle ###
### DimShuffle ###
##################
##################
#################
#################
### Broadcast ###
### Broadcast ###
#################
#################
################
################
### CAReduce ###
### CAReduce ###
################
################
def
make_loop_careduce
(
loop_orders
,
dtypes
,
loop_tasks
,
sub
):
"""
Make a nested loop over several arrays and associate specific code
to each level of nesting.
@type loop_orders: list of N tuples of length M.
@param loop_orders: Each value of each
tuple can be either the index of a dimension to loop over or
the letter 'x' which means there is no looping to be done
over that variable at that point (in other words we broadcast
over that dimension). If an entry is an integer, it will become
an alias of the entry of that rank.
@type loop_tasks: list of M+1 pieces of code.
@param loop_tasks: The ith loop_task is a pair of strings, the first
string is code to be executed before the ith loop starts, the second
one contains code to be executed just before going to the next element
of the ith dimension.
The last element if loop_tasks is a single string, containing code
to be executed at the very end.
@type sub: a dictionary.
@param sub: Maps 'lv#' to a suitable variable name.
The 'lvi' variable corresponds to the ith element of loop_orders.
"""
def
loop_over
(
preloop
,
code
,
indices
,
i
):
iterv
=
'ITER_
%
i'
%
i
update
=
""
suitable_n
=
"1"
for
j
,
index
in
enumerate
(
indices
):
var
=
sub
[
'lv
%
i'
%
j
]
update
+=
"
%(var)
s_iter +=
%(var)
s_jump
%(index)
s_
%(i)
s;
\n
"
%
locals
()
if
index
!=
'x'
:
suitable_n
=
"
%(var)
s_n
%(index)
s"
%
locals
()
return
"""
%(preloop)
s
for (int
%(iterv)
s =
%(suitable_n)
s;
%(iterv)
s;
%(iterv)
s--) {
%(code)
s
%(update)
s
}
"""
%
locals
()
preloops
=
{}
for
i
,
(
loop_order
,
dtype
)
in
enumerate
(
zip
(
loop_orders
,
dtypes
)):
for
j
,
index
in
enumerate
(
loop_order
):
if
index
!=
'x'
:
preloops
.
setdefault
(
j
,
""
)
preloops
[
j
]
+=
(
"
%%
(lv
%(i)
s)s_iter = (
%(dtype)
s*)(PyArray_DATA(
%%
(lv
%(i)
s)s));
\n
"
%
locals
())
%
sub
break
else
:
# all broadcastable
preloops
.
setdefault
(
0
,
""
)
preloops
[
0
]
+=
(
"
%%
(lv
%(i)
s)s_iter = (
%(dtype)
s*)(PyArray_DATA(
%%
(lv
%(i)
s)s));
\n
"
%
locals
())
%
sub
if
len
(
loop_tasks
)
==
1
:
s
=
preloops
.
get
(
0
,
""
)
else
:
s
=
""
for
i
,
(
pre_task
,
task
),
indices
in
reversed
(
zip
(
xrange
(
len
(
loop_tasks
)
-
1
),
loop_tasks
,
zip
(
*
loop_orders
))):
s
=
loop_over
(
preloops
.
get
(
i
,
""
)
+
pre_task
,
s
+
task
,
indices
,
i
)
s
+=
loop_tasks
[
-
1
]
return
"{
%
s}"
%
s
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论