22 #include <ns3/callback.h>
23 #include <ns3/packet.h>
24 #include <ns3/simulator.h>
25 #include <ns3/lr-wpan-error-model.h>
26 #include <ns3/propagation-loss-model.h>
27 #include <ns3/lr-wpan-net-device.h>
28 #include <ns3/lr-wpan-mac.h>
30 #include <ns3/net-device.h>
31 #include <ns3/single-model-spectrum-channel.h>
32 #include <ns3/mac16-address.h>
33 #include <ns3/constant-position-mobility-model.h>
34 #include "ns3/rng-seed-manager.h"
62 virtual void DoRun (
void);
86 virtual void DoRun (
void);
90 :
TestCase (
"Test the 802.15.4 error model vs distance"),
109 RngSeedManager::SetSeed (1);
110 RngSeedManager::SetRun (6);
125 channel->AddPropagationLossModel (model);
131 dev0->
GetPhy ()->SetMobility (mob0);
133 dev1->
GetPhy ()->SetMobility (mob1);
137 dev1->
GetMac ()->SetMcpsDataIndicationCallback (cb0);
148 mob0->SetPosition (Vector (0,0,0));
149 mob1->SetPosition (Vector (100,0,0));
150 for (
int i = 0; i < 1000; i++)
152 p = Create<Packet> (20);
153 Simulator::Schedule (
Seconds (i),
154 &LrWpanMac::McpsDataRequest,
155 dev0->
GetMac (), params, p);
164 Simulator::Destroy ();
169 :
TestCase (
"Test the 802.15.4 error model")
185 double ber = 1.0 - model->GetChunkSuccessRate (pow (10.0, snr / 10.0), 1);
188 ber = 1.0 - model->GetChunkSuccessRate (pow (10.0, snr / 10.0), 1);
191 ber = 1.0 - model->GetChunkSuccessRate (pow (10.0, snr / 10.0), 1);
194 ber = 1.0 - model->GetChunkSuccessRate (pow (10.0, snr / 10.0), 1);
197 ber = 1.0 - model->GetChunkSuccessRate (pow (10.0, snr / 10.0), 1);
214 :
TestSuite (
"lr-wpan-error-model", UNIT)
LrWpan Error Vs Distance Test.
void Callback(McpsDataIndicationParams params, Ptr< Packet > p)
Function to be called when a packet is received.
virtual ~LrWpanErrorDistanceTestCase()
LrWpanErrorDistanceTestCase()
virtual void DoRun(void)
Implementation to actually run this TestCase.
uint32_t m_received
The number of received packets.
uint32_t GetReceived(void) const
Get the number of received packets.
virtual ~LrWpanErrorModelTestCase()
LrWpanErrorModelTestCase()
virtual void DoRun(void)
Implementation to actually run this TestCase.
LrWpan Error model TestSuite.
LrWpanErrorModelTestSuite()
virtual void SetAddress(Address address)
This method indirects to LrWpanMac::SetShortAddress ()
void SetChannel(Ptr< SpectrumChannel > channel)
Set the channel to which the NetDevice, and therefore the PHY, should be attached to.
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
Ptr< LrWpanPhy > GetPhy(void) const
Get the PHY used by this NetDevice.
Ptr< LrWpanMac > GetMac(void) const
Get the MAC used by this NetDevice.
This class can contain 16 bit addresses.
uint32_t AddDevice(Ptr< NetDevice > device)
Associate a NetDevice to this node.
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#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_EQ_TOL(actual, limit, tol, msg)
Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and...
Time Seconds(double value)
Construct a Time in the indicated unit.
static LrWpanErrorModelTestSuite g_lrWpanErrorModelTestSuite
Static variable for test initialization.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Ts... > MakeCallback(R(T::*memPtr)(Ts...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
MCPS-DATA.indication params.
MCPS-DATA.request params.
LrWpanAddressMode m_srcAddrMode
Source address mode.
LrWpanAddressMode m_dstAddrMode
Destination address mode.
uint16_t m_dstPanId
Destination PAN identifier.
Mac16Address m_dstAddr
Destination address.
uint8_t m_msduHandle
MSDU handle.
uint8_t m_txOptions
Tx Options (bitfield)