22 #include <ns3/simulator.h> 
   24 #include <ns3/callback.h> 
   25 #include <ns3/config.h> 
   26 #include <ns3/string.h> 
   27 #include <ns3/double.h> 
   29 #include <ns3/boolean.h> 
   30 #include <ns3/pointer.h> 
   32 #include "ns3/mobility-helper.h" 
   33 #include "ns3/lte-helper.h" 
   35 #include <ns3/ff-mac-scheduler.h> 
   36 #include <ns3/lte-enb-net-device.h> 
   37 #include <ns3/lte-enb-phy.h> 
   38 #include <ns3/lte-enb-rrc.h> 
   39 #include <ns3/lte-ue-net-device.h> 
   40 #include <ns3/lte-ue-phy.h> 
   41 #include <ns3/lte-ue-rrc.h> 
   44 #include <ns3/lte-common.h> 
   47 #include <ns3/lte-chunk-processor.h> 
   50 #include <ns3/lte-rrc-sap.h> 
   61   : 
TestSuite (
"lte-downlink-power-control", SYSTEM)
 
   65   NS_LOG_INFO (
"Creating LteDownlinkPowerControlTestSuite");
 
   69     std::vector<int> activeRbs_txpowdB30nrb6run1earfcn500 (4);
 
   70     activeRbs_txpowdB30nrb6run1earfcn500[0] = 0;
 
   71     activeRbs_txpowdB30nrb6run1earfcn500[1] = 2;
 
   72     activeRbs_txpowdB30nrb6run1earfcn500[2] = 3;
 
   73     activeRbs_txpowdB30nrb6run1earfcn500[3] = 5;
 
   75     uint16_t earfcn = 500;
 
   79     std::map<int, double> powerTxMap;
 
   80     double rbTxPower = powerTx;
 
   83     powerTxMap.insert (std::pair<int,double>(0, rbTxPower));
 
   86     powerTxMap.insert (std::pair<int,double>(2, rbTxPower));
 
   89     powerTxMap.insert (std::pair<int,double>(3, rbTxPower));
 
   92     powerTxMap.insert (std::pair<int,double>(5, rbTxPower));
 
   94     SpectrumValue spectrumValue_txpowdB30nrb6run1earfcn500 (LteSpectrumValueHelper::GetSpectrumModel (500, 6));
 
   95     spectrumValue_txpowdB30nrb6run1earfcn500[0] = 2.325820769916e-07;
 
   96     spectrumValue_txpowdB30nrb6run1earfcn500[1] = 0.000000000000e+00;
 
   97     spectrumValue_txpowdB30nrb6run1earfcn500[2] = 4.640622533585e-07;
 
   98     spectrumValue_txpowdB30nrb6run1earfcn500[3] = 9.259259259259e-07;
 
   99     spectrumValue_txpowdB30nrb6run1earfcn500[4] = 0.000000000000e+00;
 
  100     spectrumValue_txpowdB30nrb6run1earfcn500[5] = 1.467493696723e-06;
 
  104                                                                    powerTxMap, activeRbs_txpowdB30nrb6run1earfcn500,
 
  105                                                                    spectrumValue_txpowdB30nrb6run1earfcn500), TestCase::QUICK);
 
  109     std::vector<int> activeRbs_txpowdB30nrb6run1earfcn500 (4);
 
  110     activeRbs_txpowdB30nrb6run1earfcn500[0] = 0;
 
  111     activeRbs_txpowdB30nrb6run1earfcn500[1] = 2;
 
  112     activeRbs_txpowdB30nrb6run1earfcn500[2] = 3;
 
  113     activeRbs_txpowdB30nrb6run1earfcn500[3] = 5;
 
  115     uint16_t earfcn = 500;
 
  119     std::map<int, double> powerTxMap;
 
  120     double rbTxPower = powerTx;
 
  123     powerTxMap.insert (std::pair<int,double>(2, rbTxPower));
 
  126     powerTxMap.insert (std::pair<int,double>(3, rbTxPower));
 
  129     powerTxMap.insert (std::pair<int,double>(5, rbTxPower));
 
  131     SpectrumValue spectrumValue_txpowdB30nrb6run1earfcn500 (LteSpectrumValueHelper::GetSpectrumModel (500, 6));
 
  132     spectrumValue_txpowdB30nrb6run1earfcn500[0] = 9.259259259259e-07;
 
  133     spectrumValue_txpowdB30nrb6run1earfcn500[1] = 0.000000000000e+00;
 
  134     spectrumValue_txpowdB30nrb6run1earfcn500[2] = 4.640622533585e-07;
 
  135     spectrumValue_txpowdB30nrb6run1earfcn500[3] = 9.259259259259e-07;
 
  136     spectrumValue_txpowdB30nrb6run1earfcn500[4] = 0.000000000000e+00;
 
  137     spectrumValue_txpowdB30nrb6run1earfcn500[5] = 1.467493696723e-06;
 
  141                                                                    powerTxMap, activeRbs_txpowdB30nrb6run1earfcn500,
 
  142                                                                    spectrumValue_txpowdB30nrb6run1earfcn500), TestCase::QUICK);
 
  145     std::vector<int> activeRbs_txpowdB30nrb25run1earfcn500 (15);
 
  146     activeRbs_txpowdB30nrb25run1earfcn500[0] = 0;
 
  147     activeRbs_txpowdB30nrb25run1earfcn500[1] = 1;
 
  148     activeRbs_txpowdB30nrb25run1earfcn500[2] = 2;
 
  149     activeRbs_txpowdB30nrb25run1earfcn500[3] = 3;
 
  150     activeRbs_txpowdB30nrb25run1earfcn500[4] = 7;
 
  151     activeRbs_txpowdB30nrb25run1earfcn500[5] = 8;
 
  152     activeRbs_txpowdB30nrb25run1earfcn500[6] = 9;
 
  153     activeRbs_txpowdB30nrb25run1earfcn500[7] = 11;
 
  154     activeRbs_txpowdB30nrb25run1earfcn500[8] = 13;
 
  155     activeRbs_txpowdB30nrb25run1earfcn500[9] = 14;
 
  156     activeRbs_txpowdB30nrb25run1earfcn500[10] = 18;
 
  157     activeRbs_txpowdB30nrb25run1earfcn500[11] = 19;
 
  158     activeRbs_txpowdB30nrb25run1earfcn500[12] = 20;
 
  159     activeRbs_txpowdB30nrb25run1earfcn500[13] = 21;
 
  160     activeRbs_txpowdB30nrb25run1earfcn500[14] = 24;
 
  162     uint16_t earfcn = 500;
 
  166     std::map<int, double> powerTxMap;
 
  167     double rbTxPower = powerTx;
 
  169     powerTxMap.insert (std::pair<int,double>(0, rbTxPower));
 
  171     powerTxMap.insert (std::pair<int,double>(1, rbTxPower));
 
  173     powerTxMap.insert (std::pair<int,double>(2, rbTxPower));
 
  175     powerTxMap.insert (std::pair<int,double>(3, rbTxPower));
 
  177     powerTxMap.insert (std::pair<int,double>(7, rbTxPower));
 
  179     powerTxMap.insert (std::pair<int,double>(8, rbTxPower));
 
  181     powerTxMap.insert (std::pair<int,double>(9, rbTxPower));
 
  183     powerTxMap.insert (std::pair<int,double>(11, rbTxPower));
 
  185     powerTxMap.insert (std::pair<int,double>(13, rbTxPower));
 
  187     powerTxMap.insert (std::pair<int,double>(14, rbTxPower));
 
  189     powerTxMap.insert (std::pair<int,double>(18, rbTxPower));
 
  191     powerTxMap.insert (std::pair<int,double>(19, rbTxPower));
 
  193     powerTxMap.insert (std::pair<int,double>(20, rbTxPower));
 
  195     powerTxMap.insert (std::pair<int,double>(21, rbTxPower));
 
  197     powerTxMap.insert (std::pair<int,double>(24, rbTxPower));
 
  200     SpectrumValue spectrumValue_txpowdB30nrb25run1earfcn500 (LteSpectrumValueHelper::GetSpectrumModel (500, bw));
 
  201     spectrumValue_txpowdB30nrb25run1earfcn500[0] = 1.113749408060e-07;
 
  202     spectrumValue_txpowdB30nrb25run1earfcn500[1] = 7.409475839182e-08;
 
  203     spectrumValue_txpowdB30nrb25run1earfcn500[2] = 5.581969847799e-08;
 
  204     spectrumValue_txpowdB30nrb25run1earfcn500[3] = 2.797612026209e-07;
 
  205     spectrumValue_txpowdB30nrb25run1earfcn500[4] = 0.000000000000e+00;
 
  206     spectrumValue_txpowdB30nrb25run1earfcn500[5] = 0.000000000000e+00;
 
  207     spectrumValue_txpowdB30nrb25run1earfcn500[6] = 0.000000000000e+00;
 
  208     spectrumValue_txpowdB30nrb25run1earfcn500[7] = 3.521984872135e-07;
 
  209     spectrumValue_txpowdB30nrb25run1earfcn500[8] = 3.521984872135e-07;
 
  210     spectrumValue_txpowdB30nrb25run1earfcn500[9] = 3.521984872135e-07;
 
  211     spectrumValue_txpowdB30nrb25run1earfcn500[10] = 0.000000000000e+00;
 
  212     spectrumValue_txpowdB30nrb25run1earfcn500[11] = 1.478384791559e-07;
 
  213     spectrumValue_txpowdB30nrb25run1earfcn500[12] = 0.000000000000e+00;
 
  214     spectrumValue_txpowdB30nrb25run1earfcn500[13] = 3.521984872135e-07;
 
  215     spectrumValue_txpowdB30nrb25run1earfcn500[14] = 1.113749408060e-07;
 
  216     spectrumValue_txpowdB30nrb25run1earfcn500[15] = 0.000000000000e+00;
 
  217     spectrumValue_txpowdB30nrb25run1earfcn500[16] = 0.000000000000e+00;
 
  218     spectrumValue_txpowdB30nrb25run1earfcn500[17] = 0.000000000000e+00;
 
  219     spectrumValue_txpowdB30nrb25run1earfcn500[18] = 2.222222222222e-07;
 
  220     spectrumValue_txpowdB30nrb25run1earfcn500[19] = 1.113749408060e-07;
 
  221     spectrumValue_txpowdB30nrb25run1earfcn500[20] = 1.113749408060e-07;
 
  222     spectrumValue_txpowdB30nrb25run1earfcn500[21] = 7.409475839182e-08;
 
  223     spectrumValue_txpowdB30nrb25run1earfcn500[22] = 0.000000000000e+00;
 
  224     spectrumValue_txpowdB30nrb25run1earfcn500[23] = 0.000000000000e+00;
 
  225     spectrumValue_txpowdB30nrb25run1earfcn500[24] = 4.433916255486e-07;
 
  229                                                                    powerTxMap, activeRbs_txpowdB30nrb25run1earfcn500,
 
  230                                                                    spectrumValue_txpowdB30nrb25run1earfcn500), TestCase::QUICK);
 
  234     std::vector<int> activeRbs_txpowdB30nrb25run1earfcn500 (15);
 
  235     activeRbs_txpowdB30nrb25run1earfcn500[0] = 0;
 
  236     activeRbs_txpowdB30nrb25run1earfcn500[1] = 1;
 
  237     activeRbs_txpowdB30nrb25run1earfcn500[2] = 2;
 
  238     activeRbs_txpowdB30nrb25run1earfcn500[3] = 3;
 
  239     activeRbs_txpowdB30nrb25run1earfcn500[4] = 7;
 
  240     activeRbs_txpowdB30nrb25run1earfcn500[5] = 8;
 
  241     activeRbs_txpowdB30nrb25run1earfcn500[6] = 9;
 
  242     activeRbs_txpowdB30nrb25run1earfcn500[7] = 11;
 
  243     activeRbs_txpowdB30nrb25run1earfcn500[8] = 13;
 
  244     activeRbs_txpowdB30nrb25run1earfcn500[9] = 14;
 
  245     activeRbs_txpowdB30nrb25run1earfcn500[10] = 18;
 
  246     activeRbs_txpowdB30nrb25run1earfcn500[11] = 19;
 
  247     activeRbs_txpowdB30nrb25run1earfcn500[12] = 20;
 
  248     activeRbs_txpowdB30nrb25run1earfcn500[13] = 21;
 
  249     activeRbs_txpowdB30nrb25run1earfcn500[14] = 24;
 
  251     uint16_t earfcn = 500;
 
  255     std::map<int, double> powerTxMap;
 
  256     double rbTxPower = powerTx;
 
  258     powerTxMap.insert (std::pair<int,double>(0, rbTxPower));
 
  260     powerTxMap.insert (std::pair<int,double>(2, rbTxPower));
 
  262     powerTxMap.insert (std::pair<int,double>(3, rbTxPower));
 
  264     powerTxMap.insert (std::pair<int,double>(7, rbTxPower));
 
  266     powerTxMap.insert (std::pair<int,double>(8, rbTxPower));
 
  268     powerTxMap.insert (std::pair<int,double>(13, rbTxPower));
 
  270     powerTxMap.insert (std::pair<int,double>(14, rbTxPower));
 
  272     powerTxMap.insert (std::pair<int,double>(18, rbTxPower));
 
  274     powerTxMap.insert (std::pair<int,double>(19, rbTxPower));
 
  276     powerTxMap.insert (std::pair<int,double>(24, rbTxPower));
 
  279     SpectrumValue spectrumValue_txpowdB30nrb25run1earfcn500 (LteSpectrumValueHelper::GetSpectrumModel (500, bw));
 
  280     spectrumValue_txpowdB30nrb25run1earfcn500[0] = 1.113749408060e-07;
 
  281     spectrumValue_txpowdB30nrb25run1earfcn500[1] = 2.222222222222e-07;
 
  282     spectrumValue_txpowdB30nrb25run1earfcn500[2] = 5.581969847799e-08;
 
  283     spectrumValue_txpowdB30nrb25run1earfcn500[3] = 2.797612026209e-07;
 
  284     spectrumValue_txpowdB30nrb25run1earfcn500[4] = 0.000000000000e+00;
 
  285     spectrumValue_txpowdB30nrb25run1earfcn500[5] = 0.000000000000e+00;
 
  286     spectrumValue_txpowdB30nrb25run1earfcn500[6] = 0.000000000000e+00;
 
  287     spectrumValue_txpowdB30nrb25run1earfcn500[7] = 3.521984872135e-07;
 
  288     spectrumValue_txpowdB30nrb25run1earfcn500[8] = 3.521984872135e-07;
 
  289     spectrumValue_txpowdB30nrb25run1earfcn500[9] = 2.222222222222e-07;
 
  290     spectrumValue_txpowdB30nrb25run1earfcn500[10] = 0.000000000000e+00;
 
  291     spectrumValue_txpowdB30nrb25run1earfcn500[11] = 2.222222222222e-07;
 
  292     spectrumValue_txpowdB30nrb25run1earfcn500[12] = 0.000000000000e+00;
 
  293     spectrumValue_txpowdB30nrb25run1earfcn500[13] = 3.521984872135e-07;
 
  294     spectrumValue_txpowdB30nrb25run1earfcn500[14] = 1.113749408060e-07;
 
  295     spectrumValue_txpowdB30nrb25run1earfcn500[15] = 0.000000000000e+00;
 
  296     spectrumValue_txpowdB30nrb25run1earfcn500[16] = 0.000000000000e+00;
 
  297     spectrumValue_txpowdB30nrb25run1earfcn500[17] = 0.000000000000e+00;
 
  298     spectrumValue_txpowdB30nrb25run1earfcn500[18] = 2.222222222222e-07;
 
  299     spectrumValue_txpowdB30nrb25run1earfcn500[19] = 1.113749408060e-07;
 
  300     spectrumValue_txpowdB30nrb25run1earfcn500[20] = 2.222222222222e-07;
 
  301     spectrumValue_txpowdB30nrb25run1earfcn500[21] = 2.222222222222e-07;
 
  302     spectrumValue_txpowdB30nrb25run1earfcn500[22] = 0.000000000000e+00;
 
  303     spectrumValue_txpowdB30nrb25run1earfcn500[23] = 0.000000000000e+00;
 
  304     spectrumValue_txpowdB30nrb25run1earfcn500[24] = 4.433916255486e-07;
 
  308                                                                    powerTxMap, activeRbs_txpowdB30nrb25run1earfcn500,
 
  309                                                                    spectrumValue_txpowdB30nrb25run1earfcn500), TestCase::QUICK);
 
  315                                                     "DataCtrlPowerDifference_noChange"), TestCase::QUICK);
 
  317                                                     "DataCtrlPowerDifference_dB_6"), TestCase::QUICK);
 
  319                                                     "DataCtrlPowerDifference_dB_4dot77"), TestCase::QUICK);
 
  321                                                     "DataCtrlPowerDifference_dB_3"), TestCase::QUICK);
 
  323                                                     "DataCtrlPowerDifference_dB_1dot77"), TestCase::QUICK);
 
  325                                                     "DataCtrlPowerDifference_dB0"), TestCase::QUICK);
 
  327                                                     "DataCtrlPowerDifference_dB1"), TestCase::QUICK);
 
  329                                                     "DataCtrlPowerDifference_dB2"), TestCase::QUICK);
 
  331                                                     "DataCtrlPowerDifference_dB3"), TestCase::QUICK);
 
  345   pdschConfigDedicated.
