A Discrete-Event Network Simulator
API
cqa-ff-mac-scheduler.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2012 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  * Authors: Biljana Bojovic <bbojovic@cttc.es>, Nicola Baldo<nbaldo@cttc.es>.
19  *
20  * Note: Implementation is using many common scheduler functionalities in its original version implemented by Marco Miozzo<mmiozzo@cttc.es> in PF and RR
21  * schedulers. *
22  */
23 
24 #ifndef CQA_FF_MAC_SCHEDULER_H
25 #define CQA_FF_MAC_SCHEDULER_H
26 
27 #include <ns3/lte-common.h>
28 #include <ns3/ff-mac-csched-sap.h>
29 #include <ns3/ff-mac-sched-sap.h>
30 #include <ns3/ff-mac-scheduler.h>
31 #include <vector>
32 #include <map>
33 #include <set>
34 #include <ns3/nstime.h>
35 #include <ns3/lte-amc.h>
36 #include <ns3/lte-ffr-sap.h>
37 
38 // value for SINR outside the range defined by FF-API, used to indicate that there
39 // is no CQI for this element
40 
41 #define NO_SINR -5000
42 #define HARQ_PROC_NUM 8
43 #define HARQ_DL_TIMEOUT 11
44 
45 namespace ns3 {
46 
47 typedef std::vector < uint8_t > DlHarqProcessesStatus_t;
48 typedef std::vector < uint8_t > DlHarqProcessesTimer_t;
49 typedef std::vector < DlDciListElement_s > DlHarqProcessesDciBuffer_t;
50 typedef std::vector < std::vector <struct RlcPduListElement_s> > RlcPduList_t; // vector of the LCs and layers per UE
51 typedef std::vector < RlcPduList_t > DlHarqRlcPduListBuffer_t; // vector of the 8 HARQ processes per UE
52 typedef std::vector < UlDciListElement_s > UlHarqProcessesDciBuffer_t;
53 typedef std::vector < uint8_t > UlHarqProcessesStatus_t;
54 
56 {
58  unsigned long totalBytesTransmitted;
59  unsigned int lastTtiBytesTransmitted;
63 
64 };
65 
74 {
75 public:
82 
86  virtual ~CqaFfMacScheduler ();
87 
88  // inherited from Object
89  virtual void DoDispose (void);
90  static TypeId GetTypeId (void);
91 
92  // inherited from FfMacScheduler
93  virtual void SetFfMacCschedSapUser (FfMacCschedSapUser* s);
94  virtual void SetFfMacSchedSapUser (FfMacSchedSapUser* s);
97 
98  // FFR SAPs
99  virtual void SetLteFfrSapProvider (LteFfrSapProvider* s);
100  virtual LteFfrSapUser* GetLteFfrSapUser ();
101 
104 
105  void TransmissionModeConfigurationUpdate (uint16_t rnti, uint8_t txMode);
106 
107 private:
108  //
109  // Implementation of the CSCHED API primitives
110  // (See 4.1 for description of the primitives)
111  //
112 
114 
116 
118 
120 
122 
123  //
124  // Implementation of the SCHED API primitives
125  // (See 4.2 for description of the primitives)
126  //
127 
129 
131 
133 
135 
137 
139 
141 
143 
145 
147 
149 
150 
151  int GetRbgSize (int dlbandwidth);
152 
153  int LcActivePerFlow (uint16_t rnti);
154 
155  double EstimateUlSinr (uint16_t rnti, uint16_t rb);
156 
157  void RefreshDlCqiMaps (void);
158  void RefreshUlCqiMaps (void);
159 
160  void UpdateDlRlcBufferInfo (uint16_t rnti, uint8_t lcid, uint16_t size);
161  void UpdateUlRlcBufferInfo (uint16_t rnti, uint16_t size);
162 
169  uint8_t UpdateHarqProcessId (uint16_t rnti);
170 
177  uint8_t HarqProcessAvailability (uint16_t rnti);
178 
183  void RefreshHarqProcesses ();
184 
186 
187  /*
188  * Vectors of UE's LC info
189  */
190  std::map <LteFlowId_t, FfMacSchedSapProvider::SchedDlRlcBufferReqParameters> m_rlcBufferReq;
191 
192 
193  /*
194  * Map of UE statistics (per RNTI basis) in downlink
195  */
196  std::map <uint16_t, CqasFlowPerf_t> m_flowStatsDl;
197 
198  /*
199  * Map of UE statistics (per RNTI basis)
200  */
201  std::map <uint16_t, CqasFlowPerf_t> m_flowStatsUl;
202 
203  std::map <LteFlowId_t,struct LogicalChannelConfigListElement_s> m_ueLogicalChannelsConfigList;
204 
205  /*
206  * Map of UE's DL CQI P01 received
207  */
208  std::map <uint16_t,uint8_t> m_p10CqiRxed;
209  /*
210  * Map of UE's timers on DL CQI P01 received
211  */
212  std::map <uint16_t,uint32_t> m_p10CqiTimers;
213 
214  /*
215  * Map of UE's DL CQI A30 received
216  */
217  std::map <uint16_t,SbMeasResult_s> m_a30CqiRxed;
218  /*
219  * Map of UE's timers on DL CQI A30 received
220  */
221  std::map <uint16_t,uint32_t> m_a30CqiTimers;
222 
223  /*
224  * Map of previous allocated UE per RBG
225  * (used to retrieve info from UL-CQI)
226  */
227  std::map <uint16_t, std::vector <uint16_t> > m_allocationMaps;
228 
229  /*
230  * Map of UEs' UL-CQI per RBG
231  */
232  std::map <uint16_t, std::vector <double> > m_ueCqi;
233  /*
234  * Map of UEs' timers on UL-CQI per RBG
235  */
236  std::map <uint16_t, uint32_t> m_ueCqiTimers;
237 
238  /*
239  * Map of UE's buffer status reports received
240  */
241  std::map <uint16_t,uint32_t> m_ceBsrRxed;
242 
243  // MAC SAPs
248 
249  // FFR SAPs
252 
253  // Internal parameters
255 
256 
257  double m_timeWindow;
258 
259  uint16_t m_nextRntiUl; // RNTI of the next user to be served next scheduling in UL
260 
261  uint32_t m_cqiTimersThreshold; // # of TTIs for which a CQI canbe considered valid
262 
263  std::map <uint16_t,uint8_t> m_uesTxMode; // txMode of the UEs
264 
265  // HARQ attributes
269  bool m_harqOn;
270  std::map <uint16_t, uint8_t> m_dlHarqCurrentProcessId;
271  //HARQ status
272  // 0: process Id available
273  // x>0: process Id equal to `x` trasmission count
274  std::map <uint16_t, DlHarqProcessesStatus_t> m_dlHarqProcessesStatus;
275  std::map <uint16_t, DlHarqProcessesTimer_t> m_dlHarqProcessesTimer;
276  std::map <uint16_t, DlHarqProcessesDciBuffer_t> m_dlHarqProcessesDciBuffer;
277  std::map <uint16_t, DlHarqRlcPduListBuffer_t> m_dlHarqProcessesRlcPduListBuffer;
278  std::vector <DlInfoListElement_s> m_dlInfoListBuffered; // HARQ retx buffered
279 
280  std::map <uint16_t, uint8_t> m_ulHarqCurrentProcessId;
281  //HARQ status
282  // 0: process Id available
283  // x>0: process Id equal to `x` trasmission count
284  std::map <uint16_t, UlHarqProcessesStatus_t> m_ulHarqProcessesStatus;
285  std::map <uint16_t, UlHarqProcessesDciBuffer_t> m_ulHarqProcessesDciBuffer;
286 
287 
288  // RACH attributes
289  std::vector <struct RachListElement_s> m_rachList;
290  std::vector <uint16_t> m_rachAllocationMap;
291  uint8_t m_ulGrantMcs; // MCS for UL grant (default 0)
292 
293 
294  std::string m_CqaMetric;
295 
296 };
297 
298 } // namespace ns3
299 
300 #endif /* QOS_FF_MAC_SCHEDULER_H */
double EstimateUlSinr(uint16_t rnti, uint16_t rb)
void DoSchedUlMacCtrlInfoReq(const struct FfMacSchedSapProvider::SchedUlMacCtrlInfoReqParameters &params)
unsigned int lastTtiBytesTransmitted
Total bytes send by eNb for this UE.
int GetRbgSize(int dlbandwidth)
uint8_t UpdateHarqProcessId(uint16_t rnti)
Update and return a new process Id for the RNTI specified.
virtual ~CqaFfMacScheduler()
Destructor.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
std::vector< std::vector< struct RlcPduListElement_s > > RlcPduList_t
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:73
Service Access Point (SAP) offered by the eNodeB RRC instance to the Frequency Reuse algorithm instan...
Definition: lte-ffr-sap.h:132
std::map< uint16_t, CqasFlowPerf_t > m_flowStatsDl
void UpdateUlRlcBufferInfo(uint16_t rnti, uint16_t size)
virtual FfMacCschedSapProvider * GetFfMacCschedSapProvider()
Parameters of the CSCHED_UE_RELEASE_REQ primitive.
std::vector< UlDciListElement_s > UlHarqProcessesDciBuffer_t
std::map< uint16_t, DlHarqProcessesStatus_t > m_dlHarqProcessesStatus
std::vector< uint8_t > DlHarqProcessesTimer_t
std::map< uint16_t, uint32_t > m_a30CqiTimers
Provides the CSCHED SAP.
void DoSchedDlMacBufferReq(const struct FfMacSchedSapProvider::SchedDlMacBufferReqParameters &params)
virtual void SetLteFfrSapProvider(LteFfrSapProvider *s)
Set the Provider part of the LteFfrSap that this Scheduler will interact with.
Parameters of the CSCHED_LC_RELEASE_REQ primitive.
std::map< uint16_t, UlHarqProcessesDciBuffer_t > m_ulHarqProcessesDciBuffer
Parameters of the SCHED_DL_TRIGGER_REQ primitive.
void DoSchedDlRachInfoReq(const struct FfMacSchedSapProvider::SchedDlRachInfoReqParameters &params)
double lastAveragedThroughput
Total bytes send by eNB in last tti for this UE.
void DoSchedUlNoiseInterferenceReq(const struct FfMacSchedSapProvider::SchedUlNoiseInterferenceReqParameters &params)
void DoSchedUlTriggerReq(const struct FfMacSchedSapProvider::SchedUlTriggerReqParameters &params)
std::vector< RlcPduList_t > DlHarqRlcPduListBuffer_t
Parameters of the SCHED_DL_MAC_BUFFER_REQ primitive.
Parameters of the SCHED_DL_PAGING_BUFFER_REQ primitive.
void DoSchedUlCqiInfoReq(const struct FfMacSchedSapProvider::SchedUlCqiInfoReqParameters &params)
FfMacCschedSapProvider::CschedCellConfigReqParameters m_cschedCellConfig
std::vector< DlInfoListElement_s > m_dlInfoListBuffered
std::map< uint16_t, uint8_t > m_p10CqiRxed
void DoSchedUlSrInfoReq(const struct FfMacSchedSapProvider::SchedUlSrInfoReqParameters &params)
unsigned long totalBytesTransmitted
Service Access Point (SAP) offered by the Frequency Reuse algorithm instance to the MAC Scheduler ins...
Definition: lte-ffr-sap.h:39
Parameters of the SCHED_UL_TRIGGER_REQ primitive.
FfMacSchedSapUser * m_schedSapUser
FfMacCschedSapUser * m_cschedSapUser
std::map< uint16_t, DlHarqProcessesTimer_t > m_dlHarqProcessesTimer
void DoCschedUeReleaseReq(const struct FfMacCschedSapProvider::CschedUeReleaseReqParameters &params)
Provides the SCHED SAP.
LteFfrSapProvider * m_ffrSapProvider
Parameters of the SCHED_UL_NOISE_INTERFERENCE_REQ primitive.
std::map< uint16_t, DlHarqRlcPduListBuffer_t > m_dlHarqProcessesRlcPduListBuffer
virtual void SetFfMacCschedSapUser(FfMacCschedSapUser *s)
set the user part of the FfMacCschedSap that this Scheduler will interact with.
void DoSchedDlPagingBufferReq(const struct FfMacSchedSapProvider::SchedDlPagingBufferReqParameters &params)
std::map< uint16_t, uint8_t > m_ulHarqCurrentProcessId
Every class exported by the ns3 library is enclosed in the ns3 namespace.
std::vector< uint16_t > m_rachAllocationMap
std::map< uint16_t, uint32_t > m_ceBsrRxed
std::vector< DlDciListElement_s > DlHarqProcessesDciBuffer_t
FfMacSchedSapProvider * m_schedSapProvider
Parameters of the CSCHED_LC_CONFIG_REQ primitive.
std::map< uint16_t, std::vector< double > > m_ueCqi
std::map< uint16_t, UlHarqProcessesStatus_t > m_ulHarqProcessesStatus
std::map< uint16_t, CqasFlowPerf_t > m_flowStatsUl
This abstract base class identifies the interface by means of which the helper object can plug on the...
bool m_harqOn
m_harqOn when false inhibit te HARQ mechanisms (by default active)
Parameters of the SCHED_DL_CQI_INFO_REQ primitive.
static TypeId GetTypeId(void)
std::map< LteFlowId_t, FfMacSchedSapProvider::SchedDlRlcBufferReqParameters > m_rlcBufferReq
std::vector< uint8_t > UlHarqProcessesStatus_t
std::map< uint16_t, std::vector< uint16_t > > m_allocationMaps
void DoSchedDlCqiInfoReq(const struct FfMacSchedSapProvider::SchedDlCqiInfoReqParameters &params)
std::vector< uint8_t > DlHarqProcessesStatus_t
Parameters of the SCHED_UL_CQI_INFO_REQ primitive.
void DoCschedCellConfigReq(const struct FfMacCschedSapProvider::CschedCellConfigReqParameters &params)
std::map< uint16_t, SbMeasResult_s > m_a30CqiRxed
void DoCschedUeConfigReq(const struct FfMacCschedSapProvider::CschedUeConfigReqParameters &params)
double secondLastAveragedThroughput
Past average throughput.
Parameters of the SCHED_UL_MAC_CTRL_INFO_REQ primitive.
FfMacCschedSapProvider * m_cschedSapProvider
virtual void SetFfMacSchedSapUser(FfMacSchedSapUser *s)
set the user part of the FfMacSchedSap that this Scheduler will interact with.
int LcActivePerFlow(uint16_t rnti)
std::map< LteFlowId_t, struct LogicalChannelConfigListElement_s > m_ueLogicalChannelsConfigList
Parameters of the SCHED_UL_SR_INFO_REQ primitive.
void DoSchedDlRlcBufferReq(const struct FfMacSchedSapProvider::SchedDlRlcBufferReqParameters &params)
void DoCschedLcConfigReq(const struct FfMacCschedSapProvider::CschedLcConfigReqParameters &params)
virtual LteFfrSapUser * GetLteFfrSapUser()
void DoCschedLcReleaseReq(const struct FfMacCschedSapProvider::CschedLcReleaseReqParameters &params)
std::map< uint16_t, DlHarqProcessesDciBuffer_t > m_dlHarqProcessesDciBuffer
void UpdateDlRlcBufferInfo(uint16_t rnti, uint8_t lcid, uint16_t size)
std::map< uint16_t, uint8_t > m_dlHarqCurrentProcessId
Parameters of the SCHED_DL_RACH_INFO_REQ primitive.
void TransmissionModeConfigurationUpdate(uint16_t rnti, uint8_t txMode)
virtual void DoDispose(void)
Destructor implementation.
std::vector< struct RachListElement_s > m_rachList
Parameters of the CSCHED_UE_CONFIG_REQ primitive.
virtual FfMacSchedSapProvider * GetFfMacSchedSapProvider()
std::map< uint16_t, uint32_t > m_ueCqiTimers
uint8_t HarqProcessAvailability(uint16_t rnti)
Return the availability of free process for the RNTI specified.
std::map< uint16_t, uint32_t > m_p10CqiTimers
a unique identifier for an interface.
Definition: type-id.h:58
Implements the SCHED SAP and CSCHED SAP for the Channel and QoS Aware Scheduler.
void DoSchedDlTriggerReq(const struct FfMacSchedSapProvider::SchedDlTriggerReqParameters &params)
void RefreshHarqProcesses()
Refresh HARQ processes according to the timers.
std::map< uint16_t, uint8_t > m_uesTxMode