Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
2d54ad18
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
2d54ad18
编写于
11月 12, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(lite): add global layout transform interface for load and run
GitOrigin-RevId: 65c2430ec2c93a48d633d3b638bac885e81ce52e
上级
ba2f0c2e
变更
8
显示空白变更内容
内联
并排
Showing
8 changed file
with
230 addition
and
11 deletion
+230
-11
dnn/src/cuda/conv_bias/cudnn_conv.cpp
dnn/src/cuda/conv_bias/cudnn_conv.cpp
+1
-1
lite/load_and_run/src/helpers/common.h
lite/load_and_run/src/helpers/common.h
+2
-0
lite/load_and_run/src/models/model_mdl.cpp
lite/load_and_run/src/models/model_mdl.cpp
+12
-6
lite/load_and_run/src/models/model_mdl.h
lite/load_and_run/src/models/model_mdl.h
+17
-2
lite/load_and_run/src/options/layout_trans_options.cpp
lite/load_and_run/src/options/layout_trans_options.cpp
+148
-0
lite/load_and_run/src/options/layout_trans_options.h
lite/load_and_run/src/options/layout_trans_options.h
+45
-0
lite/load_and_run/src/options/strategy_options.cpp
lite/load_and_run/src/options/strategy_options.cpp
+1
-1
lite/load_and_run/src/strategys/strategy_normal.cpp
lite/load_and_run/src/strategys/strategy_normal.cpp
+4
-1
未找到文件。
dnn/src/cuda/conv_bias/cudnn_conv.cpp
浏览文件 @
2d54ad18
...
...
@@ -138,7 +138,7 @@ void ConvBiasForwardImpl::AlgoCUDNNConv::exec(const ExecArgs& args) const {
if
(
args
.
z_layout
->
ndim
>
0
)
{
auto
z_tensor
=
*
args
.
z_tensor
;
if
(
args
.
z_layout
->
dtype
.
enumv
()
!=
args
.
bias_layout
->
dtype
.
enumv
())
{
z_tensor
.
raw_ptr
=
bundle
.
get
(
2
)
;
z_tensor
=
TensorND
{
bundle
.
get
(
2
),
args
.
z_tensor
->
layout
}
;
z_tensor
.
layout
.
dtype
=
DType
();
args
.
opr
->
check_or_deduce_dtype_fwd
(
args
.
src_layout
->
dtype
,
args
.
filter_layout
->
dtype
,
...
...
lite/load_and_run/src/helpers/common.h
浏览文件 @
2d54ad18
...
...
@@ -36,6 +36,8 @@ enum class RunStage {
AFTER_RUNNING_ITER
=
6
,
AFTER_MODEL_RUNNING
=
7
,
GLOBAL_OPTIMIZATION
=
8
,
};
/*!
* \brief: type of different model
...
...
lite/load_and_run/src/models/model_mdl.cpp
浏览文件 @
2d54ad18
...
...
@@ -52,15 +52,15 @@ void ModelMdl::load_model() {
m_model_file
->
read
(
&
testcase_num
,
sizeof
(
testcase_num
));
}
auto
format
=
m_
format
=
mgb
::
serialization
::
GraphLoader
::
identify_graph_dump_format
(
*
m_model_file
);
mgb_assert
(
format
.
valid
(),
m_
format
.
valid
(),
"invalid format, please make sure model is dumped by GraphDumper"
);
//! load computing graph of model
m_loader
=
mgb
::
serialization
::
GraphLoader
::
make
(
std
::
move
(
m_model_file
),
format
.
val
());
std
::
move
(
m_model_file
),
m_
format
.
val
());
m_load_result
=
m_loader
->
load
(
m_load_config
,
false
);
m_load_config
.
comp_graph
.
reset
();
...
...
@@ -87,9 +87,15 @@ void ModelMdl::make_output_spec() {
m_asyc_exec
=
m_load_result
.
graph_compile
(
m_output_spec
);
}
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>&
ModelMdl
::
reset_loader
()
{
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>&
ModelMdl
::
reset_loader
(
std
::
unique_ptr
<
mgb
::
serialization
::
InputFile
>
input_file
)
{
if
(
input_file
)
{
m_loader
=
mgb
::
serialization
::
GraphLoader
::
make
(
std
::
move
(
input_file
),
m_loader
->
format
());
}
else
{
m_loader
=
mgb
::
serialization
::
GraphLoader
::
make
(
m_loader
->
reset_file
(),
m_loader
->
format
());
}
return
m_loader
;
}
...
...
lite/load_and_run/src/models/model_mdl.h
浏览文件 @
2d54ad18
...
...
@@ -50,8 +50,16 @@ public:
//! get load config for megDL model
mgb
::
serialization
::
GraphLoadConfig
&
get_mdl_config
()
{
return
m_load_config
;
}
//! reset the graph loader for dump_with_testcase model
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>&
reset_loader
();
/*! reset the underlying graph loader from which further load() would read()
*
* \param input_file new input_file, can be null
* \return new loader
*/
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>&
reset_loader
(
std
::
unique_ptr
<
mgb
::
serialization
::
InputFile
>
input_file
=
{});
//! get the underlying graph loader
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>&
get_loader
()
{
return
m_loader
;
}
//! algo strategy for runing model
void
set_mdl_strategy
(
Strategy
&
u_strategy
)
{
m_strategy
=
u_strategy
;
}
...
...
@@ -88,11 +96,18 @@ public:
m_load_config
.
comp_graph
.
get
(),
range
);
}
std
::
unique_ptr
<
mgb
::
serialization
::
GraphDumper
>
get_dumper
(
std
::
unique_ptr
<
mgb
::
serialization
::
OutputFile
>
out_file
)
{
return
mgb
::
serialization
::
GraphDumper
::
make
(
std
::
move
(
out_file
),
m_format
.
val
());
}
private:
bool
share_model_mem
;
std
::
string
model_path
;
std
::
unique_ptr
<
mgb
::
serialization
::
InputFile
>
m_model_file
;
mgb
::
serialization
::
GraphLoadConfig
m_load_config
;
mgb
::
Maybe
<
mgb
::
serialization
::
GraphDumpFormat
>
m_format
;
mgb
::
serialization
::
GraphLoader
::
LoadResult
m_load_result
;
std
::
shared_ptr
<
mgb
::
serialization
::
GraphLoader
>
m_loader
;
...
...
lite/load_and_run/src/options/layout_trans_options.cpp
0 → 100644
浏览文件 @
2d54ad18
/**
* \file lite/load_and_run/src/options/layout_trans_options.h
*
* This file is part of MegEngine, a deep learning framework developed by
* Megvii.
*
* \copyright Copyright (c) 2020-2021 Megvii Inc. All rights reserved.
*/
#include "layout_trans_options.h"
#include <gflags/gflags.h>
#include "megbrain/serialization/serializer.h"
#include "misc.h"
#include "models/model_lite.h"
#include "models/model_mdl.h"
namespace
lar
{
template
<
>
void
GoptLayoutOption
::
config_model_internel
<
ModelLite
>
(
RuntimeParam
&
runtime_param
,
std
::
shared_ptr
<
ModelLite
>
/* model */
)
{
if
(
runtime_param
.
stage
==
RunStage
::
BEFORE_MODEL_LOAD
)
{
LITE_THROW
(
"lite model don't support global graph optimization"
);
}
}
template
<
>
void
GoptLayoutOption
::
config_model_internel
<
ModelMdl
>
(
RuntimeParam
&
runtime_param
,
std
::
shared_ptr
<
ModelMdl
>
model
)
{
if
(
runtime_param
.
stage
==
RunStage
::
GLOBAL_OPTIMIZATION
)
{
if
(
layout_transform
)
{
auto
&&
load_result
=
model
->
get_mdl_load_result
();
load_result
.
output_var_list
=
mgb
::
gopt
::
layout_transform
(
load_result
.
output_var_list
,
layout_transform_target
);
if
(
!
layout_transform_dump_file
.
empty
())
{
auto
out_file
=
mgb
::
serialization
::
OutputFile
::
make_fs
(
layout_transform_dump_file
.
c_str
(),
'w'
);
auto
testcase_num
=
model
->
get_testcase_num
();
if
(
testcase_num
)
{
const
char
*
magic
=
"mgbtest0"
;
constexpr
size_t
len
=
sizeof
(
magic
);
out_file
->
write
(
magic
,
len
);
out_file
->
write
(
&
testcase_num
,
sizeof
(
testcase_num
));
}
using
DumpConfig
=
mgb
::
serialization
::
GraphDumper
::
DumpConfig
;
DumpConfig
config
{
1
,
false
,
false
};
auto
dumper
=
model
->
get_dumper
(
std
::
move
(
out_file
));
dumper
->
dump
(
load_result
.
output_var_list
,
config
);
if
(
testcase_num
)
{
auto
input_file
=
model
->
get_loader
()
->
reset_file
();
auto
current_offset
=
input_file
->
tell
();
auto
loader
=
model
->
reset_loader
(
std
::
move
(
input_file
));
auto
testcase
=
loader
->
load
(
model
->
get_mdl_config
(),
false
);
mgb
::
serialization
::
GraphDumper
::
DumpConfig
config
{
1
,
false
,
false
};
for
(
size_t
i
=
0
;
i
<
testcase_num
;
++
i
)
{
auto
casefile
=
mgb
::
serialization
::
OutputFile
::
make_fs
(
layout_transform_dump_file
.
c_str
(),
'a'
);
auto
casedumper
=
model
->
get_dumper
(
std
::
move
(
casefile
));
casedumper
->
dump
(
testcase
.
output_var_list
,
config
);
if
(
i
!=
testcase_num
-
1
)
{
loader
=
model
->
reset_loader
();
testcase
=
loader
->
load
(
model
->
get_mdl_config
(),
false
);
}
}
input_file
=
model
->
get_loader
()
->
reset_file
();
input_file
->
rewind
();
input_file
->
skip
(
current_offset
);
model
->
reset_loader
(
std
::
move
(
input_file
));
}
}
}
}
}
}
// namespace lar
using
namespace
lar
;
GoptLayoutOption
::
GoptLayoutOption
()
{
m_option_name
=
"gopt_layout"
;
if
(
FLAGS_layout_transform
!=
"cuda"
&&
FLAGS_layout_transform
!=
"cpu"
&&
FLAGS_layout_transform
!=
"opencl"
)
{
layout_transform
=
false
;
layout_transform_target
=
mgb
::
gopt
::
GraphTuningOptions
::
Target
::
UNSPEC
;
}
else
{
layout_transform
=
true
;
if
(
FLAGS_layout_transform
==
"cuda"
)
{
layout_transform_target
=
mgb
::
gopt
::
GraphTuningOptions
::
Target
::
CUDA
;
}
else
if
(
FLAGS_layout_transform
==
"cpu"
)
{
layout_transform_target
=
mgb
::
gopt
::
GraphTuningOptions
::
Target
::
CPU
;
}
else
if
(
FLAGS_layout_transform
==
"opencl"
)
{
layout_transform_target
=
mgb
::
gopt
::
GraphTuningOptions
::
Target
::
OPENCL
;
}
}
layout_transform_dump_file
=
FLAGS_layout_transform_dump
;
}
bool
GoptLayoutOption
::
is_valid
()
{
bool
ret
=
false
;
if
(
!
FLAGS_layout_transform
.
empty
())
{
if
(
FLAGS_layout_transform
!=
"cuda"
&&
FLAGS_layout_transform
!=
"cpu"
&&
FLAGS_layout_transform
!=
"opencl"
)
{
mgb_assert
(
false
,
"unsupported target(got:%s) for global layout "
"transform"
,
FLAGS_layout_transform
.
c_str
());
ret
=
false
;
}
else
{
ret
=
true
;
}
}
ret
=
ret
||
FLAGS_layout_transform_dump
.
empty
();
return
ret
;
}
std
::
shared_ptr
<
OptionBase
>
GoptLayoutOption
::
create_option
()
{
static
std
::
shared_ptr
<
GoptLayoutOption
>
option
(
new
GoptLayoutOption
);
if
(
GoptLayoutOption
::
is_valid
())
{
return
std
::
static_pointer_cast
<
OptionBase
>
(
option
);
}
else
{
return
nullptr
;
}
}
void
GoptLayoutOption
::
config_model
(
RuntimeParam
&
runtime_param
,
std
::
shared_ptr
<
ModelBase
>
model
)
{
CONFIG_MODEL_FUN
;
}
DEFINE_string
(
layout_transform
,
""
,
"Enable global layout transform optimization for computing graph. User should "
"specify the device target for the optimization, and a series of passes will "
"be applied on the computing graph. The passes will benchmark the elapsed time "
"of operators on different tensor layouts, and select fastest implementation "
"for the operators. The optimization process will take some time. The default "
"target is unspec, which all the available for operators will be profiled. So "
"the optimize time will be longer."
);
DEFINE_string
(
layout_transform_dump
,
""
,
"The computing graph after global layout transform will be dumped to the given "
"file path."
);
REGIST_OPTION_CREATOR
(
gopt_layout
,
lar
::
GoptLayoutOption
::
create_option
);
lite/load_and_run/src/options/layout_trans_options.h
0 → 100644
浏览文件 @
2d54ad18
/**
* \file lite/load_and_run/src/options/layout_trans_options.h
*
* This file is part of MegEngine, a deep learning framework developed by
* Megvii.
*
* \copyright Copyright (c) 2020-2021 Megvii Inc. All rights reserved.
*/
#pragma once
#include <gflags/gflags.h>
#include "megbrain/gopt/inference.h"
#include "models/model.h"
#include "option_base.h"
DECLARE_string
(
layout_transform
);
DECLARE_string
(
layout_transform_dump
);
namespace
lar
{
class
GoptLayoutOption
final
:
public
OptionBase
{
public:
//! get condition for construct FastRunOption
static
bool
is_valid
();
//! creat option using condition from cmdline args
static
std
::
shared_ptr
<
OptionBase
>
create_option
();
//! configure model for different runtime_param
void
config_model
(
RuntimeParam
&
runtime_param
,
std
::
shared_ptr
<
ModelBase
>
model
)
override
;
//! get options name for quickly search
std
::
string
option_name
()
const
override
{
return
m_option_name
;
}
private:
GoptLayoutOption
();
//! config template for different model
template
<
typename
ModelImpl
>
void
config_model_internel
(
RuntimeParam
&
,
std
::
shared_ptr
<
ModelImpl
>
)
{}
bool
layout_transform
;
std
::
string
m_option_name
;
std
::
string
layout_transform_dump_file
;
mgb
::
gopt
::
GraphTuningOptions
::
Target
layout_transform_target
;
};
}
// namespace lar
lite/load_and_run/src/options/strategy_options.cpp
浏览文件 @
2d54ad18
lite/load_and_run/src/strategys/strategy_normal.cpp
浏览文件 @
2d54ad18
...
...
@@ -60,6 +60,9 @@ void NormalStrategy::run_subline() {
m_runtime_param
.
stage
=
RunStage
::
AFTER_MODEL_LOAD
;
stage_config_model
();
m_runtime_param
.
stage
=
RunStage
::
GLOBAL_OPTIMIZATION
;
stage_config_model
();
m_runtime_param
.
stage
=
RunStage
::
BEFORE_OUTSPEC_SET
;
stage_config_model
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录