A Discrete-Event Network Simulator
API
lte-test-fdbet-ff-mac-scheduler.cc
Go to the documentation of this file.
1 /* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Marco Miozzo <marco.miozzo@cttc.es>,
19  * Nicola Baldo <nbaldo@cttc.es>
20  * Dizhi Zhou <dizhi.zhou@gmail.com>
21  */
22 
23 #include <iostream>
24 #include <sstream>
25 #include <string>
26 
27 #include <ns3/object.h>
28 #include <ns3/spectrum-interference.h>
29 #include <ns3/spectrum-error-model.h>
30 #include <ns3/log.h>
31 #include <ns3/test.h>
32 #include <ns3/simulator.h>
33 #include <ns3/packet.h>
34 #include <ns3/ptr.h>
35 #include "ns3/radio-bearer-stats-calculator.h"
36 #include <ns3/constant-position-mobility-model.h>
37 #include <ns3/ff-mac-scheduler.h>
38 #include <ns3/eps-bearer.h>
39 #include <ns3/node-container.h>
40 #include <ns3/mobility-helper.h>
41 #include <ns3/net-device-container.h>
42 #include <ns3/lte-ue-net-device.h>
43 #include <ns3/lte-enb-net-device.h>
44 #include <ns3/lte-ue-rrc.h>
45 #include <ns3/lte-helper.h>
46 #include "ns3/string.h"
47 #include "ns3/double.h"
48 #include <ns3/lte-enb-phy.h>
49 #include <ns3/lte-ue-phy.h>
50 #include <ns3/boolean.h>
51 #include <ns3/enum.h>
52 
54 
55 using namespace ns3;
56 
57 NS_LOG_COMPONENT_DEFINE ("LenaTestFdBetFfMacScheduler");
58 
60  : TestSuite ("lte-fdbet-ff-mac-scheduler", SYSTEM)
61 {
62  NS_LOG_INFO ("creating LenaTestFdBetFfMacSchedulerSuite");
63 
64  bool errorModel = false;
65 
66  //Test Case 1: AMC works in FDBET
67 
68  //Note: here the MCS is calculated by the wideband CQI
69 
70  // DOWNLINK- DISTANCE 0 -> MCS 28 -> Itbs 26 (from table 7.1.7.2.1-1 of 36.213)
71  // 1 user -> 24 PRB at Itbs 26 -> 2196 -> 2196000 bytes/sec
72  // 3 users -> 8 PRB at Itbs 26 -> 749 -> 749000 bytes/sec
73  // 6 users -> 4 PRB at Itbs 26 -> 373 -> 373000 bytes/sec
74  // 12 users -> 2 PRB at Itbs 26 -> 185 -> 185000 bytes/sec
75  // UPLINK- DISTANCE 0 -> MCS 28 -> Itbs 26 (from table 7.1.7.2.1-1 of 36.213)
76  // 1 user -> 25 PRB at Itbs 26 -> 2292 -> 2292000 bytes/sec
77  // 3 users -> 8 PRB at Itbs 26 -> 749 -> 749000 bytes/sec
78  // 6 users -> 4 PRB at Itbs 26 -> 373 -> 373000 bytes/sec
79  // after the patch enforcing min 3 PRBs per UE:
80  // 12 users -> 3 PRB at Itbs 26 -> 277 bytes * 8/12 UE/TTI -> 184670 bytes/sec
81  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,0,2196000,2292000, errorModel), TestCase::EXTENSIVE);
82  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (3,0,749000,749000, errorModel), TestCase::EXTENSIVE);
83  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (6,0,373000,373000, errorModel), TestCase::EXTENSIVE);
84  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (12,0,185000,184670, errorModel), TestCase::EXTENSIVE);
85 
86  // DOWNLINK - DISTANCE 4800 -> MCS 22 -> Itbs 20 (from table 7.1.7.2.1-1 of 36.213)
87  // 1 user -> 24 PRB at Itbs 20 -> 1383 -> 1383000 bytes/sec
88  // 3 users -> 8 PRB at Itbs 20 -> 469 -> 469000 bytes/sec
89  // 6 users -> 4 PRB at Itbs 20 -> 233 -> 233000 bytes/sec
90  // 12 users -> 2 PRB at Itbs 20 -> 113 -> 113000 bytes/sec
91  // UPLINK - DISTANCE 4800 -> MCS 14 -> Itbs 13 (from table 7.1.7.2.1-1 of 36.213)
92  // 1 user -> 25 PRB at Itbs 13 -> 807 -> 807000 bytes/sec
93  // 3 users -> 8 PRB at Itbs 13 -> 253 -> 253000 bytes/sec
94  // 6 users -> 4 PRB at Itbs 13 -> 125 -> 125000 bytes/sec
95  // after the patch enforcing min 3 PRBs per UE:
96  // 12 users -> 3 PRB at Itbs 13 -> 93 bytes * 8/12 UE/TTI -> 62000 bytes/sec
97  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,4800,1383000,807000, errorModel), TestCase::EXTENSIVE);
98  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (3,4800,469000,253000, errorModel), TestCase::EXTENSIVE);
99  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (6,4800,233500,125000, errorModel), TestCase::EXTENSIVE);
100  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (12,4800,113000,62000, errorModel), TestCase::EXTENSIVE);
101 
102  // DOWNLINK - DISTANCE 6000 -> MCS 20 -> Itbs 18 (from table 7.1.7.2.1-1 of 36.213)
103  // 1 user -> 24 PRB at Itbs 18 -> 1191 -> 1191000 byte/sec
104  // 3 users -> 8 PRB at Itbs 18 -> 389 -> 389000 bytes/sec
105  // 6 users -> 4 PRB at Itbs 18 -> 193 -> 193000 bytes/sec
106  // 12 users -> 2 PRB at Itbs 18 -> 97 -> 97000 bytes/sec
107  // UPLINK - DISTANCE 6000 -> MCS 12 -> Itbs 11 (from table 7.1.7.2.1-1 of 36.213)
108  // 1 user -> 25 PRB at Itbs 11 -> 621 -> 621000 bytes/sec
109  // 3 users -> 8 PRB at Itbs 11 -> 201 -> 201000 bytes/sec
110  // 6 users -> 4 PRB at Itbs 11 -> 97 -> 97000 bytes/sec
111  // 12 users -> 3 PRB at Itbs 11 -> 73 bytes * 8/12 UE/TTI -> 48667 bytes/sec
112  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,6000,1191000,621000,errorModel), TestCase::EXTENSIVE);
113  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (3,6000,389000,201000,errorModel), TestCase::EXTENSIVE);
114  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (6,6000,193000,97000,errorModel), TestCase::EXTENSIVE);
115  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (12,6000,97000,48667,errorModel), TestCase::EXTENSIVE);
116 
117  // DOWNLINK - DISTANCE 10000 -> MCS 14 -> Itbs 13 (from table 7.1.7.2.1-1 of 36.213)
118  // 1 user -> 24 PRB at Itbs 13 -> 775 -> 775000 byte/sec
119  // 3 users -> 8 PRB at Itbs 13 -> 253 -> 253000 bytes/sec
120  // 6 users -> 4 PRB at Itbs 13 -> 125 -> 125000 bytes/sec
121  // 12 users -> 2 PRB at Itbs 13 -> 61 -> 61000 bytes/sec
122  // UPLINK - DISTANCE 9000 -> MCS 8 -> Itbs 8 (from table 7.1.7.2.1-1 of 36.213)
123  // 1 user -> 24 PRB at Itbs 8 -> 421 -> 421000 bytes/sec
124  // 3 users -> 8 PRB at Itbs 8 -> 137 -> 137000 bytes/sec
125  // 6 users -> 4 PRB at Itbs 8 -> 67 -> 67000 bytes/sec
126  // after the patch enforcing min 3 PRBs per UE:
127  // 12 users -> 3 PRB at Itbs 8 -> 49 bytes * 8/12 UE/TTI -> 32667 bytes/sec
128  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,10000,775000,421000,errorModel), TestCase::EXTENSIVE);
129  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (3,10000,253000,137000,errorModel), TestCase::EXTENSIVE);
130  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (6,10000,125000,67000,errorModel), TestCase::EXTENSIVE);
131  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (12,10000,61000,32667,errorModel), TestCase::EXTENSIVE);
132 
133  // DOWNLINK - DISTANCE 20000 -> MCS 8 -> Itbs 8 (from table 7.1.7.2.1-1 of 36.213)
134  // 1 user -> 24 PRB at Itbs 8 -> 421 -> 421000 bytes/sec
135  // 3 users -> 8 PRB at Itbs 8 -> 137 -> 137000 bytes/sec
136  // 6 users -> 4 PRB at Itbs 8 -> 67 -> 67000 bytes/sec
137  // 12 users -> 2 PRB at Itbs 8 -> 32 -> 32000 bytes/sec
138  // UPLINK - DISTANCE 20000 -> MCS 2 -> Itbs 2 (from table 7.1.7.2.1-1 of 36.213)
139  // 1 user -> 25 PRB at Itbs 2 -> 137 -> 137000 bytes/sec
140  // 3 users -> 8 PRB at Itbs 2 -> 41 -> 41000 bytes/sec
141  // 6 users -> 4 PRB at Itbs 2 -> 22 -> 22000 bytes/sec
142  // after the patch enforcing min 3 PRBs per UE:
143  // 12 users -> 3 PRB at Itbs 2 -> 18 bytes * 8/12 UE/TTI -> 12000 bytes/sec
144  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,20000,421000,137000,errorModel), TestCase::EXTENSIVE);
145  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (3,20000,137000,41000,errorModel), TestCase::EXTENSIVE);
146  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (6,20000,67000,22000,errorModel), TestCase::EXTENSIVE);
147  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (12,20000,32000,12000,errorModel), TestCase::EXTENSIVE);
148 
149  // DOWNLINK - DISTANCE 100000 -> CQI == 0 -> out of range -> 0 bytes/sec
150  // UPLINK - DISTANCE 100000 -> CQI == 0 -> out of range -> 0 bytes/sec
151  AddTestCase (new LenaFdBetFfMacSchedulerTestCase1 (1,100000,0,0,errorModel), TestCase::QUICK);
152 
153  // Test Case 2: fairness check
154 
155  std::vector<double> dist;
156  dist.push_back (0); // User 0 distance --> MCS 28
157  dist.push_back (4800); // User 1 distance --> MCS 22
158  dist.push_back (6000); // User 2 distance --> MCS 14
159  dist.push_back (10000); // User 3 distance --> MCS 8
160  dist.push_back (20000); // User 4 distance --> MCS 8
161  std::vector<uint32_t> estAchievableRateDl;
162  estAchievableRateDl.push_back (2196000);
163  estAchievableRateDl.push_back (1383000);
164  estAchievableRateDl.push_back (775000);
165  estAchievableRateDl.push_back (421000);
166  estAchievableRateDl.push_back (421000);
167  std::vector<uint32_t> estThrFdBetUl;
168  estThrFdBetUl.push_back (469000); // User 0 estimated TTI throughput from FDBET
169  estThrFdBetUl.push_back (157000); // User 1 estimated TTI throughput from FDBET
170  estThrFdBetUl.push_back (125000); // User 2 estimated TTI throughput from FDBET
171  estThrFdBetUl.push_back (85000); // User 3 estimated TTI throughput from FDBET
172  estThrFdBetUl.push_back (26000); // User 4 estimated TTI throughput from FDBET
173  AddTestCase (new LenaFdBetFfMacSchedulerTestCase2 (dist, estAchievableRateDl, estThrFdBetUl, errorModel), TestCase::QUICK);
174 }
175 
177 
178 
179 // --------------- T E S T - C A S E # 1 ------------------------------
180 
181 
182 std::string
184 {
185  std::ostringstream oss;
186  oss << nUser << " UEs, distance " << dist << " m";
187  return oss.str ();
188 }
189 
190 LenaFdBetFfMacSchedulerTestCase1::LenaFdBetFfMacSchedulerTestCase1 (uint16_t nUser, double dist, double thrRefDl, double thrRefUl, bool errorModelEnabled)
191  : TestCase (BuildNameString (nUser, dist)),
192  m_nUser (nUser),
193  m_dist (dist),
194  m_thrRefDl (thrRefDl),
195  m_thrRefUl (thrRefUl),
196  m_errorModelEnabled (errorModelEnabled)
197 {
198 }
199 
201 {
202 }
203 
204 void
206 {
207  if (!m_errorModelEnabled)
208  {
209  Config::SetDefault ("ns3::LteSpectrumPhy::CtrlErrorModelEnabled", BooleanValue (false));
210  Config::SetDefault ("ns3::LteSpectrumPhy::DataErrorModelEnabled", BooleanValue (false));
211  }
212 
213  Config::SetDefault ("ns3::LteHelper::UseIdealRrc", BooleanValue (true));
214  Config::SetDefault ("ns3::MacStatsCalculator::DlOutputFilename", StringValue (CreateTempDirFilename ("DlMacStats.txt")));
215  Config::SetDefault ("ns3::MacStatsCalculator::UlOutputFilename", StringValue (CreateTempDirFilename ("UlMacStats.txt")));
216  Config::SetDefault ("ns3::RadioBearerStatsCalculator::DlRlcOutputFilename", StringValue (CreateTempDirFilename ("DlRlcStats.txt")));
217  Config::SetDefault ("ns3::RadioBearerStatsCalculator::UlRlcOutputFilename", StringValue (CreateTempDirFilename ("UlRlcStats.txt")));
218 
223  Ptr<LteHelper> lteHelper = CreateObject<LteHelper> ();
224 
225  lteHelper->SetAttribute ("PathlossModel", StringValue ("ns3::FriisSpectrumPropagationLossModel"));
226 
227  // Create Nodes: eNodeB and UE
228  NodeContainer enbNodes;
229  NodeContainer ueNodes;
230  enbNodes.Create (1);
231  ueNodes.Create (m_nUser);
232 
233  // Install Mobility Model
235  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
236  mobility.Install (enbNodes);
237  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
238  mobility.Install (ueNodes);
239 
240  // Create Devices and install them in the Nodes (eNB and UE)
241  NetDeviceContainer enbDevs;
242  NetDeviceContainer ueDevs;
243  lteHelper->SetSchedulerType ("ns3::FdBetFfMacScheduler");
244  lteHelper->SetSchedulerAttribute ("UlCqiFilter", EnumValue (FfMacScheduler::SRS_UL_CQI));
245  enbDevs = lteHelper->InstallEnbDevice (enbNodes);
246  ueDevs = lteHelper->InstallUeDevice (ueNodes);
247 
248  // Attach a UE to a eNB
249  lteHelper->Attach (ueDevs, enbDevs.Get (0));
250 
251  // Activate an EPS bearer
252  enum EpsBearer::Qci q = EpsBearer::GBR_CONV_VOICE;
253  EpsBearer bearer (q);
254  lteHelper->ActivateDataRadioBearer (ueDevs, bearer);
255 
256  Ptr<LteEnbNetDevice> lteEnbDev = enbDevs.Get (0)->GetObject<LteEnbNetDevice> ();
257  Ptr<LteEnbPhy> enbPhy = lteEnbDev->GetPhy ();
258  enbPhy->SetAttribute ("TxPower", DoubleValue (30.0));
259  enbPhy->SetAttribute ("NoiseFigure", DoubleValue (5.0));
260 
261  // Set UEs' position and power
262  for (int i = 0; i < m_nUser; i++)
263  {
265  mm->SetPosition (Vector (m_dist, 0.0, 0.0));
266  Ptr<LteUeNetDevice> lteUeDev = ueDevs.Get (i)->GetObject<LteUeNetDevice> ();
267  Ptr<LteUePhy> uePhy = lteUeDev->GetPhy ();
268  uePhy->SetAttribute ("TxPower", DoubleValue (23.0));
269  uePhy->SetAttribute ("NoiseFigure", DoubleValue (9.0));
270  }
271 
272  double statsStartTime = 0.300; // need to allow for RRC connection establishment + SRS
273  double statsDuration = 0.6;
274  double tolerance = 0.1;
275  Simulator::Stop (Seconds (statsStartTime + statsDuration - 0.000001));
276 
277  lteHelper->EnableMacTraces ();
278  lteHelper->EnableRlcTraces ();
279  Ptr<RadioBearerStatsCalculator> rlcStats = lteHelper->GetRlcStats ();
280  rlcStats->SetAttribute ("StartTime", TimeValue (Seconds (statsStartTime)));
281  rlcStats->SetAttribute ("EpochDuration", TimeValue (Seconds (statsDuration)));
282 
283  Simulator::Run ();
284 
288  NS_LOG_INFO ("DL - Test with " << m_nUser << " user(s) at distance " << m_dist);
289  std::vector <uint64_t> dlDataRxed;
290  for (int i = 0; i < m_nUser; i++)
291  {
292  // get the imsi
293  uint64_t imsi = ueDevs.Get (i)->GetObject<LteUeNetDevice> ()->GetImsi ();
294  // get the lcId
295  uint8_t lcId = 3;
296  dlDataRxed.push_back (rlcStats->GetDlRxData (imsi, lcId));
297  NS_LOG_INFO ("\tUser " << i << " imsi " << imsi << " bytes rxed " << (double)dlDataRxed.at (i) << " thr " << (double)dlDataRxed.at (i) / statsDuration << " ref " << m_thrRefDl);
298  }
305  for (int i = 0; i < m_nUser; i++)
306  {
307  NS_TEST_ASSERT_MSG_EQ_TOL ((double)dlDataRxed.at (i) / statsDuration, m_thrRefDl, m_thrRefDl * tolerance, " Unfair Throughput!");
308  }
309 
313  NS_LOG_INFO ("UL - Test with " << m_nUser << " user(s) at distance " << m_dist);
314  std::vector <uint64_t> ulDataRxed;
315  for (int i = 0; i < m_nUser; i++)
316  {
317  // get the imsi
318  uint64_t imsi = ueDevs.Get (i)->GetObject<LteUeNetDevice> ()->GetImsi ();
319  // get the lcId
320  uint8_t lcId = 3;
321  ulDataRxed.push_back (rlcStats->GetUlRxData (imsi, lcId));
322  NS_LOG_INFO ("\tUser " << i << " imsi " << imsi << " bytes rxed " << (double)ulDataRxed.at (i) << " thr " << (double)ulDataRxed.at (i) / statsDuration << " ref " << m_thrRefUl);
323  }
330  for (int i = 0; i < m_nUser; i++)
331  {
332  NS_TEST_ASSERT_MSG_EQ_TOL ((double)ulDataRxed.at (i) / statsDuration, m_thrRefUl, m_thrRefUl * tolerance, " Unfair Throughput!");
333  }
334  Simulator::Destroy ();
335 
336 }
337 
338 
339 
340 // --------------- T E S T - C A S E # 2 ------------------------------
341 
342 
343 std::string
344 LenaFdBetFfMacSchedulerTestCase2::BuildNameString (uint16_t nUser, std::vector<double> dist)
345 {
346  std::ostringstream oss;
347  oss << "distances (m) = [ " ;
348  for (std::vector<double>::iterator it = dist.begin (); it != dist.end (); ++it)
349  {
350  oss << *it << " ";
351  }
352  oss << "]";
353  return oss.str ();
354 }
355 
356 
357 LenaFdBetFfMacSchedulerTestCase2::LenaFdBetFfMacSchedulerTestCase2 (std::vector<double> dist, std::vector<uint32_t> achievableRateDl, std::vector<uint32_t> estThrFdBetUl, bool errorModelEnabled)
358  : TestCase (BuildNameString (dist.size (), dist)),
359  m_nUser (dist.size ()),
360  m_dist (dist),
361  m_achievableRateDl (achievableRateDl),
362  m_estThrFdBetUl (estThrFdBetUl),
363  m_errorModelEnabled (errorModelEnabled)
364 {
365 }
366 
368 {
369 }
370 
371 void
373 {
374 
375  NS_LOG_FUNCTION (this);
376 
377  if (!m_errorModelEnabled)
378  {
379  Config::SetDefault ("ns3::LteSpectrumPhy::CtrlErrorModelEnabled", BooleanValue (false));
380  Config::SetDefault ("ns3::LteSpectrumPhy::DataErrorModelEnabled", BooleanValue (false));
381  }
382  Config::SetDefault ("ns3::LteHelper::UseIdealRrc", BooleanValue (false));
383  Config::SetDefault ("ns3::MacStatsCalculator::DlOutputFilename", StringValue (CreateTempDirFilename ("DlMacStats.txt")));
384  Config::SetDefault ("ns3::MacStatsCalculator::UlOutputFilename", StringValue (CreateTempDirFilename ("UlMacStats.txt")));
385  Config::SetDefault ("ns3::RadioBearerStatsCalculator::DlRlcOutputFilename", StringValue (CreateTempDirFilename ("DlRlcStats.txt")));
386  Config::SetDefault ("ns3::RadioBearerStatsCalculator::UlRlcOutputFilename", StringValue (CreateTempDirFilename ("UlRlcStats.txt")));
387 
392  Ptr<LteHelper> lteHelper = CreateObject<LteHelper> ();
393 
394  lteHelper->SetAttribute ("PathlossModel", StringValue ("ns3::FriisSpectrumPropagationLossModel"));
395 
396  // Create Nodes: eNodeB and UE
397  NodeContainer enbNodes;
398  NodeContainer ueNodes;
399  enbNodes.Create (1);
400  ueNodes.Create (m_nUser);
401 
402  // Install Mobility Model
404  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
405  mobility.Install (enbNodes);
406  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
407  mobility.Install (ueNodes);
408 
409  // Create Devices and install them in the Nodes (eNB and UE)
410  NetDeviceContainer enbDevs;
411  NetDeviceContainer ueDevs;
412  lteHelper->SetSchedulerType ("ns3::FdBetFfMacScheduler");
413  lteHelper->SetSchedulerAttribute ("UlCqiFilter", EnumValue (FfMacScheduler::SRS_UL_CQI));
414  enbDevs = lteHelper->InstallEnbDevice (enbNodes);
415  ueDevs = lteHelper->InstallUeDevice (ueNodes);
416 
417  // Attach a UE to a eNB
418  lteHelper->Attach (ueDevs, enbDevs.Get (0));
419 
420  // Activate an EPS bearer
421  enum EpsBearer::Qci q = EpsBearer::GBR_CONV_VOICE;
422  EpsBearer bearer (q);
423  lteHelper->ActivateDataRadioBearer (ueDevs, bearer);
424 
425  Ptr<LteEnbNetDevice> lteEnbDev = enbDevs.Get (0)->GetObject<LteEnbNetDevice> ();
426  Ptr<LteEnbPhy> enbPhy = lteEnbDev->GetPhy ();
427  enbPhy->SetAttribute ("TxPower", DoubleValue (30.0));
428  enbPhy->SetAttribute ("NoiseFigure", DoubleValue (5.0));
429 
430  // Set UEs' position and power
431  for (int i = 0; i < m_nUser; i++)
432  {
434  mm->SetPosition (Vector (m_dist.at (i), 0.0, 0.0));
435  Ptr<LteUeNetDevice> lteUeDev = ueDevs.Get (i)->GetObject<LteUeNetDevice> ();
436  Ptr<LteUePhy> uePhy = lteUeDev->GetPhy ();
437  uePhy->SetAttribute ("TxPower", DoubleValue (23.0));
438  uePhy->SetAttribute ("NoiseFigure", DoubleValue (9.0));
439  }
440 
441 
442  double statsStartTime = 0.300; // need to allow for RRC connection establishment + SRS
443  double statsDuration = 0.4;
444  double tolerance = 0.1;
445  Simulator::Stop (Seconds (statsStartTime + statsDuration - 0.000001));
446 
447  lteHelper->EnableMacTraces ();
448  lteHelper->EnableRlcTraces ();
449  Ptr<RadioBearerStatsCalculator> rlcStats = lteHelper->GetRlcStats ();
450  rlcStats->SetAttribute ("StartTime", TimeValue (Seconds (statsStartTime)));
451  rlcStats->SetAttribute ("EpochDuration", TimeValue (Seconds (statsDuration)));
452 
453  Simulator::Run ();
454 
455  NS_LOG_INFO ("DL - Test with " << m_nUser << " user(s)");
456  std::vector <uint64_t> dlDataRxed;
457  double totalData = 0;
458  double estTotalThr = 0;
459  double estUeThr = 0;
460  for (int i = 0; i < m_nUser; i++)
461  {
462  // get the imsi
463  uint64_t imsi = ueDevs.Get (i)->GetObject<LteUeNetDevice> ()->GetImsi ();
464  // get the lcId
465  uint8_t lcId = 3;
466  dlDataRxed.push_back (rlcStats->GetDlRxData (imsi, lcId));
467  totalData += (double)dlDataRxed.at (i);
468  estTotalThr += 1 / m_achievableRateDl.at (i);
469  NS_LOG_INFO ("\tUser " << i << " dist " << m_dist.at (i) << " imsi " << imsi << " bytes rxed " << (double)dlDataRxed.at (i) << " thr " << (double)dlDataRxed.at (i) / statsDuration << " ref " << m_nUser);
470  }
471 
472  estTotalThr = m_nUser * (1 / estTotalThr);
473  estUeThr = estTotalThr / m_nUser;
478  for (int i = 0; i < m_nUser; i++)
479  {
480  double thrRatio = (double) 1 / m_nUser;
481  double estThrRatio = (double)dlDataRxed.at (i) / totalData;
482  NS_LOG_INFO ("\tUser " << i << " thrRatio " << thrRatio << " estThrRatio " << estThrRatio);
483  NS_TEST_ASSERT_MSG_EQ_TOL (estThrRatio, thrRatio, tolerance, " Unfair Throughput!");
484  NS_TEST_ASSERT_MSG_EQ_TOL ((double)dlDataRxed.at (i) / statsDuration, estUeThr, estUeThr * tolerance, " Unfair Throughput!");
485 
486  }
487 
492  NS_LOG_INFO ("UL - Test with " << m_nUser);
493  std::vector <uint64_t> ulDataRxed;
494  for (int i = 0; i < m_nUser; i++)
495  {
496  // get the imsi
497  uint64_t imsi = ueDevs.Get (i)->GetObject<LteUeNetDevice> ()->GetImsi ();
498  // get the lcId
499  uint8_t lcId = 3;
500  ulDataRxed.push_back (rlcStats->GetUlRxData (imsi, lcId));
501  NS_LOG_INFO ("\tUser " << i << " dist " << m_dist.at (i) << " bytes rxed " << (double)ulDataRxed.at (i) << " thr " << (double)ulDataRxed.at (i) / statsDuration << " ref " << (double)m_estThrFdBetUl.at (i));
502  NS_TEST_ASSERT_MSG_EQ_TOL ((double)ulDataRxed.at (i) / statsDuration, (double)m_estThrFdBetUl.at (i), (double)m_estThrFdBetUl.at (i) * tolerance, " Unfair Throughput!");
503  }
504  Simulator::Destroy ();
505 
506 }
This system test program creates different test cases with a single eNB and several UEs,...
static std::string BuildNameString(uint16_t nUser, double dist)
Builds the test name string based on provided parameter values.
virtual void DoRun(void)
Implementation to actually run this TestCase.
LenaFdBetFfMacSchedulerTestCase1(uint16_t nUser, double dist, double thrRefDl, double thrRefUl, bool errorModelEnabled)
Constructor.
double m_dist
distance between the nodes
Test case is simillar to the one defined in LenaFdBetFfMacSchedulerTestCase1, with the difference tha...
bool m_errorModelEnabled
specifies whether the error model is enabled
std::vector< double > m_dist
distance between the nodes
virtual void DoRun(void)
Implementation to actually run this TestCase.
static std::string BuildNameString(uint16_t nUser, std::vector< double > dist)
Builds the test name string based on provided parameter values.
std::vector< uint32_t > m_achievableRateDl
DL achievable rate.
std::vector< uint32_t > m_estThrFdBetUl
estimated throughput FDBET UL
LenaFdBetFfMacSchedulerTestCase2(std::vector< double > dist, std::vector< uint32_t > achievableRateDl, std::vector< uint32_t > estThrFdBetUl, bool errorModelEnabled)
Constructor.
Test suite for FDBetFfMacScheduler test case.
AttributeValue implementation for Boolean.
Definition: boolean.h:37
Mobility model for which the current position does not change once it has been set and until it is se...
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Definition: double.h:41
Hold variables of type enum.
Definition: enum.h:55
This class contains the specification of EPS Bearers.
Definition: eps-bearer.h:92
Qci
QoS Class Indicator.
Definition: eps-bearer.h:107
The eNodeB device implementation.
Ptr< LteEnbPhy > GetPhy(void) const
void SetSchedulerAttribute(std::string n, const AttributeValue &v)
Set an attribute for the scheduler to be created.
Definition: lte-helper.cc:293
NetDeviceContainer InstallEnbDevice(NodeContainer c)
Create a set of eNodeB devices.
Definition: lte-helper.cc:474
Ptr< RadioBearerStatsCalculator > GetRlcStats(void)
Definition: lte-helper.cc:1572
void SetSchedulerType(std::string type)
Set the type of scheduler to be used by eNodeB devices.
Definition: lte-helper.cc:279
void Attach(NetDeviceContainer ueDevices)
Enables automatic attachment of a set of UE devices to a suitable cell using Idle mode initial cell s...
Definition: lte-helper.cc:959
void EnableRlcTraces(void)
Enable trace sinks for RLC layer.
Definition: lte-helper.cc:1435
void ActivateDataRadioBearer(NetDeviceContainer ueDevices, EpsBearer bearer)
Activate a Data Radio Bearer on a given UE devices (for LTE-only simulation).
Definition: lte-helper.cc:1313
NetDeviceContainer InstallUeDevice(NodeContainer c)
Create a set of UE devices.
Definition: lte-helper.cc:489
void EnableMacTraces(void)
Enable trace sinks for MAC layer.
Definition: lte-helper.cc:1529
The LteUeNetDevice class implements the UE net device.
Helper class used to assign positions and mobility models to nodes.
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.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
Definition: object-base.cc:256
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
Definition: object.h:470
Hold variables of type string.
Definition: string.h:41
encapsulates test code
Definition: test.h:994
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
Definition: test.cc:299
std::string CreateTempDirFilename(std::string filename)
Construct the full path to a file in a temporary directory.
Definition: test.cc:430
A suite of tests to run.
Definition: test.h:1188
AttributeValue implementation for Time.
Definition: nstime.h:1308
void SetDefault(std::string name, const AttributeValue &value)
Definition: config.cc:849
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:205
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:281
#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...
Definition: test.h:323
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1244
static LenaTestFdBetFfMacSchedulerSuite lenaTestFdBetFfMacSchedulerSuite
Every class exported by the ns3 library is enclosed in the ns3 namespace.
mobility
Definition: third.py:108