- Get link
- X
- Other Apps
Note
This is my English translated undergraduate assignment for my Telecommunication Queuing System course in the Department of Electrical Engineering, Faculty of Engineering, Udayana University. This task has never been published anywhere and I, as the author and copyright holder, license this assignment as customized CC-BY-SA where anyone can share, copy, republish, and sell it provided that my name is written as the original author and notify that the original and open version available here.
Chapter 1 Introduction
1.1 Background
The queue theory is a theory in which customers must queue to get service from the waiter. Queuing theory aims to regulate the level of service with customer arrival data. In queuing theory there are ways to set the right level of service, the level of waiters busyness, how long a customer has to wait, how many customers are in the queue, how big is the waiting room to be prepared, and so on. In the real world, a service cannot be separated from the queue, including services on the data network. To simulate queues on data networks, there are many software such as Network Simulator, which has now developed into NS3 (Network Simulator 3). In NS3 the queue can be set manually, but there are 2 types of queues that have been made, namely Droptail and RED (Random Early Detection) Queue. There are examples made by Marcos Talau and Duy Nguyen. In this paper we will simulate REDQueue on a simple point-to-point computer network.
1.2 Problem
How is the REDQueue simulation provided by Marcos Talau and Duy Nguyen?
1.3 Objective
To simulate REDQueue by Marcos Talau and Duy Nguyen on NS3.
1.4 Benefit
- Get an overview of the REDQueue queue simulation.
- Can implement queue simulation by yourself.
1.5 Scope and Limitation
- Using point-to-point IPv4 networks.
- On a 10Mbps network.
- Using the Linux version of the NS3 simulator.
- Uses Droptail and REDQueue provided on NS3.
Chapter 2 Literature Review
2.1 Queue
A simple queue model can be seen as follows:
Figure 2.1 shows the arrival of the customer λ in erlang units, the system provides a maximum waiting room w with each customer having a waiting time of Tw, and there is a waiter s with service time Ts where the level of activity is p. Tr is the average time a customer waits in the system, and r is the number of customers in the system. For calculations, see the following image (Stalling, 1998):
2.2 Droptail and RED (Random Early Detection) Queue
Droptail uses a basic queue, namely FIFO (first in first out) by discarding packets when the buffer at the node is full, while Random Early Detection instructs a connection to slow down before the buffer is full. The aim of RED is congestion avoidance to avoid congestion rather than to overcome, global synchronization avoidance, avoidance of bias against bursty traffic, and bound on average queue length to maintain the average queue length so that it maintains the average delay. In general, the algorithm from RED is that the average queue length is less than the minimum limit, so the packet will be queued. If the average queue length is between the minimum and maximum limits, there will be a probability of discarding the package. If it is above the maximum, the package will be discarded (Stallings, 1998).
2.3 Network Simulator 3
ns-3 is a discrete event network simulator, targeted primarily for research and educational use. ns-3 is free software, licensed under the GNU GPLv2 license, and the public for research, development and use (ns3-project, 2012).
Chapter 3 Experimental Method
3.1 Place and Time of Experiment
The experiment was carried out at home on May 30, 2013.
3.2 Tools
NO | Tools | Specification |
---|---|---|
1 | ACER Laptop | Intel® Pentium® dual – core processor T4200 (2.0 GHz, 800 MHz FSB, 1 MB L2 cache) Mobile Intel® Graphics Media Accelerator 4500MHD 1GB DDR2 128 WXGA Acer CrystalBriteTM LCD 250GB HDD Realtek Semiconductor Co., Ltd. RTL8111/8168B PCI Express Gigabit Ethernet Controller Atheros Communications Inc. AR928X Wireless Network Adapter Operating System Linux Backtrack 5 R3 |
2 | Software | NS3 (Network Simulator 3) |
3.3 Program
The first program takes an example from John Abraham, namely the comparison of Droptail with RED. The second program is about REDQueue by Marcos Talau and Duy Nguyen.
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ /* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation; * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * Author: John Abraham* */ #include "ns3/core-module.h" #include "ns3/network-module.h" #include "ns3/internet-module.h" #include "ns3/point-to-point-module.h" #include "ns3/applications-module.h" #include "ns3/point-to-point-layout-module.h" #include #include #include
Code 3.1 Droptail_vs_RED.cc Program
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ /* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation; * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * Authors: Marcos Talau* Duy Nguyen * */ #include "ns3/core-module.h" #include "ns3/network-module.h" #include "ns3/internet-module.h" #include "ns3/flow-monitor-helper.h" #include "ns3/point-to-point-module.h" #include "ns3/applications-module.h" using namespace ns3; NS_LOG_COMPONENT_DEFINE ("RedTests"); uint32_t checkTimes; double avgQueueSize; // The times double global_start_time; double global_stop_time; double sink_start_time; double sink_stop_time; double client_start_time; double client_stop_time; NodeContainer n0n2; NodeContainer n1n2; NodeContainer n2n3; NodeContainer n3n4; NodeContainer n3n5; Ipv4InterfaceContainer i0i2; Ipv4InterfaceContainer i1i2; Ipv4InterfaceContainer i2i3; Ipv4InterfaceContainer i3i4; Ipv4InterfaceContainer i3i5; std::stringstream filePlotQueue; std::stringstream filePlotQueueAvg; void CheckQueueSize (Ptr queue) { uint32_t qSize = StaticCast (queue)->GetQueueSize (); avgQueueSize += qSize; checkTimes++; // check queue size every 1/100 of a second Simulator::Schedule (Seconds (0.01), &CheckQueueSize, queue); std::ofstream fPlotQueue (filePlotQueue.str ().c_str (), std::ios::out|std::ios::app); fPlotQueue << Simulator::Now ().GetSeconds () << " " << qSize << std::endl; fPlotQueue.close (); std::ofstream fPlotQueueAvg (filePlotQueueAvg.str ().c_str (), std::ios::out|std::ios::app); fPlotQueueAvg << Simulator::Now ().GetSeconds () << " " << avgQueueSize / checkTimes << std::endl; fPlotQueueAvg.close (); } void BuildAppsTest (uint32_t test) { if ( (test == 1) || (test == 3) ) { // SINK is in the right side uint16_t port = 50000; Address sinkLocalAddress (InetSocketAddress (Ipv4Address::GetAny (), port)); PacketSinkHelper sinkHelper ("ns3::TcpSocketFactory", sinkLocalAddress); ApplicationContainer sinkApp = sinkHelper.Install (n3n4.Get (1)); sinkApp.Start (Seconds (sink_start_time)); sinkApp.Stop (Seconds (sink_stop_time)); // Connection one // Clients are in left side /* * Create the OnOff applications to send TCP to the server * onoffhelper is a client that send data to TCP destination */ OnOffHelper clientHelper1 ("ns3::TcpSocketFactory", Address ()); clientHelper1.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper1.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper1.SetAttribute ("DataRate", DataRateValue (DataRate ("10Mb/s"))); clientHelper1.SetAttribute ("PacketSize", UintegerValue (1000)); ApplicationContainer clientApps1; AddressValue remoteAddress (InetSocketAddress (i3i4.GetAddress (1), port)); clientHelper1.SetAttribute ("Remote", remoteAddress); clientApps1.Add (clientHelper1.Install (n0n2.Get (0))); clientApps1.Start (Seconds (client_start_time)); clientApps1.Stop (Seconds (client_stop_time)); // Connection two OnOffHelper clientHelper2 ("ns3::TcpSocketFactory", Address ()); clientHelper2.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper2.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper2.SetAttribute ("DataRate", DataRateValue (DataRate ("10Mb/s"))); clientHelper2.SetAttribute ("PacketSize", UintegerValue (1000)); ApplicationContainer clientApps2; clientHelper2.SetAttribute ("Remote", remoteAddress); clientApps2.Add (clientHelper2.Install (n1n2.Get (0))); clientApps2.Start (Seconds (3.0)); clientApps2.Stop (Seconds (client_stop_time)); } else // 4 or 5 { // SINKs // #1 uint16_t port1 = 50001; Address sinkLocalAddress1 (InetSocketAddress (Ipv4Address::GetAny (), port1)); PacketSinkHelper sinkHelper1 ("ns3::TcpSocketFactory", sinkLocalAddress1); ApplicationContainer sinkApp1 = sinkHelper1.Install (n3n4.Get (1)); sinkApp1.Start (Seconds (sink_start_time)); sinkApp1.Stop (Seconds (sink_stop_time)); // #2 uint16_t port2 = 50002; Address sinkLocalAddress2 (InetSocketAddress (Ipv4Address::GetAny (), port2)); PacketSinkHelper sinkHelper2 ("ns3::TcpSocketFactory", sinkLocalAddress2); ApplicationContainer sinkApp2 = sinkHelper2.Install (n3n5.Get (1)); sinkApp2.Start (Seconds (sink_start_time)); sinkApp2.Stop (Seconds (sink_stop_time)); // #3 uint16_t port3 = 50003; Address sinkLocalAddress3 (InetSocketAddress (Ipv4Address::GetAny (), port3)); PacketSinkHelper sinkHelper3 ("ns3::TcpSocketFactory", sinkLocalAddress3); ApplicationContainer sinkApp3 = sinkHelper3.Install (n0n2.Get (0)); sinkApp3.Start (Seconds (sink_start_time)); sinkApp3.Stop (Seconds (sink_stop_time)); // #4 uint16_t port4 = 50004; Address sinkLocalAddress4 (InetSocketAddress (Ipv4Address::GetAny (), port4)); PacketSinkHelper sinkHelper4 ("ns3::TcpSocketFactory", sinkLocalAddress4); ApplicationContainer sinkApp4 = sinkHelper4.Install (n1n2.Get (0)); sinkApp4.Start (Seconds (sink_start_time)); sinkApp4.Stop (Seconds (sink_stop_time)); // Connection #1 /* * Create the OnOff applications to send TCP to the server * onoffhelper is a client that send data to TCP destination */ OnOffHelper clientHelper1 ("ns3::TcpSocketFactory", Address ()); clientHelper1.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper1.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper1.SetAttribute ("DataRate", DataRateValue (DataRate ("10Mb/s"))); clientHelper1.SetAttribute ("PacketSize", UintegerValue (1000)); ApplicationContainer clientApps1; AddressValue remoteAddress1 (InetSocketAddress (i3i4.GetAddress (1), port1)); clientHelper1.SetAttribute ("Remote", remoteAddress1); clientApps1.Add (clientHelper1.Install (n0n2.Get (0))); clientApps1.Start (Seconds (client_start_time)); clientApps1.Stop (Seconds (client_stop_time)); // Connection #2 OnOffHelper clientHelper2 ("ns3::TcpSocketFactory", Address ()); clientHelper2.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper2.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper2.SetAttribute ("DataRate", DataRateValue (DataRate ("10Mb/s"))); clientHelper2.SetAttribute ("PacketSize", UintegerValue (1000)); ApplicationContainer clientApps2; AddressValue remoteAddress2 (InetSocketAddress (i3i5.GetAddress (1), port2)); clientHelper2.SetAttribute ("Remote", remoteAddress2); clientApps2.Add (clientHelper2.Install (n1n2.Get (0))); clientApps2.Start (Seconds (2.0)); clientApps2.Stop (Seconds (client_stop_time)); // Connection #3 OnOffHelper clientHelper3 ("ns3::TcpSocketFactory", Address ()); clientHelper3.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper3.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper3.SetAttribute ("DataRate", DataRateValue (DataRate ("10Mb/s"))); clientHelper3.SetAttribute ("PacketSize", UintegerValue (1000)); ApplicationContainer clientApps3; AddressValue remoteAddress3 (InetSocketAddress (i0i2.GetAddress (0), port3)); clientHelper3.SetAttribute ("Remote", remoteAddress3); clientApps3.Add (clientHelper3.Install (n3n4.Get (1))); clientApps3.Start (Seconds (3.5)); clientApps3.Stop (Seconds (client_stop_time)); // Connection #4 OnOffHelper clientHelper4 ("ns3::TcpSocketFactory", Address ()); clientHelper4.SetAttribute ("OnTime", StringValue ("ns3::ConstantRandomVariable[Constant=1]")); clientHelper4.SetAttribute ("OffTime", StringValue ("ns3::ConstantRandomVariable[Constant=0]")); clientHelper4.SetAttribute ("DataRate", DataRateValue (DataRate ("40b/s"))); clientHelper4.SetAttribute ("PacketSize", UintegerValue (5 * 8)); // telnet ApplicationContainer clientApps4; AddressValue remoteAddress4 (InetSocketAddress (i1i2.GetAddress (0), port4)); clientHelper4.SetAttribute ("Remote", remoteAddress4); clientApps4.Add (clientHelper4.Install (n3n5.Get (1))); clientApps4.Start (Seconds (1.0)); clientApps4.Stop (Seconds (client_stop_time)); } } int main (int argc, char *argv[]) { // LogComponentEnable ("RedExamples", LOG_LEVEL_INFO); // LogComponentEnable ("TcpNewReno", LOG_LEVEL_INFO); // LogComponentEnable ("RedQueue", LOG_LEVEL_FUNCTION); LogComponentEnable ("RedQueue", LOG_LEVEL_INFO); uint32_t redTest; std::string redLinkDataRate = "1.5Mbps"; std::string redLinkDelay = "20ms"; std::string pathOut; bool writeForPlot = false; bool writePcap = false; bool flowMonitor = false; bool printRedStats = true; global_start_time = 0.0; global_stop_time = 11; sink_start_time = global_start_time; sink_stop_time = global_stop_time + 3.0; client_start_time = sink_start_time + 0.2; client_stop_time = global_stop_time - 2.0; // Configuration and command line parameter parsing redTest = 1; // Will only save in the directory if enable opts below pathOut = "."; // Current directory CommandLine cmd; cmd.AddValue ("testNumber", "Run test 1, 3, 4 or 5", redTest); cmd.AddValue ("pathOut", "Path to save results from --writeForPlot/--writePcap/--writeFlowMonitor", pathOut); cmd.AddValue ("writeForPlot", "<0/1> to write results for plot (gnuplot)", writeForPlot); cmd.AddValue ("writePcap", "<0/1> to write results in pcapfile", writePcap); cmd.AddValue ("writeFlowMonitor", "<0/1> to enable Flow Monitor and write their results", flowMonitor); cmd.Parse (argc, argv); if ( (redTest != 1) && (redTest != 3) && (redTest != 4) && (redTest != 5) ) { NS_ABORT_MSG ("Invalid test number. Supported tests are 1, 3, 4 or 5"); } NS_LOG_INFO ("Create nodes"); NodeContainer c; c.Create (6); Names::Add ( "N0", c.Get (0)); Names::Add ( "N1", c.Get (1)); Names::Add ( "N2", c.Get (2)); Names::Add ( "N3", c.Get (3)); Names::Add ( "N4", c.Get (4)); Names::Add ( "N5", c.Get (5)); n0n2 = NodeContainer (c.Get (0), c.Get (2)); n1n2 = NodeContainer (c.Get (1), c.Get (2)); n2n3 = NodeContainer (c.Get (2), c.Get (3)); n3n4 = NodeContainer (c.Get (3), c.Get (4)); n3n5 = NodeContainer (c.Get (3), c.Get (5)); Config::SetDefault ("ns3::TcpL4Protocol::SocketType", StringValue ("ns3::TcpReno")); // 42 = headers size Config::SetDefault ("ns3::TcpSocket::SegmentSize", UintegerValue (1000 - 42)); Config::SetDefault ("ns3::TcpSocket::DelAckCount", UintegerValue (1)); GlobalValue::Bind ("ChecksumEnabled", BooleanValue (false)); uint32_t meanPktSize = 500; // RED params NS_LOG_INFO ("Set RED params"); Config::SetDefault ("ns3::RedQueue::Mode", StringValue ("QUEUE_MODE_PACKETS")); Config::SetDefault ("ns3::RedQueue::MeanPktSize", UintegerValue (meanPktSize)); Config::SetDefault ("ns3::RedQueue::Wait", BooleanValue (true)); Config::SetDefault ("ns3::RedQueue::Gentle", BooleanValue (true)); Config::SetDefault ("ns3::RedQueue::QW", DoubleValue (0.002)); Config::SetDefault ("ns3::RedQueue::MinTh", DoubleValue (5)); Config::SetDefault ("ns3::RedQueue::MaxTh", DoubleValue (15)); Config::SetDefault ("ns3::RedQueue::QueueLimit", UintegerValue (25)); if (redTest == 3) // test like 1, but with bad params { Config::SetDefault ("ns3::RedQueue::MaxTh", DoubleValue (10)); Config::SetDefault ("ns3::RedQueue::QW", DoubleValue (0.003)); } else if (redTest == 5) // test 5, same of test 4, but in byte mode { Config::SetDefault ("ns3::RedQueue::Mode", StringValue ("QUEUE_MODE_BYTES")); Config::SetDefault ("ns3::RedQueue::Ns1Compat", BooleanValue (true)); Config::SetDefault ("ns3::RedQueue::MinTh", DoubleValue (5 * meanPktSize)); Config::SetDefault ("ns3::RedQueue::MaxTh", DoubleValue (15 * meanPktSize)); Config::SetDefault ("ns3::RedQueue::QueueLimit", UintegerValue (25 * meanPktSize)); } NS_LOG_INFO ("Install internet stack on all nodes."); InternetStackHelper internet; internet.Install (c); NS_LOG_INFO ("Create channels"); PointToPointHelper p2p; p2p.SetQueue ("ns3::DropTailQueue"); p2p.SetDeviceAttribute ("DataRate", StringValue ("10Mbps")); p2p.SetChannelAttribute ("Delay", StringValue ("2ms")); NetDeviceContainer devn0n2 = p2p.Install (n0n2); p2p.SetQueue ("ns3::DropTailQueue"); p2p.SetDeviceAttribute ("DataRate", StringValue ("10Mbps")); p2p.SetChannelAttribute ("Delay", StringValue ("3ms")); NetDeviceContainer devn1n2 = p2p.Install (n1n2); p2p.SetQueue ("ns3::RedQueue", // only backbone link has RED queue "LinkBandwidth", StringValue (redLinkDataRate), "LinkDelay", StringValue (redLinkDelay)); p2p.SetDeviceAttribute ("DataRate", StringValue (redLinkDataRate)); p2p.SetChannelAttribute ("Delay", StringValue (redLinkDelay)); NetDeviceContainer devn2n3 = p2p.Install (n2n3); p2p.SetQueue ("ns3::DropTailQueue"); p2p.SetDeviceAttribute ("DataRate", StringValue ("10Mbps")); p2p.SetChannelAttribute ("Delay", StringValue ("4ms")); NetDeviceContainer devn3n4 = p2p.Install (n3n4); p2p.SetQueue ("ns3::DropTailQueue"); p2p.SetDeviceAttribute ("DataRate", StringValue ("10Mbps")); p2p.SetChannelAttribute ("Delay", StringValue ("5ms")); NetDeviceContainer devn3n5 = p2p.Install (n3n5); NS_LOG_INFO ("Assign IP Addresses"); Ipv4AddressHelper ipv4; ipv4.SetBase ("10.1.1.0", "255.255.255.0"); i0i2 = ipv4.Assign (devn0n2); ipv4.SetBase ("10.1.2.0", "255.255.255.0"); i1i2 = ipv4.Assign (devn1n2); ipv4.SetBase ("10.1.3.0", "255.255.255.0"); i2i3 = ipv4.Assign (devn2n3); ipv4.SetBase ("10.1.4.0", "255.255.255.0"); i3i4 = ipv4.Assign (devn3n4); ipv4.SetBase ("10.1.5.0", "255.255.255.0"); i3i5 = ipv4.Assign (devn3n5); // Set up the routing Ipv4GlobalRoutingHelper::PopulateRoutingTables (); if (redTest == 5) { // like in ns2 test, r2 -> r1, have a queue in packet mode Ptr nd = StaticCast (devn2n3.Get (1)); Ptr queue = nd->GetQueue (); StaticCast (queue)->SetMode (RedQueue::QUEUE_MODE_PACKETS); StaticCast (queue)->SetTh (5, 15); StaticCast (queue)->SetQueueLimit (25); } BuildAppsTest (redTest); if (writePcap) { PointToPointHelper ptp; std::stringstream stmp; stmp << pathOut << "/red"; ptp.EnablePcapAll (stmp.str ().c_str ()); } Ptr flowmon; if (flowMonitor) { FlowMonitorHelper flowmonHelper; flowmon = flowmonHelper.InstallAll (); } if (writeForPlot) { filePlotQueue << pathOut << "/" << "red-queue.plotme"; filePlotQueueAvg << pathOut << "/" << "red-queue_avg.plotme"; remove (filePlotQueue.str ().c_str ()); remove (filePlotQueueAvg.str ().c_str ()); Ptr nd = StaticCast (devn2n3.Get (0)); Ptr queue = nd->GetQueue (); Simulator::ScheduleNow (&CheckQueueSize, queue); } Simulator::Stop (Seconds (sink_stop_time)); Simulator::Run (); if (flowMonitor) { std::stringstream stmp; stmp << pathOut << "/red.flowmon"; flowmon->SerializeToXmlFile (stmp.str ().c_str (), false, false); } if (printRedStats) { Ptr nd = StaticCast (devn2n3.Get (0)); RedQueue::Stats st = StaticCast (nd->GetQueue ())->GetStats (); std::cout << "*** RED stats from Node 2 queue ***" << std::endl; std::cout << "\t " << st.unforcedDrop << " drops due prob mark" << std::endl; std::cout << "\t " << st.forcedDrop << " drops due hard mark" << std::endl; std::cout << "\t " << st.qLimDrop << " drops due queue full" << std::endl; nd = StaticCast (devn2n3.Get (1)); st = StaticCast (nd->GetQueue ())->GetStats (); std::cout << "*** RED stats from Node 3 queue ***" << std::endl; std::cout << "\t " << st.unforcedDrop << " drops due prob mark" << std::endl; std::cout << "\t " << st.forcedDrop << " drops due hard mark" << std::endl; std::cout << "\t " << st.qLimDrop << " drops due queue full" << std::endl; } Simulator::Destroy (); return 0; }
Code 3.2 red_tests.cc Program
Chapter 4 Discussion
4.1 Droptail and RED comparison simulation
It can be seen in Figure 4.1 and Figure 4.2 that according to Stallings, 1998, the droptail node will wait until the queue capacity is full before dumping it, so that a large decrease in speed is seen, which is around 300 Kbps at full time.
Meanwhile, in RED there is a preventive effort so that the capacity will not be full so disposal occurs before full capacity. Disposal of packages occurs based on the potential for excess capacity. So that you can see a gradual decrease in speed but not as big as in Droptail, which is around 50 Kbps.
4.2 RED simulation on simple topology
First, initialization occurs, namely adjustment with a very large decrease in speed, which is around 1000 Kbps.
After that, it can be seen in Figure 4.4 that the node tries to keep the capacity from exceeding 25,000 packages by gradually decreasing the speed. In the figure after Figure 4.4 the node decreases speed gradually in terms of the potential for full capacity. According to Stallings, 1998, REDQueue's work is that packets will queue if the average queue capacity does not exceed the minimum limit specified by RED. If the average queue capacity is between the minimum and the maximum limits then disposal occurs based on the probability that full capacity will occur. If the average queue capacity exceeds the maximum limit, a package discard will occur. It can be seen in the next result according to the theory.
Chapter 5 Closing
5.1 Conclusion
Network Simulator 3 can simulate REDQueue and display animation so it's easier to observe. While this simple queue simulation is in accordance with the theory where the animation shows packet dumping in the droptail when the traffic exceeds the capacity which could potentially be negative on the system, whereas in random early detection (RED) the animation shows packet dumping before the traffic exceeds capacity which can reduce the negative potential on the system.
5.2 Future Work
This simulation is just a simple experiment. Actually Network Simulator is made to simulate more complicated experiments.
Bibliography
- Ns3-project. 2012. http://www.nsnam.org. Access 27 Mei 2013.
- Stallings, W. 1998. High-Speed Networks. Prentice-Hall,inc : New Jersey.
- Get link
- X
- Other Apps
Comments
Post a Comment