A very small encapsulating class, entirely in C++, tracks a number of assorted state information. Each member of the group, , uses one SRMinfo block for every other member of the group.
An SRMinfo object about group member at , contains information about the session messages received by from . can use this information to compute its distance to .
If sends is active in sending data traffic, then the SRMinfo object will also contain information about the received data, including a bit vector indicating all packets received from .
The agent keeps a list of SRMinfo objects, one per group member,
in its member variable, sip_.
Its method, [int sender]get_state
will return the object corresponding to that sender,
possibly creating that object, if it did not already exist.
The SRMinfo../ns-2/srm-state.h has two methods
to access and set the bit vector, ,
rX
[int id]ifReceived & indicates whether the particular message
from the appropriate sender, with id id
was received at ,
[int id]setReceived & to set the bit to indicate that the
particular message from the appropriate sender,
with id id was received at .
The session message variables to access timing information are public;
no encapsulating methods are provided. These are:
int lsess_; /* # of last session msg received / int sendTime_; /* Time sess. msg. # sent / int recvTime_; /* Time sess. msg. # received / double distance_; /* Data messages */ int ldata_; /* # of last data msg sent /
Tom Henderson 2011-11-05