![]() |
User Manual, Developers Guide and API Documentation |
![]() |
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
1.5.5