![]() |
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 <RISE/scenario/pathloss/PyFunction.hpp> 00029 00030 #include <WNS/Ttos.hpp> 00031 #include <WNS/StaticFactoryBroker.hpp> 00032 00033 #include <string> 00034 #include <string> 00035 #include <iostream> 00036 #include <iomanip> 00037 00038 00039 using namespace rise::scenario::pathloss; 00040 00041 STATIC_FACTORY_BROKER_REGISTER(PyFunction, Pathloss, "PyFunction"); 00042 00043 PyFunction::PyFunction(const wns::pyconfig::View& _config) 00044 : DistanceDependent(_config), 00045 config(_config) 00046 { 00047 00048 } 00049 00050 wns::Ratio 00051 PyFunction::calculatePathloss(const antenna::Antenna& source, 00052 const antenna::Antenna& target, 00053 const wns::Frequency& frequency, 00054 const wns::Distance& /*distance*/) const 00055 { 00056 bool sourceIsBase = wns::isClass<Base>(*(source.getStation())); 00057 const antenna::Antenna& baseAntenna(sourceIsBase ? source : target); 00058 wns::Distance baseHeight = baseAntenna.getPosition().getZ(); 00059 00060 std::string s = "calculatePathloss(" 00061 +preciseDtos(source.getPosition().getX())+ "," 00062 +preciseDtos(source.getPosition().getY())+ "," 00063 +preciseDtos(target.getPosition().getX())+ "," 00064 +preciseDtos(target.getPosition().getY())+ "," 00065 +preciseDtos(frequency)+ "," 00066 +preciseDtos(baseHeight)+ ")"; 00067 wns::Ratio pl = config.get<wns::Ratio>(s); 00068 00069 return(pl); 00070 } 00071 00072 std::string 00073 PyFunction::preciseDtos(double value) const 00074 { 00075 std::ostringstream temp; 00076 temp << std::setiosflags(std::ios::fixed) << std::setprecision(3) << value; 00077 return temp.str(); 00078 }
1.5.5