A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
mobility-model.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2006,2007 INRIA
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
18 */
19#ifndef MOBILITY_MODEL_H
20#define MOBILITY_MODEL_H
21
22#include "ns3/object.h"
23#include "ns3/traced-callback.h"
24#include "ns3/vector.h"
25
26namespace ns3
27{
28
29/**
30 * \ingroup mobility
31 * \brief Keep track of the current position and velocity of an object.
32 *
33 * All space coordinates in this class and its subclasses are
34 * understood to be meters or meters/s. i.e., they are all
35 * metric international units.
36 *
37 * This is a base class for all specific mobility models.
38 */
39class MobilityModel : public Object
40{
41 public:
42 /**
43 * Register this type with the TypeId system.
44 * \return the object TypeId
45 */
46 static TypeId GetTypeId();
48 ~MobilityModel() override = 0;
49
50 /**
51 * \return the current position
52 */
53 Vector GetPosition() const;
54 /**
55 * This method may be used if the position returned may depend on some
56 * reference position provided. For example, in a hierarchical mobility
57 * model that is buildings-aware, the child mobility model may not be able
58 * to determine if it is inside or outside of a building unless it knows
59 * the parent position.
60 *
61 * \param referencePosition reference position to consider
62 * \return the current position based on the provided referencePosition
63 * \sa ns3::MobilityModel::DoGetPositionWithReference
64 */
65 Vector GetPositionWithReference(const Vector& referencePosition) const;
66 /**
67 * \param position the position to set.
68 */
69 void SetPosition(const Vector& position);
70 /**
71 * \return the current velocity.
72 */
73 Vector GetVelocity() const;
74 /**
75 * \param position a reference to another mobility model
76 * \return the distance between the two objects. Unit is meters.
77 */
78 double GetDistanceFrom(Ptr<const MobilityModel> position) const;
79 /**
80 * \param other reference to another object's mobility model
81 * \return the relative speed between the two objects. Unit is meters/s.
82 */
84 /**
85 * Assign a fixed random variable stream number to the random variables
86 * used by this model. Return the number of streams (possibly zero) that
87 * have been assigned.
88 *
89 * \param stream first stream index to use
90 * \return the number of stream indices assigned by this model
91 */
92 int64_t AssignStreams(int64_t stream);
93
94 /**
95 * TracedCallback signature.
96 *
97 * \param [in] model Value of the MobilityModel.
98 */
100
101 protected:
102 /**
103 * Must be invoked by subclasses when the course of the
104 * position changes to notify course change listeners.
105 */
106 void NotifyCourseChange() const;
107
108 private:
109 /**
110 * \return the current position.
111 *
112 * Concrete subclasses of this base class must
113 * implement this method.
114 */
115 virtual Vector DoGetPosition() const = 0;
116 /**
117 * \param referencePosition the reference position to consider
118 * \return the current position.
119 *
120 * Unless subclasses override, this method will disregard the reference
121 * position and return "DoGetPosition ()".
122 */
123 virtual Vector DoGetPositionWithReference(const Vector& referencePosition) const;
124 /**
125 * \param position the position to set.
126 *
127 * Concrete subclasses of this base class must
128 * implement this method.
129 */
130 virtual void DoSetPosition(const Vector& position) = 0;
131 /**
132 * \return the current velocity.
133 *
134 * Concrete subclasses of this base class must
135 * implement this method.
136 */
137 virtual Vector DoGetVelocity() const = 0;
138 /**
139 * The default implementation does nothing but return the passed-in
140 * parameter. Subclasses using random variables are expected to
141 * override this.
142 * \param start starting stream index
143 * \return the number of streams used
144 */
145 virtual int64_t DoAssignStreams(int64_t start);
146
147 /**
148 * Used to alert subscribers that a change in direction, velocity,
149 * or position has occurred.
150 */
152};
153
154} // namespace ns3
155
156#endif /* MOBILITY_MODEL_H */
Keep track of the current position and velocity of an object.
ns3::TracedCallback< Ptr< const MobilityModel > > m_courseChangeTrace
Used to alert subscribers that a change in direction, velocity, or position has occurred.
Vector GetPositionWithReference(const Vector &referencePosition) const
This method may be used if the position returned may depend on some reference position provided.
static TypeId GetTypeId()
Register this type with the TypeId system.
double GetDistanceFrom(Ptr< const MobilityModel > position) const
~MobilityModel() override=0
double GetRelativeSpeed(Ptr< const MobilityModel > other) const
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
virtual Vector DoGetPosition() const =0
virtual Vector DoGetPositionWithReference(const Vector &referencePosition) const
Vector GetVelocity() const
virtual void DoSetPosition(const Vector &position)=0
virtual int64_t DoAssignStreams(int64_t start)
The default implementation does nothing but return the passed-in parameter.
Vector GetPosition() const
void SetPosition(const Vector &position)
void NotifyCourseChange() const
Must be invoked by subclasses when the course of the position changes to notify course change listene...
virtual Vector DoGetVelocity() const =0
A base class which provides memory management and object aggregation.
Definition: object.h:89
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Forward calls to a chain of Callback.
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.