A Discrete-Event Network Simulator
API
ns3::Time Class Reference

Simulation virtual time values and global simulation resolution. More...

#include "nstime.h"

+ Collaboration diagram for ns3::Time:

Classes

struct  Information
 How to convert between other units and the current unit. More...
 
struct  Resolution
 Current time unit, and conversion info. More...
 

Public Types

typedef void(* TracedCallback) (Time value)
 TracedCallback signature for Time. More...
 
enum  Unit {
  Y = 0 , D = 1 , H = 2 , MIN = 3 ,
  S = 4 , MS = 5 , US = 6 , NS = 7 ,
  PS = 8 , FS = 9 , LAST = 10 , AUTO = 11
}
 The unit to use to interpret a number representing time. More...
 

Public Member Functions

 Time ()
 Default constructor, with value 0. More...
 
 Time (const std::string &s)
 Construct Time object from common time expressions like "1ms". More...
 
 Time (const Time &o)
 Copy constructor. More...
 
 Time (Time &&o)
 Move constructor. More...
 
 ~Time ()
 Destructor. More...
 
TimeWithUnit As (const enum Unit unit=Time::AUTO) const
 Attach a unit to a Time, to facilitate output in a specific unit. More...
 
int Compare (const Time &o) const
 Compare this to another Time. More...
 
bool IsNegative (void) const
 Exactly equivalent to t <= 0. More...
 
bool IsPositive (void) const
 Exactly equivalent to t >= 0. More...
 
bool IsStrictlyNegative (void) const
 Exactly equivalent to t < 0. More...
 
bool IsStrictlyPositive (void) const
 Exactly equivalent to t > 0. More...
 
bool IsZero (void) const
 Exactly equivalent to t == 0. More...
 
Timeoperator= (const Time &o)
 Assignment operator. More...
 
Time RoundTo (enum Unit unit) const
 Round a Time to a specific unit. More...
 
Numeric constructors

Construct from a numeric value.

 Time (double v)
 Construct from a numeric value. More...
 
 Time (int v)
 Construct from a numeric value. More...
 
 Time (long int v)
 Construct from a numeric value. More...
 
 Time (long long int v)
 Construct from a numeric value. More...
 
 Time (unsigned int v)
 Construct from a numeric value. More...
 
 Time (unsigned long int v)
 Construct from a numeric value. More...
 
 Time (unsigned long long int v)
 Construct from a numeric value. More...
 
 Time (const int64x64_t &v)
 Construct from a numeric value. More...
 
Convert to Number in a Unit

Convert a Time to number, in indicated units.

Conversions to seconds and larger will return doubles, with possible loss of precision. Conversions to units smaller than seconds will be rounded.

