![]() |
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. 5, 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 <APPLICATIONS/distribution/Cauchy.hpp> 00029 00030 using namespace wns::distribution; 00031 00032 STATIC_FACTORY_REGISTER_WITH_CREATOR( 00033 Cauchy, 00034 Distribution, 00035 "applications.Cauchy", 00036 wns::PyConfigViewCreator); 00037 STATIC_FACTORY_REGISTER_WITH_CREATOR( 00038 Cauchy, 00039 Distribution, 00040 "applications.Cauchy", 00041 wns::distribution::RNGConfigCreator); 00042 00043 Cauchy::Cauchy(double median, double sigma, double value, wns::rng::RNGen* rng) : 00044 Distribution(rng), 00045 median_(median), 00046 sigma_(sigma), 00047 value_(value) 00048 { 00049 } 00050 00051 Cauchy::Cauchy(const pyconfig::View& config) : 00052 Distribution(), 00053 median_(config.get<double>("median")), 00054 sigma_(config.get<double>("sigma")), 00055 value_(config.get<double>("value")) 00056 { 00057 } 00058 00059 Cauchy::Cauchy(wns::rng::RNGen* rng, const pyconfig::View& config) : 00060 Distribution(rng), 00061 median_(config.get<double>("median")), 00062 sigma_(config.get<double>("sigma")), 00063 value_(config.get<double>("value")) 00064 { 00065 } 00066 00067 Cauchy::~Cauchy() 00068 { 00069 delete uniDis; 00070 } 00071 00072 double 00073 Cauchy::operator()() 00074 { 00075 uniDis = new wns::distribution::Uniform(0.0, 1.0); 00076 double uniRandomValue = (*uniDis)(); 00077 00078 return (median_ + sigma_ * tan(M_PI * ((uniRandomValue/value_) - (1/2)))); 00079 } 00080 00081 std::string 00082 Cauchy::paramString() const 00083 { 00084 std::ostringstream tmp; 00085 tmp << "applications.Cauchy(median = " << median_ << ", sigma = " << sigma_ 00086 << ", value with the highest %-tile = " << value_ << ")"; 00087 return tmp.str(); 00088 }
1.5.5