2016-07-22 18:13:42 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2009 MIRKO BANCHI
|
|
|
|
|
* Copyright (c) 2015 University of Washington
|
|
|
|
|
*
|
2024-06-17 16:17:10 +02:00
|
|
|
* SPDX-License-Identifier: GPL-2.0-only
|
2016-07-22 18:13:42 -07:00
|
|
|
*
|
|
|
|
|
* Authors: Mirko Banchi <mk.banchi@gmail.com>
|
|
|
|
|
* Sebastien Deronne <sebastien.deronne@gmail.com>
|
|
|
|
|
* Tom Henderson <tomhend@u.washington.edu>
|
|
|
|
|
*
|
2019-07-17 15:35:33 +02:00
|
|
|
* Adapted from wifi-ht-network.cc example
|
2016-07-22 18:13:42 -07:00
|
|
|
*/
|
|
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/boolean.h"
|
2018-04-13 23:08:35 +02:00
|
|
|
#include "ns3/command-line.h"
|
|
|
|
|
#include "ns3/config.h"
|
|
|
|
|
#include "ns3/double.h"
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/internet-stack-helper.h"
|
|
|
|
|
#include "ns3/ipv4-address-helper.h"
|
2018-04-13 23:08:35 +02:00
|
|
|
#include "ns3/log.h"
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/mobility-helper.h"
|
|
|
|
|
#include "ns3/multi-model-spectrum-channel.h"
|
|
|
|
|
#include "ns3/propagation-loss-model.h"
|
2018-04-13 23:08:35 +02:00
|
|
|
#include "ns3/spectrum-wifi-helper.h"
|
|
|
|
|
#include "ns3/ssid.h"
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/string.h"
|
2018-04-13 23:08:35 +02:00
|
|
|
#include "ns3/udp-client-server-helper.h"
|
2024-01-29 15:16:19 +00:00
|
|
|
#include "ns3/udp-server.h"
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/uinteger.h"
|
2018-04-13 23:08:35 +02:00
|
|
|
#include "ns3/yans-wifi-channel.h"
|
2022-10-07 20:08:35 +00:00
|
|
|
#include "ns3/yans-wifi-helper.h"
|
|
|
|
|
|
|
|
|
|
#include <iomanip>
|
2016-07-22 18:13:42 -07:00
|
|
|
|
|
|
|
|
// This is a simple example of an IEEE 802.11n Wi-Fi network.
|
|
|
|
|
//
|
|
|
|
|
// The main use case is to enable and test SpectrumWifiPhy vs YansWifiPhy
|
|
|
|
|
// under saturation conditions (for max throughput).
|
|
|
|
|
//
|
|
|
|
|
// Network topology:
|
|
|
|
|
//
|
|
|
|
|
// Wi-Fi 192.168.1.0
|
|
|
|
|
//
|
|
|
|
|
// STA AP
|
|
|
|
|
// * <-- distance --> *
|
|
|
|
|
// | |
|
|
|
|
|
// n1 n2
|
|
|
|
|
//
|
|
|
|
|
// Users may vary the following command-line arguments in addition to the
|
|
|
|
|
// attributes, global values, and default values typically available:
|
|
|
|
|
//
|
2024-02-27 22:39:01 +01:00
|
|
|
// --simulationTime: Simulation time [10s]
|
2021-09-08 15:03:40 +00:00
|
|
|
// --distance: meters separation between nodes [1]
|
2016-07-22 18:13:42 -07:00
|
|
|
// --index: restrict index to single value between 0 and 31 [256]
|
|
|
|
|
// --wifiType: select ns3::SpectrumWifiPhy or ns3::YansWifiPhy [ns3::SpectrumWifiPhy]
|
2022-10-07 20:08:35 +00:00
|
|
|
// --errorModelType: select ns3::NistErrorRateModel or ns3::YansErrorRateModel
|
|
|
|
|
// [ns3::NistErrorRateModel]
|
2016-07-22 18:13:42 -07:00
|
|
|
// --enablePcap: enable pcap output [false]
|
|
|
|
|
//
|
|
|
|
|
// By default, the program will step through 64 index values, corresponding
|
|
|
|
|
// to the following MCS, channel width, and guard interval combinations:
|
|
|
|
|
// index 0-7: MCS 0-7, long guard interval, 20 MHz channel
|
|
|
|
|
// index 8-15: MCS 0-7, short guard interval, 20 MHz channel
|
|
|
|
|
// index 16-23: MCS 0-7, long guard interval, 40 MHz channel
|
|
|
|
|
// index 24-31: MCS 0-7, short guard interval, 40 MHz channel
|
|
|
|
|
// index 32-39: MCS 8-15, long guard interval, 20 MHz channel
|
|
|
|
|
// index 40-47: MCS 8-15, short guard interval, 20 MHz channel
|
|
|
|
|
// index 48-55: MCS 8-15, long guard interval, 40 MHz channel
|
|
|
|
|
// index 56-63: MCS 8-15, short guard interval, 40 MHz channel
|
|
|
|
|
// and send packets at a high rate using each MCS, using the SpectrumWifiPhy
|
|
|
|
|
// and the NistErrorRateModel, at a distance of 1 meter. The program outputs
|
|
|
|
|
// results such as:
|
|
|
|
|
//
|
|
|
|
|
// wifiType: ns3::SpectrumWifiPhy distance: 1m
|
|
|
|
|
// index MCS width Rate (Mb/s) Tput (Mb/s) Received
|
|
|
|
|
// 0 0 20 6.5 5.96219 5063
|
|
|
|
|
// 1 1 20 13 11.9491 10147
|
|
|
|
|
// 2 2 20 19.5 17.9184 15216
|
|
|
|
|
// 3 3 20 26 23.9253 20317
|
|
|
|
|
// ...
|
|
|
|
|
//
|
|
|
|
|
// selection of index values 32-63 will result in MCS selection 8-15
|
|
|
|
|
// involving two spatial streams
|
|
|
|
|
|
|
|
|
|
using namespace ns3;
|
|
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
NS_LOG_COMPONENT_DEFINE("WifiSpectrumSaturationExample");
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
int
|
|
|
|
|
main(int argc, char* argv[])
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2024-06-13 20:40:24 +02:00
|
|
|
meter_u distance{1};
|
2024-02-27 22:39:01 +01:00
|
|
|
Time simulationTime{"10s"};
|
|
|
|
|
uint16_t index{256};
|
|
|
|
|
uint32_t channelWidth{0};
|
|
|
|
|
std::string wifiType{"ns3::SpectrumWifiPhy"};
|
|
|
|
|
std::string errorModelType{"ns3::NistErrorRateModel"};
|
|
|
|
|
bool enablePcap{false};
|
2022-10-07 20:08:35 +00:00
|
|
|
|
|
|
|
|
CommandLine cmd(__FILE__);
|
2024-02-27 22:39:01 +01:00
|
|
|
cmd.AddValue("simulationTime", "Simulation time", simulationTime);
|
2022-10-07 20:08:35 +00:00
|
|
|
cmd.AddValue("distance", "meters separation between nodes", distance);
|
|
|
|
|
cmd.AddValue("index", "restrict index to single value between 0 and 63", index);
|
|
|
|
|
cmd.AddValue("wifiType", "select ns3::SpectrumWifiPhy or ns3::YansWifiPhy", wifiType);
|
|
|
|
|
cmd.AddValue("errorModelType",
|
|
|
|
|
"select ns3::NistErrorRateModel or ns3::YansErrorRateModel",
|
|
|
|
|
errorModelType);
|
|
|
|
|
cmd.AddValue("enablePcap", "enable pcap output", enablePcap);
|
|
|
|
|
cmd.Parse(argc, argv);
|
|
|
|
|
|
|
|
|
|
uint16_t startIndex = 0;
|
|
|
|
|
uint16_t stopIndex = 63;
|
|
|
|
|
if (index < 64)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
startIndex = index;
|
|
|
|
|
stopIndex = index;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
std::cout << "wifiType: " << wifiType << " distance: " << distance << "m" << std::endl;
|
|
|
|
|
std::cout << std::setw(5) << "index" << std::setw(6) << "MCS" << std::setw(8) << "width"
|
|
|
|
|
<< std::setw(12) << "Rate (Mb/s)" << std::setw(12) << "Tput (Mb/s)" << std::setw(10)
|
|
|
|
|
<< "Received " << std::endl;
|
|
|
|
|
for (uint16_t i = startIndex; i <= stopIndex; i++)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
uint32_t payloadSize;
|
|
|
|
|
payloadSize = 1472; // 1500 bytes IPv4
|
|
|
|
|
|
|
|
|
|
NodeContainer wifiStaNode;
|
|
|
|
|
wifiStaNode.Create(1);
|
|
|
|
|
NodeContainer wifiApNode;
|
|
|
|
|
wifiApNode.Create(1);
|
|
|
|
|
|
2024-07-12 14:17:20 -07:00
|
|
|
YansWifiPhyHelper yansPhy;
|
2022-10-07 20:08:35 +00:00
|
|
|
SpectrumWifiPhyHelper spectrumPhy;
|
|
|
|
|
if (wifiType == "ns3::YansWifiPhy")
|
|
|
|
|
{
|
|
|
|
|
YansWifiChannelHelper channel;
|
|
|
|
|
channel.AddPropagationLoss("ns3::FriisPropagationLossModel");
|
|
|
|
|
channel.SetPropagationDelay("ns3::ConstantSpeedPropagationDelayModel");
|
2024-07-12 14:17:20 -07:00
|
|
|
yansPhy.SetChannel(channel.Create());
|
|
|
|
|
yansPhy.Set("TxPowerStart", DoubleValue(1));
|
|
|
|
|
yansPhy.Set("TxPowerEnd", DoubleValue(1));
|
2022-10-07 20:08:35 +00:00
|
|
|
|
2024-05-11 02:56:07 +01:00
|
|
|
if (i > 31 && i <= 63)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2024-07-12 14:17:20 -07:00
|
|
|
yansPhy.Set("Antennas", UintegerValue(2));
|
|
|
|
|
yansPhy.Set("MaxSupportedTxSpatialStreams", UintegerValue(2));
|
|
|
|
|
yansPhy.Set("MaxSupportedRxSpatialStreams", UintegerValue(2));
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (wifiType == "ns3::SpectrumWifiPhy")
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
Ptr<MultiModelSpectrumChannel> spectrumChannel =
|
|
|
|
|
CreateObject<MultiModelSpectrumChannel>();
|
|
|
|
|
Ptr<FriisPropagationLossModel> lossModel = CreateObject<FriisPropagationLossModel>();
|
|
|
|
|
spectrumChannel->AddPropagationLossModel(lossModel);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
Ptr<ConstantSpeedPropagationDelayModel> delayModel =
|
|
|
|
|
CreateObject<ConstantSpeedPropagationDelayModel>();
|
|
|
|
|
spectrumChannel->SetPropagationDelayModel(delayModel);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
spectrumPhy.SetChannel(spectrumChannel);
|
|
|
|
|
spectrumPhy.SetErrorRateModel(errorModelType);
|
|
|
|
|
spectrumPhy.Set("TxPowerStart", DoubleValue(1));
|
|
|
|
|
spectrumPhy.Set("TxPowerEnd", DoubleValue(1));
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2024-05-11 02:56:07 +01:00
|
|
|
if (i > 31 && i <= 63)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
spectrumPhy.Set("Antennas", UintegerValue(2));
|
|
|
|
|
spectrumPhy.Set("MaxSupportedTxSpatialStreams", UintegerValue(2));
|
|
|
|
|
spectrumPhy.Set("MaxSupportedRxSpatialStreams", UintegerValue(2));
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
NS_FATAL_ERROR("Unsupported WiFi type " << wifiType);
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
WifiHelper wifi;
|
|
|
|
|
wifi.SetStandard(WIFI_STANDARD_80211n);
|
|
|
|
|
WifiMacHelper mac;
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
Ssid ssid = Ssid("ns380211n");
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
double datarate = 0;
|
|
|
|
|
StringValue DataRate;
|
|
|
|
|
if (i == 0)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs0");
|
|
|
|
|
datarate = 6.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 1)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs1");
|
|
|
|
|
datarate = 13;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 2)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs2");
|
|
|
|
|
datarate = 19.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 3)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs3");
|
|
|
|
|
datarate = 26;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 4)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs4");
|
|
|
|
|
datarate = 39;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 5)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs5");
|
|
|
|
|
datarate = 52;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 6)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs6");
|
|
|
|
|
datarate = 58.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 7)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs7");
|
|
|
|
|
datarate = 65;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 8)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs0");
|
|
|
|
|
datarate = 7.2;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 9)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs1");
|
|
|
|
|
datarate = 14.4;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 10)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs2");
|
|
|
|
|
datarate = 21.7;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 11)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs3");
|
|
|
|
|
datarate = 28.9;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 12)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs4");
|
|
|
|
|
datarate = 43.3;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 13)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs5");
|
|
|
|
|
datarate = 57.8;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 14)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs6");
|
|
|
|
|
datarate = 65;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 15)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs7");
|
|
|
|
|
datarate = 72.2;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 16)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs0");
|
|
|
|
|
datarate = 13.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 17)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs1");
|
|
|
|
|
datarate = 27;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 18)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs2");
|
|
|
|
|
datarate = 40.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 19)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs3");
|
|
|
|
|
datarate = 54;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 20)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs4");
|
|
|
|
|
datarate = 81;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 21)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs5");
|
|
|
|
|
datarate = 108;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 22)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs6");
|
|
|
|
|
datarate = 121.5;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 23)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs7");
|
|
|
|
|
datarate = 135;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 24)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs0");
|
|
|
|
|
datarate = 15;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 25)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs1");
|
|
|
|
|
datarate = 30;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 26)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs2");
|
|
|
|
|
datarate = 45;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 27)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs3");
|
|
|
|
|
datarate = 60;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 28)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs4");
|
|
|
|
|
datarate = 90;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 29)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs5");
|
|
|
|
|
datarate = 120;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 30)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs6");
|
|
|
|
|
datarate = 135;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 31)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs7");
|
|
|
|
|
datarate = 150;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 32)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs8");
|
|
|
|
|
datarate = 13;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 33)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs9");
|
|
|
|
|
datarate = 26;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 34)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs10");
|
|
|
|
|
datarate = 39;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 35)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs11");
|
|
|
|
|
datarate = 52;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 36)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs12");
|
|
|
|
|
datarate = 78;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 37)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs13");
|
|
|
|
|
datarate = 104;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 38)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs14");
|
|
|
|
|
datarate = 117;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 39)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs15");
|
|
|
|
|
datarate = 130;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 40)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs8");
|
|
|
|
|
datarate = 14.4;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 41)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs9");
|
|
|
|
|
datarate = 28.9;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 42)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs10");
|
|
|
|
|
datarate = 43.3;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 43)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs11");
|
|
|
|
|
datarate = 57.8;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 44)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs12");
|
|
|
|
|
datarate = 86.7;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 45)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs13");
|
|
|
|
|
datarate = 115.6;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 46)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs14");
|
|
|
|
|
datarate = 130.3;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 47)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs15");
|
|
|
|
|
datarate = 144.4;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 48)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs8");
|
|
|
|
|
datarate = 27;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 49)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs9");
|
|
|
|
|
datarate = 54;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 50)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs10");
|
|
|
|
|
datarate = 81;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 51)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs11");
|
|
|
|
|
datarate = 108;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 52)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs12");
|
|
|
|
|
datarate = 162;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 53)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs13");
|
|
|
|
|
datarate = 216;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 54)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs14");
|
|
|
|
|
datarate = 243;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 55)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs15");
|
|
|
|
|
datarate = 270;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 56)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs8");
|
|
|
|
|
datarate = 30;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 57)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs9");
|
|
|
|
|
datarate = 60;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 58)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs10");
|
|
|
|
|
datarate = 90;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 59)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs11");
|
|
|
|
|
datarate = 120;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 60)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs12");
|
|
|
|
|
datarate = 180;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 61)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs13");
|
|
|
|
|
datarate = 240;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 62)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs14");
|
|
|
|
|
datarate = 270;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (i == 63)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
DataRate = StringValue("HtMcs15");
|
|
|
|
|
datarate = 300;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
NS_FATAL_ERROR("Illegal index i " << i);
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
wifi.SetRemoteStationManager("ns3::ConstantRateWifiManager",
|
|
|
|
|
"DataMode",
|
|
|
|
|
DataRate,
|
|
|
|
|
"ControlMode",
|
|
|
|
|
DataRate);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
NetDeviceContainer staDevice;
|
|
|
|
|
NetDeviceContainer apDevice;
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
channelWidth = (i <= 15 || (i > 31 && i <= 47) ? 20 : 40);
|
|
|
|
|
std::string channelStr = "{0, " + std::to_string(channelWidth) + ", BAND_5GHZ, 0}";
|
2021-02-11 19:01:28 +01:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
if (wifiType == "ns3::YansWifiPhy")
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
mac.SetType("ns3::StaWifiMac", "Ssid", SsidValue(ssid));
|
2024-07-12 14:17:20 -07:00
|
|
|
yansPhy.Set("ChannelSettings", StringValue(channelStr));
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2024-07-12 14:17:20 -07:00
|
|
|
staDevice = wifi.Install(yansPhy, mac, wifiStaNode);
|
2022-10-07 20:08:35 +00:00
|
|
|
mac.SetType("ns3::ApWifiMac", "Ssid", SsidValue(ssid));
|
2024-07-12 14:17:20 -07:00
|
|
|
yansPhy.Set("ChannelSettings", StringValue(channelStr));
|
|
|
|
|
apDevice = wifi.Install(yansPhy, mac, wifiApNode);
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
else if (wifiType == "ns3::SpectrumWifiPhy")
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
mac.SetType("ns3::StaWifiMac", "Ssid", SsidValue(ssid));
|
2024-07-12 14:17:20 -07:00
|
|
|
spectrumPhy.Set("ChannelSettings", StringValue(channelStr));
|
2022-10-07 20:08:35 +00:00
|
|
|
staDevice = wifi.Install(spectrumPhy, mac, wifiStaNode);
|
|
|
|
|
mac.SetType("ns3::ApWifiMac", "Ssid", SsidValue(ssid));
|
2024-07-12 14:17:20 -07:00
|
|
|
spectrumPhy.Set("ChannelSettings", StringValue(channelStr));
|
2022-10-07 20:08:35 +00:00
|
|
|
apDevice = wifi.Install(spectrumPhy, mac, wifiApNode);
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
|
2024-05-11 02:56:07 +01:00
|
|
|
bool shortGuardIntervalSupported =
|
|
|
|
|
(i > 7 && i <= 15) || (i > 23 && i <= 31) || (i > 39 && i <= 47) || (i > 55);
|
|
|
|
|
Config::Set("/NodeList/*/DeviceList/*/$ns3::WifiNetDevice/HtConfiguration/"
|
|
|
|
|
"ShortGuardIntervalSupported",
|
|
|
|
|
BooleanValue(shortGuardIntervalSupported));
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
// mobility.
|
|
|
|
|
MobilityHelper mobility;
|
|
|
|
|
Ptr<ListPositionAllocator> positionAlloc = CreateObject<ListPositionAllocator>();
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
positionAlloc->Add(Vector(0.0, 0.0, 0.0));
|
|
|
|
|
positionAlloc->Add(Vector(distance, 0.0, 0.0));
|
|
|
|
|
mobility.SetPositionAllocator(positionAlloc);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
mobility.Install(wifiApNode);
|
|
|
|
|
mobility.Install(wifiStaNode);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
/* Internet stack*/
|
|
|
|
|
InternetStackHelper stack;
|
|
|
|
|
stack.Install(wifiApNode);
|
|
|
|
|
stack.Install(wifiStaNode);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
Ipv4AddressHelper address;
|
|
|
|
|
address.SetBase("192.168.1.0", "255.255.255.0");
|
|
|
|
|
Ipv4InterfaceContainer staNodeInterface;
|
|
|
|
|
Ipv4InterfaceContainer apNodeInterface;
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
staNodeInterface = address.Assign(staDevice);
|
|
|
|
|
apNodeInterface = address.Assign(apDevice);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
/* Setting applications */
|
|
|
|
|
uint16_t port = 9;
|
|
|
|
|
UdpServerHelper server(port);
|
|
|
|
|
ApplicationContainer serverApp = server.Install(wifiStaNode.Get(0));
|
2024-11-08 18:01:13 +00:00
|
|
|
serverApp.Start(Seconds(0));
|
|
|
|
|
serverApp.Stop(simulationTime + Seconds(1));
|
2024-03-06 20:50:32 +01:00
|
|
|
const auto packetInterval = payloadSize * 8.0 / (datarate * 1e6);
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
UdpClientHelper client(staNodeInterface.GetAddress(0), port);
|
|
|
|
|
client.SetAttribute("MaxPackets", UintegerValue(4294967295U));
|
2024-03-06 20:50:32 +01:00
|
|
|
client.SetAttribute("Interval", TimeValue(Seconds(packetInterval)));
|
2022-10-07 20:08:35 +00:00
|
|
|
client.SetAttribute("PacketSize", UintegerValue(payloadSize));
|
|
|
|
|
ApplicationContainer clientApp = client.Install(wifiApNode.Get(0));
|
2024-11-08 18:01:13 +00:00
|
|
|
clientApp.Start(Seconds(1));
|
|
|
|
|
clientApp.Stop(simulationTime + Seconds(1));
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
if (enablePcap)
|
2016-07-22 18:13:42 -07:00
|
|
|
{
|
2024-07-12 14:17:20 -07:00
|
|
|
auto& phy =
|
|
|
|
|
(wifiType == "ns3::YansWifiPhy" ? dynamic_cast<WifiPhyHelper&>(yansPhy)
|
|
|
|
|
: dynamic_cast<WifiPhyHelper&>(spectrumPhy));
|
2022-10-07 20:08:35 +00:00
|
|
|
phy.SetPcapDataLinkType(WifiPhyHelper::DLT_IEEE802_11_RADIO);
|
|
|
|
|
std::stringstream ss;
|
|
|
|
|
ss << "wifi-spectrum-saturation-example-" << i;
|
|
|
|
|
phy.EnablePcap(ss.str(), apDevice);
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
|
|
|
|
|
2024-11-08 18:01:13 +00:00
|
|
|
Simulator::Stop(simulationTime + Seconds(1));
|
2022-10-07 20:08:35 +00:00
|
|
|
Simulator::Run();
|
2016-07-22 18:13:42 -07:00
|
|
|
|
2024-02-27 22:39:01 +01:00
|
|
|
double totalPacketsThrough = DynamicCast<UdpServer>(serverApp.Get(0))->GetReceived();
|
|
|
|
|
auto throughput =
|
|
|
|
|
totalPacketsThrough * payloadSize * 8 / simulationTime.GetMicroSeconds(); // Mbit/s
|
2022-10-07 20:08:35 +00:00
|
|
|
std::cout << std::setw(5) << i << std::setw(6) << (i % 8) + 8 * (i / 32) << std::setw(8)
|
|
|
|
|
<< channelWidth << std::setw(10) << datarate << std::setw(12) << throughput
|
|
|
|
|
<< std::setw(8) << totalPacketsThrough << std::endl;
|
|
|
|
|
Simulator::Destroy();
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|
2022-10-07 20:08:35 +00:00
|
|
|
return 0;
|
2016-07-22 18:13:42 -07:00
|
|
|
}
|