27 std::shared_ptr<storm::dft::storage::DFT<ValueType>> dft;
28 if (dftIOSettings.isDftFileSet()) {
29 STORM_LOG_DEBUG(
"Loading DFT from Galileo file " << dftIOSettings.getDftFilename());
30 dft = storm::dft::api::loadDFTGalileoFile<ValueType>(dftIOSettings.getDftFilename());
31 }
else if (dftIOSettings.isDftJsonFileSet()) {
32 STORM_LOG_DEBUG(
"Loading DFT from Json file " << dftIOSettings.getDftJsonFilename());
33 dft = storm::dft::api::loadDFTJsonFile<ValueType>(dftIOSettings.getDftJsonFilename());
35 STORM_LOG_THROW(
false, storm::exceptions::InvalidSettingsException,
"No input model given.");
39 if (dftIOSettings.isShowDftStatisticsSet()) {
40 dft->writeStatsToStream(std::cout);
45 if (dftIOSettings.isExportToJson()) {
46 storm::dft::api::exportDFTToJsonFile<ValueType>(*dft, dftIOSettings.getExportJsonFilename());
51 STORM_LOG_THROW(wellFormedResult.first, storm::exceptions::UnmetRequirementException,
"DFT is not well-formed: " << wellFormedResult.second);
54 if (dftGspnSettings.isTransformToGspn()) {
56 std::shared_ptr<storm::gspn::GSPN> gspn = pair.first;
57 uint64_t toplevelFailedPlace = pair.second;
69 if (dftIOSettings.isExportToSmt()) {
70 storm::dft::api::exportDFTToSMT<ValueType>(*dft, dftIOSettings.getExportSmtFilename());
75 uint64_t solverTimeout = 10;
77 if (faultTreeSettings.solveWithSMT()) {
92 STORM_LOG_DEBUG(
"BE failure bounds: lower bound: " << bounds.first <<
", upper bound: " << bounds.second <<
".");
104 if (dftIOSettings.isExportToBddDot() || dftIOSettings.isAnalyzeWithBdds() || dftIOSettings.isMinimalCutSets() || dftIOSettings.isImportanceMeasureSet()) {
105 bool const isImportanceMeasureSet{dftIOSettings.isImportanceMeasureSet()};
106 bool const isMinimalCutSets{dftIOSettings.isMinimalCutSets()};
107 bool const isMTTF{dftIOSettings.usePropExpectedTime()};
108 double const mttfPrecision{faultTreeSettings.getMttfPrecision()};
109 double const mttfStepsize{faultTreeSettings.getMttfStepsize()};
110 std::string
const mttfAlgorithm{faultTreeSettings.getMttfAlgorithm()};
111 bool const isExportToBddDot{dftIOSettings.isExportToBddDot()};
112 bool const isTimebound{dftIOSettings.usePropTimebound()};
113 bool const isTimepoints{dftIOSettings.usePropTimepoints()};
115 bool const probabilityAnalysis{ioSettings.isPropertySet() || !isImportanceMeasureSet};
116 size_t const chunksize{faultTreeSettings.getChunksize()};
117 bool const isModularisation{faultTreeSettings.useModularisation()};
119 std::vector<double> timepoints{};
121 timepoints = dftIOSettings.getPropTimepoints();
124 timepoints.push_back(dftIOSettings.getPropTimebound());
127 std::string filename{
""};
128 if (isExportToBddDot) {
129 filename = dftIOSettings.getExportBddDotFilename();
133 std::vector<std::shared_ptr<storm::logic::Formula const>> manuallyInputtedProperties;
134 if (ioSettings.isPropertySet()) {
138 std::string importanceMeasureName{
""};
139 if (isImportanceMeasureSet) {
140 importanceMeasureName = dftIOSettings.getImportanceMeasure();
143 auto const additionalRelevantEventNames{faultTreeSettings.getRelevantEvents()};
144 storm::dft::api::analyzeDFTBdd<ValueType>(dft, isExportToBddDot, filename, isMTTF, mttfPrecision, mttfStepsize, mttfAlgorithm, isMinimalCutSets,
145 probabilityAnalysis, isModularisation, importanceMeasureName, timepoints, manuallyInputtedProperties,
146 additionalRelevantEventNames, chunksize);
149 if (dftIOSettings.isAnalyzeWithBdds()) {
157 std::string optimizationDirection =
"min";
158 if (dftIOSettings.isComputeMaximalValue()) {
159 optimizationDirection =
"max";
164 std::vector<std::string> properties;
165 if (ioSettings.isPropertySet()) {
166 properties.push_back(ioSettings.getProperty());
168 if (dftIOSettings.usePropExpectedTime()) {
169 properties.push_back(
"T" + optimizationDirection +
"=? [F \"failed\"]");
171 if (dftIOSettings.usePropProbability()) {
172 properties.push_back(
"P" + optimizationDirection +
"=? [F \"failed\"]");
174 if (dftIOSettings.usePropTimebound()) {
175 std::stringstream stream;
176 stream <<
"P" << optimizationDirection <<
"=? [F<=" << dftIOSettings.getPropTimebound() <<
" \"failed\"]";
177 properties.push_back(stream.str());
179 if (dftIOSettings.usePropTimepoints()) {
180 for (
double timepoint : dftIOSettings.getPropTimepoints()) {
181 std::stringstream stream;
182 stream <<
"P" << optimizationDirection <<
"=? [F<=" << timepoint <<
" \"failed\"]";
183 properties.push_back(stream.str());
188 std::vector<std::shared_ptr<storm::logic::Formula const>> props;
189 if (!properties.empty()) {
190 std::string propString;
191 for (
size_t i = 0; i < properties.size(); ++i) {
192 propString += properties[i];
193 if (i + 1 < properties.size()) {
201 std::vector<std::string> additionalRelevantEventNames;
202 if (faultTreeSettings.areRelevantEventsSet()) {
204 additionalRelevantEventNames = faultTreeSettings.getRelevantEvents();
205 }
else if (faultTreeSettings.isDisableDC()) {
207 additionalRelevantEventNames = {
"all"};
212 dft = storm::dft::api::prepareForMarkovAnalysis<ValueType>(*dft);
213 STORM_LOG_DEBUG(
"DFT after preparation for Markov analysis:\n" << dft->getElementsString());
225 STORM_LOG_WARN(
"No property given. No analysis will be performed.");
227 double approximationError = 0.0;
228 if (faultTreeSettings.isApproximationErrorSet()) {
229 approximationError = faultTreeSettings.getApproximationError();
231 storm::dft::api::analyzeDFT<ValueType>(*dft, props, faultTreeSettings.useSymmetryReduction(), faultTreeSettings.useModularisation(), relevantEvents,
232 faultTreeSettings.isAllowDCForRelevantEvents(), approximationError,
233 faultTreeSettings.getApproximationHeuristic(), transformationSettings.isChainEliminationSet(),
234 transformationSettings.getLabelBehavior(),
true);