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  .AddConstructor<OnOffApplication> ()
57  .AddAttribute ("DataRate", "The data rate in on state.",
58  DataRateValue (DataRate ("500kb/s")),
61  .AddAttribute ("PacketSize", "The size of packets sent in on state",
62  UintegerValue (512),
64  MakeUintegerChecker<uint32_t> (1))
65  .AddAttribute ("Remote", "The address of the destination",
66  AddressValue (),
69  .AddAttribute ("OnTime", "A RandomVariableStream used to pick the duration of the 'On' state.",
70  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
72  MakePointerChecker <RandomVariableStream>())
73  .AddAttribute ("OffTime", "A RandomVariableStream used to pick the duration of the 'Off' state.",
74  StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
76  MakePointerChecker <RandomVariableStream>())
77  .AddAttribute ("MaxBytes",
78  "The total number of bytes to send. Once these bytes are sent, "
79  "no packet is sent again, even in on state. The value zero means "
80  "that there is no limit.",
81  UintegerValue (0),
83  MakeUintegerChecker<uint32_t> ())
84  .AddAttribute ("Protocol", "The type of protocol to use.",
88  .AddTraceSource ("Tx", "A new packet is created and is sent",
90  "ns3::Packet::TracedCallback")
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.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:95
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 this RNG stream.
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:44
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:39
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:61
static bool IsMatchingType(const Address &address)
#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:107
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition: log.h:244
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:311
bool IsRunning(void) const
This method is syntactic sugar for !IsExpired().
Definition: event-id.cc:65
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:819
virtual double GetValue(void)=0
Returns a random double from the underlying distribution.
int64x64_t To(enum Unit unit) const
Get the Time value expressed in a particular unit.
Definition: nstime.h:465
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:87
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:210
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:103
AttributeValue implementation for TypeId.
Definition: type-id.h:410
Ptr< Socket > GetSocket(void) const
Return a pointer to associated socket.
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
Definition: callback.h:1290
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:70
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:219
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
Definition: log.h:252
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)
Destructor implementation.
Definition: application.cc:82
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:235
Ptr< const AttributeChecker > MakeAddressChecker(void)
Definition: address.cc:172
void SetMaxBytes(uint32_t maxBytes)
Set the total number of bytes to send.
static Time Now(void)
Return the current simulation virtual time.
Definition: simulator.cc:223
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:410
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:228
AttributeValue implementation for DataRate.
Definition: data-rate.h:219
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:859
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:213
uint32_t m_maxBytes
Limit total number of bytes sent.
void ConnectionFailed(Ptr< Socket > socket)
Handle a Connection Failed event.
uint32_t m_totBytes
Total bytes sent so far.
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:83
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:886
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:51
TypeId SetParent(TypeId tid)
Definition: type-id.cc:631
uint32_t m_residualBits
Number of generated, but not sent, bits.
static bool IsMatchingType(const Address &address)