Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
DeepSpeech
提交
3c2dcfad
D
DeepSpeech
项目概览
PaddlePaddle
/
DeepSpeech
大约 2 年 前同步成功
通知
210
Star
8425
Fork
1598
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
245
列表
看板
标记
里程碑
合并请求
3
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
DeepSpeech
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
245
Issue
245
列表
看板
标记
里程碑
合并请求
3
合并请求
3
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
3c2dcfad
编写于
7月 05, 2021
作者:
H
Hui Zhang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
masked_fill and continues
上级
fa04af90
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
27 addition
and
6 deletion
+27
-6
deepspeech/modules/attention.py
deepspeech/modules/attention.py
+5
-4
deepspeech/utils/tensor_utils.py
deepspeech/utils/tensor_utils.py
+22
-2
未找到文件。
deepspeech/modules/attention.py
浏览文件 @
3c2dcfad
...
...
@@ -21,6 +21,7 @@ from paddle import nn
from
paddle.nn
import
initializer
as
I
from
deepspeech.utils.log
import
Log
from
deepspeech.utils.tensor_utils
import
masked_fill
logger
=
Log
(
__name__
).
getlog
()
...
...
@@ -100,17 +101,17 @@ class MultiHeadedAttention(nn.Layer):
if
mask
is
not
None
:
mask
=
mask
.
unsqueeze
(
1
).
equal
(
paddle
.
to_tensor
(
0
,
dtype
=
mask
.
dtype
))
# (batch, 1, *, time2)
scores
=
scores
.
masked_fill
(
mask
,
-
float
(
'inf'
))
scores
=
masked_fill
(
scores
,
mask
,
-
float
(
'inf'
))
attn
=
paddle
.
softmax
(
scores
,
axis
=-
1
)
.
masked_fill
(
mask
,
0.0
)
# (batch, head, time1, time2)
scores
,
axis
=-
1
)
attn
=
masked_fill
(
attn
,
mask
,
0.0
)
# (batch, head, time1, time2)
else
:
attn
=
paddle
.
softmax
(
scores
,
axis
=-
1
)
# (batch, head, time1, time2)
p_attn
=
self
.
dropout
(
attn
)
x
=
paddle
.
matmul
(
p_attn
,
value
)
# (batch, head, time1, d_k)
x
=
x
.
transpose
([
0
,
2
,
1
,
3
]).
contiguous
().
reshape
(
x
=
x
.
transpose
([
0
,
2
,
1
,
3
]).
reshape
(
[
n_batch
,
-
1
,
self
.
h
*
self
.
d_k
])
# (batch, time1, d_model)
return
self
.
linear_out
(
x
)
# (batch, time1, d_model)
...
...
deepspeech/utils/tensor_utils.py
浏览文件 @
3c2dcfad
...
...
@@ -14,15 +14,35 @@
"""Unility functions for Transformer."""
from
typing
import
List
from
typing
import
Tuple
from
typing
import
Optional
from
typing
import
Union
import
paddle
from
deepspeech.utils.log
import
Log
__all__
=
[
"pad_sequence"
,
"add_sos_eos"
,
"th_accuracy"
]
__all__
=
[
"
masked_fill"
,
"
pad_sequence"
,
"add_sos_eos"
,
"th_accuracy"
]
logger
=
Log
(
__name__
).
getlog
()
def
is_broadcastable
(
shp1
,
shp2
):
for
a
,
b
in
zip
(
shp1
[::
-
1
],
shp2
[::
-
1
]):
if
a
==
1
or
b
==
1
or
a
==
b
:
pass
else
:
return
False
return
True
def
masked_fill
(
xs
:
paddle
.
Tensor
,
mask
:
paddle
.
Tensor
,
value
:
Union
[
float
,
int
]):
if
paddle
.
in_dynamic_mode
():
assert
is_broadcastable
(
xs
.
shape
,
mask
.
shape
)
is
True
bshape
=
paddle
.
broadcast_shape
(
xs
.
shape
,
mask
.
shape
)
mask
=
mask
.
broadcast_to
(
bshape
)
trues
=
paddle
.
ones_like
(
xs
)
*
value
xs
=
paddle
.
where
(
mask
,
trues
,
xs
)
return
xs
def
pad_sequence
(
sequences
:
List
[
paddle
.
Tensor
],
batch_first
:
bool
=
False
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录