ns3::SatUtHelper Class Referenceabstract

Creates needed objects for UT nodes like SatOrbiterNetDevice objects. More...

#include "satellite-ut-helper.h"

+ Inheritance diagram for ns3::SatUtHelper:
+ Collaboration diagram for ns3::SatUtHelper:

Classes

struct  RandomAccessSettings_s
 Define RandomAccessSettings as a struct. More...
 

Public Member Functions

 SatUtHelper ()
 Default constructor. More...
 
 SatUtHelper (SatTypedefs::CarrierBandwidthConverter_t carrierBandwidthConverter, uint32_t rtnLinkCarrierCount, Ptr< SatSuperframeSeq > seq, SatMac::ReadCtrlMsgCallback readCb, SatMac::ReserveCtrlMsgCallback reserveCb, SatMac::SendCtrlMsgCallback sendCb, RandomAccessSettings_s randomAccessSettings)
 Create a SatUtHelper to make life easier when creating Satellite point to point network connections. More...
 
virtual ~SatUtHelper ()
 Destructor. More...
 
void EnableCreationTraces (Ptr< OutputStreamWrapper > stream, CallbackBase &cb)
 Enables creation traces to be written in given file. More...
 
TypeId GetInstanceTypeId (void) const
 Derived from Object. More...
 
void Initialize (Ptr< SatLinkResultsFwd > lrFwd)
 
NetDeviceContainer Install (NodeContainer c, uint32_t satId, uint32_t beamId, Ptr< SatChannel > fCh, Ptr< SatChannel > rCh, Ptr< SatNetDevice > gwNd, Ptr< SatNcc > ncc, Address satUserAddress, SatPhy::ChannelPairGetterCallback cbChannel, SatMac::RoutingUpdateCallback cbRouting)
 
virtual Ptr< NetDevice > Install (Ptr< Node > n, uint32_t satId, uint32_t beamId, Ptr< SatChannel > fCh, Ptr< SatChannel > rCh, Ptr< SatNetDevice > gwNd, Ptr< SatNcc > ncc, Address satUserAddress, SatPhy::ChannelPairGetterCallback cbChannel, SatMac::RoutingUpdateCallback cbRouting)=0
 
void SetChannelAttribute (std::string name, const AttributeValue &value)
 Set an attribute value to be propagated to each Channel created by the helper. More...
 
void SetDeviceAttribute (std::string name, const AttributeValue &value)
 Set an attribute value to be propagated to each NetDevice created by the helper. More...
 
void SetPhyAttribute (std::string name, const AttributeValue &value)
 Set an attribute value to be propagated to each Phy created by the helper. More...
 

Static Public Member Functions

static TypeId GetTypeId (void)
 Derived from Object. More...
 

Protected Attributes

bool m_asyncAccess
 
SatTypedefs::CarrierBandwidthConverter_t m_carrierBandwidthConverter
 
ObjectFactory m_channelFactory
 
bool m_crdsaOnlyForControl
 Planned CRDSA usage: More...
 
TracedCallback< std::string > m_creationTrace
 Trace callback for creation traces. More...
 
double m_daConstantErrorRate
 
SatPhy::InterferenceModel m_daInterferenceModel
 
ObjectFactory m_deviceFactory
 
bool m_enableChannelEstimationError
 Enable channel estimation error modeling at forward link receiver (= UT). More...
 
SatPhy::ErrorModel m_errorModel
 
uint32_t m_fwdLinkCarrierCount
 
Ptr< SatLinkResultsm_linkResults
 
Ptr< SatLowerLayerServiceConfm_llsConf
 Configured lower layer service configuration. More...
 
RandomAccessSettings_s m_raSettings
 The used random access model settings. More...
 
SatMac::ReadCtrlMsgCallback m_readCtrlCb
 
SatMac::ReserveCtrlMsgCallback m_reserveCtrlCb
 
SatMac::SendCtrlMsgCallback m_sendCtrlCb
 
Ptr< SatSuperframeSeqm_superframeSeq
 

Detailed Description

Creates needed objects for UT nodes like SatOrbiterNetDevice objects.

Handles needed configuration for the UT nodes.

Definition at line 52 of file satellite-ut-helper.h.

Constructor & Destructor Documentation

◆ SatUtHelper() [1/2]

ns3::SatUtHelper::SatUtHelper ( )

Default constructor.

Definition at line 118 of file satellite-ut-helper.cc.

◆ SatUtHelper() [2/2]