pa = pa;
 
  346   double rbTxpower = txPower + LteRrcSap::ConvertPdschConfigDedicated2Double (pdschConfigDedicated);
 
  359                                                                                             uint16_t earfcn, uint8_t bw, 
double powerTx,
 
  360                                                                                             std::map<int, double> powerTxMap, std::vector <int> activeRbs,
 
  362   : 
TestCase (
"Downlink Power Control: " + name),
 
  363     m_actual (
LteSpectrumValueHelper::CreateTxPowerSpectralDensity (earfcn, bw, powerTx, powerTxMap, activeRbs)),
 
  366   NS_LOG_INFO (
"Creating LteDownlinkPowerControlTestCase");
 
  376   NS_LOG_INFO (
"Creating LteDownlinkPowerControlSpectrumValueTestCase");
 
  383   : 
TestCase (
"Downlink Power Control: " + name)
 
  388   NS_LOG_INFO (
"Creating LteDownlinkPowerControlTestCase");
 
  428   lteHelper->
Attach (ueDevs, enbDevs.
Get (0));
 
  431   enbDevs.
Get (0)->GetAttribute (
"LteFfrAlgorithm", tmp);
 
  448   testDlDataPowerReceived->AddCallback (
MakeCallback (&LteSpectrumValueCatcher::ReportValue, &dlDataPowerReceivedCatcher));
 
  453   testDlCtrlPowerReceived->
