23 #ifndef LTE_SPECTRUM_PHY_H
24 #define LTE_SPECTRUM_PHY_H
26 #include <ns3/event-id.h>
27 #include <ns3/spectrum-value.h>
28 #include <ns3/mobility-model.h>
29 #include <ns3/packet.h>
30 #include <ns3/nstime.h>
31 #include <ns3/net-device.h>
32 #include <ns3/spectrum-phy.h>
33 #include <ns3/spectrum-channel.h>
34 #include <ns3/spectrum-interference.h>
35 #include <ns3/data-rate.h>
36 #include <ns3/generic-phy.h>
37 #include <ns3/packet-burst.h>
38 #include <ns3/lte-interference.h>
39 #include "ns3/random-variable-stream.h"
41 #include <ns3/ff-mac-common.h>
42 #include <ns3/lte-harq-phy.h>
43 #include <ns3/lte-common.h>
54 TbId_t (
const uint16_t a,
const uint8_t b);
380 void AddExpectedTb (uint16_t rnti, uint8_t ndi, uint16_t size, uint8_t mcs, std::vector<int> map, uint8_t layer, uint8_t harqId, uint8_t rv,
bool downlink);
Ptr< LteHarqPhy > m_harqPhyModule
void SetLtePhyTxEndCallback(LtePhyTxEndCallback c)
keep track of time values and allow control of global simulation resolution
smart pointer class similar to boost::intrusive_ptr
void StartRxData(Ptr< LteSpectrumSignalParametersDataFrame > params)
Ptr< LteInterference > m_interferenceCtrl
LtePhyRxCtrlEndOkCallback m_ltePhyRxCtrlEndOkCallback
TracedCallback< Ptr< const PacketBurst > > m_phyTxEndTrace
void SetState(State newState)
Set the state of the phy layer.
forward calls to a chain of CallbackAn ns3::TracedCallback has almost exactly the same API as a norma...
void AddInterferenceCtrlChunkProcessor(Ptr< LteSinrChunkProcessor > p)
TracedCallback< Ptr< const Packet > > m_phyRxEndErrorTrace
void SetLtePhyRxDataEndErrorCallback(LtePhyRxDataEndErrorCallback c)
void SetTxModeGain(uint8_t txMode, double gain)
LtePhyRxCtrlEndErrorCallback m_ltePhyRxCtrlEndErrorCallback
void SetTransmissionMode(uint8_t txMode)
Ptr< SpectrumChannel > m_channel
std::list< Ptr< LteControlMessage > > m_txControlMessageList
LtePhyTxEndCallback m_ltePhyTxEndCallback
Callback< void, UlInfoListElement_s > LtePhyUlHarqFeedbackCallback
expectedTbs_t m_expectedTbs
Ptr< LteInterference > m_interferenceData
Callback< void > LtePhyRxCtrlEndErrorCallback
Ptr< SpectrumChannel > GetChannel()
LtePhyRxDataEndErrorCallback m_ltePhyRxDataEndErrorCallback
void SetNoisePowerSpectralDensity(Ptr< const SpectrumValue > noisePsd)
set the noise power spectral density
Ptr< UniformRandomVariable > m_random
Provides uniform random variables.
void SetDevice(Ptr< NetDevice > d)
std::list< Ptr< PacketBurst > > m_rxPacketBurstList
Callback< void, std::list< Ptr< LteControlMessage > > > LtePhyRxCtrlEndOkCallback
void SetLtePhyUlHarqFeedbackCallback(LtePhyUlHarqFeedbackCallback c)
void ChangeState(State newState)
std::list< Ptr< LteControlMessage > > m_rxControlMessageList
void SetLtePhyRxCtrlEndOkCallback(LtePhyRxCtrlEndOkCallback c)
void SetTxPowerSpectralDensity(Ptr< SpectrumValue > txPsd)
void SetLtePhyRxCtrlEndErrorCallback(LtePhyRxCtrlEndErrorCallback c)
friend bool operator==(const TbId_t &a, const TbId_t &b)
Ptr< AntennaModel > m_antenna
TracedCallback< Ptr< const PacketBurst > > m_phyRxStartTrace
LtePhyRxDataEndOkCallback m_ltePhyRxDataEndOkCallback
bool StartTxDataFrame(Ptr< PacketBurst > pb, std::list< Ptr< LteControlMessage > > ctrlMsgList, Time duration)
uint8_t m_transmissionMode
std::map< TbId_t, tbInfo_t > expectedTbs_t
Ptr< MobilityModel > m_mobility
void SetHarqPhyModule(Ptr< LteHarqPhy > harq)
virtual ~LteSpectrumPhy()
int64_t AssignStreams(int64_t stream)
void StartRxCtrl(Ptr< SpectrumSignalParameters > params)
Ptr< NetDevice > GetDevice()
Ptr< SpectrumValue > m_txPsd
friend bool operator<(const TbId_t &a, const TbId_t &b)
void SetAntenna(Ptr< AntennaModel > a)
void AddRsPowerChunkProcessor(Ptr< LteSinrChunkProcessor > p)
EventId m_endRxDlCtrlEvent
bool m_dataErrorModelEnabled
Callback< void, uint16_t, Ptr< SpectrumValue > > LtePhyRxPssCallback
void AddExpectedTb(uint16_t rnti, uint8_t ndi, uint16_t size, uint8_t mcs, std::vector< int > map, uint8_t layer, uint8_t harqId, uint8_t rv, bool downlink)
Ptr< const SpectrumModel > GetRxSpectrumModel() const
Ptr< AntennaModel > GetRxAntenna()
Ptr< MobilityModel > GetMobility()
Ptr< const SpectrumModel > m_rxSpectrumModel
LtePhyDlHarqFeedbackCallback m_ltePhyDlHarqFeedbackCallback
Ptr< PacketBurst > m_txPacketBurst
void SetChannel(Ptr< SpectrumChannel > c)
TracedCallback< PhyReceptionStatParameters > m_ulPhyReception
Ptr< NetDevice > m_device
bool m_ctrlErrorModelEnabled
LtePhyUlHarqFeedbackCallback m_ltePhyUlHarqFeedbackCallback
static TypeId GetTypeId(void)
TracedCallback< Ptr< const Packet > > m_phyRxEndOkTrace
bool StartTxDlCtrlFrame(std::list< Ptr< LteControlMessage > > ctrlMsgList, bool pss)
void SetLtePhyDlHarqFeedbackCallback(LtePhyDlHarqFeedbackCallback c)
an identifier for simulation events.
void AddCtrlSinrChunkProcessor(Ptr< LteSinrChunkProcessor > p)
void AddDataSinrChunkProcessor(Ptr< LteSinrChunkProcessor > p)
void SetLtePhyRxPssCallback(LtePhyRxPssCallback c)
LtePhyRxPssCallback m_ltePhyRxPssCallback
void AddInterferenceDataChunkProcessor(Ptr< LteSinrChunkProcessor > p)
Callback< void, DlInfoListElement_s > LtePhyDlHarqFeedbackCallback
EventId m_endRxUlSrsEvent
void SetLtePhyRxDataEndOkCallback(LtePhyRxDataEndOkCallback c)
void SetMobility(Ptr< MobilityModel > m)
Callback< void, Ptr< Packet > > LtePhyRxDataEndOkCallback
Callback< void, Ptr< const Packet > > LtePhyTxEndCallback
void StartRx(Ptr< SpectrumSignalParameters > params)
TracedCallback< Ptr< const PacketBurst > > m_phyTxStartTrace
Set of values corresponding to a given SpectrumModel.
interface for antenna radiation pattern models
a unique identifier for an interface.
void UpdateSinrPerceived(const SpectrumValue &sinr)
void SetCellId(uint16_t cellId)
std::vector< int > rbBitmap
SpectrumValue m_sinrPerceived
std::vector< double > m_txModeGain
TracedCallback< PhyReceptionStatParameters > m_dlPhyReception
Callback< void > LtePhyRxDataEndErrorCallback