EMANE  1.2.1
nakagamifadingalgorithm.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017 - Adjacent Link LLC, Bridgewater, New Jersey
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * * Neither the name of Adjacent Link LLC nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #ifndef EMANENAKAGAMIFADINGALGORITHM_HEADER_
34 #define EMANENAKAGAMIFADINGALGORITHM_HEADER_
35 
36 #include "fadingalgorithm.h"
39 #include <random>
40 
41 namespace EMANE
42 {
44  {
45  public:
47  PlatformServiceProvider * pPlatformService,
48  const std::string & sPrefix);
49 
50  void initialize(Registrar & registrar) override;
51 
52  void configure(const ConfigurationUpdate & update);
53 
54  void modify(const ConfigurationUpdate & update) override;
55 
56  double operator()(double dPowerdBm, double dDistanceMeters) override
57  {
58  double m{};
59 
60  if(dDistanceMeters < dDistance0Meters_)
61  {
62  m = dm0_;
63  }
64  else if (dDistanceMeters < dDistance1Meters_)
65  {
66  m = dm1_;
67  }
68  else
69  {
70  m = dm2_;
71  }
72 
73  return Utils::MILLIWATT_TO_DB(distribution_(generator_,
74  Distribution::param_type{m,
75  Utils::DB_TO_MILLIWATT(dPowerdBm) / m}));
76  }
77 
78  private:
79  double dm0_;
80  double dm1_;
81  double dm2_;
82  double dDistance0Meters_;
83  double dDistance1Meters_;
84  std::mt19937 generator_;
85  using Distribution = std::gamma_distribution<>;
86  Distribution distribution_;
87 
88  void configure_i(const ConfigurationUpdate & update);
89  };
90 }
91 
92 #endif // EMANENAKAGAMIFADINGALGORITHM_HEADER_
double MILLIWATT_TO_DB(double dMillWatt)
The Registrar interface provides access to all of the emulator registrars.
Definition: registrar.h:50
double operator()(double dPowerdBm, double dDistanceMeters) override
The PlatformServiceProvider interface provides access to emulator services.
void modify(const ConfigurationUpdate &update) override
void configure(const ConfigurationUpdate &update)
std::uint16_t NEMId
Definition: types.h:52
NakagamiFadingAlgorithm(NEMId id, PlatformServiceProvider *pPlatformService, const std::string &sPrefix)
std::vector< ConfigurationNameAnyValues > ConfigurationUpdate
double DB_TO_MILLIWATT(double ddB)
void initialize(Registrar &registrar) override
Definition: agent.h:43