satellite-interference-elimination.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2018 CNES
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Mathias Ettinger <mettinger@toulouse.viveris.com>
19  */
20 
21 #ifndef SATELLITE_INTERFERENCE_ELIMINATION_H
22 #define SATELLITE_INTERFERENCE_ELIMINATION_H
23 
24 #include <ns3/object.h>
25 
26 namespace ns3
27 {
28 
29 class SatSignalParameters;
30 
35 class SatInterferenceElimination : public Object
36 {
37  public:
41  static TypeId GetTypeId(void);
42 
46  TypeId GetInstanceTypeId(void) const;
47 
52 
57 
65  virtual void EliminateInterferences(Ptr<SatSignalParameters> packetInterferedWith,
66  Ptr<SatSignalParameters> processedPacket,
67  double EsNo,
68  bool isRegenerative) = 0;
69 
79  virtual void EliminateInterferences(Ptr<SatSignalParameters> packetInterferedWith,
80  Ptr<SatSignalParameters> processedPacket,
81  double EsNo,
82  bool isRegenerative,
83  double startTime,
84  double endTime) = 0;
85 
89  virtual double GetResidualPower(Ptr<SatSignalParameters> processedPacket, double EsNo) = 0;
90 };
91 
92 } // namespace ns3
93 
94 #endif /* SATELLITE_INTERFERENCE_ELIMINATION_H */
Abstract class defining interface for interference elimination calculation objects.
virtual ~SatInterferenceElimination()
Destructor for Satellite interference elimination base class.
virtual void EliminateInterferences(Ptr< SatSignalParameters > packetInterferedWith, Ptr< SatSignalParameters > processedPacket, double EsNo, bool isRegenerative, double startTime, double endTime)=0
Calculate residual power of interference for the given packets.
static TypeId GetTypeId(void)
Derived from Object.
virtual void EliminateInterferences(Ptr< SatSignalParameters > packetInterferedWith, Ptr< SatSignalParameters > processedPacket, double EsNo, bool isRegenerative)=0
Calculate residual power of interference for the given packets.
TypeId GetInstanceTypeId(void) const
Derived from Object.
SatInterferenceElimination()
Constructor for Satellite interference elimination base class.
virtual double GetResidualPower(Ptr< SatSignalParameters > processedPacket, double EsNo)=0
Calculate the residual power of interference for a given packet.
SatArqSequenceNumber is handling the sequence numbers for the ARQ process.