AddCallback (
MakeCallback (&LteSpectrumValueCatcher::ReportValue, &dlCtrlPowerReceivedCatcher));
 
  456   Simulator::Stop (
Seconds (0.400));
 
  459   double dataPower = 10.0 * std::log10 (dlDataPowerReceivedCatcher.GetValue ()->operator[] (0));
 
  460   double ctrlPower = 10.0 * std::log10 (dlCtrlPowerReceivedCatcher.GetValue ()->operator[] (0));
 
  461   double powerDiff = (-1.0)*ctrlPower + dataPower;
 
  469                              "Downlink Data and Ctrl Power Difference are not equal within tolerance");
 
  471   Simulator::Destroy ();
 
  476                                    std::string context, uint64_t imsi, uint16_t cellId, uint16_t rnti)
 
  483                                     std::string context, uint64_t imsi, uint16_t cellId, uint16_t rnti)
 
  490                                     std::string context, uint16_t rnti, uint8_t pa)
 
  497   : 
TestCase (
"Downlink Power Control: " + name),
 
  498     m_useIdealRrc (useIdealRrc),
 
  499     m_changePdschConfigDedicatedTriggered (false),
 
  500     m_connectionReconfigurationUeReceived (false),
 
  501     m_connectionReconfigurationEnbCompleted (false)
 
  515       NS_LOG_DEBUG (
"eNb ConnectionReconfigurationCompleted");
 
  533   NS_LOG_DEBUG (
"FFR Algorithm ChangePdschConfigDedicated");
 
  570   lteHelper->
