User Manual, Developers Guide and API Documentation

Erlang.cpp

Go to the documentation of this file.
00001 /*******************************************************************************
00002  * This file is part of openWNS (open Wireless Network Simulator)
00003  * _____________________________________________________________________________
00004  *
00005  * Copyright (C) 2004-2007
00006  * Chair of Communication Networks (ComNets)
00007  * Kopernikusstr. 16, D-52074 Aachen, Germany
00008  * phone: ++49-241-80-27910,
00009  * fax: ++49-241-80-22242
00010  * email: info@openwns.org
00011  * www: http://www.openwns.org
00012  * _____________________________________________________________________________
00013  *
00014  * openWNS is free software; you can redistribute it and/or modify it under the
00015  * terms of the GNU Lesser General Public License version 2 as published by the
00016  * Free Software Foundation;
00017  *
00018  * openWNS is distributed in the hope that it will be useful, but WITHOUT ANY
00019  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
00020  * A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more
00021  * details.
00022  *
00023  * You should have received a copy of the GNU Lesser General Public License
00024  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
00025  *
00026  ******************************************************************************/
00027 
00028 #include <WNS/distribution/Erlang.hpp>
00029 
00030 using namespace wns::distribution;
00031 
00032 STATIC_FACTORY_REGISTER_WITH_CREATOR(
00033     Erlang,
00034     Distribution,
00035     "Erlang",
00036     wns::PyConfigViewCreator);
00037 STATIC_FACTORY_REGISTER_WITH_CREATOR(
00038     Erlang,
00039     Distribution,
00040     "Erlang",
00041     wns::distribution::RNGConfigCreator);
00042 
00043 Erlang::Erlang(const double rate, const int shape, wns::rng::RNGen* rng) :
00044     Distribution(rng),
00045     rate_(rate),
00046     shape_(shape),
00047     dis_(getRNG())
00048 {
00049 }
00050 
00051 Erlang::Erlang(const pyconfig::View& config) :
00052     Distribution(),
00053     rate_(config.get<double>("rate")),
00054     shape_(config.get<int>("shape")),
00055     dis_(getRNG())
00056 {
00057 }
00058 
00059 Erlang::Erlang(wns::rng::RNGen* rng, const pyconfig::View& config) :
00060     Distribution(rng),
00061     rate_(config.get<double>("rate")),
00062     shape_(config.get<int>("shape")),
00063     dis_(getRNG())
00064 {
00065 }
00066 
00067 Erlang::~Erlang()
00068 {
00069 }
00070 
00071 
00072 double
00073 Erlang::operator()()
00074 {
00075     double product = 1.0;
00076         
00077     for (unsigned long int i = 0; i < shape_; i++)
00078     {
00079         product *= dis_();
00080     }
00081     return -log(product) / rate_ ;
00082 }
00083 
00084 double
00085 Erlang::getMean() const
00086 {
00087     return (double)shape_ / rate_;
00088 }
00089 
00090 std::string
00091 Erlang::paramString() const
00092 {
00093     std::ostringstream tmp;
00094     tmp << "Erlang(rate=" << this->getMean() << ",shape=" << shape_ << ")";
00095     return tmp.str();
00096 }
00097 
00098 /*
00099   Local Variables:
00100   mode: c++
00101   fill-column: 80
00102   c-basic-offset: 8
00103   c-comment-only-line-offset: 0
00104   c-tab-always-indent: t
00105   indent-tabs-mode: t
00106   tab-width: 8
00107   End:
00108 */
00109 

Generated on Wed May 23 03:31:33 2012 for openWNS by  doxygen 1.5.5