blob: 398ec0258f48705fdbb2e96ba1ab7a220fc0ba73 [file] [log] [blame]
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -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: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
19 */
20
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070021#include "ndn-consumer-batches.h"
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -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/uinteger.h"
29#include "ns3/double.h"
30#include "ns3/batches.h"
31
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070032NS_LOG_COMPONENT_DEFINE ("ndn.ConsumerBatches");
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080033
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070034namespace ns3 {
35namespace ndn {
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080036
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070037NS_OBJECT_ENSURE_REGISTERED (ConsumerBatches);
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080038
39TypeId
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070040ConsumerBatches::GetTypeId (void)
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080041{
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070042 static TypeId tid = TypeId ("ns3::ndn::ConsumerBatches")
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070043 .SetGroupName ("Ndn")
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070044 .SetParent<Consumer> ()
45 .AddConstructor<ConsumerBatches> ()
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080046
47 .AddAttribute ("Batches", "Batches to schedule. Should be vector, containing pairs of time and amount",
48 // TypeId::ATTR_SET,
49 StringValue (""),
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070050 MakeBatchesAccessor (&ConsumerBatches::GetBatch, &ConsumerBatches::SetBatch),
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080051 MakeBatchesChecker ())
52 ;
53
54 return tid;
55}
56
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070057ConsumerBatches::ConsumerBatches ()
Alexander Afanasyev3476edf2012-08-14 11:26:00 -070058 : m_initial (true)
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080059{
60}
61
62void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070063ConsumerBatches::SetBatch (const Batches &batches)
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080064{
65 // std::cout << "Batches: " << batches << "\n";
66 for (Batches::const_iterator i = batches.begin (); i != batches.end (); i++)
67 {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070068 Simulator::Schedule (i->get<0> (), &ConsumerBatches::AddBatch, this, i->get<1> ());
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080069 }
70}
71
72void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070073ConsumerBatches::AddBatch (uint32_t amount)
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080074{
75 // std::cout << Simulator::Now () << " adding batch of " << amount << "\n";
76 m_seqMax += amount;
Alexander Afanasyev8e0d2812012-01-19 22:38:14 -080077 m_rtt->ClearSent (); // this is important, otherwise RTT estimation for the new batch will be affected by previous batch history
Alexander Afanasyev3476edf2012-08-14 11:26:00 -070078 m_initial = true;
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080079 ScheduleNextPacket ();
80}
81
82void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070083ConsumerBatches::ScheduleNextPacket ()
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080084{
85 if (!m_sendEvent.IsRunning ())
Alexander Afanasyev3476edf2012-08-14 11:26:00 -070086 {
87 Time delay = Seconds (0);
88 if (!m_initial) delay = m_rtt->RetransmitTimeout ();
89
90 m_initial = false;
91 m_sendEvent = Simulator::Schedule (delay, &Consumer::SendPacket, this);
92 }
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -080093}
94
95///////////////////////////////////////////////////
96// Process incoming packets //
97///////////////////////////////////////////////////
98
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070099} // namespace ndn
Alexander Afanasyevb7ad2322012-01-17 22:54:49 -0800100} // namespace ns3