Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
f30d0055
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
f30d0055
编写于
1月 19, 2021
作者:
Z
Zhen Wang
提交者:
GitHub
1月 19, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix the compiling error of update_loss_scaling when using cuda9. (#30538)
上级
81217a94
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
8 deletion
+21
-8
paddle/fluid/operators/amp/update_loss_scaling_op.h
paddle/fluid/operators/amp/update_loss_scaling_op.h
+21
-8
未找到文件。
paddle/fluid/operators/amp/update_loss_scaling_op.h
浏览文件 @
f30d0055
...
...
@@ -14,6 +14,9 @@
#pragma once
#if defined(PADDLE_WITH_CUDA) && defined(__NVCC__)
#include <cuda.h>
#endif // PADDLE_WITH_CUDA && __NVCC__
#include <cmath>
#include <vector>
#include "paddle/fluid/framework/operator.h"
...
...
@@ -29,13 +32,23 @@ namespace operators {
using
Tensor
=
framework
::
Tensor
;
template
<
typename
T
>
HOSTDEVICE
void
Update
(
const
bool
*
found_inf_data
,
const
T
*
pre_loss_scaling_data
,
const
int
*
good_in_data
,
const
int
*
bad_in_data
,
const
int
incr_every_n_steps
,
const
int
decr_every_n_nan_or_inf
,
const
float
incr_ratio
,
const
float
decr_ratio
,
T
*
updated_loss_scaling_data
,
int
*
good_out_data
,
int
*
bad_out_data
)
{
inline
HOSTDEVICE
bool
check_finite
(
T
value
)
{
#if defined(PADDLE_WITH_CUDA) && defined(__NVCC__)
return
isfinite
(
value
);
#else
return
std
::
isfinite
(
value
);
#endif
}
template
<
typename
T
>
inline
HOSTDEVICE
void
Update
(
const
bool
*
found_inf_data
,
const
T
*
pre_loss_scaling_data
,
const
int
*
good_in_data
,
const
int
*
bad_in_data
,
const
int
incr_every_n_steps
,
const
int
decr_every_n_nan_or_inf
,
const
float
incr_ratio
,
const
float
decr_ratio
,
T
*
updated_loss_scaling_data
,
int
*
good_out_data
,
int
*
bad_out_data
)
{
if
(
*
found_inf_data
)
{
*
good_out_data
=
0
;
*
bad_out_data
=
*
bad_in_data
+
1
;
...
...
@@ -51,7 +64,7 @@ HOSTDEVICE void Update(const bool* found_inf_data,
*
good_out_data
=
*
good_in_data
+
1
;
if
(
*
good_out_data
==
incr_every_n_steps
)
{
T
new_loss_scaling
=
*
pre_loss_scaling_data
*
incr_ratio
;
*
updated_loss_scaling_data
=
std
::
is
finite
(
new_loss_scaling
)
*
updated_loss_scaling_data
=
check_
finite
(
new_loss_scaling
)
?
new_loss_scaling
:
*
pre_loss_scaling_data
;
*
good_out_data
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录