Hierarchical mobility model. More...
#include "hierarchical-mobility-model.h"
Public Member Functions | |
HierarchicalMobilityModel () | |
Ptr< MobilityModel > | GetChild (void) const |
Ptr< MobilityModel > | GetParent (void) const |
void | SetChild (Ptr< MobilityModel > model) |
Sets the child mobility model to a new one, possibly replacing an existing one. More... | |
void | SetParent (Ptr< MobilityModel > model) |
Sets the parent mobility model to a new one, possibly replacing an existing one. More... | |
Public Member Functions inherited from ns3::MobilityModel | |
MobilityModel () | |
virtual | ~MobilityModel ()=0 |
int64_t | AssignStreams (int64_t stream) |
Assign a fixed random variable stream number to the random variables used by this model. More... | |
double | GetDistanceFrom (Ptr< const MobilityModel > position) const |
Vector | GetPosition (void) const |
Vector | GetPositionWithReference (const Vector &referencePosition) const |
This method may be used if the position returned may depend on some reference position provided. More... | |
double | GetRelativeSpeed (Ptr< const MobilityModel > other) const |
Vector | GetVelocity (void) const |
void | SetPosition (const Vector &position) |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
virtual | ~Object () |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose (void) |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator (void) const |
Get an iterator to the Objects aggregated to this one. More... | |
virtual TypeId | GetInstanceTypeId (void) const |
Get the most derived TypeId for this Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (void) const |
Get a pointer to the requested aggregated Object. More... | |
void | Initialize (void) |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized (void) const |
Check if the object has been initialized. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount (void) const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= ([[maybe_unused]] const SimpleRefCount &o) |
Assignment operator. 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 |
Get the value of an attribute, raising fatal errors if unsuccessful. More... | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising erros. More... | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. More... | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. More... | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. More... | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. More... | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. More... | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. More... | |
Static Public Member Functions | |
static TypeId | GetTypeId (void) |
Register this type with the TypeId system. More... | |
Static Public Member Functions inherited from ns3::MobilityModel | |
static TypeId | GetTypeId (void) |
Register this type with the TypeId system. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId (void) |
Get the type ID. More... | |
Private Member Functions | |
void | ChildChanged (Ptr< const MobilityModel > model) |
Callback for when child mobility model course change occurs. More... | |
virtual int64_t | DoAssignStreams (int64_t) |
The default implementation does nothing but return the passed-in parameter. More... | |
virtual Vector | DoGetPosition (void) const |
virtual Vector | DoGetVelocity (void) const |
virtual void | DoInitialize (void) |
Initialize() implementation. More... | |
virtual void | DoSetPosition (const Vector &position) |
void | ParentChanged (Ptr< const MobilityModel > model) |
Callback for when parent mobility model course change occurs. More... | |
Private Attributes | |
Ptr< MobilityModel > | m_child |
pointer to child mobility model More... | |
Ptr< MobilityModel > | m_parent |
pointer to parent mobility model More... | |
Additional Inherited Members | |
Public Types inherited from ns3::MobilityModel | |
typedef void(* | TracedCallback) (Ptr< const MobilityModel > model) |
TracedCallback signature. More... | |
Protected Member Functions inherited from ns3::MobilityModel | |
void | NotifyCourseChange (void) const |
Must be invoked by subclasses when the course of the position changes to notify course change listeners. More... | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoDispose (void) |
Destructor implementation. More... | |
virtual void | NotifyNewAggregate (void) |
Notify all Objects aggregated to this one of a new Object being aggregated. More... | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. More... | |
virtual void | NotifyConstructionCompleted (void) |
Notifier called once the ObjectBase is fully constructed. More... | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid (void) |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
Hierarchical mobility model.
This model allows you to specify the position of a child object relative to a parent object.
Basically this is a mobility model that combines two other mobility models: a "parent" model and a "child" model. The position of the hierarchical model is always the vector sum of the parent + child positions, so that if the parent model "moves", then this model will report an equal relative movement. Useful, for instance, if you want to simulate a node inside another node that moves, such as a vehicle.
Setting the position on this model is always done using world absolute coordinates, and it changes only the child mobility model position, never the parent. The child mobility model always uses a coordinate system relative to the parent model position.
ns3::HierarchicalMobilityModel is accessible through the following paths with Config::Set and Config::Connect:
No TraceSources are defined for this type.
Size of this type is 72 bytes (on a 64-bit architecture).
Definition at line 57 of file hierarchical-mobility-model.h.
ns3::HierarchicalMobilityModel::HierarchicalMobilityModel | ( | ) |
Definition at line 52 of file hierarchical-mobility-model.cc.
References NS_LOG_FUNCTION.
|
private |
Callback for when child mobility model course change occurs.
model | mobility mode (unused) |
Definition at line 184 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::NotifyCourseChange().
Referenced by SetChild().
|
privatevirtual |
The default implementation does nothing but return the passed-in parameter.
Subclasses using random variables are expected to override this.
start | starting stream index |
Reimplemented from ns3::MobilityModel.
Definition at line 201 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::AssignStreams(), m_child, m_parent, and NS_LOG_FUNCTION.
|
privatevirtual |
Concrete subclasses of this base class must implement this method.
Implements ns3::MobilityModel.
Definition at line 124 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::GetPosition(), ns3::MobilityModel::GetPositionWithReference(), m_child, and m_parent.
|
privatevirtual |
Concrete subclasses of this base class must implement this method.
Implements ns3::MobilityModel.
Definition at line 160 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::GetVelocity(), m_child, and m_parent.
|
privatevirtual |
Initialize() implementation.
This method is called only once by Initialize(). If the user calls Initialize() multiple times, DoInitialize() is called only the first time.
Subclasses are expected to override this method and chain up to their parent's implementation once they are done. It is safe to call GetObject() and AggregateObject() from within this method.
Reimplemented from ns3::Object.
Definition at line 190 of file hierarchical-mobility-model.cc.
References ns3::Object::Initialize(), ns3::Object::IsInitialized(), m_child, m_parent, and NS_LOG_FUNCTION.
|
privatevirtual |
position | the position to set. |
Concrete subclasses of this base class must implement this method.
Implements ns3::MobilityModel.
Definition at line 137 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::GetPosition(), m_child, m_parent, NS_LOG_FUNCTION, and ns3::MobilityModel::SetPosition().
Ptr< MobilityModel > ns3::HierarchicalMobilityModel::GetChild | ( | void | ) | const |
Calling GetPosition() on the model returned by this method allows one to access the position of the child relative to its parent.
Definition at line 112 of file hierarchical-mobility-model.cc.
References m_child.
Referenced by GetTypeId().
Ptr< MobilityModel > ns3::HierarchicalMobilityModel::GetParent | ( | void | ) | const |
Calling GetPosition() on the model returned by this method allows one to access the position of the parent alone, which is used as the reference position to which the child position is added.
Definition at line 118 of file hierarchical-mobility-model.cc.
References m_parent.
Referenced by GetTypeId().
|
static |
Register this type with the TypeId system.
Definition at line 32 of file hierarchical-mobility-model.cc.
References GetChild(), GetParent(), ns3::MakePointerAccessor(), SetChild(), SetParent(), and ns3::TypeId::SetParent().
|
private |
Callback for when parent mobility model course change occurs.
model | mobility mode (unused) |
Definition at line 178 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::NotifyCourseChange().
Referenced by SetParent().
void ns3::HierarchicalMobilityModel::SetChild | ( | Ptr< MobilityModel > | model | ) |
Sets the child mobility model to a new one, possibly replacing an existing one.
If the child model is being replaced, then the new child mobility model's current position is also set to the previous position to ensure that the composite position is preserved by this operation.
model | new mobility model child |
Definition at line 60 of file hierarchical-mobility-model.cc.
References ChildChanged(), ns3::MobilityModel::GetPosition(), m_child, ns3::MakeCallback(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::MobilityModel::SetPosition(), ns3::ObjectBase::TraceConnectWithoutContext(), and ns3::ObjectBase::TraceDisconnectWithoutContext().
Referenced by GetTypeId().
void ns3::HierarchicalMobilityModel::SetParent | ( | Ptr< MobilityModel > | model | ) |
Sets the parent mobility model to a new one, possibly replacing an existing one.
If the parent model is being replaced, then the new position is set to the position that was set before replacement, to ensure that the composite position is preserved across changes to the parent model.
model | new mobility model parent |
Definition at line 84 of file hierarchical-mobility-model.cc.
References ns3::MobilityModel::GetPosition(), m_child, m_parent, ns3::MakeCallback(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ParentChanged(), ns3::MobilityModel::SetPosition(), ns3::ObjectBase::TraceConnectWithoutContext(), and ns3::ObjectBase::TraceDisconnectWithoutContext().
Referenced by GetTypeId().
|
private |
pointer to child mobility model
Definition at line 120 of file hierarchical-mobility-model.h.
Referenced by DoAssignStreams(), DoGetPosition(), DoGetVelocity(), DoInitialize(), DoSetPosition(), GetChild(), SetChild(), and SetParent().
|
private |
pointer to parent mobility model
Definition at line 121 of file hierarchical-mobility-model.h.
Referenced by DoAssignStreams(), DoGetPosition(), DoGetVelocity(), DoInitialize(), DoSetPosition(), GetParent(), and SetParent().