22 #ifndef WIFI_SPECTRUM_VALUE_HELPER_H
23 #define WIFI_SPECTRUM_VALUE_HELPER_H
25 #include <ns3/spectrum-value.h>
65 uint16_t channelWidth,
66 uint32_t bandBandwidth,
67 uint16_t guardBandwidth);
85 uint16_t guardBandwidth);
104 uint16_t channelWidth,
106 uint16_t guardBandwidth,
107 double minInnerBandDbr = -20,
108 double minOuterbandDbr = -28,
109 double lowestPointDbr = -40);
128 uint32_t centerFrequency,
129 uint16_t channelWidth,
131 uint16_t guardBandwidth,
132 double minInnerBandDbr = -20,
133 double minOuterbandDbr = -28,
134 double lowestPointDbr = -40,
135 const std::vector<bool>& puncturedSubchannels = std::vector<bool>{});
154 uint16_t channelWidth,
156 uint16_t guardBandwidth,
157 double minInnerBandDbr = -20,
158 double minOuterbandDbr = -28,
159 double lowestPointDbr = -40);
179 uint32_t centerFrequency,
180 uint16_t channelWidth,
182 uint16_t guardBandwidth,
183 double minInnerBandDbr = -20,
184 double minOuterbandDbr = -28,
185 double lowestPointDbr = -40,
186 const std::vector<bool>& puncturedSubchannels = std::vector<bool>{});
202 uint16_t channelWidth,
204 uint16_t guardBandwidth,
219 uint16_t channelWidth,
220 uint32_t bandBandwidth,
222 uint16_t guardBandwidth);
248 uint16_t totalChannelWidth,
249 uint32_t bandBandwidth,
250 uint16_t guardBandwidth,
302 const std::vector<WifiSpectrumBand>& allocatedSubBands,
304 double txPowerPerBandW,
305 uint32_t nGuardBands,
306 uint32_t innerSlopeWidth,
307 double minInnerBandDbr,
308 double minOuterbandDbr,
309 double lowestPointDbr,
310 const std::vector<WifiSpectrumBand>& puncturedSubBands = std::vector<WifiSpectrumBand>{},
311 uint32_t puncturedSlopeWidth = 0);
331 static double DbmToW(
double dbm);
Implements Wifi SpectrumValue for the 2.4 GHz ISM band only, with a 5 MHz spectrum resolution.
virtual Ptr< SpectrumValue > CreateConstant(double psd)
Creates a SpectrumValue instance with a constant value for all frequencies.
virtual Ptr< SpectrumValue > CreateRfFilter(uint8_t channel)
Creates a SpectrumValue instance which represents the frequency response of the RF filter which is us...
virtual Ptr< SpectrumValue > CreateTxPowerSpectralDensity(double txPower, uint8_t channel)
Creates a SpectrumValue instance that represents the TX Power Spectral Density of a wifi device corre...
virtual ~WifiSpectrumValue5MhzFactory()
Destructor.
This class defines all functions to create a spectrum model for Wi-Fi based on a a spectral model ali...
static void CreateSpectrumMaskForOfdm(Ptr< SpectrumValue > c, const std::vector< WifiSpectrumBand > &allocatedSubBands, WifiSpectrumBand maskBand, double txPowerPerBandW, uint32_t nGuardBands, uint32_t innerSlopeWidth, double minInnerBandDbr, double minOuterbandDbr, double lowestPointDbr, const std::vector< WifiSpectrumBand > &puncturedSubBands=std::vector< WifiSpectrumBand >{}, uint32_t puncturedSlopeWidth=0)
Create a transmit power spectral density corresponding to OFDM transmit spectrum mask requirements fo...
virtual ~WifiSpectrumValueHelper()
Destructor.
static Ptr< SpectrumValue > CreateDuplicated20MhzTxPowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, double txPowerW, uint16_t guardBandwidth, double minInnerBandDbr=-20, double minOuterbandDbr=-28, double lowestPointDbr=-40, const std::vector< bool > &puncturedSubchannels=std::vector< bool >{})
Create a transmit power spectral density corresponding to OFDM duplicated over multiple 20 MHz subcha...
static Ptr< SpectrumValue > CreateHtOfdmTxPowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, double txPowerW, uint16_t guardBandwidth, double minInnerBandDbr=-20, double minOuterbandDbr=-28, double lowestPointDbr=-40)
Create a transmit power spectral density corresponding to OFDM High Throughput (HT) (802....
static Ptr< SpectrumValue > CreateOfdmTxPowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, double txPowerW, uint16_t guardBandwidth, double minInnerBandDbr=-20, double minOuterbandDbr=-28, double lowestPointDbr=-40)
Create a transmit power spectral density corresponding to OFDM (802.11a/g).
static Ptr< SpectrumValue > CreateDsssTxPowerSpectralDensity(uint32_t centerFrequency, double txPowerW, uint16_t guardBandwidth)
Create a transmit power spectral density corresponding to DSSS.
static Ptr< SpectrumModel > GetSpectrumModel(uint32_t centerFrequency, uint16_t channelWidth, uint32_t bandBandwidth, uint16_t guardBandwidth)
Return a SpectrumModel instance corresponding to the center frequency and channel width.
static Ptr< SpectrumValue > CreateNoisePowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, uint32_t bandBandwidth, double noiseFigure, uint16_t guardBandwidth)
Create a power spectral density corresponding to the noise.
static Ptr< SpectrumValue > CreateHeMuOfdmTxPowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, double txPowerW, uint16_t guardBandwidth, WifiSpectrumBand ru)
Create a transmit power spectral density corresponding to the OFDMA part of HE TB PPDUs for a given R...
static double DbmToW(double dbm)
Convert from dBm to Watts.
static void NormalizeSpectrumMask(Ptr< SpectrumValue > c, double txPowerW)
Normalize the transmit spectrum mask generated by CreateSpectrumMaskForOfdm so that the total transmi...
static double GetBandPowerW(Ptr< SpectrumValue > psd, const WifiSpectrumBand &band)
Calculate the power of the specified band composed of uniformly-sized sub-bands.
static Ptr< SpectrumValue > CreateRfFilter(uint32_t centerFrequency, uint16_t totalChannelWidth, uint32_t bandBandwidth, uint16_t guardBandwidth, WifiSpectrumBand band)
Create a spectral density corresponding to the RF filter.
static Ptr< SpectrumValue > CreateHeOfdmTxPowerSpectralDensity(uint32_t centerFrequency, uint16_t channelWidth, double txPowerW, uint16_t guardBandwidth, double minInnerBandDbr=-20, double minOuterbandDbr=-28, double lowestPointDbr=-40, const std::vector< bool > &puncturedSubchannels=std::vector< bool >{})
Create a transmit power spectral density corresponding to OFDM High Efficiency (HE) (802....
Every class exported by the ns3 library is enclosed in the ns3 namespace.
std::pair< uint32_t, uint32_t > WifiSpectrumBand
typedef for a pair of start and stop sub-band indexes