22#include <ns3/building-position-allocator.h> 
   23#include <ns3/building.h> 
   24#include <ns3/buildings-helper.h> 
   25#include <ns3/constant-position-mobility-model.h> 
   26#include <ns3/mobility-building-info.h> 
   27#include <ns3/mobility-helper.h> 
   28#include <ns3/mobility-model.h> 
   29#include <ns3/simulator.h> 
   72    return ((a.
x < b.
x) || ((a.
x == b.
x) && (a.
y < b.
y)) ||
 
   73            ((a.
x == b.
x) && (a.
y == b.
y) && (a.
z < b.
z)));
 
   88    void DoRun() 
override;
 
   92    : 
TestCase(
"RandomRoom, 12 rooms, 24 nodes")
 
  103    b->SetBoundaries(
Box(1, 3, 1, 4, 1, 3));
 
  112    mobility.SetMobilityModel(
"ns3::ConstantPositionMobilityModel");
 
  114    mobility.SetPositionAllocator(positionAlloc);
 
  115    mobility.Install(
nodes);
 
  118    std::map<Room, uint32_t> roomCounter;
 
  123        NS_ASSERT_MSG(mm, 
"no mobility model aggregated to this node");
 
  126                      "MobilityBuildingInfo has not been aggregated to this node mobility model");
 
  129        Room r(bmm->GetRoomNumberX(), bmm->GetRoomNumberY(), bmm->GetFloorNumber());
 
  132        Vector p = mm->GetPosition();
 
  141    for (
auto it = roomCounter.begin(); it != roomCounter.end(); ++it)
 
  166    void DoRun() 
override;
 
  181    b->SetBoundaries(
Box(-10, -6, 20, 26, -1, 5));
 
  190    mobility.SetMobilityModel(
"ns3::ConstantPositionMobilityModel");
 
  192    mobility.SetPositionAllocator(positionAlloc);
 
  193    mobility.Install(
nodes);
 
  198    positionAlloc = CreateObject<SameRoomPositionAllocator>(
nodes);
 
  199    mobility.SetPositionAllocator(positionAlloc);
 
  200    mobility.Install(copyNodes);
 
  203    std::map<Room, uint32_t> roomCounter;
 
  205    for (
auto it = copyNodes.
Begin(); it != copyNodes.
End(); ++it)
 
  208        NS_ASSERT_MSG(mm, 
"no mobility model aggregated to this node");
 
  211                      "MobilityBuildingInfo has not been aggregated to this node mobility model");
 
  214        Room r(bmm->GetRoomNumberX(), bmm->GetRoomNumberY(), bmm->GetFloorNumber());
 
  218    for (
auto it = roomCounter.begin(); it != roomCounter.end(); ++it)
 
  241    : 
TestSuite(
"building-position-allocator", UNIT)
 
bool operator<(const Room &a, const Room &b)
static BuildingPositionAllocatorTestSuite buildingsPositionAllocatorTestSuiteInstance
Static variable for test initialization.
RandomRoomPositionAllocator TestSuite.
BuildingPositionAllocatorTestSuite()
RandomRoomPositionAllocator test.
void DoRun() override
Implementation to actually run this TestCase.
RandomRoomPositionAllocatorTestCase()
SameRoomPositionAllocator test.
SameRoomPositionAllocatorTestCase()
void DoRun() override
Implementation to actually run this TestCase.
static void Install(Ptr< Node > node)
Install the MobilityBuildingInfo to a node.
mobility buildings information (to be used by mobility models)
Helper class used to assign positions and mobility models to nodes.
Keep track of the current position and velocity of an object.
keep track of a set of node pointers.
Iterator End() const
Get an iterator which indicates past-the-last Node in the container.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
Iterator Begin() const
Get an iterator which refers to the first Node in the container.
Smart pointer class similar to boost::intrusive_ptr.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_TEST_ASSERT_MSG_LT(actual, limit, msg)
Test that an actual value is less than a limit and report and abort if not.
#define NS_TEST_ASSERT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report and abort if not.
#define NS_TEST_ASSERT_MSG_GT(actual, limit, msg)
Test that an actual value is greater than a limit and report and abort if not.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
uint32_t z
Z coord (floor)
Room(uint32_t xx, uint32_t yy, uint32_t zz)
Constructor.