You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
27 lines
1.2 KiB
27 lines
1.2 KiB
#include <vector>
|
|
#include "storm-dft/storage/dft/DFT.h"
|
|
#include "storm-dft/modelchecker/dft/DFTASFChecker.h"
|
|
|
|
namespace storm {
|
|
namespace dft {
|
|
namespace utility {
|
|
|
|
template<typename ValueType>
|
|
class FDEPConflictFinder {
|
|
public:
|
|
|
|
/*!
|
|
* Get a vector of index pairs of FDEPs in the DFT which are conflicting. Two FDEPs are conflicting if
|
|
* their simultaneous triggering may cause unresolvable non-deterministic behavior.
|
|
*
|
|
* @param dft The DFT.
|
|
* @param useSMT If set, an SMT solver is used to refine the conflict set.
|
|
* @param timeout Timeout for each SMT query in seconds, defaults to 10 seconds.
|
|
* @return A vector of pairs of indices. The indices in a pair refer to FDEPs which are conflicting.
|
|
*/
|
|
static std::vector<std::pair<uint64_t, uint64_t>> getDependencyConflicts(storm::storage::DFT<ValueType> const& dft, bool useSMT = false,
|
|
uint_fast64_t timeout = 10);
|
|
};
|
|
}
|
|
}
|
|
}
|