Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
96bb63f9
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看板
提交
96bb63f9
编写于
9月 15, 2020
作者:
S
seiriosPlus
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix UT
上级
202c5375
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
169 addition
and
0 deletion
+169
-0
python/paddle/fluid/tests/unittests/test_dist_lookup_sparse_table_fuse_ops.py
...tests/unittests/test_dist_lookup_sparse_table_fuse_ops.py
+169
-0
未找到文件。
python/paddle/fluid/tests/unittests/test_dist_lookup_sparse_table_fuse_ops.py
0 → 100644
浏览文件 @
96bb63f9
# Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from
__future__
import
print_function
import
unittest
import
numpy
as
np
import
paddle.fluid
as
fluid
import
paddle.fluid.core
as
core
class
TestLookupTableFuseOp
(
unittest
.
TestCase
):
def
test_fuse
(
self
):
places
=
[
core
.
CPUPlace
()]
# currently only support CPU
for
place
in
places
:
self
.
check_with_place
(
place
)
def
check_with_place
(
self
,
place
):
scope
=
fluid
.
global_scope
()
scope
.
var
(
"LearningRate"
).
get_tensor
().
set
([
0.01
],
place
)
scope
.
var
(
"Ids"
).
get_tensor
().
set
([
i
for
i
in
range
(
100
)],
place
)
init_program
=
fluid
.
Program
()
lr
=
init_program
.
global_block
().
create_var
(
name
=
"LearningRate"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
1
],
dtype
=
"float32"
)
ids
=
init_program
.
global_block
().
create_var
(
name
=
"Ids"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
100
],
dtype
=
"int64"
)
output
=
init_program
.
global_block
().
create_var
(
name
=
"output"
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
100
,
8
],
dtype
=
"float32"
)
metas
=
[]
metas
.
append
(
"embedding_1.block0:Param,Moment1,Moment2:8,8,8:0:embedding_1@GRAD.block0:embedding_1.block0,embedding_1_moment1_0,embedding_1_moment2_0,kSparseIDs@embedding_1.block0:uniform_random&0&-0.5&0.5,fill_constant&0.0,fill_constant&0.0:none"
)
metas
.
append
(
"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"
)
init_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_init"
,
inputs
=
None
,
outputs
=
None
,
attrs
=
{
"large_scale_metas"
:
metas
})
init_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_read"
,
inputs
=
{
"Ids"
:
ids
},
outputs
=
{
"Out"
:
output
},
attrs
=
{
"tablename"
:
"embedding_1.block0"
,
"init"
:
True
,
"value_names"
:
[
"Param"
],
})
init_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_read"
,
inputs
=
{
"Ids"
:
ids
},
outputs
=
{
"Out"
:
output
},
attrs
=
{
"tablename"
:
"embedding_2.block0"
,
"init"
:
True
,
"value_names"
:
[
"Param"
],
})
executor
=
fluid
.
Executor
(
place
)
executor
.
run
(
init_program
)
training_program
=
fluid
.
Program
()
scope
.
var
(
'Beta1Pow'
).
get_tensor
().
set
([
0
],
place
)
scope
.
var
(
'Beta2Pow'
).
get_tensor
().
set
([
0
],
place
)
rows
=
[
0
,
1
,
2
,
3
,
4
,
5
,
6
]
row_numel
=
8
w_selected_rows
=
scope
.
var
(
'Grad'
).
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
)
lr
=
training_program
.
global_block
().
create_var
(
name
=
"LearningRate"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
1
],
dtype
=
"float32"
)
grads
=
training_program
.
global_block
().
create_var
(
name
=
"Grad"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
SELECTED_ROWS
,
shape
=
[
100
,
8
],
dtype
=
"float32"
)
beta1
=
training_program
.
global_block
().
create_var
(
name
=
"Beta1Pow"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
1
],
dtype
=
"float32"
)
beta2
=
training_program
.
global_block
().
create_var
(
name
=
"Beta2Pow"
,
persistable
=
True
,
type
=
fluid
.
core
.
VarDesc
.
VarType
.
LOD_TENSOR
,
shape
=
[
1
],
dtype
=
"float32"
)
training_program
.
global_block
().
append_op
(
type
=
"lookup_sparse_table_fuse_adam"
,
inputs
=
{
"Grad"
:
grads
,
"LearningRate"
:
lr
,
"Beta1Pow"
:
beta1
,
"Beta2Pow"
:
beta2
,
},
outputs
=
{
"Beta1PowOut"
:
beta1
,
"Beta2PowOut"
:
beta2
},
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"
:
grads
,
"LearningRate"
:
lr
},
attrs
=
{
"is_entry"
:
False
,
"tablename"
:
"embedding_2.block0"
,
"value_names"
:
[
"Param"
],
})
executor
.
run
(
training_program
)
if
__name__
==
"__main__"
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录