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
28namespace ns3 {
29
30
37{
38public:
48 static double GetCarrierFrequency (uint32_t earfcn);
49
57 static uint16_t GetDownlinkCarrierBand (uint32_t nDl);
58
66 static uint16_t GetUplinkCarrierBand (uint32_t nUl);
67
77 static double GetDownlinkCarrierFrequency (uint32_t earfcn);
78
88 static double GetUplinkCarrierFrequency (uint32_t earfcn);
89
98 static double GetChannelBandwidth (uint16_t txBandwidthConf);
99
112 static Ptr<SpectrumModel> GetSpectrumModel (uint32_t earfcn, uint16_t bandwidth);
113
114
129 uint16_t bandwidth,
130 double powerTx,
131 std::vector <int> activeRbs);
132
150 uint16_t bandwidth,
151 double powerTx,
152 std::map<int, double> powerTxMap,
153 std::vector <int> activeRbs);
154
170 uint16_t bandwidth,
171 double powerTx,
172 std::vector <int> activeRbs);
173
185 static Ptr<SpectrumValue> CreateNoisePowerSpectralDensity (uint32_t earfcn, uint16_t bandwidth, double noiseFigure);
186
195 static Ptr<SpectrumValue> CreateNoisePowerSpectralDensity (double noiseFigure, Ptr<SpectrumModel> spectrumModel);
196
197};
198
199
200} // namespace ns3
201
202
203
204#endif /* LTE_SPECTRUM_VALUE_HELPER_H */
This class defines all functions to create spectrum model for lte.
static Ptr< SpectrumValue > CreateUlTxPowerSpectralDensity(uint16_t earfcn, uint16_t bandwidth, double powerTx, std::vector< int > activeRbs)
create a spectrum value representing the uplink power spectral density of a signal to be transmitted.
static Ptr< SpectrumValue > CreateNoisePowerSpectralDensity(uint32_t earfcn, uint16_t bandwidth, double noiseFigure)
create a SpectrumValue that models the power spectral density of AWGN
static Ptr< SpectrumValue > CreateTxPowerSpectralDensity(uint32_t earfcn, uint16_t bandwidth, double powerTx, std::vector< int > activeRbs)
create a spectrum value representing the power spectral density of a signal to be transmitted.
static uint16_t GetUplinkCarrierBand(uint32_t nUl)
Converts uplink EARFCN to corresponding LTE frequency band number.
static uint16_t GetDownlinkCarrierBand(uint32_t nDl)
Converts downlink EARFCN to corresponding LTE frequency band number.
static double GetChannelBandwidth(uint16_t txBandwidthConf)
static double GetUplinkCarrierFrequency(uint32_t earfcn)
Calculates the uplink carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EARF...
static double GetCarrierFrequency(uint32_t earfcn)
Calculates the carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EARFCN) acc...
static Ptr< SpectrumModel > GetSpectrumModel(uint32_t earfcn, uint16_t bandwidth)
static double GetDownlinkCarrierFrequency(uint32_t earfcn)
Calculates the downlink carrier frequency from the E-UTRA Absolute Radio Frequency Channel Number (EA...
Every class exported by the ns3 library is enclosed in the ns3 namespace.