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
55using namespace ns3;
56
57NS_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
182std::string
184{
185 std::ostringstream oss;
186 oss << nUser << " UEs, distance " << dist << " m";
187 return oss.str ();
188}
189
190LenaFdBetFfMacSchedulerTestCase1::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
204void
206{
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
343std::string
344LenaFdBetFfMacSchedulerTestCase2::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
357LenaFdBetFfMacSchedulerTestCase2::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
371void
373{
374
375 NS_LOG_FUNCTION (this);
376
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:107