User Manual, Developers Guide and API Documentation

Cauchy.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. 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 }

Generated on Sun May 27 03:31:38 2012 for openWNS by  doxygen 1.5.5