Browse Source

storm-conv: Added an option to replace variables without assignment by constants.

tempestpy_adaptions
Tim Quatmann 5 years ago
parent
commit
9128318ced
  1. 6
      src/storm-conv/api/storm-conv.cpp
  2. 4
      src/storm-conv/converter/options/JaniConversionOptions.cpp
  3. 4
      src/storm-conv/converter/options/JaniConversionOptions.h
  4. 6
      src/storm-conv/settings/modules/JaniExportSettings.cpp
  5. 3
      src/storm-conv/settings/modules/JaniExportSettings.h

6
src/storm-conv/api/storm-conv.cpp

@ -18,8 +18,12 @@ namespace storm {
void transformJani(storm::jani::Model& janiModel, std::vector<storm::jani::Property>& properties, storm::converter::JaniConversionOptions const& options) { void transformJani(storm::jani::Model& janiModel, std::vector<storm::jani::Property>& properties, storm::converter::JaniConversionOptions const& options) {
if (options.replaceUnassignedVariablesWithConstants) {
janiModel.replaceUnassignedVariablesWithConstants();
}
if (options.substituteConstants) { if (options.substituteConstants) {
janiModel = janiModel.substituteConstants();
janiModel.substituteConstantsInPlace();
} }
if (options.localVars) { if (options.localVars) {

4
src/storm-conv/converter/options/JaniConversionOptions.cpp

@ -3,11 +3,11 @@
namespace storm { namespace storm {
namespace converter { namespace converter {
JaniConversionOptions::JaniConversionOptions() : edgeAssignments(false), flatten(false), substituteConstants(true), localVars(false), globalVars(false), allowedModelFeatures(storm::jani::getAllKnownModelFeatures()), addPropertyConstants(true) {
JaniConversionOptions::JaniConversionOptions() : edgeAssignments(false), flatten(false), substituteConstants(true), localVars(false), globalVars(false), allowedModelFeatures(storm::jani::getAllKnownModelFeatures()), addPropertyConstants(true), replaceUnassignedVariablesWithConstants(false) {
// Intentionally left empty // Intentionally left empty
} }
JaniConversionOptions::JaniConversionOptions(storm::settings::modules::JaniExportSettings const& settings) : locationVariables(settings.getLocationVariables()), edgeAssignments(settings.isAllowEdgeAssignmentsSet()), flatten(settings.isExportFlattenedSet()), substituteConstants(true), localVars(settings.isLocalVarsSet()), globalVars(settings.isGlobalVarsSet()), allowedModelFeatures(storm::jani::getAllKnownModelFeatures()), addPropertyConstants(true) {
JaniConversionOptions::JaniConversionOptions(storm::settings::modules::JaniExportSettings const& settings) : locationVariables(settings.getLocationVariables()), edgeAssignments(settings.isAllowEdgeAssignmentsSet()), flatten(settings.isExportFlattenedSet()), substituteConstants(true), localVars(settings.isLocalVarsSet()), globalVars(settings.isGlobalVarsSet()), allowedModelFeatures(storm::jani::getAllKnownModelFeatures()), addPropertyConstants(true), replaceUnassignedVariablesWithConstants(settings.isReplaceUnassignedVariablesWithConstantsSet()) {
if (settings.isEliminateFunctionsSet()) { if (settings.isEliminateFunctionsSet()) {
allowedModelFeatures.remove(storm::jani::ModelFeature::Functions); allowedModelFeatures.remove(storm::jani::ModelFeature::Functions);
} }

4
src/storm-conv/converter/options/JaniConversionOptions.h

@ -39,9 +39,11 @@ namespace storm {
/// Only these model features are allowed in the output /// Only these model features are allowed in the output
storm::jani::ModelFeatures allowedModelFeatures; storm::jani::ModelFeatures allowedModelFeatures;
// Add constants that are defined in the properties to the model
/// Add constants that are defined in the properties to the model
bool addPropertyConstants; bool addPropertyConstants;
/// If set, local and global variables that are (a) not assigned to some value and (b) have a known initial value are replaced by constants.
bool replaceUnassignedVariablesWithConstants;
}; };
} }
} }

6
src/storm-conv/settings/modules/JaniExportSettings.cpp

@ -22,6 +22,7 @@ namespace storm {
const std::string JaniExportSettings::compactJsonOptionName = "compactjson"; const std::string JaniExportSettings::compactJsonOptionName = "compactjson";
const std::string JaniExportSettings::eliminateArraysOptionName = "remove-arrays"; const std::string JaniExportSettings::eliminateArraysOptionName = "remove-arrays";
const std::string JaniExportSettings::eliminateFunctionsOptionName = "remove-functions"; const std::string JaniExportSettings::eliminateFunctionsOptionName = "remove-functions";
const std::string JaniExportSettings::replaceUnassignedVariablesWithConstantsOptionName = "replace-unassigned-vars";
JaniExportSettings::JaniExportSettings() : ModuleSettings(moduleName) { JaniExportSettings::JaniExportSettings() : ModuleSettings(moduleName) {
this->addOption(storm::settings::OptionBuilder(moduleName, locationVariablesOptionName, true, "Variables to export in the location").addArgument(storm::settings::ArgumentBuilder::createStringArgument("variables", "A comma separated list of automaton and local variable names seperated by a dot, e.g. A.x,B.y.").setDefaultValueString("").build()).build()); this->addOption(storm::settings::OptionBuilder(moduleName, locationVariablesOptionName, true, "Variables to export in the location").addArgument(storm::settings::ArgumentBuilder::createStringArgument("variables", "A comma separated list of automaton and local variable names seperated by a dot, e.g. A.x,B.y.").setDefaultValueString("").build()).build());
@ -32,6 +33,7 @@ namespace storm {
this->addOption(storm::settings::OptionBuilder(moduleName, compactJsonOptionName, false, "If set, the size of the resulting jani file will be reduced at the cost of (human-)readability.").build()); this->addOption(storm::settings::OptionBuilder(moduleName, compactJsonOptionName, false, "If set, the size of the resulting jani file will be reduced at the cost of (human-)readability.").build());
this->addOption(storm::settings::OptionBuilder(moduleName, eliminateArraysOptionName, false, "If set, transforms the model such that array variables/expressions are eliminated.").build()); this->addOption(storm::settings::OptionBuilder(moduleName, eliminateArraysOptionName, false, "If set, transforms the model such that array variables/expressions are eliminated.").build());
this->addOption(storm::settings::OptionBuilder(moduleName, eliminateFunctionsOptionName, false, "If set, transforms the model such that functions are eliminated.").build()); this->addOption(storm::settings::OptionBuilder(moduleName, eliminateFunctionsOptionName, false, "If set, transforms the model such that functions are eliminated.").build());
this->addOption(storm::settings::OptionBuilder(moduleName, replaceUnassignedVariablesWithConstantsOptionName, false, "If set, local and global variables that are (a) not assigned to some value and (b) have a known initial value are replaced by constants.").build());
} }
bool JaniExportSettings::isAllowEdgeAssignmentsSet() const { bool JaniExportSettings::isAllowEdgeAssignmentsSet() const {
@ -82,6 +84,10 @@ namespace storm {
return this->getOption(eliminateFunctionsOptionName).getHasOptionBeenSet(); return this->getOption(eliminateFunctionsOptionName).getHasOptionBeenSet();
} }
bool JaniExportSettings::isReplaceUnassignedVariablesWithConstantsSet() const {
return this->getOption(replaceUnassignedVariablesWithConstantsOptionName).getHasOptionBeenSet();
}
void JaniExportSettings::finalize() { void JaniExportSettings::finalize() {
} }

3
src/storm-conv/settings/modules/JaniExportSettings.h

@ -30,6 +30,8 @@ namespace storm {
bool isEliminateFunctionsSet() const; bool isEliminateFunctionsSet() const;
bool isReplaceUnassignedVariablesWithConstantsSet() const;
std::vector<std::pair<std::string, std::string>> getLocationVariables() const; std::vector<std::pair<std::string, std::string>> getLocationVariables() const;
bool check() const override; bool check() const override;
@ -46,6 +48,7 @@ namespace storm {
static const std::string compactJsonOptionName; static const std::string compactJsonOptionName;
static const std::string eliminateArraysOptionName; static const std::string eliminateArraysOptionName;
static const std::string eliminateFunctionsOptionName; static const std::string eliminateFunctionsOptionName;
static const std::string replaceUnassignedVariablesWithConstantsOptionName;
}; };
} }

Loading…
Cancel
Save