A Discrete-Event Network Simulator
API
bsm-application.h
Go to the documentation of this file.
1 /* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014 North Carolina State University
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: Scott E. Carpenter <scarpen@ncsu.edu>
19  *
20  */
21 
22 #ifndef BSM_APPLICATION_H
23 #define BSM_APPLICATION_H
24 
25 #include "ns3/application.h"
26 #include "ns3/wave-bsm-stats.h"
27 #include "ns3/random-variable-stream.h"
28 #include "ns3/internet-stack-helper.h"
29 
30 namespace ns3 {
41 {
42 public:
47  static TypeId GetTypeId (void);
48 
52  BsmApplication ();
53  virtual ~BsmApplication ();
54 
73  void Setup (Ipv4InterfaceContainer & i,
74  int nodeId,
75  Time totalTime,
76  uint32_t wavePacketSize, // bytes
77  Time waveInterval,
78  double gpsAccuracyNs,
79  std::vector <double> rangesSq, // m ^ 2
80  Ptr<WaveBsmStats> waveBsmStats,
81  std::vector<int> * nodesMoving,
82  int mode,
83  Time txDelay);
84 
94  int64_t AssignStreams (int64_t streamIndex);
95 
99  static int wavePort;
100 
101 protected:
102  virtual void DoDispose (void);
103 
104 private:
105  // inherited from Application base class.
106  virtual void StartApplication (void);
107  virtual void StopApplication (void);
108 
118  void GenerateWaveTraffic (Ptr<Socket> socket, uint32_t pktSize,
119  uint32_t pktCount, Time pktInterval,
120  uint32_t sendingNodeId);
121 
126  void ReceiveWavePacket (Ptr<Socket> socket);
127 
133  void HandleReceivedBsmPacket (Ptr<Node> txNode,
134  Ptr<Node> rxNode);
135 
141  Ptr<Node> GetNode (int id);
142 
148  Ptr<NetDevice> GetNetDevice (int id);
149 
152  std::vector <double> m_txSafetyRangesSq;
154  uint32_t m_wavePacketSize;
155  uint32_t m_numWavePackets;
159  std::vector<int> * m_nodesMoving;
161  int m_nodeId;
174 };
175 
176 } // namespace ns3
177 
178 #endif /* BSM_APPLICATION_H*/
The base class for all ns3 applications.
Definition: application.h:61
Ptr< Node > GetNode() const
Definition: application.cc:104
The BsmApplication class sends and receives the IEEE 1609 WAVE (Wireless Access in Vehicular Environm...
uint32_t m_wavePacketSize
bytes
Ptr< NetDevice > GetNetDevice(int id)
Get the net device for the desired id.
Ipv4InterfaceContainer * m_adhocTxInterfaces
transmit interfaces
Time m_TotalSimTime
total sim time
int64_t AssignStreams(int64_t streamIndex)
Assign a fixed random variable stream number to the random variables used by this model.
void GenerateWaveTraffic(Ptr< Socket > socket, uint32_t pktSize, uint32_t pktCount, Time pktInterval, uint32_t sendingNodeId)
Creates and transmits a WAVE BSM packet.
virtual void StartApplication(void)
Called at time specified by Start.
std::vector< double > m_txSafetyRangesSq
tx safety range squared, for optimization
Time m_txMaxDelay
When transmitting at a default rate of 10 Hz, the subsystem shall transmit every 100 ms +/- a random ...
uint32_t m_numWavePackets
number of wave packets
double m_gpsAccuracyNs
GPS accuracy.
void ReceiveWavePacket(Ptr< Socket > socket)
Receive a WAVE BSM packet.
std::vector< int > * m_nodesMoving
nodes moving
static TypeId GetTypeId(void)
Get the type ID.
virtual void StopApplication(void)
Called at time specified by Stop.
int m_chAccessMode
WAVE channel access mode. 0=continuous PHY; 1=channel-switching.
Ptr< UniformRandomVariable > m_unirv
random variable
static int wavePort
(Arbitrary) port number that is used to create a socket for transmitting WAVE BSMs.
Time m_waveInterval
wave interval
void Setup(Ipv4InterfaceContainer &i, int nodeId, Time totalTime, uint32_t wavePacketSize, Time waveInterval, double gpsAccuracyNs, std::vector< double > rangesSq, Ptr< WaveBsmStats > waveBsmStats, std::vector< int > *nodesMoving, int mode, Time txDelay)
Setup BSM generation parameters for a node.
Time m_prevTxDelay
previous transmit delay
BsmApplication()
Constructor.
virtual void DoDispose(void)
Destructor implementation.
void HandleReceivedBsmPacket(Ptr< Node > txNode, Ptr< Node > rxNode)
Handle the receipt of a WAVE BSM packet from sender to receiver.
Ptr< WaveBsmStats > m_waveBsmStats
BSM stats.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:74
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:103
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.
uint32_t pktSize
packet size used for the simulation (in bytes)
Definition: wifi-bianchi.cc:89