|
A Discrete-Event Network Simulator
|
API
|
Go to the documentation of this file.
38 #include "ns3/animation-interface.h"
39 #include "ns3/channel.h"
40 #include "ns3/config.h"
42 #include "ns3/mobility-model.h"
43 #include "ns3/packet.h"
44 #include "ns3/simulator.h"
45 #include "ns3/wifi-mac-header.h"
46 #include "ns3/wimax-mac-header.h"
47 #include "ns3/wifi-net-device.h"
48 #include "ns3/wifi-mac.h"
49 #include "ns3/wifi-psdu.h"
50 #include "ns3/lr-wpan-mac-header.h"
51 #include "ns3/lr-wpan-net-device.h"
52 #include "ns3/constant-position-mobility-model.h"
53 #include "ns3/lte-ue-phy.h"
54 #include "ns3/lte-enb-phy.h"
55 #include "ns3/uan-net-device.h"
56 #include "ns3/uan-mac.h"
57 #include "ns3/double.h"
60 #include "ns3/ipv4-routing-protocol.h"
61 #include "ns3/energy-source-container.h"
78 m_mobilityPollInterval (
Seconds (0.25)),
79 m_outputFileName (fn),
83 m_enablePacketMetadata (false),
85 m_stopTime (
Seconds (3600 * 1000)),
87 m_originalFileName (fn),
88 m_routingStopTime (
Seconds (0)),
89 m_routingFileName (
""),
90 m_routingPollInterval (
Seconds (5)),
303 loc = CreateObject<ConstantPositionMobilityModel> ();
304 n->AggregateObject (loc);
306 Vector hubVec (
x, y, z);
307 loc->SetPosition (hubVec);
308 NS_LOG_INFO (
"Node:" <<
n->GetId () <<
" Position set to:(" <<
x <<
"," << y <<
"," << z <<
")");
315 NS_LOG_INFO (
"Setting node image for Node Id:" << nodeId);
318 NS_FATAL_ERROR (
"Resource Id:" << resourceId <<
" not found. Did you use AddResource?");
328 NS_FATAL_ERROR (
"NodeCounter Id:" << nodeCounterId <<
" not found. Did you use AddNodeCounter?");
336 if ((opacity < 0) || (opacity > 1))
361 NS_LOG_INFO (
"Setting node color for Node Id:" << nodeId);
369 std::string linkDescription)
376 std::string linkDescription)
403 const EnergyFractionMap::const_iterator fractionIter =
m_nodeEnergyFraction.find (node->GetId ());
405 return fractionIter->second;
432 if ((ceil (oldLocation.x) == ceil (newLocation.x))
433 && (ceil (oldLocation.y) == ceil (newLocation.y)))
449 for (uint32_t i = 0; i < MovedNodes.size (); i++)
468 std::vector <Ptr <Node> >
471 std::vector < Ptr <Node> > movedNodes;
484 newLocation =
mobility->GetPosition ();
493 movedNodes.push_back (
n);
510 return WriteN (st.c_str (), st.length (),
f);
521 uint32_t nLeft = count;
522 const char* p =
data;
523 uint32_t written = 0;
526 int n = std::fwrite (p, 1, nLeft,
f);
541 NS_LOG_INFO (
"Writing Route Path From :" << nodeId <<
" To: " << destination.c_str ());
561 const std::vector<std::string>
564 std::vector <std::string> elements;
565 std::size_t pos1 = 0, pos2;
566 while (pos1 != context.npos)
568 pos1 = context.find (
"/",pos1);
569 pos2 = context.find (
"/",pos1 + 1);
570 elements.push_back (context.substr (pos1 + 1,pos2 - (pos1 + 1)));
600 return n->GetDevice (atoi (elements.at (3).c_str ()));
642 const uint32_t nodeId = node->GetId ();
644 NS_LOG_INFO (
"Remaining energy on one of sources on node " << nodeId <<
": " << currentEnergy);
650 const double energyFraction = currentEnergy / energySource->GetInitialEnergy ();
652 NS_LOG_INFO (
"Total energy fraction on node " << nodeId <<
": " << energyFraction);
792 double lbTx = (now + txTime).GetSeconds ();
793 double fbRx = (now + rxTime - txTime).GetSeconds ();
794 double lbRx = (now + rxTime).GetSeconds ();
825 std::ostringstream oss;
852 pendingPackets->at (animUid).ProcessRxBegin (ndev,
Simulator::Now ().GetSeconds ());
882 for (
auto& psdu : psduMap)
898 std::ostringstream oss;
907 NS_ABORT_MSG (
"This NetDevice should be a Wi-Fi network device");
920 NS_LOG_INFO (
"Wifi RxBeginTrace for packet: " << animUid);
924 std::ostringstream oss;
934 NS_LOG_WARN (
"Transmitter Mac address " << oss.str () <<
" never seen before. Skipping");
941 NS_LOG_WARN (
"WifiPhyRxBegin: unknown Uid, but we are adding a wifi packet");
971 std::ostringstream oss;
984 NS_LOG_WARN (
"LrWpanMacHeader without source address");
1018 NS_LOG_INFO (
"LrWpan RxBeginTrace for packet:" << animUid);
1021 NS_LOG_WARN (
"LrWpanPhyRxBeginTrace: unknown Uid - most probably it's an ACK.");
1045 NS_LOG_INFO (
"Wave RxBeginTrace for packet:" << animUid);
1049 std::ostringstream oss;
1059 NS_LOG_WARN (
"Transmitter Mac address " << oss.str () <<
" never seen before. Skipping");
1066 NS_LOG_WARN (
"WavePhyRxBegin: unknown Uid, but we are adding a wave packet");
1113 context =
"/" + context;
1118 std::list <Ptr <Packet> > pbList = pb->GetPackets ();
1143 context =
"/" + context;
1148 std::list <Ptr <Packet> > pbList = pb->GetPackets ();
1158 NS_LOG_WARN (
"LteSpectrumPhyRxTrace: unknown Uid");
1194 NS_LOG_INFO (
"CsmaPhyTxEndTrace for packet:" << animUid);
1201 NS_LOG_WARN (
"Unknown Uid, but adding Csma Packet anyway");
1225 NS_LOG_INFO (
"CsmaPhyRxEndTrace for packet:" << animUid);
1226 NS_LOG_INFO (
"CsmaPhyRxEndTrace for packet:" << animUid <<
" complete");
1246 NS_LOG_INFO (
"MacRxTrace for packet:" << animUid <<
" complete");
1254 uint32_t nodeId = 0;
1297 pendingPackets->insert (AnimUidPacketInfoMap::value_type (animUid, pktInfo));
1305 return (pendingPackets->find (animUid) != pendingPackets->end ());
1313 if (pendingPackets->empty ())
1317 std::vector <uint64_t> purgeList;
1318 for (AnimUidPacketInfoMap::iterator i = pendingPackets->begin ();
1319 i != pendingPackets->end ();
1327 purgeList.push_back (i->first);
1330 for (std::vector <uint64_t>::iterator i = purgeList.begin ();
1331 i != purgeList.end ();
1334 pendingPackets->erase (*i);
1342 switch (protocolType)
1380 return pendingPackets;
1387 std::string result =
"Unknown";
1388 switch (protocolType)
1434 std::string typeString =
"unknown";
1435 switch (counterType)
1439 typeString =
"UINT32";
1444 typeString =
"DOUBLE";
1456 std::ostringstream oss;
1523 for (std::vector<std::string>::const_iterator i = ipv4Addresses.begin ();
1524 i != ipv4Addresses.end ();
1541 for (std::vector<std::string>::const_iterator i = ipv6Addresses.begin ();
1542 i != ipv6Addresses.end ();
1557 std::ostringstream oss;
1559 oss <<
"NodeList/" <<
n->GetId () <<
"/DeviceList/" << devIndex <<
"/";
1581 std::ostringstream oss;
1583 oss <<
"NodeList/" <<
n->GetId () <<
"/DeviceList/" << devIndex <<
"/";
1604 uint32_t nDevices =
n->GetNDevices ();
1605 for (uint32_t devIndex = 0; devIndex < nDevices; ++devIndex)
1619 if (lteEnbNetDevice)
1731 Config::ConnectFailSafe (
"/NodeList/*/DeviceList/*/$ns3::WaveNetDevice/PhyEntities/*/$ns3::WifiPhy/PhyTxBegin",
1733 Config::ConnectFailSafe (
"/NodeList/*/DeviceList/*/$ns3::WaveNetDevice/PhyEntities/*/$ns3::WifiPhy/PhyRxBegin",
1747 NS_LOG_UNCOND (
"AnimationInterface WARNING:Node:" <<
n->GetId () <<
" Does not have a mobility model. Use SetConstantPosition if it is stationary");
1779 NS_FATAL_ERROR (
"Node:" <<
n->GetId () <<
" not found in Location table");
1789 std::ostringstream oss;
1791 return oss.str ().substr (6);
1803 int32_t ifIndex = ipv4->GetInterfaceForDevice (nd);
1810 std::ostringstream oss;
1824 int32_t ifIndex = ipv6->GetInterfaceForDevice (nd);
1830 bool nonLinkLocalFound =
false;
1831 uint32_t nAddresses = ipv6->GetNAddresses (ifIndex);
1833 for (uint32_t addressIndex = 0; addressIndex < nAddresses; ++addressIndex)
1835 addr = ipv6->GetAddress (ifIndex, addressIndex);
1838 nonLinkLocalFound =
true;
1842 if (!nonLinkLocalFound)
1844 addr = ipv6->GetAddress (ifIndex, 0);
1846 std::ostringstream oss;
1853 std::vector<std::string>
1856 std::vector<std::string> ipv4Addresses;
1861 return ipv4Addresses;
1863 int32_t ifIndex = ipv4->GetInterfaceForDevice (nd);
1867 return ipv4Addresses;
1869 for (uint32_t index = 0; index < ipv4->GetNAddresses (ifIndex); ++index)
1872 std::ostringstream oss;
1874 ipv4Addresses.push_back (oss.str ());
1876 return ipv4Addresses;
1879 std::vector<std::string>
1882 std::vector<std::string> ipv6Addresses;
1887 return ipv6Addresses;
1889 int32_t ifIndex = ipv6->GetInterfaceForDevice (nd);
1893 return ipv6Addresses;
1895 for (uint32_t index = 0; index < ipv6->GetNAddresses (ifIndex); ++index)
1898 std::ostringstream oss;
1900 ipv6Addresses.push_back (oss.str ());
1902 return ipv6Addresses;
1913 std::vector <std::string> ipv4Addresses;
1914 std::pair<NodeIdIpv4Map::const_iterator, NodeIdIpv4Map::const_iterator> iterPair =
m_nodeIdIpv4Map.equal_range (i->first);
1915 for (NodeIdIpv4Map::const_iterator it = iterPair.first;
1916 it != iterPair.second;
1919 ipv4Addresses.push_back (it->second);
1932 std::vector <std::string> ipv6Addresses;
1933 std::pair<NodeIdIpv6Map::const_iterator, NodeIdIpv6Map::const_iterator> iterPair =
m_nodeIdIpv6Map.equal_range (i->first);
1934 for (NodeIdIpv6Map::const_iterator it = iterPair.first;
1935 it != iterPair.second;
1938 ipv6Addresses.push_back (it->second);
1951 uint32_t n1Id =
n->GetId ();
1952 uint32_t nDev =
n->GetNDevices ();
1953 for (uint32_t i = 0; i < nDev; ++i)
1958 std::string channelType =
"Unknown channel";
1965 if (!ch || (channelType != std::string (
"ns3::PointToPointChannel")))
1982 if (!ipv4Addresses.empty ())
1987 else if (!ipv6Addresses.empty ())
1995 else if (channelType == std::string (
"ns3::PointToPointChannel"))
1999 for (std::size_t j = 0; j < nChDev; ++j)
2018 if (!ipv4Addresses.empty ())
2023 else if (!ipv6Addresses.empty ())
2043 NS_LOG_INFO (
"Update Position for Node: " <<
n->GetId ());
2108 if (!routing &&
m_f)
2118 NS_LOG_INFO (
"Creating new trace file:" << fn.c_str ());
2120 f = std::fopen (fn.c_str (),
"w");
2218 NS_LOG_INFO (
"TrackIpv4L3ProtocolCounters Completed");
2264 NS_LOG_WARN (
"Routing protocol object not found");
2278 rpElements.push_back (elem);
2282 std::ostringstream oss;
2283 oss << rt->GetGateway ();
2285 if (rt->GetGateway () ==
"0.0.0.0")
2288 rpElements.push_back (elem);
2292 rpElements.push_back (elem2);
2295 else if (rt->GetGateway () ==
"127.0.0.1")
2298 rpElements.push_back (elem);
2303 rpElements.push_back (elem);
2347 NS_LOG_WARN (
"Node " <<
n->GetId () <<
" Does not have an Ipv4 object");
2350 std::stringstream stream;
2353 return stream.str ();
2360 NS_LOG_INFO (
"RecursiveIpv4RoutePathSearch from:" << from.c_str () <<
" to:" << to.c_str ());
2361 if ((from ==
"0.0.0.0") || (from ==
"127.0.0.1"))
2363 NS_LOG_INFO (
"Got " << from.c_str () <<
" End recursion");
2371 rpElements.push_back (elem);
2393 NS_LOG_WARN (
"Routing protocol object not found");
2406 std::ostringstream oss;
2407 oss << rt->GetGateway ();
2412 rpElements.push_back (elem);
2416 rpElements.push_back (elem2);
2422 rpElements.push_back (elem);
2452 std::string closeString =
"</" + name +
">\n";
2519 for (std::vector<std::string>::const_iterator i = ipv4Addresses.begin ();
2520 i != ipv4Addresses.end ();
2535 for (std::vector<std::string>::const_iterator i = ipv6Addresses.begin ();
2536 i != ipv6Addresses.end ();
2552 element.
AddAttribute (
"info", routingInfo.c_str (),
true);
2559 std::string tagName =
"rp";
2565 for (Ipv4RoutePathElements::const_iterator i = rpElements.begin ();
2566 i != rpElements.end ();
2586 if (!metaInfo.empty ())
2588 element.
AddAttribute (
"meta-info", metaInfo.c_str (),
true);
2606 uint32_t tId,
double fbRx,
double lbRx, std::string metaInfo)
2612 if (!metaInfo.empty ())
2614 element.
AddAttribute (
"meta-info", metaInfo.c_str (),
true);
2743 : m_tagName (tagName),
2748 template <
typename T>
2752 std::ostringstream oss;
2753 oss << std::setprecision (10);
2755 std::string attributeString = attribute.c_str ();
2758 attributeString +=
"=\"";
2759 std::string valueStr = oss.str ();
2760 for (std::string::iterator it = valueStr.begin (); it != valueStr.end (); ++it)
2765 attributeString +=
"&";
2768 attributeString +=
""";
2771 attributeString +=
"'";
2774 attributeString +=
"<";
2777 attributeString +=
">";
2780 attributeString += *it;
2784 attributeString +=
"\" ";
2788 attributeString +=
"=\"" + oss.str () +
"\" ";
2790 m_attributes.push_back (attributeString);
2796 m_children.push_back (e.
ToString ());
2808 std::string elementString =
"<" + m_tagName +
" ";
2811 for (std::vector<std::string>::const_iterator i = m_attributes.begin ();
2812 i != m_attributes.end ();
2815 elementString += *i;
2817 if (m_children.empty () && m_text.empty ())
2821 elementString +=
"/>";
2826 elementString +=
">";
2827 if (!m_text.empty ())
2829 elementString += m_text;
2831 if (!m_children.empty ())
2833 elementString +=
"\n";
2834 for (std::vector<std::string>::const_iterator i = m_children.begin ();
2835 i != m_children.end ();
2838 elementString += *i +
"\n";
2844 elementString +=
"</" + m_tagName +
">";
2849 return elementString + ((autoClose) ?
"\n" :
"");
2863 .SetGroupName (
"NetAnim")
2872 return GetTypeId ();
2878 return sizeof (uint64_t);
2896 os <<
"AnimUid=" << m_AnimUid;
2902 m_AnimUid = AnimUid;
2934 m_fbTx (fbTx.GetSeconds ()),
void WriteRoutePath(uint32_t nodeId, std::string destination, Ipv4RoutePathElements rpElements)
Write route path function.
void EnableQueueCounters(Time startTime, Time stopTime, Time pollInterval=Seconds(1))
Enable tracking of Queue Counters such as Enqueue, Dequeue, Queue Drops.
void WriteNonP2pLinkProperties(uint32_t id, std::string ipv4Address, std::string channelType)
Write non P2P link properties function.
void WavePhyRxBeginTrace(std::string context, Ptr< const Packet > p)
WAVE Phy receive begin trace function.
a unique identifier for an interface.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Time m_queueCountersPollInterval
queue counters poll interval
Time m_routingPollInterval
routing poll interval
void EnableWifiMacCounters(Time startTime, Time stopTime, Time pollInterval=Seconds(1))
Enable tracking of Wifi Mac Counters such as Tx, TxDrop, Rx, RxDrop.
uint32_t m_wifiPhyTxDropCounterId
wifi Phy transmit drop counter ID
void PurgePendingPackets(ProtocolType protocolType)
Purge pending packets function.
IPv6 address associated with an interface.
void WriteNodeColors()
Write node colors function.
void ConnectLteUe(Ptr< Node > n, Ptr< LteUeNetDevice > nd, uint32_t devIndex)
Connect LTE ue function.
void WriteNodeSizes()
Write node sizes function.
void UpdateNodeColor(Ptr< Node > n, uint8_t r, uint8_t g, uint8_t b)
Helper function to update the node color.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
NodeCounterMap64 m_nodeWifiMacTxDrop
node wifi MAC transmit drop
void SetMaxPktsPerTraceFile(uint64_t maxPktsPerFile)
Set Max packets per trace file.
void WriteXmlIpv6Addresses(uint32_t nodeId, std::vector< std::string > ipv6Addresses)
Write XML Ipv6 addresses function.
LinkPropertiesMap m_linkProperties
link properties
void CheckMaxPktsPerTraceFile()
Check maximum packets per trace file function.
uint32_t PeekHeader(Header &header) const
Deserialize but does not remove the header from the internal buffer.
uint32_t fromNodeId
from node ID
void ProcessRxBegin(Ptr< const NetDevice > nd, const double fbRx)
Process receive begin.
uint32_t fromNode
from node
TypeId GetTypeId(void) const
void UpdateNodeCounter(uint32_t nodeCounterId, uint32_t nodeId, double counter)
Helper function to update a node's counter referenced by the nodeCounterId.
std::string GetPacketMetadata(Ptr< const Packet > p)
Get packet metadata function.
void AppendChild(AnimXmlElement e)
Append child function.
void WriteXmlUpdateBackground(std::string fileName, double x, double y, double scaleX, double scaleY, double opacity)
Write XML update background function.
void ConnectCallbacks()
Connect callbacks function.
std::string ToString(bool autoClose=true)
Get text for the element function.
static Iterator Begin(void)
void WriteXmlLink(uint32_t fromId, uint32_t toLp, uint32_t toId)
Write XML link counter function.
void EnableWifiPhyCounters(Time startTime, Time stopTime, Time pollInterval=Seconds(1))
Enable tracking of Wifi Phy Counters such as TxDrop, RxDrop.
NodeCounterMap64 m_nodeIpv4Rx
node IPv4 receive
std::pair< uint32_t, std::string > NodeIdIpv6Pair
NodeIdIpv6Pair typedef.
uint32_t GetId(void) const
std::string toNodeDescription
to node description
SocketErrno
Enumeration of the possible errors returned by a socket.
NodeCounterMap64 m_nodeLrWpanMacRx
node LR-WPAN MAC receive
void DequeueTrace(std::string context, Ptr< const Packet >)
Dequeue trace function.
virtual Address GetAddress(void) const =0
ProtocolType
ProtocolType enumeration.
Mobility model for which the current position does not change once it has been set and until it is se...
NodeCounterMap64 m_nodeIpv4Tx
node IPv4 transmit
static Time Now(void)
Return the current simulation virtual time.
std::map< std::string, uint32_t > m_macToNodeIdMap
MAC to node ID map.
void QueueDropTrace(std::string context, Ptr< const Packet >)
Queue trace function.
void TrackIpv4Route()
Track IPv4 router function.
void GetTag(Tag &tag) const
Read the requested tag and store it in the user-provided tag instance.
std::string nextHop
next hop
virtual void Deserialize(TagBuffer i)
Deserialize function.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ipv6Address GetAddress() const
Get the IPv6 address.
uint64_t gAnimUid
Packet unique identifier used by AnimationInterface.
std::vector< Ipv4RoutePathElement > Ipv4RoutePathElements
Ipv4RoutePathElements typedef.
NodeCounterMap64 m_nodeQueueEnqueue
node queue enqueue
void LteRxTrace(std::string context, Ptr< const Packet > p, const Mac48Address &m)
LTE receive trace function.
static bool IsInitialized(void)
Check if AnimationInterface is initialized.
uint32_t m_wifiMacTxDropCounterId
wifi MAC transmit drop counter ID
AnimationInterface & AddSourceDestination(uint32_t fromNodeId, std::string destinationIpv4Address)
Helper function to print the routing path from a source node to destination IP.
static bool initialized
Initialization flag.
int WriteN(const char *data, uint32_t count, FILE *f)
WriteN function.
void WriteXmlAddResource(uint32_t resourceId, std::string resourcePath)
Write XML add resource function.
This class can contain 16 bit addresses.
bool IsPacketPending(uint64_t animUid, ProtocolType protocolType)
Is packet pending function.
std::vector< std::string > GetIpv6Addresses(Ptr< NetDevice > nd)
Get IPv6 addresses.
AnimUidPacketInfoMap m_pendingWavePackets
pending WAVE packets
void EnableIpv4L3ProtocolCounters(Time startTime, Time stopTime, Time pollInterval=Seconds(1))
Enable tracking of Ipv4 L3 Protocol Counters such as Tx, Rx, Drop.
void LrWpanMacTxTrace(std::string context, Ptr< const Packet > p)
LR-WPAN MAC transmit trace function.
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
static void EnablePrinting(void)
Enable printing packets metadata.
uint32_t m_remainingEnergyCounterId
remaining energy counter ID
void SetBackgroundImage(std::string fileName, double x, double y, double scaleX, double scaleY, double opacity)
Helper function to set the background image.
std::string GetIpv6Address(Ptr< NetDevice > nd)
Get IPv6 address.
Vector UpdatePosition(Ptr< Node > n)
Update position function.
NodeCounterMap64 m_nodeWifiPhyTxDrop
node wifi Phy transmit drop
std::string m_outputFileName
output file name
NodeCounterMap64 m_nodeLrWpanMacRxDrop
node LR-WPAN MAC receive drop
#define NS_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
NodeCounterMap64 m_nodeWifiMacTx
node wifi MAC transmit
AnimUidPacketInfoMap m_pendingCsmaPackets
pending CSMA packets
Ptr< const NetDevice > m_rxnd
receive device
std::map< uint32_t, NodeSize > m_nodeSizes
node sizes
Ipv4 addresses are stored in host order in this class.
P2pLinkNodeIdPair structure.
Time m_wifiMacCountersPollInterval
wifi MAC counters poll interval
virtual Ptr< NetDevice > GetDevice(std::size_t i) const =0
void WriteXmlNode(uint32_t id, uint32_t sysId, double locX, double locY)
Write XML node function.
uint32_t GetN(void) const
Get the number of Ptr<Node> stored in this container.
Byte tag using by Anim to uniquely identify packets.
void WriteXmlUpdateNodeDescription(uint32_t nodeId)
Write XML update node description function.
Interface to network animator.
std::string GetIpv4RoutingTable(Ptr< Node > n)
Get IPv4 routing table function.
static void SetConstantPosition(Ptr< Node > n, double x, double y, double z=0)
Helper function to set Constant Position for a given node.
void EnqueueTrace(std::string context, Ptr< const Packet >)
Enqueue trace function.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
virtual std::size_t GetNDevices(void) const =0
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
virtual TypeId GetInstanceTypeId(void) const
Get Instance Type Id.
void WifiPhyTxDropTrace(std::string context, Ptr< const Packet > p)
wifi Phy transmit drop trace function
void WriteXmlAddNodeCounter(uint32_t counterId, std::string counterName, CounterType counterType)
Write XML add node counter function.
void LrWpanPhyRxBeginTrace(std::string context, Ptr< const Packet > p)
LR-WPAN Phy receive begin trace function.
void CsmaMacRxTrace(std::string context, Ptr< const Packet > p)
CSMA MAC receive trace function.
bool m_trackPackets
track packets
std::unordered_map< uint16_t, Ptr< const WifiPsdu > > WifiConstPsduMap
Map of const PSDUs indexed by STA-ID.
NodeIdIpv4Map m_nodeIdIpv4Map
node ID to IPv4 map
static EventId Schedule(Time const &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
DropReason
Reason why a packet has been dropped.
ByteTagIterator GetByteTagIterator(void) const
Returns an iterator over the set of byte tags included in this packet.
Identifies a byte tag and a set of bytes within a packet to which the tag applies.
U * PeekPointer(const Ptr< U > &p)
NodeContainer m_routingNc
routing node container
TypeId SetParent(TypeId tid)
Set the parent TypeId.
This class can be used to hold variables of floating point type such as 'double' or 'float'.
NodeIdIpv6Map m_nodeIdIpv6Map
node ID to IPv6 map
std::map< uint64_t, AnimPacketInfo > AnimUidPacketInfoMap
AnimUidPacketInfoMap typedef.
void WriteXmlP(std::string pktType, uint32_t fId, double fbTx, double lbTx, uint32_t tId, double fbRx, double lbRx, std::string metaInfo="")
Write XMLP function.
void StopAnimation(bool onlyAnimation=false)
Stop animation function.
void MobilityAutoCheck()
Mobility auto check function.
void WriteXmlUpdateNodeSize(uint32_t nodeId, double width, double height)
Write XML update node size function.
Ptr< LteEnbPhy > GetPhy(void) const
void LrWpanPhyTxBeginTrace(std::string context, Ptr< const Packet > p)
LR-WPAN Phy receive begin trace function.
std::vector< std::string > GetIpv4Addresses(Ptr< NetDevice > nd)
Get IPv4 addresses.
Time m_wifiPhyCountersStopTime
wifi Phy counters stop time
std::vector< Ptr< Node > > GetMovedNodes()
Get moved nodes function.
uint32_t m_ipv4L3ProtocolDropCounterId
IPv4 protocol drop counter ID.
void WriteXmlUpdateNodeColor(uint32_t nodeId, uint8_t r, uint8_t g, uint8_t b)
Write XML update node color function.
std::string GetNetAnimVersion()
Get netanim version function.
CounterType
Counter Types.
Access to the IPv4 forwarding table, interfaces, and configuration.
AnimWriteCallback m_writeCallback
write callback
void SetOutputFile(const std::string &fn, bool routing=false)
Set output file function.
uint64_t Get(void) const
Get Uid in tag.
void GenericWirelessRxTrace(std::string context, Ptr< const Packet > p, ProtocolType protocolType)
Generic wireless receive trace function.
void AddPendingPacket(ProtocolType protocolType, uint64_t animUid, AnimPacketInfo pktInfo)
Add pending packet function.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
uint32_t m_ipv4L3ProtocolTxCounterId
IPv4 L3 protocol transmit counter ID.
Ptr< const NetDevice > m_txnd
transmit device
bool IsLinkLocal() const
If the IPv6 address is a link-local address (fe80::/64).
void OutputWirelessPacketRxInfo(Ptr< const Packet > p, AnimPacketInfo &pktInfo, uint64_t animUid)
Output wireless packet receive info.
uint32_t m_wifiMacRxCounterId
wifi MAC receive counter ID
void RecursiveIpv4RoutePathSearch(std::string from, std::string to, Ipv4RoutePathElements &rpElements)
Recursive IPv4 route path search function.
uint32_t m_queueEnqueueCounterId
queue enqueue counter ID
virtual uint32_t GetSerializedSize(void) const
Get Serialized Size.
WifiPhyRxfailureReason
Enumeration of the possible reception failure reasons.
void UpdateLinkDescription(uint32_t fromNode, uint32_t toNode, std::string linkDescription)
Helper function to update the description for a link.
NodeCounterMap64 m_nodeWifiPhyRxDrop
node wifi Phy receive drop
void WriteXmlUpdateLink(uint32_t fromId, uint32_t toId, std::string linkDescription)
Write XML update link counter function.
void WifiPhyRxDropTrace(std::string context, Ptr< const Packet > p, WifiPhyRxfailureReason reason)
wifi Phy receive drop trace function
void TrackIpv4L3ProtocolCounters()
Track IPv4 L3 protocol counters function.
std::vector< Ptr< Node > >::const_iterator Iterator
Node container iterator.
std::string fromNodeDescription
from node description
#define CHECK_STARTED_INTIMEWINDOW_TRACKPACKETS
void WimaxRxTrace(std::string context, Ptr< const Packet > p, const Mac48Address &m)
WIMax receive trace function.
void EnablePacketMetadata(bool enable=true)
Enable Packet metadata.
void LteSpectrumPhyTxStart(std::string context, Ptr< const PacketBurst > pb)
LTE Spectrum Phy transmit start function.
void SetAnimWriteCallback(AnimWriteCallback cb)
Set a callback function to listen to AnimationInterface write events.
Time m_ipv4L3ProtocolCountersStopTime
IPv4 L3 protocol counters stop time.
tag a set of bytes in a packet
a polymophic address class
a class to store IPv4 address information on an interface
Iterator Begin(void) const
Get an iterator which refers to the first Node in the container.
void WriteXmlClose(std::string name, bool routing=false)
Write XML close function.
NodeDescriptionsMap m_nodeDescriptions
node description
void TrackQueueCounters()
Track queue counters function.
Time m_routingStopTime
routing stop time
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Ptr< NetDevice > GetNetDeviceFromContext(std::string context)
Get net device from context.
bool IsStarted(void)
Is AnimationInterface started.
uint32_t AddResource(std::string resourcePath)
Add a resource such as the path to an image file.
virtual Ptr< Node > GetNode(void) const =0
uint64_t m_maxPktsPerFile
maximum pakets per file
std::string m_routingFileName
routing file name
Ptr< Node > GetNode(void) const override
void ConnectLte()
Connect LTE function.
void WifiMacRxDropTrace(std::string context, Ptr< const Packet > p)
wifi MAC receive drop trace function
#define NS_UNUSED(x)
Mark a local variable as unused.
Introspection did not find any typical Config paths.
AnimationInterface & EnableIpv4RouteTracking(std::string fileName, Time startTime, Time stopTime, Time pollInterval=Seconds(5))
Enable tracking of the Ipv4 routing table for all Nodes.
#define MAX_PKTS_PER_TRACE_FILE
NodeCounterMap64 m_nodeLrWpanMacTx
node LR-WPAN MAC transmit
uint64_t GetAnimUidFromPacket(Ptr< const Packet >)
Get anim UID from packet function.
void SetText(std::string text)
Set text function.
void StartAnimation(bool restart=false)
Start animation function.
bool ConnectWithoutContextFailSafe(std::string path, const CallbackBase &cb)
This function will attempt to find all trace sources which match the input path and will then connect...
void CsmaPhyTxEndTrace(std::string context, Ptr< const Packet > p)
CSMA Phy transmit end trace function.
AnimUidPacketInfoMap m_pendingWifiPackets
pending wifi packets
void WriteXmlRp(uint32_t nodeId, std::string destination, Ipv4RoutePathElements rpElements)
Write XMLRP function.
Simulation virtual time values and global simulation resolution.
AnimUidPacketInfoMap * ProtocolTypeToPendingPackets(ProtocolType protocolType)
Protocol type to pending packets function.
bool ConnectFailSafe(std::string path, const CallbackBase &cb)
This function will attempt to find all trace sources which match the input path and will then connect...
Ipv4RoutePathElement structure.
void SkipPacketTracing()
Do not trace packets.
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
void WriteXmlRouting(uint32_t id, std::string routingInfo)
Write XML routing function.
void UpdateNodeSize(uint32_t nodeId, double width, double height)
Helper function to update the size of a node.
#define NS_LOG_UNCOND(msg)
Output the requested message unconditionally.
FILE * m_f
File handle for output (0 if none)
uint32_t m_queueDropCounterId
queue drop counter ID
void SetStopTime(Time t)
Specify the time at which capture should stop.
std::string CounterTypeToString(CounterType counterType)
Counter type to string function.
virtual Ptr< Channel > GetChannel(void) const =0
Time m_wifiPhyCountersPollInterval
wifi Phy counters poll interval
void WriteIpv4Addresses()
Write IPv4 Addresses function.
void TrackWifiMacCounters()
Track wifi MAC counters function.
uint64_t m_currentPktCount
current packet count
static TypeId GetTypeId(void)
Get Type Id.
void WriteLinkProperties()
Write link properties function.
void WriteXmlIpv4Addresses(uint32_t nodeId, std::vector< std::string > ipv4Addresses)
Write XML Ipv4 addresses function.
NodeColorsMap m_nodeColors
node colors
Callback< R, Ts... > MakeCallback(R(T::*memPtr)(Ts...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
uint32_t m_ipv4L3ProtocolRxCounterId
IPv4 L3 protocol receive counter ID.
double GetNodeEnergyFraction(Ptr< const Node > node) const
Get node's energy fraction (This used only for testing)
LinkProperties structure.
void WifiMacTxDropTrace(std::string context, Ptr< const Packet > p)
wifi MAC transmit drop trace function
uint32_t m_wifiMacRxDropCounterId
wifi MAC receive drop counter ID
Ptr< Node > GetNodeFromContext(const std::string &context) const
Get node from context.
virtual Ptr< Ipv4RoutingProtocol > GetRoutingProtocol(void) const =0
Get the routing protocol to be used by this Ipv4 stack.
NodeCounterMap64 m_nodeWifiMacRxDrop
node wifi MAC receive drop
void Ipv4RxTrace(std::string context, Ptr< const Packet > p, Ptr< Ipv4 > ipv4, uint32_t interfaceIndex)
IPv4 receive trace function.
static Iterator End(void)
uint32_t m_wifiMacTxCounterId
wifi MAC transmit counter ID
std::vector< Ptr< Node > >::const_iterator Iterator
Node container iterator.
std::string GetName(void) const
Get the name.
void Ipv4TxTrace(std::string context, Ptr< const Packet > p, Ptr< Ipv4 > ipv4, uint32_t interfaceIndex)
IPv4 transmit trace function.
AnimUidPacketInfoMap m_pendingWimaxPackets
pending wimax packets
const std::vector< std::string > GetElementsFromContext(const std::string &context) const
Get elements from context.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
bool m_enablePacketMetadata
enable packet metadata
Ipv4RouteTrackElement structure.
void ResetAnimWriteCallback()
Reset the write callback function.
Time Seconds(double value)
Construct a Time in the indicated unit.
NodeCounterMap64 m_nodeIpv4Drop
node IPv4 drop
void UanPhyGenRxTrace(std::string context, Ptr< const Packet >)
UAN Phy gen receive trace function.
std::pair< uint32_t, std::string > NodeIdIpv4Pair
NodeIdIpv4Pair typedef.
void ConnectLteEnb(Ptr< Node > n, Ptr< LteEnbNetDevice > nd, uint32_t devIndex)
Connect LTE ENB function.
virtual TypeId GetInstanceTypeId(void) const
Get the most derived TypeId for this Object.
double f(double x, void *params)
void LrWpanMacRxTrace(std::string context, Ptr< const Packet > p)
LR-WPAN MAC receive trace function.
std::vector< std::string > m_resources
resources
std::map< std::string, uint32_t > m_ipv6ToNodeIdMap
IPv6 to node ID map.
NodeCounterMap64 m_nodeLrWpanMacTxDrop
node LR-WPAN MAC transmit drop
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
AnimUidPacketInfoMap m_pendingLrWpanPackets
pending LR-WPAN packets
static bool IsFinished(void)
Check if the simulation should finish.
Keep track of the current position and velocity of an object.
uint32_t m_wifiPhyRxDropCounterId
wifi Phy receive drop counter ID
std::string GetMacAddress(Ptr< NetDevice > nd)
Get MAC address function.
keep track of a set of node pointers.
void WriteXmlUpdateNodeCounter(uint32_t counterId, uint32_t nodeId, double value)
Write XML update node counter function.
void WifiPhyRxBeginTrace(std::string context, Ptr< const Packet > p, RxPowerWattPerChannelBand rxPowersW)
wifi Phy receive begin trace function
NodeCounterMap64 m_nodeQueueDrop
node queue drop
Ipv4Address GetLocal(void) const
Get the local address.
virtual void Print(std::ostream &os) const
Print tag info.
Access to the IPv6 forwarding table, interfaces, and configuration.
void WriteXmlUpdateNodeImage(uint32_t nodeId, uint32_t resourceId)
Write XML update node image function.
uint64_t GetTracePktCount()
Get trace file packet count (This used only for testing)
void WifiMacRxTrace(std::string context, Ptr< const Packet > p)
wifi MAC receive trace function
Iterator End(void) const
Get an iterator which indicates past-the-last Node in the container.
void Print(std::ostream &os) const
Print the packet contents.
std::map< WifiSpectrumBand, double > RxPowerWattPerChannelBand
A map of the received power (Watts) for each band.
uint32_t m_queueDequeueCounterId
queue dequeue counter ID
void AddToIpv4AddressNodeIdTable(std::string ipv4Address, uint32_t nodeId)
Add to IPv4 address node ID table function.
AnimXmlElement(std::string tagName, bool emptyElement=true)
Constructor.
void WifiPhyTxBeginTrace(std::string context, WifiConstPsduMap psduMap, WifiTxVector txVector, double txPowerW)
wifi Phy transmit PSDU begin trace function
EnergyFractionMap m_nodeEnergyFraction
node energy fraction
Time m_queueCountersStopTime
queue counters stop time
NodeCounterMap64 m_nodeWifiMacRx
node wifi MAC receive
void WavePhyTxBeginTrace(std::string context, Ptr< const Packet > p)
WAVE Phy transmit begin trace function.
Time m_ipv4L3ProtocolCountersPollInterval
IPv4 L3 protocol counters poll interval.
std::map< uint32_t, Vector > m_nodeLocation
node location
void LrWpanMacTxDropTrace(std::string context, Ptr< const Packet > p)
LR-WPAN MAC transmit drop trace function.
NodeCounterMap64 m_nodeQueueDequeue
node queue dequeue
void CsmaPhyTxBeginTrace(std::string context, Ptr< const Packet > p)
CSMA Phy transmit begin trace function.
void WriteXmlPRef(uint64_t animUid, uint32_t fId, double fbTx, std::string metaInfo="")
Write XMLP Ref function.
void OutputWirelessPacketTxInfo(Ptr< const Packet > p, AnimPacketInfo &pktInfo, uint64_t animUid)
Output wireless packet transmit info.
void AddToIpv6AddressNodeIdTable(std::string ipv6Address, uint32_t nodeId)
Add to IPv6 address node ID table function.
std::string GetIpv4Address(Ptr< NetDevice > nd)
Get IPv4 address.
void WimaxTxTrace(std::string context, Ptr< const Packet > p, const Mac48Address &m)
WIMax transmit trace function.
AnimUidPacketInfoMap m_pendingUanPackets
pending UAN packets
void MobilityCourseChangeTrace(Ptr< const MobilityModel > mob)
Mobility course change trace function.
AnimUidPacketInfoMap m_pendingLtePackets
pending LTE packets
bool IsInTimeWindow()
Is in time window function.
void WriteXmlNonP2pLinkProperties(uint32_t id, std::string ipAddress, std::string channelType)
Write XML non P2P link properties function.
void CsmaPhyRxEndTrace(std::string context, Ptr< const Packet > p)
CSMA Phy receive end trace function.
Iterator over the set of byte tags in a packet.
Vector GetPosition(Ptr< Node > n)
Get position function.
bool FindFirstMatchingByteTag(Tag &tag) const
Finds the first tag matching the parameter Tag type.
void OutputCsmaPacket(Ptr< const Packet > p, AnimPacketInfo &pktInfo)
Output CSMA packet function.
AnimationInterface(const std::string filename)
Constructor.
void UpdateNodeImage(uint32_t nodeId, uint32_t resourceId)
Helper function to update the image of a node.
void WriteXmlAnim(bool routing=false)
Write XML anim function.
void UpdateNodeDescription(Ptr< Node > n, std::string descr)
Helper function to update the description for a given node.
void Set(uint64_t AnimUid)
Set global Uid in tag.
void SetMobilityPollInterval(Time t)
Set mobility poll interval:WARNING: setting a low interval can cause slowness.
uint32_t m_txNodeId
node ID
Ptr< LrWpanMac > GetMac(void) const
Get the MAC used by this NetDevice.
void TrackWifiPhyCounters()
Track wifi phy counters function.
void Ipv4DropTrace(std::string context, const Ipv4Header &ipv4Header, Ptr< const Packet > p, Ipv4L3Protocol::DropReason dropReason, Ptr< Ipv4 > ipv4, uint32_t interfaceIndex)
IPv4 drop trace function.
void WriteXmlUpdateNodePosition(uint32_t nodeId, double x, double y)
Write XML update node position function.
void TrackIpv4RoutePaths()
Track IPv4 route paths function.
void SetStartTime(Time t)
Specify the time at which capture should start.
void WriteIpv6Addresses()
Write IPv6 Addresses function.
uint32_t AddNodeCounter(std::string counterName, CounterType counterType)
Setup a node counter.
std::string linkDescription
link description
void GenericWirelessTxTrace(std::string context, Ptr< const Packet > p, ProtocolType protocolType)
Generic wireless transmit trace function.
Time m_startTime
start time
Time m_wifiMacCountersStopTime
wifi MAC counters stop time
void WriteNodeEnergies()
Write node energies function.
void AddAttribute(std::string attribute, T value, bool xmlEscape=false)
Add attribute function.
void UanPhyGenTxTrace(std::string context, Ptr< const Packet >)
UAN Phy gen transmit trace function.
Vector GetPosition(void) const
void WifiMacTxTrace(std::string context, Ptr< const Packet > p)
wifi MAC transmit trace function
void AddByteTag(const Tag &tag) const
Tag each byte included in this packet with a new byte tag.
Time m_mobilityPollInterval
mobility poll interval
void LrWpanMacRxDropTrace(std::string context, Ptr< const Packet > p)
LR-WPAN MAC receive drop trace function.
std::vector< Ipv4RouteTrackElement > m_ipv4RouteTrackElements
IPv route track elements.
~AnimationInterface()
Destructor for the animator interface.
void DevTxTrace(std::string context, Ptr< const Packet > p, Ptr< NetDevice > tx, Ptr< NetDevice > rx, Time txTime, Time rxTime)
Device transmit trace function.
void RemainingEnergyTrace(std::string context, double previousEnergy, double currentEnergy)
Remaining energy trace function.
bool NodeHasMoved(Ptr< Node > n, Vector newLocation)
Node has moved function.
static Ptr< Node > GetNode(uint32_t n)
std::vector< std::string > m_nodeCounters
node counters
#define CHECK_STARTED_INTIMEWINDOW
double GetSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
std::string destination
destination
void LteSpectrumPhyRxStart(std::string context, Ptr< const PacketBurst > pb)
LTE Spectrum Phy receive start function.
void WriteU64(uint64_t v)
void AddByteTag(uint64_t animUid, Ptr< const Packet > p)
Add byte tag function.
std::string ProtocolTypeToString(ProtocolType protocolType)
Protocol type to string function.
void WriteNodes()
Write nodes function.
Ptr< WifiMac > GetMac(void) const
std::map< std::string, uint32_t > m_ipv4ToNodeIdMap
IPv4 to node ID map.
FILE * m_routingF
File handle for routing table output (0 if None);.
#define NS_ABORT_MSG(msg)
Unconditional abnormal program termination with a message.
virtual void Serialize(TagBuffer i) const
Serialize function.
void LteTxTrace(std::string context, Ptr< const Packet > p, const Mac48Address &m)
LTE transmit trace function.