25#include "ns3/config.h"
26#include "ns3/error-model.h"
28#include "ns3/lte-rlc-header.h"
29#include "ns3/lte-rlc-um.h"
30#include "ns3/net-device-container.h"
31#include "ns3/node-container.h"
32#include "ns3/packet.h"
33#include "ns3/pointer.h"
34#include "ns3/radio-bearer-stats-calculator.h"
35#include "ns3/rng-seed-manager.h"
36#include "ns3/simulator.h"
55 double losses[] = {0.0, 0.10, 0.25, 0.50, 0.75, 0.90, 1.00};
56 uint32_t seeds[] = {1111, 2222, 3333, 4444, 5555, 6666, 7777, 8888, 9999, 10101};
58 for (
uint32_t l = 0; l < (
sizeof(losses) /
sizeof(
double)); l++)
62 std::ostringstream name;
63 name <<
" Losses = " << losses[l] <<
"%. Seed = " << seeds[s];
67 testDuration = TestCase::QUICK;
71 testDuration = TestCase::EXTENSIVE;
117 uint16_t numberOfNodes = 1;
130 RngSeedManager::SetSeed(
m_seed);
136 lteSimpleHelper->SetAttribute(
"RlcEntity",
StringValue(
"RlcUm"));
141 enbNodes.
Create(numberOfNodes);
142 ueNodes.
Create(numberOfNodes);
170 ueLteDevs.
Get(0)->SetAttribute(
"ReceiveErrorModel",
PointerValue(dlEm));
171 ueLteDevs.
Get(0)->TraceConnectWithoutContext(
174 enbLteDevs.
Get(0)->SetAttribute(
"ReceiveErrorModel",
PointerValue(ulEm));
175 enbLteDevs.
Get(0)->TraceConnectWithoutContext(
180 lteSimpleHelper->m_enbRrc->SetArrivalTime(
Seconds(0.010));
181 lteSimpleHelper->m_enbRrc->SetPduSize(100);
184 lteSimpleHelper->m_enbMac->SetTxOppSize(150);
185 lteSimpleHelper->m_enbMac->SetTxOppTime(
Seconds(0.005));
186 lteSimpleHelper->m_enbMac->SetTxOpportunityMode(LteTestMac::RANDOM_MODE);
189 lteSimpleHelper->m_ueRrc->SetArrivalTime(
Seconds(0.010));
190 lteSimpleHelper->m_ueRrc->SetPduSize(100);
193 lteSimpleHelper->m_ueMac->SetTxOppSize(150);
194 lteSimpleHelper->m_ueMac->SetTxOppTime(
Seconds(0.005));
195 lteSimpleHelper->m_ueMac->SetTxOpportunityMode(LteTestMac::RANDOM_MODE);
198 Simulator::Schedule(
Seconds(0.100), &LteTestRrc::Start, lteSimpleHelper->m_enbRrc);
199 Simulator::Schedule(
Seconds(10.100), &LteTestRrc::Stop, lteSimpleHelper->m_enbRrc);
202 Simulator::Schedule(
Seconds(20.100), &LteTestRrc::Start, lteSimpleHelper->m_ueRrc);
203 Simulator::Schedule(
Seconds(30.100), &LteTestRrc::Stop, lteSimpleHelper->m_ueRrc);
205 Simulator::Stop(
Seconds(31.000));
208 uint32_t txEnbRrcPdus = lteSimpleHelper->m_enbRrc->GetTxPdus();
209 uint32_t rxUeRrcPdus = lteSimpleHelper->m_ueRrc->GetRxPdus();
211 uint32_t txUeRrcPdus = lteSimpleHelper->m_ueRrc->GetTxPdus();
212 uint32_t rxEnbRrcPdus = lteSimpleHelper->m_enbRrc->GetRxPdus();
232 "Downlink: TX PDUs (" << txEnbRrcPdus <<
") != RX PDUs (" << rxUeRrcPdus
236 "Uplink: TX PDUs (" << txUeRrcPdus <<
") != RX PDUs (" << rxEnbRrcPdus
239 Simulator::Destroy();
Test end-to-end flow when RLC UM is being used.
uint32_t m_dlDrops
number of Dl drops
double m_losses
error rate
void UlDropEvent(Ptr< const Packet > p)
UL drop event.
void DoRun() override
Implementation to actually run this TestCase.
void DlDropEvent(Ptr< const Packet > p)
DL drop event.
uint32_t m_seed
random number seed
uint32_t m_ulDrops
number of UL drops
~LteRlcUmE2eTestCase() override
Test suite for RlcUmE2eTestCase.
LteRlcUmE2eTestSuite()
Test x.x.x RLC UM: End-to-end flow.
This class can be used to hold variables of floating point type such as 'double' or 'float'.
holds a vector of ns3::NetDevice pointers
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr<NetDevice> stored in this container at a given index.
keep track of a set of node pointers.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
Hold objects of type Ptr<T>.
Hold variables of type string.
TestDuration
How long the test takes to execute.
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_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
#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.
Time Seconds(double value)
Construct a Time in the indicated unit.
static LteRlcUmE2eTestSuite lteRlcUmE2eTestSuite
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...