blob: 02927144c57b3c49f78394f0e8b32b2f880a1525 [file] [log] [blame]
Klaus Schneider9e5122b2019-03-19 17:03:25 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2016-2019, Regents of the University of California,
4 * Colorado State University,
5 * University Pierre & Marie Curie, Sorbonne University.
6 *
7 * This file is part of ndn-tools (Named Data Networking Essential Tools).
8 * See AUTHORS.md for complete list of ndn-tools authors and contributors.
9 *
10 * ndn-tools is free software: you can redistribute it and/or modify it under the terms
11 * of the GNU General Public License as published by the Free Software Foundation,
12 * either version 3 of the License, or (at your option) any later version.
13 *
14 * ndn-tools is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 * PURPOSE. See the GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along with
19 * ndn-tools, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
20 *
21 * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
22 *
23 * @author Shuo Yang
24 * @author Weiwei Liu
25 * @author Chavoosh Ghasemi
26 * @author Klaus Schneider
27 */
28
29#include "pipeline-interests-aimd.hpp"
30
31#include <cmath>
32
33namespace ndn {
34namespace chunks {
35
36PipelineInterestsAimd::PipelineInterestsAimd(Face& face, RttEstimator& rttEstimator,
37 const Options& options)
38 : PipelineInterestsAdaptive(face, rttEstimator, options)
39{
40 if (options.isVerbose) {
41 std::cerr << options;
42 }
43}
44
45void
46PipelineInterestsAimd::increaseWindow()
47{
48 if (m_cwnd < m_ssthresh) {
49 m_cwnd += m_options.aiStep; // additive increase
50 }
51 else {
52 m_cwnd += m_options.aiStep / std::floor(m_cwnd); // congestion avoidance
53 }
54
55 emitSignal(afterCwndChange, time::steady_clock::now() - getStartTime(), m_cwnd);
56}
57
58void
59PipelineInterestsAimd::decreaseWindow()
60{
61 // please refer to RFC 5681, Section 3.1 for the rationale behind it
62 m_ssthresh = std::max(MIN_SSTHRESH, m_cwnd * m_options.mdCoef); // multiplicative decrease
63 m_cwnd = m_options.resetCwndToInit ? m_options.initCwnd : m_ssthresh;
64
65 emitSignal(afterCwndChange, time::steady_clock::now() - getStartTime(), m_cwnd);
66}
67
68} // namespace chunks
69} // namespace ndn