blob: c9c81b986fcde697451db86c128a56feee603a44 [file] [log] [blame]
Alexander Afanasyev029d38d2012-01-09 13:50:50 -08001/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2011 University of California, Los Angeles
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 * Author: Ilya Moiseenko <iliamo@cs.ucla.edu>
19 */
20
Alexander Afanasyev0c395372014-12-20 15:54:02 -080021#include "ndn-consumer-cbr.hpp"
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080022#include "ns3/ptr.h"
23#include "ns3/log.h"
24#include "ns3/simulator.h"
25#include "ns3/packet.h"
26#include "ns3/callback.h"
27#include "ns3/string.h"
28#include "ns3/boolean.h"
29#include "ns3/uinteger.h"
Alexander Afanasyeva89bc102013-07-16 10:17:31 -070030#include "ns3/integer.h"
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080031#include "ns3/double.h"
32
Alexander Afanasyev0c395372014-12-20 15:54:02 -080033#include "ns3/ndn-app-face.hpp"
34#include "ns3/ndn-interest.hpp"
35#include "ns3/ndn-data.hpp"
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080036
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080037NS_LOG_COMPONENT_DEFINE("ndn.ConsumerCbr");
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080038
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070039namespace ns3 {
40namespace ndn {
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080041
42NS_OBJECT_ENSURE_REGISTERED(ConsumerCbr);
43
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080044TypeId
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080045ConsumerCbr::GetTypeId(void)
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080046{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080047 static TypeId tid =
48 TypeId("ns3::ndn::ConsumerCbr")
49 .SetGroupName("Ndn")
50 .SetParent<Consumer>()
51 .AddConstructor<ConsumerCbr>()
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080052
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080053 .AddAttribute("Frequency", "Frequency of interest packets", StringValue("1.0"),
54 MakeDoubleAccessor(&ConsumerCbr::m_frequency), MakeDoubleChecker<double>())
Alexander Afanasyevf8b0f712012-12-28 19:25:12 -080055
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080056 .AddAttribute("Randomize",
57 "Type of send time randomization: none (default), uniform, exponential",
58 StringValue("none"),
59 MakeStringAccessor(&ConsumerCbr::SetRandomize, &ConsumerCbr::GetRandomize),
60 MakeStringChecker())
61
62 .AddAttribute("MaxSeq", "Maximum sequence number to request",
63 IntegerValue(std::numeric_limits<uint32_t>::max()),
64 MakeIntegerAccessor(&ConsumerCbr::m_seqMax), MakeIntegerChecker<uint32_t>())
Alexander Afanasyevf8b0f712012-12-28 19:25:12 -080065
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080066 ;
67
68 return tid;
69}
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080070
71ConsumerCbr::ConsumerCbr()
72 : m_frequency(1.0)
73 , m_firstTime(true)
74 , m_random(0)
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080075{
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080076 NS_LOG_FUNCTION_NOARGS();
77 m_seqMax = std::numeric_limits<uint32_t>::max();
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080078}
79
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080080ConsumerCbr::~ConsumerCbr()
Alexander Afanasyev59e67712012-02-07 11:49:34 -080081{
82 if (m_random)
83 delete m_random;
84}
85
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080086void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080087ConsumerCbr::ScheduleNextPacket()
Alexander Afanasyev029d38d2012-01-09 13:50:50 -080088{
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080089 // double mean = 8.0 * m_payloadSize / m_desiredRate.GetBitRate ();
Alexander Afanasyev94cebd02012-01-16 12:22:34 -080090 // std::cout << "next: " << Simulator::Now().ToDouble(Time::S) + mean << "s\n";
Alexander Afanasyev359bfb72012-01-09 18:42:50 -080091
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -080092 if (m_firstTime) {
93 m_sendEvent = Simulator::Schedule(Seconds(0.0), &Consumer::SendPacket, this);
94 m_firstTime = false;
95 }
96 else if (!m_sendEvent.IsRunning())
97 m_sendEvent = Simulator::Schedule((m_random == 0) ? Seconds(1.0 / m_frequency)
98 : Seconds(m_random->GetValue()),
99 &Consumer::SendPacket, this);
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800100}
101
Alexander Afanasyev59e67712012-02-07 11:49:34 -0800102void
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800103ConsumerCbr::SetRandomize(const std::string& value)
Alexander Afanasyev59e67712012-02-07 11:49:34 -0800104{
105 if (m_random)
106 delete m_random;
107
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800108 if (value == "uniform") {
109 m_random = new UniformVariable(0.0, 2 * 1.0 / m_frequency);
110 }
111 else if (value == "exponential") {
112 m_random = new ExponentialVariable(1.0 / m_frequency, 50 * 1.0 / m_frequency);
113 }
Alexander Afanasyev59e67712012-02-07 11:49:34 -0800114 else
115 m_random = 0;
116
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800117 m_randomType = value;
Alexander Afanasyev59e67712012-02-07 11:49:34 -0800118}
119
120std::string
Alexander Afanasyevbe55cf62014-12-20 17:51:09 -0800121ConsumerCbr::GetRandomize() const
Alexander Afanasyev59e67712012-02-07 11:49:34 -0800122{
123 return m_randomType;
124}
125
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800126///////////////////////////////////////////////////
127// Process incoming packets //
128///////////////////////////////////////////////////
129
130// void
Alexander Afanasyev772f51b2013-08-01 18:53:25 -0700131// Consumer::OnData (const Ptr<const Data> &contentObject,
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800132// const Ptr<const Packet> &payload)
133// {
Alexander Afanasyev772f51b2013-08-01 18:53:25 -0700134// Consumer::OnData (contentObject, payload); // tracing inside
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800135// }
136
137// void
Alexander Afanasyeveae83ee2013-03-15 15:01:10 -0700138// Consumer::OnNack (const Ptr<const Interest> &interest)
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800139// {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700140// Consumer::OnNack (interest); // tracing inside
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800141// }
142
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700143} // namespace ndn
Alexander Afanasyev029d38d2012-01-09 13:50:50 -0800144} // namespace ns3