Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
36d1aadf
M
mindspore
项目概览
magicwindyyd
/
mindspore
与 Fork 源项目一致
Fork自
MindSpore / mindspore
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindspore
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
36d1aadf
编写于
6月 09, 2020
作者:
H
huanghui
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix when Batchnorm's output is 0,1,2,4, fission doesn't work
上级
09318086
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
3 addition
and
3 deletion
+3
-3
mindspore/ccsrc/pre_activate/ascend/ascend_backend_optimization.cc
.../ccsrc/pre_activate/ascend/ascend_backend_optimization.cc
+1
-1
mindspore/ccsrc/pre_activate/ascend/ir_fission/single_batch_norm_fission.cc
...e_activate/ascend/ir_fission/single_batch_norm_fission.cc
+2
-2
未找到文件。
mindspore/ccsrc/pre_activate/ascend/ascend_backend_optimization.cc
浏览文件 @
36d1aadf
...
...
@@ -99,6 +99,7 @@ namespace {
void
AddAscendBackendOptionalIRFusion
(
PassManager
*
ir_fusion_pm
)
{
MS_EXCEPTION_IF_NULL
(
ir_fusion_pm
);
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
BatchNormBertFission
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
SingleBatchNormFission
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
SquareSumFusion
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
ClipByNormNoDivSquareSumFusion
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
LambUpdateWithLRRuleFusion
>
());
...
...
@@ -225,7 +226,6 @@ void AscendBackendIRFusionOptimization(const std::shared_ptr<session::KernelGrap
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
FusedBatchNormFusion
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
FusedBatchNormMixPrecisionFusion0
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
FusedBatchNormMixPrecisionFusion1
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
SingleBatchNormFission
>
());
}
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
AddMemcpyAsync
>
());
ir_fusion_pm
->
AddPass
(
std
::
make_shared
<
InsertPadForNMSWithMask
>
());
...
...
mindspore/ccsrc/pre_activate/ascend/ir_fission/single_batch_norm_fission.cc
浏览文件 @
36d1aadf
...
...
@@ -24,7 +24,7 @@ namespace mindspore {
namespace
opt
{
namespace
{
const
std
::
vector
<
int
>
kOutputIndex
{
0
,
1
,
2
,
3
,
4
};
constexpr
size_t
kBatchNorm
RealOutputNum
=
5
;
constexpr
size_t
kBatchNorm
LeastOutputNum
=
1
;
constexpr
size_t
kBatchNormRealInputNum
=
3
;
bool
GetBatchNormOutputs
(
const
FuncGraphPtr
&
func_graph
,
const
AnfNodePtr
&
bn
,
std
::
vector
<
AnfNodePtr
>
*
bn_outputs
)
{
...
...
@@ -56,7 +56,7 @@ bool GetBatchNormOutputs(const FuncGraphPtr &func_graph, const AnfNodePtr &bn, s
bn_outputs
->
push_back
(
output
);
output_num
++
;
}
return
output_num
==
kBatchNormReal
OutputNum
;
return
output_num
>
kBatchNormLeast
OutputNum
;
}
AnfNodePtr
CreateBNTrainingReduce
(
const
FuncGraphPtr
&
func_graph
,
const
AnfNodePtr
&
bn
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录