Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
8bd2879e
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看板
未验证
提交
8bd2879e
编写于
4年前
作者:
石
石晓伟
提交者:
GitHub
4年前
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update the operator registration for incompatible upgrade, test=develop (#29720)
上级
10edfb6f
develop
2.0.1-rocm-post
Ligoml-patch-1
OliverLPH-patch-1
OliverLPH-patch-2
PaddlePM-patch-1
PaddlePM-patch-2
ZHUI-patch-1
add_default_att
add_model_benchmark_ci
add_some_yaml_config
addfile
all_new_design_exec
ascendrc
ascendrelease
cherry_undefined_var
compile_windows
delete_2.0.1-rocm-post
delete_add_default_att
delete_all_new_design_exec
delete_ascendrc
delete_compile_windows
delete_delete_addfile
delete_disable_iterable_dataset_unittest
delete_fix_dataloader_memory_leak
delete_fix_imperative_dygraph_error
delete_fix_retry_ci
delete_fix_undefined_var
delete_improve_sccache
delete_paralleltest
delete_prv-disable-more-cache
delete_revert-31068-fix_conv3d_windows
delete_revert-31562-mean
delete_revert-33630-bug-fix
delete_revert-34159-add_npu_bce_logical_dev
delete_revert-34910-spinlocks_for_allocator
delete_revert-35069-revert-34910-spinlocks_for_allocator
delete_revert-36057-dev/read_flags_in_ut
dingjiaweiww-patch-1
disable_iterable_dataset_unittest
dy2static
enable_eager_model_test
final_state_gen_python_c
final_state_intermediate
fix-numpy-issue
fix_concat_slice
fix_dataloader_memory_leak
fix_imperative_dygraph_error
fix_npu_ci
fix_op_flops
fix_retry_ci
fix_rnn_docs
fix_tensor_type
fix_undefined_var
fixiscan
fixiscan1
fixiscan2
fixiscan3
improve_sccache
incubate/infrt
inplace_addto
make_flag_adding_easier
move_embedding_to_phi
move_histogram_to_pten
move_sgd_to_phi
move_slice_to_pten
move_temporal_shift_to_phi
move_yolo_box_to_phi
npu_fix_alloc
paralleltest
preln_ernie
prv-disable-more-cache
prv-md-even-more
prv-onednn-2.5
pten_tensor_refactor
release/2.1
release/2.2
release/2.3
release/2.3-fc-ernie-fix
release/2.4
revert-31068-fix_conv3d_windows
revert-31562-mean
revert-32290-develop-hardlabel
revert-33037-forci
revert-33475-fix_cifar_label_dimension
revert-33630-bug-fix
revert-34159-add_npu_bce_logical_dev
revert-34406-add_copy_from_tensor
revert-34910-spinlocks_for_allocator
revert-35069-revert-34910-spinlocks_for_allocator
revert-36057-dev/read_flags_in_ut
revert-36201-refine_fast_threaded_ssa_graph_executor
revert-36985-add_license
revert-37318-refactor_dygraph_to_eager
revert-37926-eager_coreops_500
revert-37956-revert-37727-pylayer_support_tuple
revert-38100-mingdong
revert-38301-allocation_rearrange_pr
revert-38703-numpy_bf16_package_reupload
revert-38732-remove_useless_header_in_elementwise_mul_grad
revert-38959-Reduce_Grad
revert-39143-adjust_empty
revert-39227-move_trace_op_to_pten
revert-39268-dev/remove_concat_fluid_kernel
revert-40170-support_partial_grad
revert-41056-revert-40727-move_some_activaion_to_phi
revert-41065-revert-40993-mv_ele_floordiv_pow
revert-41068-revert-40790-phi_new
revert-41944-smaller_inference_api_test
revert-42149-do-not-reset-default-stream-for-stream-safe-cuda-allocator
revert-43155-fix_ut_tempfile
revert-43882-revert-41944-smaller_inference_api_test
revert-45808-phi/simplify_size_op
revert-46827-deform_comment
rocm_dev_0217
support_weight_transpose
test_benchmark_ci
test_model_benchmark
test_model_benchmark_ci
zhiqiu-patch-1
v2.4.0-rc0
v2.3.2
v2.3.1
v2.3.0
v2.3.0-rc0
v2.2.2
v2.2.1
v2.2.0
v2.2.0-rc0
v2.2.0-bak0
v2.1.3
v2.1.2
v2.1.1
v2.1.0
v2.1.0-rc0
无相关合并请求
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
79 addition
and
12 deletion
+79
-12
paddle/fluid/framework/op_version_registry.cc
paddle/fluid/framework/op_version_registry.cc
+31
-0
paddle/fluid/framework/op_version_registry.h
paddle/fluid/framework/op_version_registry.h
+35
-12
paddle/fluid/framework/op_version_registry_test.cc
paddle/fluid/framework/op_version_registry_test.cc
+13
-0
未找到文件。
paddle/fluid/framework/op_version_registry.cc
浏览文件 @
8bd2879e
...
...
@@ -62,6 +62,37 @@ OpVersionDesc&& OpVersionDesc::BugfixWithBehaviorChanged(
return
std
::
move
(
*
this
);
}
OpVersionDesc
&&
OpVersionDesc
::
DeleteAttr
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
)
{
infos_
.
emplace_back
(
new_update
<
OpUpdateType
::
kDeleteAttr
>
(
OpAttrInfo
(
name
,
remark
)));
return
std
::
move
(
*
this
);
}
OpVersionDesc
&&
OpVersionDesc
::
ModifyInput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
)
{
infos_
.
emplace_back
(
new_update
<
OpUpdateType
::
kModifyInput
>
(
OpInputOutputInfo
(
name
,
remark
)));
return
std
::
move
(
*
this
);
}
OpVersionDesc
&&
OpVersionDesc
::
ModifyOutput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
)
{
infos_
.
emplace_back
(
new_update
<
OpUpdateType
::
kModifyOutput
>
(
OpInputOutputInfo
(
name
,
remark
)));
return
std
::
move
(
*
this
);
}
OpVersionDesc
&&
OpVersionDesc
::
DeleteInput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
)
{
infos_
.
emplace_back
(
new_update
<
OpUpdateType
::
kDeleteInput
>
(
OpInputOutputInfo
(
name
,
remark
)));
return
std
::
move
(
*
this
);
}
OpVersionDesc
&&
OpVersionDesc
::
DeleteOutput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
)
{
infos_
.
emplace_back
(
new_update
<
OpUpdateType
::
kDeleteOutput
>
(
OpInputOutputInfo
(
name
,
remark
)));
return
std
::
move
(
*
this
);
}
OpVersion
&
OpVersionRegistrar
::
Register
(
const
std
::
string
&
op_type
)
{
PADDLE_ENFORCE_EQ
(
op_version_map_
.
find
(
op_type
),
op_version_map_
.
end
(),
...
...
This diff is collapsed.
Click to expand it.
paddle/fluid/framework/op_version_registry.h
浏览文件 @
8bd2879e
...
...
@@ -20,6 +20,7 @@ limitations under the License. */
#include <utility>
#include <vector>
#include <boost/none.hpp>
#include <boost/variant.hpp>
#include "paddle/fluid/framework/framework.pb.h"
#include "paddle/fluid/framework/op_version_proto.h"
...
...
@@ -30,16 +31,17 @@ namespace framework {
namespace
compatible
{
using
OpAttrVariantT
=
boost
::
variant
<
bool
,
/* AttrType::BOOL */
float
,
/* AttrType::FLOAT */
int32_t
,
/* AttrType::INT */
int64_t
,
/* AttrType::LONG*/
std
::
string
,
/* AttrType::STRING */
std
::
vector
<
bool
>
,
/* AttrType::BOOLS */
std
::
vector
<
float
>
,
/* AttrType::FLOATS */
std
::
vector
<
int32_t
>
,
/* AttrType::INTS */
std
::
vector
<
int64_t
>
,
/* AttrType::LONGS */
std
::
vector
<
std
::
string
>
/* AttrType::STRINGS */
boost
::
variant
<
bool
,
/* AttrType::BOOL */
float
,
/* AttrType::FLOAT */
int32_t
,
/* AttrType::INT */
int64_t
,
/* AttrType::LONG*/
std
::
string
,
/* AttrType::STRING */
std
::
vector
<
bool
>
,
/* AttrType::BOOLS */
std
::
vector
<
float
>
,
/* AttrType::FLOATS */
std
::
vector
<
int32_t
>
,
/* AttrType::INTS */
std
::
vector
<
int64_t
>
,
/* AttrType::LONGS */
std
::
vector
<
std
::
string
>
,
/* AttrType::STRINGS */
boost
::
none_t
/* None */
>
;
struct
OpUpdateInfo
{
...
...
@@ -48,7 +50,7 @@ struct OpUpdateInfo {
struct
OpAttrInfo
:
OpUpdateInfo
{
OpAttrInfo
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
,
const
OpAttrVariantT
&
default_value
)
const
OpAttrVariantT
&
default_value
=
boost
::
none
)
:
name_
{
name
},
default_value_
{
default_value
},
remark_
{
remark
}
{}
const
std
::
string
&
name
()
const
{
return
name_
;
}
...
...
@@ -83,11 +85,18 @@ struct OpBugfixInfo : OpUpdateInfo {
enum
class
OpUpdateType
{
kInvalid
=
0
,
/* Compatibility upgrade */
kModifyAttr
,
kNewAttr
,
kNewInput
,
kNewOutput
,
kBugfixWithBehaviorChanged
,
/* Incompatible upgrade, only for existing registration. */
kDeleteAttr
=
100
,
kModifyInput
,
kModifyOutput
,
kDeleteInput
,
kDeleteOutput
,
};
class
OpUpdateBase
{
...
...
@@ -111,6 +120,7 @@ class OpUpdate : public OpUpdateBase {
class
OpVersionDesc
{
public:
/* Compatibility upgrade */
OpVersionDesc
&&
ModifyAttr
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
,
const
OpAttrVariantT
&
default_value
);
OpVersionDesc
&&
NewAttr
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
,
...
...
@@ -118,10 +128,23 @@ class OpVersionDesc {
OpVersionDesc
&&
NewInput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
NewOutput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
BugfixWithBehaviorChanged
(
const
std
::
string
&
remark
);
/* Incompatible upgrade, only for existing registration. */
OpVersionDesc
&&
DeleteAttr
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
ModifyInput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
ModifyOutput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
DeleteInput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
OpVersionDesc
&&
DeleteOutput
(
const
std
::
string
&
name
,
const
std
::
string
&
remark
);
public:
const
std
::
vector
<
std
::
unique_ptr
<
OpUpdateBase
>>&
infos
()
const
{
return
infos_
;
}
OpVersionDesc
()
=
default
;
OpVersionDesc
(
OpVersionDesc
&&
)
=
default
;
OpVersionDesc
&
operator
=
(
OpVersionDesc
&&
)
=
default
;
...
...
This diff is collapsed.
Click to expand it.
paddle/fluid/framework/op_version_registry_test.cc
浏览文件 @
8bd2879e
...
...
@@ -53,6 +53,19 @@ TEST(test_operator_version, test_operator_version) {
framework
::
compatible
::
OpVersionDesc
()
.
NewInput
(
"X2"
,
"The second input."
)
.
NewOutput
(
"Y2"
,
"The second output."
));
REGISTER_OP_VERSION
(
op_name_0__
)
.
AddCheckpoint
(
R"ROC(
Incompatible upgrade of attribute [height], input [X2] and output [Y2]
)ROC"
,
framework
::
compatible
::
OpVersionDesc
()
.
DeleteAttr
(
"height"
,
"Parameters deleted due to interface alignment."
)
.
ModifyInput
(
"X2"
,
"Modify input due to interface alignment."
)
.
ModifyOutput
(
"Y2"
,
"Modify output due to interface alignment."
)
.
DeleteInput
(
"X2"
,
"Delete input due to interface alignment."
)
.
DeleteOutput
(
"Y2"
,
"Delete output due to interface alignment."
));
}
TEST
(
test_pass_op_version_checker
,
test_pass_op_version_checker
)
{
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录
反馈
建议
客服
返回
顶部