From 8cb54ede8ce802b7b742181984a90d8972fbf2ce Mon Sep 17 00:00:00 2001 From: Chen Weihang Date: Wed, 4 Sep 2019 17:48:25 +0800 Subject: [PATCH] Add user-friendly error message in optimizer ops to give a hint about the position sensitive problem of run(startup_program) (#19605) * add extra error message hint in optimizer ops * polish format & delete useless change, test=develop * extract init judue from shape compare, test=develop --- paddle/fluid/operators/optimizers/adadelta_op.cc | 5 +++++ paddle/fluid/operators/optimizers/adagrad_op.cc | 5 +++++ paddle/fluid/operators/optimizers/adam_op.cc | 5 +++++ paddle/fluid/operators/optimizers/adamax_op.cc | 5 +++++ .../fluid/operators/optimizers/decayed_adagrad_op.cc | 5 +++++ paddle/fluid/operators/optimizers/ftrl_op.cc | 5 +++++ paddle/fluid/operators/optimizers/momentum_op.h | 11 +++++++++-- paddle/fluid/operators/optimizers/sgd_op.cc | 5 +++++ 8 files changed, 44 insertions(+), 2 deletions(-) diff --git a/paddle/fluid/operators/optimizers/adadelta_op.cc b/paddle/fluid/operators/optimizers/adadelta_op.cc index dd365629fc..01c0f1bb2d 100644 --- a/paddle/fluid/operators/optimizers/adadelta_op.cc +++ b/paddle/fluid/operators/optimizers/adadelta_op.cc @@ -56,6 +56,11 @@ class AdadeltaOp : public framework::OperatorWithKernel { PADDLE_ENFORCE_EQ( param_dim, ctx->GetInputDim("Grad"), "param and grad input of AdadeltaOp should have same dimension"); + PADDLE_ENFORCE_NE(framework::product(ctx->GetInputDim("AvgSquaredGrad")), 0, + "Maybe the Input variable AvgSquaredGrad has not " + "been initialized. You may need to confirm if you put " + "exe.run(startup_program) after optimizer.minimize " + "function."); PADDLE_ENFORCE_EQ(param_dim, ctx->GetInputDim("AvgSquaredGrad"), "Param and AvgSquaredGrad input of AdadeltaOp " "should have same dimension"); diff --git a/paddle/fluid/operators/optimizers/adagrad_op.cc b/paddle/fluid/operators/optimizers/adagrad_op.cc index bd1bb98e63..0310fe2eba 100644 --- a/paddle/fluid/operators/optimizers/adagrad_op.cc +++ b/paddle/fluid/operators/optimizers/adagrad_op.cc @@ -44,6 +44,11 @@ class AdagradOp : public framework::OperatorWithKernel { "Output(MomentOut) of AdagradOp should not be null."); auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, "LearningRate should have one element"); auto param_dims = ctx->GetInputDim("Param"); diff --git a/paddle/fluid/operators/optimizers/adam_op.cc b/paddle/fluid/operators/optimizers/adam_op.cc index dd347aa0af..fc851e56cb 100644 --- a/paddle/fluid/operators/optimizers/adam_op.cc +++ b/paddle/fluid/operators/optimizers/adam_op.cc @@ -43,6 +43,11 @@ void AdamOp::InferShape(framework::InferShapeContext* ctx) const { "Output(Moment2Out) of AdamOp should not be null."); auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, "Learning rate should have 1 dimension"); auto beta1_pow_dims = ctx->GetInputDim("Beta1Pow"); diff --git a/paddle/fluid/operators/optimizers/adamax_op.cc b/paddle/fluid/operators/optimizers/adamax_op.cc index aef1fc972c..a015290623 100644 --- a/paddle/fluid/operators/optimizers/adamax_op.cc +++ b/paddle/fluid/operators/optimizers/adamax_op.cc @@ -54,6 +54,11 @@ class AdamaxOp : public framework::OperatorWithKernel { "Output(InfNormOut) of AdamaxOp should not be null."); auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, "Learning rate should have 1 dimension"); auto beta1_pow_dims = ctx->GetInputDim("Beta1Pow"); diff --git a/paddle/fluid/operators/optimizers/decayed_adagrad_op.cc b/paddle/fluid/operators/optimizers/decayed_adagrad_op.cc index 07899278f9..b44a84ccf7 100644 --- a/paddle/fluid/operators/optimizers/decayed_adagrad_op.cc +++ b/paddle/fluid/operators/optimizers/decayed_adagrad_op.cc @@ -49,6 +49,11 @@ class DecayedAdagradOp : public framework::OperatorWithKernel { "Output(MomentOut) of DecayedAdagradOp should not be null."); auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, "LearningRate should have one element"); auto param_dims = ctx->GetInputDim("Param"); diff --git a/paddle/fluid/operators/optimizers/ftrl_op.cc b/paddle/fluid/operators/optimizers/ftrl_op.cc index c1a4f5790b..98b7117562 100644 --- a/paddle/fluid/operators/optimizers/ftrl_op.cc +++ b/paddle/fluid/operators/optimizers/ftrl_op.cc @@ -57,6 +57,11 @@ class FTRLOp : public framework::OperatorWithKernel { "Two input of FTRL Op's dimension must be same."); auto lr_dim = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dim), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dim), 1, "Learning Rate should be a scalar."); diff --git a/paddle/fluid/operators/optimizers/momentum_op.h b/paddle/fluid/operators/optimizers/momentum_op.h index 29a2ae6755..f56f5b6bbe 100644 --- a/paddle/fluid/operators/optimizers/momentum_op.h +++ b/paddle/fluid/operators/optimizers/momentum_op.h @@ -54,6 +54,15 @@ class MomentumOp : public framework::OperatorWithKernel { PADDLE_ENFORCE(ctx->HasOutput("VelocityOut"), "Output(VelocityOut) of Momentum should not be null."); + auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); + PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, + "Learning_rate should be a scalar"); + auto param_dim = ctx->GetInputDim("Param"); if (ctx->GetInputsVarType("Grad")[0] == framework::proto::VarType::LOD_TENSOR) { @@ -64,8 +73,6 @@ class MomentumOp : public framework::OperatorWithKernel { param_dim, ctx->GetInputDim("Velocity"), "Param and Velocity of MomentumOp should have the same dimension."); } - PADDLE_ENFORCE_EQ(framework::product(ctx->GetInputDim("LearningRate")), 1, - "Learning_rate should be a scalar"); ctx->SetOutputDim("ParamOut", param_dim); ctx->SetOutputDim("VelocityOut", param_dim); diff --git a/paddle/fluid/operators/optimizers/sgd_op.cc b/paddle/fluid/operators/optimizers/sgd_op.cc index 62163e45c8..9ccf3d9364 100644 --- a/paddle/fluid/operators/optimizers/sgd_op.cc +++ b/paddle/fluid/operators/optimizers/sgd_op.cc @@ -32,6 +32,11 @@ class SGDOp : public framework::OperatorWithKernel { "Output(ParamOut) of SGDOp should not be null."); auto lr_dims = ctx->GetInputDim("LearningRate"); + PADDLE_ENFORCE_NE(framework::product(lr_dims), 0, + "Maybe the Input variable LearningRate has not " + "been initialized. You may need to confirm " + "if you put exe.run(startup_program) " + "after optimizer.minimize function."); PADDLE_ENFORCE_EQ(framework::product(lr_dims), 1, "Learning rate should have 1 element"); auto param_dim = ctx->GetInputDim("Param"); -- GitLab