23#include <ns3/application-container.h> 
   24#include <ns3/friis-spectrum-propagation-loss.h> 
   25#include <ns3/internet-stack-helper.h> 
   26#include <ns3/ipv4-address-helper.h> 
   27#include <ns3/ipv4-interface-container.h> 
   28#include <ns3/ipv4-static-routing-helper.h> 
   30#include <ns3/lte-enb-net-device.h> 
   31#include <ns3/lte-helper.h> 
   32#include <ns3/lte-ue-net-device.h> 
   33#include <ns3/lte-ue-rrc.h> 
   34#include <ns3/mobility-helper.h> 
   35#include <ns3/net-device-container.h> 
   36#include <ns3/node-container.h> 
   37#include <ns3/packet-sink.h> 
   38#include <ns3/point-to-point-epc-helper.h> 
   39#include <ns3/point-to-point-helper.h> 
   40#include <ns3/simulator.h> 
   41#include <ns3/udp-client.h> 
   51    : 
TestSuite(
"lte-aggregation-throughput-scale", SYSTEM)
 
   85    auto lteHelper = CreateObject<LteHelper>();
 
   86    lteHelper->SetAttribute(
"PathlossModel",
 
   88    lteHelper->SetAttribute(
"NumberOfComponentCarriers", 
UintegerValue(numberOfComponentCarriers));
 
   89    lteHelper->SetAttribute(
"EnbComponentCarrierManager",
 
   92    auto epcHelper = CreateObject<PointToPointEpcHelper>();
 
   93    lteHelper->SetEpcHelper(epcHelper);
 
   95    auto enbNode = CreateObject<Node>();
 
   96    auto ueNode = CreateObject<Node>();
 
   97    auto pgwNode = epcHelper->GetPgwNode();
 
  100    mobility.SetMobilityModel(
"ns3::ConstantPositionMobilityModel");
 
  101    mobility.Install(enbNode);
 
  102    mobility.Install(ueNode);
 
  105    internet.Install(ueNode);
 
  108    ipv4h.
SetBase(
"1.0.0.0", 
"255.0.0.0");
 
  112    ueStaticRouting->SetDefaultRoute(epcHelper->GetUeDefaultGatewayAddress(), 1);
 
  114    auto enbDev = DynamicCast<LteEnbNetDevice>(lteHelper->InstallEnbDevice(enbNode).Get(0));
 
  115    auto ueDevs = lteHelper->InstallUeDevice(ueNode);
 
  116    auto ueDev = DynamicCast<LteUeNetDevice>(ueDevs.Get(0));
 
  121    std::map<uint8_t, Ptr<ComponentCarrierUe>> ueCcMap = ueDev->GetCcMap();
 
  122    ueDev->SetDlEarfcn(ueCcMap.at(numberOfComponentCarriers - 1)->GetDlEarfcn());
 
  123    lteHelper->Attach(ueDevs);
 
  124    m_expectedCellId = enbDev->GetCcMap().at(numberOfComponentCarriers - 1)->GetCellId();
 
  127    const uint16_t 
port = 21;
 
  131    auto sink = CreateObject<PacketSink>();
 
  134    ueNode->AddApplication(
sink);
 
  137    auto client = CreateObject<UdpClient>();
 
  143    pgwNode->AddApplication(client);
 
  160    std::vector<double> throughputs;
 
  161    for (uint8_t i = 1; i <= 4; i++)
 
  166                              "UE has attached to an unexpected cell");
 
  169        std::accumulate(begin(throughputs), end(throughputs), 0.0) / throughputs.size();
 
  170    for (
double throughput : throughputs)
 
  175                                  "Throughput does not scale with number of component carriers");
 
Testing that UE throughput scales linearly with number of component carriers.
uint16_t m_actualCellId
Cell ID UE has attached to.
void DoRun() override
Setup the simulation, run it, and verify the result.
double GetThroughput(uint8_t numberOfComponentCarriers)
Get throughput function.
uint16_t m_expectedCellId
Cell ID UE is expected to attach to.
~LteAggregationThroughputScaleTestCase() override
LteAggregationThroughputScaleTestCase(std::string name)
Creates an instance of the carrier aggregation throughput scaling test case.
Test suite for executing carrier aggregation throughput scaling test case.
LteAggregationThroughputScaleTestSuite()
AttributeValue implementation for Address.
holds a vector of ns3::Application pointers.
void Start(Time start) const
Start all of the Applications in this container at the start time given as a parameter.
void Add(ApplicationContainer other)
Append the contents of another ApplicationContainer to the end of this container.
static TypeId GetTypeId()
Get the type ID.
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
Access to the IPv4 forwarding table, interfaces, and configuration.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
Helper class that adds ns3::Ipv4StaticRouting objects.
Ptr< Ipv4StaticRouting > GetStaticRouting(Ptr< Ipv4 > ipv4) const
Try and find the static routing protocol as either the main routing protocol or in the list of routin...
Helper class used to assign positions and mobility models to nodes.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
uint64_t GetTotalRx() const
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void Run()
Run the simulation.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Hold variables of type string.
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
std::string GetName() const
AttributeValue implementation for Time.
AttributeValue implementation for TypeId.
Hold an unsigned integer type.
void SetDefault(std::string name, const AttributeValue &value)
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
static LteAggregationThroughputScaleTestSuite g_lteAggregationThroughputScaleTestSuite
Static variable for test initialization.
#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.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ptr< PacketSink > sink
Pointer to the packet sink application.