|  |  | @ -85,7 +85,87 @@ namespace { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, AndMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/and.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 3.0); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 3); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, OrMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/or.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, VotingMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/voting.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 5/3); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/voting2.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 10/17); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/voting3.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1.73562); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/voting4.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 5/6); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, PandMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/pand.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_EQ(result, storm::utility::infinity<double>()); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, PorMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/por.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_EQ(result, storm::utility::infinity<double>()); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, FdepMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/fdep.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 2/3); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/fdep2.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 2); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/fdep3.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 2.5); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/fdep4.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/fdep5.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 3); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, PdepMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/pdep.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 8/3); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/pdep2.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 38/15); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/pdep3.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 2.79167); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/pdep4.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_EQ(result, storm::utility::infinity<double>()); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, SpareMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 3.53846); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare2.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1.86957); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare3.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1.27273); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare4.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 4.8459); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare5.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 8/3); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare6.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 1.4); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare7.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 3.67333); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/spare8.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 4.78846); // DFTCalc says 4.33779
 | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |     TYPED_TEST(DftModelCheckerTest, SeqMTTF) { | 
			
		
	
		
			
				
					|  |  |  |         double result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/seq.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 4); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/seq2.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 6); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/seq3.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 6); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/seq4.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_FLOAT_EQ(result, 6); | 
			
		
	
		
			
				
					|  |  |  |         result = this->analyzeMTTF(STORM_TEST_RESOURCES_DIR "/dft/seq5.dft"); | 
			
		
	
		
			
				
					|  |  |  |         EXPECT_EQ(result, storm::utility::infinity<double>()); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | } |