X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/edc5c089fec77e74e39c8887a640fe03226d8a3f..976687c46605cb7f3513a3f9549ef43f737e4b7d:/src/mc/explo/odpor/WakeupTree.hpp diff --git a/src/mc/explo/odpor/WakeupTree.hpp b/src/mc/explo/odpor/WakeupTree.hpp index c6cbf20c32..ea8cf2959a 100644 --- a/src/mc/explo/odpor/WakeupTree.hpp +++ b/src/mc/explo/odpor/WakeupTree.hpp @@ -49,10 +49,10 @@ public: WakeupTreeNode& operator=(const WakeupTreeNode&) = delete; WakeupTreeNode& operator=(WakeupTreeNode&&) = default; - const auto begin() const { return this->children_.begin(); } - const auto end() const { return this->children_.end(); } - const auto rbegin() const { return this->children_.rbegin(); } - const auto rend() const { return this->children_.rend(); } + auto begin() const { return this->children_.begin(); } + auto end() const { return this->children_.end(); } + auto rbegin() const { return this->children_.rbegin(); } + auto rend() const { return this->children_.rend(); } bool is_leaf() const { return children_.empty(); } bool is_root() const { return parent_ == nullptr; } @@ -163,6 +163,17 @@ public: */ bool empty() const { return nodes_.size() == static_cast(1); } + /** + * @brief Returns the number of *non-empty* entries in the tree, viz. the + * number of nodes in the tree that have an action mapped to them + */ + size_t get_num_entries() const { return !empty() ? (nodes_.size() - 1) : static_cast(0); } + + /** + * @brief Returns the number of nodes in the tree, including the root node + */ + size_t get_num_nodes() const { return nodes_.size(); } + /** * @brief Gets the actor of the node that is the "smallest" (with respect * to the tree's "<" relation) single-process node. @@ -179,6 +190,9 @@ public: */ std::optional get_min_single_process_node() const; + /** @brief Describes how a tree insertion was carried out */ + enum class InsertionResult { leaf, interior_node, root }; + /** * @brief Inserts an sequence `seq` of processes into the tree * such that that this tree is a wakeup tree relative to the @@ -203,8 +217,11 @@ public: * * @invariant: It is assumed that this tree is a wakeup tree * with respect to the given execution `E` + * + * @return Whether a sequence equivalent to `seq` is already contained + * as a leaf node in the tree */ - void insert(const Execution& E, const PartialExecution& seq); + InsertionResult insert(const Execution& E, const PartialExecution& seq); }; } // namespace simgrid::mc::odpor