1#include "storm-config.h"
17 double probabilityAtTimeboundOne;
19 std::vector<double> birnbaum;
20 std::vector<double> CIF;
21 std::vector<double> DIF;
22 std::vector<double> RAW;
23 std::vector<double> RRW;
25 friend std::ostream &
operator<<(std::ostream &os, SftTestData
const &data) {
26 auto printVector = [&os](std::vector<double>
const &arr) {
28 for (
auto const &i : arr) {
37 os <<
"{\"" << data.testname <<
'"';
38 os <<
", \"" << data.filepath <<
'"';
39 os <<
", \"" << data.bddHash <<
'"';
40 os <<
", " << data.probabilityAtTimeboundOne;
41 os <<
", " << data.mttf;
42 printVector(data.birnbaum);
43 printVector(data.CIF);
44 printVector(data.DIF);
45 printVector(data.RAW);
46 printVector(data.RRW);
52class SftBddTest :
public testing::TestWithParam<SftTestData> {
54 void SetUp()
override {
55 auto const ¶m{TestWithParam::GetParam()};
56 auto dft{storm::dft::api::loadDFTGalileoFile<double>(param.filepath)};
57 checker = std::make_shared<storm::dft::modelchecker::SFTBDDChecker>(dft);
60 std::shared_ptr<storm::dft::modelchecker::SFTBDDChecker> checker;
63TEST_P(SftBddTest, bddHash) {
64 auto const ¶m{TestWithParam::GetParam()};
65 EXPECT_EQ(checker->getTransformator()->transformTopLevel().GetShaHash(), param.bddHash);
68TEST_P(SftBddTest, ProbabilityAtTimeOne) {
69 auto const ¶m{TestWithParam::GetParam()};
70 EXPECT_NEAR(checker->getProbabilityAtTimebound(1), param.probabilityAtTimeboundOne, 1e-6);
73TEST_P(SftBddTest, MTTF) {
74 auto const ¶m{TestWithParam::GetParam()};
79template<
typename T1,
typename T2>
80void expectVectorNear(T1
const &v1, T2
const &v2,
double const precision = 1e-6) {
81 ASSERT_EQ(v1.size(), v2.size());
82 for (
size_t i{0};
i < v1.size(); ++
i) {
83 if (!std::isinf(v1[i])) {
84 EXPECT_NEAR(v1[i], v2[i], precision);
86 EXPECT_EQ(v1[i], v2[i]);
91TEST_P(SftBddTest, Birnbaum) {
92 auto const ¶m{TestWithParam::GetParam()};
93 expectVectorNear(checker->getAllBirnbaumFactorsAtTimebound(1), param.birnbaum);
96TEST_P(SftBddTest, CIF) {
97 auto const ¶m{TestWithParam::GetParam()};
98 expectVectorNear(checker->getAllCIFsAtTimebound(1), param.CIF);
101TEST_P(SftBddTest, DIF) {
102 auto const ¶m{TestWithParam::GetParam()};
103 expectVectorNear(checker->getAllDIFsAtTimebound(1), param.DIF);
106TEST_P(SftBddTest, RAW) {
107 auto const ¶m{TestWithParam::GetParam()};
108 expectVectorNear(checker->getAllRAWsAtTimebound(1), param.RAW);
111TEST_P(SftBddTest, RRW) {
112 auto const ¶m{TestWithParam::GetParam()};
113 expectVectorNear(checker->getAllRRWsAtTimebound(1), param.RRW);
116static std::vector<SftTestData> sftTestData{
119 STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndTest.dft",
120 "07251c962e40a962c342b8673fd18b45a1461ebd917f83f6720aa106cf277f9f",
127 {INFINITY, INFINITY},
131 STORM_TEST_RESOURCES_DIR
"/dft/bdd/OrTest.dft",
132 "c5cf2304417926961c3e1ce1d876fc2886ece1365fd946bfd3e1abd71401696d",
136 {0.3333333333, 0.3333333333},
137 {0.666667, 0.666667},
138 {1.333333333, 1.333333333},
143 STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndOrTest.dft",
144 "fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae",
147 {0.375, 0.375, 0.375, 0.375},
148 {0.3333333333, 0.3333333333, 0.3333333333, 0.3333333333},
149 {0.666667, 0.666667, 0.666667, 0.666667},
150 {1.333333333, 1.333333333, 1.333333333, 1.333333333},
151 {1.5, 1.5, 1.5, 1.5},
155 STORM_TEST_RESOURCES_DIR
"/dft/bdd/VotTest.dft",
156 "c005a8d6ad70cc497e1efa3733b0dc52e94c465572d3f1fc5de4983ddd178094",
159 {0.375, 0.375, 0.375, 0.375},
160 {0.27272727, 0.27272727, 0.27272727, 0.27272727},
161 {0.636364, 0.636364, 0.636364, 0.636364},
162 {1.27272727, 1.27272727, 1.27272727, 1.27272727},
163 {1.375, 1.375, 1.375, 1.375},
167 STORM_TEST_RESOURCES_DIR
"/dft/bdd/ImportanceTest.dft",
168 "38221c1eb557dd6f15cf33faf61e18c4e426fab2fb909c56ac0d5f4ff0be499f",
171 {0.531011, 0.368041, 0.224763, 0.0596235, 0.0543206, 0.0810368, 0},
172 {1, 0.693094, 0.153453, 0.112283, 0.09231, 0.192934, 0},
173 {1, 0.846547, 0.306906, 0.556142, 0.501849, 0.703097, 0.5},
174 {2, 1.693094106, 1.693094106, 1.112283035, 1.112283035, 1.112283035, 1},
175 {INFINITY, 3.25832778, 1.18127, 1.126485175, 1.1016977, 1.23905588, 1},
178INSTANTIATE_TEST_SUITE_P(SFTs, SftBddTest, testing::ValuesIn(sftTestData), [](
auto const &info) {
return info.param.testname; });
180TEST(TestBdd, AndOrRelevantEvents) {
181 auto dft = storm::dft::api::loadDFTGalileoFile<double>(STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndOrTest.dft");
182 auto manager = std::make_shared<storm::dft::storage::SylvanBddManager>();
186 auto const result = transformer.transformRelevantEvents();
188 EXPECT_EQ(result.size(), 4ul);
190 EXPECT_EQ(result.at(
"F").GetShaHash(),
"fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae");
191 EXPECT_EQ(result.at(
"F1").GetShaHash(),
"c5cf2304417926961c3e1ce1d876fc2886ece1365fd946bfd3e1abd71401696d");
192 EXPECT_EQ(result.at(
"F2").GetShaHash(),
"a4f129fa27c6cd32625b088811d4b12f8059ae0547ee035c083deed9ef9d2c59");
193 EXPECT_EQ(result.at(
"x1").GetShaHash(),
"b0d991484e405a391b6d3d241fed9c00d4a2e5bf6f57300512394d819253893d");
196TEST(TestBdd, AndOrRelevantEventsChecked) {
197 auto dft = storm::dft::api::loadDFTGalileoFile<double>(STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndOrTest.dft");
198 auto manager{std::make_shared<storm::dft::storage::SylvanBddManager>()};
200 auto transformator{std::make_shared<storm::dft::transformations::SftToBddTransformator<double>>(dft,
manager, relevantEvents)};
204 auto relevantEventsBdds = transformator->transformRelevantEvents();
206 EXPECT_NEAR(checker.getProbabilityAtTimebound(relevantEventsBdds[
"F"], 1), 0.5625, 1e-6);
208 EXPECT_NEAR(checker.getProbabilityAtTimebound(relevantEventsBdds[
"F1"], 1), 0.75, 1e-6);
209 EXPECT_NEAR(checker.getProbabilityAtTimebound(relevantEventsBdds[
"F2"], 1), 0.75, 1e-6);
211 EXPECT_NEAR(checker.getProbabilityAtTimebound(relevantEventsBdds[
"x1"], 1), 0.5, 1e-6);
214TEST(TestBdd, AndOrFormulaFail) {
215 auto dft = storm::dft::api::loadDFTGalileoFile<double>(STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndOrTest.dft");
222TEST(TestBdd, AndOrFormula) {
223 auto dft = storm::dft::api::loadDFTGalileoFile<double>(STORM_TEST_RESOURCES_DIR
"/dft/bdd/AndOrTest.dft");
226 "P=? [F <= 1 \"F_failed\"];"
227 "P=? [F <= 1 \"F1_failed\" & \"F2_failed\"];"
228 "P=? [F = 1 !\"failed\"];"
229 "P=? [F = 1 !\"F1_failed\"];"
230 "P=? [F = 1 !\"F2_failed\"];"
231 "P=? [F <= 1 \"F1_failed\"];"
232 "P=? [F <= 1 \"F2_failed\"];"))};
235 auto const resultProbs{checker.
check()};
236 auto const result{checker.formulasToBdd()};
238 EXPECT_EQ(result.size(), 8ul);
240 EXPECT_EQ(resultProbs[0], resultProbs[1]);
241 EXPECT_EQ(resultProbs[1], resultProbs[2]);
242 EXPECT_NEAR(resultProbs[0], 0.5625, 1e-6);
244 EXPECT_NEAR(resultProbs[3], 1 - resultProbs[0], 1e-6);
246 EXPECT_EQ(resultProbs[6], resultProbs[7]);
247 EXPECT_NEAR(resultProbs[6], 0.75, 1e-6);
249 EXPECT_EQ(resultProbs[4], resultProbs[5]);
250 EXPECT_NEAR(resultProbs[4], 1 - resultProbs[6], 1e-6);
252 EXPECT_EQ(result[0], result[1]);
253 EXPECT_EQ(result[1], result[2]);
254 EXPECT_EQ(result[2], result[0]);
256 EXPECT_EQ(result[0].GetBDD(), result[1].GetBDD());
257 EXPECT_EQ(result[1].GetBDD(), result[2].GetBDD());
258 EXPECT_EQ(result[2].GetBDD(), result[0].GetBDD());
260 EXPECT_EQ(result[0].GetBDD(), (!result[3]).GetBDD());
261 EXPECT_NE(result[0].GetBDD(), result[3].GetBDD());
263 EXPECT_EQ(result[6].GetBDD(), (!result[4]).GetBDD());
264 EXPECT_NE(result[6].GetBDD(), result[4].GetBDD());
266 EXPECT_EQ(result[7].GetBDD(), (!result[5]).GetBDD());
267 EXPECT_NE(result[7].GetBDD(), result[5].GetBDD());
269 EXPECT_NE(result[3].GetBDD(), result[4].GetBDD());
271 EXPECT_EQ(result[0].GetShaHash(),
"fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae");
272 EXPECT_EQ(result[1].GetShaHash(),
"fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae");
273 EXPECT_EQ(result[2].GetShaHash(),
"fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae");
274 EXPECT_EQ(result[3].GetShaHash(),
"fc1e9a418e3c207e81ffa7fde7768f027b6996732c4216c1ed5de6861dbc86ae");
275 EXPECT_EQ(result[4].GetShaHash(),
"c5cf2304417926961c3e1ce1d876fc2886ece1365fd946bfd3e1abd71401696d");
276 EXPECT_EQ(result[5].GetShaHash(),
"a4f129fa27c6cd32625b088811d4b12f8059ae0547ee035c083deed9ef9d2c59");
277 EXPECT_EQ(result[6].GetShaHash(),
"c5cf2304417926961c3e1ce1d876fc2886ece1365fd946bfd3e1abd71401696d");
278 EXPECT_EQ(result[7].GetShaHash(),
"a4f129fa27c6cd32625b088811d4b12f8059ae0547ee035c083deed9ef9d2c59");
Main class for the SFTBDDChecker.
std::vector< storm::jani::Property > parseProperties(storm::parser::FormulaParser &formulaParser, std::string const &inputString, boost::optional< std::set< std::string > > const &propertyFilter)
std::vector< std::shared_ptr< storm::logic::Formula const > > extractFormulasFromProperties(std::vector< storm::jani::Property > const &properties)
std::ostream & operator<<(std::ostream &out, Counterexample const &counterexample)
double MTTFHelperVariableChange(std::shared_ptr< storm::dft::storage::DFT< double > > const dft, double const stepsize)
Tries to numerically approximate the mttf of the given dft by integrating 1 - cdf(dft) by changing th...
double MTTFHelperProceeding(std::shared_ptr< storm::dft::storage::DFT< double > > const dft, double const stepsize, double const precision)
Tries to numerically approximate the mttf of the given dft by integrating 1 - cdf(dft) with Simpson's...
SettingsManager const & manager()
Retrieves the settings manager.
#define STORM_SILENT_EXPECT_THROW(statement, expected_exception)