ns3::SatUtHelper::SatUtHelper ( SatTypedefs::CarrierBandwidthConverter_t  carrierBandwidthConverter,
uint32_t  rtnLinkCarrierCount,
Ptr< SatSuperframeSeq seq,
SatMac::ReadCtrlMsgCallback  readCb,
SatMac::ReserveCtrlMsgCallback  reserveCb,
SatMac::SendCtrlMsgCallback  sendCb,
RandomAccessSettings_s  randomAccessSettings 
)

Create a SatUtHelper to make life easier when creating Satellite point to point network connections.

Definition at line 138 of file satellite-ut-helper.cc.

References m_channelFactory, m_deviceFactory, and m_llsConf.

◆ ~SatUtHelper()

virtual ns3::SatUtHelper::~SatUtHelper ( )
inlinevirtual

Destructor.

Definition at line 96 of file satellite-ut-helper.h.

Member Function Documentation

◆ EnableCreationTraces()

void ns3::SatUtHelper::EnableCreationTraces ( Ptr< OutputStreamWrapper >  stream,
CallbackBase &  cb 
)

Enables creation traces to be written in given file.

Parameters
streamstream for creation trace outputs
cbcallback to connect traces

Definition at line 230 of file satellite-ut-helper.cc.

◆ GetInstanceTypeId()

TypeId ns3::SatUtHelper::GetInstanceTypeId ( void  ) const

Derived from Object.

Definition at line 111 of file satellite-ut-helper.cc.

References GetTypeId().

+ Here is the call graph for this function:

◆ GetTypeId()

◆ Initialize()

void ns3::SatUtHelper::Initialize ( Ptr< SatLinkResultsFwd lrFwd)

◆ Install() [1/2]

NetDeviceContainer ns3::SatUtHelper::Install ( NodeContainer  c,
uint32_t  satId,
uint32_t  beamId,
Ptr< SatChannel fCh,
Ptr< SatChannel rCh,
Ptr< SatNetDevice gwNd,
Ptr< SatNcc ncc,
Address  satUserAddress,
SatPhy::ChannelPairGetterCallback  cbChannel,
SatMac::RoutingUpdateCallback  cbRouting 
)
Parameters
ca set of nodes
satIdid of the satellite
beamIdid of the beam
fChforward channel
rChreturn channel
gwNdsatellite netdevice of the GW
nccNCC (Network Control Center)
satUserAddressMAC address of satellite user link
Returns
Container of installed net devices

This method creates a ns3::SatChannel with the attributes configured by SatUtHelper::SetChannelAttribute, then, for each node in the input container, we create a ns3::SatNetDevice with the requested attributes, a queue for this ns3::NetDevice, and associate the resulting ns3::NetDevice with the ns3::Node and ns3::SatChannel.

Definition at line 205 of file satellite-ut-helper.cc.

◆ Install() [2/2]

virtual Ptr<NetDevice> ns3::SatUtHelper::Install ( Ptr< Node >  n,
uint32_t  satId,
uint32_t  beamId,
Ptr< SatChannel fCh,
Ptr< SatChannel rCh,
Ptr< SatNetDevice gwNd,
Ptr< SatNcc ncc,
Address  satUserAddress,
SatPhy::ChannelPairGetterCallback  cbChannel,
SatMac::RoutingUpdateCallback  cbRouting 
)
pure virtual
Parameters
nnode
satIdid of the satellite
beamIdid of the beam
fChforward channel
rChreturn channel
gwNdsatellite netdevice of the GW
nccNCC (Network Control Center)
satUserAddressMAC address of satellite user link
Returns
Net device installed to node

Saves you from having to construct a temporary NodeContainer. This method is implemented in child classes.

Implemented in ns3::SatUtHelperLora, and ns3::SatUtHelperDvb.

◆ SetChannelAttribute()

void ns3::SatUtHelper::SetChannelAttribute ( std::string  name,
const AttributeValue &  value 
)

Set an attribute value to be propagated to each Channel created by the helper.

Parameters
namethe name of the attribute to set
valuethe value of the attribute to set

Set these attribute on each ns3::SatChannel created by SatUtHelper::Install

Definition at line 189 of file satellite-ut-helper.cc.

References m_channelFactory.

◆ SetDeviceAttribute()

void ns3::SatUtHelper::SetDeviceAttribute ( std::string  name,
const AttributeValue &  value 
)

Set an attribute value to be propagated to each NetDevice created by the helper.

Parameters
namethe name of the attribute to set
valuethe value of the attribute to set

