A Discrete-Event Network Simulator
API
lte-spectrum-value-helper.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2010 TELEMATICS LAB, DEE - Politecnico di Bari
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: Giuseppe Piro <g.piro@poliba.it>
19  */
20 
21 #ifndef LTE_SPECTRUM_VALUE_HELPER_H
22 #define LTE_SPECTRUM_VALUE_HELPER_H
23 
24 
25 #include <ns3/spectrum-value.h>
26 #include <vector>
27 
28 namespace ns3 {
29 
30 
37 {
38 public:
48  static double GetCarrierFrequency (uint16_t earfcn);
49 
59  static double GetDownlinkCarrierFrequency (uint16_t earfcn);
60 
70  static double GetUplinkCarrierFrequency (uint16_t earfcn);
71 
80  static double GetChannelBandwidth (uint8_t txBandwidthConf);
81 
94  static Ptr<SpectrumModel> GetSpectrumModel (uint16_t earfcn, uint8_t bandwidth);
95 
96 
110  static Ptr<SpectrumValue> CreateTxPowerSpectralDensity (uint16_t earfcn,
111  uint8_t bandwidth,
112  double powerTx,
113  std::vector <int> activeRbs);
114 
131  static Ptr<SpectrumValue> CreateTxPowerSpectralDensity (uint16_t earfcn,
132  uint8_t bandwidth,
133  double powerTx,
134  std::map<int, double> powerTxMap,
135  std::vector <int> activeRbs);
136 
148  static Ptr<SpectrumValue> CreateNoisePowerSpectralDensity (uint16_t earfcn, uint8_t bandwidth, double noiseFigure);
149 
158  static Ptr<SpectrumValue> CreateNoisePowerSpectralDensity (double noiseFigure, Ptr<SpectrumModel> spectrumModel);
159 
160 };
161 
162 
163 } // namespace ns3
164 
165 
166 
167 #endif /* LTE_SPECTRUM_VALUE_HELPER_H */
static Ptr< SpectrumModel > GetSpectrumModel(uint16_t earfcn, uint8_t bandwidth)
This class defines all functions to create spectrum model for lte.
static double GetCarrierFrequency(uint16_t earfcn)
Calculates the carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EARFCN) acc...
static double GetDownlinkCarrierFrequency(uint16_t earfcn)
Calculates the dowlink carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EAR...
static double GetUplinkCarrierFrequency(uint16_t earfcn)
Calculates the uplink carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EARF...
Every class exported by the ns3 library is enclosed in the ns3 namespace.
static double GetChannelBandwidth(uint8_t txBandwidthConf)
static Ptr< SpectrumValue > CreateTxPowerSpectralDensity(uint16_t earfcn, uint8_t bandwidth, double powerTx, std::vector< int > activeRbs)
create a spectrum value representing the power spectral density of a signal to be transmitted...
static Ptr< SpectrumValue > CreateNoisePowerSpectralDensity(uint16_t earfcn, uint8_t bandwidth, double noiseFigure)
create a SpectrumValue that models the power spectral density of AWGN