Browse Source

Fixed priorities for dependencies and export of PDEP probabilities into PNPRO format

tempestpy_adaptions
Alexander Bork 7 years ago
parent
commit
8c3bd15eae
  1. 10
      src/storm-dft/transformations/DftToGspnTransformator.cpp
  2. 4
      src/storm-gspn/storage/gspn/GSPN.cpp

10
src/storm-dft/transformations/DftToGspnTransformator.cpp

@ -37,10 +37,13 @@ namespace storm {
template<typename ValueType>
std::map<uint64_t, uint64_t> DftToGspnTransformator<ValueType>::computePriorities() {
std::map<uint64_t, uint64_t> priorities;
// Set priority for PDEP and FDEP according to Monolithic MA semantics
uint64_t dependency_priority = 2;
for (std::size_t i = 0; i < mDft.nrElements(); i++) {
// Give all elements the same priority
priorities[i] = (-(mDft.getElement(i)->rank()) + mDft.maxRank()) * 2 + 2;
if (mDft.getElement(i)->type() == storm::storage::DFTElementType::PDEP)
priorities[i] = dependency_priority;
else
priorities[i] = (-(mDft.getElement(i)->rank()) + mDft.maxRank()) * 2 + 5;
}
return priorities;
}
@ -126,7 +129,6 @@ namespace storm {
dftBE->name() + STR_ACTIVATED);
activePlaces.emplace(dftBE->id(), activePlace);
builder.setPlaceLayoutInfo(activePlace, storm::gspn::LayoutInfo(xcenter - 3.0, ycenter));
uint64_t tActive = builder.addTimedTransition(getFailPriority(dftBE), dftBE->activeFailureRate(),
dftBE->name() + "_activeFailing");
builder.setTransitionLayoutInfo(tActive, storm::gspn::LayoutInfo(xcenter, ycenter + 3.0));

4
src/storm-gspn/storage/gspn/GSPN.cpp

@ -433,7 +433,8 @@ namespace storm {
stream << space3 << "<transition name=\"" << trans.getName() << "\" ";
stream << "type=\"EXP\" ";
stream << "nservers-x=\"" << trans.getRate() << "\" ";
stream << "delay=\"" << trans.getRate() << "\" ";
//Note: The rate is translated to a number showing the decimal figures so GreatSPN can process it
stream << "delay=\"" << std::showpoint << trans.getRate() << "\" ";
if (transitionLayout.count(trans.getID()) > 0) {
stream << "x=\"" << transitionLayout.at(trans.getID()).x << "\" ";
stream << "y=\"" << transitionLayout.at(trans.getID()).y << "\" ";
@ -449,6 +450,7 @@ namespace storm {
stream << space3 << "<transition name=\"" << trans.getName() << "\" ";
stream << "type=\"IMM\" ";
stream << "priority=\"" << trans.getPriority() << "\" ";
stream << "weight=\"" << trans.getWeight() << "\" ";
if (transitionLayout.count(trans.getID()) > 0) {
stream << "x=\"" << transitionLayout.at(trans.getID()).x << "\" ";
stream << "y=\"" << transitionLayout.at(trans.getID()).y << "\" ";

Loading…
Cancel
Save