22 #ifndef TTA_FF_MAC_SCHEDULER_H 
   23 #define TTA_FF_MAC_SCHEDULER_H 
   25 #include <ns3/lte-common.h> 
   26 #include <ns3/ff-mac-csched-sap.h> 
   27 #include <ns3/ff-mac-sched-sap.h> 
   28 #include <ns3/ff-mac-scheduler.h> 
   32 #include <ns3/nstime.h> 
   33 #include <ns3/lte-amc.h> 
   34 #include <ns3/lte-ffr-sap.h> 
   41 #define HARQ_PROC_NUM 8 
   42 #define HARQ_DL_TIMEOUT 11 
   50 typedef std::vector < std::vector <struct RlcPduListElement_s> > 
RlcPduList_t; 
 
  181   std::map <LteFlowId_t, FfMacSchedSapProvider::SchedDlRlcBufferReqParameters> 
m_rlcBufferReq;
 
  222   std::map <uint16_t, std::vector <double> > 
m_ueCqi;
 
std::vector< DlInfoListElement_s > m_dlInfoListBuffered
 
FfMacCschedSapUser * m_cschedSapUser
 
int GetRbgSize(int dlbandwidth)
 
void DoSchedUlCqiInfoReq(const struct FfMacSchedSapProvider::SchedUlCqiInfoReqParameters ¶ms)
 
std::vector< struct RachListElement_s > m_rachList
 
std::map< uint16_t, DlHarqProcessesDciBuffer_t > m_dlHarqProcessesDciBuffer
 
double EstimateUlSinr(uint16_t rnti, uint16_t rb)
 
std::vector< std::vector< struct RlcPduListElement_s > > RlcPduList_t
 
Smart pointer class similar to boost::intrusive_ptr. 
 
Service Access Point (SAP) offered by the eNodeB RRC instance to the Frequency Reuse algorithm instan...
 
void DoCschedLcReleaseReq(const struct FfMacCschedSapProvider::CschedLcReleaseReqParameters ¶ms)
 
std::map< uint16_t, uint32_t > m_ceBsrRxed
 
std::map< uint16_t, UlHarqProcessesDciBuffer_t > m_ulHarqProcessesDciBuffer
 
Parameters of the CSCHED_UE_RELEASE_REQ primitive. 
 
std::map< LteFlowId_t, FfMacSchedSapProvider::SchedDlRlcBufferReqParameters > m_rlcBufferReq
 
void DoSchedDlRachInfoReq(const struct FfMacSchedSapProvider::SchedDlRachInfoReqParameters ¶ms)
 
std::vector< UlDciListElement_s > UlHarqProcessesDciBuffer_t
 
virtual FfMacSchedSapProvider * GetFfMacSchedSapProvider()
 
std::vector< uint8_t > DlHarqProcessesTimer_t
 
void RefreshDlCqiMaps(void)
 
void DoSchedDlCqiInfoReq(const struct FfMacSchedSapProvider::SchedDlCqiInfoReqParameters ¶ms)
 
FfMacSchedSapUser * m_schedSapUser
 
std::map< uint16_t, uint32_t > m_a30CqiTimers
 
Parameters of the CSCHED_LC_RELEASE_REQ primitive. 
 
Parameters of the SCHED_DL_TRIGGER_REQ primitive. 
 
virtual void DoDispose(void)
Destructor implementation. 
 
std::map< uint16_t, uint32_t > m_p10CqiTimers
 
void UpdateDlRlcBufferInfo(uint16_t rnti, uint8_t lcid, uint16_t size)
 
void RefreshHarqProcesses()
Refresh HARQ processes according to the timers. 
 
LteFfrSapProvider * m_ffrSapProvider
 
void DoCschedUeConfigReq(const struct FfMacCschedSapProvider::CschedUeConfigReqParameters ¶ms)
 
std::map< uint16_t, SbMeasResult_s > m_a30CqiRxed
 
void DoSchedDlRlcBufferReq(const struct FfMacSchedSapProvider::SchedDlRlcBufferReqParameters ¶ms)
 
std::map< uint16_t, DlHarqRlcPduListBuffer_t > m_dlHarqProcessesRlcPduListBuffer
 
std::vector< RlcPduList_t > DlHarqRlcPduListBuffer_t
 
Parameters of the SCHED_DL_MAC_BUFFER_REQ primitive. 
 
FfMacCschedSapProvider::CschedCellConfigReqParameters m_cschedCellConfig
 
Parameters of the SCHED_DL_PAGING_BUFFER_REQ primitive. 
 
std::map< uint16_t, uint8_t > m_p10CqiRxed
 
void DoSchedUlMacCtrlInfoReq(const struct FfMacSchedSapProvider::SchedUlMacCtrlInfoReqParameters ¶ms)
 
Service Access Point (SAP) offered by the Frequency Reuse algorithm instance to the MAC Scheduler ins...
 
Parameters of the SCHED_UL_TRIGGER_REQ primitive. 
 
