Stochastic Loading Module
normal_dist.h
1 #ifndef _NORMAL_DIST_H_
2 #define _NORMAL_DIST_H_
3 
4 #include <string>
5 #include <vector>
6 #include <boost/math/distributions/normal.hpp>
7 #include "distribution.h"
8 
9 namespace stochastic {
14  public:
18  NormalDistribution() = delete;
19 
26  NormalDistribution(double mean, double std_dev);
27 
31  virtual ~NormalDistribution(){};
32 
37  std::string name() const override { return "NormalDist"; };
38 
46  std::vector<double> cumulative_dist_func(
47  const std::vector<double>& locations) const override;
48 
56  std::vector<double> inv_cumulative_dist_func(
57  const std::vector<double>& probabilities) const override;
58 
59  protected:
60  double mean_;
61  double std_dev_;
62  boost::math::normal distribution_;
63 };
64 } // namespace stochastic
65 
66 #endif // _NORMAL_DIST_H_
std::string name() const override
Definition: normal_dist.h:37
boost::math::normal distribution_
Definition: normal_dist.h:62
std::vector< double > inv_cumulative_dist_func(const std::vector< double > &probabilities) const override
Definition: normal_dist.cc:23
std::vector< double > cumulative_dist_func(const std::vector< double > &locations) const override
Definition: normal_dist.cc:12