A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
lte-test-pss-ff-mac-scheduler.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Marco Miozzo <marco.miozzo@cttc.es>,
18 * Nicola Baldo <nbaldo@cttc.es>
19 * Dizhi Zhou <dizhi.zhou@gmail.com>
20 */
21
22#ifndef LENA_TEST_PSS_FF_MAC_SCHEDULER_H
23#define LENA_TEST_PSS_FF_MAC_SCHEDULER_H
24
25#include "ns3/simulator.h"
26#include "ns3/test.h"
27
28using namespace ns3;
29
30/**
31 * \ingroup lte-test
32 *
33 * \brief This system test program creates different test cases with a single eNB and
34 * several UEs, all having the same Radio Bearer specification. In each test
35 * case, the UEs see the same SINR from the eNB; different test cases are
36 * implemented obtained by using different SINR values and different numbers of
37 * UEs. The test consists on checking that the obtained throughput performance
38 * is equal among users is consistent with the definition of token bank fair
39 * queue scheduling
40 */
42{
43 public:
44 /**
45 * Constructor
46 *
47 * \param nUser the number of UE nodes
48 * \param dist the distance between nodes
49 * \param thrRefDl the DL throughput reference
50 * \param thrRefUl the UL throughput reference
51 * \param packetSize the packet size
52 * \param interval the interval time
53 * \param errorModelEnabled if true the error model is enabled
54 */
55 LenaPssFfMacSchedulerTestCase1(uint16_t nUser,
56 double dist,
57 double thrRefDl,
58 double thrRefUl,
59 uint16_t packetSize,
60 uint16_t interval,
61 bool errorModelEnabled);
63
64 private:
65 /**
66 * Builds the test name string based on provided parameter values
67 * \param nUser the number of UE nodes
68 * \param dist the distance between nodes
69 * \returns the name string
70 */
71 static std::string BuildNameString(uint16_t nUser, double dist);
72 void DoRun() override;
73 uint16_t m_nUser; ///< number of UE nodes
74 double m_dist; ///< the distance between nodes
75 uint16_t m_packetSize; ///< the packet size in bytes
76 uint16_t m_interval; ///< the interval time in ms
77 double m_thrRefDl; ///< the DL throughput reference value
78 double m_thrRefUl; ///< the UL throughput reference value
79 bool m_errorModelEnabled; ///< indicates whether the error model is enabled
80};
81
82/**
83 * \ingroup lte-test
84 *
85 * \brief Similar to the LenaPssFfMacSchedulerTestCase1 with the difference that
86 * UEs are places in such a way to experience different SINRs. Test checks if the
87 * achieved throughput in such conditions has expected value.
88 */
90{
91 public:
92 /**
93 * Constructor
94 *
95 * \param dist the distance between nodes
96 * \param estThrPssDl the estimated DL throughput PSS
97 * \param packetSize the packet size
98 * \param interval the interval time
99 * \param errorModelEnabled if true the error model is enabled
100 */
101 LenaPssFfMacSchedulerTestCase2(std::vector<double> dist,
102 std::vector<uint32_t> estThrPssDl,
103 std::vector<uint16_t> packetSize,
104 uint16_t interval,
105 bool errorModelEnabled);
107
108 private:
109 /**
110 * Builds the test name string based on provided parameter values
111 * \param nUser the number of UE nodes
112 * \param dist the distance between nodes
113 * \returns the name string
114 */
115 static std::string BuildNameString(uint16_t nUser, std::vector<double> dist);
116 void DoRun() override;
117 uint16_t m_nUser; ///< number of UE nodes
118 std::vector<double> m_dist; ///< the distance between nodes
119 std::vector<uint16_t> m_packetSize; ///< the packet size in bytes
120 uint16_t m_interval; ///< the interval time in ms
121 std::vector<uint32_t> m_estThrPssDl; ///< the DL estimated throughput PSS
122 bool m_errorModelEnabled; ///< indicates whether the error model is enabled
123};
124
125/**
126 * \ingroup lte-test
127 *
128 * \brief Lena Pss Ff Mac Scheduler Test Suite
129 */
131{
132 public:
134};
135
136#endif /* LENA_TEST_PSS_FF_MAC_SCHEDULER_H */
This system test program creates different test cases with a single eNB and several UEs,...
uint16_t m_interval
the interval time in ms
uint16_t m_packetSize
the packet size in bytes
bool m_errorModelEnabled
indicates whether the error model is enabled
double m_thrRefDl
the DL throughput reference value
static std::string BuildNameString(uint16_t nUser, double dist)
Builds the test name string based on provided parameter values.
double m_thrRefUl
the UL throughput reference value
double m_dist
the distance between nodes
void DoRun() override
Implementation to actually run this TestCase.
Similar to the LenaPssFfMacSchedulerTestCase1 with the difference that UEs are places in such a way t...
bool m_errorModelEnabled
indicates whether the error model is enabled
std::vector< double > m_dist
the distance between nodes
uint16_t m_interval
the interval time in ms
std::vector< uint16_t > m_packetSize
the packet size in bytes
static std::string BuildNameString(uint16_t nUser, std::vector< double > dist)
Builds the test name string based on provided parameter values.
void DoRun() override
Implementation to actually run this TestCase.
std::vector< uint32_t > m_estThrPssDl
the DL estimated throughput PSS
Lena Pss Ff Mac Scheduler Test Suite.
encapsulates test code
Definition: test.h:1061
A suite of tests to run.
Definition: test.h:1268
Every class exported by the ns3 library is enclosed in the ns3 namespace.
static const uint32_t packetSize
Packet size generated at the AP.