![]() |
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/Rice.hpp> 00029 00030 using namespace wns::distribution; 00031 00032 STATIC_FACTORY_REGISTER_WITH_CREATOR( 00033 Rice, 00034 Distribution, 00035 "Rice", 00036 wns::PyConfigViewCreator); 00037 STATIC_FACTORY_REGISTER_WITH_CREATOR( 00038 Rice, 00039 Distribution, 00040 "Rice", 00041 wns::distribution::RNGConfigCreator); 00042 00043 Rice::Rice(double losFactor, double variance, wns::rng::RNGen* rng) : 00044 Distribution(rng), 00045 losFactor_(losFactor), 00046 variance_(variance), 00047 disA_(losFactor_, variance_ * variance_, getRNG()), 00048 disB_(0.0, variance_ * variance_, getRNG()) 00049 { 00050 } 00051 00052 Rice::Rice(const pyconfig::View& config) : 00053 Distribution(), 00054 losFactor_(config.get<double>("losFactor")), 00055 variance_(config.get<double>("variance")), 00056 disA_(losFactor_, variance_*variance_, getRNG()), 00057 disB_(0.0, variance_ * variance_, getRNG()) 00058 { 00059 } 00060 00061 Rice::Rice(wns::rng::RNGen* rng, const pyconfig::View& config) : 00062 Distribution(rng), 00063 losFactor_(config.get<double>("losFactor")), 00064 variance_(config.get<double>("variance")), 00065 disA_(losFactor_, variance_*variance_, getRNG()), 00066 disB_(0.0, variance_ * variance_, getRNG()) 00067 { 00068 } 00069 00070 00071 Rice::~Rice() 00072 { 00073 } 00074 00075 double 00076 Rice::operator()() 00077 { 00078 double rnd_a = disA_(); 00079 double rnd_b = disB_(); 00080 00081 return sqrt(rnd_a * rnd_a + rnd_b * rnd_b); 00082 } 00083 00084 std::string 00085 Rice::paramString() const 00086 { 00087 std::ostringstream tmp; 00088 tmp << "Rice(LOS Factor=" << losFactor_ << " variance=" << variance_ << ")"; 00089 return tmp.str(); 00090 } 00091 00092 /* 00093 Local Variables: 00094 mode: c++ 00095 fill-column: 80 00096 c-basic-offset: 8 00097 c-comment-only-line-offset: 0 00098 c-tab-always-indent: t 00099 indent-tabs-mode: t 00100 tab-width: 8 00101 End: 00102 */ 00103
1.5.5