double GetYears (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
double GetDays (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
double GetHours (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
double GetMinutes (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
double GetSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
int64_t GetMilliSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
int64_t GetMicroSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
int64_t GetNanoSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
int64_t GetPicoSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
int64_t GetFemtoSeconds (void) const
 Get an approximation of the time stored in this instance in the indicated unit. More...
 
Convert to Raw Value

Convert a Time to a number in the current resolution units.

int64_t GetTimeStep (void) const
 Get the raw time value, in the current resolution unit. More...
 
double GetDouble (void) const
 Get the raw time value, in the current resolution unit. More...
 
int64_t GetInteger (void) const
 Get the raw time value, in the current resolution unit. More...
 
Get Times as Numbers in Specified Units

Get the Time as integers or doubles in the indicated unit.

int64_t ToInteger (enum Unit unit) const
 Get the Time value expressed in a particular unit. More...
 
double ToDouble (enum Unit unit) const
 Get the Time value expressed in a particular unit. More...
 
int64x64_t To (enum Unit unit) const
 Get the Time value expressed in a particular unit. More...
 

Static Public Member Functions

static Time From (const int64x64_t &value)
 Create a Time in the current unit. More...
 
static enum Unit GetResolution (void)
 
static Time Max ()
 Maximum representable Time Not to be confused with Max(Time,Time). More...
 
static Time Min ()
 Minimum representable Time Not to be confused with Min(Time,Time). More...
 
static void SetResolution (enum Unit resolution)
 
static bool StaticInit ()
 Function to force static initialization of Time. More...
 
Create Times from Values and Units

Create Times from values given in the indicated units.

static Time FromInteger (uint64_t value, enum Unit unit)
 Create a Time equal to value in unit unit. More...
 
static Time FromDouble (double value, enum Unit unit)
 Create a Time equal to value in unit unit. More...
 
static Time From (const int64x64_t &value, enum Unit unit)
 Create a Time equal to value in unit unit. More...
 

Private Types

typedef std::set< Time * > MarkedTimes
 Record all instances of Time, so we can rescale them when the resolution changes. More...
 

Static Private Member Functions

static void Clear (Time *const time)
 Remove a Time instance from the MarkedTimes, called by ~Time(). More...
 
static void ClearMarkedTimes ()
 Remove all MarkedTimes. More...
 
static void ConvertTimes (const enum Unit unit)
 Convert existing Times to the new unit. More...
 
static void Mark (Time *const time)
 Record a Time instance with the MarkedTimes. More...
 
static struct InformationPeekInformation (enum Unit timeUnit)
 Get the Information record for timeUnit for the current Resolution. More...
 
static struct ResolutionPeekResolution (void)
 Get the current Resolution. More...
 
static struct Resolution SetDefaultNsResolution (void)
 Set the default resolution. More...
 
static void SetResolution (enum Unit unit, struct Resolution *resolution, const bool convert=true)
 Set the current Resolution. More...
 

Private Attributes

int64_t m_data
 Virtual time value, in the current unit. More...
 

Static Private Attributes

static MarkedTimesg_markingTimes = 0
 Record of outstanding Time objects which will need conversion when the resolution is set. More...
 

Friends

template<class T >
std::enable_if< std::is_floating_point< T >::value, Time >::type operator* (const Time &lhs, T rhs)
 Scale a Time by an integer value. More...
 
template<class T >
std::enable_if< std::is_floating_point< T >::value, Time >::type operator/ (const Time &lhs, T rhs)
 Divide a Time by an integer value. More...
 
Comparison operators
bool operator== (const Time &lhs, const Time &rhs)
 Equality operator for Time. More...
 
bool operator!= (const Time &lhs, const Time &rhs)
 Inequality operator for Time. More...
 
bool operator<= (const Time &lhs, const Time &rhs)
 Less than or equal operator for Time. More...
 
bool operator>= (const Time &lhs, const Time &rhs)
 Greater than or equal operator for Time. More...
 
bool operator< (const Time &lhs, const Time &rhs)
 Less than operator for Time. More...
 
bool operator> (const Time &lhs, const Time &rhs)
 Greater than operator for Time. More...
 
bool operator< (const Time &time, const EventId &event)
 Compare a Time to an EventId. More...
 
Arithmetic operators
Time operator+ (const Time &lhs, const Time &rhs)
 Addition operator for Time. More...
 
Time operator- (const Time &lhs, const Time &rhs)
 Subtraction operator for Time. More...
 
Time operator* (const Time &lhs, const int64x64_t &rhs)
 Scale a Time by a numeric value. More...
 
Time operator* (const int64x64_t &lhs, const Time &rhs)
 Scale a Time by a numeric value. More...
 
int64x64_t operator/ (const Time &lhs, const Time &rhs)
 Exact division, returning a dimensionless fixed point number. More...
 
Time operator/ (const Time &lhs, const int64x64_t &rhs)
 Scale a Time by a numeric value. More...
 
Time operator% (const Time &lhs, const Time &rhs)
 Remainder (modulus) from the quotient of two Times. More...
 
int64_t Div (const Time &lhs, const Time &rhs)
 Integer quotient from dividing two Times. More...
 
Time Rem (const Time &lhs, const Time &rhs)
 Addition operator for Time. More...
 
template<class T >
std::enable_if< std::is_integral< T >::value, Time >::type operator* (const Time &lhs, T rhs)
 Scale a Time by an integer value. More...
 
template<class T >
std::enable_if< std::is_arithmetic< T >::value, Time >::type operator* (T lhs, const Time &rhs)
 Scale a Time by a numeric value. More...
 
template<class T >
std::enable_if< std::is_integral< T >::value, Time >::type operator/ (const Time &lhs, T rhs)
 Divide a Time by an integer value. More...
 
Time Abs (const Time &time)
 Absolute value for Time. More...
 
Time Max (const Time &timeA, const Time &timeB)
 Maximum of two Times. More...
 
Time Min (const Time &timeA, const Time &timeB)
 Minimum of two Times. More...
 
Compound assignment operators
Timeoperator+= (Time &lhs, const Time &rhs)
 Compound addition assignment for Time. More...
 
Timeoperator-= (Time &lhs, const Time &rhs)
 Compound subtraction assignment for Time. More...
 

Related Functions

(Note that these are not member functions.)

static bool g_TimeStaticInit = Time::StaticInit ()
 Force static initialization order of Time in each compilation unit. More...
 
Time TimeStep (uint64_t ts)
 Scheduler interface. More...
 

Detailed Description

Simulation virtual time values and global simulation resolution.

This class defines all the classic C++ addition/subtraction operators: +, -, +=, -=; and all the classic comparison operators: ==, !=, <, >, <=, >=. It is thus easy to add, subtract, or compare Time objects.

For example:

Time t1 = Seconds (10.0);
Time t2 = Seconds (10.0);
Time t3 = t1;
t3 += t2;
Time()
Default constructor, with value 0.
Definition: nstime.h:135
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1244

You can also use the following non-member functions to manipulate any of these ns3::Time object:

This class also controls the resolution of the underlying time representation. The resolution is the smallest representable time interval. The default resolution is nanoseconds.

To change the resolution, use SetResolution(). All Time objects created before the call to SetResolution() will be updated to the new resolution. This can only be done once! (Tracking each Time object uses 4 pointers. For speed, once we convert the existing instances we discard the recording data structure and stop tracking new instances, so we have no way to do a second conversion.)

If you increase the global resolution, you also implicitly decrease the maximum simulation duration. The global simulation time is stored in a 64 bit integer whose interpretation will depend on the global resolution. Therefore the maximum possible duration of your simulation if you use picoseconds is 2^64 ps = 2^24 s = 7 months, whereas, had you used nanoseconds, you could have run for 584 years.

Definition at line 102 of file nstime.h.

Member Typedef Documentation

◆ MarkedTimes

typedef std::set< Time * > ns3::Time::MarkedTimes
private

Record all instances of Time, so we can rescale them when the resolution changes.

Internal:

We use a std::set so we can remove the record easily when ~Time() is called.

We don't use Ptr<Time>, because we would have to bloat every Time instance with SimpleRefCount<Time>.

Seems like this should be std::set< Time * const >, but Stack Overflow says otherwise, quoting the standard:

& sect;23.1/3 states that std::set key types must be assignable and copy constructable; clearly a const type will not be assignable.

Definition at line 655 of file nstime.h.

◆ TracedCallback

typedef void(* ns3::Time::TracedCallback) (Time value)

TracedCallback signature for Time.

Parameters
[in]valueCurrent value of Time

Definition at line 580 of file nstime.h.

Member Enumeration Documentation

◆ Unit

The unit to use to interpret a number representing time.

Enumerator

year, 365 days

day, 24 hours

hour, 60 minutes

MIN 

minute, 60 seconds

second

MS 

millisecond

US 

microsecond

NS 

nanosecond

PS 

picosecond

FS 

femtosecond

LAST 

marker for last normal value

AUTO 

auto-scale output when using Time::As()

Definition at line 108 of file nstime.h.

Constructor & Destructor Documentation

◆ Time() [1/12]

ns3::Time::Time ( )
inline

Default constructor, with value 0.

Definition at line 135 of file nstime.h.

References g_markingTimes, and Mark().

Referenced by From(), FromInteger(), Max(), and Min().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ Time() [2/12]

ns3::Time::Time ( const Time o)
inline

Copy constructor.

Parameters
[in]oTime to copy

Definition at line 148 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [3/12]

ns3::Time::Time ( Time &&  o)
inline

Move constructor.

Parameters
[in]oTime from which take the data

Definition at line 162 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [4/12]

ns3::Time::Time ( double  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 180 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [5/12]

ns3::Time::Time ( int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 188 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [6/12]

ns3::Time::Time ( long int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 196 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [7/12]

ns3::Time::Time ( long long int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 204 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [8/12]

ns3::Time::Time ( unsigned int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 212 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [9/12]

ns3::Time::Time ( unsigned long int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 220 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [10/12]

ns3::Time::Time ( unsigned long long int  v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 228 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [11/12]

ns3::Time::Time ( const int64x64_t v)
inlineexplicit

Construct from a numeric value.

The current time resolution will be assumed as the unit.

Parameters
[in]vThe value.

Definition at line 236 of file nstime.h.

References g_markingTimes, and Mark().

+ Here is the call graph for this function:

◆ Time() [12/12]

ns3::Time::Time ( const std::string &  s)
explicit

Construct Time object from common time expressions like "1ms".

Supported units include:

  • s (seconds)
  • ms (milliseconds)
  • us (microseconds)
  • ns (nanoseconds)
  • ps (picoseconds)
  • fs (femtoseconds)
  • min (minutes)
  • h (hours)
  • d (days)
  • y (years)

There can be no white space between the numerical portion and the units. Any otherwise malformed string causes a fatal error to occur.

Parameters
[in]sThe string to parse into a Time

Definition at line 129 of file time.cc.

◆ ~Time()

ns3::Time::~Time ( )
inline

Destructor.

Definition at line 288 of file nstime.h.

References Clear(), and g_markingTimes.

+ Here is the call graph for this function:

Member Function Documentation

◆ As()

TimeWithUnit ns3::Time::As ( const enum Unit  unit = Time::AUTO) const

Attach a unit to a Time, to facilitate output in a specific unit.

For example,

Time t (3.14e9); // Pi seconds
std::cout << t.As (Time::MS) << std::endl;
@ MS
millisecond
Definition: nstime.h:115

will print +3140.0ms

Parameters
[in]unitThe unit to use.
Returns
The Time with embedded unit.

Definition at line 418 of file time.cc.

Referenced by ns3::SixLowPanNetDevice::AddContext(), ThreeGppHttpClientServerTestSuite::AddHttpObjectTestCase(), ns3::dsr::DsrRouteCache::AddRoute_Link(), ns3::AsciiLrWpanMacTransmitSinkWithContext(), ns3::AsciiLrWpanMacTransmitSinkWithoutContext(), ns3::InterferenceHelper::CalculatePhyHeaderSectionPsr(), ns3::LrWpanCsmaCa::CanProceed(), TimeInputOutputTestCase::CheckAs(), ns3::FlowMonitor::CheckForLostPackets(), ThreeGppHttpObjectTestCase::ClientRxDelayCallback(), ThreeGppHttpObjectTestCase::ClientRxRttCallback(), ns3::ThreeGppHttpServerTxBuffer::CloseAllSockets(), ns3::ThreeGppHttpServerTxBuffer::CloseSocket(), ns3::CobaltQueueDisc::CobaltShouldDrop(), BatteryLifetimeTest::ConstantLoadTest(), ns3::dsr::DsrRouteCache::DecStability(), ns3::DefaultTimePrinter(), ns3::TbfQueueDisc::DoDequeue(), ns3::A3RsrpHandoverAlgorithm::DoInitialize(), ns3::LteRlcSm::DoReceivePdu(), LteRadioLinkFailureTestCase::DoRun(), TimeInputOutputTestCase::DoRun(), LrWpanSlottedCsmacaTestCase::DoRun(), LteRlcAmE2eTestCase::DoRun(), LteHandoverDelayTestCase::EnbHandoverEndOkCallback(), EnbRrcTimeout(), ns3::PhyEntity::EndOfMpdu(), ns3::UanMacCw::Enqueue(), ns3::ThreeGppHttpClient::EnterParsingTime(), ns3::ThreeGppHttpClient::EnterReadingTime(), ns3::dsr::DsrRouteCache::FindSameRoute(), ns3::dot11s::HwmpProtocol::ForwardPathError(), ns3::LteUePhy::GenerateCqiRsrpRsrq(), ns3::ChannelAccessManager::GetBackoffEndFor(), ns3::ChannelAccessManager::GetBackoffStartFor(), ns3::CommandLineHelper::GetDefault< Time >(), ns3::PhyEntity::GetReceptionStatus(), ns3::dsdv::RoutingProtocol::GetSettlingTime(), ns3::LrWpanCsmaCa::GetTimeToNextSlot(), ns3::ShowProgress::GiveFeedback(), ns3::LrWpanMac::IfsWaitTimeout(), ns3::dsr::DsrRouteCache::IncStability(), ns3::aodv::RoutingTableEntry::Invalidate(), ns3::QosFrameExchangeManager::IsWithinSizeAndTimeLimits(), ns3::olsr::RoutingProtocol::LinkSensing(), OcbWifiMacTestCase::MacAssoc(), ns3::aodv::RoutingTable::MarkLinkAsUnidirectional(), JakesPropagationExample::Next(), NotifyConnectionEstablishedEnb(), NotifyConnectionEstablishedUe(), NotifyConnectionTimeoutUe(), NotifyHandoverEndOkEnb(), NotifyHandoverEndOkUe(), NotifyHandoverStartEnb(), NotifyHandoverStartUe(), NotifyRandomAccessErrorUe(), NotifyRaResponseTimeoutUe(), NotifyViaTraceSource(), ns3::CoDelQueueDisc::OkToDrop(), ns3::operator<<(), ns3::LrWpanMac::PdDataConfirm(), ns3::LrWpanMac::PdDataIndication(), LrWpanCcaTestCase::PhyRxBegin(), LrWpanCcaTestCase::PhyRxDrop(), LrWpanCcaTestCase::PhyRxEnd(), OcbWifiMacTestCase::PhyRxOkTrace(), PhySyncDetection(), LrWpanCcaTestCase::PhyTxBegin(), LrWpanCcaTestCase::PhyTxEnd(), OcbWifiMacTestCase::PhyTxTrace(), LrWpanCcaTestCase::PlmeCcaConfirm(), ns3::dsdv::RoutingTableEntry::Print(), ns3::SeqTsEchoHeader::Print(), ns3::UanHeaderRcData::Print(), ns3::UanHeaderRcRts::Print(), ns3::UanHeaderRcCtsGlobal::Print(), ns3::UanHeaderRcCts::Print(), ns3::TcpTxItem::Print(), PrintCellInfo(), ns3::Ipv6RoutingHelper::PrintNdiscCache(), ns3::Ipv6RoutingHelper::PrintNdiscCacheEvery(), PrintReceivedRoutingPacket(), ns3::NixVectorRouting< T >::PrintRoutingPath(), ns3::aodv::RoutingProtocol::PrintRoutingTable(), ns3::dsdv::RoutingProtocol::PrintRoutingTable(), ns3::Ipv4GlobalRouting::PrintRoutingTable(), ns3::Ipv4ListRouting::PrintRoutingTable(), ns3::Ipv4StaticRouting::PrintRoutingTable(), ns3::Ipv6ListRouting::PrintRoutingTable(), ns3::Ipv6StaticRouting::PrintRoutingTable(), ns3::Rip::PrintRoutingTable(), ns3::RipNg::PrintRoutingTable(), ns3::NixVectorRouting< T >::PrintRoutingTable(), ns3::olsr::RoutingProtocol::PrintRoutingTable(), ns3::UplinkSchedulerMBQoS::ProcessBandwidthRequest(), ns3::LrWpanCsmaCa::RandomBackoffDelay(), WaveNetDeviceExample::Receive(), ns3::V4Ping::Receive(), ns3::V4TraceRoute::Receive(), ns3::ThreeGppHttpServer::ReceivedDataCallback(), ns3::MeshPointDevice::ReceiveFromDevice(), ns3::dot11s::HwmpProtocol::ReceivePrep(), ns3::dot11s::HwmpProtocol::ReceivePreq(), WaveNetDeviceExample::ReceiveVsa(), ns3::ThreeGppHttpServerTxBuffer::RecordNextServe(), ns3::dsdv::RoutingProtocol::RecvDsdv(), ns3::ThreeGppHttpServerTxBuffer::RemoveSocket(), ns3::SixLowPanNetDevice::RenewContext(), ns3::WifiTxTimer::Reschedule(), ns3::FrameExchangeManager::RxStartIndication(), ns3::UanMacRc::ScheduleData(), ns3::PhyEntity::ScheduleEndOfMpdus(), ns3::OnOffApplication::ScheduleNextTx(), ns3::aodv::RoutingProtocol::ScheduleRreqRetry(), ns3::dsr::DsrRouting::ScheduleRreqRetry(), ns3::OnOffApplication::ScheduleStartEvent(), ns3::OnOffApplication::ScheduleStopEvent(), ns3::WifiPhy::Send(), ns3::aodv::RoutingProtocol::SendRerrMessage(), ns3::aodv::RoutingProtocol::SendRerrWhenNoRouteToForward(), ns3::ThreeGppHttpHeader::SetClientTs(), ns3::ThreeGppHttpVariables::SetEmbeddedObjectGenerationDelay(), ns3::PointToPointNetDevice::SetInterframeGap(), ns3::ThreeGppHttpVariables::SetMainObjectGenerationDelay(), ns3::ThreeGppHttpVariables::SetParsingTimeMean(), ns3::ThreeGppHttpVariables::SetReadingTimeMean(), ns3::ThreeGppHttpHeader::SetServerTs(), ns3::HePhy::SetTrigVector(), ns3::TimeProbe::SetValue(), ns3::TimeProbe::SetValueByPath(), ns3::dsr::DsrRouting::Start(), ns3::FlowMonitor::Start(), ns3::UanMacRcGw::StartCycle(), ns3::BaseStationNetDevice::StartDlSubFrame(), ns3::LrWpanMac::StartInactivePeriod(), ns3::QosTxop::StartMuEdcaTimerNow(), ns3::SpectrumWifiPhy::StartRx(), ns3::UanMacCw::StartTimer(), ns3::WaveFrameExchangeManager::StartTransmission(), ns3::BaseStationNetDevice::StartUlSubFrame(), StateChangeNotification(), ns3::FlowMonitor::Stop(), ns3::WifiPhy::SwitchMaybeToCcaBusy(), Throughput(), ns3::TimeProbe::TraceSink(), ns3::CsmaNetDevice::TransmitCompleteEvent(), ns3::CsmaChannel::TransmitEnd(), ns3::CsmaNetDevice::TransmitStart(), ns3::PointToPointNetDevice::TransmitStart(), ns3::RrMultiUserScheduler::TrySendingBasicTf(), ns3::RrMultiUserScheduler::TrySendingBsrpTf(), LteHandoverDelayTestCase::UeHandoverEndOkCallback(), UeStateTransition(), and BatteryLifetimeTest::VariableLoadTest().

◆ Clear()

void ns3::Time::Clear ( Time *const  time)
staticprivate

Remove a Time instance from the MarkedTimes, called by ~Time().

Parameters
[in]timeThe Time instance to remove.

Definition at line 343 of file time.cc.

References ns3::g_markingMutex, g_markingTimes, NS_ASSERT, NS_ASSERT_MSG, NS_LOG_FUNCTION, NS_LOG_LOGIC, and NS_LOG_WARN.

Referenced by ~Time().

+ Here is the caller graph for this function:

◆ ClearMarkedTimes()

void ns3::Time::ClearMarkedTimes ( )
staticprivate

Remove all MarkedTimes.

Internal:
Has to be visible to the Simulator class, hence the friending.
Internal:

We're called by Simulator::Run, which knows nothing about the mutex, so we need a critical section here.

It would seem natural to use this function at the end of ConvertTimes, but that function already has the mutex. The mutex can not be locked more than once in the same thread, so calling this function from ConvertTimes is a bad idea.

Instead, we copy this body into ConvertTimes.

Definition at line 287 of file time.cc.

References ns3::g_markingMutex, g_markingTimes, NS_LOG_FUNCTION_NOARGS, and NS_LOG_LOGIC.

Referenced by ns3::Simulator::Run().

+ Here is the caller graph for this function:

◆ Compare()

int ns3::Time::Compare ( const Time o) const
inline

Compare this to another Time.

Parameters
[in]oThe other Time
Returns
-1,0,+1 if this < o, this == o, or this > o

Definition at line 342 of file nstime.h.

References m_data.

◆ ConvertTimes()

void ns3::Time::ConvertTimes ( const enum Unit  unit)
staticprivate

Convert existing Times to the new unit.

Parameters
[in]unitThe Unit to convert existing Times to.

Definition at line 373 of file time.cc.

References ns3::g_markingMutex, g_markingTimes, m_data, max, min, NS_ASSERT_MSG, NS_LOG_FUNCTION_NOARGS, NS_LOG_LOGIC, and ToInteger().

Referenced by SetResolution().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ From() [1/2]

static Time ns3::Time::From ( const int64x64_t value)
inlinestatic

Create a Time in the current unit.

Parameters
[in]valueThe value of the new Time.
Returns
A Time with value in the current time unit.

Definition at line 450 of file nstime.h.

References Time().

Referenced by ns3::Days(), ns3::FemtoSeconds(), FromDouble(), ns3::Hours(), ns3::RttMeanDeviation::IntegerUpdate(), ns3::MicroSeconds(), ns3::MilliSeconds(), ns3::Minutes(), ns3::NanoSeconds(), ns3::PicoSeconds(), RoundTo(), ns3::Seconds(), and ns3::Years().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ From() [2/2]

static Time ns3::Time::From ( const int64x64_t value,
enum Unit  unit 
)
inlinestatic

Create a Time equal to value in unit unit.

Parameters
[in]valueThe new Time value, expressed in unit
[in]unitThe unit of value
Returns
The Time representing value in unit

Definition at line 484 of file nstime.h.

References Time(), ns3::Time::Information::fromMul, ns3::int64x64_t::MulByInvert(), PeekInformation(), and ns3::Time::Information::timeFrom.

+ Here is the call graph for this function:

◆ FromDouble()

static Time ns3::Time::FromDouble ( double  value,
enum Unit  unit 
)
inlinestatic

Create a Time equal to value in unit unit.

Parameters
[in]valueThe new Time value, expressed in unit
[in]unitThe unit of value
Returns
The Time representing value in unit

Definition at line 480 of file nstime.h.

References From().

Referenced by ns3::Days(), ns3::RttMeanDeviation::FloatingPointUpdate(), ns3::Hours(), ns3::Minutes(), ns3::TcpSocketBase::ReTxTimeout(), ns3::Seconds(), SetDefaultNsResolution(), and ns3::Years().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ FromInteger()

static Time ns3::Time::FromInteger ( uint64_t  value,
enum Unit  unit 
)
inlinestatic

Create a Time equal to value in unit unit.

Parameters
[in]valueThe new Time value, expressed in unit
[in]unitThe unit of value
Returns
The Time representing value in unit

Definition at line 467 of file nstime.h.

References Time(), ns3::Time::Information::factor, ns3::Time::Information::fromMul, and PeekInformation().

Referenced by ns3::FemtoSeconds(), ns3::MicroSeconds(), ns3::MilliSeconds(), ns3::NanoSeconds(), and ns3::PicoSeconds().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ GetDays()

double ns3::Time::GetDays ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 367 of file nstime.h.

References D, and ToDouble().

+ Here is the call graph for this function:

◆ GetDouble()

double ns3::Time::GetDouble ( void  ) const
inline

Get the raw time value, in the current resolution unit.

Returns
The raw time value

Definition at line 419 of file nstime.h.

References m_data.

Referenced by ns3::BsmApplication::StartApplication(), TimeSimpleTestCase::TestMultiplicationByDecimalTypes(), and ns3::TcpHtcp::UpdateBeta().

+ Here is the caller graph for this function:

◆ GetFemtoSeconds()

int64_t ns3::Time::GetFemtoSeconds ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 399 of file nstime.h.

References FS, and ToInteger().

Referenced by DataRateTestCase::CheckTimesEqual(), ns3::HtPhy::GetPayloadDuration(), ns3::OfdmPhy::GetPayloadDuration(), and ns3::HePhy::GetSigBDuration().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ GetHours()

double ns3::Time::GetHours ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 371 of file nstime.h.

References H, and ToDouble().

+ Here is the call graph for this function:

◆ GetInteger()

◆ GetMicroSeconds()

◆ GetMilliSeconds()

int64_t ns3::Time::GetMilliSeconds ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 383 of file nstime.h.

References MS, and ToInteger().

Referenced by ns3::aodv::RrepHeader::RrepHeader(), ns3::DefaultChannelScheduler::AssignExtendedAccess(), ns3::PieQueueDisc::CalculateP(), ns3::TcpLedbat::CongestionAvoidance(), ns3::TraceFadingLossModel::DoCalcRxPowerSpectralDensity(), ns3::PieQueueDisc::DoEnqueue(), ns3::A3RsrpHandoverAlgorithm::DoInitialize(), ns3::LteRlcAm::DoReportBufferStatus(), ns3::LteRlcTm::DoReportBufferStatus(), ns3::LteRlcUm::DoReportBufferStatus(), LteUeMeasurementsHandoverTestCase::DoRun(), LenaDataPhyErrorModelTestCase::DoRun(), LenaDlCtrlPhyErrorModelTestCase::DoRun(), ns3::TcpOptionTS::ElapsedTimeFromTsValue(), ns3::LteSpectrumPhy::EndRxData(), ns3::QKDBuffer::FetchDeltaTime(), ns3::ChannelCoordinator::GetIntervalTime(), LteHandoverTargetTestCase::HandoverStartCallback(), ns3::TcpYeah::IncreaseWindow(), TcpVegasTest::IncreaseWindow(), ns3::TcpBbr::InitPacingRate(), ns3::TraceFadingLossModel::LoadTrace(), ChannelCoordinationTestCase::NotifyCchStartNow(), ChannelCoordinationTestCase::NotifyGuardStartNow(), ChannelCoordinationTestCase::NotifySchStartNow(), ns3::TcpOptionTS::NowToTsValue(), PingRtt(), ns3::TcpLp::PktsAcked(), ns3::TcpYeah::PktsAcked(), ns3::TcpHybla::RecalcParam(), TcpIllinoisTest::RecalcParam(), ns3::TcpIllinois::RecalcParam(), ns3::V4Ping::Receive(), ns3::LteUePhy::ReceiveLteControlMessageList(), LteUeMeasurementsPiecewiseTestCase1::RecvMeasurementReportCallback(), LteUeMeasurementsPiecewiseTestCase2::RecvMeasurementReportCallback(), LteUeMeasurementsPiecewiseTestCase3::RecvMeasurementReportCallback(), LteUeMeasurementsHandoverTestCase::RecvMeasurementReportCallback(), ns3::UanHeaderRcData::Serialize(), ns3::UanHeaderRcRts::Serialize(), ns3::UanHeaderRcCtsGlobal::Serialize(), ns3::UanHeaderRcCts::Serialize(), ns3::aodv::RrepHeader::SetHello(), ns3::aodv::RrepHeader::SetLifeTime(), ns3::ChannelCoordinator::StartChannelCoordination(), ns3::LteEnbPhy::StartSubFrame(), and ChannelCoordinationTestCase::TestIntervalAfter().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ GetMinutes()

double ns3::Time::GetMinutes ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 375 of file nstime.h.

References MIN, and ToDouble().

+ Here is the call graph for this function:

◆ GetNanoSeconds()

◆ GetPicoSeconds()

int64_t ns3::Time::GetPicoSeconds ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 395 of file nstime.h.

References PS, and ToInteger().

+ Here is the call graph for this function:

◆ GetResolution()

enum Time::Unit ns3::Time::GetResolution ( void  )
static
Returns
The current global resolution.

Definition at line 373 of file time.cc.

Referenced by ns3::DefaultTimePrinter(), and ns3::operator<<().

+ Here is the caller graph for this function:

◆ GetSeconds()

double ns3::Time::GetSeconds ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 379 of file nstime.h.

References S, and ToDouble().

Referenced by ns3::RttEstimator::RttEstimator(), ns3::dot11s::HwmpRtable::AddReactivePath(), ns3::AsciiPhyReceiveSinkWithContext(), ns3::AsciiPhyReceiveSinkWithoutContext(), ns3::AsciiPhyRxOkEvent(), ns3::AsciiPhyTransmitSinkWithContext(), ns3::AsciiPhyTransmitSinkWithoutContext(), ns3::AsciiPhyTxEvent(), ns3::WimaxHelper::AsciiRxEvent(), ns3::WimaxHelper::AsciiTxEvent(), ns3::RandomWalk2dOutdoorMobilityModel::AvoidBuilding(), BackoffTrace(), BytesInQueueTrace(), ns3::ThreeGppSpectrumPropagationLossModel::CalcBeamformingGain(), ns3::InterferenceHelper::CalculateChunkSuccessRate(), ns3::SimpleOfdmWimaxPhy::CalculateDataRate(), ns3::PieQueueDisc::CalculateP(), ns3::InterferenceHelper::CalculatePayloadChunkSuccessRate(), ns3::LiIonEnergySource::CalculateRemainingEnergy(), TcpYeahDecrementTest::CalculateSsThresh(), CalculateThroughput(), ns3::MinstrelHtWifiManager::CalculateThroughput(), ns3::LteUeRrc::CancelEnteringTrigger(), ns3::LteUeRrc::CancelLeavingTrigger(), ns3::LrWpanCsmaCa::CanProceed(), ns3::AcousticModemEnergyModel::ChangeState(), ns3::WifiRadioEnergyModel::ChangeState(), CheckQueueDiscSize(), CheckQueueSize(), CheckT1QueueSize(), CheckT2QueueSize(), ThreeGppHttpObjectTestCase::ClientRxDelayCallback(), ThreeGppHttpObjectTestCase::ClientRxRttCallback(), ns3::CobaltQueueDisc::CobaltShouldDrop(), ns3::UanMacRcGw::ComputeAlpha(), ns3::UanMacRcGw::ComputeExpS(), ComputeSnr(), Ns2MobilityHelperTest::CourseChange(), WaypointMobilityModelNotifyTest::CourseChangeCallback(), ns3::QKDKeyManagerSystemApplication::CreateNew004Association(), ns3::AnimationInterface::CsmaPhyTxEndTrace(), CwndChange(), CwndTrace(), CwndTracer(), Ns3TcpLossTestCase::CwndTracer(), CwTrace(), LrWpanDataIfsTestCase::DataReceivedDev0(), LrWpanDataIfsTestCase::DataReceivedDev1(), ns3::AsciiTraceHelper::DefaultDequeueSinkWithContext(), ns3::AsciiTraceHelper::DefaultDequeueSinkWithoutContext(), ns3::AsciiTraceHelper::DefaultDropSinkWithContext(), ns3::AsciiTraceHelper::DefaultDropSinkWithoutContext(), ns3::AsciiTraceHelper::DefaultEnqueueSinkWithContext(), ns3::AsciiTraceHelper::DefaultEnqueueSinkWithoutContext(), ns3::AsciiTraceHelper::DefaultReceiveSinkWithContext(), ns3::AsciiTraceHelper::DefaultReceiveSinkWithoutContext(), CobaltQueueDiscCeThresholdTest::DequeueWithDelay(), CobaltQueueDiscEnhancedBlueTest::DequeueWithDelay(), ns3::AnimationInterface::DevTxTrace(), ns3::MacStatsCalculator::DlScheduling(), ns3::TraceFadingLossModel::DoCalcRxPowerSpectralDensity(), ns3::CoDelQueueDisc::DoDequeue(), ns3::PieQueueDisc::DoDequeue(), ns3::TbfQueueDisc::DoDequeue(), ns3::SimpleOfdmWimaxPhy::DoGetFrameDurationCode(), ns3::SimpleOfdmWimaxPhy::DoGetNrBytes(), ns3::SimpleOfdmWimaxPhy::DoGetNrSymbols(), ns3::Rip::DoInitialize(), ns3::RipNg::DoInitialize(), ns3::dot11s::HwmpProtocol::DoInitialize(), ns3::MeshWifiInterfaceMac::DoInitialize(), TimeWithSignTestCase::DoRun(), TcpHyblaIncrementTest::DoRun(), TcpVenoTest::DoRun(), ns3::SimpleOfdmWimaxPhy::DoSetPhyParameters(), ns3::RandomWalk2dOutdoorMobilityModel::DoWalk(), ns3::GaussMarkovMobilityModel::DoWalk(), ns3::RandomWalk2dMobilityModel::DoWalk(), DropAtQueue(), ns3::PieQueueDisc::DropEarly(), DroppingStateTracer(), ns3::LteChunkProcessor::End(), ns3::BaseStationNetDevice::EndDlSubFrame(), ns3::BaseStationNetDevice::EndUlSubFrame(), CobaltQueueDiscCeThresholdTest::EnqueueWithDelay(), ns3::TcpWestwood::EstimateBW(), ns3::LteChunkProcessor::EvaluateChunk(), ns3::ShannonSpectrumErrorModel::EvaluateChunk(), EveryDropTracer(), anonymous_namespace{sample-simulator.cc}::ExampleFunction(), ns3::SpectrumAnalyzer::GenerateReport(), ns3::TcpRateLinux::GenerateSample(), GenerateTraffic(), ns3::QKDBuffer::GetAverageKeyConsumptionRate(), ns3::UanMacRcGw::GetExpPdk(), ns3::LrWpanCsmaCa::GetTimeToNextSlot(), ns3::SimpleDeviceEnergyModel::GetTotalEnergyConsumption(), ns3::WifiRadioEnergyModel::GetTotalEnergyConsumption(), ns3::JakesProcess::Oscillator::GetValueAt(), GoodputSampling(), anonymous_namespace{sample-simulator.cc}::MyModel::HandleEvent(), Ipv4DynamicGlobalRoutingTestCase::HandleRead(), ns3::TcpVegas::IncreaseWindow(), ns3::TcpVeno::IncreaseWindow(), ns3::TcpYeah::IncreaseWindow(), TcpYeahIncrementTest::IncreaseWindow(), InFlightTracer(), ns3::RedQueueDisc::InitializeParams(), ns3::TcpBbr::InitPacingRate(), ns3::SubscriberStationNetDevice::InitSubscriberStationNetDevice(), ns3::RraaWifiManager::InitThresholds(), ns3::RrpaaWifiManager::InitThresholds(), ns3::Ipv4L3ProtocolDropSinkWithContext(), ns3::Ipv4L3ProtocolDropSinkWithoutContext(), ns3::Ipv4L3ProtocolRxSinkWithContext(), ns3::Ipv4L3ProtocolRxSinkWithoutContext(), ns3::Ipv4L3ProtocolTxSinkWithContext(), ns3::Ipv4L3ProtocolTxSinkWithoutContext(), ns3::Ipv6L3ProtocolDropSinkWithContext(), ns3::Ipv6L3ProtocolDropSinkWithoutContext(), ns3::Ipv6L3ProtocolRxSinkWithContext(), ns3::Ipv6L3ProtocolRxSinkWithoutContext(), ns3::Ipv6L3ProtocolTxSinkWithContext(), ns3::Ipv6L3ProtocolTxSinkWithoutContext(), ns3::ArpCache::Entry::IsExpired(), LimitsTrace(), MacRxTrace(), MacTxTrace(), ns3::LrWpanMac::McpsDataRequest(), modify(), ns3::TcpSocketBase::NewAck(), NextRxTracer(), NextTxTracer(), ns3::operator*(), ns3::operator<<(), PacingRateTracer(), PacketDequeue(), PhyStateTrace(), PhyTxTrace(), ns3::TcpHtcp::PktsAcked(), ns3::Ipv4RoutingHelper::PrintArpCache(), ns3::Ipv4RoutingHelper::PrintArpCacheEvery(), PrintFairness(), IpAddressHelper::PrintIpAddresses(), PrintPosition(), PrintProgress(), PrintReceivedPacket(), PrintThroughput(), ns3::QKDGraph::ProcessMCurrent(), ns3::QKDTotalGraph::ProcessMCurrent(), ns3::QKDGraph::ProcessMStatus(), ns3::QKDTotalGraph::ProcessMThr(), ns3::QKDGraph::ProcessMThrStatus(), ns3::QKDKeyManagerSystemApplication::PurgeExpiredAssociations(), ns3::AnimationInterface::PurgePendingPackets(), ns3::LrWpanCsmaCa::RandomBackoffDelay(), anonymous_namespace{sample-simulator.cc}::RandomFunction(), ns3::RandomWalk2dOutdoorMobilityModel::Rebound(), RemainingEnergyTrace(), anonymous_namespace{sample-log-time-format.cc}::ReplacementTimePrinter(), ns3::MeshHelper::Report(), ns3::dot11s::HwmpProtocol::Report(), ns3::dot11s::PeerLink::Report(), ns3::flame::FlameProtocol::Report(), ns3::MeshWifiInterfaceMac::Report(), ns3::PhyStatsCalculator::ReportCurrentCellRsrpSinr(), ns3::PhyStatsCalculator::ReportInterference(), ns3::FlowMonitor::ReportLastRx(), ns3::PhyStatsCalculator::ReportUeSinr(), SampleEmitter::Reschedule(), NetAnimExperiment::ResetData(), Experiment::ResetData(), ns3::TcpSocketBase::ReTxTimeout(), TcpBytesInFlightTest::RTOExpired(), RtoTracer(), TcpRttEstimationTest::RttTrace(), RttTracer(), Experiment::Run(), RxEvent(), RxTracer(), ns3::DhcpServer::SendAck(), ns3::TcpSocketBase::SendDataPacket(), TcpDctcpCongestedRouter::SendDataPacket(), ns3::TcpSocketCongestedRouter::SendDataPacket(), ns3::TcpSocketBase::SendEmptyPacket(), ns3::TcpSocketSmallAcks::SendEmptyPacket(), ns3::DhcpServer::SendOffer(), ns3::TcpGeneralTest::SendPacket(), ns3::Rip::SendTriggeredRouteUpdate(), ns3::RipNg::SendTriggeredRouteUpdate(), ns3::Rip::SendUnsolicitedRouteUpdate(), ns3::RipNg::SendUnsolicitedRouteUpdate(), ns3::dot11s::PeerLink::SetBeaconInformation(), ns3::SimpleDeviceEnergyModel::SetCurrentA(), ns3::ThreeGppHttpVariables::SetEmbeddedObjectGenerationDelay(), ns3::olsr::MessageHeader::Hello::SetHTime(), ns3::ThreeGppHttpVariables::SetMainObjectGenerationDelay(), ns3::ThreeGppHttpVariables::SetParsingTimeMean(), ns3::ThreeGppHttpVariables::SetReadingTimeMean(), ns3::DhcpHeader::SetTime(), NodeStatistics::SetupPhy(), ns3::TimeProbe::SetValue(), ns3::olsr::MessageHeader::SetVTime(), showPosition(), SocketPrinter(), SocketSendTrace(), SsThreshTracer(), ns3::UanMacRcGw::StartCycle(), ns3::BaseStationNetDevice::StartDlSubFrame(), Ns3TcpLossTestCase::StartFlow(), Ns3TcpStateTestCase::StartFlow(), ns3::BaseStationNetDevice::StartFrame(), ns3::BaseStationNetDevice::StartUlSubFrame(), NodeStatistics::StateCallback(), TcPacketsInQueue(), TestDeterministicByTime(), Throughput(), TraceDrop(), TraceDropsFrequency(), TraceMark(), TraceMarksFrequency(), TraceN0Cwnd(), TraceN0Rtt(), TraceN0Throughput(), TraceN1Cwnd(), TraceN1Rtt(), TraceN1Throughput(), TracePingRtt(), TraceQueueLength(), ns3::TimeProbe::TraceSink(), TcpPacingTest::Tx(), TxTracer(), ns3::MacStatsCalculator::UlScheduling(), ns3::TcpCubic::Update(), ns3::ConstantVelocityHelper::Update(), ns3::TcpBbr::UpdateAckAggregation(), ns3::TcpHtcp::UpdateAlpha(), ns3::TcpLedbat::UpdateBaseDelay(), TcpPacingTest::UpdateExpectedInterval(), ns3::BasicEnergyHarvester::UpdateHarvestedPower(), ns3::QKDBuffer::UpdateKeyConsumptionStatistics(), ns3::QKDBuffer::UpdateKeyGenerationStatistics(), ns3::TcpSocketBase::UpdatePacingRate(), ns3::WriteAveragePowerSpectralDensityReport(), ns3::RadioBearerStatsCalculator::WriteDlResults(), ns3::RadioBearerStatsCalculator::WriteUlResults(), Ns3TcpLossTestCase::WriteUntilBufferFull(), and Ns3TcpStateTestCase::WriteUntilBufferFull().

+ Here is the call graph for this function:

◆ GetTimeStep()

int64_t ns3::Time::GetTimeStep ( void  ) const
inline

Get the raw time value, in the current resolution unit.

Returns
The raw time value

Definition at line 415 of file nstime.h.

References m_data.

Referenced by ns3::LrWpanPhy::EndEd(), ns3::LrWpanPhy::EndRx(), ns3::WaveformGenerator::GenerateWaveform(), GetInteger(), ns3::Radvd::HandleRead(), ns3::Synchronizer::NanosecondToTimeStep(), ns3::DistributedSimulatorImpl::NextTs(), ns3::OmnetDataOutput::OmnetOutputCallback::OutputSingleton(), ns3::SqliteDataOutput::SqliteOutputCallback::OutputSingleton(), ns3::RealtimeSimulatorImpl::ProcessOneEvent(), ns3::DefaultSimulatorImpl::Schedule(), ns3::RealtimeSimulatorImpl::Schedule(), ns3::DistributedSimulatorImpl::Schedule(), ns3::NullMessageSimulatorImpl::Schedule(), ns3::RealtimeSimulatorImpl::ScheduleRealtimeWithContext(), ns3::DefaultSimulatorImpl::ScheduleWithContext(), ns3::RealtimeSimulatorImpl::ScheduleWithContext(), ns3::DistributedSimulatorImpl::ScheduleWithContext(), ns3::NullMessageSimulatorImpl::ScheduleWithContext(), ns3::NullMessageMpiInterface::SendNullMessage(), ns3::GrantedTimeWindowMpiInterface::SendPacket(), ns3::NullMessageMpiInterface::SendPacket(), AnnexC_TestCase::SendPacket(), ChannelAccessTestCase::SendX(), ns3::SeqTsEchoHeader::Serialize(), ns3::DelayJitterEstimationTimestampTag::Serialize(), ns3::AmpduTag::Serialize(), ns3::ThreeGppHttpHeader::SetClientTs(), ns3::ThreeGppHttpHeader::SetServerTs(), ns3::LrWpanPhy::StartRx(), ns3::DefaultSimulatorImpl::Stop(), ns3::DistributedSimulatorImpl::Stop(), ns3::NullMessageSimulatorImpl::Stop(), TimeSimpleTestCase::TestDivisionByIntegerTypes(), TimeSimpleTestCase::TestMultiplicationByIntegerTypes(), and ns3::DesMetrics::TraceWithContext().

+ Here is the caller graph for this function:

◆ GetYears()

double ns3::Time::GetYears ( void  ) const
inline

Get an approximation of the time stored in this instance in the indicated unit.

Returns
An approximate value in the indicated unit.

Definition at line 363 of file nstime.h.

References ToDouble(), and Y.

+ Here is the call graph for this function:

◆ IsNegative()

bool ns3::Time::IsNegative ( void  ) const
inline

Exactly equivalent to t <= 0.

Returns
true if the time is negative or zero, false otherwise.

Definition at line 308 of file nstime.h.

References m_data.

Referenced by ns3::QosFrameExchangeManager::IsWithinSizeAndTimeLimits(), and ns3::RrMultiUserScheduler::TrySendingBasicTf().

+ Here is the caller graph for this function:

◆ IsPositive()

◆ IsStrictlyNegative()

bool ns3::Time::IsStrictlyNegative ( void  ) const
inline

Exactly equivalent to t < 0.

Returns
true if the time is strictly negative, false otherwise.

Definition at line 324 of file nstime.h.

References m_data.

Referenced by ns3::FrameExchangeManager::DoSendCtsAfterRts(), ns3::QosTxop::GetRemainingTxop(), ns3::HtFrameExchangeManager::SendBlockAck(), ns3::FrameExchangeManager::SendNormalAck(), and ns3::WifiPhy::SetOperatingChannel().

+ Here is the caller graph for this function:

◆ IsStrictlyPositive()

◆ IsZero()

◆ Mark()

void ns3::Time::Mark ( Time *const  time)
staticprivate

Record a Time instance with the MarkedTimes.

Parameters
[in]timeThe Time instance to record.

Definition at line 317 of file time.cc.

References ns3::g_markingMutex, g_markingTimes, NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, and NS_LOG_WARN.

Referenced by Time(), and SetDefaultNsResolution().

+ Here is the caller graph for this function:

◆ Max()

◆ Min()

static Time ns3::Time::Min ( )
inlinestatic

◆ operator=()

Time& ns3::Time::operator= ( const Time o)
inline

Assignment operator.

Parameters
[in]oTime to assign.
Returns
The Time.

Definition at line 129 of file nstime.h.

References m_data.

◆ PeekInformation()

static struct Information* ns3::Time::PeekInformation ( enum Unit  timeUnit)
inlinestaticprivate

Get the Information record for timeUnit for the current Resolution.

Parameters
[in]timeUnitThe Unit to get Information for
Returns
The Information for timeUnit

Definition at line 615 of file nstime.h.

References ns3::Time::Resolution::info, and PeekResolution().

Referenced by From(), FromInteger(), To(), and ToInteger().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ PeekResolution()

static struct Resolution* ns3::Time::PeekResolution ( void  )
inlinestaticprivate

Get the current Resolution.

Returns
A pointer to the current Resolution

Definition at line 604 of file nstime.h.

References SetDefaultNsResolution().

Referenced by PeekInformation(), and SetResolution().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ RoundTo()

Time ns3::Time::RoundTo ( enum Unit  unit) const
inline

Round a Time to a specific unit.

Rounding is to nearest integer.

Parameters
[in]unitThe unit to round to.
Returns
The Time rounded to the specific unit.

Definition at line 555 of file nstime.h.

References From(), and To().

Referenced by ns3::UanHeaderRcData::Serialize(), ns3::UanHeaderRcRts::Serialize(), ns3::UanHeaderRcCtsGlobal::Serialize(), and ns3::UanHeaderRcCts::Serialize().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ SetDefaultNsResolution()

struct Time::Resolution ns3::Time::SetDefaultNsResolution ( void  )
staticprivate

Set the default resolution.

Returns
The Resolution object for the default resolution.

Definition at line 129 of file time.cc.

References D, FromDouble(), FS, g_markingTimes, H, Mark(), MIN, MS, NS, NS_ABORT_MSG, NS_LOG_FUNCTION, PS, S, US, and Y.

Referenced by PeekResolution().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ SetResolution() [1/2]

void ns3::Time::SetResolution ( enum Unit  resolution)
static
Parameters
[in]resolutionThe new resolution to use

Change the global resolution used to convert all user-provided time values in Time objects and Time objects in user-expected time units.

Definition at line 213 of file time.cc.

References NS_LOG_FUNCTION, and PeekResolution().

+ Here is the call graph for this function:

◆ SetResolution() [2/2]

void ns3::Time::SetResolution ( enum Unit  unit,
struct Resolution resolution,
const bool  convert = true 
)
staticprivate

Set the current Resolution.

Parameters
[in]unitThe unit to use as the new resolution.
[in,out]resolutionThe Resolution record to update.
[in]convertWhether to convert existing Time objects to the new resolution.

Definition at line 222 of file time.cc.

References ConvertTimes(), ns3::Time::Information::factor, ns3::Time::Information::fromMul, ns3::Time::Resolution::info, ns3::int64x64_t::Invert(), LAST, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Time::Information::timeFrom, ns3::Time::Information::timeTo, ns3::Time::Information::toMul, ns3::Time::Resolution::unit, ns3::anonymous_namespace{time.cc}::UNIT_COEFF, and ns3::anonymous_namespace{time.cc}::UNIT_POWER.

+ Here is the call graph for this function:

◆ StaticInit()

bool ns3::Time::StaticInit ( )
static

Function to force static initialization of Time.

Returns
true on the first call

Definition at line 96 of file time.cc.

References ns3::g_markingMutex, g_markingTimes, and NS_LOG_ERROR.

◆ To()

int64x64_t ns3::Time::To ( enum Unit  unit) const
inline

Get the Time value expressed in a particular unit.

Parameters
[in]unitThe desired unit
Returns
The Time expressed in unit

Definition at line 533 of file nstime.h.

References m_data, ns3::int64x64_t::MulByInvert(), PeekInformation(), ns3::Time::Information::timeTo, and ns3::Time::Information::toMul.

Referenced by ns3::OnOffApplication::CancelEvents(), RoundTo(), and ToDouble().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ ToDouble()

double ns3::Time::ToDouble ( enum Unit  unit) const
inline

Get the Time value expressed in a particular unit.

Parameters
[in]unitThe desired unit
Returns
The Time expressed in unit

Definition at line 529 of file nstime.h.

References ns3::int64x64_t::GetDouble(), and To().

Referenced by ns3::RrMultiUserScheduler::ComputeDlMuInfo(), ns3::RttMeanDeviation::FloatingPointUpdate(), GetDays(), GetHours(), GetMinutes(), GetSeconds(), GetYears(), Ipv4DeduplicationTest::MakeName(), and SojournTimeTrace().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ ToInteger()

int64_t ns3::Time::ToInteger ( enum Unit  unit) const
inline

Get the Time value expressed in a particular unit.

Parameters
[in]unitThe desired unit
Returns
The Time expressed in unit

Definition at line 515 of file nstime.h.

References ns3::Time::Information::factor, m_data, PeekInformation(), and ns3::Time::Information::toMul.

Referenced by ConvertTimes(), GetFemtoSeconds(), GetMicroSeconds(), GetMilliSeconds(), GetNanoSeconds(), and GetPicoSeconds().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Friends And Related Function Documentation

◆ Abs

Time Abs ( const Time time)
friend

Absolute value for Time.

Parameters
[in]timeThe Time value
Returns
The absolute value of the input.

Definition at line 1136 of file nstime.h.

◆ Div

int64_t Div ( const Time lhs,
const Time rhs 
)
friend

Integer quotient from dividing two Times.

This is the same as the "normal" C++ integer division, which truncates (discarding any remainder).

As usual, if ta, and tb are both Times

ta == tb * Div (ta, tb) + Rem (ta, tb);
ta == tb * (ta / tb).GetHigh() + ta % tb;
friend Time Rem(const Time &lhs, const Time &rhs)
Addition operator for Time.
Definition: nstime.h:1078
friend int64_t Div(const Time &lhs, const Time &rhs)
Integer quotient from dividing two Times.
Definition: nstime.h:1105
Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The integer portion of lhs / rhs.
See also
Rem()

Definition at line 1105 of file nstime.h.

◆ g_TimeStaticInit

bool g_TimeStaticInit = Time::StaticInit ()
related

Force static initialization order of Time in each compilation unit.

This is internal to the Time implementation.

Definition at line 802 of file nstime.h.

◆ Max

Time Max ( const Time timeA,
const Time timeB 
)
friend

Maximum of two Times.

Parameters
[in]timeAThe first value
[in]timeBThe second value
Returns
The larger of the two operands.

Definition at line 1146 of file nstime.h.

◆ Min

Time Min ( const Time timeA,
const Time timeB 
)
friend

Minimum of two Times.

Parameters
[in]timeAThe first value
[in]timeBThe second value
Returns
The smaller of the two operands.

Definition at line 1156 of file nstime.h.

◆ operator!=

bool operator!= ( const Time lhs,
const Time rhs 
)
friend

Inequality operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the two input values not are equal.

Definition at line 822 of file nstime.h.

◆ operator%

Time operator% ( const Time lhs,
const Time rhs 
)
friend

Remainder (modulus) from the quotient of two Times.

Rem() and operator% are equivalent:

Rem (ta, tb)  ==  ta % tb;
See also
Div()
Parameters
[in]lhsThe first time value
[in]rhsThe second time value
Returns
The remainder of lhs / rhs.

Definition at line 1073 of file nstime.h.

◆ operator* [1/5]

Time operator* ( const int64x64_t lhs,
const Time rhs 
)
friend

Scale a Time by a numeric value.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The Time scaled by the other operand.

Definition at line 939 of file nstime.h.

◆ operator* [2/5]

Time operator* ( const Time lhs,
const int64x64_t rhs 
)
friend

Scale a Time by a numeric value.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The Time scaled by the other operand.

Definition at line 926 of file nstime.h.

◆ operator* [3/5]

template<class T >
std::enable_if<std::is_integral<T>::value, Time>::type operator* ( const Time lhs,
rhs 
)
friend

Scale a Time by an integer value.

Template Parameters
TInteger data type (int, long, etc.)
Parameters
[in]lhsThe Time instance to scale
[in]rhsThe scale value
Returns
A new Time instance containing the scaled value

Definition at line 955 of file nstime.h.

◆ operator* [4/5]

template<class T >
std::enable_if<std::is_floating_point<T>::value, Time>::type operator* ( const Time lhs,
rhs 
)
friend

Scale a Time by an integer value.

Template Parameters
TInteger data type (int, long, etc.)
Parameters
[in]lhsThe Time instance to scale
[in]rhsThe scale value
Returns
A new Time instance containing the scaled value

Definition at line 955 of file nstime.h.

◆ operator* [5/5]

template<class T >
std::enable_if<std::is_arithmetic<T>::value, Time>::type operator* ( lhs,
const Time rhs 
)
friend

Scale a Time by a numeric value.

This overload handles the case where the scale value comes before the Time value. It swaps the arguments so that the Time argument comes first and calls the appropriate overload of operator*

Template Parameters
TArithmetic data type (int, long, float, etc.)
Parameters
[in]lhsThe scale value
[in]rhsThe Time instance to scale
Returns
A new Time instance containing the scaled value

Definition at line 986 of file nstime.h.

◆ operator+

Time operator+ ( const Time lhs,
const Time rhs 
)
friend

Addition operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The sum of the two input values.

Definition at line 904 of file nstime.h.

◆ operator+=

Time& operator+= ( Time lhs,
const Time rhs 
)
friend

Compound addition assignment for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The sum of the two inputs.

Definition at line 1115 of file nstime.h.

◆ operator-

Time operator- ( const Time lhs,
const Time rhs 
)
friend

Subtraction operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The difference of the two input values.

Definition at line 914 of file nstime.h.

◆ operator-=

Time& operator-= ( Time lhs,
const Time rhs 
)
friend

Compound subtraction assignment for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The difference of the two operands.

Definition at line 1126 of file nstime.h.

◆ operator/ [1/4]

Time operator/ ( const Time lhs,
const int64x64_t rhs 
)
friend

Scale a Time by a numeric value.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The Time divided by the scalar operand.

Definition at line 1024 of file nstime.h.

◆ operator/ [2/4]

int64x64_t operator/ ( const Time lhs,
const Time rhs 
)
friend

Exact division, returning a dimensionless fixed point number.

This can be truncated to integer, or converted to double (with loss of precison). Assuming ta and tb are Times:

int64x64_t ratio = ta / tb;
int64_t i = ratio.GetHigh (); // Get just the integer part, resulting in truncation
double ratioD = double (ratio); // Convert to double, with loss of precision
Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The exact ratio of the two operands.

Definition at line 1010 of file nstime.h.

◆ operator/ [3/4]

template<class T >
std::enable_if<std::is_integral<T>::value, Time>::type operator/ ( const Time lhs,
rhs 
)
friend

Divide a Time by an integer value.

Template Parameters
TInteger data type (int, long, etc.)
Parameters
[in]lhsThe Time instance to scale
[in]rhsThe scale value
Returns
A new Time instance containing the scaled value

Definition at line 1042 of file nstime.h.

◆ operator/ [4/4]

template<class T >
std::enable_if<std::is_floating_point<T>::value, Time>::type operator/ ( const Time lhs,
rhs 
)
friend

Divide a Time by an integer value.

Template Parameters
TInteger data type (int, long, etc.)
Parameters
[in]lhsThe Time instance to scale
[in]rhsThe scale value
Returns
A new Time instance containing the scaled value

Definition at line 1042 of file nstime.h.

◆ operator< [1/2]

bool operator< ( const Time lhs,
const Time rhs 
)
friend

Less than operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the first input value is less than the second input value.

Definition at line 854 of file nstime.h.

◆ operator< [2/2]

bool operator< ( const Time time,
const EventId event 
)
friend

Compare a Time to an EventId.

This is useful when you have cached a previously scheduled event:

m_event = Schedule (...);

and later you want to know the relationship between that event and some other Time when:

if (when < m_event) ...
Parameters
[in]timeThe Time operand.
[in]eventThe EventId
Returns
true if time is before (less than) the time stamp of the EventId.

Definition at line 887 of file nstime.h.

◆ operator<=

bool operator<= ( const Time lhs,
const Time rhs 
)
friend

Less than or equal operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the first input value is less than or equal to the second input value.

Definition at line 832 of file nstime.h.

◆ operator==

bool operator== ( const Time lhs,
const Time rhs 
)
friend

Equality operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the two input values are equal.

Definition at line 811 of file nstime.h.

◆ operator>

bool operator> ( const Time lhs,
const Time rhs 
)
friend

Greater than operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the first input value is greater than the second input value.

Definition at line 866 of file nstime.h.

◆ operator>=

bool operator>= ( const Time lhs,
const Time rhs 
)
friend

Greater than or equal operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
true if the first input value is greater than or equal to the second input value.

Definition at line 844 of file nstime.h.

◆ Rem

Time Rem ( const Time lhs,
const Time rhs 
)
friend

Addition operator for Time.

Parameters
[in]lhsThe first value
[in]rhsThe second value
Returns
The sum of the two input values.

Definition at line 1078 of file nstime.h.

◆ TimeStep()

Time TimeStep ( uint64_t  ts)
related

Scheduler interface.

Note
This is internal to the Time implementation.
Parameters
[in]tsThe time value, in the current unit.
Returns
A Time.

Definition at line 1303 of file nstime.h.

Member Data Documentation

◆ g_markingTimes

Time::MarkedTimes * ns3::Time::g_markingTimes = 0
staticprivate

Record of outstanding Time objects which will need conversion when the resolution is set.

Internal:

Use a classic static variable so we can check in Time ctors without a function call.

We'd really like to initialize this here, but we don't want to require C++0x, so we init in time.cc. To ensure that happens before first use, we add a call to StaticInit (below) to every compilation unit which includes nstime.h.

Definition at line 670 of file nstime.h.

Referenced by Time(), ~Time(), Clear(), ClearMarkedTimes(), ConvertTimes(), Mark(), SetDefaultNsResolution(), and StaticInit().

◆ m_data

int64_t ns3::Time::m_data
private

Virtual time value, in the current unit.

Definition at line 781 of file nstime.h.

Referenced by Compare(), ConvertTimes(), GetDouble(), GetTimeStep(), IsNegative(), IsPositive(), IsStrictlyNegative(), IsStrictlyPositive(), IsZero(), operator=(), To(), and ToInteger().


The documentation for this class was generated from the following files: