|
|
@ -11,18 +11,24 @@ |
|
|
|
#include "atomic_proposition.h" |
|
|
|
|
|
|
|
|
|
|
|
#define USE_STD_UNORDERED_MAP |
|
|
|
|
|
|
|
/* Map types: By default, the boost hash map is used. |
|
|
|
* When the macro DEFAULT_MAP is defined, the default C++ class (std::map) |
|
|
|
* If the macro USE_STD_MAP is defined, the default C++ class (std::map) |
|
|
|
* is used instead. |
|
|
|
*/ |
|
|
|
#ifdef DEFAULT_MAP |
|
|
|
#ifdef USE_STD_MAP |
|
|
|
# include <map> |
|
|
|
# define MAP std::map |
|
|
|
#else |
|
|
|
# ifdef USE_STD_UNORDERED_MAP |
|
|
|
# include <unordered_map> |
|
|
|
# define MAP std::unordered_map |
|
|
|
# else |
|
|
|
# include "boost/unordered_map.hpp" |
|
|
|
# define MAP boost::unordered_map |
|
|
|
# endif |
|
|
|
#endif |
|
|
|
|
|
|
|
#include <stdexcept> |
|
|
|
|
|
|
@ -33,11 +39,17 @@ namespace mrmc { |
|
|
|
|
|
|
|
namespace dtmc { |
|
|
|
|
|
|
|
|
|
|
|
/*! This class manages the objects of class atomic_proposition. Access is possible with the |
|
|
|
* string identifiers which are used in the input. |
|
|
|
*/ |
|
|
|
class labeling { |
|
|
|
public: |
|
|
|
|
|
|
|
|
|
|
|
/*! Constructor creating an object of class labeling. |
|
|
|
* @param nodeCount The number of nodes; necessary for class AtomicProposition. |
|
|
|
* @param propositionCount The number of atomic propositions. |
|
|
|
*/ |
|
|
|
labeling(const uint_fast32_t nodeCount, |
|
|
|
const uint_fast32_t propositionCount) { |
|
|
|
node_count = nodeCount; |
|
|
@ -60,6 +72,12 @@ class labeling { |
|
|
|
propositions = NULL; |
|
|
|
} |
|
|
|
|
|
|
|
/*! Registers the name of a proposition. |
|
|
|
* Will throw an error if more propositions are added than were initialized, |
|
|
|
* or if a proposition is registered twice. |
|
|
|
* @param proposition The name of the proposition to add. |
|
|
|
* @return The index of the new proposition. |
|
|
|
*/ |
|
|
|
uint_fast32_t addProposition(std::string proposition) { |
|
|
|
if (proposition_map.count(proposition) != 0) { |
|
|
|
throw std::out_of_range("Proposition does already exist."); |
|
|
@ -74,11 +92,17 @@ class labeling { |
|
|
|
return returnValue; |
|
|
|
} |
|
|
|
|
|
|
|
/*! Checks whether the name of a proposition is already registered with the labeling. |
|
|
|
* @return True if the proposition was added to the labeling, false otherwise. |
|
|
|
*/ |
|
|
|
bool containsProposition(std::string proposition) { |
|
|
|
return (proposition_map.count(proposition) != 0); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/*! Labels a node with an atomic proposition. |
|
|
|
* @param proposition The name of the proposition |
|
|
|
* @param node The index of the node to label |
|
|
|
*/ |
|
|
|
void addLabelToNode(std::string proposition, const uint_fast32_t node) { |
|
|
|
//TODO (Thomas Heinemann): Differentiate exceptions? |
|
|
|
if (proposition_map.count(proposition) == 0) { |
|
|
@ -90,14 +114,28 @@ class labeling { |
|
|
|
propositions[proposition_map[proposition]]->addLabelToNode(node); |
|
|
|
} |
|
|
|
|
|
|
|
/*! Checks whether a node is labeled with a proposition. |
|
|
|
* @param proposition The name of the proposition |
|
|
|
* @param node The index of the node |
|
|
|
* @return True if the node is labeled with the proposition, false otherwise. |
|
|
|
*/ |
|
|
|
bool nodeHasProposition(std::string proposition, const uint_fast32_t node) { |
|
|
|
return propositions[proposition_map[proposition]]->hasNodeLabel(node); |
|
|
|
} |
|
|
|
|
|
|
|
/*! Returns the number of propositions managed by this object (which was set in the initialization) |
|
|
|
* @return The number of propositions. |
|
|
|
*/ |
|
|
|
uint_fast32_t getNumberOfPropositions() { |
|
|
|
return proposition_count; |
|
|
|
} |
|
|
|
|
|
|
|
/*! This function provides direct access to an atomic_proposition class object |
|
|
|
* by its string identifier. This object manages the nodes that are labeled with the |
|
|
|
* respective atomic proposition. |
|
|
|
* @param proposition The name of the proposition. |
|
|
|
* @return A pointer to the atomic_proposition object of the proposition. |
|
|
|
*/ |
|
|
|
AtomicProposition* getProposition(std::string proposition) { |
|
|
|
return (propositions[proposition_map[proposition]]); |
|
|
|
} |
|
|
|