a binary heap event scheduler More...
#include <heap-scheduler.h>
Inheritance diagram for ns3::HeapScheduler:
Collaboration diagram for ns3::HeapScheduler:Public Member Functions | |
| HeapScheduler () | |
| virtual | ~HeapScheduler () |
| virtual void | Insert (const Event &ev) |
| virtual bool | IsEmpty (void) const |
| virtual Event | PeekNext (void) const |
| virtual void | Remove (const Event &ev) |
| virtual Event | RemoveNext (void) |
| This method cannot be invoked if the list is empty. More... | |
Public Member Functions inherited from ns3::Scheduler | |
| virtual | ~Scheduler ()=0 |
| virtual void | Insert (const Event &ev)=0 |
| virtual void | Remove (const Event &ev)=0 |
Public Member Functions inherited from ns3::Object | |
| Object () | |
| virtual | ~Object () |
| void | AggregateObject (Ptr< Object > other) |
| void | Dispose (void) |
| Run the DoDispose methods of this object and all the objects aggregated to it. More... | |
| AggregateIterator | GetAggregateIterator (void) const |
| virtual TypeId | GetInstanceTypeId (void) const |
| template<typename T > | |
| Ptr< T > | GetObject (void) const |
| template<typename T > | |
| Ptr< T > | GetObject (TypeId tid) const |
| void | Initialize (void) |
| This method calls the virtual DoInitialize method on all the objects aggregated to this object. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
| SimpleRefCount () | |
| Constructor. More... | |
| SimpleRefCount (const SimpleRefCount &o) | |
| Copy constructor. More... | |
| uint32_t | GetReferenceCount (void) const |
| Get the reference count of the object. More... | |
| SimpleRefCount & | operator= (const SimpleRefCount &o) |
| Assignment. More... | |
| void | Ref (void) const |
| Increment the reference count. More... | |
| void | Unref (void) const |
| Decrement the reference count. More... | |
Public Member Functions inherited from ns3::ObjectBase | |
| virtual | ~ObjectBase () |
| Virtual destructor. More... | |
| void | GetAttribute (std::string name, AttributeValue &value) const |
| bool | GetAttributeFailSafe (std::string name, AttributeValue &attribute) const |
| void | SetAttribute (std::string name, const AttributeValue &value) |
| bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
| bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
| bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
| bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
| bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Static Public Member Functions | |
| static TypeId | GetTypeId (void) |
Static Public Member Functions inherited from ns3::Scheduler | |
| static TypeId | GetTypeId (void) |
Static Public Member Functions inherited from ns3::Object | |
| static TypeId | GetTypeId (void) |
| Register this type. More... | |
Static Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
| static void | Cleanup (void) |
| Noop. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
| static TypeId | GetTypeId (void) |
| Get the type ID. More... | |
Private Types | |
| typedef std::vector< Event > | BinaryHeap |
Private Member Functions | |
| void | BottomUp (void) |
| void | Exch (uint32_t a, uint32_t b) |
| bool | IsBottom (uint32_t id) const |
| bool | IsLessStrictly (uint32_t a, uint32_t b) const |
| bool | IsRoot (uint32_t id) const |
| uint32_t | Last (void) const |
| uint32_t | LeftChild (uint32_t id) const |
| uint32_t | Parent (uint32_t id) const |
| uint32_t | RightChild (uint32_t id) const |
| uint32_t | Root (void) const |
| uint32_t | Sibling (uint32_t id) const |
| uint32_t | Smallest (uint32_t a, uint32_t b) const |
| void | TopDown (uint32_t start) |
Private Attributes | |
| BinaryHeap | m_heap |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::Object | |
| Object (const Object &o) | |
| virtual void | DoDispose (void) |
| This method is called by Object::Dispose or by the object's destructor, whichever comes first. More... | |
| virtual void | DoInitialize (void) |
| This method is called only once by Object::Initialize. More... | |
| virtual void | NotifyNewAggregate (void) |
| This method is invoked whenever two sets of objects are aggregated together. More... | |
Protected Member Functions inherited from ns3::ObjectBase | |
| void | ConstructSelf (const AttributeConstructionList &attributes) |
| virtual void | NotifyConstructionCompleted (void) |
| This method is invoked once all member attributes have been initialized. More... | |
a binary heap event scheduler
Doxygen introspection did not find any typical Config paths.
This code started as a c++ translation of a java-based code written in 2005 to implement a heap sort. So, this binary heap is really a pretty straightforward implementation of the classic data structure. Not much to say about it.
What is smart about this code ?
No Attributes are defined for this type.
No TraceSources are defined for this type.
Definition at line 47 of file heap-scheduler.h.
|
private |
Definition at line 62 of file heap-scheduler.h.
| ns3::HeapScheduler::HeapScheduler | ( | ) |
Definition at line 44 of file heap-scheduler.cc.
References m_heap, and NS_LOG_FUNCTION.
|
virtual |
Definition at line 54 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
|
private |
Definition at line 146 of file heap-scheduler.cc.
References Exch(), IsLessStrictly(), IsRoot(), Last(), NS_LOG_FUNCTION, and Parent().
Referenced by Insert().
Here is the call graph for this function:
Here is the caller graph for this function:
|
inlineprivate |
Definition at line 114 of file heap-scheduler.cc.
References m_heap, NS_ASSERT, NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by BottomUp(), Remove(), RemoveNext(), and TopDown().
Here is the caller graph for this function:
|
static |
Definition at line 35 of file heap-scheduler.cc.
References ns3::TypeId::SetParent().
Here is the call graph for this function:
|
virtual |
Definition at line 195 of file heap-scheduler.cc.
References BottomUp(), m_heap, and NS_LOG_FUNCTION.
Here is the call graph for this function:
|
inlineprivate |
Definition at line 107 of file heap-scheduler.cc.
References m_heap, and NS_LOG_FUNCTION.
Referenced by TopDown().
Here is the caller graph for this function:
|
virtual |
Implements ns3::Scheduler.
Definition at line 139 of file heap-scheduler.cc.
References m_heap, and NS_LOG_FUNCTION.
|
inlineprivate |
Definition at line 125 of file heap-scheduler.cc.
References m_heap, and NS_LOG_FUNCTION.
Referenced by BottomUp(), Smallest(), and TopDown().
Here is the caller graph for this function:
|
inlineprivate |
Definition at line 92 of file heap-scheduler.cc.
References NS_LOG_FUNCTION, and Root().
Referenced by BottomUp().
Here is the call graph for this function:
Here is the caller graph for this function:
|
private |
Definition at line 99 of file heap-scheduler.cc.
References m_heap, and NS_LOG_FUNCTION.
Referenced by BottomUp(), Remove(), and RemoveNext().
Here is the caller graph for this function:
|
inlineprivate |
Definition at line 72 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
Referenced by TopDown().
Here is the caller graph for this function:
|
inlineprivate |
Definition at line 60 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
Referenced by BottomUp().
Here is the caller graph for this function:
|
virtual |
This method cannot be invoked if the list is empty.
Implements ns3::Scheduler.
Definition at line 203 of file heap-scheduler.cc.
References m_heap, NS_LOG_FUNCTION, and Root().
Here is the call graph for this function:
|
virtual |
Definition at line 221 of file heap-scheduler.cc.
References Exch(), Last(), m_heap, NS_ASSERT, NS_LOG_FUNCTION, and TopDown().
Here is the call graph for this function:
|
virtual |
This method cannot be invoked if the list is empty.
Remove the next earliest event from the event list.
Implements ns3::Scheduler.
Definition at line 209 of file heap-scheduler.cc.
References Exch(), Last(), m_heap, NS_LOG_FUNCTION, Root(), and TopDown().
Here is the call graph for this function:
|
inlineprivate |
Definition at line 78 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
Referenced by TopDown().
Here is the caller graph for this function:
|
inlineprivate |
Definition at line 85 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
Referenced by IsRoot(), PeekNext(), and RemoveNext().
Here is the caller graph for this function:
|
private |
Definition at line 66 of file heap-scheduler.cc.
References NS_LOG_FUNCTION.
|
inlineprivate |
Definition at line 132 of file heap-scheduler.cc.
References IsLessStrictly(), and NS_LOG_FUNCTION.
Referenced by TopDown().
Here is the call graph for this function:
Here is the caller graph for this function:
|
private |
Definition at line 159 of file heap-scheduler.cc.
References Exch(), IsBottom(), IsLessStrictly(), LeftChild(), NS_ASSERT, NS_LOG_FUNCTION, RightChild(), Smallest(), and visualizer.core::start().
Referenced by Remove(), and RemoveNext().
Here is the call graph for this function:
Here is the caller graph for this function:
|
private |
Definition at line 80 of file heap-scheduler.h.
Referenced by Exch(), HeapScheduler(), Insert(), IsBottom(), IsEmpty(), IsLessStrictly(), Last(), PeekNext(), Remove(), and RemoveNext().