Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenDILab开源决策智能平台
treevalue
提交
04cc5e72
T
treevalue
项目概览
OpenDILab开源决策智能平台
/
treevalue
大约 1 年 前同步成功
通知
3
Star
213
Fork
3
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
treevalue
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
04cc5e72
编写于
12月 31, 2021
作者:
HansBug
😆
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
test(hansbug): add benchmark for speed test
上级
0f1096c7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
56 addition
and
24 deletion
+56
-24
test/compare/deepmind/test_dm_tree.py
test/compare/deepmind/test_dm_tree.py
+31
-14
test/compare/jax/test_jax.py
test/compare/jax/test_jax.py
+25
-10
未找到文件。
test/compare/deepmind/test_dm_tree.py
浏览文件 @
04cc5e72
...
@@ -9,23 +9,40 @@ _TREE_1 = FastTreeValue(_TREE_DATA_1)
...
@@ -9,23 +9,40 @@ _TREE_1 = FastTreeValue(_TREE_DATA_1)
@
pytest
.
mark
.
benchmark
(
group
=
'dm-tree'
)
@
pytest
.
mark
.
benchmark
(
group
=
'dm-tree'
)
class
TestCompareWithDMTree
:
class
TestCompareWithDMTree
:
def
test_dm_flatten_with_path
(
self
,
benchmark
):
N
=
5
benchmark
(
tree
.
flatten_with_path
,
_TREE_DATA_1
)
def
test_dm_flatten_without_path
(
self
,
benchmark
):
def
__create_nested_tree_data
(
self
,
n
):
benchmark
(
tree
.
flatten
,
_TREE_DATA_1
)
return
{
(
'no_%04d'
%
(
i
+
1
,)):
_TREE_DATA_1
for
i
in
range
(
n
)
}
def
test_tv_flatten
(
self
,
benchmark
):
def
__create_nested_tree
(
self
,
n
):
benchmark
(
flatten
,
_TREE_1
)
return
FastTreeValue
(
self
.
__create_nested_tree_data
(
n
)
)
def
test_dm_map_structure
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
tree
.
map_structure
,
lambda
x
:
x
**
2
,
_TREE_DATA_1
)
def
test_dm_flatten_with_path
(
self
,
benchmark
,
n
):
benchmark
(
tree
.
flatten_with_path
,
self
.
__create_nested_tree_data
(
n
))
def
test_tv_mapping
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
mapping
,
_TREE_1
,
lambda
x
:
x
**
2
)
def
test_dm_flatten_without_path
(
self
,
benchmark
,
n
):
benchmark
(
tree
.
flatten
,
self
.
__create_nested_tree_data
(
n
))
def
test_dm_map_structure_with_path
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
tree
.
map_structure_with_path
,
lambda
p
,
x
:
x
*
len
(
p
),
_TREE_DATA_1
)
def
test_tv_flatten
(
self
,
benchmark
,
n
):
benchmark
(
flatten
,
self
.
__create_nested_tree
(
n
))
def
test_tv_mapping_with_path
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
mapping
,
_TREE_1
,
lambda
x
,
p
:
x
*
len
(
p
))
def
test_dm_map_structure
(
self
,
benchmark
,
n
):
benchmark
(
tree
.
map_structure
,
lambda
x
:
x
**
2
,
self
.
__create_nested_tree_data
(
n
))
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
def
test_tv_mapping
(
self
,
benchmark
,
n
):
benchmark
(
mapping
,
self
.
__create_nested_tree
(
n
),
lambda
x
:
x
**
2
)
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
def
test_dm_map_structure_with_path
(
self
,
benchmark
,
n
):
benchmark
(
tree
.
map_structure_with_path
,
lambda
p
,
x
:
x
*
len
(
p
),
self
.
__create_nested_tree_data
(
n
))
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
def
test_tv_mapping_with_path
(
self
,
benchmark
,
n
):
benchmark
(
mapping
,
self
.
__create_nested_tree
(
n
),
lambda
x
,
p
:
x
*
len
(
p
))
test/compare/jax/test_jax.py
浏览文件 @
04cc5e72
...
@@ -11,20 +11,35 @@ _TREE_1 = FastTreeValue(_TREE_DATA_1)
...
@@ -11,20 +11,35 @@ _TREE_1 = FastTreeValue(_TREE_DATA_1)
@
pytest
.
mark
.
benchmark
(
group
=
'jax-pytree'
)
@
pytest
.
mark
.
benchmark
(
group
=
'jax-pytree'
)
class
TestCompareWithJaxPytree
:
class
TestCompareWithJaxPytree
:
def
test_jax_tree_map
(
self
,
benchmark
):
N
=
5
benchmark
(
pytree
.
tree_map
,
lambda
x
:
x
**
2
,
_TREE_DATA_1
)
def
test_tv_mapping
(
self
,
benchmark
):
def
__create_nested_tree_data
(
self
,
n
):
benchmark
(
mapping
,
_TREE_1
,
lambda
x
:
x
**
2
)
return
{
(
'no_%04d'
%
(
i
+
1
,)):
_TREE_DATA_1
for
i
in
range
(
n
)
}
def
__create_nested_tree
(
self
,
n
):
return
FastTreeValue
(
self
.
__create_nested_tree_data
(
n
))
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
def
test_jax_tree_map
(
self
,
benchmark
,
n
):
benchmark
(
pytree
.
tree_map
,
lambda
x
:
x
**
2
,
self
.
__create_nested_tree_data
(
n
))
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
def
test_tv_mapping
(
self
,
benchmark
,
n
):
benchmark
(
mapping
,
self
.
__create_nested_tree
(
n
),
lambda
x
:
x
**
2
)
def
test_tv_mapping_with_path
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
mapping
,
_TREE_1
,
lambda
x
,
p
:
x
**
2
)
def
test_tv_mapping_with_path
(
self
,
benchmark
,
n
):
benchmark
(
mapping
,
self
.
__create_nested_tree
(
n
),
lambda
x
,
p
:
x
**
2
)
def
test_jax_tree_flatten
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
pytree
.
tree_flatten
,
_TREE_DATA_1
)
def
test_jax_tree_flatten
(
self
,
benchmark
,
n
):
benchmark
(
pytree
.
tree_flatten
,
self
.
__create_nested_tree_data
(
n
))
def
test_tv_flatten
(
self
,
benchmark
):
@
pytest
.
mark
.
parametrize
(
'n'
,
[
2
**
i
for
i
in
range
(
N
)])
benchmark
(
flatten
,
_TREE_1
)
def
test_tv_flatten
(
self
,
benchmark
,
n
):
benchmark
(
flatten
,
self
.
__create_nested_tree
(
n
))
def
test_jax_tree_unflatten
(
self
,
benchmark
):
def
test_jax_tree_unflatten
(
self
,
benchmark
):
leaves
,
treedef
=
pytree
.
tree_flatten
(
_TREE_DATA_1
)
leaves
,
treedef
=
pytree
.
tree_flatten
(
_TREE_DATA_1
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录