The Random Number Generator (RNG) that has a specified empirical distribution. More...
#include "random-variable-stream.h"
Classes | |
class | ValueCDF |
Helper to hold one point of the CDF. More... | |
Public Member Functions | |
EmpiricalRandomVariable (void) | |
Creates an empirical RNG that has a specified, empirical distribution, and configured for interpolating mode. More... | |
void | CDF (double v, double c) |
Specifies a point in the empirical distribution. More... | |
virtual uint32_t | GetInteger (void) |
Returns the next value in the empirical distribution. More... | |
virtual double | GetValue (void) |
Returns the next value in the empirical distribution. More... | |
virtual double | Interpolate (void) |
Returns the next value in the empirical distribution using linear interpolation. More... | |
bool | SetInterpolate (bool interpolate) |
Switch the mode between sampling the CDF and interpolating. More... | |
Public Member Functions inherited from ns3::RandomVariableStream | |
RandomVariableStream () | |
Default constructor. More... | |
virtual | ~RandomVariableStream () |
Destructor. More... | |
int64_t | GetStream (void) const |
Returns the stream number for the RngStream. More... | |
bool | IsAntithetic (void) const |
Check if antithetic values will be generated. More... | |
void | SetAntithetic (bool isAntithetic) |
Specify whether antithetic values should be generated. More... | |
void | SetStream (int64_t stream) |
Specifies the stream number for the RngStream. More... | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
virtual | ~Object () |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose (void) |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator (void) const |
Get an iterator to the Objects aggregated to this one. More... | |
virtual TypeId | GetInstanceTypeId (void) const |
Get the most derived TypeId for this Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (void) const |
Get a pointer to the requested aggregated Object. More... | |
void | Initialize (void) |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized (void) const |
Check if the object has been initialized. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount (void) const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= ([[maybe_unused]] const SimpleRefCount &o) |
Assignment operator. More... | |
void | Ref (void) const |
Increment the reference count. More... | |
void | Unref (void) const |
Decrement the reference count. More... | |
Public Member Functions inherited from ns3::ObjectBase | |
virtual | ~ObjectBase () |
Virtual destructor. More... | |
void | GetAttribute (std::string name, AttributeValue &value) const |
Get the value of an attribute, raising fatal errors if unsuccessful. More... | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising erros. More... | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. More... | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. More... | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. More... | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. More... | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. More... | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. More... | |
Static Public Member Functions | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::RandomVariableStream | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId (void) |
Get the type ID. More... | |
Private Member Functions | |
double | DoInterpolate (double r) |
Linear interpolation between two points on the CDF to estimate the value at r . More... | |
double | DoSampleCDF (double r) |
Sample the CDF as a histogram (without interpolation). More... | |
bool | PreSample (double &value) |
Do the initial rng draw and check against the extrema. More... | |
void | Validate (void) |
Check that the CDF is valid. More... | |
Private Attributes | |
std::vector< ValueCDF > | m_emp |
The vector of CDF points. More... | |
bool | m_interpolate |
If true GetValue will interpolate, otherwise treat CDF as normal histogram. More... | |
bool | m_validated |
true once the CDF has been validated. More... | |
Friends | |
bool | operator< (ValueCDF a, ValueCDF b) |
Comparison operator, for use by std::upper_bound. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::RandomVariableStream | |
RngStream * | Peek (void) const |
Get the pointer to the underlying RngStream. More... | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoDispose (void) |
Destructor implementation. More... | |
virtual void | DoInitialize (void) |
Initialize() implementation. More... | |
virtual void | NotifyNewAggregate (void) |
Notify all Objects aggregated to this one of a new Object being aggregated. More... | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. More... | |
virtual void | NotifyConstructionCompleted (void) |
Notifier called once the ObjectBase is fully constructed. More... | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid (void) |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
The Random Number Generator (RNG) that has a specified empirical distribution.
Defines a random variable that has a specified, empirical distribution. The cumulative probability distribution function (CDF) is specified by a series of calls to the CDF() member function, specifying a value and the probability that the distribution is less than the specified value. When random values are requested, a uniform random variable r
is used to select a probability, and the return value is chosen from the largest input value with CDF less than the random value. The method is known as inverse transform sampling: (http://en.wikipedia.org/wiki/Inverse_transform_sampling).
This generator has two modes: sampling and interpolating. In sampling mode this random variable generator treats the CDF as an exact histogram and returns one of the histogram inputs exactly. This is appropriate when the configured CDF represents the exact probability distribution, for a categorical variable, for example.
In interpolating mode this random variable generator linearly interpolates between the CDF values defining the histogram bins. This is appropriate when the configured CDF is an approximation to a continuous underlying probability distribution.
For historical reasons the default is interpolating. To switch modes use the Interpolate
Attribute, or call SetInterpolate(). You can change modes at any time.
If you find yourself switching frequently it could be simpler to set the mode to sampling, then use the GetValue() function for sampled values, and Interpolate() function for interpolated values.
The CDF need not start with a probability of zero, nor end with a probability of 1.0. If the selected uniform random value r
is less than the first CDF point, that point is selected. If r
is greater than the last CDF point the last point is selected. In either case the interpolating mode will not interpolate (since there is no value beyond r
to work with), but simply return the extremal CDF value, as in sampling.
Here is an example of how to use this class:
// Create the RNG with a non-uniform distribution between 0 and 10. // in sampling mode. Ptr<EmpiricalRandomVariable> x = CreateObject<EmpiricalRandomVariable> (); x->SetInterpolate (false); x->CDF ( 0.0, 0.0); x->CDF ( 5.0, 0.25); x->CDF (10.0, 1.0);
double value = x->GetValue ();
The expected values and probabilities returned by GetValue are
Value | Probability |
---|---|
0.0 | 0 |
5.0 | 25% |
10.0 | 75% |
The only two values ever returned are 5 and 10, with unequal probability.
If instead you want linear interpolation between the points of the CDF use the Interpolate() function:
double interp = x->Interpolate ();
This will return continuous values on the range [0,1).
See empirical-random-variable-example.cc for an example.
ns3::EmpiricalRandomVariable is accessible through the following paths with Config::Set and Config::Connect:
No TraceSources are defined for this type.
Size of this type is 96 bytes (on a 64-bit architecture).
Definition at line 2481 of file random-variable-stream.h.
ns3::EmpiricalRandomVariable::EmpiricalRandomVariable | ( | void | ) |
Creates an empirical RNG that has a specified, empirical distribution, and configured for interpolating mode.
Definition at line 1561 of file random-variable-stream.cc.
References NS_LOG_FUNCTION.
void ns3::EmpiricalRandomVariable::CDF | ( | double | v, |
double | c | ||
) |
Specifies a point in the empirical distribution.
c
[in] | v | The function value for this point |
[in] | c | Probability that the function is less than or equal to v |
Definition at line 1694 of file random-variable-stream.cc.
References m_emp, and NS_LOG_FUNCTION.
|
private |
Linear interpolation between two points on the CDF to estimate the value at r
.
[in] | r | The argument value to interpolate to. |
Definition at line 1667 of file random-variable-stream.cc.
References m_emp, and NS_LOG_FUNCTION.
Referenced by GetValue(), and Interpolate().
|
private |
Sample the CDF as a histogram (without interpolation).
[in] | r | The CDF value at which to sample the CDF. |
r
. Definition at line 1640 of file random-variable-stream.cc.
References m_emp, and NS_LOG_FUNCTION.
Referenced by GetValue().
|
virtual |
Returns the next value in the empirical distribution.
Note that this does not interpolate the CDF, but treats it as a stepwise continuous function. Also note that antithetic values are being generated if m_isAntithetic is equal to true. If is a uniform variable over [0,1] and is a value that would be returned normally, then ) is the distance that would be from . The value returned in the antithetic case, , uses (1-u), which is the distance is from the 1.
Implements ns3::RandomVariableStream.
Definition at line 1577 of file random-variable-stream.cc.
References GetValue(), and NS_LOG_FUNCTION.
|
static |
Register this type.
Definition at line 1546 of file random-variable-stream.cc.
References m_interpolate, ns3::MakeBooleanAccessor(), ns3::MakeBooleanChecker(), and ns3::TypeId::SetParent().
|
virtual |
Returns the next value in the empirical distribution.
Note that this does not interpolate the CDF, but treats it as a stepwise continuous function.
Also note that antithetic values are being generated if m_isAntithetic is equal to true. If is a uniform variable over [0,1] and is a value that would be returned normally, then ) is the distance that would be from . The value returned in the antithetic case, , uses (1-u), which is the distance is from the 1.
Implements ns3::RandomVariableStream.
Definition at line 1617 of file random-variable-stream.cc.
References DoInterpolate(), DoSampleCDF(), m_interpolate, NS_LOG_FUNCTION, and PreSample().
Referenced by GetInteger().
|
virtual |
Returns the next value in the empirical distribution using linear interpolation.
Definition at line 1651 of file random-variable-stream.cc.
References DoInterpolate(), NS_LOG_FUNCTION, and PreSample().
|
private |
Do the initial rng draw and check against the extrema.
If the extrema apply, value
will have the extremal value and the return will be true
.
If the extrema do not apply value
will have the URNG value and the return will be false
.
[out] | value | The extremal value, or the URNG. |
true
if value
is the extremal result, or false
if value
is the URNG value. Definition at line 1584 of file random-variable-stream.cc.
References ns3::RandomVariableStream::IsAntithetic(), m_emp, m_validated, NS_LOG_FUNCTION, ns3::RandomVariableStream::Peek(), ns3::RngStream::RandU01(), and Validate().
Referenced by GetValue(), and Interpolate().
bool ns3::EmpiricalRandomVariable::SetInterpolate | ( | bool | interpolate | ) |
Switch the mode between sampling the CDF and interpolating.
The default mode is sampling.
[in] | interpolate | If true set to interpolation, otherwise sampling. |
Definition at line 1568 of file random-variable-stream.cc.
References m_interpolate, and NS_LOG_FUNCTION.
|
private |
Check that the CDF is valid.
A valid CDF has
It is a fatal error to fail validation.
Definition at line 1703 of file random-variable-stream.cc.
References ns3::EmpiricalRandomVariable::ValueCDF::cdf, m_emp, m_validated, NS_FATAL_ERROR, NS_LOG_FUNCTION, and ns3::EmpiricalRandomVariable::ValueCDF::value.
Referenced by PreSample().
|
friend |
Comparison operator, for use by std::upper_bound.
a | [in] the first value |
b | [in] the second value |
true
if a.cdf
< b.cdf
Definition at line 1538 of file random-variable-stream.cc.
|
private |
The vector of CDF points.
Definition at line 2625 of file random-variable-stream.h.
Referenced by CDF(), DoInterpolate(), DoSampleCDF(), PreSample(), and Validate().
|
private |
If true
GetValue will interpolate, otherwise treat CDF as normal histogram.
Definition at line 2630 of file random-variable-stream.h.
Referenced by GetTypeId(), GetValue(), and SetInterpolate().
|
private |
true
once the CDF has been validated.
Definition at line 2623 of file random-variable-stream.h.
Referenced by PreSample(), and Validate().