Attach (ueDevs, enbDevs.
Get (0));
 
  573   enbDevs.
Get (0)->GetAttribute (
"LteFfrAlgorithm", tmp);
 
  576   pdschConfigDedicated.
pa = LteRrcSap::PdschConfigDedicated::dB_6;
 
  585   Config::Connect (
"/NodeList/0/DeviceList/0/LteFfrAlgorithm/ChangePdschConfigDedicated",
 
  587   Config::Connect (
"/NodeList/1/DeviceList/0/LteUeRrc/ConnectionReconfiguration",
 
  589   Config::Connect (
"/NodeList/0/DeviceList/0/LteEnbRrc/ConnectionReconfiguration",
 
  592   Simulator::Stop (
Seconds (0.400));
 
  596                          "Ffr have not changed PdschConfigDedicated for UE");
 
  598                          "Ue have not received RrcConnectionReconfiguration");
 
  600                          "Enb have not received RrcConnectionReconfigurationCompleted");
 
  602   Simulator::Destroy ();
 
AttributeValue implementation for Boolean. 
 
virtual void DoRun(void)
Implementation to actually run this TestCase. 
 
NetDeviceContainer InstallEnbDevice(NodeContainer c)
Create a set of eNodeB devices. 
 
Ptr< T > GetObject(void) const 
Get a pointer to the requested aggregated Object. 
 
