21 #include "ns3/simulator.h" 22 #include "ns3/boolean.h" 23 #include "ns3/config.h" 24 #include "ns3/waypoint-mobility-model.h" 44 :
TestCase (lazy ?
"Check Waypoint Mobility Model LAZY notification accuracy" 45 :
"Check Waypoint Mobility Model NON-LAZY notification accuracy"),
60 virtual void DoRun (
void);
61 virtual void DoTeardown (
void);
63 void ForceUpdates (
void);
74 mobilityStack.clear();
85 mobilityFactory.
SetTypeId (
"ns3::WaypointMobilityModel");
89 for (uint32_t i = 0; i < mobilityCount; i++)
95 mobilityStack.push_back (model);
102 for ( uint32_t iw = 0; iw < waypointCount; ++iw )
105 waypoints.push_back (wpt);
109 std::vector<Ptr<MobilityModel> >::iterator i;
110 for (i = mobilityStack.begin (); i != mobilityStack.end (); ++i)
115 for ( std::deque<Waypoint>::iterator w = waypoints.begin (); w != waypoints.end (); ++w )
122 for (
double updateTime = 0.5; updateTime <= ((double)waypointCount + 1.5); updateTime += 1.0 )
134 std::vector<Ptr<MobilityModel> >::iterator i;
135 for (i = mobilityStack.begin (); i != mobilityStack.end (); ++i)
154 "Course didn't change on one second time boundary with NON-LAZY notifications");
160 "Course didn't change between waypoints with LAZY notifications");
174 :
TestCase (
"Check Waypoint Mobility Model waypoint add")
187 virtual void DoRun (
void);
188 virtual void DoTeardown (
void);
206 m_waypointCount = 10;
207 m_waypointCounter = 1;
210 mobilityFactory.
SetTypeId (
"ns3::WaypointMobilityModel");
221 Waypoint m_nextWaypoint (
Seconds (m_waypointCounter), Vector (0.0, 0.0, 0.0));
235 std::cout << now <<
" CourseChangeCallback" << std::endl;
239 if (now <
Seconds ((
double)m_waypointCount) )
241 m_waypointCounter ++;
242 m_nextWaypoint =
Waypoint (
Seconds (m_waypointCounter), Vector (0.0, 0.0, 0.0));
Simulation virtual time values and global simulation resolution.
Waypoint Mobility Model Notify Test.
Time time
The waypoint time.
Smart pointer class similar to boost::intrusive_ptr.
uint32_t mobilityCount
mobility count
AttributeValue implementation for Boolean.
void CourseChangeCallback(Ptr< const MobilityModel > model)
Course change callback.
void AddWaypoint(const Waypoint &waypoint)
double GetSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
virtual void DoRun(void)
Implementation to actually run this TestCase.
static void Run(void)
Run the simulation.
void SetTypeId(TypeId tid)
Set the TypeId of the Objects to be created by this factory.
#define NS_TEST_EXPECT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report if not.
uint32_t waypointCount
waypoint count
virtual ~WaypointMobilityModelNotifyTest()
bool lazyNotify
lazy notify?
Keep track of the current position and velocity of an object.
uint32_t m_waypointCount
waypoint count
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay.
Ptr< Object > Create(void) const
Create an Object instance of the configured TypeId.
WaypointMobilityModelAddWaypointTest()
Ptr< MobilityModel > m_mobilityModel
mobility model
virtual void DoRun(void)
Implementation to actually run this TestCase.
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
virtual ~WaypointMobilityModelAddWaypointTest()
virtual void DoTeardown(void)
Implementation to do any local setup required for this TestCase.
static void Destroy(void)
Execute the events scheduled with ScheduleDestroy().
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
Waypoint m_nextWaypoint
next waypoint
bool TraceConnectWithoutContext(std::string name, const CallbackBase &cb)
Connect a TraceSource to a Callback without a context.
virtual void Update(void) const
Update the underlying state corresponding to the stored waypoints.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
void CourseChangeCallback(Ptr< const MobilityModel > model)
Course change calback.
WaypointMobilityModelTestSuite g_waypointMobilityModelTestSuite
the test suite
void Set(std::string name, const AttributeValue &value)
Set an attribute to be set during construction.
static Time Now(void)
Return the current simulation virtual time.
void ForceUpdates(void)
Force updates.
Instantiate subclasses of ns3::Object.
WaypointMobilityModelNotifyTest(bool lazy)
Constructor.
static void Stop(void)
Tell the Simulator the calling event should be the last one executed.
Waypoint Mobility Model Test Suite.
Time Seconds(double value)
Construct a Time in the indicated unit.
Waypoint m_current
The ns3::Waypoint currently being used.
Waypoint-based mobility model.
std::deque< Waypoint > waypoints
waypoints
virtual void DoTeardown(void)
Implementation to do any local setup required for this TestCase.
Waypoint Mobility Model Add Waypoint Test.
WaypointMobilityModelTestSuite()
uint32_t m_waypointCounter
waypoint counter
std::vector< Ptr< MobilityModel > > mobilityStack
mobilty model
void Initialize(void)
Invoke DoInitialize on all Objects aggregated to this one.
static void CourseChangeCallback(std::string path, Ptr< const MobilityModel > model)