A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
spectrum-converter.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2009 CTTC
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: Nicola Baldo <nbaldo@cttc.es>
19  */
20 
21 #ifndef SPECTRUM_CONVERTER_H
22 #define SPECTRUM_CONVERTER_H
23 
24 #include <ns3/spectrum-value.h>
25 
26 
27 namespace ns3 {
28 
42 class SpectrumConverter : public SimpleRefCount<SpectrumConverter>
43 {
44 public:
53  SpectrumConverter (Ptr<const SpectrumModel> fromSpectrumModel, Ptr<const SpectrumModel> toSpectrumModel);
54 
56 
57 
58 
67 
68 
69 private:
79  double GetCoefficient (const BandInfo& from, const BandInfo& to) const;
80 
81  std::vector<std::vector<double> > m_conversionMatrix; // /< matrix of conversion coefficients
82  Ptr<const SpectrumModel> m_fromSpectrumModel; // /< the SpectrumModel this SpectrumConverter instance can convert from
83  Ptr<const SpectrumModel> m_toSpectrumModel; // /< the SpectrumModel this SpectrumConverter instance can convert to
84 
85 };
86 
87 
88 
89 } // namespace ns3
90 
91 
92 
93 #endif /* SPECTRUM_CONVERTER_H */
94 
95 
Ptr< const SpectrumModel > m_toSpectrumModel
double GetCoefficient(const BandInfo &from, const BandInfo &to) const
Calculate the coefficient for value conversion between elements.
smart pointer class similar to boost::intrusive_ptr
Definition: ptr.h:59
std::vector< std::vector< double > > m_conversionMatrix
Class which implements a converter between SpectrumValue which are defined over different SpectrumMod...
Ptr< SpectrumValue > Convert(Ptr< const SpectrumValue > vvf) const
Convert a particular ValueVsFreq instance to.
Ptr< const SpectrumModel > m_fromSpectrumModel
The building block of a SpectrumModel.
A template-based reference counting class.