Set these attributes on each ns3::SatNetDevice created by SatUtHelper::Install

Definition at line 181 of file satellite-ut-helper.cc.

References m_deviceFactory.

◆ SetPhyAttribute()

void ns3::SatUtHelper::SetPhyAttribute ( std::string  name,
const AttributeValue &  value 
)

Set an attribute value to be propagated to each Phy created by the helper.

Parameters
namethe name of the attribute to set
valuethe value of the attribute to set

Set these attributes on each ns3::SatNetDevice created by SatUtHelper::Install

Definition at line 197 of file satellite-ut-helper.cc.

Member Data Documentation

◆ m_asyncAccess

bool ns3::SatUtHelper::m_asyncAccess
protected

Definition at line 264 of file satellite-ut-helper.h.

Referenced by GetTypeId().

◆ m_carrierBandwidthConverter

SatTypedefs::CarrierBandwidthConverter_t ns3::SatUtHelper::m_carrierBandwidthConverter
protected

◆ m_channelFactory

ObjectFactory ns3::SatUtHelper::m_channelFactory
protected

Definition at line 211 of file satellite-ut-helper.h.

Referenced by SatUtHelper(), and SetChannelAttribute().

◆ m_crdsaOnlyForControl

bool ns3::SatUtHelper::m_crdsaOnlyForControl
protected

Planned CRDSA usage:

  • true -> only for control
  • false -> for control and user data

Definition at line 257 of file satellite-ut-helper.h.

Referenced by GetTypeId(), and ns3::SatUtHelperDvb::Install().

◆ m_creationTrace

TracedCallback<std::string> ns3::SatUtHelper::m_creationTrace
protected

Trace callback for creation traces.

Definition at line 239 of file satellite-ut-helper.h.

Referenced by GetTypeId().

◆ m_daConstantErrorRate

double ns3::SatUtHelper::m_daConstantErrorRate
protected

◆ m_daInterferenceModel

SatPhy::InterferenceModel ns3::SatUtHelper::m_daInterferenceModel
protected

◆ m_deviceFactory

ObjectFactory ns3::SatUtHelper::m_deviceFactory
protected

◆ m_enableChannelEstimationError

bool ns3::SatUtHelper::m_enableChannelEstimationError
protected

Enable channel estimation error modeling at forward link receiver (= UT).

Definition at line 250 of file satellite-ut-helper.h.

Referenced by GetTypeId(), ns3::SatUtHelperDvb::Install(), and ns3::SatUtHelperLora::Install().

◆ m_errorModel

SatPhy::ErrorModel ns3::SatUtHelper::m_errorModel
protected

◆ m_fwdLinkCarrierCount

uint32_t ns3::SatUtHelper::m_fwdLinkCarrierCount
protected

◆ m_linkResults

Ptr<SatLinkResults> ns3::SatUtHelper::m_linkResults
protected

◆ m_llsConf

Ptr<SatLowerLayerServiceConf> ns3::SatUtHelper::m_llsConf
protected

Configured lower layer service configuration.

Definition at line 244 of file satellite-ut-helper.h.

Referenced by SatUtHelper(), GetTypeId(), ns3::SatUtHelperDvb::Install(), and ns3::SatUtHelperLora::Install().

◆ m_raSettings

RandomAccessSettings_s ns3::SatUtHelper::m_raSettings
protected

The used random access model settings.

Definition at line 269 of file satellite-ut-helper.h.

Referenced by ns3::SatUtHelperDvb::Install(), and ns3::SatUtHelperLora::Install().

◆ m_readCtrlCb

SatMac::ReadCtrlMsgCallback ns3::SatUtHelper::m_readCtrlCb
protected

Definition at line 207 of file satellite-ut-helper.h.

Referenced by ns3::SatUtHelperDvb::Install().

◆ m_reserveCtrlCb

SatMac::ReserveCtrlMsgCallback ns3::SatUtHelper::m_reserveCtrlCb
protected

Definition at line 208 of file satellite-ut-helper.h.

Referenced by ns3::SatUtHelperDvb::Install().

◆ m_sendCtrlCb

SatMac::SendCtrlMsgCallback ns3::SatUtHelper::m_sendCtrlCb
protected

Definition at line 209 of file satellite-ut-helper.h.

Referenced by ns3::SatUtHelperDvb::Install().

◆ m_superframeSeq

Ptr<SatSuperframeSeq> ns3::SatUtHelper::m_superframeSeq
protected

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