A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
onoff-application.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 //
3 // Copyright (c) 2006 Georgia Tech Research Corporation
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: George F. Riley<riley@ece.gatech.edu>
19 //
20 
21 // ns3 - On/Off Data Source Application class
22 // George F. Riley, Georgia Tech, Spring 2007
23 // Adapted from ApplicationOnOff in GTNetS.
24 
25 #include "ns3/log.h"
26 #include "ns3/address.h"
27 #include "ns3/inet-socket-address.h"
28 #include "ns3/inet6-socket-address.h"
29 #include "ns3/packet-socket-address.h"
30 #include "ns3/node.h"
31 #include "ns3/nstime.h"
32 #include "ns3/data-rate.h"
33 #include "ns3/random-variable-stream.h"
34 #include "ns3/socket.h"
35 #include "ns3/simulator.h"
36 #include "ns3/socket-factory.h"
37 #include "ns3/packet.h"
38 #include "ns3/uinteger.h"
39 #include "ns3/trace-source-accessor.h"
40 #include "onoff-application.h"
41 #include "ns3/udp-socket-factory.h"
42 #include "ns3/string.h"
43 #include "ns3/pointer.h"
44 
45 NS_LOG_COMPONENT_DEFINE ("OnOffApplication");
46 
47 namespace ns3 {
48 
49 NS_OBJECT_ENSURE_REGISTERED (OnOffApplication)
50  ;
51 
52 TypeId
54 {
55  static TypeId tid = TypeId ("ns3::OnOffApplication")
57  .AddConstructor<OnOffApplication> ()
58  .AddAttribute ("DataRate", "The data rate in on state.",
59  DataRateValue (DataRate ("500kb/s")),
60  MakeDataRateAccessor (&OnOffApplication::m_cbrRate),
61  MakeDataRateChecker ())
62  .AddAttribute ("PacketSize", "The size of packets sent in on state",
63  UintegerValue (512),
64  MakeUintegerAccessor (&OnOffApplication::m_pktSize),
65  MakeUintegerChecker<uint32_t> (1))
66  .AddAttribute ("Remote", "The address of the destination",
67  AddressValue (),
68  MakeAddressAccessor (&OnOffApplication::m_peer),
69  MakeAddressChecker ())
70  .AddAttribute ("OnTime", "A RandomVariableStream used to pick the duration of the 'On' state.",
71  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
72  MakePointerAccessor (&OnOffApplication::m_onTime),
73  MakePointerChecker <RandomVariableStream>())
74  .AddAttribute ("OffTime", "A RandomVariableStream used to pick the duration of the 'Off' state.",
75  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
76  MakePointerAccessor (&OnOffApplication::m_offTime),
77  MakePointerChecker <RandomVariableStream>())
78  .AddAttribute ("MaxBytes",
79  "The total number of bytes to send. Once these bytes are sent, "
80  "no packet is sent again, even in on state. The value zero means "
81  "that there is no limit.",
82  UintegerValue (0),
83  MakeUintegerAccessor (&OnOffApplication::m_maxBytes),
84  MakeUintegerChecker<uint32_t> ())
85  .AddAttribute ("Protocol", "The type of protocol to use.",
87  MakeTypeIdAccessor (&OnOffApplication::m_tid),
88  MakeTypeIdChecker ())
89  .AddTraceSource ("Tx", "A new packet is created and is sent",
91  ;
92  return tid;
93 }
94 
95 
97  : m_socket (0),
98  m_connected (false),
99  m_residualBits (0),
100  m_lastStartTime (Seconds (0)),
101  m_totBytes (0)
102 {
103  NS_LOG_FUNCTION (this);
104 }
105 
107 {
108  NS_LOG_FUNCTION (this);
109 }
110 
111 void
112 OnOffApplication::SetMaxBytes (uint32_t maxBytes)
113 {
114  NS_LOG_FUNCTION (this << maxBytes);
115  m_maxBytes = maxBytes;
116 }
117 
120 {
121  NS_LOG_FUNCTION (this);
122  return m_socket;
123 }
124 
125 int64_t
127 {
128  NS_LOG_FUNCTION (this << stream);
129  m_onTime->SetStream (stream);
130  m_offTime->SetStream (stream + 1);
131  return 2;
132 }
133 
134 void
136 {
137  NS_LOG_FUNCTION (this);
138 
139  m_socket = 0;
140  // chain up
142 }
143 
144 // Application Methods
145 void OnOffApplication::StartApplication () // Called at time specified by Start
146 {
147  NS_LOG_FUNCTION (this);
148 
149  // Create the socket if not already
150  if (!m_socket)
151  {
154  {
155  m_socket->Bind6 ();
156  }
159  {
160  m_socket->Bind ();
161  }
163  m_socket->SetAllowBroadcast (true);
165 
169  }
171 
172  // Insure no pending event
173  CancelEvents ();
174  // If we are not yet connected, there is nothing to do here
175  // The ConnectionComplete upcall will start timers at that time
176  //if (!m_connected) return;
178 }
179 
180 void OnOffApplication::StopApplication () // Called at time specified by Stop
181 {
182  NS_LOG_FUNCTION (this);
183 
184  CancelEvents ();
185  if(m_socket != 0)
186  {
187  m_socket->Close ();
188  }
189  else
190  {
191  NS_LOG_WARN ("OnOffApplication found null socket to close in StopApplication");
192  }
193 }
194 
196 {
197  NS_LOG_FUNCTION (this);
198 
200  { // Cancel the pending send packet event
201  // Calculate residual bits since last packet sent
202  Time delta (Simulator::Now () - m_lastStartTime);
203  int64x64_t bits = delta.To (Time::S) * m_cbrRate.GetBitRate ();
204  m_residualBits += bits.GetHigh ();
205  }
209 }
210 
211 // Event handlers
213 {
214  NS_LOG_FUNCTION (this);
216  ScheduleNextTx (); // Schedule the send packet event
218 }
219 
221 {
222  NS_LOG_FUNCTION (this);
223  CancelEvents ();
224 
226 }
227 
228 // Private helpers
230 {
231  NS_LOG_FUNCTION (this);
232 
233  if (m_maxBytes == 0 || m_totBytes < m_maxBytes)
234  {
235  uint32_t bits = m_pktSize * 8 - m_residualBits;
236  NS_LOG_LOGIC ("bits = " << bits);
237  Time nextTime (Seconds (bits /
238  static_cast<double>(m_cbrRate.GetBitRate ()))); // Time till next packet
239  NS_LOG_LOGIC ("nextTime = " << nextTime);
240  m_sendEvent = Simulator::Schedule (nextTime,
242  }
243  else
244  { // All done, cancel any pending events
245  StopApplication ();
246  }
247 }
248 
250 { // Schedules the event to start sending data (switch to the "On" state)
251  NS_LOG_FUNCTION (this);
252 
253  Time offInterval = Seconds (m_offTime->GetValue ());
254  NS_LOG_LOGIC ("start at " << offInterval);
256 }
257 
259 { // Schedules the event to stop sending data (switch to "Off" state)
260  NS_LOG_FUNCTION (this);
261 
262  Time onInterval = Seconds (m_onTime->GetValue ());
263  NS_LOG_LOGIC ("stop at " << onInterval);
265 }
266 
267 
269 {
270  NS_LOG_FUNCTION (this);
271 
273  Ptr<Packet> packet = Create<Packet> (m_pktSize);
274  m_txTrace (packet);
275  m_socket->Send (packet);
278  {
279  NS_LOG_INFO ("At time " << Simulator::Now ().GetSeconds ()
280  << "s on-off application sent "
281  << packet->GetSize () << " bytes to "
283  << " port " << InetSocketAddress::ConvertFrom (m_peer).GetPort ()
284  << " total Tx " << m_totBytes << " bytes");
285  }
287  {
288  NS_LOG_INFO ("At time " << Simulator::Now ().GetSeconds ()
289  << "s on-off application sent "
290  << packet->GetSize () << " bytes to "
293  << " total Tx " << m_totBytes << " bytes");
294  }
296  m_residualBits = 0;
297  ScheduleNextTx ();
298 }
299 
300 
302 {
303  NS_LOG_FUNCTION (this << socket);
304  m_connected = true;
305 }
306 
308 {
309  NS_LOG_FUNCTION (this << socket);
310 }
311 
312 
313 } // Namespace ns3
static TypeId GetTypeId(void)
Get the type ID.
void StopSending()
Start an Off period.
Ipv6Address GetIpv6(void) const
Get the IPv6 address.
keep track of time values and allow control of global simulation resolution
Definition: nstime.h:81
Ipv4Address GetIpv4(void) const
#define NS_LOG_FUNCTION(parameters)
Definition: log.h:345
void SetStream(int64_t stream)
Specifies the stream number for this RNG stream.
virtual void StartApplication(void)
Application specific startup code.
EventId m_sendEvent
Event id of pending "send packet" event.
uint32_t m_pktSize
Size of packets.
virtual int Bind6()=0
Allocate a local IPv6 endpoint for this socket.
hold variables of type string
Definition: string.h:19
virtual bool SetAllowBroadcast(bool allowBroadcast)=0
Configure whether broadcast datagram transmissions are allowed.
void ScheduleStartEvent()
Schedule the next On period start.
void CancelEvents()
Cancel all pending events.
#define NS_ASSERT(condition)
Definition: assert.h:64
static bool IsMatchingType(const Address &address)
NS_OBJECT_ENSURE_REGISTERED(NullMessageSimulatorImpl)
virtual int ShutdownRecv(void)=0
void ScheduleStopEvent()
Schedule the next Off period start.
#define NS_LOG_INFO(msg)
Definition: log.h:298
static void Cancel(const EventId &id)
Set the cancel bit on this event: the event's associated function will not be invoked when it expires...
Definition: simulator.cc:268
bool IsRunning(void) const
This method is syntactic sugar for the ns3::Simulator::isExpired method.
Definition: event-id.cc:59
static EventId Schedule(Time const &time, MEM mem_ptr, OBJ obj)
Schedule an event to expire at the relative time "time" is reached.
Definition: simulator.h:824
virtual double GetValue(void)=0
Returns a random double from the underlying distribution.
DataRate m_cbrRateFailSafe
Rate that data is generated (check copy)
Class for representing data rates.
Definition: data-rate.h:71
virtual void DoDispose(void)
This method is called by Object::Dispose or by the object's destructor, whichever comes first...
EventId m_startStopEvent
Event id for next start or stop event.
void SendPacket()
Send a packet.
TypeId m_tid
Type of the socket used.
The base class for all ns3 applications.
Definition: application.h:61
Address m_peer
Peer address.
DataRate m_cbrRate
Rate that data is generated.
Hold an unsigned integer type.
Definition: uinteger.h:46
Ptr< RandomVariableStream > m_onTime
rng for On Time
Ptr< Node > GetNode() const
Definition: application.cc:104
hold objects of type ns3::TypeId
Ptr< Socket > GetSocket(void) const
Return a pointer to associated socket.
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1238
Ptr< Socket > m_socket
Associated socket.
static Ptr< Socket > CreateSocket(Ptr< Node > node, TypeId tid)
This method wraps the creation of sockets that is performed on a given node by a SocketFactory specif...
Definition: socket.cc:71
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model...
#define NS_LOG_LOGIC(msg)
Definition: log.h:368
Ptr< RandomVariableStream > m_offTime
rng for Off Time
virtual int Connect(const Address &address)=0
Initiate a connection to a remote host.
virtual void DoDispose(void)
This method is called by Object::Dispose or by the object's destructor, whichever comes first...
Definition: application.cc:83
TracedCallback< Ptr< const Packet > > m_txTrace
Traced Callback: transmitted packets.
virtual int Bind(const Address &address)=0
Allocate a local endpoint for this socket.
static InetSocketAddress ConvertFrom(const Address &address)
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
void ScheduleNextTx()
Schedule the next packet transmission.
void StartSending()
Start an On period.
uint64_t GetBitRate() const
Get the underlying bitrate.
Definition: data-rate.cc:235
void SetMaxBytes(uint32_t maxBytes)
Set the total number of bytes to send.
static Time Now(void)
Return the "current simulation time".
Definition: simulator.cc:180
void ConnectionSucceeded(Ptr< Socket > socket)
Handle a Connection Succeed event.
Time m_lastStartTime
Time last packet sent.
hold objects of type ns3::Address
static TypeId GetTypeId(void)
Get the type ID.
#define NS_LOG_WARN(msg)
Definition: log.h:280
hold objects of type ns3::DataRate
static Inet6SocketAddress ConvertFrom(const Address &addr)
Convert the address to a InetSocketAddress.
static bool IsMatchingType(const Address &addr)
If the address match.
uint16_t GetPort(void) const
Get the port.
uint32_t m_maxBytes
Limit total number of bytes sent.
void ConnectionFailed(Ptr< Socket > socket)
Handle a Connection Failed event.
NS_LOG_COMPONENT_DEFINE("OnOffApplication")
uint32_t m_totBytes
Total bytes sent so far.
uint16_t GetPort(void) const
second
Definition: nstime.h:93
void SetConnectCallback(Callback< void, Ptr< Socket > > connectionSucceeded, Callback< void, Ptr< Socket > > connectionFailed)
Specify callbacks to allow the caller to determine if the connection succeeds of fails.
Definition: socket.cc:84
bool m_connected
True if connected.
virtual void StopApplication(void)
Application specific shutdown code.
virtual int Send(Ptr< Packet > p, uint32_t flags)=0
Send data (or dummy data) to the remote host.
virtual int Close(void)=0
Close a socket.
bool IsExpired(void) const
This method is syntactic sugar for the ns3::Simulator::isExpired method.
Definition: event-id.cc:53
a unique identifier for an interface.
Definition: type-id.h:49
TypeId SetParent(TypeId tid)
Definition: type-id.cc:611
uint32_t m_residualBits
Number of generated, but not sent, bits.
static bool IsMatchingType(const Address &address)
int64x64_t To(enum Unit timeUnit) const
Definition: nstime.h:464