Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Parakeet
提交
e0ba85f6
P
Parakeet
项目概览
PaddlePaddle
/
Parakeet
通知
14
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
19
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Parakeet
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
19
Issue
19
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
e0ba85f6
编写于
5月 08, 2020
作者:
C
chenfeiyu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update for wavenet and clarinet
上级
ff1d66ea
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
21 addition
and
33 deletion
+21
-33
README.md
README.md
+1
-1
examples/clarinet/train.py
examples/clarinet/train.py
+5
-5
examples/wavenet/train.py
examples/wavenet/train.py
+6
-7
parakeet/models/clarinet/utils.py
parakeet/models/clarinet/utils.py
+6
-18
parakeet/models/wavenet/wavenet.py
parakeet/models/wavenet/wavenet.py
+3
-2
未找到文件。
README.md
浏览文件 @
e0ba85f6
...
@@ -40,7 +40,7 @@ sudo apt-get install libsndfile1
...
@@ -40,7 +40,7 @@ sudo apt-get install libsndfile1
### Install PaddlePaddle
### Install PaddlePaddle
See
[
install
](
https://www.paddlepaddle.org.cn/install/quick
)
for more details. This repo requires PaddlePaddle
**1.
7.1
**
or above.
See
[
install
](
https://www.paddlepaddle.org.cn/install/quick
)
for more details. This repo requires PaddlePaddle
**1.
8.0
**
or above.
### Install Parakeet
### Install Parakeet
...
...
examples/clarinet/train.py
浏览文件 @
e0ba85f6
...
@@ -163,11 +163,11 @@ if __name__ == "__main__":
...
@@ -163,11 +163,11 @@ if __name__ == "__main__":
anneal_interval
=
train_config
[
"anneal_interval"
]
anneal_interval
=
train_config
[
"anneal_interval"
]
lr_scheduler
=
dg
.
ExponentialDecay
(
lr_scheduler
=
dg
.
ExponentialDecay
(
learning_rate
,
anneal_interval
,
anneal_rate
,
staircase
=
True
)
learning_rate
,
anneal_interval
,
anneal_rate
,
staircase
=
True
)
optim
=
fluid
.
optimizer
.
Adam
(
lr_scheduler
,
parameter_list
=
model
.
parameters
())
gradiant_max_norm
=
train_config
[
"gradient_max_norm"
]
gradiant_max_norm
=
train_config
[
"gradient_max_norm"
]
clipper
=
fluid
.
dygraph_grad_clip
.
GradClipByGlobalNorm
(
optim
=
fluid
.
optimizer
.
Adam
(
gradiant_max_norm
)
lr_scheduler
,
parameter_list
=
model
.
parameters
(),
grad_clip
=
fluid
.
clip
.
ClipByGlobalNorm
(
gradiant_max_norm
))
# train
# train
max_iterations
=
train_config
[
"max_iterations"
]
max_iterations
=
train_config
[
"max_iterations"
]
...
@@ -229,7 +229,7 @@ if __name__ == "__main__":
...
@@ -229,7 +229,7 @@ if __name__ == "__main__":
step_loss
))
step_loss
))
l
.
backward
()
l
.
backward
()
optim
.
minimize
(
l
,
grad_clip
=
clipper
)
optim
.
minimize
(
l
)
optim
.
clear_gradients
()
optim
.
clear_gradients
()
if
global_step
%
eval_interval
==
0
:
if
global_step
%
eval_interval
==
0
:
...
...
examples/wavenet/train.py
浏览文件 @
e0ba85f6
...
@@ -126,12 +126,11 @@ if __name__ == "__main__":
...
@@ -126,12 +126,11 @@ if __name__ == "__main__":
anneal_interval
=
train_config
[
"anneal_interval"
]
anneal_interval
=
train_config
[
"anneal_interval"
]
lr_scheduler
=
dg
.
ExponentialDecay
(
lr_scheduler
=
dg
.
ExponentialDecay
(
learning_rate
,
anneal_interval
,
anneal_rate
,
staircase
=
True
)
learning_rate
,
anneal_interval
,
anneal_rate
,
staircase
=
True
)
optim
=
fluid
.
optimizer
.
Adam
(
lr_scheduler
,
parameter_list
=
model
.
parameters
())
gradiant_max_norm
=
train_config
[
"gradient_max_norm"
]
gradiant_max_norm
=
train_config
[
"gradient_max_norm"
]
clipper
=
fluid
.
dygraph_grad_clip
.
GradClipByGlobalNorm
(
optim
=
fluid
.
optimizer
.
Adam
(
gradiant_max_norm
)
lr_scheduler
,
parameter_list
=
model
.
parameters
(),
grad_clip
=
fluid
.
clip
.
ClipByGlobalNorm
(
gradiant_max_norm
))
train_loader
=
fluid
.
io
.
DataLoader
.
from_generator
(
train_loader
=
fluid
.
io
.
DataLoader
.
from_generator
(
capacity
=
10
,
return_list
=
True
)
capacity
=
10
,
return_list
=
True
)
...
@@ -149,7 +148,7 @@ if __name__ == "__main__":
...
@@ -149,7 +148,7 @@ if __name__ == "__main__":
log_dir
=
os
.
path
.
join
(
args
.
output
,
"log"
)
log_dir
=
os
.
path
.
join
(
args
.
output
,
"log"
)
writer
=
SummaryWriter
(
log_dir
)
writer
=
SummaryWriter
(
log_dir
)
# load parameters and optimizer, and
opdate iterations done so
far
# load parameters and optimizer, and
update iterations done so
far
if
args
.
checkpoint
is
not
None
:
if
args
.
checkpoint
is
not
None
:
iteration
=
io
.
load_parameters
(
iteration
=
io
.
load_parameters
(
model
,
optim
,
checkpoint_path
=
args
.
checkpoint
)
model
,
optim
,
checkpoint_path
=
args
.
checkpoint
)
...
@@ -181,7 +180,7 @@ if __name__ == "__main__":
...
@@ -181,7 +180,7 @@ if __name__ == "__main__":
writer
.
add_scalar
(
"learning_rate"
,
writer
.
add_scalar
(
"learning_rate"
,
optim
.
_learning_rate
.
step
().
numpy
()[
0
],
optim
.
_learning_rate
.
step
().
numpy
()[
0
],
global_step
)
global_step
)
optim
.
minimize
(
loss_var
,
grad_clip
=
clipper
)
optim
.
minimize
(
loss_var
)
optim
.
clear_gradients
()
optim
.
clear_gradients
()
print
(
"global_step: {}
\t
loss: {:<8.6f}"
.
format
(
global_step
,
print
(
"global_step: {}
\t
loss: {:<8.6f}"
.
format
(
global_step
,
loss_np
[
0
]))
loss_np
[
0
]))
...
...
parakeet/models/clarinet/utils.py
浏览文件 @
e0ba85f6
...
@@ -29,22 +29,10 @@ def conv2d(input,
...
@@ -29,22 +29,10 @@ def conv2d(input,
data_format
=
"NCHW"
):
data_format
=
"NCHW"
):
padding
=
tuple
(
pad
for
pad_dim
in
padding
for
pad
in
pad_dim
)
padding
=
tuple
(
pad
for
pad_dim
in
padding
for
pad
in
pad_dim
)
inputs
=
{
attrs
=
(
'strides'
,
stride
,
'paddings'
,
padding
,
'dilations'
,
dilation
,
'Input'
:
[
input
],
'groups'
,
groups
,
'use_cudnn'
,
use_cudnn
,
'use_mkldnn'
,
False
,
'Filter'
:
[
weight
],
'fuse_relu_before_depthwise_conv'
,
False
,
"padding_algorithm"
,
}
"EXPLICIT"
,
"data_format"
,
data_format
)
attrs
=
{
'strides'
:
stride
,
'paddings'
:
padding
,
'dilations'
:
dilation
,
'groups'
:
groups
,
'use_cudnn'
:
use_cudnn
,
'use_mkldnn'
:
False
,
'fuse_relu_before_depthwise_conv'
:
False
,
"padding_algorithm"
:
"EXPLICIT"
,
"data_format"
:
data_format
,
}
outputs
=
ops
.
conv2d
(
inputs
,
attrs
)
out
=
ops
.
conv2d
(
input
,
weight
,
*
attrs
)
out
=
outputs
[
"Output"
][
0
]
return
out
return
out
parakeet/models/wavenet/wavenet.py
浏览文件 @
e0ba85f6
...
@@ -111,7 +111,7 @@ class ResidualBlock(dg.Layer):
...
@@ -111,7 +111,7 @@ class ResidualBlock(dg.Layer):
h
=
h
[:,
:,
:
time_steps
]
h
=
h
[:,
:,
:
time_steps
]
# condition
# condition
if
condition
:
if
condition
is
not
None
:
h
+=
self
.
condition_proj
(
condition
)
h
+=
self
.
condition_proj
(
condition
)
# gated tanh
# gated tanh
...
@@ -398,7 +398,8 @@ class WaveNet(dg.Layer):
...
@@ -398,7 +398,8 @@ class WaveNet(dg.Layer):
x_std
=
inv_std
*
(
t
-
mu
)
x_std
=
inv_std
*
(
t
-
mu
)
exponent
=
F
.
exp
(
-
0.5
*
x_std
*
x_std
)
exponent
=
F
.
exp
(
-
0.5
*
x_std
*
x_std
)
pdf_x
=
1.0
/
np
.
sqrt
(
2.0
*
np
.
pi
)
*
inv_std
*
exponent
pdf_x
=
1.0
/
math
.
sqrt
(
2.0
*
math
.
pi
)
*
inv_std
*
exponent
pdf_x
=
p_mixture
*
pdf_x
pdf_x
=
p_mixture
*
pdf_x
# pdf_x: [bs, len]
# pdf_x: [bs, len]
pdf_x
=
F
.
reduce_sum
(
pdf_x
,
dim
=-
1
)
pdf_x
=
F
.
reduce_sum
(
pdf_x
,
dim
=-
1
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录