satellite-per-packet-interference.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: Jani Puttonen <jani.puttonen@magister.fi>
20  * Author: Mathias Ettinger <mettinger@toulouse.viveris.fr>
21  */
22 
23 #ifndef SATELLITE_PER_PACKET_INTERFERENCE_H
24 #define SATELLITE_PER_PACKET_INTERFERENCE_H
25 
26 #include "satellite-enums.h"
28 #include "satellite-interference.h"
29 
30 #include <map>
31 #include <set>
32 #include <stdint.h>
33 #include <tuple>
34 #include <utility>
35 #include <vector>
36 
37 namespace ns3
38 {
39 
47 {
48  public:
53  static TypeId GetTypeId(void);
54 
59  TypeId GetInstanceTypeId(void) const;
60 
65 
71  SatPerPacketInterference(SatEnums::ChannelType_t channelType, double rxBandwidthHz);
72 
77 
81  void DoDispose();
82 
87  void SetRxBandwidth(double rxBandwidth);
88 
89  protected:
98  virtual std::vector<std::pair<double, double>> DoCalculate(
99  Ptr<SatInterference::InterferenceChangeEvent> event);
100 
106  virtual void onOwnStartReached(double ifPowerW);
107 
125  virtual void onInterferentEvent(long double timeRatio,
126  double interferenceValue,
127  double& ifPowerW);
128 
129  private:
138  virtual Ptr<SatInterference::InterferenceChangeEvent> DoAdd(Time rxDuration,
139  double rxPower,
140  Address rxAddress);
141 
145  virtual void DoReset(void);
146 
152  virtual void DoNotifyRxStart(Ptr<SatInterference::InterferenceChangeEvent> event);
153 
159  virtual void DoNotifyRxEnd(Ptr<SatInterference::InterferenceChangeEvent> event);
160 
164  typedef std::tuple<uint32_t, long double, bool> InterferenceChange;
165 
169  typedef std::multimap<Time, InterferenceChange> InterferenceChanges;
170 
176 
183 
188 
192  std::set<uint32_t> m_rxEventIds;
193 
198  long double m_residualPowerW;
199 
203  bool m_rxing;
204 
208  uint32_t m_nextEventId;
209 
214 
219 
224 };
225 
226 } // namespace ns3
227 
228 #endif /* SATELLITE_PER_PACKET_INTERFERENCE_H */
ChannelType_t
Types of channel.
Abstract class defining interface for interference calculations objects.
virtual void DoReset(void)
Resets current interference.
bool m_rxing
flag to indicate that at least one receiving is on
long double m_residualPowerW
Residual power value for interference.
virtual void DoNotifyRxEnd(Ptr< SatInterference::InterferenceChangeEvent > event)
Notifies that RX is ended by a receiver.
InterferenceChanges m_interferenceChanges
interference change list
virtual void DoNotifyRxStart(Ptr< SatInterference::InterferenceChangeEvent > event)
Notifies that RX is started by a receiver.
std::set< uint32_t > m_rxEventIds
notified interference event IDs
virtual void onInterferentEvent(long double timeRatio, double interferenceValue, double &ifPowerW)
Helper function meant for subclasses to override.
std::tuple< uint32_t, long double, bool > InterferenceChange
SatPerPacketInterference(const SatPerPacketInterference &o)
virtual std::vector< std::pair< double, double > > DoCalculate(Ptr< SatInterference::InterferenceChangeEvent > event)
Calculates interference power for the given reference Sets final power at end time to finalPower.
SatPerPacketInterference & operator=(const SatPerPacketInterference &o)
std::multimap< Time, InterferenceChange > InterferenceChanges
virtual void onOwnStartReached(double ifPowerW)
Helper function meant for subclasses to override.
virtual Ptr< SatInterference::InterferenceChangeEvent > DoAdd(Time rxDuration, double rxPower, Address rxAddress)
Adds interference power to interference object.
SatArqSequenceNumber is handling the sequence numbers for the ARQ process.