22 #ifndef BSM_APPLICATION_H
23 #define BSM_APPLICATION_H
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"
76 uint32_t wavePacketSize,
79 std::vector <double> rangesSq,
81 std::vector<int> * nodesMoving,
119 uint32_t pktCount,
Time pktInterval,
120 uint32_t sendingNodeId);
The base class for all ns3 applications.
Ptr< Node > GetNode() const
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.
virtual ~BsmApplication()
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.
Simulation virtual time values and global simulation resolution.
a unique identifier for an interface.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
uint32_t pktSize
packet size used for the simulation (in bytes)