23 #include "ns3/string.h"
24 #include "ns3/qos-utils.h"
25 #include "ns3/packet.h"
26 #include "ns3/wifi-net-device.h"
27 #include "ns3/ap-wifi-mac.h"
28 #include "ns3/mobility-helper.h"
29 #include "ns3/spectrum-wifi-helper.h"
30 #include "ns3/multi-model-spectrum-channel.h"
31 #include "ns3/udp-client-server-helper.h"
32 #include "ns3/internet-stack-helper.h"
33 #include "ns3/ipv4-address-helper.h"
34 #include "ns3/rng-seed-manager.h"
35 #include "ns3/config.h"
36 #include "ns3/queue-size.h"
67 virtual void DoRun (
void);
83 :
TestCase (
"Test case for resuming data transmission when the recipient moves back"),
85 m_lastCheckPointTime (
Seconds (0)),
111 RngSeedManager::SetSeed (1);
112 RngSeedManager::SetRun (40);
113 int64_t streamNumber = 100;
123 spectrumChannel->AddPropagationLossModel (lossModel);
125 spectrumChannel->SetPropagationDelayModel (delayModel);
128 phy.SetChannel (spectrumChannel);
132 wifi.SetRemoteStationManager (
"ns3::ConstantRateWifiManager",
139 mac.SetType (
"ns3::StaWifiMac",
144 mac.SetType (
"ns3::ApWifiMac",
156 positionAlloc->Add (Vector (0.0, 0.0, 0.0));
157 positionAlloc->Add (Vector (5.0, 0.0, 0.0));
158 mobility.SetPositionAllocator (positionAlloc);
160 mobility.SetMobilityModel (
"ns3::ConstantPositionMobilityModel");
167 stack.Install (wifiStaNode);
170 address.SetBase (
"192.168.1.0",
"255.255.255.0");
182 serverApp = server.
Install (wifiStaNode.
Get (0));
184 serverApp.
Stop (warmup + simulationTime);
191 clientApp.
Start (warmup);
192 clientApp.
Stop (warmup + simulationTime);
198 Vector (10000.0, 0.0, 0.0));
200 DynamicCast<UdpServer> (serverApp.
Get (0)));
204 Vector (5.0, 0.0, 0.0));
206 DynamicCast<UdpServer> (serverApp.
Get (0)));
210 DynamicCast<UdpServer> (serverApp.
Get (0)));
212 Simulator::Stop (warmup + simulationTime);
223 std::cout <<
"Throughput = " << t <<
" Mb/s" << std::endl;
226 Simulator::Destroy ();
Test for issue 211 (https://gitlab.com/nsnam/ns-3-dev/-/issues/211)
std::vector< double > m_tputValues
throughput in sub-intervals
Time m_lastCheckPointTime
time of last check-point
virtual void DoRun(void)
Implementation to actually run this TestCase.
Issue211Test()
Constructor.
uint32_t m_payloadSize
payload size in bytes
uint64_t m_lastRxBytes
RX bytes at last check-point.
void CalcThroughput(Ptr< UdpServer > server)
Compute the average throughput since the last check-point.
holds a vector of ns3::Application pointers.
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
AttributeValue implementation for Boolean.
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
Helper class used to assign positions and mobility models to nodes.
Keep track of the current position and velocity of an object.
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
Smart pointer class similar to boost::intrusive_ptr.
Class for representing queue sizes.
Make it easy to create and manage PHY objects for the spectrum model.
The IEEE 802.11 SSID Information Element.
AttributeValue implementation for Ssid.
Hold variables of type string.
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
Simulation virtual time values and global simulation resolution.
AttributeValue implementation for Time.
Create a client application which sends UDP packets carrying a 32bit sequence number and a 64 bit tim...
void SetAttribute(std::string name, const AttributeValue &value)
Record an attribute to be set in each Application after it is is created.
ApplicationContainer Install(NodeContainer c)
Create a server application which waits for input UDP packets and uses the information carried into t...
ApplicationContainer Install(NodeContainer c)
Create one UDP server application on each of the Nodes in the NodeContainer.
Hold an unsigned integer type.
helps to create WifiNetDevice objects
create MAC layers for a ns3::WifiNetDevice.
void SetDefault(std::string name, const AttributeValue &value)
Time Now(void)
create an ns3::Time instance which contains the current simulation time.
#define NS_TEST_EXPECT_MSG_GT(actual, limit, msg)
Test that an actual value is greater than a limit and report if not.
#define NS_TEST_EXPECT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report if not.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit.
@ WIFI_STANDARD_80211n_5GHZ
Every class exported by the ns3 library is enclosed in the ns3 namespace.
static void SetPosition(Ptr< Node > node, Vector position)
static Issue211TestSuite g_issue211TestSuite
the test suite