Ptr< NetDevice > Get(uint32_t i) const 
Get the Ptr stored in this container at a given index. 
 
Ptr< SpectrumValue > m_expected
 
virtual void DoRun(void)
Implementation to actually run this TestCase. 
 
static LteDownlinkPowerControlTestSuite lteDownlinkPowerControlTestSuite
 
Callback< R > MakeBoundCallback(R(*fnPtr)(TX), ARG a1)
Make Callbacks with one bound argument. 
 
SpectrumModelUid_t GetSpectrumModelUid() const 
 
Ptr< Object > GetObject(void) const 
Get the Object referenced by the PointerValue. 
 
void Attach(NetDeviceContainer ueDevices)
Enables automatic attachment of a set of UE devices to a suitable cell using Idle mode initial cell s...
 
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name. 
 
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit. 
 
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO. 
 
void ChangePdschConfigDedicated(uint16_t rnti, uint8_t pa)
 
void ActivateDataRadioBearer(NetDeviceContainer ueDevices, EpsBearer bearer)
Activate a Data Radio Bearer on a given UE devices (for LTE-only simulation). 
 
This class defines all functions to create spectrum model for lte. 
 
void SetFfrAlgorithmType(std::string type)
Set the type of FFR algorithm to be used by eNodeB devices. 
 
