Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle
提交
c5a1e49c
P
Paddle
项目概览
PaddlePaddle
/
Paddle
大约 2 年 前同步成功
通知
2325
Star
20933
Fork
5424
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1423
列表
看板
标记
里程碑
合并请求
543
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1,423
Issue
1,423
列表
看板
标记
里程碑
合并请求
543
合并请求
543
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
c5a1e49c
编写于
7月 25, 2022
作者:
Z
Zhang Jun
提交者:
GitHub
7月 25, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add swish using TensorRT layer (#44561)
* update * empty commit * update * update * update
上级
3e170163
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
43 addition
and
24 deletion
+43
-24
paddle/fluid/inference/tensorrt/convert/op_converter.h
paddle/fluid/inference/tensorrt/convert/op_converter.h
+26
-12
paddle/fluid/inference/tensorrt/convert/split_op.cc
paddle/fluid/inference/tensorrt/convert/split_op.cc
+1
-1
paddle/fluid/inference/tensorrt/convert/swish_op.cc
paddle/fluid/inference/tensorrt/convert/swish_op.cc
+16
-11
未找到文件。
paddle/fluid/inference/tensorrt/convert/op_converter.h
浏览文件 @
c5a1e49c
...
@@ -482,10 +482,18 @@ class OpConverter {
...
@@ -482,10 +482,18 @@ class OpConverter {
template
<
typename
T
>
template
<
typename
T
>
// Create and add Multi-D constant float/int32 layer
// Create and add Multi-D constant float/int32 layer
nvinfer1
::
ITensor
*
AddConstantLayer
(
const
T
*
data
,
nvinfer1
::
ITensor
*
AddConstantLayer
(
const
T
*
data
,
const
std
::
vector
<
int32_t
>&
weight_dims
,
nvinfer1
::
Dims
shape
,
const
std
::
string
&
weight_name
)
{
const
std
::
string
&
weight_name
=
""
)
{
if
(
!
(
std
::
is_same
<
T
,
float
>::
value
||
std
::
is_same
<
T
,
platform
::
float16
>::
value
||
std
::
is_same
<
T
,
int32_t
>::
value
))
{
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
"Unsupported data type (%s) for TensorRT AddConstantLayer, only "
"supports float, half or int32_t."
));
}
int
data_size
=
std
::
accumulate
(
int
data_size
=
std
::
accumulate
(
weight_dims
.
begin
(),
weight_dims
.
end
()
,
1
,
std
::
multiplies
<
int
>
());
shape
.
d
,
shape
.
d
+
shape
.
nbDims
,
1
,
std
::
multiplies
<
int
>
());
std
::
unique_ptr
<
framework
::
Tensor
>
tmp_tensor
(
new
framework
::
Tensor
());
std
::
unique_ptr
<
framework
::
Tensor
>
tmp_tensor
(
new
framework
::
Tensor
());
tmp_tensor
->
Resize
({
data_size
});
tmp_tensor
->
Resize
({
data_size
});
auto
*
tmp_data
=
tmp_tensor
->
mutable_data
<
T
>
(
platform
::
CPUPlace
());
auto
*
tmp_data
=
tmp_tensor
->
mutable_data
<
T
>
(
platform
::
CPUPlace
());
...
@@ -502,12 +510,9 @@ class OpConverter {
...
@@ -502,12 +510,9 @@ class OpConverter {
TensorRTEngine
::
Weight
weight
{
trt_dtype
,
TensorRTEngine
::
Weight
weight
{
trt_dtype
,
static_cast
<
void
*>
(
tmp_data
),
static_cast
<
void
*>
(
tmp_data
),
static_cast
<
size_t
>
(
data_size
)};
static_cast
<
size_t
>
(
data_size
)};
nvinfer1
::
Dims
trt_dims
;
trt_dims
.
nbDims
=
weight_dims
.
size
();
for
(
size_t
i
=
0
;
i
<
weight_dims
.
size
();
i
++
)
trt_dims
.
d
[
i
]
=
weight_dims
[
i
];
auto
const_layer
=
auto
const_layer
=
TRT_ENGINE_ADD_LAYER
(
engine_
,
Constant
,
trt_dims
,
weight
.
get
());
TRT_ENGINE_ADD_LAYER
(
engine_
,
Constant
,
shape
,
weight
.
get
());
return
const_layer
->
getOutput
(
0
);
return
const_layer
->
getOutput
(
0
);
}
}
...
@@ -516,6 +521,14 @@ class OpConverter {
...
@@ -516,6 +521,14 @@ class OpConverter {
nvinfer1
::
ITensor
*
Add1DConstantLayer
(
const
std
::
vector
<
T
>&
data
,
nvinfer1
::
ITensor
*
Add1DConstantLayer
(
const
std
::
vector
<
T
>&
data
,
const
std
::
string
&
weight_name
=
""
,
const
std
::
string
&
weight_name
=
""
,
bool
scalar
=
false
)
{
bool
scalar
=
false
)
{
if
(
!
(
std
::
is_same
<
T
,
float
>::
value
||
std
::
is_same
<
T
,
platform
::
float16
>::
value
||
std
::
is_same
<
T
,
int32_t
>::
value
))
{
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
"Unsupported data type (%s) for TensorRT AddConstantLayer, only "
"supports float, half or int32_t."
));
}
std
::
unique_ptr
<
framework
::
Tensor
>
tmp_tensor
(
new
framework
::
Tensor
());
std
::
unique_ptr
<
framework
::
Tensor
>
tmp_tensor
(
new
framework
::
Tensor
());
int
data_size
=
data
.
size
();
int
data_size
=
data
.
size
();
tmp_tensor
->
Resize
({
data_size
});
tmp_tensor
->
Resize
({
data_size
});
...
@@ -549,12 +562,13 @@ class OpConverter {
...
@@ -549,12 +562,13 @@ class OpConverter {
return
Add1DConstantLayer
(
tmp_data
,
weight_name
,
scalar
);
return
Add1DConstantLayer
(
tmp_data
,
weight_name
,
scalar
);
}
}
nvinfer1
::
ITensor
*
Add1DConstantLayer
(
int32_t
data
,
template
<
typename
T
>
nvinfer1
::
ITensor
*
Add1DConstantLayer
(
T
data
,
const
std
::
string
&
weight_name
=
""
,
const
std
::
string
&
weight_name
=
""
,
bool
scalar
=
false
)
{
bool
scalar
=
false
)
{
std
::
vector
<
int
>
tmp
_data
;
std
::
vector
<
T
>
input
_data
;
tmp
_data
.
push_back
(
data
);
input
_data
.
push_back
(
data
);
return
Add1DConstantLayer
(
tmp
_data
,
weight_name
,
scalar
);
return
Add1DConstantLayer
(
input
_data
,
weight_name
,
scalar
);
}
}
// For cases when input is not middle-tensor , but persistable tensor
// For cases when input is not middle-tensor , but persistable tensor
...
...
paddle/fluid/inference/tensorrt/convert/split_op.cc
浏览文件 @
c5a1e49c
...
@@ -91,7 +91,7 @@ class SplitOpConverter : public OpConverter {
...
@@ -91,7 +91,7 @@ class SplitOpConverter : public OpConverter {
start_point
+=
output_lengths
[
i
];
start_point
+=
output_lengths
[
i
];
}
else
{
}
else
{
this_len_tensor
=
avg_len_tensor
;
this_len_tensor
=
avg_len_tensor
;
auto
*
i_tensor
=
Add1DConstantLayer
(
i
);
auto
*
i_tensor
=
Add1DConstantLayer
(
static_cast
<
int
>
(
i
)
);
start_point_tensor
=
Prod
(
i_tensor
,
avg_len_tensor
);
start_point_tensor
=
Prod
(
i_tensor
,
avg_len_tensor
);
}
}
...
...
paddle/fluid/inference/tensorrt/convert/swish_op.cc
浏览文件 @
c5a1e49c
...
@@ -63,17 +63,22 @@ class SwishOpConverter : public OpConverter {
...
@@ -63,17 +63,22 @@ class SwishOpConverter : public OpConverter {
nvinfer1
::
ILayer
*
layer
=
nullptr
;
nvinfer1
::
ILayer
*
layer
=
nullptr
;
if
(
engine_
->
with_dynamic_shape
())
{
if
(
engine_
->
with_dynamic_shape
())
{
#if IS_TRT_VERSION_GE(6000)
int32_t
rank
=
input
->
getDimensions
().
nbDims
;
bool
with_fp16
=
nvinfer1
::
Dims
constant_shape
;
engine_
->
WithFp16
()
&&
!
engine_
->
disable_trt_plugin_fp16
();
constant_shape
.
nbDims
=
rank
;
plugin
::
SwishPluginDynamic
*
plugin
=
std
::
fill
(
constant_shape
.
d
,
constant_shape
.
d
+
rank
,
1
);
new
plugin
::
SwishPluginDynamic
(
beta
,
with_fp16
);
std
::
vector
<
float
>
weight_data
{
beta
};
layer
=
engine_
->
AddDynamicPlugin
(
&
input
,
input_num
,
plugin
);
auto
*
beta_data
=
AddConstantLayer
(
weight_data
.
data
(),
constant_shape
);
#else
auto
*
input_mul_with_beta
=
Prod
(
beta_data
,
input
);
PADDLE_THROW
(
platform
::
errors
::
Fatal
(
auto
*
sigmoid
=
TRT_ENGINE_ADD_LAYER
(
engine_
,
"You are running the TRT Dynamic Shape mode, need to confirm that "
Activation
,
"your TRT version is no less than 6.0"
));
*
input_mul_with_beta
,
#endif
nvinfer1
::
ActivationType
::
kSIGMOID
);
layer
=
TRT_ENGINE_ADD_LAYER
(
engine_
,
ElementWise
,
*
input
,
*
(
sigmoid
->
getOutput
(
0
)),
nvinfer1
::
ElementWiseOperation
::
kPROD
);
}
else
{
}
else
{
bool
with_fp16
=
bool
with_fp16
=
engine_
->
WithFp16
()
&&
!
engine_
->
disable_trt_plugin_fp16
();
engine_
->
WithFp16
()
&&
!
engine_
->
disable_trt_plugin_fp16
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录