A Discrete-Event Network Simulator
API
pie-queue-disc.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2016 NITK Surathkal
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  * Authors: Shravya Ks <shravya.ks0@gmail.com>
19  * Smriti Murali <m.smriti.95@gmail.com>
20  * Mohit P. Tahiliani <tahiliani@nitk.edu.in>
21  */
22 
23 /*
24  * PORT NOTE: This code was ported from ns-2.36rc1 (queue/pie.h).
25  * Most of the comments are also ported from the same.
26  */
27 
28 #ifndef PIE_QUEUE_DISC_H
29 #define PIE_QUEUE_DISC_H
30 
31 #include "ns3/queue-disc.h"
32 #include "ns3/nstime.h"
33 #include "ns3/boolean.h"
34 #include "ns3/data-rate.h"
35 #include "ns3/timer.h"
36 #include "ns3/event-id.h"
37 #include "ns3/random-variable-stream.h"
38 
39 #define BURST_RESET_TIMEOUT 1.5
40 
41 namespace ns3 {
42 
43 class TraceContainer;
44 class UniformRandomVariable;
45 
51 class PieQueueDisc : public QueueDisc
52 {
53 public:
58  static TypeId GetTypeId (void);
59 
63  PieQueueDisc ();
64 
68  virtual ~PieQueueDisc ();
69 
74  {
78  };
79 
86  {
89  };
90 
98  void SetMode (QueueDiscMode mode);
99 
107  QueueDiscMode GetMode (void) const;
108 
114  uint32_t GetQueueSize (void);
115 
123  void SetQueueLimit (uint32_t lim);
124 
130  Time GetQueueDelay (void);
131 
140  int64_t AssignStreams (int64_t stream);
141 
142  // Reasons for dropping packets
143  static constexpr const char* UNFORCED_DROP = "Unforced drop";
144  static constexpr const char* FORCED_DROP = "Forced drop";
145 
146 protected:
150  virtual void DoDispose (void);
151 
152 private:
153  virtual bool DoEnqueue (Ptr<QueueDiscItem> item);
154  virtual Ptr<QueueDiscItem> DoDequeue (void);
155  virtual Ptr<const QueueDiscItem> DoPeek (void);
156  virtual bool CheckConfig (void);
157 
161  virtual void InitializeParams (void);
162 
169  bool DropEarly (Ptr<QueueDiscItem> item, uint32_t qSize);
170 
176  void CalculateP ();
177 
179 
180  // ** Variables supplied by user
184  uint32_t m_meanPktSize;
186  double m_a;
187  double m_b;
188  uint32_t m_dqThreshold;
189 
190  // ** Variables maintained by PIE
191  double m_dropProb;
195  uint32_t m_burstReset;
198  double m_avgDqRate;
199  double m_dqStart;
200  uint64_t m_dqCount;
203 };
204 
205 }; // namespace ns3
206 
207 #endif
208 
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
Time m_tUpdate
Time period after which CalculateP () is called.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:73
void SetMode(QueueDiscMode mode)
Set the operating mode of this queue disc.
double m_avgDqRate
Time averaged dequeue rate.
Time m_maxBurst
Maximum burst allowed before random early dropping kicks in.
double m_a
Parameter to pie controller.
QueueDiscMode GetMode(void) const
Get the operating mode of this queue disc.
static constexpr const char * FORCED_DROP
Drops due to queue limit: reactive.
virtual void InitializeParams(void)
Initialize the queue parameters.
Use number of packets for maximum queue disc size.
uint32_t m_burstReset
Used to reset value of burst allowance.
static constexpr const char * UNFORCED_DROP
Early probability drops: proactive.
QueueDisc is an abstract base class providing the interface and implementing the operations common to...
Definition: queue-disc.h:181
Implements PIE Active Queue Management discipline.
Time m_qDelayRef
Desired queue delay.
double m_dropProb
Variable used in calculation of drop probability.
uint32_t m_meanPktSize
Average packet size in bytes.
void SetQueueLimit(uint32_t lim)
Set the limit of the queue in bytes or packets.
Time GetQueueDelay(void)
Get queue delay.
#define max(a, b)
Definition: 80211b.c:45
virtual bool CheckConfig(void)
Check whether the current configuration is correct.
Time m_sUpdate
Start time of the update timer.
uint32_t m_dqThreshold
Minimum queue size in bytes before dequeue rate is measured.
Time m_qDelayOld
Old value of queue delay.
BurstStateT
Burst types.
double m_dqStart
Start timestamp of current measurement cycle.
bool DropEarly(Ptr< QueueDiscItem > item, uint32_t qSize)
Check if a packet needs to be dropped due to probability drop.
virtual void DoDispose(void)
Dispose of the object.
QueueDiscMode
Enumeration of the modes supported in the class.
void CalculateP()
Periodically update the drop probability based on the delay samples: not only the current delay sampl...
Every class exported by the ns3 library is enclosed in the ns3 namespace.
uint32_t GetQueueSize(void)
Get the current value of the queue in bytes or packets.
EventId m_rtrsEvent
Event used to decide the decision of interval of drop probability calculation.
Ptr< UniformRandomVariable > m_uv
Rng stream.
PieQueueDisc()
PieQueueDisc Constructor.
virtual Ptr< QueueDiscItem > DoDequeue(void)
This function actually extracts a packet from the queue disc.
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model...
virtual Ptr< const QueueDiscItem > DoPeek(void)
This function returns a copy of the next packet the queue disc will extract.
Time m_qDelay
Current value of queue delay.
An identifier for simulation events.
Definition: event-id.h:53
static TypeId GetTypeId(void)
Get the type ID.
BurstStateT m_burstState
Used to determine the current state of burst.
Time m_burstAllowance
Current max burst value in seconds that is allowed before random drops kick in.
virtual ~PieQueueDisc()
PieQueueDisc Destructor.
virtual bool DoEnqueue(Ptr< QueueDiscItem > item)
This function actually enqueues a packet into the queue disc.
Use number of bytes for maximum queue disc size.
double m_b
Parameter to pie controller.
uint64_t m_dqCount
Number of bytes departed since current measurement cycle starts.
a unique identifier for an interface.
Definition: type-id.h:58
static const uint64_t DQCOUNT_INVALID
Invalid dqCount value.
bool m_inMeasurement
Indicates whether we are in a measurement cycle.