void NotifyConnectionReconfigurationUe(LteDownlinkPowerControlRrcConnectionReconfigurationTestCase *testcase, std::string context, uint64_t imsi, uint16_t cellId, uint16_t rnti)
 
void SetSchedulerType(std::string type)
Set the type of scheduler to be used by eNodeB devices. 
 
LteDownlinkPowerControlTestSuite()
TestSuite. 
 
This class contains the specification of EPS Bearers. 
 
bool m_connectionReconfigurationUeReceived
 
void Install(Ptr< Node > node) const 
"Layout" a single node according to the current position allocator type. 
 
LteRrcSap::PdschConfigDedicated m_pdschConfigDedicated
 
virtual void AddCallback(LteChunkProcessorCallback c)
Add callback to list. 
 
Ptr< SpectrumValue > m_actual
 
void AddTestCase(TestCase *testCase, enum TestDuration duration)
Add an individual child TestCase to this test suite. 
 
void ChangePdschConfigDedicated(bool change)
 
void ConnectionReconfigurationEnb(std::string context, uint64_t imsi, uint16_t cellid, uint16_t rnti)
 
#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. 
 
holds a vector of ns3::NetDevice pointers 
 
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
 
virtual ~LteDownlinkPowerControlRrcConnectionReconfigurationTestCase()
 
