diff --git a/src/logic/FragmentSpecification.cpp b/src/logic/FragmentSpecification.cpp index c9dd90e24..bf63e5019 100644 --- a/src/logic/FragmentSpecification.cpp +++ b/src/logic/FragmentSpecification.cpp @@ -89,6 +89,7 @@ namespace storm { multiObjective.setMultiObjectiveFormulasAllowed(true); multiObjective.setProbabilityOperatorsAllowed(true); multiObjective.setUntilFormulasAllowed(true); + multiObjective.setGloballyFormulasAllowed(true); multiObjective.setReachabilityProbabilityFormulasAllowed(true); multiObjective.setRewardOperatorsAllowed(true); multiObjective.setReachabilityRewardFormulasAllowed(true); @@ -466,4 +467,4 @@ namespace storm { } } -} \ No newline at end of file +} diff --git a/src/modelchecker/multiobjective/helper/SparseMultiObjectiveModelCheckerHelper.cpp b/src/modelchecker/multiobjective/helper/SparseMultiObjectiveModelCheckerHelper.cpp index c57b41215..c29e112c0 100644 --- a/src/modelchecker/multiobjective/helper/SparseMultiObjectiveModelCheckerHelper.cpp +++ b/src/modelchecker/multiobjective/helper/SparseMultiObjectiveModelCheckerHelper.cpp @@ -94,7 +94,7 @@ namespace storm { } STORM_LOG_ASSERT(optimizingObjIndex < info.objectives.size(), "Numerical Query invoked but there are no objectives without threshold"); auto thresholdsAsPolytope = storm::storage::geometry::Polytope::create(thresholdConstraints); - WeightVector directionOfOptimizingObjective(info.objectives.size()); + WeightVector directionOfOptimizingObjective(info.objectives.size(), storm::utility::zero()); directionOfOptimizingObjective[optimizingObjIndex] = storm::utility::one(); // Try to find one valid solution @@ -187,6 +187,7 @@ namespace storm { storm::storage::TotalScheduler scheduler = weightedObjectivesChecker.getScheduler(); Point weightedObjectivesResult = storm::utility::vector::convertNumericVector(weightedObjectivesChecker.getInitialStateResultOfObjectives()); + STORM_LOG_DEBUG("Result with weighted objectives is " << storm::utility::vector::toString(weightedObjectivesResult)); // Insert the computed scheduler and check whether we have already seen it before auto schedulerInsertRes = schedulers.insert(std::make_pair(std::move(scheduler), paretoOptimalPoints.end())); diff --git a/src/storage/geometry/Halfspace.h b/src/storage/geometry/Halfspace.h index eb2bdbdcb..64c0cd8a0 100644 --- a/src/storage/geometry/Halfspace.h +++ b/src/storage/geometry/Halfspace.h @@ -73,7 +73,12 @@ namespace storm { } stream << std::setw(10) << numberStream.str(); } - stream << ") * x <= " << offset(); + stream << ") * x <= "; + if(numbersAsDouble) { + stream << storm::utility::convertNumber(offset()); + } else { + stream << offset(); + } return stream.str(); }