1#include "storm-config.h"
9TEST(DftParserTest, LoadFromGalileoFile) {
10 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/and.dft";
11 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTGalileoFile<double>(file);
12 EXPECT_EQ(3ul, dft->nrElements());
13 EXPECT_EQ(2ul, dft->nrBasicElements());
17TEST(DftParserTest, LoadFromJsonFile) {
18 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/and.json";
19 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTJsonFile<double>(file);
20 EXPECT_EQ(3ul, dft->nrElements());
21 EXPECT_EQ(2ul, dft->nrBasicElements());
25TEST(DftParserTest, LoadAllBeDistributionsFromGalileoFile) {
26 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/all_be_distributions.dft";
27 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTGalileoFile<double>(file);
28 EXPECT_EQ(8ul, dft->nrElements());
29 EXPECT_EQ(7ul, dft->nrBasicElements());
40TEST(DftParserTest, LoadAllGatesFromGalileoFile) {
41 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/all_gates.dft";
42 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTGalileoFile<double>(file);
43 EXPECT_EQ(42ul, dft->nrElements());
44 EXPECT_EQ(19ul, dft->nrBasicElements());
45 EXPECT_EQ(5ul, dft->nrStaticElements());
46 EXPECT_EQ(18ul, dft->nrDynamicElements());
50TEST(DftParserTest, LoadAllBEDistributionsFromJsonFile) {
51 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/all_be_distributions.json";
52 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTJsonFile<double>(file);
53 EXPECT_EQ(8ul, dft->nrElements());
54 EXPECT_EQ(7ul, dft->nrBasicElements());
65TEST(DftParserTest, LoadAllGatesFromJsonFile) {
66 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/all_gates.json";
67 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTJsonFile<double>(file);
68 EXPECT_EQ(42ul, dft->nrElements());
69 EXPECT_EQ(19ul, dft->nrBasicElements());
70 EXPECT_EQ(5ul, dft->nrStaticElements());
71 EXPECT_EQ(18ul, dft->nrDynamicElements());
75TEST(DftParserTest, CatchCycles) {
76 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/cyclic.dft";
80TEST(DftParserTest, LoadSeqChildren) {
81 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/seqChild.dft";
82 std::shared_ptr<storm::dft::storage::DFT<double>> dft = storm::dft::api::loadDFTGalileoFile<double>(file);
83 EXPECT_EQ(4ul, dft->nrElements());
84 EXPECT_EQ(2ul, dft->nrBasicElements());
88TEST(DftParserTest, LoadParametricFromGalileoFile) {
89 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/and_param.dft";
90 std::shared_ptr<storm::dft::storage::DFT<storm::RationalFunction>> dft = storm::dft::api::loadDFTGalileoFile<storm::RationalFunction>(file);
91 EXPECT_EQ(3ul, dft->nrElements());
92 EXPECT_EQ(2ul, dft->nrBasicElements());
95 EXPECT_TRUE(parameters.size() == 1);
97 EXPECT_TRUE(it != parameters.end());
100TEST(DftParserTest, LoadParametricFromJsonFile) {
101 std::string file = STORM_TEST_RESOURCES_DIR
"/dft/and_param.json";
102 std::shared_ptr<storm::dft::storage::DFT<storm::RationalFunction>> dft = storm::dft::api::loadDFTJsonFile<storm::RationalFunction>(file);
103 EXPECT_EQ(3ul, dft->nrElements());
104 EXPECT_EQ(2ul, dft->nrBasicElements());
107 EXPECT_TRUE(parameters.size() == 1);
109 EXPECT_TRUE(it != parameters.end());
std::pair< bool, std::string > isWellFormed(storm::dft::storage::DFT< ValueType > const &dft, bool validForMarkovianAnalysis=true)
Check whether the DFT is well-formed.
std::set< storm::RationalFunctionVariable > getParameters(DFT< storm::RationalFunction > const &dft)
Get all rate/probability parameters occurring in the DFT.
carl::Variable RationalFunctionVariable
#define STORM_SILENT_EXPECT_THROW(statement, expected_exception)