A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
tcp-yeah.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2016 ResiliNets, ITTC, University of Kansas
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Truc Anh N. Nguyen <annguyen@ittc.ku.edu>
18 *
19 * James P.G. Sterbenz <jpgs@ittc.ku.edu>, director
20 * ResiliNets Research Group https://resilinets.org/
21 * Information and Telecommunication Technology Center (ITTC)
22 * and Department of Electrical Engineering and Computer Science
23 * The University of Kansas Lawrence, KS USA.
24 */
25
26#ifndef TCPYEAH_H
27#define TCPYEAH_H
28
29#include "tcp-recovery-ops.h"
30#include "tcp-scalable.h"
31
32namespace ns3
33{
34
35/**
36 * \ingroup congestionOps
37 *
38 * \brief An implementation of TCP YeAH
39 *
40 * YeAH-TCP (Yet Another HighSpeed TCP) is a heuristic designed to balance various
41 * requirements of a state-of-the-art congestion control algorithm:
42 * 1) fully exploit the link capacity of high BDP networks while inducing a small
43 * number of congestion events
44 * 2) compete friendly with Reno flows
45 * 3) achieve intra and RTT fairness
46 * 4) robust to random losses
47 * 5) achieve high performance regardless of buffer size
48 *
49 * YeAH operates between 2 modes: Fast and Slow mode. In the Fast mode when the
50 * queue occupancy is small and the network congestion level is low, YeAH
51 * increments its congestion window according to the aggressive STCP rule.
52 * When the number of packets in the queue grows beyond a threshold and the
53 * network congestion level is high, YeAH enters its Slow mode, acting as Reno
54 * with a decongestion algorithm. YeAH employs Vegas' mechanism for calculating
55 * the backlog as in Equation (1). The estimation of the network congestion
56 * level is shown in Equation (2).
57 *
58 * Q = (RTT - BaseRTT) (cwnd / RTT) (1)
59 * L = (RTT - BaseRTT) / BaseRTT (2)
60 *
61 * To ensure TCP friendliness, YeAH also implements an algorithm to detect the
62 * presence of legacy Reno flows. Upon the receipt of 3 duplicate ACKs,
63 * YeAH decreases its slow start threshold according to Equation (3) if
64 * it's not competing with Reno flows. Otherwise, the ssthresh is halved
65 * as in Reno.
66 *
67 * ssthresh = min{max{cwnd/8, Q}, cwnd/2}
68 *
69 * More information: http://www.csc.lsu.edu/~sjpark/cs7601/4-YeAH_TCP.pdf
70 */
71
72class TcpYeah : public TcpNewReno
73{
74 public:
75 /**
76 * \brief Get the type ID.
77 * \return the object TypeId
78 */
79 static TypeId GetTypeId();
80
81 /**
82 * Create an unbound tcp socket.
83 */
84 TcpYeah();
85
86 /**
87 * \brief Copy constructor
88 * \param sock the object to copy
89 */
90 TcpYeah(const TcpYeah& sock);
91 ~TcpYeah() override;
92
93 std::string GetName() const override;
94
95 /**
96 * \brief Compute RTTs needed to execute YeAH algorithm
97 *
98 * The function filters RTT samples from the last RTT to find
99 * the current smallest propagation delay + queueing delay (minRtt).
100 * We take the minimum to avoid the effects of delayed ACKs.
101 *
102 * The function also min-filters all RTT measurements seen to find the
103 * propagation delay (baseRtt).
104 *
105 * \param tcb internal congestion state
106 * \param segmentsAcked count of segments ACKed
107 * \param rtt last RTT
108 *
109 */
110 void PktsAcked(Ptr<TcpSocketState> tcb, uint32_t segmentsAcked, const Time& rtt) override;
111
112 /**
113 * \brief Enable/disable YeAH algorithm depending on the congestion state
114 *
115 * We only start a YeAH cycle when we are in normal congestion state (CA_OPEN state).
116 *
117 * \param tcb internal congestion state
118 * \param newState new congestion state to which the TCP is going to switch
119 */
121 const TcpSocketState::TcpCongState_t newState) override;
122
123 /**
124 * \brief Adjust cwnd following YeAH dual-mode algorithm
125 *
126 * \param tcb internal congestion state
127 * \param segmentsAcked count of segments ACKed
128 */
129 void IncreaseWindow(Ptr<TcpSocketState> tcb, uint32_t segmentsAcked) override;
130
131 /**
132 * \brief Get slow start threshold upon the receipt of 3 dupACKs
133 *
134 * \param tcb internal congestion state
135 * \param bytesInFlight number of outstanding bytes
136 *
137 * \return the slow start threshold value
138 */
139 uint32_t GetSsThresh(Ptr<const TcpSocketState> tcb, uint32_t bytesInFlight) override;
140
141 Ptr<TcpCongestionOps> Fork() override;
142
143 protected:
144 private:
145 /**
146 * \brief Enable YeAH algorithm to start taking YeAH samples
147 *
148 * YeAH algorithm is enabled in the following situations:
149 * 1. at the establishment of a connection
150 * 2. after an RTO
151 * 3. after fast recovery
152 * 4. when an idle connection is restarted
153 *
154 * \param nextTxSequence Sequence to transmit next
155 */
156 void EnableYeah(const SequenceNumber32& nextTxSequence);
157
158 /**
159 * \brief Stop taking YeAH samples
160 */
161 void DisableYeah();
162
163 private:
164 uint32_t m_alpha; //!< Maximum backlog allowed at the bottleneck queue; Q_max in the paper
165 uint32_t m_gamma; //!< Fraction of queue to be removed per RTT when precautionary decongestion
166 //!< executed
167 uint32_t m_delta; //!< Log minimum fraction of cwnd to be removed on loss
168 uint32_t m_epsilon; //!< Log maximum fraction to be removed on early decongestion
169 uint32_t m_phy; //!< Maximum delta from base
170 uint32_t m_rho; //!< Minimum number of consecutive RTT to consider competition with Reno flows
171 //!< on loss
172 uint32_t m_zeta; //!< Minimum number of state switches to reset m_renoCount
173
174 uint32_t m_stcpAiFactor; //!< STCP additive increase parameter
175 Ptr<TcpScalable> m_stcp; //!< TcpScalable object
176 Time m_baseRtt; //!< Minimum of all YeAH RTT measurements seen during connection
177 Time m_minRtt; //!< Minimum of all RTTs measured within last RTT
178 uint32_t m_cntRtt; //!< Number of RTT measurements during last RTT
179 bool m_doingYeahNow; //!< If true, do YeAH for this RTT
180 SequenceNumber32 m_begSndNxt; //!< Right edge during last RTT
181 uint32_t m_lastQ; //!< Last number of packets in the bottleneck queue
182 uint32_t m_doingRenoNow; //!< Number of RTTs in "Slow" mode
183 uint32_t m_renoCount; //!< Estimated cwnd of competing Reno flow
184 uint32_t m_fastCount; //!< Number of RTTs in "Fast" mode
185};
186
187} // namespace ns3
188
189#endif // TCPYEAH_H
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
The NewReno implementation.
TcpCongState_t
Definition of the Congestion state machine.
An implementation of TCP YeAH.
Definition: tcp-yeah.h:73
Time m_minRtt
Minimum of all RTTs measured within last RTT.
Definition: tcp-yeah.h:177
uint32_t m_zeta
Minimum number of state switches to reset m_renoCount.
Definition: tcp-yeah.h:172
void IncreaseWindow(Ptr< TcpSocketState > tcb, uint32_t segmentsAcked) override
Adjust cwnd following YeAH dual-mode algorithm.
Definition: tcp-yeah.cc:204
void PktsAcked(Ptr< TcpSocketState > tcb, uint32_t segmentsAcked, const Time &rtt) override
Compute RTTs needed to execute YeAH algorithm.
Definition: tcp-yeah.cc:149
Ptr< TcpCongestionOps > Fork() override
Copy the congestion control algorithm across sockets.
Definition: tcp-yeah.cc:143
uint32_t m_renoCount
Estimated cwnd of competing Reno flow.
Definition: tcp-yeah.h:183
bool m_doingYeahNow
If true, do YeAH for this RTT.
Definition: tcp-yeah.h:179
void CongestionStateSet(Ptr< TcpSocketState > tcb, const TcpSocketState::TcpCongState_t newState) override
Enable/disable YeAH algorithm depending on the congestion state.
Definition: tcp-yeah.cc:189
static TypeId GetTypeId()
Get the type ID.
Definition: tcp-yeah.cc:37
uint32_t m_cntRtt
Number of RTT measurements during last RTT.
Definition: tcp-yeah.h:178
std::string GetName() const override
Get the name of the congestion control algorithm.
Definition: tcp-yeah.cc:315
uint32_t m_lastQ
Last number of packets in the bottleneck queue.
Definition: tcp-yeah.h:181
uint32_t GetSsThresh(Ptr< const TcpSocketState > tcb, uint32_t bytesInFlight) override
Get slow start threshold upon the receipt of 3 dupACKs.
Definition: tcp-yeah.cc:321
SequenceNumber32 m_begSndNxt
Right edge during last RTT.
Definition: tcp-yeah.h:180
uint32_t m_stcpAiFactor
STCP additive increase parameter.
Definition: tcp-yeah.h:174
Ptr< TcpScalable > m_stcp
TcpScalable object.
Definition: tcp-yeah.h:175
uint32_t m_alpha
Maximum backlog allowed at the bottleneck queue; Q_max in the paper.
Definition: tcp-yeah.h:164
uint32_t m_phy
Maximum delta from base.
Definition: tcp-yeah.h:169
uint32_t m_epsilon
Log maximum fraction to be removed on early decongestion.
Definition: tcp-yeah.h:168
void EnableYeah(const SequenceNumber32 &nextTxSequence)
Enable YeAH algorithm to start taking YeAH samples.
Definition: tcp-yeah.cc:170
uint32_t m_doingRenoNow
Number of RTTs in "Slow" mode.
Definition: tcp-yeah.h:182
uint32_t m_rho
Minimum number of consecutive RTT to consider competition with Reno flows on loss.
Definition: tcp-yeah.h:170
TcpYeah()
Create an unbound tcp socket.
Definition: tcp-yeah.cc:87
void DisableYeah()
Stop taking YeAH samples.
Definition: tcp-yeah.cc:181
uint32_t m_fastCount
Number of RTTs in "Fast" mode.
Definition: tcp-yeah.h:184
Time m_baseRtt
Minimum of all YeAH RTT measurements seen during connection.
Definition: tcp-yeah.h:176
uint32_t m_gamma
Fraction of queue to be removed per RTT when precautionary decongestion executed.
Definition: tcp-yeah.h:165
uint32_t m_delta
Log minimum fraction of cwnd to be removed on loss.
Definition: tcp-yeah.h:167
~TcpYeah() override
Definition: tcp-yeah.cc:137
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.