|
|
@ -26,7 +26,7 @@ namespace storm { |
|
|
|
namespace utility { |
|
|
|
namespace graph { |
|
|
|
|
|
|
|
template<typename T> |
|
|
|
template<typename T> |
|
|
|
storm::storage::BitVector getReachableStates(storm::storage::SparseMatrix<T> const& transitionMatrix, storm::storage::BitVector const& initialStates, storm::storage::BitVector const& constraintStates, storm::storage::BitVector const& targetStates) { |
|
|
|
storm::storage::BitVector reachableStates(initialStates); |
|
|
|
|
|
|
@ -59,7 +59,7 @@ namespace storm { |
|
|
|
return reachableStates; |
|
|
|
} |
|
|
|
|
|
|
|
template<typename T> |
|
|
|
template<typename T> |
|
|
|
std::vector<std::size_t> getDistances(storm::storage::SparseMatrix<T> const& transitionMatrix, storm::storage::BitVector const& initialStates) { |
|
|
|
std::vector<std::size_t> distances(transitionMatrix.getRowGroupCount()); |
|
|
|
|
|
|
@ -90,7 +90,7 @@ namespace storm { |
|
|
|
return distances; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProbGreater0(storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates, bool useStepBound, uint_fast64_t maximalSteps) { |
|
|
|
// Prepare the resulting bit vector.
|
|
|
|
uint_fast64_t numberOfStates = phiStates.size(); |
|
|
@ -146,14 +146,14 @@ namespace storm { |
|
|
|
return statesWithProbabilityGreater0; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb1(storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates, storm::storage::BitVector const& statesWithProbabilityGreater0) { |
|
|
|
storm::storage::BitVector statesWithProbability1 = performProbGreater0(backwardTransitions, ~psiStates, ~statesWithProbabilityGreater0); |
|
|
|
statesWithProbability1.complement(); |
|
|
|
return statesWithProbability1; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb1(storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
storm::storage::BitVector statesWithProbabilityGreater0 = performProbGreater0(backwardTransitions, phiStates, psiStates); |
|
|
|
storm::storage::BitVector statesWithProbability1 = performProbGreater0(backwardTransitions, ~psiStates, ~(statesWithProbabilityGreater0)); |
|
|
@ -161,7 +161,7 @@ namespace storm { |
|
|
|
return statesWithProbability1; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> performProb01(storm::models::sparse::DeterministicModel<T> const& model, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> result; |
|
|
|
storm::storage::SparseMatrix<T> backwardTransitions = model.getBackwardTransitions(); |
|
|
@ -171,7 +171,7 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> performProb01(storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> result; |
|
|
|
result.first = performProbGreater0(backwardTransitions, phiStates, psiStates); |
|
|
@ -180,7 +180,7 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProbGreater0(storm::models::symbolic::Model<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates, boost::optional<uint_fast64_t> const& stepBound) { |
|
|
|
// Initialize environment for backward search.
|
|
|
|
storm::dd::DdManager<Type> const& manager = model.getManager(); |
|
|
@ -205,20 +205,20 @@ namespace storm { |
|
|
|
return statesWithProbabilityGreater0; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb1(storm::models::symbolic::Model<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates, storm::dd::Bdd<Type> const& statesWithProbabilityGreater0) { |
|
|
|
storm::dd::Bdd<Type> statesWithProbability1 = performProbGreater0(model, transitionMatrix, !psiStates && model.getReachableStates(), !statesWithProbabilityGreater0 && model.getReachableStates()); |
|
|
|
statesWithProbability1 = !statesWithProbability1 && model.getReachableStates(); |
|
|
|
return statesWithProbability1; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb1(storm::models::symbolic::Model<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
storm::dd::Bdd<Type> statesWithProbabilityGreater0 = performProbGreater0(model, transitionMatrix, phiStates, psiStates); |
|
|
|
return performProb1(model, transitionMatrix, phiStates, psiStates, statesWithProbabilityGreater0); |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
std::pair<storm::dd::Bdd<Type>, storm::dd::Bdd<Type>> performProb01(storm::models::symbolic::DeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
std::pair<storm::dd::Bdd<Type>, storm::dd::Bdd<Type>> result; |
|
|
|
storm::dd::Bdd<Type> transitionMatrix = model.getTransitionMatrix().notZero(); |
|
|
@ -228,7 +228,7 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
std::pair<storm::dd::Bdd<Type>, storm::dd::Bdd<Type>> performProb01(storm::models::symbolic::Model<Type> const& model, storm::dd::Add<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
std::pair<storm::dd::Bdd<Type>, storm::dd::Bdd<Type>> result; |
|
|
|
storm::dd::Bdd<Type> transitionMatrixBdd = transitionMatrix.notZero(); |
|
|
@ -238,7 +238,7 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProbGreater0E(storm::storage::SparseMatrix<T> const& transitionMatrix, std::vector<uint_fast64_t> const& nondeterministicChoiceIndices, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates, bool useStepBound, uint_fast64_t maximalSteps) { |
|
|
|
size_t numberOfStates = phiStates.size(); |
|
|
|
|
|
|
@ -301,12 +301,12 @@ namespace storm { |
|
|
|
return statesWithProbability0; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb0A(storm::models::sparse::NondeterministicModel<T> const& model, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
return performProb0A(model.getTransitionMatrix(), model.getNondeterministicChoiceIndices(), backwardTransitions, phiStates, psiStates); |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb1E(storm::storage::SparseMatrix<T> const& transitionMatrix, std::vector<uint_fast64_t> const& nondeterministicChoiceIndices, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
size_t numberOfStates = phiStates.size(); |
|
|
|
|
|
|
@ -364,7 +364,7 @@ namespace storm { |
|
|
|
return currentStates; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb1E(storm::models::sparse::NondeterministicModel<T> const& model, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
return performProb1E(model.getTransitionMatrix(), model.getNondeterministicChoiceIndices(), backwardTransitions, phiStates, psiStates); |
|
|
|
} |
|
|
@ -378,12 +378,12 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> performProb01Max(storm::models::sparse::NondeterministicModel<T> const& model, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
return performProb01Max(model.getTransitionMatrix(), model.getTransitionMatrix().getRowGroupIndices(), model.getBackwardTransitions(), phiStates, psiStates); |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProbGreater0A(storm::storage::SparseMatrix<T> const& transitionMatrix, std::vector<uint_fast64_t> const& nondeterministicChoiceIndices, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates, bool useStepBound, uint_fast64_t maximalSteps) { |
|
|
|
size_t numberOfStates = phiStates.size(); |
|
|
|
|
|
|
@ -460,7 +460,7 @@ namespace storm { |
|
|
|
return statesWithProbabilityGreater0; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb0E(storm::models::sparse::NondeterministicModel<T> const& model, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
storm::storage::BitVector statesWithProbability0 = performProbGreater0A(model.getTransitionMatrix(), model.getNondeterministicChoiceIndices(), backwardTransitions, phiStates, psiStates); |
|
|
|
statesWithProbability0.complement(); |
|
|
@ -474,7 +474,7 @@ namespace storm { |
|
|
|
return statesWithProbability0; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
storm::storage::BitVector performProb1A( storm::storage::SparseMatrix<T> const& transitionMatrix, std::vector<uint_fast64_t> const& nondeterministicChoiceIndices, storm::storage::SparseMatrix<T> const& backwardTransitions, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
size_t numberOfStates = phiStates.size(); |
|
|
|
|
|
|
@ -549,12 +549,12 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::pair<storm::storage::BitVector, storm::storage::BitVector> performProb01Min(storm::models::sparse::NondeterministicModel<T> const& model, storm::storage::BitVector const& phiStates, storm::storage::BitVector const& psiStates) { |
|
|
|
return performProb01Min(model.getTransitionMatrix(), model.getTransitionMatrix().getRowGroupIndices(), model.getBackwardTransitions(), phiStates, psiStates); |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProbGreater0E(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
// Initialize environment for backward search.
|
|
|
|
storm::dd::DdManager<Type> const& manager = model.getManager(); |
|
|
@ -575,12 +575,12 @@ namespace storm { |
|
|
|
return statesWithProbabilityGreater0E; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb0A(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
return !performProbGreater0E(model, transitionMatrix, phiStates, psiStates) && model.getReachableStates(); |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProbGreater0A(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
// Initialize environment for backward search.
|
|
|
|
storm::dd::DdManager<Type> const& manager = model.getManager(); |
|
|
@ -602,12 +602,12 @@ namespace storm { |
|
|
|
return statesWithProbabilityGreater0A; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb0E(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates) { |
|
|
|
return !performProbGreater0A(model, transitionMatrix, phiStates, psiStates) && model.getReachableStates(); |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb1A(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates, storm::dd::Bdd<Type> const& statesWithProbabilityGreater0A) { |
|
|
|
// Initialize environment for backward search.
|
|
|
|
storm::dd::DdManager<Type> const& manager = model.getManager(); |
|
|
@ -629,7 +629,7 @@ namespace storm { |
|
|
|
return statesWithProbability1A; |
|
|
|
} |
|
|
|
|
|
|
|
template <storm::dd::DdType Type> |
|
|
|
template <storm::dd::DdType Type> |
|
|
|
storm::dd::Bdd<Type> performProb1E(storm::models::symbolic::NondeterministicModel<Type> const& model, storm::dd::Bdd<Type> const& transitionMatrix, storm::dd::Bdd<Type> const& phiStates, storm::dd::Bdd<Type> const& psiStates, storm::dd::Bdd<Type> const& statesWithProbabilityGreater0E) { |
|
|
|
// Initialize environment for backward search.
|
|
|
|
storm::dd::DdManager<Type> const& manager = model.getManager(); |
|
|
@ -688,7 +688,7 @@ namespace storm { |
|
|
|
return result; |
|
|
|
} |
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::vector<uint_fast64_t> getTopologicalSort(storm::storage::SparseMatrix<T> const& matrix) { |
|
|
|
if (matrix.getRowCount() != matrix.getColumnCount()) { |
|
|
|
LOG4CPLUS_ERROR(logger, "Provided matrix is required to be square."); |
|
|
@ -725,10 +725,10 @@ namespace storm { |
|
|
|
for (; successorIterator != matrix.end(currentState); ++successorIterator) { |
|
|
|
if (!visitedStates.get(successorIterator->getColumn())) { |
|
|
|
// Put unvisited successor on top of our recursion stack and remember that.
|
|
|
|
recursionStack.push_back(successorIterator->getColumn()); |
|
|
|
recursionStack.push_back(successorIterator->getColumn()); |
|
|
|
|
|
|
|
// Also, put initial value for iterator on corresponding recursion stack.
|
|
|
|
iteratorRecursionStack.push_back(matrix.begin(successorIterator->getColumn())); |
|
|
|
iteratorRecursionStack.push_back(matrix.begin(successorIterator->getColumn())); |
|
|
|
|
|
|
|
goto recursionStepForward; |
|
|
|
} |
|
|
@ -759,7 +759,7 @@ namespace storm { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
template <typename T> |
|
|
|
template <typename T> |
|
|
|
std::pair<std::vector<T>, std::vector<uint_fast64_t>> performDijkstra(storm::models::sparse::Model<T> const& model, |
|
|
|
storm::storage::SparseMatrix<T> const& transitions, |
|
|
|
storm::storage::BitVector const& startingStates, |
|
|
@ -767,7 +767,7 @@ namespace storm { |
|
|
|
|
|
|
|
LOG4CPLUS_INFO(logger, "Performing Dijkstra search."); |
|
|
|
|
|
|
|
const uint_fast64_t noPredecessorValue = storm::utility::zero<uint_fast64_t>(); |
|
|
|
const uint_fast64_t noPredecessorValue = storm::utility::zero<uint_fast64_t>(); |
|
|
|
std::vector<T> probabilities(model.getNumberOfStates(), storm::utility::zero<T>()); |
|
|
|
std::vector<uint_fast64_t> predecessors(model.getNumberOfStates(), noPredecessorValue); |
|
|
|
|
|
|
|