forked from PaddlePaddle/Paddle
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[CustomOp] New custom operator extension mechanism in 2.0.1 (PaddlePa…
…ddle#31097) [CustomOp] New custom operator extension mechanism in 2.0.1 Cherry-pick New custom operator basic implementation related PRs
- Loading branch information
Showing
45 changed files
with
5,021 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
/* Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. */ | ||
|
||
#pragma once | ||
|
||
// All paddle apis in C++ frontend | ||
#include "paddle/fluid/extension/include/all.h" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
/* Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. */ | ||
|
||
#pragma once | ||
|
||
#if !defined(_MSC_VER) && __cplusplus < 199711L | ||
#error C++11 or later compatible compiler is required to use Paddle. | ||
#endif | ||
|
||
#include "paddle/fluid/extension/include/dispatch.h" | ||
#include "paddle/fluid/extension/include/dtype.h" | ||
#include "paddle/fluid/extension/include/op_meta_info.h" | ||
#include "paddle/fluid/extension/include/place.h" | ||
#include "paddle/fluid/extension/include/tensor.h" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,168 @@ | ||
/* Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. */ | ||
|
||
#pragma once | ||
|
||
#include "paddle/fluid/extension/include/dtype.h" | ||
|
||
namespace paddle { | ||
|
||
///////// Basic Marco /////////// | ||
|
||
#define PD_PRIVATE_CASE_TYPE_USING_HINT(NAME, enum_type, type, HINT, ...) \ | ||
case enum_type: { \ | ||
using HINT = type; \ | ||
__VA_ARGS__(); \ | ||
break; \ | ||
} | ||
|
||
#define PD_PRIVATE_CASE_TYPE(NAME, enum_type, type, ...) \ | ||
PD_PRIVATE_CASE_TYPE_USING_HINT(NAME, enum_type, type, data_t, __VA_ARGS__) | ||
|
||
///////// Floating Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_FLOATING_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT32, float, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT64, double, \ | ||
__VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
///////// Integral Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_INTEGRAL_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT32, int, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT64, int64_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT8, int8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::UINT8, uint8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT16, int16_t, \ | ||
__VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
///////// Complex Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_COMPLEX_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX64, \ | ||
::paddle::complex64, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX128, \ | ||
::paddle::complex128, __VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
///////// Floating and Integral Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_FLOATING_AND_INTEGRAL_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT32, float, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT64, double, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT32, int, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT64, int64_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT8, int8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::UINT8, uint8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT16, int16_t, \ | ||
__VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
///////// Floating and Complex Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_FLOATING_AND_COMPLEX_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT32, float, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT64, double, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX64, \ | ||
::paddle::complex64, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX128, \ | ||
::paddle::complex128, __VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
///////// Floating, Integral and Complex Dispatch Marco /////////// | ||
|
||
#define PD_DISPATCH_FLOATING_AND_INTEGRAL_AND_COMPLEX_TYPES(TYPE, NAME, ...) \ | ||
[&] { \ | ||
const auto& __dtype__ = TYPE; \ | ||
switch (__dtype__) { \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT32, float, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::FLOAT64, double, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT32, int, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT64, int64_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT8, int8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::UINT8, uint8_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::INT16, int16_t, \ | ||
__VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX64, \ | ||
::paddle::complex64, __VA_ARGS__) \ | ||
PD_PRIVATE_CASE_TYPE(NAME, ::paddle::DataType::COMPLEX128, \ | ||
::paddle::complex128, __VA_ARGS__) \ | ||
default: \ | ||
throw std::runtime_error("function " #NAME \ | ||
" not implemented for data type `" + \ | ||
::paddle::ToString(__dtype__) + "`"); \ | ||
} \ | ||
}() | ||
|
||
// TODO(chenweihang): Add more Marcos in the future if needed | ||
|
||
} // namespace paddle |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,103 @@ | ||
/* Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. */ | ||
|
||
#pragma once | ||
|
||
#include "paddle/fluid/platform/bfloat16.h" | ||
#include "paddle/fluid/platform/complex128.h" | ||
#include "paddle/fluid/platform/complex64.h" | ||
#include "paddle/fluid/platform/float16.h" | ||
|
||
namespace paddle { | ||
|
||
using float16 = paddle::platform::float16; | ||
using bfloat16 = paddle::platform::bfloat16; | ||
using complex64 = paddle::platform::complex64; | ||
using complex128 = paddle::platform::complex128; | ||
|
||
enum DataType { | ||
BOOL, | ||
INT8, | ||
UINT8, | ||
INT16, | ||
INT32, | ||
INT64, | ||
FLOAT16, | ||
BFLOAT16, | ||
FLOAT32, | ||
FLOAT64, | ||
COMPLEX64, | ||
COMPLEX128, | ||
// TODO(JiabinYang) support more data types if needed. | ||
}; | ||
|
||
inline std::string ToString(DataType dtype) { | ||
switch (dtype) { | ||
case DataType::BOOL: | ||
return "bool"; | ||
case DataType::INT8: | ||
return "int8_t"; | ||
case DataType::UINT8: | ||
return "uint8_t"; | ||
case DataType::INT16: | ||
return "int16_t"; | ||
case DataType::INT32: | ||
return "int32_t"; | ||
case DataType::INT64: | ||
return "int64_t"; | ||
case DataType::FLOAT16: | ||
return "float16"; | ||
case DataType::BFLOAT16: | ||
return "bfloat16"; | ||
case DataType::FLOAT32: | ||
return "float"; | ||
case DataType::FLOAT64: | ||
return "double"; | ||
case DataType::COMPLEX64: | ||
return "complex64"; | ||
case DataType::COMPLEX128: | ||
return "complex128"; | ||
default: | ||
throw std::runtime_error("Unsupported paddle enum data type."); | ||
} | ||
} | ||
|
||
#define PD_FOR_EACH_DATA_TYPE(_) \ | ||
_(bool, DataType::BOOL) \ | ||
_(int8_t, DataType::INT8) \ | ||
_(uint8_t, DataType::UINT8) \ | ||
_(int16_t, DataType::INT16) \ | ||
_(int, DataType::INT32) \ | ||
_(int64_t, DataType::INT64) \ | ||
_(float16, DataType::FLOAT16) \ | ||
_(bfloat16, DataType::BFLOAT16) \ | ||
_(float, DataType::FLOAT32) \ | ||
_(double, DataType::FLOAT64) \ | ||
_(complex64, DataType::COMPLEX64) \ | ||
_(complex128, DataType::COMPLEX128) | ||
|
||
template <paddle::DataType T> | ||
struct DataTypeToCPPType; | ||
|
||
#define PD_SPECIALIZE_DataTypeToCPPType(cpp_type, data_type) \ | ||
template <> \ | ||
struct DataTypeToCPPType<data_type> { \ | ||
using type = cpp_type; \ | ||
}; | ||
|
||
PD_FOR_EACH_DATA_TYPE(PD_SPECIALIZE_DataTypeToCPPType) | ||
|
||
#undef PD_SPECIALIZE_DataTypeToCPPType | ||
|
||
} // namespace paddle |
Oops, something went wrong.