From aa630ce62b79bdd9e4a624914a5e03268f4ad88e Mon Sep 17 00:00:00 2001 From: Jip Spel Date: Thu, 16 Aug 2018 14:25:38 +0200 Subject: [PATCH] Monotone increasing in all parameters implemented --- src/storm-pars-cli/storm-pars.cpp | 46 +++++++++++++++++++++++-------- 1 file changed, 35 insertions(+), 11 deletions(-) diff --git a/src/storm-pars-cli/storm-pars.cpp b/src/storm-pars-cli/storm-pars.cpp index 931ac740d..11d6a98bb 100644 --- a/src/storm-pars-cli/storm-pars.cpp +++ b/src/storm-pars-cli/storm-pars.cpp @@ -641,18 +641,42 @@ namespace storm { // Transform to LatticeLattice storm::analysis::Lattice* lattice = toLattice(sparseModel, topStates, bottomStates); lattice->toString(std::cout); - std::cout << "Bye, Jip" << std::endl; - // TODO: Analyse lattice with transition matrix - // Where do the parameters occur? - // initially incr.Boolean and decr.Boolean true - // At every occurence as long as either incr.Boolean or decr.Boolean true - // --> check if monotonic - // --> yes --> check position in lattice - // --> if incr. set incr.Boolean = incr.Boolean && true, decr.Boolean = false; - // --> if decr. set incr.Boolean = false, decr.Boolean = decr.Boolean && true; - // --> no --> set both booleans to false - // --> set both incr.bool and decr.bool to false + bool monotoneInAll = true; + + storm::storage::SparseMatrix matrix = sparseModel.get()->getTransitionMatrix(); + for (uint_fast64_t i = 0; i < sparseModel.get()->getNumberOfStates(); ++i) { + // go over all rows + auto row = matrix.getRow(i); + + + auto first = (*row.begin()); + if (first.getValue() != ValueType(1)) { + auto second = (* (row.begin() + 1)); + + auto val = first.getValue(); + auto vars = val.gatherVariables(); + for (auto itr = vars.begin(); itr != vars.end(); ++itr) { + auto derivative = val.derivative(*itr); + STORM_LOG_THROW(derivative.isConstant(), storm::exceptions::NotSupportedException, "Expecting probability to have at most degree 1"); + auto compare = lattice->compare(first.getColumn(), second.getColumn()); + if (compare == 1) { + monotoneInAll &=derivative.constantPart() >= 0; + } else if (compare == 2) { + monotoneInAll &=derivative.constantPart() <= 0; + } else { + monotoneInAll = false; + } + } + } + + + } + if (monotoneInAll) { + std::cout << "Monotone increasing in all parameters" << std::endl; + } + // TODO: split into monotonicity in different parameters + std::cout << "Bye, Jip" << std::endl; return; }