From 2b57211a98f8e23e93a94dc25b9ca9d03e7932f0 Mon Sep 17 00:00:00 2001 From: Tim Quatmann Date: Tue, 24 Mar 2020 14:51:48 +0100 Subject: [PATCH] cli: Making sure that the warning for unsupported model checking queries is only displayed in the main binary. --- src/storm-cli-utilities/cli.cpp | 4 +- src/storm-cli-utilities/model-handling.h | 51 ++++++++++++++---------- 2 files changed, 32 insertions(+), 23 deletions(-) diff --git a/src/storm-cli-utilities/cli.cpp b/src/storm-cli-utilities/cli.cpp index 869fc2942..12d5771bd 100644 --- a/src/storm-cli-utilities/cli.cpp +++ b/src/storm-cli-utilities/cli.cpp @@ -256,9 +256,11 @@ namespace storm { // Preprocess the symbolic input std::tie(symbolicInput, mpi) = preprocessSymbolicInput(symbolicInput); + STORM_LOG_WARN_COND(mpi.isCompatible, "The model checking query does not seem to be supported for the selected engine. Storm will try to solve the query, but you will most likely get an error for at least one of the provided properties."); + // Export symbolic input (if requested) exportSymbolicInput(symbolicInput); - + #ifdef STORM_HAVE_CARL switch (mpi.verificationValueType) { case ModelProcessingInformation::ValueType::Parametric: diff --git a/src/storm-cli-utilities/model-handling.h b/src/storm-cli-utilities/model-handling.h index 69af92244..0e4fe4812 100644 --- a/src/storm-cli-utilities/model-handling.h +++ b/src/storm-cli-utilities/model-handling.h @@ -173,6 +173,10 @@ namespace storm { // The environment used during model checking storm::Environment env; + + // A flag which is set to true, if the settings were detected to be compatible. + // If this is false, it could be that the query can not be handled. + bool isCompatible; }; void getModelProcessingInformationPortfolio(SymbolicInput const& input, ModelProcessingInformation& mpi) { @@ -261,30 +265,33 @@ namespace storm { } // Check whether these settings are compatible with the provided input. - bool incompatibleSettings = false; if (input.model) { - switch (mpi.verificationValueType) { - case ModelProcessingInformation::ValueType::Parametric: - incompatibleSettings = !storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); - break; - case ModelProcessingInformation::ValueType::Exact: - incompatibleSettings = !storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); - break; - case ModelProcessingInformation::ValueType::FinitePrecision: - incompatibleSettings = !storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); - break; - } - } - if (incompatibleSettings) { - if (usePortfolio) { - bool useExact = mpi.verificationValueType != ModelProcessingInformation::ValueType::FinitePrecision; - STORM_LOG_WARN("The settings picked by the portfolio engine (engine=" << mpi.engine << ", bisim=" << mpi.applyBisimulation << ", exact=" << useExact << ") are incompatible with this model. Falling back to default settings."); - mpi.engine = storm::utility::Engine::Sparse; - mpi.applyBisimulation = false; - mpi.verificationValueType = originalVerificationValueType; - } else { - STORM_LOG_WARN("The model checking query does not seem to be supported for the selected engine. Storm will try to solve the query, but you will most likely get an error for at least one of the provided properties."); + auto checkCompatibleSettings = [&mpi, &input] { + switch (mpi.verificationValueType) { + case ModelProcessingInformation::ValueType::Parametric: + return storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); + case ModelProcessingInformation::ValueType::Exact: + return storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); + break; + case ModelProcessingInformation::ValueType::FinitePrecision: + return storm::utility::canHandle(mpi.engine, input.preprocessedProperties.is_initialized() ? input.preprocessedProperties.get() : input.properties, input.model.get()); + } + }; + mpi.isCompatible = checkCompatibleSettings(); + if (!mpi.isCompatible) { + if (usePortfolio) { + bool useExact = mpi.verificationValueType != ModelProcessingInformation::ValueType::FinitePrecision; + STORM_LOG_WARN("The settings picked by the portfolio engine (engine=" << mpi.engine << ", bisim=" << mpi.applyBisimulation << ", exact=" << useExact << ") are incompatible with this model. Falling back to default settings."); + mpi.engine = storm::utility::Engine::Sparse; + mpi.applyBisimulation = false; + mpi.verificationValueType = originalVerificationValueType; + // Retry check with new settings + mpi.isCompatible = checkCompatibleSettings(); + } } + } else { + // If there is no input model, nothing has to be done, actually + mpi.isCompatible = true; } // Set whether a transformation to jani is required or necessary