bool m_changePdschConfigDedicatedTriggered
 
A sink to be plugged to the callback of LteChunkProcessor allowing to save and later retrieve the lat...
 
bool m_changePdschConfigDedicated
 
Ptr< LteSpectrumPhy > GetDownlinkSpectrumPhy()
 
LteDownlinkPowerControlSpectrumValueTestCase(std::string name, uint16_t earfcn, uint8_t bw, double powerTx, std::map< int, double > powerTxMap, std::vector< int > activeRbs, SpectrumValue &expected)
TestCase Data. 
 
#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...
 
void Connect(std::string path, const CallbackBase &cb)
 
double CalculateRbTxPower(double txPower, uint8_t pa)
 
void ChangePdschConfigDedicatedCallback(LteDownlinkPowerControlRrcConnectionReconfigurationTestCase *testcase, std::string context, uint16_t rnti, uint8_t pa)
 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
 
keep track of a set of node pointers. 
 
Hold objects of type Ptr. 
 
void SetMobilityModel(std::string type, std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue())
 
virtual ~LteDownlinkPowerControlSpectrumValueTestCase()
 
Ptr< T > Create(void)
Create class instances by constructors with varying numbers of arguments and return them by Ptr...
 
void Reset(void)
Reset the initial value of every attribute as well as the value of every global to what they were bef...
 
double m_expectedPowerDiff
 
NetDeviceContainer InstallUeDevice(NodeContainer c)
Create a set of UE devices. 
 
Helper class used to assign positions and mobility models to nodes. 
 
virtual void DoRun(void)
Implementation to actually run this TestCase. 
 
#define NS_TEST_ASSERT_MSG_SPECTRUM_VALUE_EQ_TOL(actual, expected, tol, msg)
Test if two SpectrumValue instances are equal within a given tolerance. 
 
virtual ~LteDownlinkPowerControlTestCase()
 
Test 1.1 SINR calculation in downlink. 
 
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG. 
 
Time Seconds(double value)
Construct a Time in the indicated unit. 
 
void SetDefault(std::string name, const AttributeValue &value)
 
void ConnectionReconfigurationUe(std::string context, uint64_t imsi, uint16_t cellid, uint16_t rnti)
 
void SetPdschConfigDedicated(LteRrcSap::PdschConfigDedicated pdschConfigDedicated)
 
LteDownlinkPowerControlTestCase(bool changePower, uint8_t pa, std::string name)
 
Time Now(void)
create an ns3::Time instance which contains the current simulation time. 
 
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer. 
 
bool m_connectionReconfigurationEnbCompleted
 
Set of values corresponding to a given SpectrumModel. 
 
LteDownlinkPowerControlRrcConnectionReconfigurationTestCase(bool useIdealRrc, std::string name)
 
void NotifyConnectionReconfigurationEnb(LteDownlinkPowerControlRrcConnectionReconfigurationTestCase *testcase, std::string context, uint64_t imsi, uint16_t cellId, uint16_t rnti)
 
The LtePhy models the physical layer of LTE. 
 
The LteUeNetDevice class implements the UE net device.