Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
2cebcf4a
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
2cebcf4a
编写于
4月 27, 2022
作者:
C
Chen Weihang
提交者:
GitHub
4月 27, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Unify utils naming style (#42264)
* unify utils naming style * polish details
上级
4c80385a
变更
30
显示空白变更内容
内联
并排
Showing
30 changed file
with
408 addition
and
395 deletion
+408
-395
paddle/fluid/framework/infershape_utils.cc
paddle/fluid/framework/infershape_utils.cc
+4
-4
paddle/fluid/framework/infershape_utils.h
paddle/fluid/framework/infershape_utils.h
+5
-4
paddle/fluid/framework/new_executor/new_executor_defs.cc
paddle/fluid/framework/new_executor/new_executor_defs.cc
+4
-4
paddle/fluid/framework/new_executor/new_executor_defs.h
paddle/fluid/framework/new_executor/new_executor_defs.h
+2
-2
paddle/fluid/framework/op_desc.cc
paddle/fluid/framework/op_desc.cc
+4
-4
paddle/fluid/framework/operator.cc
paddle/fluid/framework/operator.cc
+6
-6
paddle/fluid/framework/operator.h
paddle/fluid/framework/operator.h
+2
-2
paddle/fluid/framework/phi_utils.cc
paddle/fluid/framework/phi_utils.cc
+9
-9
paddle/fluid/framework/phi_utils.h
paddle/fluid/framework/phi_utils.h
+3
-3
paddle/fluid/framework/shape_inference.h
paddle/fluid/framework/shape_inference.h
+2
-2
paddle/fluid/imperative/execution_context.h
paddle/fluid/imperative/execution_context.h
+2
-2
paddle/fluid/imperative/infer_shape_context.h
paddle/fluid/imperative/infer_shape_context.h
+6
-5
paddle/fluid/imperative/prepared_operator.h
paddle/fluid/imperative/prepared_operator.h
+2
-2
paddle/fluid/pybind/imperative.cc
paddle/fluid/pybind/imperative.cc
+29
-29
paddle/infrt/dialect/phi/pass/kernel_op_desc.cc
paddle/infrt/dialect/phi/pass/kernel_op_desc.cc
+2
-2
paddle/phi/core/compat/arg_map_context.h
paddle/phi/core/compat/arg_map_context.h
+12
-12
paddle/phi/core/infermeta_utils.cc
paddle/phi/core/infermeta_utils.cc
+2
-2
paddle/phi/core/infermeta_utils.h
paddle/phi/core/infermeta_utils.h
+7
-7
paddle/phi/core/kernel_context.cc
paddle/phi/core/kernel_context.cc
+4
-4
paddle/phi/core/kernel_context.h
paddle/phi/core/kernel_context.h
+9
-9
paddle/phi/core/kernel_factory.h
paddle/phi/core/kernel_factory.h
+11
-10
paddle/phi/ops/compat/adam_sig.cc
paddle/phi/ops/compat/adam_sig.cc
+16
-16
paddle/phi/ops/compat/adamw_sig.cc
paddle/phi/ops/compat/adamw_sig.cc
+16
-16
paddle/phi/ops/compat/clip_sig.cc
paddle/phi/ops/compat/clip_sig.cc
+1
-1
paddle/phi/ops/compat/strided_slice_sig.cc
paddle/phi/ops/compat/strided_slice_sig.cc
+16
-16
paddle/phi/tests/core/test_meta_fn_utils.cc
paddle/phi/tests/core/test_meta_fn_utils.cc
+1
-1
paddle/utils/array_ref.h
paddle/utils/array_ref.h
+84
-82
paddle/utils/array_ref_test.cc
paddle/utils/array_ref_test.cc
+17
-17
paddle/utils/small_vector.h
paddle/utils/small_vector.h
+128
-120
paddle/utils/small_vector_test.cc
paddle/utils/small_vector_test.cc
+2
-2
未找到文件。
paddle/fluid/framework/infershape_utils.cc
浏览文件 @
2cebcf4a
...
...
@@ -323,7 +323,7 @@ void CompatInferMetaContext::EmplaceBackOutput(CompatMetaTensor output) {
}
void
CompatInferMetaContext
::
EmplaceBackInputs
(
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
)
{
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
)
{
int
index
=
compat_inputs_
.
size
();
input_range_
.
emplace_back
(
std
::
pair
<
int
,
int
>
(
index
,
index
+
inputs
.
size
()));
compat_inputs_
.
insert
(
compat_inputs_
.
end
(),
...
...
@@ -332,7 +332,7 @@ void CompatInferMetaContext::EmplaceBackInputs(
}
void
CompatInferMetaContext
::
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
)
{
int
index
=
compat_outputs_
.
size
();
output_range_
.
emplace_back
(
...
...
@@ -431,7 +431,7 @@ CompatInferMetaContext BuildInferMetaContext(InferShapeContext* ctx,
infer_meta_context
.
EmplaceBackInput
(
std
::
move
(
CompatMetaTensor
(
input_var
[
0
],
ctx
->
IsRuntime
())));
}
else
{
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
;
for
(
const
auto
&
in
:
input_var
)
{
inputs
.
emplace_back
(
...
...
@@ -672,7 +672,7 @@ CompatInferMetaContext BuildInferMetaContext(InferShapeContext* ctx,
infer_meta_context
.
EmplaceBackOutput
(
std
::
move
(
CompatMetaTensor
(
output_var
[
0
],
ctx
->
IsRuntime
())));
}
else
{
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
;
for
(
const
auto
&
out
:
output_var
)
{
if
(
ctx
->
IsRuntime
())
{
...
...
paddle/fluid/framework/infershape_utils.h
浏览文件 @
2cebcf4a
...
...
@@ -100,9 +100,10 @@ class CompatInferMetaContext : public phi::InferMetaContext {
void
EmplaceBackOutput
(
CompatMetaTensor
output
);
void
EmplaceBackInputs
(
paddle
::
SmallVector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
);
paddle
::
small_vector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
);
void
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
);
const
phi
::
MetaTensor
&
InputAt
(
size_t
idx
)
const
override
;
...
...
@@ -121,9 +122,9 @@ class CompatInferMetaContext : public phi::InferMetaContext {
virtual
~
CompatInferMetaContext
()
=
default
;
private:
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kInputSmallVectorSize
>
compat_inputs_
;
paddle
::
SmallV
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
CompatMetaTensor
,
phi
::
kOutputSmallVectorSize
>
compat_outputs_
;
};
...
...
paddle/fluid/framework/new_executor/new_executor_defs.cc
浏览文件 @
2cebcf4a
...
...
@@ -328,21 +328,21 @@ bool InterpretercoreInferShapeContext::IsRunMKLDNNKernel() const {
}
// TODO(paddle-dev): Can this be template?
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
InterpretercoreInferShapeContext
::
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
{
const
std
::
vector
<
Variable
*>&
vars
=
InputVars
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
res
.
reserve
(
vars
.
size
());
res
.
insert
(
res
.
begin
(),
vars
.
begin
(),
vars
.
end
());
return
res
;
}
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
InterpretercoreInferShapeContext
::
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
{
const
std
::
vector
<
Variable
*>&
vars
=
OutputVars
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
res
.
reserve
(
vars
.
size
());
res
.
insert
(
res
.
begin
(),
vars
.
begin
(),
vars
.
end
());
return
res
;
...
...
paddle/fluid/framework/new_executor/new_executor_defs.h
浏览文件 @
2cebcf4a
...
...
@@ -90,10 +90,10 @@ class InterpretercoreInferShapeContext : public InferShapeContext {
bool
IsRunMKLDNNKernel
()
const
override
;
// TODO(paddle-dev): Can this be template?
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
override
;
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
override
;
DDim
GetInputDim
(
const
std
::
string
&
name
)
const
override
;
...
...
paddle/fluid/framework/op_desc.cc
浏览文件 @
2cebcf4a
...
...
@@ -202,10 +202,10 @@ class CompileTimeInferShapeContext : public InferShapeContext {
}
}
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
const
std
::
vector
<
std
::
string
>
arg_names
=
Inputs
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
res
.
reserve
(
arg_names
.
size
());
std
::
transform
(
arg_names
.
begin
(),
arg_names
.
end
(),
std
::
back_inserter
(
res
),
[
this
](
const
std
::
string
&
name
)
{
...
...
@@ -214,10 +214,10 @@ class CompileTimeInferShapeContext : public InferShapeContext {
return
res
;
}
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
const
std
::
vector
<
std
::
string
>
arg_names
=
Outputs
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
res
.
reserve
(
arg_names
.
size
());
std
::
transform
(
arg_names
.
begin
(),
arg_names
.
end
(),
std
::
back_inserter
(
res
),
[
this
](
const
std
::
string
&
name
)
{
...
...
paddle/fluid/framework/operator.cc
浏览文件 @
2cebcf4a
...
...
@@ -946,19 +946,19 @@ class RuntimeInferShapeContext : public InferShapeContext {
}
// TODO(paddle-dev): Can this be template?
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
const
std
::
vector
<
Variable
*>&
vars
=
InputVars
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
res
.
reserve
(
vars
.
size
());
res
.
insert
(
res
.
begin
(),
vars
.
begin
(),
vars
.
end
());
return
res
;
}
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
const
std
::
vector
<
Variable
*>&
vars
=
OutputVars
(
name
);
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
res
.
reserve
(
vars
.
size
());
res
.
insert
(
res
.
begin
(),
vars
.
begin
(),
vars
.
end
());
return
res
;
...
...
@@ -2344,7 +2344,7 @@ void OperatorWithKernel::BuildPhiKernelContext(
tensor_in
=
&
(
var
->
Get
<
phi
::
SelectedRows
>
());
pt_kernel_context
->
EmplaceBackInputWithoutSetRange
(
tensor_in
);
}
else
if
(
var
->
IsType
<
framework
::
LoDTensorArray
>
())
{
paddle
::
SmallV
ector
<
const
phi
::
TensorBase
*>
tensor_vector
;
paddle
::
small_v
ector
<
const
phi
::
TensorBase
*>
tensor_vector
;
auto
&
tensor_array
=
var
->
Get
<
framework
::
LoDTensorArray
>
();
for
(
auto
&
t
:
tensor_array
)
{
tensor_vector
.
emplace_back
(
&
t
);
...
...
@@ -2393,7 +2393,7 @@ void OperatorWithKernel::BuildPhiKernelContext(
tensor_out
=
var
->
template
GetMutable
<
phi
::
SelectedRows
>();
pt_kernel_context
->
EmplaceBackOutputWithoutSetRange
(
tensor_out
);
}
else
if
(
var
->
template
IsType
<
framework
::
LoDTensorArray
>())
{
paddle
::
SmallV
ector
<
phi
::
TensorBase
*>
tensor_vector
;
paddle
::
small_v
ector
<
phi
::
TensorBase
*>
tensor_vector
;
auto
*
tensor_array
=
var
->
template
GetMutable
<
framework
::
LoDTensorArray
>();
// Note: If the input LoDTensorArray size is 0, the output
...
...
paddle/fluid/framework/operator.h
浏览文件 @
2cebcf4a
...
...
@@ -333,8 +333,8 @@ class ExecutionContext {
return
it
->
second
;
}
virtual
paddle
::
SmallV
ector
<
const
std
::
string
*>
InNameList
()
const
{
paddle
::
SmallV
ector
<
const
std
::
string
*>
vec_temp
;
virtual
paddle
::
small_v
ector
<
const
std
::
string
*>
InNameList
()
const
{
paddle
::
small_v
ector
<
const
std
::
string
*>
vec_temp
;
vec_temp
.
reserve
(
ctx_
.
inputs
.
size
());
for
(
auto
&
input
:
ctx_
.
inputs
)
{
...
...
paddle/fluid/framework/phi_utils.cc
浏览文件 @
2cebcf4a
...
...
@@ -41,9 +41,9 @@ class KernelArgsNameMakerByOpProto : public KernelArgsNameMaker {
~
KernelArgsNameMakerByOpProto
()
{}
const
paddle
::
SmallV
ector
<
const
char
*>&
GetInputArgsNames
()
override
;
const
paddle
::
SmallV
ector
<
const
char
*>&
GetOutputArgsNames
()
override
;
const
paddle
::
SmallV
ector
<
const
char
*>&
GetAttrsArgsNames
()
override
;
const
paddle
::
small_v
ector
<
const
char
*>&
GetInputArgsNames
()
override
;
const
paddle
::
small_v
ector
<
const
char
*>&
GetOutputArgsNames
()
override
;
const
paddle
::
small_v
ector
<
const
char
*>&
GetAttrsArgsNames
()
override
;
phi
::
KernelSignature
GetKernelSignature
();
...
...
@@ -53,9 +53,9 @@ class KernelArgsNameMakerByOpProto : public KernelArgsNameMaker {
private:
const
framework
::
proto
::
OpProto
*
op_proto_
;
paddle
::
SmallV
ector
<
const
char
*>
input_names_
;
paddle
::
SmallV
ector
<
const
char
*>
output_names_
;
paddle
::
SmallV
ector
<
const
char
*>
attr_names_
;
paddle
::
small_v
ector
<
const
char
*>
input_names_
;
paddle
::
small_v
ector
<
const
char
*>
output_names_
;
paddle
::
small_v
ector
<
const
char
*>
attr_names_
;
};
OpKernelType
TransPhiKernelKeyToOpKernelType
(
const
phi
::
KernelKey
&
kernel_key
)
{
...
...
@@ -149,7 +149,7 @@ phi::KernelKey FallBackToCpu(const OpKernelType& expected_kernel_key,
return
phi
::
KernelKey
();
}
const
paddle
::
SmallV
ector
<
const
char
*>&
const
paddle
::
small_v
ector
<
const
char
*>&
KernelArgsNameMakerByOpProto
::
GetInputArgsNames
()
{
for
(
int
i
=
0
;
i
<
op_proto_
->
inputs_size
();
++
i
)
{
auto
&
in
=
op_proto_
->
inputs
()[
i
];
...
...
@@ -174,7 +174,7 @@ KernelArgsNameMakerByOpProto::GetInputArgsNames() {
return
input_names_
;
}
const
paddle
::
SmallV
ector
<
const
char
*>&
const
paddle
::
small_v
ector
<
const
char
*>&
KernelArgsNameMakerByOpProto
::
GetOutputArgsNames
()
{
for
(
int
i
=
0
;
i
<
op_proto_
->
outputs_size
();
++
i
)
{
auto
&
out
=
op_proto_
->
outputs
()[
i
];
...
...
@@ -194,7 +194,7 @@ KernelArgsNameMakerByOpProto::GetOutputArgsNames() {
return
output_names_
;
}
const
paddle
::
SmallV
ector
<
const
char
*>&
const
paddle
::
small_v
ector
<
const
char
*>&
KernelArgsNameMakerByOpProto
::
GetAttrsArgsNames
()
{
for
(
int
i
=
0
;
i
<
op_proto_
->
attrs_size
();
++
i
)
{
auto
&
attr
=
op_proto_
->
attrs
()[
i
];
...
...
paddle/fluid/framework/phi_utils.h
浏览文件 @
2cebcf4a
...
...
@@ -53,9 +53,9 @@ phi::KernelKey FallBackToCpu(const OpKernelType& expected_kernel_key,
class
KernelArgsNameMaker
{
public:
virtual
~
KernelArgsNameMaker
()
{}
virtual
const
paddle
::
SmallV
ector
<
const
char
*>&
GetInputArgsNames
()
=
0
;
virtual
const
paddle
::
SmallV
ector
<
const
char
*>&
GetOutputArgsNames
()
=
0
;
virtual
const
paddle
::
SmallV
ector
<
const
char
*>&
GetAttrsArgsNames
()
=
0
;
virtual
const
paddle
::
small_v
ector
<
const
char
*>&
GetInputArgsNames
()
=
0
;
virtual
const
paddle
::
small_v
ector
<
const
char
*>&
GetOutputArgsNames
()
=
0
;
virtual
const
paddle
::
small_v
ector
<
const
char
*>&
GetAttrsArgsNames
()
=
0
;
};
void
InitDefaultKernelSignatureMap
();
...
...
paddle/fluid/framework/shape_inference.h
浏览文件 @
2cebcf4a
...
...
@@ -110,9 +110,9 @@ class InferShapeContext {
virtual
bool
IsRunMKLDNNKernel
()
const
=
0
;
virtual
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
virtual
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
=
0
;
virtual
paddle
::
SmallV
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
virtual
paddle
::
small_v
ector
<
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
=
0
;
virtual
const
phi
::
ArgumentMappingFn
*
GetPhiArgumentMappingFn
()
const
=
0
;
...
...
paddle/fluid/imperative/execution_context.h
浏览文件 @
2cebcf4a
...
...
@@ -117,8 +117,8 @@ class DygraphExecutionContext : public framework::ExecutionContext {
return
it
->
second
;
}
paddle
::
SmallV
ector
<
const
std
::
string
*>
InNameList
()
const
override
{
paddle
::
SmallV
ector
<
const
std
::
string
*>
vec_temp
;
paddle
::
small_v
ector
<
const
std
::
string
*>
InNameList
()
const
override
{
paddle
::
small_v
ector
<
const
std
::
string
*>
vec_temp
;
vec_temp
.
reserve
(
var_map_in_
.
size
());
for
(
auto
&
v
:
var_map_in_
)
{
...
...
paddle/fluid/imperative/infer_shape_context.h
浏览文件 @
2cebcf4a
...
...
@@ -239,9 +239,10 @@ class DygraphInferShapeContext : public framework::InferShapeContext {
(
op_kernel_type_
->
data_layout_
==
framework
::
DataLayout
::
kMKLDNN
));
}
paddle
::
SmallV
ector
<
framework
::
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
framework
::
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
GetInputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
paddle
::
SmallVector
<
framework
::
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_vector
<
framework
::
InferShapeVarPtr
,
phi
::
kInputSmallVectorSize
>
res
;
auto
it
=
var_map_in_
->
find
(
name
);
PADDLE_ENFORCE_NE
(
...
...
@@ -253,9 +254,9 @@ class DygraphInferShapeContext : public framework::InferShapeContext {
return
res
;
}
paddle
::
SmallV
ector
<
framework
::
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
framework
::
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
GetOutputVarPtrs
(
const
std
::
string
&
name
)
const
override
{
paddle
::
SmallV
ector
<
framework
::
InferShapeVarPtr
,
paddle
::
small_v
ector
<
framework
::
InferShapeVarPtr
,
phi
::
kOutputSmallVectorSize
>
res
;
auto
it
=
var_map_out_
->
find
(
name
);
...
...
paddle/fluid/imperative/prepared_operator.h
浏览文件 @
2cebcf4a
...
...
@@ -311,7 +311,7 @@ void BuildDygraphPhiKernelContext(const phi::KernelSignature& kernel_signature,
tensor_in
=
&
(
var
.
template
Get
<
phi
::
SelectedRows
>());
kernel_ctx
->
EmplaceBackInputWithoutSetRange
(
tensor_in
);
}
else
if
(
var
.
template
IsType
<
framework
::
LoDTensorArray
>())
{
paddle
::
SmallV
ector
<
const
phi
::
TensorBase
*>
tensor_vector
;
paddle
::
small_v
ector
<
const
phi
::
TensorBase
*>
tensor_vector
;
auto
&
tensor_array
=
var
.
template
Get
<
framework
::
LoDTensorArray
>();
for
(
auto
&
t
:
tensor_array
)
{
tensor_vector
.
emplace_back
(
&
t
);
...
...
@@ -357,7 +357,7 @@ void BuildDygraphPhiKernelContext(const phi::KernelSignature& kernel_signature,
tensor_out
=
var
->
template
GetMutable
<
phi
::
SelectedRows
>();
kernel_ctx
->
EmplaceBackOutputWithoutSetRange
(
tensor_out
);
}
else
if
(
var
->
template
IsType
<
framework
::
LoDTensorArray
>())
{
paddle
::
SmallV
ector
<
phi
::
TensorBase
*>
tensor_vector
;
paddle
::
small_v
ector
<
phi
::
TensorBase
*>
tensor_vector
;
auto
*
tensor_array
=
var
->
template
GetMutable
<
framework
::
LoDTensorArray
>();
for
(
auto
&
t
:
*
tensor_array
)
{
...
...
paddle/fluid/pybind/imperative.cc
浏览文件 @
2cebcf4a
...
...
@@ -2028,8 +2028,7 @@ void BindImperative(py::module *m_ptr) {
*
(
imperative
::
AmpOperators
::
Instance
().
GetMutableAllowOps
()),
*
(
imperative
::
AmpOperators
::
Instance
().
GetMutableBlockOps
()));
})
.
def
(
"_get_kernel_signature"
,
.
def
(
"_get_kernel_signature"
,
[](
imperative
::
Tracer
&
self
,
const
std
::
string
&
type
,
const
PyNameVarBaseMap
&
ins
,
const
PyNameVarBaseMap
&
outs
,
framework
::
AttributeMap
attrs
)
{
...
...
@@ -2038,14 +2037,15 @@ void BindImperative(py::module *m_ptr) {
auto
outs_map
=
ConvertToNameTensorMap
(
outs
);
{
auto
input_to_vector
=
[](
paddle
::
SmallV
ector
<
const
char
*>
&
vec
)
{
[](
paddle
::
small_v
ector
<
const
char
*>
&
vec
)
{
return
std
::
vector
<
std
::
string
>
(
vec
.
begin
(),
vec
.
end
());
};
auto
output_to_vector
=
[](
paddle
::
SmallV
ector
<
const
char
*>
&
vec
)
{
[](
paddle
::
small_v
ector
<
const
char
*>
&
vec
)
{
return
std
::
vector
<
std
::
string
>
(
vec
.
begin
(),
vec
.
end
());
};
auto
attr_to_vector
=
[](
paddle
::
SmallVector
<
const
char
*>
&
vec
)
{
auto
attr_to_vector
=
[](
paddle
::
small_vector
<
const
char
*>
&
vec
)
{
return
std
::
vector
<
std
::
string
>
(
vec
.
begin
(),
vec
.
end
());
};
auto
ret
=
self
.
GetExpectedKernelSignature
(
type
,
ins_map
,
...
...
paddle/infrt/dialect/phi/pass/kernel_op_desc.cc
浏览文件 @
2cebcf4a
...
...
@@ -93,9 +93,9 @@ std::vector<PhiKernelDesc> GetCandidateKernels(
phi_kernel_desc
.
input_types
.
clear
();
phi_kernel_desc
.
output_types
.
clear
();
phi
::
KernelArgsDef
args_def
=
kernel_key_map
.
at
(
kernel_key
).
args_def
();
const
paddle
::
SmallV
ector
<
phi
::
TensorArgDef
,
phi
::
kInputSmallVectorSize
>&
const
paddle
::
small_v
ector
<
phi
::
TensorArgDef
,
phi
::
kInputSmallVectorSize
>&
input_arg
=
args_def
.
input_defs
();
const
paddle
::
SmallV
ector
<
phi
::
TensorArgDef
,
phi
::
kOutputSmallVectorSize
>&
const
paddle
::
small_v
ector
<
phi
::
TensorArgDef
,
phi
::
kOutputSmallVectorSize
>&
output_arg
=
args_def
.
output_defs
();
for
(
auto
tensor_arg
:
input_arg
)
{
phi_kernel_desc
.
input_types
.
emplace_back
(
ConvertPlaceFromPhi
(
tensor_arg
));
...
...
paddle/phi/core/compat/arg_map_context.h
浏览文件 @
2cebcf4a
...
...
@@ -27,30 +27,30 @@ limitations under the License. */
namespace
phi
{
// tuple(input_names, attr_names, output_names)
using
KernelArgsTuple
=
std
::
tuple
<
paddle
::
SmallV
ector
<
const
char
*>
,
paddle
::
SmallV
ector
<
const
char
*>
,
paddle
::
SmallV
ector
<
const
char
*>>
;
using
KernelArgsTuple
=
std
::
tuple
<
paddle
::
small_v
ector
<
const
char
*>
,
paddle
::
small_v
ector
<
const
char
*>
,
paddle
::
small_v
ector
<
const
char
*>>
;
struct
KernelSignature
{
const
char
*
name
;
paddle
::
SmallV
ector
<
const
char
*>
input_names
;
paddle
::
SmallV
ector
<
const
char
*>
attr_names
;
paddle
::
SmallV
ector
<
const
char
*>
output_names
;
paddle
::
small_v
ector
<
const
char
*>
input_names
;
paddle
::
small_v
ector
<
const
char
*>
attr_names
;
paddle
::
small_v
ector
<
const
char
*>
output_names
;
KernelSignature
()
=
default
;
KernelSignature
(
const
char
*
kernel_name
,
paddle
::
SmallV
ector
<
const
char
*>&&
inputs
,
paddle
::
SmallV
ector
<
const
char
*>&&
attrs
,
paddle
::
SmallV
ector
<
const
char
*>&&
outputs
)
paddle
::
small_v
ector
<
const
char
*>&&
inputs
,
paddle
::
small_v
ector
<
const
char
*>&&
attrs
,
paddle
::
small_v
ector
<
const
char
*>&&
outputs
)
:
name
(
kernel_name
),
input_names
(
std
::
move
(
inputs
)),
attr_names
(
std
::
move
(
attrs
)),
output_names
(
std
::
move
(
outputs
))
{}
KernelSignature
(
const
char
*
kernel_name
,
const
paddle
::
SmallV
ector
<
const
char
*>&
inputs
,
const
paddle
::
SmallV
ector
<
const
char
*>&
attrs
,
const
paddle
::
SmallV
ector
<
const
char
*>&
outputs
)
const
paddle
::
small_v
ector
<
const
char
*>&
inputs
,
const
paddle
::
small_v
ector
<
const
char
*>&
attrs
,
const
paddle
::
small_v
ector
<
const
char
*>&
outputs
)
:
name
(
kernel_name
),
input_names
(
inputs
),
attr_names
(
attrs
),
...
...
paddle/phi/core/infermeta_utils.cc
浏览文件 @
2cebcf4a
...
...
@@ -35,7 +35,7 @@ void InferMetaContext::EmplaceBackAttr(Attribute attr) {
}
void
InferMetaContext
::
EmplaceBackInputs
(
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
)
{
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
)
{
int
index
=
inputs_
.
size
();
input_range_
.
emplace_back
(
std
::
pair
<
int
,
int
>
(
index
,
index
+
inputs
.
size
()));
inputs_
.
insert
(
inputs_
.
end
(),
...
...
@@ -43,7 +43,7 @@ void InferMetaContext::EmplaceBackInputs(
std
::
make_move_iterator
(
inputs
.
end
()));
}
void
InferMetaContext
::
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
)
{
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
)
{
int
index
=
outputs_
.
size
();
output_range_
.
emplace_back
(
std
::
pair
<
int
,
int
>
(
index
,
index
+
outputs
.
size
()));
...
...
paddle/phi/core/infermeta_utils.h
浏览文件 @
2cebcf4a
...
...
@@ -45,9 +45,9 @@ class InferMetaContext {
void
EmplaceBackAttr
(
Attribute
attr
);
void
EmplaceBackInputs
(
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
);
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs
);
void
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
);
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs
);
virtual
const
MetaTensor
&
InputAt
(
size_t
idx
)
const
;
virtual
paddle
::
optional
<
const
MetaTensor
&>
OptionalInputAt
(
size_t
idx
)
const
;
...
...
@@ -72,16 +72,16 @@ class InferMetaContext {
protected:
MetaConfig
config_
;
paddle
::
SmallV
ector
<
Attribute
,
kAttrSmallVectorSize
>
attrs_
;
paddle
::
small_v
ector
<
Attribute
,
kAttrSmallVectorSize
>
attrs_
;
paddle
::
SmallV
ector
<
std
::
pair
<
int
,
int
>
,
phi
::
kInputSmallVectorSize
>
paddle
::
small_v
ector
<
std
::
pair
<
int
,
int
>
,
phi
::
kInputSmallVectorSize
>
input_range_
;
paddle
::
SmallV
ector
<
std
::
pair
<
int
,
int
>
,
phi
::
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
std
::
pair
<
int
,
int
>
,
phi
::
kOutputSmallVectorSize
>
output_range_
;
private:
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs_
;
paddle
::
SmallV
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs_
;
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kInputSmallVectorSize
>
inputs_
;
paddle
::
small_v
ector
<
MetaTensor
,
phi
::
kOutputSmallVectorSize
>
outputs_
;
};
#define PD_INFER_META(...) \
...
...
paddle/phi/core/kernel_context.cc
浏览文件 @
2cebcf4a
...
...
@@ -28,7 +28,7 @@ void KernelContext::EmplaceBackInputWithoutSetRange(const TensorBase* input) {
}
void
KernelContext
::
EmplaceBackInputs
(
paddle
::
SmallV
ector
<
const
TensorBase
*>
inputs
)
{
paddle
::
small_v
ector
<
const
TensorBase
*>
inputs
)
{
int
index
=
inputs_
.
size
();
// Record the start and end index of the input
input_range_
.
emplace_back
(
std
::
pair
<
int
,
int
>
(
index
,
index
+
inputs
.
size
()));
...
...
@@ -38,7 +38,7 @@ void KernelContext::EmplaceBackInputs(
}
void
KernelContext
::
EmplaceBackInputsWithoutSetRange
(
paddle
::
SmallV
ector
<
const
TensorBase
*>
inputs
)
{
paddle
::
small_v
ector
<
const
TensorBase
*>
inputs
)
{
inputs_
.
insert
(
inputs_
.
end
(),
std
::
make_move_iterator
(
inputs
.
begin
()),
std
::
make_move_iterator
(
inputs
.
end
()));
...
...
@@ -56,7 +56,7 @@ void KernelContext::EmplaceBackOutputWithoutSetRange(TensorBase* output) {
}
void
KernelContext
::
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
TensorBase
*>
outputs
)
{
paddle
::
small_v
ector
<
TensorBase
*>
outputs
)
{
int
index
=
outputs_
.
size
();
// Record the start and end index of the input
output_range_
.
emplace_back
(
...
...
@@ -67,7 +67,7 @@ void KernelContext::EmplaceBackOutputs(
}
void
KernelContext
::
EmplaceBackOutputsWithoutSetRange
(
paddle
::
SmallV
ector
<
TensorBase
*>
outputs
)
{
paddle
::
small_v
ector
<
TensorBase
*>
outputs
)
{
outputs_
.
insert
(
outputs_
.
end
(),
std
::
make_move_iterator
(
outputs
.
begin
()),
std
::
make_move_iterator
(
outputs
.
end
()));
...
...
paddle/phi/core/kernel_context.h
浏览文件 @
2cebcf4a
...
...
@@ -51,19 +51,19 @@ class KernelContext {
void
EmplaceBackInputWithoutSetRange
(
const
TensorBase
*
input
);
void
EmplaceBackInputs
(
paddle
::
SmallV
ector
<
const
TensorBase
*>
inputs
);
void
EmplaceBackInputs
(
paddle
::
small_v
ector
<
const
TensorBase
*>
inputs
);
void
EmplaceBackInputsWithoutSetRange
(
paddle
::
SmallV
ector
<
const
TensorBase
*>
inputs
);
paddle
::
small_v
ector
<
const
TensorBase
*>
inputs
);
void
EmplaceBackOutput
(
TensorBase
*
output
);
void
EmplaceBackOutputWithoutSetRange
(
TensorBase
*
output
);
void
EmplaceBackOutputs
(
paddle
::
SmallV
ector
<
TensorBase
*>
outputs
);
void
EmplaceBackOutputs
(
paddle
::
small_v
ector
<
TensorBase
*>
outputs
);
void
EmplaceBackOutputsWithoutSetRange
(
paddle
::
SmallV
ector
<
TensorBase
*>
outputs
);
paddle
::
small_v
ector
<
TensorBase
*>
outputs
);
void
EmplaceBackAttr
(
Attribute
attr
);
...
...
@@ -138,12 +138,12 @@ class KernelContext {
private:
DeviceContext
*
dev_ctx_
;
paddle
::
SmallV
ector
<
const
TensorBase
*>
inputs_
;
paddle
::
SmallV
ector
<
TensorBase
*>
outputs_
;
paddle
::
SmallV
ector
<
Attribute
,
kAttrSmallVectorSize
>
attrs_
;
paddle
::
small_v
ector
<
const
TensorBase
*>
inputs_
;
paddle
::
small_v
ector
<
TensorBase
*>
outputs_
;
paddle
::
small_v
ector
<
Attribute
,
kAttrSmallVectorSize
>
attrs_
;
paddle
::
SmallV
ector
<
std
::
pair
<
int
,
int
>
,
kInputSmallVectorSize
>
input_range_
;
paddle
::
SmallV
ector
<
std
::
pair
<
int
,
int
>
,
kOutputSmallVectorSize
>
paddle
::
small_v
ector
<
std
::
pair
<
int
,
int
>
,
kInputSmallVectorSize
>
input_range_
;
paddle
::
small_v
ector
<
std
::
pair
<
int
,
int
>
,
kOutputSmallVectorSize
>
output_range_
;
};
...
...
paddle/phi/core/kernel_factory.h
浏览文件 @
2cebcf4a
...
...
@@ -173,37 +173,38 @@ class KernelArgsDef {
attribute_defs_
.
emplace_back
(
AttributeArgDef
(
type_index
));
}
const
paddle
::
SmallV
ector
<
TensorArgDef
,
kInputSmallVectorSize
>&
input_defs
()
const
paddle
::
small_v
ector
<
TensorArgDef
,
kInputSmallVectorSize
>&
input_defs
()
const
{
return
input_defs_
;
}
const
paddle
::
SmallVector
<
TensorArgDef
,
kOutputSmallVectorSize
>&
output_defs
()
const
{
const
paddle
::
small_vector
<
TensorArgDef
,
kOutputSmallVectorSize
>&
output_defs
()
const
{
return
output_defs_
;
}
const
paddle
::
SmallV
ector
<
AttributeArgDef
,
kAttrSmallVectorSize
>&
const
paddle
::
small_v
ector
<
AttributeArgDef
,
kAttrSmallVectorSize
>&
attribute_defs
()
const
{
return
attribute_defs_
;
}
paddle
::
SmallV
ector
<
TensorArgDef
,
kInputSmallVectorSize
>&
input_defs
()
{
paddle
::
small_v
ector
<
TensorArgDef
,
kInputSmallVectorSize
>&
input_defs
()
{
return
input_defs_
;
}
paddle
::
SmallV
ector
<
TensorArgDef
,
kOutputSmallVectorSize
>&
output_defs
()
{
paddle
::
small_v
ector
<
TensorArgDef
,
kOutputSmallVectorSize
>&
output_defs
()
{
return
output_defs_
;
}
paddle
::
SmallVector
<
AttributeArgDef
,
kAttrSmallVectorSize
>&
attribute_defs
()
{
paddle
::
small_vector
<
AttributeArgDef
,
kAttrSmallVectorSize
>&
attribute_defs
()
{
return
attribute_defs_
;
}
private:
paddle
::
SmallV
ector
<
TensorArgDef
,
kInputSmallVectorSize
>
input_defs_
{{}};
paddle
::
SmallV
ector
<
TensorArgDef
,
kOutputSmallVectorSize
>
output_defs_
{{}};
paddle
::
SmallV
ector
<
AttributeArgDef
,
kAttrSmallVectorSize
>
attribute_defs_
{
paddle
::
small_v
ector
<
TensorArgDef
,
kInputSmallVectorSize
>
input_defs_
{{}};
paddle
::
small_v
ector
<
TensorArgDef
,
kOutputSmallVectorSize
>
output_defs_
{{}};
paddle
::
small_v
ector
<
AttributeArgDef
,
kAttrSmallVectorSize
>
attribute_defs_
{
{}};
};
...
...
paddle/phi/ops/compat/adam_sig.cc
浏览文件 @
2cebcf4a
...
...
@@ -19,7 +19,7 @@
namespace
phi
{
KernelSignature
AdamOpArgumentMapping
(
const
ArgumentMappingContext
&
ctx
)
{
paddle
::
SmallV
ector
<
const
char
*>
in_names
=
{
"Param"
,
paddle
::
small_v
ector
<
const
char
*>
in_names
=
{
"Param"
,
"Grad"
,
"LearningRate"
,
"Moment1"
,
...
...
@@ -28,13 +28,13 @@ KernelSignature AdamOpArgumentMapping(const ArgumentMappingContext& ctx) {
"Beta2Pow"
,
"MasterParam"
,
"SkipUpdate"
};
paddle
::
SmallV
ector
<
const
char
*>
out_names
=
{
"ParamOut"
,
paddle
::
small_v
ector
<
const
char
*>
out_names
=
{
"ParamOut"
,
"Moment1Out"
,
"Moment2Out"
,
"Beta1PowOut"
,
"Beta2PowOut"
,
"MasterParamOut"
};
paddle
::
SmallV
ector
<
const
char
*>
attr_names
;
paddle
::
small_v
ector
<
const
char
*>
attr_names
;
attr_names
.
emplace_back
(
ctx
.
HasInput
(
"Beta1Tensor"
)
?
"Beta1Tensor"
:
"beta1"
);
...
...
paddle/phi/ops/compat/adamw_sig.cc
浏览文件 @
2cebcf4a
...
...
@@ -19,7 +19,7 @@
namespace
phi
{
KernelSignature
AdamwOpArgumentMapping
(
const
ArgumentMappingContext
&
ctx
)
{
paddle
::
SmallV
ector
<
const
char
*>
in_names
=
{
"Param"
,
paddle
::
small_v
ector
<
const
char
*>
in_names
=
{
"Param"
,
"Grad"
,
"LearningRate"
,
"Moment1"
,
...
...
@@ -28,13 +28,13 @@ KernelSignature AdamwOpArgumentMapping(const ArgumentMappingContext& ctx) {
"Beta2Pow"
,
"MasterParam"
,
"SkipUpdate"
};
paddle
::
SmallV
ector
<
const
char
*>
out_names
=
{
"ParamOut"
,
paddle
::
small_v
ector
<
const
char
*>
out_names
=
{
"ParamOut"
,
"Moment1Out"
,
"Moment2Out"
,
"Beta1PowOut"
,
"Beta2PowOut"
,
"MasterParamOut"
};
paddle
::
SmallV
ector
<
const
char
*>
attr_names
;
paddle
::
small_v
ector
<
const
char
*>
attr_names
;
attr_names
.
emplace_back
(
ctx
.
HasInput
(
"Beta1Tensor"
)
?
"Beta1Tensor"
:
"beta1"
);
...
...
paddle/phi/ops/compat/clip_sig.cc
浏览文件 @
2cebcf4a
...
...
@@ -18,7 +18,7 @@
namespace
phi
{
KernelSignature
ClipOpArgumentMapping
(
const
ArgumentMappingContext
&
ctx
)
{
paddle
::
SmallV
ector
<
std
::
string
,
kAttrSmallVectorSize
>
attr_names
;
paddle
::
small_v
ector
<
std
::
string
,
kAttrSmallVectorSize
>
attr_names
;
attr_names
.
emplace_back
(
ctx
.
HasInput
(
"Min"
)
?
"Min"
:
"min"
);
attr_names
.
emplace_back
(
ctx
.
HasInput
(
"Max"
)
?
"Max"
:
"max"
);
if
(
ctx
.
IsDenseTensorInput
(
"X"
))
{
...
...
paddle/phi/ops/compat/strided_slice_sig.cc
浏览文件 @
2cebcf4a
...
...
@@ -48,14 +48,14 @@ KernelSignature StridedSliceOpArgumentMapping(
?
(
use_attr_strides
?
"strides"
:
"StridesTensorList"
)
:
"strides"
);
paddle
::
SmallV
ector
<
const
char
*>
inputs
=
{
"Input"
};
paddle
::
SmallV
ector
<
const
char
*>
attrs
=
{
"axes"
,
paddle
::
small_v
ector
<
const
char
*>
inputs
=
{
"Input"
};
paddle
::
small_v
ector
<
const
char
*>
attrs
=
{
"axes"
,
starts_key
,
ends_key
,
strides_key
,
"infer_flags"
,
"decrease_axis"
};
paddle
::
SmallV
ector
<
const
char
*>
outputs
=
{
"Out"
};
paddle
::
small_v
ector
<
const
char
*>
outputs
=
{
"Out"
};
const
char
*
kernel_name
;
if
(
ctx
.
IsDenseTensorVectorInput
(
"Input"
))
{
...
...
@@ -97,14 +97,14 @@ KernelSignature StridedSliceGradOpArgumentMapping(
?
(
use_attr_strides
?
"strides"
:
"StridesTensorList"
)
:
"strides"
);
paddle
::
SmallV
ector
<
const
char
*>
inputs
=
{
"Input"
,
"Out@GRAD"
};
paddle
::
SmallV
ector
<
const
char
*>
attrs
=
{
"axes"
,
paddle
::
small_v
ector
<
const
char
*>
inputs
=
{
"Input"
,
"Out@GRAD"
};
paddle
::
small_v
ector
<
const
char
*>
attrs
=
{
"axes"
,
starts_key
,
ends_key
,
strides_key
,
"infer_flags"
,
"decrease_axis"
};
paddle
::
SmallV
ector
<
const
char
*>
outputs
=
{
"Input@GRAD"
};
paddle
::
small_v
ector
<
const
char
*>
outputs
=
{
"Input@GRAD"
};
const
char
*
kernel_name
;
if
(
ctx
.
IsDenseTensorVectorInput
(
"Input"
))
{
...
...
paddle/phi/tests/core/test_meta_fn_utils.cc
浏览文件 @
2cebcf4a
...
...
@@ -68,7 +68,7 @@ TEST(MetaFnFactory, SplitInferMetaFn) {
phi
::
DenseTensor
dense_out1
;
phi
::
DenseTensor
dense_out2
;
paddle
::
SmallV
ector
<
phi
::
MetaTensor
,
kOutputSmallVectorSize
>
out
;
paddle
::
small_v
ector
<
phi
::
MetaTensor
,
kOutputSmallVectorSize
>
out
;
out
.
emplace_back
(
phi
::
MetaTensor
(
&
dense_out1
));
out
.
emplace_back
(
phi
::
MetaTensor
(
&
dense_out2
));
...
...
paddle/utils/array_ref.h
浏览文件 @
2cebcf4a
...
...
@@ -3,8 +3,10 @@
// 1. remove hash_value functions
// 2. replace with the llvm::NoneType with paddle::none_t
// 3. remove drop_while, drop_until, take_while, take_until methods
// 4. change ArrayRef to array_ref to unify naming style of utils
//===- ArrayRef.h - Array Reference Wrapper ---------------------*- C++ -*-===//
//===- ArrayRef.h - Array Reference Wrapper ---------------------*- C++
//-*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
...
...
@@ -29,19 +31,19 @@
namespace
paddle
{
///
ArrayR
ef - Represent a constant reference to an array (0 or more elements
///
array_r
ef - Represent a constant reference to an array (0 or more elements
/// consecutively in memory), i.e. a start pointer and a length. It allows
/// various APIs to take consecutive elements easily and conveniently.
///
/// This class does not own the underlying data, it is expected to be used in
/// situations where the data resides in some other buffer, whose lifetime
/// extends past that of the
ArrayR
ef. For this reason, it is not in general
/// safe to store an
ArrayR
ef.
/// extends past that of the
array_r
ef. For this reason, it is not in general
/// safe to store an
array_r
ef.
///
/// This is intended to be trivially copyable, so it should be passed by
/// value.
template
<
typename
T
>
class
ArrayR
ef
{
class
array_r
ef
{
public:
using
iterator
=
const
T
*
;
using
const_iterator
=
const
T
*
;
...
...
@@ -59,81 +61,81 @@ class ArrayRef {
/// @name Constructors
/// @{
/// Construct an empty
ArrayR
ef.
/*implicit*/
ArrayR
ef
()
=
default
;
/// Construct an empty
array_r
ef.
/*implicit*/
array_r
ef
()
=
default
;
/// Construct an empty
ArrayR
ef from None.
/*implicit*/
ArrayR
ef
(
none_t
)
{}
/// Construct an empty
array_r
ef from None.
/*implicit*/
array_r
ef
(
none_t
)
{}
/// Construct an
ArrayR
ef from a single element.
/*implicit*/
ArrayR
ef
(
const
T
&
OneElt
)
:
Data
(
&
OneElt
),
Length
(
1
)
{}
/// Construct an
array_r
ef from a single element.
/*implicit*/
array_r
ef
(
const
T
&
OneElt
)
:
Data
(
&
OneElt
),
Length
(
1
)
{}
/// Construct an
ArrayR
ef from a pointer and length.
/*implicit*/
ArrayR
ef
(
const
T
*
data
,
size_t
length
)
/// Construct an
array_r
ef from a pointer and length.
/*implicit*/
array_r
ef
(
const
T
*
data
,
size_t
length
)
:
Data
(
data
),
Length
(
length
)
{}
/// Construct an
ArrayR
ef from a range.
ArrayR
ef
(
const
T
*
begin
,
const
T
*
end
)
:
Data
(
begin
),
Length
(
end
-
begin
)
{}
/// Construct an
array_r
ef from a range.
array_r
ef
(
const
T
*
begin
,
const
T
*
end
)
:
Data
(
begin
),
Length
(
end
-
begin
)
{}
/// Construct an
ArrayRef from a SmallV
ector. This is templated in order to
/// avoid instantiating
SmallVectorTemplateC
ommon<T> whenever we
/// copy-construct an
ArrayR
ef.
/// Construct an
array_ref from a small_v
ector. This is templated in order to
/// avoid instantiating
small_vector_template_c
ommon<T> whenever we
/// copy-construct an
array_r
ef.
template
<
typename
U
>
/*implicit*/
ArrayRef
(
const
SmallVectorTemplateC
ommon
<
T
,
U
>
&
Vec
)
/*implicit*/
array_ref
(
const
small_vector_template_c
ommon
<
T
,
U
>
&
Vec
)
:
Data
(
Vec
.
data
()),
Length
(
Vec
.
size
())
{}
/// Construct an
ArrayR
ef from a std::vector.
/// Construct an
array_r
ef from a std::vector.
template
<
typename
A
>
/*implicit*/
ArrayR
ef
(
const
std
::
vector
<
T
,
A
>
&
Vec
)
/*implicit*/
array_r
ef
(
const
std
::
vector
<
T
,
A
>
&
Vec
)
:
Data
(
Vec
.
data
()),
Length
(
Vec
.
size
())
{}
/// Construct an
ArrayR
ef from a std::array
/// Construct an
array_r
ef from a std::array
template
<
size_t
N
>
/*implicit*/
constexpr
ArrayR
ef
(
const
std
::
array
<
T
,
N
>
&
Arr
)
/*implicit*/
constexpr
array_r
ef
(
const
std
::
array
<
T
,
N
>
&
Arr
)
:
Data
(
Arr
.
data
()),
Length
(
N
)
{}
/// Construct an
ArrayR
ef from a C array.
/// Construct an
array_r
ef from a C array.
template
<
size_t
N
>
/*implicit*/
constexpr
ArrayR
ef
(
const
T
(
&
Arr
)[
N
])
:
Data
(
Arr
),
Length
(
N
)
{}
/*implicit*/
constexpr
array_r
ef
(
const
T
(
&
Arr
)[
N
])
:
Data
(
Arr
),
Length
(
N
)
{}
/// Construct an
ArrayR
ef from a std::initializer_list.
/// Construct an
array_r
ef from a std::initializer_list.
#if defined(__GNUC__) && !defined(__clang__) && __GNUC__ >= 9
// Disable gcc's warning in this constructor as it generates an enormous
// amount
// of messages. Anyone using
ArrayR
ef should already be aware of the fact that
// of messages. Anyone using
array_r
ef should already be aware of the fact that
// it does not do lifetime extension.
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Winit-list-lifetime"
#endif
/*implicit*/
ArrayR
ef
(
const
std
::
initializer_list
<
T
>
&
Vec
)
/*implicit*/
array_r
ef
(
const
std
::
initializer_list
<
T
>
&
Vec
)
:
Data
(
Vec
.
begin
()
==
Vec
.
end
()
?
(
T
*
)
nullptr
:
Vec
.
begin
()),
Length
(
Vec
.
size
())
{}
#if defined(__GNUC__) && !defined(__clang__) && __GNUC__ >= 9
#pragma GCC diagnostic pop
#endif
/// Construct an
ArrayRef<const T*> from ArrayR
ef<T*>. This uses SFINAE to
/// Construct an
array_ref<const T*> from array_r
ef<T*>. This uses SFINAE to
/// ensure that only ArrayRefs of pointers can be converted.
template
<
typename
U
>
ArrayRef
(
const
ArrayR
ef
<
U
*>
&
A
,
array_ref
(
const
array_r
ef
<
U
*>
&
A
,
std
::
enable_if_t
<
std
::
is_convertible
<
U
*
const
*
,
T
const
*>::
value
>
*
=
nullptr
)
:
Data
(
A
.
data
()),
Length
(
A
.
size
())
{}
/// Construct an
ArrayRef<const T*> from a SmallV
ector<T*>. This is
/// templated in order to avoid instantiating
SmallVectorTemplateC
ommon<T>
/// whenever we copy-construct an
ArrayR
ef.
/// Construct an
array_ref<const T*> from a small_v
ector<T*>. This is
/// templated in order to avoid instantiating
small_vector_template_c
ommon<T>
/// whenever we copy-construct an
array_r
ef.
template
<
typename
U
,
typename
DummyT
>
/*implicit*/
ArrayR
ef
(
const
SmallVectorTemplateC
ommon
<
U
*
,
DummyT
>
&
Vec
,
/*implicit*/
array_r
ef
(
const
small_vector_template_c
ommon
<
U
*
,
DummyT
>
&
Vec
,
std
::
enable_if_t
<
std
::
is_convertible
<
U
*
const
*
,
T
const
*>::
value
>
*
=
nullptr
)
:
Data
(
Vec
.
data
()),
Length
(
Vec
.
size
())
{}
/// Construct an
ArrayR
ef<const T*> from std::vector<T*>. This uses SFINAE
/// Construct an
array_r
ef<const T*> from std::vector<T*>. This uses SFINAE
/// to ensure that only vectors of pointers can be converted.
template
<
typename
U
,
typename
A
>
ArrayR
ef
(
array_r
ef
(
const
std
::
vector
<
U
*
,
A
>
&
Vec
,
std
::
enable_if_t
<
std
::
is_convertible
<
U
*
const
*
,
T
const
*>::
value
>
*
=
0
)
:
Data
(
Vec
.
data
()),
Length
(
Vec
.
size
())
{}
...
...
@@ -168,50 +170,50 @@ class ArrayRef {
return
Data
[
Length
-
1
];
}
// copy - Allocate copy in Allocator and return
ArrayR
ef<T> to it.
// copy - Allocate copy in Allocator and return
array_r
ef<T> to it.
template
<
typename
Allocator
>
ArrayR
ef
<
T
>
copy
(
Allocator
&
A
)
{
array_r
ef
<
T
>
copy
(
Allocator
&
A
)
{
T
*
Buff
=
A
.
template
Allocate
<
T
>(
Length
);
std
::
uninitialized_copy
(
begin
(),
end
(),
Buff
);
return
ArrayR
ef
<
T
>
(
Buff
,
Length
);
return
array_r
ef
<
T
>
(
Buff
,
Length
);
}
/// equals - Check for element-wise equality.
bool
equals
(
ArrayR
ef
RHS
)
const
{
bool
equals
(
array_r
ef
RHS
)
const
{
if
(
Length
!=
RHS
.
Length
)
return
false
;
return
std
::
equal
(
begin
(),
end
(),
RHS
.
begin
());
}
/// slice(n, m) - Chop off the first N elements of the array, and keep M
/// elements in the array.
ArrayR
ef
<
T
>
slice
(
size_t
N
,
size_t
M
)
const
{
array_r
ef
<
T
>
slice
(
size_t
N
,
size_t
M
)
const
{
assert
(
N
+
M
<=
size
()
&&
"Invalid specifier"
);
return
ArrayR
ef
<
T
>
(
data
()
+
N
,
M
);
return
array_r
ef
<
T
>
(
data
()
+
N
,
M
);
}
/// slice(n) - Chop off the first N elements of the array.
ArrayR
ef
<
T
>
slice
(
size_t
N
)
const
{
return
slice
(
N
,
size
()
-
N
);
}
array_r
ef
<
T
>
slice
(
size_t
N
)
const
{
return
slice
(
N
,
size
()
-
N
);
}
/// Drop the first \p N elements of the array.
ArrayR
ef
<
T
>
drop_front
(
size_t
N
=
1
)
const
{
array_r
ef
<
T
>
drop_front
(
size_t
N
=
1
)
const
{
assert
(
size
()
>=
N
&&
"Dropping more elements than exist"
);
return
slice
(
N
,
size
()
-
N
);
}
/// Drop the last \p N elements of the array.
ArrayR
ef
<
T
>
drop_back
(
size_t
N
=
1
)
const
{
array_r
ef
<
T
>
drop_back
(
size_t
N
=
1
)
const
{
assert
(
size
()
>=
N
&&
"Dropping more elements than exist"
);
return
slice
(
0
,
size
()
-
N
);
}
/// Return a copy of *this with only the first \p N elements.
ArrayR
ef
<
T
>
take_front
(
size_t
N
=
1
)
const
{
array_r
ef
<
T
>
take_front
(
size_t
N
=
1
)
const
{
if
(
N
>=
size
())
return
*
this
;
return
drop_back
(
size
()
-
N
);
}
/// Return a copy of *this with only the last \p N elements.
ArrayR
ef
<
T
>
take_back
(
size_t
N
=
1
)
const
{
array_r
ef
<
T
>
take_back
(
size_t
N
=
1
)
const
{
if
(
N
>=
size
())
return
*
this
;
return
drop_front
(
size
()
-
N
);
}
...
...
@@ -229,7 +231,7 @@ class ArrayRef {
/// The declaration here is extra complicated so that "arrayRef = {}"
/// continues to select the move assignment operator.
template
<
typename
U
>
std
::
enable_if_t
<
std
::
is_same
<
U
,
T
>::
value
,
ArrayR
ef
<
T
>>
&
operator
=
(
std
::
enable_if_t
<
std
::
is_same
<
U
,
T
>::
value
,
array_r
ef
<
T
>>
&
operator
=
(
U
&&
Temporary
)
=
delete
;
/// Disallow accidental assignment from a temporary.
...
...
@@ -237,7 +239,7 @@ class ArrayRef {
/// The declaration here is extra complicated so that "arrayRef = {}"
/// continues to select the move assignment operator.
template
<
typename
U
>
std
::
enable_if_t
<
std
::
is_same
<
U
,
T
>::
value
,
ArrayR
ef
<
T
>>
&
operator
=
(
std
::
enable_if_t
<
std
::
is_same
<
U
,
T
>::
value
,
array_r
ef
<
T
>>
&
operator
=
(
std
::
initializer_list
<
U
>
)
=
delete
;
/// @}
...
...
@@ -255,90 +257,90 @@ class ArrayRef {
/// @}
};
/// @name
ArrayR
ef Convenience constructors
/// @name
array_r
ef Convenience constructors
/// @{
/// Construct an
ArrayR
ef from a single element.
/// Construct an
array_r
ef from a single element.
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
T
&
OneElt
)
{
array_ref
<
T
>
make_array_r
ef
(
const
T
&
OneElt
)
{
return
OneElt
;
}
/// Construct an
ArrayR
ef from a pointer and length.
/// Construct an
array_r
ef from a pointer and length.
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
T
*
data
,
size_t
length
)
{
return
ArrayR
ef
<
T
>
(
data
,
length
);
array_ref
<
T
>
make_array_r
ef
(
const
T
*
data
,
size_t
length
)
{
return
array_r
ef
<
T
>
(
data
,
length
);
}
/// Construct an
ArrayR
ef from a range.
/// Construct an
array_r
ef from a range.
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
T
*
begin
,
const
T
*
end
)
{
return
ArrayR
ef
<
T
>
(
begin
,
end
);
array_ref
<
T
>
make_array_r
ef
(
const
T
*
begin
,
const
T
*
end
)
{
return
array_r
ef
<
T
>
(
begin
,
end
);
}
/// Construct an
ArrayRef from a SmallV
ector.
/// Construct an
array_ref from a small_v
ector.
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayRef
(
const
SmallVectorI
mpl
<
T
>
&
Vec
)
{
array_ref
<
T
>
make_array_ref
(
const
small_vector_i
mpl
<
T
>
&
Vec
)
{
return
Vec
;
}
/// Construct an
ArrayRef from a SmallV
ector.
/// Construct an
array_ref from a small_v
ector.
template
<
typename
T
,
unsigned
N
>
ArrayRef
<
T
>
makeArrayRef
(
const
SmallV
ector
<
T
,
N
>
&
Vec
)
{
array_ref
<
T
>
make_array_ref
(
const
small_v
ector
<
T
,
N
>
&
Vec
)
{
return
Vec
;
}
/// Construct an
ArrayR
ef from a std::vector.
/// Construct an
array_r
ef from a std::vector.
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
std
::
vector
<
T
>
&
Vec
)
{
array_ref
<
T
>
make_array_r
ef
(
const
std
::
vector
<
T
>
&
Vec
)
{
return
Vec
;
}
/// Construct an
ArrayR
ef from a std::array.
/// Construct an
array_r
ef from a std::array.
template
<
typename
T
,
std
::
size_t
N
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
std
::
array
<
T
,
N
>
&
Arr
)
{
array_ref
<
T
>
make_array_r
ef
(
const
std
::
array
<
T
,
N
>
&
Arr
)
{
return
Arr
;
}
/// Construct an
ArrayRef from an ArrayR
ef (no-op) (const)
/// Construct an
array_ref from an array_r
ef (no-op) (const)
template
<
typename
T
>
ArrayRef
<
T
>
makeArrayRef
(
const
ArrayR
ef
<
T
>
&
Vec
)
{
array_ref
<
T
>
make_array_ref
(
const
array_r
ef
<
T
>
&
Vec
)
{
return
Vec
;
}
/// Construct an
ArrayRef from an ArrayR
ef (no-op)
/// Construct an
array_ref from an array_r
ef (no-op)
template
<
typename
T
>
ArrayRef
<
T
>
&
makeArrayRef
(
ArrayR
ef
<
T
>
&
Vec
)
{
array_ref
<
T
>
&
make_array_ref
(
array_r
ef
<
T
>
&
Vec
)
{
return
Vec
;
}
/// Construct an
ArrayR
ef from a C array.
/// Construct an
array_r
ef from a C array.
template
<
typename
T
,
size_t
N
>
ArrayRef
<
T
>
makeArrayR
ef
(
const
T
(
&
Arr
)[
N
])
{
return
ArrayR
ef
<
T
>
(
Arr
);
array_ref
<
T
>
make_array_r
ef
(
const
T
(
&
Arr
)[
N
])
{
return
array_r
ef
<
T
>
(
Arr
);
}
/// @}
/// @name
ArrayR
ef Comparison Operators
/// @name
array_r
ef Comparison Operators
/// @{
template
<
typename
T
>
inline
bool
operator
==
(
ArrayRef
<
T
>
LHS
,
ArrayR
ef
<
T
>
RHS
)
{
inline
bool
operator
==
(
array_ref
<
T
>
LHS
,
array_r
ef
<
T
>
RHS
)
{
return
LHS
.
equals
(
RHS
);
}
template
<
typename
T
>
inline
bool
operator
==
(
SmallVectorImpl
<
T
>
&
LHS
,
ArrayR
ef
<
T
>
RHS
)
{
return
ArrayR
ef
<
T
>
(
LHS
).
equals
(
RHS
);
inline
bool
operator
==
(
small_vector_impl
<
T
>
&
LHS
,
array_r
ef
<
T
>
RHS
)
{
return
array_r
ef
<
T
>
(
LHS
).
equals
(
RHS
);
}
template
<
typename
T
>
inline
bool
operator
!=
(
ArrayRef
<
T
>
LHS
,
ArrayR
ef
<
T
>
RHS
)
{
inline
bool
operator
!=
(
array_ref
<
T
>
LHS
,
array_r
ef
<
T
>
RHS
)
{
return
!
(
LHS
==
RHS
);
}
template
<
typename
T
>
inline
bool
operator
!=
(
SmallVectorImpl
<
T
>
&
LHS
,
ArrayR
ef
<
T
>
RHS
)
{
inline
bool
operator
!=
(
small_vector_impl
<
T
>
&
LHS
,
array_r
ef
<
T
>
RHS
)
{
return
!
(
LHS
==
RHS
);
}
...
...
paddle/utils/array_ref_test.cc
浏览文件 @
2cebcf4a
...
...
@@ -21,53 +21,53 @@
#include "gtest/gtest.h"
TEST
(
array_ref
,
array_ref
)
{
paddle
::
ArrayR
ef
<
int
>
a
;
paddle
::
array_r
ef
<
int
>
a
;
CHECK_EQ
(
a
.
size
(),
size_t
(
0
));
CHECK_EQ
(
a
.
data
(),
static_cast
<
int
*>
(
nullptr
));
paddle
::
ArrayR
ef
<
int
>
b
(
paddle
::
none
);
paddle
::
array_r
ef
<
int
>
b
(
paddle
::
none
);
CHECK_EQ
(
b
.
size
(),
size_t
(
0
));
CHECK_EQ
(
b
.
data
(),
static_cast
<
int
*>
(
nullptr
));
int
v
=
1
;
paddle
::
ArrayR
ef
<
int
>
c
(
v
);
paddle
::
array_r
ef
<
int
>
c
(
v
);
CHECK_EQ
(
c
.
size
(),
size_t
(
1
));
CHECK_EQ
(
c
.
data
(),
&
v
);
CHECK_EQ
(
c
.
equals
(
paddle
::
make
ArrayR
ef
(
v
)),
true
);
CHECK_EQ
(
c
.
equals
(
paddle
::
make
_array_r
ef
(
v
)),
true
);
int
v1
[
5
]
=
{
1
,
2
,
3
,
4
,
5
};
paddle
::
ArrayR
ef
<
int
>
d
(
v1
,
5
);
paddle
::
array_r
ef
<
int
>
d
(
v1
,
5
);
CHECK_EQ
(
d
.
size
(),
size_t
(
5
));
CHECK_EQ
(
d
.
data
(),
v1
);
CHECK_EQ
(
d
.
equals
(
paddle
::
make
ArrayR
ef
(
v1
,
5
)),
true
);
CHECK_EQ
(
d
.
equals
(
paddle
::
make
_array_r
ef
(
v1
,
5
)),
true
);
paddle
::
ArrayR
ef
<
int
>
e
(
&
v1
[
0
],
&
v1
[
4
]);
paddle
::
array_r
ef
<
int
>
e
(
&
v1
[
0
],
&
v1
[
4
]);
CHECK_EQ
(
e
.
size
(),
size_t
(
4
));
CHECK_EQ
(
e
.
data
(),
v1
);
CHECK_EQ
(
e
.
equals
(
paddle
::
make
ArrayR
ef
(
&
v1
[
0
],
&
v1
[
4
])),
true
);
CHECK_EQ
(
e
.
equals
(
paddle
::
make
_array_r
ef
(
&
v1
[
0
],
&
v1
[
4
])),
true
);
paddle
::
SmallV
ector
<
int
,
3
>
small_vector
{
1
,
2
,
3
};
paddle
::
ArrayR
ef
<
int
>
f
(
small_vector
);
paddle
::
small_v
ector
<
int
,
3
>
small_vector
{
1
,
2
,
3
};
paddle
::
array_r
ef
<
int
>
f
(
small_vector
);
CHECK_EQ
(
f
.
size
(),
size_t
(
3
));
CHECK_EQ
(
f
.
data
(),
small_vector
.
data
());
CHECK_EQ
(
f
.
equals
(
paddle
::
make
ArrayR
ef
(
small_vector
)),
true
);
CHECK_EQ
(
f
.
equals
(
paddle
::
make
_array_r
ef
(
small_vector
)),
true
);
std
::
vector
<
int
>
vector
{
1
,
2
,
3
};
paddle
::
ArrayR
ef
<
int
>
g
(
vector
);
paddle
::
array_r
ef
<
int
>
g
(
vector
);
CHECK_EQ
(
g
.
size
(),
size_t
(
3
));
CHECK_EQ
(
g
.
data
(),
vector
.
data
());
CHECK_EQ
(
g
.
equals
(
paddle
::
make
ArrayR
ef
(
vector
)),
true
);
CHECK_EQ
(
g
.
equals
(
paddle
::
make
_array_r
ef
(
vector
)),
true
);
std
::
initializer_list
<
int
>
list
=
{
1
,
2
,
3
};
paddle
::
ArrayR
ef
<
int
>
h
(
list
);
paddle
::
array_r
ef
<
int
>
h
(
list
);
CHECK_EQ
(
h
.
size
(),
size_t
(
3
));
CHECK_EQ
(
h
.
data
(),
list
.
begin
());
paddle
::
ArrayR
ef
<
int
>
i
(
h
);
paddle
::
array_r
ef
<
int
>
i
(
h
);
CHECK_EQ
(
i
.
size
(),
size_t
(
3
));
CHECK_EQ
(
i
.
data
(),
list
.
begin
());
CHECK_EQ
(
i
.
equals
(
h
),
true
);
CHECK_EQ
(
i
.
equals
(
paddle
::
make
ArrayR
ef
(
h
)),
true
);
CHECK_EQ
(
i
.
equals
(
paddle
::
make
_array_r
ef
(
h
)),
true
);
auto
slice
=
i
.
slice
(
1
,
2
);
CHECK_EQ
(
slice
.
size
(),
size_t
(
2
));
...
...
@@ -78,7 +78,7 @@ TEST(array_ref, array_ref) {
CHECK_EQ
(
drop
.
size
(),
size_t
(
1
));
CHECK_EQ
(
drop
[
0
],
3
);
paddle
::
ArrayR
ef
<
int
>
nums
=
{
1
,
2
,
3
,
4
,
5
,
6
,
7
,
8
};
paddle
::
array_r
ef
<
int
>
nums
=
{
1
,
2
,
3
,
4
,
5
,
6
,
7
,
8
};
auto
front
=
nums
.
take_front
(
3
);
CHECK_EQ
(
front
.
size
(),
size_t
(
3
));
for
(
size_t
i
=
0
;
i
<
3
;
++
i
)
{
...
...
paddle/utils/small_vector.h
浏览文件 @
2cebcf4a
...
...
@@ -5,6 +5,7 @@
// 3. add at(index) method for small vector
// 4. wrap the call to max and min with parenthesis to prevent the macro
// expansion to fix the build error on windows platform
// 5. change SmallVector to small_vector to unify naming style of utils
//===- llvm/ADT/SmallVector.h - 'Normally small' vectors --------*- C++ -*-===//
//
...
...
@@ -79,13 +80,13 @@ iterator_range<T> make_range(std::pair<T, T> p) {
/// This is all the stuff common to all SmallVectors.
///
/// The template parameter specifies the type which should be used to hold the
/// Size and Capacity of the
SmallV
ector, so it can be adjusted.
/// Using 32 bit size is desirable to shrink the size of the
SmallV
ector.
/// Using 64 bit size is desirable for cases like
SmallV
ector<char>, where a
/// Size and Capacity of the
small_v
ector, so it can be adjusted.
/// Using 32 bit size is desirable to shrink the size of the
small_v
ector.
/// Using 64 bit size is desirable for cases like
small_v
ector<char>, where a
/// 32 bit size would limit the vector to ~4GB. SmallVectors are used for
/// buffering bitcode output - which can exceed 4GB.
template
<
class
Size_T
>
class
SmallVectorB
ase
{
class
small_vector_b
ase
{
protected:
void
*
BeginX
;
Size_T
Size
=
0
,
Capacity
;
...
...
@@ -95,8 +96,8 @@ class SmallVectorBase {
return
(
std
::
numeric_limits
<
Size_T
>::
max
)();
}
SmallVectorB
ase
()
=
delete
;
SmallVectorB
ase
(
void
*
FirstEl
,
size_t
TotalCapacity
)
small_vector_b
ase
()
=
delete
;
small_vector_b
ase
(
void
*
FirstEl
,
size_t
TotalCapacity
)
:
BeginX
(
FirstEl
),
Capacity
(
TotalCapacity
)
{}
/// This is a helper for \a grow() that's out of line to reduce code
...
...
@@ -139,22 +140,23 @@ using SmallVectorSizeType =
/// Figure out the offset of the first element.
template
<
class
T
,
typename
=
void
>
struct
SmallVectorAlignmentAndSize
{
alignas
(
SmallVectorB
ase
<
SmallVectorSizeType
<
T
>>
)
char
Base
[
sizeof
(
SmallVectorB
ase
<
SmallVectorSizeType
<
T
>>
)];
alignas
(
small_vector_b
ase
<
SmallVectorSizeType
<
T
>>
)
char
Base
[
sizeof
(
small_vector_b
ase
<
SmallVectorSizeType
<
T
>>
)];
alignas
(
T
)
char
FirstEl
[
sizeof
(
T
)];
};
/// This is the part of SmallVectorTemplateBase which does not depend on whether
/// the type T is a POD. The extra dummy template argument is used by ArrayRef
/// This is the part of small_vector_template_base which does not depend on
/// whether
/// the type T is a POD. The extra dummy template argument is used by array_ref
/// to avoid unnecessarily requiring T to be complete.
template
<
typename
T
,
typename
=
void
>
class
SmallVectorTemplateC
ommon
:
public
SmallVectorB
ase
<
SmallVectorSizeType
<
T
>>
{
using
Base
=
SmallVectorB
ase
<
SmallVectorSizeType
<
T
>>
;
class
small_vector_template_c
ommon
:
public
small_vector_b
ase
<
SmallVectorSizeType
<
T
>>
{
using
Base
=
small_vector_b
ase
<
SmallVectorSizeType
<
T
>>
;
/// Find the address of the first element. For this pointer math to be valid
/// with small-size of 0 for T with lots of alignment, it's important that
///
SmallVectorS
torage is properly-aligned even for small-size of 0.
///
small_vector_s
torage is properly-aligned even for small-size of 0.
void
*
getFirstEl
()
const
{
return
const_cast
<
void
*>
(
reinterpret_cast
<
const
void
*>
(
reinterpret_cast
<
const
char
*>
(
this
)
+
...
...
@@ -163,7 +165,7 @@ class SmallVectorTemplateCommon
// Space after 'FirstEl' is clobbered, do not add any instance vars after it.
protected:
SmallVectorTemplateC
ommon
(
size_t
Size
)
:
Base
(
getFirstEl
(),
Size
)
{}
small_vector_template_c
ommon
(
size_t
Size
)
:
Base
(
getFirstEl
(),
Size
)
{}
void
grow_pod
(
size_t
MinSize
,
size_t
TSize
)
{
Base
::
grow_pod
(
getFirstEl
(),
MinSize
,
TSize
);
...
...
@@ -358,7 +360,7 @@ class SmallVectorTemplateCommon
}
};
///
SmallVectorTemplateB
ase<TriviallyCopyable = false> - This is where we put
///
small_vector_template_b
ase<TriviallyCopyable = false> - This is where we put
/// method implementations that are designed to work with non-trivial T's.
///
/// We approximate is_trivially_copyable with trivial move/copy construction and
...
...
@@ -370,14 +372,15 @@ template <typename T,
bool
=
(
std
::
is_trivially_copy_constructible
<
T
>
::
value
)
&&
(
std
::
is_trivially_move_constructible
<
T
>::
value
)
&&
std
::
is_trivially_destructible
<
T
>::
value
>
class
SmallVectorTemplateBase
:
public
SmallVectorTemplateC
ommon
<
T
>
{
friend
class
SmallVectorTemplateC
ommon
<
T
>
;
class
small_vector_template_base
:
public
small_vector_template_c
ommon
<
T
>
{
friend
class
small_vector_template_c
ommon
<
T
>
;
protected:
static
constexpr
bool
TakesParamByValue
=
false
;
using
ValueParamT
=
const
T
&
;
SmallVectorTemplateBase
(
size_t
Size
)
:
SmallVectorTemplateCommon
<
T
>
(
Size
)
{}
small_vector_template_base
(
size_t
Size
)
:
small_vector_template_common
<
T
>
(
Size
)
{}
static
void
destroy_range
(
T
*
S
,
T
*
E
)
{
while
(
S
!=
E
)
{
...
...
@@ -410,7 +413,7 @@ class SmallVectorTemplateBase : public SmallVectorTemplateCommon<T> {
/// in \p NewCapacity. This is the first section of \a grow().
T
*
mallocForGrow
(
size_t
MinSize
,
size_t
&
NewCapacity
)
{
return
static_cast
<
T
*>
(
SmallVectorB
ase
<
SmallVectorSizeType
<
T
>>::
mallocForGrow
(
small_vector_b
ase
<
SmallVectorSizeType
<
T
>>::
mallocForGrow
(
MinSize
,
sizeof
(
T
),
NewCapacity
));
}
...
...
@@ -480,7 +483,7 @@ class SmallVectorTemplateBase : public SmallVectorTemplateCommon<T> {
// Define this out-of-line to dissuade the C++ compiler from inlining it.
template
<
typename
T
,
bool
TriviallyCopyable
>
void
SmallVectorTemplateB
ase
<
T
,
TriviallyCopyable
>::
grow
(
size_t
MinSize
)
{
void
small_vector_template_b
ase
<
T
,
TriviallyCopyable
>::
grow
(
size_t
MinSize
)
{
size_t
NewCapacity
;
T
*
NewElts
=
mallocForGrow
(
MinSize
,
NewCapacity
);
moveElementsForGrow
(
NewElts
);
...
...
@@ -489,7 +492,7 @@ void SmallVectorTemplateBase<T, TriviallyCopyable>::grow(size_t MinSize) {
// Define this out-of-line to dissuade the C++ compiler from inlining it.
template
<
typename
T
,
bool
TriviallyCopyable
>
void
SmallVectorTemplateB
ase
<
T
,
TriviallyCopyable
>::
moveElementsForGrow
(
void
small_vector_template_b
ase
<
T
,
TriviallyCopyable
>::
moveElementsForGrow
(
T
*
NewElts
)
{
// Move the elements over.
this
->
uninitialized_move
(
this
->
begin
(),
this
->
end
(),
NewElts
);
...
...
@@ -500,7 +503,7 @@ void SmallVectorTemplateBase<T, TriviallyCopyable>::moveElementsForGrow(
// Define this out-of-line to dissuade the C++ compiler from inlining it.
template
<
typename
T
,
bool
TriviallyCopyable
>
void
SmallVectorTemplateB
ase
<
T
,
TriviallyCopyable
>::
takeAllocationForGrow
(
void
small_vector_template_b
ase
<
T
,
TriviallyCopyable
>::
takeAllocationForGrow
(
T
*
NewElts
,
size_t
NewCapacity
)
{
// If this wasn't grown from the inline copy, deallocate the old space.
if
(
!
this
->
isSmall
())
free
(
this
->
begin
());
...
...
@@ -509,13 +512,14 @@ void SmallVectorTemplateBase<T, TriviallyCopyable>::takeAllocationForGrow(
this
->
Capacity
=
NewCapacity
;
}
///
SmallVectorTemplateB
ase<TriviallyCopyable = true> - This is where we put
///
small_vector_template_b
ase<TriviallyCopyable = true> - This is where we put
/// method implementations that are designed to work with trivially copyable
/// T's. This allows using memcpy in place of copy/move construction and
/// skipping destruction.
template
<
typename
T
>
class
SmallVectorTemplateBase
<
T
,
true
>
:
public
SmallVectorTemplateCommon
<
T
>
{
friend
class
SmallVectorTemplateCommon
<
T
>
;
class
small_vector_template_base
<
T
,
true
>
:
public
small_vector_template_common
<
T
>
{
friend
class
small_vector_template_common
<
T
>
;
protected:
/// True if it's cheap enough to take parameters by value. Doing so avoids
...
...
@@ -527,7 +531,8 @@ class SmallVectorTemplateBase<T, true> : public SmallVectorTemplateCommon<T> {
using
ValueParamT
=
typename
std
::
conditional
<
TakesParamByValue
,
T
,
const
T
&>::
type
;
SmallVectorTemplateBase
(
size_t
Size
)
:
SmallVectorTemplateCommon
<
T
>
(
Size
)
{}
small_vector_template_base
(
size_t
Size
)
:
small_vector_template_common
<
T
>
(
Size
)
{}
// No need to do a destroy loop for POD's.
static
void
destroy_range
(
T
*
,
T
*
)
{}
...
...
@@ -557,7 +562,7 @@ class SmallVectorTemplateBase<T, true> : public SmallVectorTemplateCommon<T> {
T2
*
Dest
,
std
::
enable_if_t
<
std
::
is_same
<
typename
std
::
remove_const
<
T1
>::
type
,
T2
>::
value
>
*
=
nullptr
)
{
// Use memcpy for PODs iterated by pointers (which includes
SmallV
ector
// Use memcpy for PODs iterated by pointers (which includes
small_v
ector
// iterators): std::uninitialized_copy optimizes to memmove, but we can
// use memcpy here. Note that I and E are iterators and thus might be
// invalid for memcpy if they are equal.
...
...
@@ -612,11 +617,11 @@ class SmallVectorTemplateBase<T, true> : public SmallVectorTemplateCommon<T> {
void
pop_back
()
{
this
->
set_size
(
this
->
size
()
-
1
);
}
};
/// This class consists of common code factored out of the
SmallV
ector class to
/// reduce code duplication based on the
SmallV
ector 'N' template parameter.
/// This class consists of common code factored out of the
small_v
ector class to
/// reduce code duplication based on the
small_v
ector 'N' template parameter.
template
<
typename
T
>
class
SmallVectorImpl
:
public
SmallVectorTemplateB
ase
<
T
>
{
using
SuperClass
=
SmallVectorTemplateB
ase
<
T
>
;
class
small_vector_impl
:
public
small_vector_template_b
ase
<
T
>
{
using
SuperClass
=
small_vector_template_b
ase
<
T
>
;
public:
using
iterator
=
typename
SuperClass
::
iterator
;
...
...
@@ -625,16 +630,16 @@ class SmallVectorImpl : public SmallVectorTemplateBase<T> {
using
size_type
=
typename
SuperClass
::
size_type
;
protected:
using
SmallVectorTemplateB
ase
<
T
>::
TakesParamByValue
;
using
small_vector_template_b
ase
<
T
>::
TakesParamByValue
;
using
ValueParamT
=
typename
SuperClass
::
ValueParamT
;
// Default ctor - Initialize to empty.
explicit
SmallVectorImpl
(
unsigned
N
)
:
SmallVectorTemplateB
ase
<
T
>
(
N
)
{}
explicit
small_vector_impl
(
unsigned
N
)
:
small_vector_template_b
ase
<
T
>
(
N
)
{}
public:
SmallVectorImpl
(
const
SmallVectorI
mpl
&
)
=
delete
;
small_vector_impl
(
const
small_vector_i
mpl
&
)
=
delete
;
~
SmallVectorI
mpl
()
{
~
small_vector_i
mpl
()
{
// Subclass has already destructed this vector's elements.
// If this wasn't grown from the inline copy, deallocate the old space.
if
(
!
this
->
isSmall
())
free
(
this
->
begin
());
...
...
@@ -695,9 +700,9 @@ class SmallVectorImpl : public SmallVectorTemplateBase<T> {
return
Result
;
}
void
swap
(
SmallVectorI
mpl
&
RHS
);
void
swap
(
small_vector_i
mpl
&
RHS
);
/// Add the specified range to the end of the
SmallV
ector.
/// Add the specified range to the end of the
small_v
ector.
template
<
typename
in_iter
,
typename
=
std
::
enable_if_t
<
std
::
is_convertible
<
typename
std
::
iterator_traits
<
in_iter
>
::
iterator_category
,
...
...
@@ -719,7 +724,7 @@ class SmallVectorImpl : public SmallVectorTemplateBase<T> {
void
append
(
std
::
initializer_list
<
T
>
IL
)
{
append
(
IL
.
begin
(),
IL
.
end
());
}
void
append
(
const
SmallVectorI
mpl
&
RHS
)
{
append
(
RHS
.
begin
(),
RHS
.
end
());
}
void
append
(
const
small_vector_i
mpl
&
RHS
)
{
append
(
RHS
.
begin
(),
RHS
.
end
());
}
void
assign
(
size_type
NumElts
,
ValueParamT
Elt
)
{
// Note that Elt could be an internal reference.
...
...
@@ -755,7 +760,7 @@ class SmallVectorImpl : public SmallVectorTemplateBase<T> {
append
(
IL
);
}
void
assign
(
const
SmallVectorI
mpl
&
RHS
)
{
assign
(
RHS
.
begin
(),
RHS
.
end
());
}
void
assign
(
const
small_vector_i
mpl
&
RHS
)
{
assign
(
RHS
.
begin
(),
RHS
.
end
());
}
iterator
erase
(
const_iterator
CI
)
{
// Just cast away constness because this is a non-const member function.
...
...
@@ -976,24 +981,26 @@ class SmallVectorImpl : public SmallVectorTemplateBase<T> {
return
this
->
back
();
}
SmallVectorImpl
&
operator
=
(
const
SmallVectorI
mpl
&
RHS
);
small_vector_impl
&
operator
=
(
const
small_vector_i
mpl
&
RHS
);
SmallVectorImpl
&
operator
=
(
SmallVectorI
mpl
&&
RHS
);
small_vector_impl
&
operator
=
(
small_vector_i
mpl
&&
RHS
);
bool
operator
==
(
const
SmallVectorI
mpl
&
RHS
)
const
{
bool
operator
==
(
const
small_vector_i
mpl
&
RHS
)
const
{
if
(
this
->
size
()
!=
RHS
.
size
())
return
false
;
return
std
::
equal
(
this
->
begin
(),
this
->
end
(),
RHS
.
begin
());
}
bool
operator
!=
(
const
SmallVectorImpl
&
RHS
)
const
{
return
!
(
*
this
==
RHS
);
}
bool
operator
!=
(
const
small_vector_impl
&
RHS
)
const
{
return
!
(
*
this
==
RHS
);
}
bool
operator
<
(
const
SmallVectorI
mpl
&
RHS
)
const
{
bool
operator
<
(
const
small_vector_i
mpl
&
RHS
)
const
{
return
std
::
lexicographical_compare
(
this
->
begin
(),
this
->
end
(),
RHS
.
begin
(),
RHS
.
end
());
}
};
template
<
typename
T
>
void
SmallVectorImpl
<
T
>::
swap
(
SmallVectorI
mpl
<
T
>
&
RHS
)
{
void
small_vector_impl
<
T
>::
swap
(
small_vector_i
mpl
<
T
>
&
RHS
)
{
if
(
this
==
&
RHS
)
return
;
// We can only avoid copying elements if neither vector is small.
...
...
@@ -1028,8 +1035,8 @@ void SmallVectorImpl<T>::swap(SmallVectorImpl<T> &RHS) {
}
template
<
typename
T
>
SmallVectorImpl
<
T
>
&
SmallVectorI
mpl
<
T
>::
operator
=
(
const
SmallVectorI
mpl
<
T
>
&
RHS
)
{
small_vector_impl
<
T
>
&
small_vector_i
mpl
<
T
>::
operator
=
(
const
small_vector_i
mpl
<
T
>
&
RHS
)
{
// Avoid self-assignment.
if
(
this
==
&
RHS
)
return
*
this
;
...
...
@@ -1076,7 +1083,8 @@ SmallVectorImpl<T> &SmallVectorImpl<T>::operator=(
}
template
<
typename
T
>
SmallVectorImpl
<
T
>
&
SmallVectorImpl
<
T
>::
operator
=
(
SmallVectorImpl
<
T
>
&&
RHS
)
{
small_vector_impl
<
T
>
&
small_vector_impl
<
T
>::
operator
=
(
small_vector_impl
<
T
>
&&
RHS
)
{
// Avoid self-assignment.
if
(
this
==
&
RHS
)
return
*
this
;
...
...
@@ -1135,38 +1143,38 @@ SmallVectorImpl<T> &SmallVectorImpl<T>::operator=(SmallVectorImpl<T> &&RHS) {
return
*
this
;
}
/// Storage for the
SmallV
ector elements. This is specialized for the N=0 case
/// Storage for the
small_v
ector elements. This is specialized for the N=0 case
/// to avoid allocating unnecessary storage.
template
<
typename
T
,
unsigned
N
>
struct
SmallVectorS
torage
{
struct
small_vector_s
torage
{
alignas
(
T
)
char
InlineElts
[
N
*
sizeof
(
T
)];
};
/// We need the storage to be properly aligned even for small-size of 0 so that
/// the pointer math in \a
SmallVectorTemplateC
ommon::getFirstEl() is
/// the pointer math in \a
small_vector_template_c
ommon::getFirstEl() is
/// well-defined.
template
<
typename
T
>
struct
alignas
(
T
)
SmallVectorS
torage
<
T
,
0
>
{};
struct
alignas
(
T
)
small_vector_s
torage
<
T
,
0
>
{};
/// Forward declaration of
SmallV
ector so that
/// Forward declaration of
small_v
ector so that
/// calculateSmallVectorDefaultInlinedElements can reference
/// `sizeof(
SmallV
ector<T, 0>)`.
/// `sizeof(
small_v
ector<T, 0>)`.
template
<
typename
T
,
unsigned
N
>
class
SmallV
ector
;
class
small_v
ector
;
/// Helper class for calculating the default number of inline elements for
/// `
SmallV
ector<T>`.
/// `
small_v
ector<T>`.
///
/// This should be migrated to a constexpr function when our minimum
/// compiler support is enough for multi-statement constexpr functions.
template
<
typename
T
>
struct
CalculateSmallVectorDefaultInlinedElements
{
// Parameter controlling the default number of inlined elements
// for `
SmallV
ector<T>`.
// for `
small_v
ector<T>`.
//
// The default number of inlined elements ensures that
// 1. There is at least one inlined element.
// 2. `sizeof(
SmallV
ector<T>) <= kPreferredSmallVectorSizeof` unless
// 2. `sizeof(
small_v
ector<T>) <= kPreferredSmallVectorSizeof` unless
// it contradicts 1.
static
constexpr
size_t
kPreferredSmallVectorSizeof
=
64
;
...
...
@@ -1175,14 +1183,14 @@ struct CalculateSmallVectorDefaultInlinedElements {
// Because our policy guarantees at least one inlined element, it is possible
// for an arbitrarily large inlined element to allocate an arbitrarily large
// amount of inline storage. We generally consider it an antipattern for a
//
SmallV
ector to allocate an excessive amount of inline storage, so we want
//
small_v
ector to allocate an excessive amount of inline storage, so we want
// to call attention to these cases and make sure that users are making an
// intentional decision if they request a lot of inline storage.
//
// We want this assertion to trigger in pathological cases, but otherwise
// not be too easy to hit. To accomplish that, the cutoff is actually somewhat
// larger than kPreferredSmallVectorSizeof (otherwise,
// `
SmallVector<SmallV
ector<T>>` would be one easy way to trip it, and that
// `
small_vector<small_v
ector<T>>` would be one easy way to trip it, and that
// pattern seems useful in practice).
//
// One wrinkle is that this assertion is in theory non-portable, since
...
...
@@ -1195,14 +1203,14 @@ struct CalculateSmallVectorDefaultInlinedElements {
static_assert
(
sizeof
(
T
)
<=
256
,
"You are trying to use a default number of inlined elements for "
"`
SmallV
ector<T>` but `sizeof(T)` is really big! Please use an "
"explicit number of inlined elements with `
SmallV
ector<T, N>` to make "
"`
small_v
ector<T>` but `sizeof(T)` is really big! Please use an "
"explicit number of inlined elements with `
small_v
ector<T, N>` to make "
"sure you really want that much inline storage."
);
// Discount the size of the header itself when calculating the maximum inline
// bytes.
static
constexpr
size_t
PreferredInlineBytes
=
kPreferredSmallVectorSizeof
-
sizeof
(
SmallV
ector
<
T
,
0
>
);
kPreferredSmallVectorSizeof
-
sizeof
(
small_v
ector
<
T
,
0
>
);
static
constexpr
size_t
NumElementsThatFit
=
PreferredInlineBytes
/
sizeof
(
T
);
static
constexpr
size_t
value
=
NumElementsThatFit
==
0
?
1
:
NumElementsThatFit
;
...
...
@@ -1216,27 +1224,27 @@ struct CalculateSmallVectorDefaultInlinedElements {
///
/// \note
/// In the absence of a well-motivated choice for the number of inlined
/// elements \p N, it is recommended to use \c
SmallV
ector<T> (that is,
/// elements \p N, it is recommended to use \c
small_v
ector<T> (that is,
/// omitting the \p N). This will choose a default number of inlined elements
/// reasonable for allocation on the stack (for example, trying to keep \c
/// sizeof(
SmallV
ector<T>) around 64 bytes).
/// sizeof(
small_v
ector<T>) around 64 bytes).
///
/// \warning This does not attempt to be exception safe.
///
/// \see https://llvm.org/docs/ProgrammersManual.html#llvm-adt-smallvector-h
template
<
typename
T
,
unsigned
N
=
CalculateSmallVectorDefaultInlinedElements
<
T
>
::
value
>
class
SmallVector
:
public
SmallVectorImpl
<
T
>
,
SmallVectorS
torage
<
T
,
N
>
{
class
small_vector
:
public
small_vector_impl
<
T
>
,
small_vector_s
torage
<
T
,
N
>
{
public:
SmallVector
()
:
SmallVectorI
mpl
<
T
>
(
N
)
{}
small_vector
()
:
small_vector_i
mpl
<
T
>
(
N
)
{}
~
SmallV
ector
()
{
~
small_v
ector
()
{
// Destroy the constructed elements in the vector.
this
->
destroy_range
(
this
->
begin
(),
this
->
end
());
}
explicit
SmallV
ector
(
size_t
Size
,
const
T
&
Value
=
T
())
:
SmallVectorI
mpl
<
T
>
(
N
)
{
explicit
small_v
ector
(
size_t
Size
,
const
T
&
Value
=
T
())
:
small_vector_i
mpl
<
T
>
(
N
)
{
this
->
assign
(
Size
,
Value
);
}
...
...
@@ -1244,63 +1252,63 @@ class SmallVector : public SmallVectorImpl<T>, SmallVectorStorage<T, N> {
typename
=
std
::
enable_if_t
<
std
::
is_convertible
<
typename
std
::
iterator_traits
<
ItTy
>
::
iterator_category
,
std
::
input_iterator_tag
>::
value
>>
SmallVector
(
ItTy
S
,
ItTy
E
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
small_vector
(
ItTy
S
,
ItTy
E
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
this
->
append
(
S
,
E
);
}
template
<
typename
RangeTy
>
explicit
SmallV
ector
(
const
iterator_range
<
RangeTy
>
&
R
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
explicit
small_v
ector
(
const
iterator_range
<
RangeTy
>
&
R
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
this
->
append
(
R
.
begin
(),
R
.
end
());
}
SmallVector
(
std
::
initializer_list
<
T
>
IL
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
small_vector
(
std
::
initializer_list
<
T
>
IL
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
this
->
assign
(
IL
);
}
SmallVector
(
const
SmallVector
&
RHS
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
SmallVectorI
mpl
<
T
>::
operator
=
(
RHS
);
small_vector
(
const
small_vector
&
RHS
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
small_vector_i
mpl
<
T
>::
operator
=
(
RHS
);
}
SmallVector
&
operator
=
(
const
SmallV
ector
&
RHS
)
{
SmallVectorI
mpl
<
T
>::
operator
=
(
RHS
);
small_vector
&
operator
=
(
const
small_v
ector
&
RHS
)
{
small_vector_i
mpl
<
T
>::
operator
=
(
RHS
);
return
*
this
;
}
SmallVector
(
SmallVector
&&
RHS
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
SmallVectorI
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
small_vector
(
small_vector
&&
RHS
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
small_vector_i
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
}
SmallVector
(
SmallVectorImpl
<
T
>
&&
RHS
)
:
SmallVectorI
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
SmallVectorI
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
small_vector
(
small_vector_impl
<
T
>
&&
RHS
)
:
small_vector_i
mpl
<
T
>
(
N
)
{
if
(
!
RHS
.
empty
())
small_vector_i
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
}
SmallVector
&
operator
=
(
SmallV
ector
&&
RHS
)
{
SmallVectorI
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
small_vector
&
operator
=
(
small_v
ector
&&
RHS
)
{
small_vector_i
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
return
*
this
;
}
SmallVector
&
operator
=
(
SmallVectorI
mpl
<
T
>
&&
RHS
)
{
SmallVectorI
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
small_vector
&
operator
=
(
small_vector_i
mpl
<
T
>
&&
RHS
)
{
small_vector_i
mpl
<
T
>::
operator
=
(
::
std
::
move
(
RHS
));
return
*
this
;
}
SmallV
ector
&
operator
=
(
std
::
initializer_list
<
T
>
IL
)
{
small_v
ector
&
operator
=
(
std
::
initializer_list
<
T
>
IL
)
{
this
->
assign
(
IL
);
return
*
this
;
}
};
template
<
typename
T
,
unsigned
N
>
inline
size_t
capacity_in_bytes
(
const
SmallV
ector
<
T
,
N
>
&
X
)
{
inline
size_t
capacity_in_bytes
(
const
small_v
ector
<
T
,
N
>
&
X
)
{
return
X
.
capacity_in_bytes
();
}
/// Given a range of type R, iterate the entire range and return a
///
SmallV
ector with elements of the vector. This is useful, for example,
///
small_v
ector with elements of the vector. This is useful, for example,
/// when you want to iterate a range and then sort the results.
template
<
unsigned
Size
,
typename
R
>
SmallV
ector
<
typename
std
::
remove_const
<
typename
std
::
remove_reference
<
small_v
ector
<
typename
std
::
remove_const
<
typename
std
::
remove_reference
<
decltype
(
*
std
::
begin
(
std
::
declval
<
R
&>
()))
>::
type
>::
type
,
Size
>
to_vector
(
R
&&
Range
)
{
...
...
@@ -1352,22 +1360,22 @@ struct Struct32B {
alignas
(
32
)
void
*
X
;
};
}
static_assert
(
sizeof
(
SmallV
ector
<
void
*
,
0
>
)
==
static_assert
(
sizeof
(
small_v
ector
<
void
*
,
0
>
)
==
sizeof
(
unsigned
)
*
2
+
sizeof
(
void
*
),
"wasted space in
SmallV
ector size 0"
);
static_assert
(
alignof
(
SmallV
ector
<
Struct16B
,
0
>
)
>=
alignof
(
Struct16B
),
"wasted space in
small_v
ector size 0"
);
static_assert
(
alignof
(
small_v
ector
<
Struct16B
,
0
>
)
>=
alignof
(
Struct16B
),
"wrong alignment for 16-byte aligned T"
);
static_assert
(
alignof
(
SmallV
ector
<
Struct32B
,
0
>
)
>=
alignof
(
Struct32B
),
static_assert
(
alignof
(
small_v
ector
<
Struct32B
,
0
>
)
>=
alignof
(
Struct32B
),
"wrong alignment for 32-byte aligned T"
);
static_assert
(
sizeof
(
SmallV
ector
<
Struct16B
,
0
>
)
>=
alignof
(
Struct16B
),
static_assert
(
sizeof
(
small_v
ector
<
Struct16B
,
0
>
)
>=
alignof
(
Struct16B
),
"missing padding for 16-byte aligned T"
);
static_assert
(
sizeof
(
SmallV
ector
<
Struct32B
,
0
>
)
>=
alignof
(
Struct32B
),
static_assert
(
sizeof
(
small_v
ector
<
Struct32B
,
0
>
)
>=
alignof
(
Struct32B
),
"missing padding for 32-byte aligned T"
);
static_assert
(
sizeof
(
SmallV
ector
<
void
*
,
1
>
)
==
static_assert
(
sizeof
(
small_v
ector
<
void
*
,
1
>
)
==
sizeof
(
unsigned
)
*
2
+
sizeof
(
void
*
)
*
2
,
"wasted space in
SmallV
ector size 1"
);
"wasted space in
small_v
ector size 1"
);
static_assert
(
sizeof
(
SmallV
ector
<
char
,
0
>
)
==
static_assert
(
sizeof
(
small_v
ector
<
char
,
0
>
)
==
sizeof
(
void
*
)
*
2
+
sizeof
(
void
*
),
"1 byte elements have word-sized type for size and capacity"
);
...
...
@@ -1375,7 +1383,7 @@ static_assert(sizeof(SmallVector<char, 0>) ==
/// std::length_error or calls report_fatal_error.
static
void
report_size_overflow
(
size_t
MinSize
,
size_t
MaxSize
);
static
void
report_size_overflow
(
size_t
MinSize
,
size_t
MaxSize
)
{
std
::
string
Reason
=
"
SmallV
ector unable to grow. Requested capacity ("
+
std
::
string
Reason
=
"
small_v
ector unable to grow. Requested capacity ("
+
std
::
to_string
(
MinSize
)
+
") is larger than maximum value for size type ("
+
std
::
to_string
(
MaxSize
)
+
")"
;
...
...
@@ -1387,7 +1395,7 @@ static void report_size_overflow(size_t MinSize, size_t MaxSize) {
static
void
report_at_maximum_capacity
(
size_t
MaxSize
);
static
void
report_at_maximum_capacity
(
size_t
MaxSize
)
{
std
::
string
Reason
=
"
SmallV
ector capacity unable to grow. Already at maximum size "
+
"
small_v
ector capacity unable to grow. Already at maximum size "
+
std
::
to_string
(
MaxSize
);
throw
std
::
length_error
(
Reason
);
}
...
...
@@ -1415,7 +1423,7 @@ static size_t getNewCapacity(size_t MinSize, size_t TSize, size_t OldCapacity) {
// Note: Moving this function into the header may cause performance regression.
template
<
class
Size_T
>
void
*
SmallVectorB
ase
<
Size_T
>::
mallocForGrow
(
size_t
MinSize
,
void
*
small_vector_b
ase
<
Size_T
>::
mallocForGrow
(
size_t
MinSize
,
size_t
TSize
,
size_t
&
NewCapacity
)
{
NewCapacity
=
getNewCapacity
<
Size_T
>
(
MinSize
,
TSize
,
this
->
capacity
());
...
...
@@ -1424,7 +1432,7 @@ void *SmallVectorBase<Size_T>::mallocForGrow(size_t MinSize,
// Note: Moving this function into the header may cause performance regression.
template
<
class
Size_T
>
void
SmallVectorB
ase
<
Size_T
>::
grow_pod
(
void
*
FirstEl
,
void
small_vector_b
ase
<
Size_T
>::
grow_pod
(
void
*
FirstEl
,
size_t
MinSize
,
size_t
TSize
)
{
size_t
NewCapacity
=
getNewCapacity
<
Size_T
>
(
MinSize
,
TSize
,
this
->
capacity
());
...
...
@@ -1443,38 +1451,38 @@ void SmallVectorBase<Size_T>::grow_pod(void *FirstEl,
this
->
Capacity
=
NewCapacity
;
}
template
class
paddle
::
SmallVectorB
ase
<
uint32_t
>;
template
class
paddle
::
small_vector_b
ase
<
uint32_t
>;
// Disable the uint64_t instantiation for 32-bit builds.
// Both uint32_t and uint64_t instantiations are needed for 64-bit builds.
// This instantiation will never be used in 32-bit builds, and will cause
// warnings when sizeof(Size_T) > sizeof(size_t).
#if SIZE_MAX > UINT32_MAX
template
class
paddle
::
SmallVectorB
ase
<
uint64_t
>;
template
class
paddle
::
small_vector_b
ase
<
uint64_t
>;
// Assertions to ensure this #if stays in sync with SmallVectorSizeType.
static_assert
(
sizeof
(
SmallVectorSizeType
<
char
>
)
==
sizeof
(
uint64_t
),
"Expected
SmallVectorB
ase<uint64_t> variant to be in use."
);
"Expected
small_vector_b
ase<uint64_t> variant to be in use."
);
#else
static_assert
(
sizeof
(
SmallVectorSizeType
<
char
>
)
==
sizeof
(
uint32_t
),
"Expected
SmallVectorB
ase<uint32_t> variant to be in use."
);
"Expected
small_vector_b
ase<uint32_t> variant to be in use."
);
#endif
}
// namespace paddle
namespace
std
{
/// Implement std::swap in terms of
SmallV
ector swap.
/// Implement std::swap in terms of
small_v
ector swap.
template
<
typename
T
>
inline
void
swap
(
paddle
::
SmallVectorI
mpl
<
T
>
&
LHS
,
paddle
::
SmallVectorI
mpl
<
T
>
&
RHS
)
{
inline
void
swap
(
paddle
::
small_vector_i
mpl
<
T
>
&
LHS
,
paddle
::
small_vector_i
mpl
<
T
>
&
RHS
)
{
LHS
.
swap
(
RHS
);
}
/// Implement std::swap in terms of
SmallV
ector swap.
/// Implement std::swap in terms of
small_v
ector swap.
template
<
typename
T
,
unsigned
N
>
inline
void
swap
(
paddle
::
SmallV
ector
<
T
,
N
>
&
LHS
,
paddle
::
SmallV
ector
<
T
,
N
>
&
RHS
)
{
inline
void
swap
(
paddle
::
small_v
ector
<
T
,
N
>
&
LHS
,
paddle
::
small_v
ector
<
T
,
N
>
&
RHS
)
{
LHS
.
swap
(
RHS
);
}
...
...
paddle/utils/small_vector_test.cc
浏览文件 @
2cebcf4a
...
...
@@ -21,7 +21,7 @@
#include "gtest/gtest.h"
template
<
typename
T
,
unsigned
N
>
static
std
::
vector
<
T
>
ToStdVector
(
const
paddle
::
SmallV
ector
<
T
,
N
>
&
vec
)
{
static
std
::
vector
<
T
>
ToStdVector
(
const
paddle
::
small_v
ector
<
T
,
N
>
&
vec
)
{
std
::
vector
<
T
>
std_vec
;
std_vec
.
reserve
(
vec
.
size
());
for
(
size_t
i
=
0
;
i
<
vec
.
size
();
++
i
)
{
...
...
@@ -35,7 +35,7 @@ void SmallVectorCheck(size_t n) {
std
::
srand
(
std
::
time
(
nullptr
));
std
::
vector
<
int
>
std_vec
;
paddle
::
SmallV
ector
<
int
,
N
>
vec
;
paddle
::
small_v
ector
<
int
,
N
>
vec
;
for
(
size_t
i
=
0
;
i
<
n
;
++
i
)
{
int
value
=
rand
();
// NOLINT
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录