Commit c3608b9b authored by Sébastien Villemot's avatar Sébastien Villemot
Browse files

Preprocessor: fix crash when mean or stderr of an estimated parameter is...

Preprocessor: fix crash when mean or stderr of an estimated parameter is specified as an expression instead of a plain value (bug introduced in 28d30d9a)
parent 9cf9df4b
......@@ -362,12 +362,20 @@ EstimatedParamsStatement::checkPass(ModFileStructure &mod_file_struct)
if (it->name == "dsge_prior_weight")
mod_file_struct.dsge_prior_weight_in_estimated_params = true;
// Handle case of degenerate beta prior
if (it->prior == "1") //BETA_PDF is associated with "1" in DynareBison.yy
if (dynamic_cast<NumConstNode *>(it->mean)->isNumConstNodeEqualTo(0.5) &&
dynamic_cast<NumConstNode *>(it->std)->isNumConstNodeEqualTo(0.5))
try
{
cerr << "ERROR: The prior density is not defined for the beta distribution when the mean = standard deviation = 0.5." << endl;
exit(EXIT_FAILURE);
if (it->mean->eval(eval_context_type()) == 0.5 &&
it->std->eval(eval_context_type()) == 0.5)
{
cerr << "ERROR: The prior density is not defined for the beta distribution when the mean = standard deviation = 0.5." << endl;
exit(EXIT_FAILURE);
}
}
catch (ExprNode::EvalException &e)
{
// We don't have enough information to compute the numerical value, skip the test
}
}
}
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment