23 auto const& dftIOSettings = storm::settings::getModule<storm::dft::settings::modules::DftIOSettings>();
24 auto const& faultTreeSettings = storm::settings::getModule<storm::dft::settings::modules::FaultTreeSettings>();
25 auto const& ioSettings = storm::settings::getModule<storm::settings::modules::IOSettings>();
26 auto const& dftGspnSettings = storm::settings::getModule<storm::dft::settings::modules::DftGspnSettings>();
27 auto const& transformationSettings = storm::settings::getModule<storm::settings::modules::TransformationSettings>();
30 std::shared_ptr<storm::dft::storage::DFT<ValueType>> dft;
31 if (dftIOSettings.isDftFileSet()) {
32 STORM_LOG_DEBUG(
"Loading DFT from Galileo file " << dftIOSettings.getDftFilename());
33 dft = storm::dft::api::loadDFTGalileoFile<ValueType>(dftIOSettings.getDftFilename());
34 }
else if (dftIOSettings.isDftJsonFileSet()) {
35 STORM_LOG_DEBUG(
"Loading DFT from Json file " << dftIOSettings.getDftJsonFilename());
36 dft = storm::dft::api::loadDFTJsonFile<ValueType>(dftIOSettings.getDftJsonFilename());
38 STORM_LOG_THROW(
false, storm::exceptions::InvalidSettingsException,
"No input model given.");
42 if (dftIOSettings.isShowDftStatisticsSet()) {
43 dft->writeStatsToStream(std::cout);
48 if (dftIOSettings.isExportToJson()) {
49 storm::dft::api::exportDFTToJsonFile<ValueType>(*dft, dftIOSettings.getExportJsonFilename());
54 STORM_LOG_THROW(wellFormedResult.first, storm::exceptions::UnmetRequirementException,
"DFT is not well-formed: " << wellFormedResult.second);
60 if (dftGspnSettings.isTransformToGspn()) {
62 std::shared_ptr<storm::gspn::GSPN> gspn = pair.first;
63 uint64_t toplevelFailedPlace = pair.second;
75 if (dftIOSettings.isExportToSmt()) {
76 storm::dft::api::exportDFTToSMT<ValueType>(*dft, dftIOSettings.getExportSmtFilename());
81 uint64_t solverTimeout = 10;
83 if (faultTreeSettings.solveWithSMT()) {
98 STORM_LOG_DEBUG(
"BE failure bounds: lower bound: " << bounds.first <<
", upper bound: " << bounds.second <<
".");
110 if (dftIOSettings.isExportToBddDot() || dftIOSettings.isAnalyzeWithBdds() || dftIOSettings.isMinimalCutSets() || dftIOSettings.isImportanceMeasureSet()) {
111 bool const isImportanceMeasureSet{dftIOSettings.isImportanceMeasureSet()};
112 bool const isMinimalCutSets{dftIOSettings.isMinimalCutSets()};
113 bool const isMTTF{dftIOSettings.usePropExpectedTime()};
114 double const mttfPrecision{faultTreeSettings.getMttfPrecision()};
115 double const mttfStepsize{faultTreeSettings.getMttfStepsize()};
116 std::string
const mttfAlgorithm{faultTreeSettings.getMttfAlgorithm()};
117 bool const isExportToBddDot{dftIOSettings.isExportToBddDot()};
118 bool const isTimebound{dftIOSettings.usePropTimebound()};
119 bool const isTimepoints{dftIOSettings.usePropTimepoints()};
121 bool const probabilityAnalysis{ioSettings.isPropertySet() || !isImportanceMeasureSet};
122 size_t const chunksize{faultTreeSettings.getChunksize()};
123 bool const isModularisation{faultTreeSettings.useModularisation()};
125 std::vector<double> timepoints{};
127 timepoints = dftIOSettings.getPropTimepoints();
130 timepoints.push_back(dftIOSettings.getPropTimebound());
133 std::string filename{
""};
134 if (isExportToBddDot) {
135 filename = dftIOSettings.getExportBddDotFilename();
139 std::vector<std::shared_ptr<storm::logic::Formula const>> manuallyInputtedProperties;
140 if (ioSettings.isPropertySet()) {
144 std::string importanceMeasureName{
""};
145 if (isImportanceMeasureSet) {
146 importanceMeasureName = dftIOSettings.getImportanceMeasure();
150 if (dftIOSettings.isVariableOrderingFileSet()) {
152 dft->setBEOrder(beOrder);
155 auto const additionalRelevantEventNames{faultTreeSettings.getRelevantEvents()};
156 storm::dft::api::analyzeDFTBdd<ValueType>(dft, isExportToBddDot, filename, isMTTF, mttfPrecision, mttfStepsize, mttfAlgorithm, isMinimalCutSets,
157 probabilityAnalysis, isModularisation, importanceMeasureName, timepoints, manuallyInputtedProperties,
158 additionalRelevantEventNames, chunksize);
161 if (dftIOSettings.isAnalyzeWithBdds()) {
169 std::string optimizationDirection =
"min";
170 if (dftIOSettings.isComputeMaximalValue()) {
171 optimizationDirection =
"max";
176 std::vector<std::string> properties;
177 if (ioSettings.isPropertySet()) {
178 properties.push_back(ioSettings.getProperty());
180 if (dftIOSettings.usePropExpectedTime()) {
181 properties.push_back(
"T" + optimizationDirection +
"=? [F \"failed\"]");
183 if (dftIOSettings.usePropProbability()) {
184 properties.push_back(
"P" + optimizationDirection +
"=? [F \"failed\"]");
186 if (dftIOSettings.usePropTimebound()) {
187 std::stringstream stream;
188 stream <<
"P" << optimizationDirection <<
"=? [F<=" << dftIOSettings.getPropTimebound() <<
" \"failed\"]";
189 properties.push_back(stream.str());
191 if (dftIOSettings.usePropTimepoints()) {
192 for (
double timepoint : dftIOSettings.getPropTimepoints()) {
193 std::stringstream stream;
194 stream <<
"P" << optimizationDirection <<
"=? [F<=" << timepoint <<
" \"failed\"]";
195 properties.push_back(stream.str());
200 std::vector<std::shared_ptr<storm::logic::Formula const>> props;
201 if (!properties.empty()) {
202 std::string propString;
203 for (
size_t i = 0; i < properties.size(); ++i) {
204 propString += properties[i];
205 if (i + 1 < properties.size()) {
213 std::vector<std::string> additionalRelevantEventNames;
214 if (faultTreeSettings.areRelevantEventsSet()) {
216 additionalRelevantEventNames = faultTreeSettings.getRelevantEvents();
217 }
else if (faultTreeSettings.isDisableDC()) {
219 additionalRelevantEventNames = {
"all"};
224 dft = storm::dft::api::prepareForMarkovAnalysis<ValueType>(*dft);
225 STORM_LOG_DEBUG(
"DFT after preparation for Markov analysis:\n" << dft->getElementsString());
237 STORM_LOG_WARN(
"No property given. No analysis will be performed.");
239 double approximationError = 0.0;
240 if (faultTreeSettings.isApproximationErrorSet()) {
241 approximationError = faultTreeSettings.getApproximationError();
243 storm::dft::api::analyzeDFT<ValueType>(*dft, props, faultTreeSettings.useSymmetryReduction(), faultTreeSettings.useModularisation(), relevantEvents,
244 faultTreeSettings.isAllowDCForRelevantEvents(), approximationError,
245 faultTreeSettings.getApproximationHeuristic(), transformationSettings.isChainEliminationSet(),
246 transformationSettings.getLabelBehavior(),
true);