28 std::shared_ptr<storm::dft::storage::DFT<ValueType>> dft;
29 if (dftIOSettings.isDftFileSet()) {
30 STORM_LOG_DEBUG(
"Loading DFT from Galileo file " << dftIOSettings.getDftFilename());
31 dft = storm::dft::api::loadDFTGalileoFile<ValueType>(dftIOSettings.getDftFilename());
32 }
else if (dftIOSettings.isDftJsonFileSet()) {
33 STORM_LOG_DEBUG(
"Loading DFT from Json file " << dftIOSettings.getDftJsonFilename());
34 dft = storm::dft::api::loadDFTJsonFile<ValueType>(dftIOSettings.getDftJsonFilename());
36 STORM_LOG_THROW(
false, storm::exceptions::InvalidSettingsException,
"No input model given.");
40 if (dftIOSettings.isShowDftStatisticsSet()) {
41 dft->writeStatsToStream(std::cout);
46 if (dftIOSettings.isExportToJson()) {
47 storm::dft::api::exportDFTToJsonFile<ValueType>(*dft, dftIOSettings.getExportJsonFilename());
52 STORM_LOG_THROW(wellFormedResult.first, storm::exceptions::UnmetRequirementException,
"DFT is not well-formed: " << wellFormedResult.second);
58 if (dftGspnSettings.isTransformToGspn()) {
60 std::shared_ptr<storm::gspn::GSPN> gspn = pair.first;
61 uint64_t toplevelFailedPlace = pair.second;
73 if (dftIOSettings.isExportToSmt()) {
74 storm::dft::api::exportDFTToSMT<ValueType>(*dft, dftIOSettings.getExportSmtFilename());
79 uint64_t solverTimeout = 10;
81 if (faultTreeSettings.solveWithSMT()) {
96 STORM_LOG_DEBUG(
"BE failure bounds: lower bound: " << bounds.first <<
", upper bound: " << bounds.second <<
".");
108 if (dftIOSettings.isExportToBddDot() || dftIOSettings.isAnalyzeWithBdds() || dftIOSettings.isMinimalCutSets() || dftIOSettings.isImportanceMeasureSet()) {
109 bool const isImportanceMeasureSet{dftIOSettings.isImportanceMeasureSet()};
110 bool const isMinimalCutSets{dftIOSettings.isMinimalCutSets()};
111 bool const isMTTF{dftIOSettings.usePropExpectedTime()};
112 double const mttfPrecision{faultTreeSettings.getMttfPrecision()};
113 double const mttfStepsize{faultTreeSettings.getMttfStepsize()};
114 std::string
const mttfAlgorithm{faultTreeSettings.getMttfAlgorithm()};
115 bool const isExportToBddDot{dftIOSettings.isExportToBddDot()};
116 bool const isTimebound{dftIOSettings.usePropTimebound()};
117 bool const isTimepoints{dftIOSettings.usePropTimepoints()};
119 bool const probabilityAnalysis{ioSettings.isPropertySet() || !isImportanceMeasureSet};
120 size_t const chunksize{faultTreeSettings.getChunksize()};
121 bool const isModularisation{faultTreeSettings.useModularisation()};
123 std::vector<double> timepoints{};
125 timepoints = dftIOSettings.getPropTimepoints();
128 timepoints.push_back(dftIOSettings.getPropTimebound());
131 std::string filename{
""};
132 if (isExportToBddDot) {
133 filename = dftIOSettings.getExportBddDotFilename();
137 std::vector<std::shared_ptr<storm::logic::Formula const>> manuallyInputtedProperties;
138 if (ioSettings.isPropertySet()) {
142 std::string importanceMeasureName{
""};
143 if (isImportanceMeasureSet) {
144 importanceMeasureName = dftIOSettings.getImportanceMeasure();
148 if (dftIOSettings.isVariableOrderingFileSet()) {
150 dft->setBEOrder(beOrder);
153 auto const additionalRelevantEventNames{faultTreeSettings.getRelevantEvents()};
154 storm::dft::api::analyzeDFTBdd<ValueType>(dft, isExportToBddDot, filename, isMTTF, mttfPrecision, mttfStepsize, mttfAlgorithm, isMinimalCutSets,
155 probabilityAnalysis, isModularisation, importanceMeasureName, timepoints, manuallyInputtedProperties,
156 additionalRelevantEventNames, chunksize);
159 if (dftIOSettings.isAnalyzeWithBdds()) {
167 std::string optimizationDirection =
"min";
168 if (dftIOSettings.isComputeMaximalValue()) {
169 optimizationDirection =
"max";
174 std::vector<std::string> properties;
175 if (ioSettings.isPropertySet()) {
176 properties.push_back(ioSettings.getProperty());
178 if (dftIOSettings.usePropExpectedTime()) {
179 properties.push_back(
"T" + optimizationDirection +
"=? [F \"failed\"]");
181 if (dftIOSettings.usePropProbability()) {
182 properties.push_back(
"P" + optimizationDirection +
"=? [F \"failed\"]");
184 if (dftIOSettings.usePropTimebound()) {
185 std::stringstream stream;
186 stream <<
"P" << optimizationDirection <<
"=? [F<=" << dftIOSettings.getPropTimebound() <<
" \"failed\"]";
187 properties.push_back(stream.str());
189 if (dftIOSettings.usePropTimepoints()) {
190 for (
double timepoint : dftIOSettings.getPropTimepoints()) {
191 std::stringstream stream;
192 stream <<
"P" << optimizationDirection <<
"=? [F<=" << timepoint <<
" \"failed\"]";
193 properties.push_back(stream.str());
198 std::vector<std::shared_ptr<storm::logic::Formula const>> props;
199 if (!properties.empty()) {
200 std::string propString;
201 for (
size_t i = 0; i < properties.size(); ++i) {
202 propString += properties[i];
203 if (i + 1 < properties.size()) {
211 std::vector<std::string> additionalRelevantEventNames;
212 if (faultTreeSettings.areRelevantEventsSet()) {
214 additionalRelevantEventNames = faultTreeSettings.getRelevantEvents();
215 }
else if (faultTreeSettings.isDisableDC()) {
217 additionalRelevantEventNames = {
"all"};
222 dft = storm::dft::api::prepareForMarkovAnalysis<ValueType>(*dft);
223 STORM_LOG_DEBUG(
"DFT after preparation for Markov analysis:\n" << dft->getElementsString());
235 STORM_LOG_WARN(
"No property given. No analysis will be performed.");
237 double approximationError = 0.0;
238 if (faultTreeSettings.isApproximationErrorSet()) {
239 approximationError = faultTreeSettings.getApproximationError();
241 storm::dft::api::analyzeDFT<ValueType>(*dft, props, faultTreeSettings.useSymmetryReduction(), faultTreeSettings.useModularisation(), relevantEvents,
242 faultTreeSettings.isAllowDCForRelevantEvents(), approximationError,
243 faultTreeSettings.getApproximationHeuristic(), transformationSettings.isChainEliminationSet(),
244 transformationSettings.getLabelBehavior(),
true);