uint8_t UpdateHarqProcessId(uint16_t rnti)
Update and return a new process Id for the RNTI specified. 
 
std::map< uint16_t, uint8_t > m_uesTxMode
 
std::map< uint16_t, uint32_t > m_ueCqiTimers
 
int LcActivePerFlow(uint16_t rnti)
 
std::map< uint16_t, uint8_t > m_ulHarqCurrentProcessId
 
virtual void SetLteFfrSapProvider(LteFfrSapProvider *s)
Set the Provider part of the LteFfrSap that this Scheduler will interact with. 
 
Parameters of the SCHED_UL_NOISE_INTERFERENCE_REQ primitive. 
 
void DoCschedLcConfigReq(const struct FfMacCschedSapProvider::CschedLcConfigReqParameters ¶ms)
 
Parameters of the API primitives. 
 
uint8_t HarqProcessAvailability(uint16_t rnti)
Return the availability of free process for the RNTI specified. 
 
void DoSchedUlNoiseInterferenceReq(const struct FfMacSchedSapProvider::SchedUlNoiseInterferenceReqParameters ¶ms)
 
static TypeId GetTypeId(void)
 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
 
virtual FfMacCschedSapProvider * GetFfMacCschedSapProvider()
 
LteFfrSapUser * m_ffrSapUser
 
std::vector< DlDciListElement_s > DlHarqProcessesDciBuffer_t
 
Parameters of the CSCHED_LC_CONFIG_REQ primitive. 
 
FfMacSchedSapProvider * m_schedSapProvider
 
void UpdateUlRlcBufferInfo(uint16_t rnti, uint16_t size)
 
std::set< uint16_t > m_flowStatsDl
 
std::set< uint16_t > m_flowStatsUl
 
This abstract base class identifies the interface by means of which the helper object can plug on the...
 
void TransmissionModeConfigurationUpdate(uint16_t rnti, uint8_t txMode)
 
void DoCschedCellConfigReq(const struct FfMacCschedSapProvider::CschedCellConfigReqParameters ¶ms)
 
bool m_harqOn
m_harqOn when false inhibit te HARQ mechanisms (by default active) 
 
std::map< uint16_t, std::vector< double > > m_ueCqi
 
Parameters of the SCHED_DL_CQI_INFO_REQ primitive. 
 
void DoCschedUeReleaseReq(const struct FfMacCschedSapProvider::CschedUeReleaseReqParameters ¶ms)
 
virtual ~TtaFfMacScheduler()
Destructor. 
 
TtaFfMacScheduler()
Constructor. 
 
std::vector< uint8_t > UlHarqProcessesStatus_t
 
void DoSchedDlPagingBufferReq(const struct FfMacSchedSapProvider::SchedDlPagingBufferReqParameters ¶ms)
 
void DoSchedDlTriggerReq(const struct FfMacSchedSapProvider::SchedDlTriggerReqParameters ¶ms)
 
std::vector< uint8_t > DlHarqProcessesStatus_t
 
Parameters of the SCHED_UL_CQI_INFO_REQ primitive. 
 
void DoSchedDlMacBufferReq(const struct FfMacSchedSapProvider::SchedDlMacBufferReqParameters ¶ms)
 
std::map< uint16_t, UlHarqProcessesStatus_t > m_ulHarqProcessesStatus
 
Parameters of the API primitives. 
 
Parameters of the SCHED_UL_MAC_CTRL_INFO_REQ primitive. 
 
std::map< uint16_t, DlHarqProcessesStatus_t > m_dlHarqProcessesStatus
 
std::map< uint16_t, DlHarqProcessesTimer_t > m_dlHarqProcessesTimer
 
Parameters of the SCHED_UL_SR_INFO_REQ primitive. 
 
std::map< uint16_t, uint8_t > m_dlHarqCurrentProcessId
 
void DoSchedUlTriggerReq(const struct FfMacSchedSapProvider::SchedUlTriggerReqParameters ¶ms)
 
virtual void SetFfMacSchedSapUser(FfMacSchedSapUser *s)
set the user part of the FfMacSchedSap that this Scheduler will interact with. 
 
Parameters of the SCHED_DL_RACH_INFO_REQ primitive. 
 
virtual void SetFfMacCschedSapUser(FfMacCschedSapUser *s)
set the user part of the FfMacCschedSap that this Scheduler will interact with. 
 
Parameters of the CSCHED_UE_CONFIG_REQ primitive. 
 
std::vector< uint16_t > m_rachAllocationMap
 
FfMacCschedSapProvider * m_cschedSapProvider
 
uint32_t m_cqiTimersThreshold
 
std::map< uint16_t, std::vector< uint16_t > > m_allocationMaps
 
a unique identifier for an interface. 
 
void RefreshUlCqiMaps(void)
 
Implements the SCHED SAP and CSCHED SAP for a Throughput to Average scheduler. 
 
void DoSchedUlSrInfoReq(const struct FfMacSchedSapProvider::SchedUlSrInfoReqParameters ¶ms)
 
virtual LteFfrSapUser * GetLteFfrSapUser()