Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
3ab9ace5
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看板
提交
3ab9ace5
编写于
12月 28, 2021
作者:
H
HydrogenSulfate
提交者:
chajchaj
1月 10, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update code
上级
09d4a3a4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
29 addition
and
52 deletion
+29
-52
python/paddle/nn/functional/loss.py
python/paddle/nn/functional/loss.py
+29
-52
未找到文件。
python/paddle/nn/functional/loss.py
浏览文件 @
3ab9ace5
...
...
@@ -1665,6 +1665,27 @@ def cross_entropy(input,
if
input_dims
-
1
==
label_dims
:
label
=
paddle
.
unsqueeze
(
label
,
axis
=
axis
)
if
in_dygraph_mode
():
if
not
soft_label
:
valid_label
=
paddle
.
cast
(
label
!=
ignore_index
,
dtype
=
label
.
dtype
)
*
label
# TODO: Temporarily use paddle.nonzero instead of paddle.max
# to detect and find out possible illegal label values
if
len
(
paddle
.
nonzero
(
valid_label
<
0
))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
<
0
))
raise
ValueError
(
"Target({}) is out of class_dimension's lower bound({})"
.
format
(
invalid_label
[
0
],
0
))
# TODO: Temporarily use paddle.nonzero instead of paddle.max
# to detect and find out possible illegal label values
if
len
(
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
raise
ValueError
(
"Target({}) is out of class_dimension's upper bound({})"
.
format
(
invalid_label
[
0
],
input
.
shape
[
axis
]
-
1
))
if
core
.
is_compiled_with_npu
():
_
,
_
,
out
=
_C_ops
.
softmax_with_cross_entropy
(
input
,
label
,
'soft_label'
,
soft_label
,
'ignore_index'
,
...
...
@@ -1681,7 +1702,7 @@ def cross_entropy(input,
# trans weight from class to sample, shape:N or [N,H,W] for 1d and 2d cases.
if
soft_label
==
True
:
# chajchaj:
# weight's shape is C, where C is class num.
# weight's shape is C, where C is class num.
# for 1d case: label's shape is [N,C], weight_gather's shape is N.
# for 2d case: label's shape is [N,H,W,C], weight_gather's shape is [N,H,W].
weight_gather
=
paddle
.
matmul
(
...
...
@@ -1703,32 +1724,8 @@ def cross_entropy(input,
"when weight is provided"
\
.
format
(
input
.
shape
[
axis
],
weight
.
shape
[
-
1
]))
ignore_weight_mask
=
(
label
!=
ignore_index
)
# ignored position will be False
valid_label
=
paddle
.
cast
(
ignore_weight_mask
,
dtype
=
label
.
dtype
)
*
label
# ignored position will be 0
if
len
(
paddle
.
nonzero
(
valid_label
<
0
))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
<
0
))
raise
ValueError
(
"Target({}) is out of class_dimension's lower bound({})"
.
format
(
invalid_label
[
0
],
0
))
# TODO: Temporarily use paddle.nonzero instead of paddle.max
# to detect and find out possible illegal label values
if
len
(
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
raise
ValueError
(
"Target({}) is out of class_dimension's upper bound({})"
.
format
(
invalid_label
[
0
],
input
.
shape
[
axis
]
-
1
))
ignore_weight_mask
=
paddle
.
cast
(
ignore_weight_mask
,
out
.
dtype
)
# convert from 0 to 0.0
ignore_weight_mask
=
paddle
.
cast
((
label
!=
ignore_index
),
out
.
dtype
)
if
ignore_weight_mask
.
ndim
>
1
and
ignore_weight_mask
.
shape
[
axis
]
==
1
:
# TODO: Temporarily use squeeze instead of squeeze_
...
...
@@ -1842,32 +1839,12 @@ def cross_entropy(input,
"when weight is provided"
\
.
format
(
input
.
shape
[
axis
],
weight
.
shape
[
-
1
]))
ignore_weight_mask
=
(
label
!=
ignore_index
)
# ignored position will be False
valid_label
=
paddle
.
cast
(
ignore_weight_mask
,
dtype
=
label
.
dtype
)
*
label
# ignored position will be 0
if
len
(
paddle
.
nonzero
(
valid_label
<
0
))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
<
0
))
raise
ValueError
(
"Target({}) is out of class_dimension's lower bound({})"
.
format
(
invalid_label
[
0
],
0
))
# TODO: Temporarily use paddle.nonzero instead of paddle.max
# to detect and find out possible illegal label values
if
len
(
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
>
0
:
invalid_label
=
paddle
.
gather_nd
(
valid_label
,
paddle
.
nonzero
(
valid_label
>=
input
.
shape
[
axis
]))
raise
ValueError
(
"Target({}) is out of class_dimension's upper bound({})"
.
format
(
invalid_label
[
0
],
input
.
shape
[
axis
]
-
1
))
ignore_weight_mask
=
paddle
.
cast
(
ignore_weight_mask
,
out
.
dtype
)
# convert from 0 to 0.0
valid_label
=
paddle
.
multiply
(
paddle
.
cast
(
label
!=
ignore_index
,
dtype
=
label
.
dtype
),
label
)
ignore_weight_mask
=
paddle
.
cast
((
label
!=
ignore_index
),
input
.
dtype
)
if
ignore_weight_mask
.
ndim
>
1
and
ignore_weight_mask
.
shape
[
axis
]
==
1
:
ignore_weight_mask
=
paddle
.
squeeze
(
ignore_weight_mask
,
axis
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录