Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
ffd5f44e
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ffd5f44e
编写于
9月 14, 2020
作者:
S
seiriosPlus
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add UT for fuse
上级
d41d716f
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
47 addition
and
6 deletion
+47
-6
python/paddle/fluid/tests/unittests/test_lookup_sparse_table_fuse_ops.py
...luid/tests/unittests/test_lookup_sparse_table_fuse_ops.py
+47
-6
未找到文件。
python/paddle/fluid/tests/unittests/test_lookup_sparse_table_fuse_ops.py
浏览文件 @
ffd5f44e
...
...
@@ -15,6 +15,8 @@
from
__future__
import
print_function
import
unittest
import
numpy
as
np
import
paddle.fluid
as
fluid
import
paddle.fluid.core
as
core
...
...
@@ -27,8 +29,11 @@ class TestLookupTableFuseOp(unittest.TestCase):
self
.
check_with_place
(
place
)
def
check_with_place
(
self
,
place
):
scope
=
core
.
Scope
()
program
=
fluid
.
Program
()
scope
=
fluid
.
global_scope
()
init_program
=
fluid
.
Program
()
lr
=
scope
.
var
(
"LearningRate"
)
lr
.
get_tensor
().
set
([
0.01
],
place
)
ids
=
[
i
for
i
in
range
(
100
)]
out
=
scope
.
var
(
"output"
)
...
...
@@ -41,13 +46,13 @@ class TestLookupTableFuseOp(unittest.TestCase):
"embedding_2.block0:Param:8:0:embedding_2@GRAD.block0:embedding_2.block0,kSparseIDs@embedding_2.block0:uniform_random&0&-0.5&0.5:none"
)
program
.
global_block
().
append_op
(
init_
program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_init"
,
inputs
=
None
,
outputs
=
None
,
attrs
=
{
"large_scale_metas"
:
metas
})
program
.
global_block
().
append_op
(
init_
program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_read"
,
inputs
=
{
"Ids"
:
ids
},
outputs
=
{
"Out"
:
out
},
...
...
@@ -57,7 +62,7 @@ class TestLookupTableFuseOp(unittest.TestCase):
"value_names"
:
[
"Param"
,
"Moment1"
,
"Moment2"
],
})
program
.
global_block
().
append_op
(
init_
program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_read"
,
inputs
=
{
"Ids"
:
ids
},
outputs
=
{
"Out"
:
out
},
...
...
@@ -68,7 +73,43 @@ class TestLookupTableFuseOp(unittest.TestCase):
})
executor
=
fluid
.
Executor
(
fluid
.
CPUPlace
())
executor
.
run
(
program
)
executor
.
run
(
init_program
)
training_program
=
fluid
.
Program
()
rows
=
[
0
,
1
,
2
,
3
,
4
,
5
,
6
]
row_numel
=
7
w_selected_rows
=
scope
.
var
(
'W'
).
get_selected_rows
()
w_selected_rows
.
set_height
(
len
(
rows
))
w_selected_rows
.
set_rows
(
rows
)
w_array
=
np
.
ones
((
len
(
rows
),
row_numel
)).
astype
(
"float32"
)
for
i
in
range
(
len
(
rows
)):
w_array
[
i
]
*=
i
w_tensor
=
w_selected_rows
.
get_tensor
()
w_tensor
.
set
(
w_array
,
place
)
training_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_fuse_adam"
,
inputs
=
{
"Grad"
:
ids
,
"LearningRate"
:
lr
},
outputs
=
{
"Out"
:
out
},
attrs
=
{
"is_entry"
:
False
,
"tablename"
:
"embedding_1.block0"
,
"value_names"
:
[
"Param"
,
"Moment1"
,
"Moment2"
],
})
training_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_fuse_sgd"
,
inputs
=
{
"Grad"
:
ids
,
"LearningRate"
:
lr
},
outputs
=
{
"Out"
:
out
},
attrs
=
{
"is_entry"
:
False
,
"tablename"
:
"embedding_2.block0"
,
"value_names"
:
[
"Param"
],
})
if
__name__
==
"__main__"
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录