satellite-ut-helper.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013 Magister Solutions Ltd
4  * Copyright (c) 2018 CNES
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation;
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18  *
19  * Author: Sami Rantanen <sami.rantanen@magister.fi>
20  * Author: Mathias Ettinger <mettinger@viveris.toulouse.fr>
21  */
22 
23 #ifndef SATELLITE_UT_HELPER_H
24 #define SATELLITE_UT_HELPER_H
25 
26 #include <ns3/net-device-container.h>
27 #include <ns3/node-container.h>
28 #include <ns3/object-factory.h>
29 #include <ns3/output-stream-wrapper.h>
30 #include <ns3/satellite-channel.h>
31 #include <ns3/satellite-link-results.h>
32 #include <ns3/satellite-mac.h>
33 #include <ns3/satellite-ncc.h>
34 #include <ns3/satellite-phy.h>
35 #include <ns3/satellite-random-access-container-conf.h>
36 #include <ns3/satellite-random-access-container.h>
37 #include <ns3/satellite-superframe-sequence.h>
38 #include <ns3/satellite-typedefs.h>
39 #include <ns3/traced-callback.h>
40 
41 #include <stdint.h>
42 #include <string>
43 
44 namespace ns3
45 {
46 
52 class SatUtHelper : public Object
53 {
54  public:
58  typedef struct
59  {
65 
69  static TypeId GetTypeId(void);
70 
74  TypeId GetInstanceTypeId(void) const;
75 
79  SatUtHelper();
80 
85  SatUtHelper(SatTypedefs::CarrierBandwidthConverter_t carrierBandwidthConverter,
86  uint32_t rtnLinkCarrierCount,
87  Ptr<SatSuperframeSeq> seq,
91  RandomAccessSettings_s randomAccessSettings);
92 
96  virtual ~SatUtHelper()
97  {
98  }
99 
100  /*
101  * Initializes the UT helper based on attributes
102  * \param lrFwd DVB-S2 or DVB-S2X link results
103  */
104  void Initialize(Ptr<SatLinkResultsFwd> lrFwd);
105 
116  void SetDeviceAttribute(std::string name, const AttributeValue& value);
117 
128  void SetChannelAttribute(std::string name, const AttributeValue& value);
129 
139  void SetPhyAttribute(std::string name, const AttributeValue& value);
140 
159  NetDeviceContainer Install(NodeContainer c,
160  uint32_t satId,
161  uint32_t beamId,
162  Ptr<SatChannel> fCh,
163  Ptr<SatChannel> rCh,
164  Ptr<SatNetDevice> gwNd,
165  Ptr<SatNcc> ncc,
166  Address satUserAddress,
183  virtual Ptr<NetDevice> Install(Ptr<Node> n,
184  uint32_t satId,
185  uint32_t beamId,
186  Ptr<SatChannel> fCh,
187  Ptr<SatChannel> rCh,
188  Ptr<SatNetDevice> gwNd,
189  Ptr<SatNcc> ncc,
190  Address satUserAddress,
192  SatMac::RoutingUpdateCallback cbRouting) = 0;
193 
199  void EnableCreationTraces(Ptr<OutputStreamWrapper> stream, CallbackBase& cb);
200 
201  protected:
204  Ptr<SatSuperframeSeq> m_superframeSeq;
205 
206  // Control message container callbacks
210 
211  ObjectFactory m_channelFactory;
212  ObjectFactory m_deviceFactory;
213 
214  /*
215  * Configured dedicated access interference model for the forward link. Set as an attribute.
216  */
218 
219  /*
220  * Configured error model for the forward link. Set as an attribute.
221  */
223 
224  /*
225  * Constant error rate for dedicated access in the FWD link.
226  */
228 
229  /*
230  * Forward channel link results (DVB-S2) are created if ErrorModel
231  * is configured to be AVI. Note, that only one instance of the
232  * link results is needed for all UTs.
233  */
234  Ptr<SatLinkResults> m_linkResults;
235 
239  TracedCallback<std::string> m_creationTrace;
240 
244  Ptr<SatLowerLayerServiceConf> m_llsConf;
245 
251 
258 
259  /*
260  * Asynchronous access on the return channel:
261  * - true -> asynchronous
262  * - false -> synchronous
263  */
265 
270 };
271 
272 } // namespace ns3
273 
274 #endif /* SATELLITE_UT_HELPER_H */
RandomAccessModel_t
The defined random access models.
Callback< uint32_t, Ptr< SatControlMessage > > ReserveCtrlMsgCallback
Callback to reserve an id and initially store the control message.
Callback< void, Address, Address > RoutingUpdateCallback
Callback to update routing and ARP tables after handover.
Callback< uint32_t, uint32_t > SendCtrlMsgCallback
Callback to send a control message and allocate a recv ID for it.
Callback< Ptr< SatControlMessage >, uint32_t > ReadCtrlMsgCallback
Callback to read control messages from container storing control messages.
Callback< SatChannelPair::ChannelPair_t, uint32_t, uint32_t > ChannelPairGetterCallback
Callback for retrieving a pair of SatChannel associated to a beam.
InterferenceEliminationModel
Interference cancelation model enum.
RandomAccessCollisionModel
Random access collision model enum.
InterferenceModel
Interference model enum.
Callback< double, SatEnums::ChannelType_t, uint32_t, SatEnums::CarrierBandwidthType_t > CarrierBandwidthConverter_t
Callback for carrier bandwidths.
Creates needed objects for UT nodes like SatOrbiterNetDevice objects.
void EnableCreationTraces(Ptr< OutputStreamWrapper > stream, CallbackBase &cb)
Enables creation traces to be written in given file.
SatPhy::ErrorModel m_errorModel
void SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper.
SatPhy::InterferenceModel m_daInterferenceModel
RandomAccessSettings_s m_raSettings
The used random access model settings.
bool m_enableChannelEstimationError
Enable channel estimation error modeling at forward link receiver (= UT).
SatMac::ReadCtrlMsgCallback m_readCtrlCb
TracedCallback< std::string > m_creationTrace
Trace callback for creation traces.
void SetPhyAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Phy created by the helper.
void Initialize(Ptr< SatLinkResultsFwd > lrFwd)
ObjectFactory m_channelFactory
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)
Ptr< SatLinkResults > m_linkResults
Ptr< SatLowerLayerServiceConf > m_llsConf
Configured lower layer service configuration.
SatUtHelper()
Default constructor.
SatTypedefs::CarrierBandwidthConverter_t m_carrierBandwidthConverter
ObjectFactory m_deviceFactory
bool m_crdsaOnlyForControl
Planned CRDSA usage:
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
virtual ~SatUtHelper()
Destructor.
SatMac::SendCtrlMsgCallback m_sendCtrlCb
Ptr< SatSuperframeSeq > m_superframeSeq
SatMac::ReserveCtrlMsgCallback m_reserveCtrlCb
static TypeId GetTypeId(void)
Derived from Object.
TypeId GetInstanceTypeId(void) const
Derived from Object.
void SetDeviceAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each NetDevice created by the helper.
SatArqSequenceNumber is handling the sequence numbers for the ARQ process.
Define RandomAccessSettings as a struct.
SatEnums::RandomAccessModel_t m_randomAccessModel
SatPhyRxCarrierConf::RandomAccessCollisionModel m_raCollisionModel
SatPhyRxCarrierConf::InterferenceEliminationModel m_raInterferenceEliminationModel
SatPhyRxCarrierConf::InterferenceModel m_raInterferenceModel