A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
pf-ff-mac-scheduler.h
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  */
20 
21 #ifndef PF_FF_MAC_SCHEDULER_H
22 #define PF_FF_MAC_SCHEDULER_H
23 
24 #include <ns3/lte-common.h>
25 #include <ns3/ff-mac-csched-sap.h>
26 #include <ns3/ff-mac-sched-sap.h>
27 #include <ns3/ff-mac-scheduler.h>
28 #include <vector>
29 #include <map>
30 #include <ns3/nstime.h>
31 #include <ns3/lte-amc.h>
32 
33 
34 // value for SINR outside the range defined by FF-API, used to indicate that there
35 // is no CQI for this element
36 #define NO_SINR -5000
37 
38 
39 #define HARQ_PROC_NUM 8
40 #define HARQ_DL_TIMEOUT 11
41 
42 namespace ns3 {
43 
44 
45 typedef std::vector < uint8_t > DlHarqProcessesStatus_t;
46 typedef std::vector < uint8_t > DlHarqProcessesTimer_t;
47 typedef std::vector < DlDciListElement_s > DlHarqProcessesDciBuffer_t;
48 typedef std::vector < std::vector <struct RlcPduListElement_s> > RlcPduList_t; // vector of the LCs and layers per UE
49 typedef std::vector < RlcPduList_t > DlHarqRlcPduListBuffer_t; // vector of the 8 HARQ processes per UE
50 
51 typedef std::vector < UlDciListElement_s > UlHarqProcessesDciBuffer_t;
52 typedef std::vector < uint8_t > UlHarqProcessesStatus_t;
53 
54 
56 {
57  Time flowStart;
58  unsigned long totalBytesTransmitted;
59  unsigned int lastTtiBytesTrasmitted;
60  double lastAveragedThroughput;
61 };
62 
63 
76 {
77 public:
84 
88  virtual ~PfFfMacScheduler ();
89 
90  // inherited from Object
91  virtual void DoDispose (void);
92  static TypeId GetTypeId (void);
93 
94  // inherited from FfMacScheduler
95  virtual void SetFfMacCschedSapUser (FfMacCschedSapUser* s);
96  virtual void SetFfMacSchedSapUser (FfMacSchedSapUser* s);
99 
102 
103  void TransmissionModeConfigurationUpdate (uint16_t rnti, uint8_t txMode);
104 
105 private:
106  //
107  // Implementation of the CSCHED API primitives
108  // (See 4.1 for description of the primitives)
109  //
110 
111  void DoCschedCellConfigReq (const struct FfMacCschedSapProvider::CschedCellConfigReqParameters& params);
112 
113  void DoCschedUeConfigReq (const struct FfMacCschedSapProvider::CschedUeConfigReqParameters& params);
114 
115  void DoCschedLcConfigReq (const struct FfMacCschedSapProvider::CschedLcConfigReqParameters& params);
116 
117  void DoCschedLcReleaseReq (const struct FfMacCschedSapProvider::CschedLcReleaseReqParameters& params);
118 
119  void DoCschedUeReleaseReq (const struct FfMacCschedSapProvider::CschedUeReleaseReqParameters& params);
120 
121  //
122  // Implementation of the SCHED API primitives
123  // (See 4.2 for description of the primitives)
124  //
125 
126  void DoSchedDlRlcBufferReq (const struct FfMacSchedSapProvider::SchedDlRlcBufferReqParameters& params);
127 
128  void DoSchedDlPagingBufferReq (const struct FfMacSchedSapProvider::SchedDlPagingBufferReqParameters& params);
129 
130  void DoSchedDlMacBufferReq (const struct FfMacSchedSapProvider::SchedDlMacBufferReqParameters& params);
131 
132  void DoSchedDlTriggerReq (const struct FfMacSchedSapProvider::SchedDlTriggerReqParameters& params);
133 
134  void DoSchedDlRachInfoReq (const struct FfMacSchedSapProvider::SchedDlRachInfoReqParameters& params);
135 
136  void DoSchedDlCqiInfoReq (const struct FfMacSchedSapProvider::SchedDlCqiInfoReqParameters& params);
137 
138  void DoSchedUlTriggerReq (const struct FfMacSchedSapProvider::SchedUlTriggerReqParameters& params);
139 
140  void DoSchedUlNoiseInterferenceReq (const struct FfMacSchedSapProvider::SchedUlNoiseInterferenceReqParameters& params);
141 
142  void DoSchedUlSrInfoReq (const struct FfMacSchedSapProvider::SchedUlSrInfoReqParameters& params);
143 
144  void DoSchedUlMacCtrlInfoReq (const struct FfMacSchedSapProvider::SchedUlMacCtrlInfoReqParameters& params);
145 
146  void DoSchedUlCqiInfoReq (const struct FfMacSchedSapProvider::SchedUlCqiInfoReqParameters& params);
147 
148 
149  int GetRbgSize (int dlbandwidth);
150 
151  int LcActivePerFlow (uint16_t rnti);
152 
153  double EstimateUlSinr (uint16_t rnti, uint16_t rb);
154 
155  void RefreshDlCqiMaps (void);
156  void RefreshUlCqiMaps (void);
157 
158  void UpdateDlRlcBufferInfo (uint16_t rnti, uint8_t lcid, uint16_t size);
159  void UpdateUlRlcBufferInfo (uint16_t rnti, uint16_t size);
160 
167  uint8_t UpdateHarqProcessId (uint16_t rnti);
168 
175  uint8_t HarqProcessAvailability (uint16_t rnti);
176 
181  void RefreshHarqProcesses ();
182 
183  Ptr<LteAmc> m_amc;
184 
185  /*
186  * Vectors of UE's LC info
187  */
188  std::map <LteFlowId_t, FfMacSchedSapProvider::SchedDlRlcBufferReqParameters> m_rlcBufferReq;
189 
190 
191  /*
192  * Map of UE statistics (per RNTI basis) in downlink
193  */
194  std::map <uint16_t, pfsFlowPerf_t> m_flowStatsDl;
195 
196  /*
197  * Map of UE statistics (per RNTI basis)
198  */
199  std::map <uint16_t, pfsFlowPerf_t> m_flowStatsUl;
200 
201 
202  /*
203  * Map of UE's DL CQI P01 received
204  */
205  std::map <uint16_t,uint8_t> m_p10CqiRxed;
206  /*
207  * Map of UE's timers on DL CQI P01 received
208  */
209  std::map <uint16_t,uint32_t> m_p10CqiTimers;
210 
211  /*
212  * Map of UE's DL CQI A30 received
213  */
214  std::map <uint16_t,SbMeasResult_s> m_a30CqiRxed;
215  /*
216  * Map of UE's timers on DL CQI A30 received
217  */
218  std::map <uint16_t,uint32_t> m_a30CqiTimers;
219 
220  /*
221  * Map of previous allocated UE per RBG
222  * (used to retrieve info from UL-CQI)
223  */
224  std::map <uint16_t, std::vector <uint16_t> > m_allocationMaps;
225 
226  /*
227  * Map of UEs' UL-CQI per RBG
228  */
229  std::map <uint16_t, std::vector <double> > m_ueCqi;
230  /*
231  * Map of UEs' timers on UL-CQI per RBG
232  */
233  std::map <uint16_t, uint32_t> m_ueCqiTimers;
234 
235  /*
236  * Map of UE's buffer status reports received
237  */
238  std::map <uint16_t,uint32_t> m_ceBsrRxed;
239 
240  // MAC SAPs
241  FfMacCschedSapUser* m_cschedSapUser;
242  FfMacSchedSapUser* m_schedSapUser;
243  FfMacCschedSapProvider* m_cschedSapProvider;
244  FfMacSchedSapProvider* m_schedSapProvider;
245 
246 
247  // Internal parameters
249 
250 
251  double m_timeWindow;
252 
253  uint16_t m_nextRntiUl; // RNTI of the next user to be served next scheduling in UL
254 
255  uint32_t m_cqiTimersThreshold; // # of TTIs for which a CQI canbe considered valid
256 
257  std::map <uint16_t,uint8_t> m_uesTxMode; // txMode of the UEs
258 
259  // HARQ attributes
263  bool m_harqOn;
264  std::map <uint16_t, uint8_t> m_dlHarqCurrentProcessId;
265  //HARQ status
266  // 0: process Id available
267  // x>0: process Id equal to `x` trasmission count
268  std::map <uint16_t, DlHarqProcessesStatus_t> m_dlHarqProcessesStatus;
269  std::map <uint16_t, DlHarqProcessesTimer_t> m_dlHarqProcessesTimer;
270  std::map <uint16_t, DlHarqProcessesDciBuffer_t> m_dlHarqProcessesDciBuffer;
271  std::map <uint16_t, DlHarqRlcPduListBuffer_t> m_dlHarqProcessesRlcPduListBuffer;
272  std::vector <DlInfoListElement_s> m_dlInfoListBuffered; // HARQ retx buffered
273 
274  std::map <uint16_t, uint8_t> m_ulHarqCurrentProcessId;
275  //HARQ status
276  // 0: process Id available
277  // x>0: process Id equal to `x` trasmission count
278  std::map <uint16_t, UlHarqProcessesStatus_t> m_ulHarqProcessesStatus;
279  std::map <uint16_t, UlHarqProcessesDciBuffer_t> m_ulHarqProcessesDciBuffer;
280 
281 
282  // RACH attributes
283  std::vector <struct RachListElement_s> m_rachList;
284  std::vector <uint16_t> m_rachAllocationMap;
285  uint8_t m_ulGrantMcs; // MCS for UL grant (default 0)
286 
287 };
288 
289 } // namespace ns3
290 
291 #endif /* PF_FF_MAC_SCHEDULER_H */
keep track of time unit.
Definition: nstime.h:149
smart pointer class similar to boost::intrusive_ptr
Definition: ptr.h:59
Implements the SCHED SAP and CSCHED SAP for a Proportional Fair scheduler.
virtual FfMacSchedSapProvider * GetFfMacSchedSapProvider()
uint8_t HarqProcessAvailability(uint16_t rnti)
Return the availability of free process for the RNTI specified.
Provides the CSCHED SAP.
virtual void SetFfMacSchedSapUser(FfMacSchedSapUser *s)
virtual FfMacCschedSapProvider * GetFfMacCschedSapProvider()
Provides the SCHED SAP.
virtual void DoDispose(void)
void RefreshHarqProcesses()
Refresh HARQ processes according to the timers.
virtual void SetFfMacCschedSapUser(FfMacCschedSapUser *s)
a unique identifier for an interface.
Definition: type-id.h:44
uint8_t UpdateHarqProcessId(uint16_t rnti)
Update and return a new process Id for the RNTI specified.