A Discrete-Event Network Simulator
API
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 namespace ns3 {
46 
47 NS_LOG_COMPONENT_DEFINE ("OnOffApplication");
48 
49 NS_OBJECT_ENSURE_REGISTERED (OnOffApplication);
50 
51 TypeId
53 {
54  static TypeId tid = TypeId ("ns3::OnOffApplication")
56  .SetGroupName("Applications")
57  .AddConstructor<OnOffApplication> ()
58  .AddAttribute ("DataRate", "The data rate in on state.",
59  DataRateValue (DataRate ("500kb/s")),
62  .AddAttribute ("PacketSize", "The size of packets sent in on state",
63  UintegerValue (512),
65  MakeUintegerChecker<uint32_t> (1))
66  .AddAttribute ("Remote", "The address of the destination",
67  AddressValue (),
70  .AddAttribute ("OnTime", "A RandomVariableStream used to pick the duration of the 'On' state.",
71  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
73  MakePointerChecker <RandomVariableStream>())
74  .AddAttribute ("OffTime", "A RandomVariableStream used to pick the duration of the 'Off' state.",
75  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
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),
84  MakeUintegerChecker<uint64_t> ())
85  .AddAttribute ("Protocol", "The type of protocol to use. This should be "
86  "a subclass of ns3::SocketFactory",
89  // This should check for SocketFactory as a parent
91  .AddTraceSource ("Tx", "A new packet is created and is sent",
93  "ns3::Packet::TracedCallback")
94  ;
95  return tid;
96 }
97 
98 
100  : m_socket (0),
101  m_connected (false),
102  m_residualBits (0),
103  m_lastStartTime (Seconds (0)),
104  m_totBytes (0)
105 {
106  NS_LOG_FUNCTION (this);
107 }
108 
110 {
111  NS_LOG_FUNCTION (this);
112 }
113 
114 void
115 OnOffApplication::SetMaxBytes (uint64_t maxBytes)
116 {
117  NS_LOG_FUNCTION (this << maxBytes);
118  m_maxBytes = maxBytes;
119 }
120 
123 {
124  NS_LOG_FUNCTION (this);
125  return m_socket;
126 }
127 
128 int64_t
130 {
131  NS_LOG_FUNCTION (this << stream);
132  m_onTime->SetStream (stream);
133  m_offTime->SetStream (stream + 1);
134  return 2;
135 }
136 
137 void
139 {
140  NS_LOG_FUNCTION (this);
141 
142  m_socket = 0;
143  // chain up
145 }
146 
147 // Application Methods
148 void OnOffApplication::StartApplication () // Called at time specified by Start
149 {
150  NS_LOG_FUNCTION (this);
151 
152  // Create the socket if not already
153  if (!m_socket)
154  {
157  {
158  if (m_socket->Bind6 () == -1)
159  {
160  NS_FATAL_ERROR ("Failed to bind socket");
161  }
162  }
165  {
166  if (m_socket->Bind () == -1)
167  {
168  NS_FATAL_ERROR ("Failed to bind socket");
169  }
170  }
172  m_socket->SetAllowBroadcast (true);
174 
178  }
180 
181  // Insure no pending event
182  CancelEvents ();
183  // If we are not yet connected, there is nothing to do here
184  // The ConnectionComplete upcall will start timers at that time
185  //if (!m_connected) return;
187 }
188 
189 void OnOffApplication::StopApplication () // Called at time specified by Stop
190 {
191  NS_LOG_FUNCTION (this);
192 
193  CancelEvents ();
194  if(m_socket != 0)
195  {
196  m_socket->Close ();
197  }
198  else
199  {
200  NS_LOG_WARN ("OnOffApplication found null socket to close in StopApplication");
201  }
202 }
203 
205 {
206  NS_LOG_FUNCTION (this);
207 
209  { // Cancel the pending send packet event
210  // Calculate residual bits since last packet sent
211  Time delta (Simulator::Now () - m_lastStartTime);
212  int64x64_t bits = delta.To (Time::S) * m_cbrRate.GetBitRate ();
213  m_residualBits += bits.GetHigh ();
214  }
218 }
219 
220 // Event handlers
222 {
223  NS_LOG_FUNCTION (this);
225  ScheduleNextTx (); // Schedule the send packet event
227 }
228 
230 {
231  NS_LOG_FUNCTION (this);
232  CancelEvents ();
233 
235 }
236 
237 // Private helpers
239 {
240  NS_LOG_FUNCTION (this);
241 
242  if (m_maxBytes == 0 || m_totBytes < m_maxBytes)
243  {
244  uint32_t bits = m_pktSize * 8 - m_residualBits;
245  NS_LOG_LOGIC ("bits = " << bits);
246  Time nextTime (Seconds (bits /
247  static_cast<double>(m_cbrRate.GetBitRate ()))); // Time till next packet
248  NS_LOG_LOGIC ("nextTime = " << nextTime);
249  m_sendEvent = Simulator::Schedule (nextTime,
251  }
252  else
253  { // All done, cancel any pending events
254  StopApplication ();
255  }
256 }
257 
259 { // Schedules the event to start sending data (switch to the "On" state)
260  NS_LOG_FUNCTION (this);
261 
262  Time offInterval = Seconds (m_offTime->GetValue ());
263  NS_LOG_LOGIC ("start at " << offInterval);
265 }
266 
268 { // Schedules the event to stop sending data (switch to "Off" state)
269  NS_LOG_FUNCTION (this);
270 
271  Time onInterval = Seconds (m_onTime->GetValue ());
272  NS_LOG_LOGIC ("stop at " << onInterval);
274 }
275 
276 
278 {
279  NS_LOG_FUNCTION (this);
280 
282  Ptr<Packet> packet = Create<Packet> (m_pktSize);
283  m_txTrace (packet);
284  m_socket->Send (packet);
287  {
288  NS_LOG_INFO ("At time " << Simulator::Now ().GetSeconds ()
289  << "s on-off application sent "
290  << packet->GetSize () << " bytes to "
292  << " port " << InetSocketAddress::ConvertFrom (m_peer).GetPort ()
293  << " total Tx " << m_totBytes << " bytes");
294  }
296  {
297  NS_LOG_INFO ("At time " << Simulator::Now ().GetSeconds ()
298  << "s on-off application sent "
299  << packet->GetSize () << " bytes to "
302  << " total Tx " << m_totBytes << " bytes");
303  }
305  m_residualBits = 0;
306  ScheduleNextTx ();
307 }
308 
309 
311 {
312  NS_LOG_FUNCTION (this << socket);
313  m_connected = true;
314 }
315 
317 {
318  NS_LOG_FUNCTION (this << socket);
319 }
320 
321 
322 } // Namespace ns3
static TypeId GetTypeId(void)
Get the type ID.
void StopSending()
Start an Off period.
Ipv6Address GetIpv6(void) const
Get the IPv6 address.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:102
Ipv4Address GetIpv4(void) const
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by "...
void SetStream(int64_t stream)
Specifies the stream number for the RngStream.
virtual void StartApplication(void)
Application specific startup code.
EventId m_sendEvent
Event id of pending "send packet" event.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition: object-base.h:45
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:41
virtual bool SetAllowBroadcast(bool allowBroadcast)=0
Configure whether broadcast datagram transmissions are allowed.
High precision numerical type, implementing Q64.64 fixed precision.
Definition: int64x64-128.h:45
void ScheduleStartEvent()
Schedule the next On period start.
void CancelEvents()
Cancel all pending events.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file...
Definition: assert.h:67
static bool IsMatchingType(const Address &address)
Generate traffic to a single destination according to an OnOff pattern.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:201
virtual int ShutdownRecv(void)=0
void ScheduleStopEvent()
Schedule the next Off period start.
second
Definition: nstime.h:114
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:277
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
Definition: fatal-error.h:162
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:346
bool IsRunning(void) const
This method is syntactic sugar for !IsExpired().
Definition: event-id.cc:65
virtual double GetValue(void)=0
Get the next random value as a double drawn from the distribution.
int64x64_t To(enum Unit unit) const
Get the Time value expressed in a particular unit.
Definition: nstime.h:495
Ptr< const AttributeChecker > MakeDataRateChecker(void)
Definition: data-rate.cc:30
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
DataRate m_cbrRateFailSafe
Rate that data is generated (check copy)
Class for representing data rates.
Definition: data-rate.h:88
virtual void DoDispose(void)
Destructor implementation.
EventId m_startStopEvent
Event id for next start or stop event.
Ptr< const AttributeAccessor > MakeAddressAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method...
Definition: address.h:278
void SendPacket()
Send a packet.
Ptr< const AttributeAccessor > MakePointerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method...
Definition: pointer.h:220
static EventId Schedule(Time const &delay, MEM mem_ptr, OBJ obj)
Schedule an event to expire after delay.
Definition: simulator.h:1375
TypeId m_tid
Type of the socket used.
The base class for all ns3 applications.
Definition: application.h:60
Address m_peer
Peer address.
DataRate m_cbrRate
Rate that data is generated.
Hold an unsigned integer type.
Definition: uinteger.h:44
Ptr< RandomVariableStream > m_onTime
rng for On Time
Ptr< Node > GetNode() const
Definition: application.cc:104
AttributeValue implementation for TypeId.
Definition: type-id.h:608
Ptr< Socket > GetSocket(void) const
Return a pointer to associated socket.
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1489
uint64_t m_totBytes
Total bytes sent so far.
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...
Ptr< const AttributeAccessor > MakeDataRateAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method...
Definition: data-rate.h:242
Ptr< RandomVariableStream > m_offTime
rng for Off Time
void SetMaxBytes(uint64_t maxBytes)
Set the total number of bytes to send.
virtual int Connect(const Address &address)=0
Initiate a connection to a remote host.
virtual void DoDispose(void)
Destructor implementation.
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.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
static InetSocketAddress ConvertFrom(const Address &address)
Returns an InetSocketAddress which corresponds to the input Address.
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:249
Ptr< const AttributeChecker > MakeAddressChecker(void)
Definition: address.cc:172
static Time Now(void)
Return the current simulation virtual time.
Definition: simulator.cc:249
NS_LOG_LOGIC("Net device "<< nd<< " is not bridged")
void ConnectionSucceeded(Ptr< Socket > socket)
Handle a Connection Succeed event.
Time m_lastStartTime
Time last packet sent.
Ptr< const AttributeAccessor > MakeTypeIdAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method...
Definition: type-id.h:608
AttributeValue implementation for Address.
Definition: address.h:278
static TypeId GetTypeId(void)
Get the type ID.
#define NS_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
Definition: log.h:261
AttributeValue implementation for DataRate.
Definition: data-rate.h:242
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:993
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.
int64_t GetHigh(void) const
Get the integer portion.
Definition: int64x64-128.h:219
void ConnectionFailed(Ptr< Socket > socket)
Handle a Connection Failed event.
uint16_t GetPort(void) const
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.
Ptr< const AttributeChecker > MakeTypeIdChecker(void)
Definition: type-id.cc:1224
bool IsExpired(void) const
This method is syntactic sugar for the ns3::Simulator::IsExpired method.
Definition: event-id.cc:59
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method...
Definition: uinteger.h:45
a unique identifier for an interface.
Definition: type-id.h:58
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition: type-id.cc:914
uint32_t m_residualBits
Number of generated, but not sent, bits.
uint64_t m_maxBytes
Limit total number of bytes sent.
static bool IsMatchingType(const Address &address)