A Discrete-Event Network Simulator
API
lte-test-ue-phy.h
Go to the documentation of this file.
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: Manuel Requena <manuel.requena@cttc.es> : Based on lte-ue-phy code
19  */
20 
21 #ifndef LTE_TEST_UE_PHY_H
22 #define LTE_TEST_UE_PHY_H
23 
24 #include "ns3/lte-phy.h"
25 
26 #include "ns3/lte-control-messages.h"
27 
28 namespace ns3 {
29 
38 class LteTestUePhy : public LtePhy
39 {
40 public:
44  LteTestUePhy ();
45 
51 
52  virtual ~LteTestUePhy ();
53 
54  virtual void DoDispose ();
59  static TypeId GetTypeId (void);
60 
65  virtual void DoSendMacPdu (Ptr<Packet> p);
66 
72 
73  virtual void GenerateCtrlCqiReport (const SpectrumValue& sinr);
74 
75  virtual void GenerateDataCqiReport (const SpectrumValue& sinr);
76 
77  virtual void ReportInterference (const SpectrumValue& interf);
78 
79  virtual void ReportRsReceivedPower (const SpectrumValue& power);
80 
86 
92 
93 private:
95 };
96 
97 
98 } // namespace ns3
99 
100 #endif /* LTE_TEST_UE_PHY_H */
The LtePhy models the physical layer of LTE.
Definition: lte-phy.h:53
Defines a simplified LtePhy class that is used for testing purposes of downlink and uplink SINR gener...
SpectrumValue m_sinr
the SINR
virtual void GenerateCtrlCqiReport(const SpectrumValue &sinr)
generate a CQI report based on the given SINR of Ctrl frame
virtual void DoDispose()
Destructor implementation.
virtual Ptr< SpectrumValue > CreateTxPowerSpectralDensity()
Create the PSD for the TX.
virtual void GenerateDataCqiReport(const SpectrumValue &sinr)
generate a CQI report based on the given SINR of Data frame (used for PUSCH CQIs)
virtual void DoSendMacPdu(Ptr< Packet > p)
Queue the MAC PDU to be sent.
virtual void ReceiveLteControlMessage(Ptr< LteControlMessage > msg)
Reeive LTE Control Message.
virtual void ReportInterference(const SpectrumValue &interf)
generate a report based on the linear interference and noise power perceived during DATA frame NOTE: ...
virtual void ReportRsReceivedPower(const SpectrumValue &power)
generate a report based on the linear RS power perceived during CTRL frame NOTE: used only by UE for ...
SpectrumValue GetSinr()
Get the SINR.
static TypeId GetTypeId(void)
Get the type ID.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:74
Set of values corresponding to a given SpectrumModel.
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.