Browse Source

Removed unnecessary members

tempestpy_adaptions
Matthias Volk 6 years ago
parent
commit
2c1855f69a
  1. 4
      src/storm-dft/api/storm-dft.h
  2. 25
      src/storm-dft/modelchecker/dft/DFTModelChecker.cpp
  3. 25
      src/storm-dft/modelchecker/dft/DFTModelChecker.h

4
src/storm-dft/api/storm-dft.h

@ -80,7 +80,7 @@ namespace storm {
typename storm::modelchecker::DFTModelChecker<ValueType>::dft_results results = modelChecker.check(dft, properties, symred, allowModularisation, enableDC, 0.0); typename storm::modelchecker::DFTModelChecker<ValueType>::dft_results results = modelChecker.check(dft, properties, symred, allowModularisation, enableDC, 0.0);
if (printOutput) { if (printOutput) {
modelChecker.printTimings(); modelChecker.printTimings();
modelChecker.printResults();
modelChecker.printResults(results);
} }
return results; return results;
} }
@ -106,7 +106,7 @@ namespace storm {
typename storm::modelchecker::DFTModelChecker<ValueType>::dft_results results = modelChecker.check(dft, properties, symred, allowModularisation, enableDC, approximationError, approximationHeuristic); typename storm::modelchecker::DFTModelChecker<ValueType>::dft_results results = modelChecker.check(dft, properties, symred, allowModularisation, enableDC, approximationError, approximationHeuristic);
if (printOutput) { if (printOutput) {
modelChecker.printTimings(); modelChecker.printTimings();
modelChecker.printResults();
modelChecker.printResults(results);
} }
return results; return results;
} }

25
src/storm-dft/modelchecker/dft/DFTModelChecker.cpp

@ -18,9 +18,8 @@ namespace storm {
template<typename ValueType> template<typename ValueType>
typename DFTModelChecker<ValueType>::dft_results DFTModelChecker<ValueType>::check(storm::storage::DFT<ValueType> const& origDft, std::vector<std::shared_ptr<const storm::logic::Formula>> const& properties, bool symred, bool allowModularisation, bool enableDC, double approximationError, storm::builder::ApproximationHeuristic approximationHeuristic) { typename DFTModelChecker<ValueType>::dft_results DFTModelChecker<ValueType>::check(storm::storage::DFT<ValueType> const& origDft, std::vector<std::shared_ptr<const storm::logic::Formula>> const& properties, bool symred, bool allowModularisation, bool enableDC, double approximationError, storm::builder::ApproximationHeuristic approximationHeuristic) {
// Initialize
this->approximationError = approximationError;
totalTimer.start(); totalTimer.start();
dft_results results;
// Optimizing DFT // Optimizing DFT
storm::storage::DFT<ValueType> dft = origDft.optimize(); storm::storage::DFT<ValueType> dft = origDft.optimize();
@ -34,13 +33,13 @@ namespace storm {
// Model checking // Model checking
std::vector<ValueType> resultsValue = checkModel(model, properties); std::vector<ValueType> resultsValue = checkModel(model, properties);
for (ValueType result : resultsValue) { for (ValueType result : resultsValue) {
checkResults.push_back(result);
results.push_back(result);
} }
} else { } else {
checkResults = checkHelper(dft, properties, symred, allowModularisation, enableDC, approximationError, approximationHeuristic);
results = checkHelper(dft, properties, symred, allowModularisation, enableDC, approximationError, approximationHeuristic);
} }
totalTimer.stop(); totalTimer.stop();
return checkResults;
return results;
} }
template<typename ValueType> template<typename ValueType>
@ -442,22 +441,16 @@ namespace storm {
} }
template<typename ValueType> template<typename ValueType>
void DFTModelChecker<ValueType>::printResults(std::ostream& os) {
void DFTModelChecker<ValueType>::printResults(dft_results const& results, std::ostream& os) {
bool first = true; bool first = true;
os << "Result: ["; os << "Result: [";
for (auto result : checkResults) {
if (!first) {
os << ", ";
}
if (this->approximationError > 0.0) {
approximation_result resultApprox = boost::get<approximation_result>(result);
os << "(" << resultApprox.first << ", " << resultApprox.second << ")";
} else {
os << boost::get<ValueType>(result);
}
for (auto result : results) {
if (first) { if (first) {
first = false; first = false;
} else {
os << ", ";
} }
os << boost::apply_visitor(ResultOutputVisitor(), result);
} }
os << "]" << std::endl; os << "]" << std::endl;
} }

25
src/storm-dft/modelchecker/dft/DFTModelChecker.h

@ -22,6 +22,22 @@ namespace storm {
typedef std::vector<boost::variant<ValueType, approximation_result>> dft_results; typedef std::vector<boost::variant<ValueType, approximation_result>> dft_results;
typedef std::vector<std::shared_ptr<storm::logic::Formula const>> property_vector; typedef std::vector<std::shared_ptr<storm::logic::Formula const>> property_vector;
class ResultOutputVisitor : public boost::static_visitor<std::string> {
public:
std::string operator()(ValueType result) const {
std::stringstream stream;
stream << result;
return stream.str();
}
std::string operator()(std::pair<ValueType, ValueType> const& result) const {
std::stringstream stream;
stream << "(" << result.first << ", " << result.second << ")";
return stream.str();
}
};
/*! /*!
* Constructor. * Constructor.
*/ */
@ -53,9 +69,10 @@ namespace storm {
/*! /*!
* Print result to stream. * Print result to stream.
* *
* @param results List of results.
* @param os Output stream to write to. * @param os Output stream to write to.
*/ */
void printResults(std::ostream& os = std::cout);
void printResults(dft_results const& results, std::ostream& os = std::cout);
private: private:
@ -68,12 +85,6 @@ namespace storm {
storm::utility::Stopwatch modelCheckingTimer; storm::utility::Stopwatch modelCheckingTimer;
storm::utility::Stopwatch totalTimer; storm::utility::Stopwatch totalTimer;
// Model checking results
dft_results checkResults;
// Allowed error bound for approximation
double approximationError;
/*! /*!
* Internal helper for model checking a DFT. * Internal helper for model checking a DFT.
* *

Loading…
Cancel
Save