diff --git a/paddle/fluid/operators/distributed_ops/split_byref_op.cc b/paddle/fluid/operators/distributed_ops/split_byref_op.cc index 79d9c272e8b4e5241ec5f5d79a706fd5376788d9..5d26c80f8830a4edda37bfb83be93572ce605f61 100644 --- a/paddle/fluid/operators/distributed_ops/split_byref_op.cc +++ b/paddle/fluid/operators/distributed_ops/split_byref_op.cc @@ -24,10 +24,9 @@ class SplitByrefOp : public framework::OperatorWithKernel { using framework::OperatorWithKernel::OperatorWithKernel; void InferShape(framework::InferShapeContext *ctx) const override { - PADDLE_ENFORCE(ctx->HasInput("X"), - "Input(X) of SplitOp should not be null."); - PADDLE_ENFORCE_GE(ctx->Outputs("Out").size(), 1UL, - "Outputs(Out) of SplitOp should not be empty."); + OP_INOUT_CHECK(ctx->HasInput("X"), "Input", "Ids", "SplitByrefOp"); + OP_INOUT_CHECK(ctx->HasOutputs("Out"), "Output", "Out", "SplitByrefOp"); + auto in_dims = ctx->GetInputDim("X"); auto outs_names = ctx->Outputs("Out"); size_t num = static_cast(ctx->Attrs().Get("num")); @@ -51,9 +50,10 @@ class SplitByrefOp : public framework::OperatorWithKernel { outs_dims.push_back(dim); } } else if (sections.size() > 0) { - PADDLE_ENFORCE_EQ(sections.size(), outs_number, - "tensor split sections size" - "should be equal to output size."); + PADDLE_ENFORCE_EQ( + sections.size(), outs_number, + platform::errors::InvalidArgument("tensor split sections size" + "should be equal to output size")); for (size_t i = 0; i < outs_number; ++i) { auto dim = in_dims; dim[0] = sections[i]; diff --git a/paddle/fluid/operators/distributed_ops/split_ids_op.cc b/paddle/fluid/operators/distributed_ops/split_ids_op.cc index df9681c315c67299189c203591f533efb93489a5..86738b7c69e8b5a8c013f0992bf94f8de7feea00 100644 --- a/paddle/fluid/operators/distributed_ops/split_ids_op.cc +++ b/paddle/fluid/operators/distributed_ops/split_ids_op.cc @@ -52,13 +52,19 @@ class SplitIdsOp : public framework::OperatorWithKernel { using framework::OperatorWithKernel::OperatorWithKernel; void InferShape(framework::InferShapeContext *ctx) const override { - PADDLE_ENFORCE(ctx->HasInputs("Ids"), "SplitIdsOp must have input Ids."); - PADDLE_ENFORCE(ctx->HasOutputs("Out"), "SplitIdsOp must have output Out."); + OP_INOUT_CHECK(ctx->HasInputs("Ids"), "Input", "Ids", "SplitIdsOp"); + OP_INOUT_CHECK(ctx->HasOutputs("Out"), "Output", "Out", "SplitIdsOp"); auto ids_var_type = ctx->GetInputsVarType("Ids").front(); auto ids_dims = ctx->GetInputsDim("Ids"); if (ids_var_type == framework::proto::VarType::LOD_TENSOR) { - PADDLE_ENFORCE_EQ(ids_dims[0].size(), 2); + PADDLE_ENFORCE_EQ( + ids_dims[0].size(), 2, + platform::errors::InvalidArgument( + "ShapeError: The dimensions of the 'split_ids' must be 2. " + "But received split_ids's dimensions = %d, " + "split_ids's shape = [%s].", + ids_dims[0].size(), ids_dims[0])); } } diff --git a/paddle/fluid/operators/distributed_ops/split_ids_op.h b/paddle/fluid/operators/distributed_ops/split_ids_op.h index 8a75dd8062359a4e2fdbbeffb24c3b92d71b87bd..8a3ebe6e258e57205bb46675060162e673c7b300 100644 --- a/paddle/fluid/operators/distributed_ops/split_ids_op.h +++ b/paddle/fluid/operators/distributed_ops/split_ids_op.h @@ -30,12 +30,17 @@ class SplitIdsOpKernel : public framework::OpKernel { void Compute(const framework::ExecutionContext &ctx) const override { auto place = ctx.GetPlace(); if (!platform::is_cpu_place(place)) { - PADDLE_THROW("SplitIds do not support GPU kernel"); + PADDLE_THROW(platform::errors::Unimplemented( + "SplitIds do not support GPU kernel")); } const auto ids_vars = ctx.MultiInputVar("Ids"); - PADDLE_ENFORCE_GT(ids_vars.size(), 0, "The number of Ids should > 0"); + PADDLE_ENFORCE_GT( + ids_vars.size(), 0, + platform::errors::InvalidArgument( + ids_vars.size(), 0, "The number of Ids expected > 0, but got %d", + ids_vars.size())); auto *ids_var = ids_vars[0]; if (ids_var->IsType()) { @@ -83,9 +88,6 @@ class SplitIdsOpKernel : public framework::OpKernel { } else if (ids_var->IsType()) { const auto *ids_selected_rows = ctx.Input("Ids"); auto &ids_dims = ids_selected_rows->value().dims(); - PADDLE_ENFORCE_EQ(ids_dims[0], - static_cast(ids_selected_rows->rows().size()), - ""); const T *ids_data = ids_selected_rows->value().data(); const auto &ids_rows = ids_selected_rows->rows(); auto outs = ctx.MultiOutput("Out"); @@ -114,9 +116,9 @@ class SplitIdsOpKernel : public framework::OpKernel { } } } else { - PADDLE_THROW( + PADDLE_THROW(platform::errors::InvalidArgument( "% should be LoDTensor or SelectedRows, but the received type is %s", - ctx.InputNames("Ids")[0], framework::ToTypeName(ids_var->Type())); + ctx.InputNames("Ids")[0], framework::ToTypeName(ids_var->Type()))); } } };