![]() |
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 #ifndef JAKES_FADING_GENERATOR 00029 #define JAKES_FADING_GENERATOR 00030 00031 #include <WNS/PowerRatio.hpp> 00032 00033 #include <vector> 00034 #include <complex> 00035 00036 00037 namespace rise { namespace scenario { namespace ftfading { 00038 00039 class JakesFadingGenerator 00040 { 00041 public: 00042 // empty constructor needed for std::vector<JakesFadingGenerator> 00043 JakesFadingGenerator(); 00044 ~JakesFadingGenerator(); 00045 00051 void initJakes(const double _maximumDopplerFrequency, const double _samplingTime, const unsigned int _numberOfWaves); 00052 00053 std::complex<double> getNextComplexFadingValue(); 00054 wns::Ratio getNextFadingRatio(); 00055 double getNextFadingValue(); 00056 00057 private: 00059 unsigned int currentSampleIndex; 00061 //double maximumDopplerFrequency; // maximum Doppler shift 00063 double samplingTime; 00065 //double samplingFrequency_; // sampling frequency 00067 //unsigned int numberOfWaves; 00069 unsigned int numberOfWavesQuarter; // No_ in formulas 00070 00071 //double scaleFactor; // std::sqrt(2.0/(static_cast<double>(numberOfWavesQuarter))) 00072 //UniDis randomAngle; // between 0..2pi 00073 00075 std::vector< std::complex<double> > complexTurningFactorVector; 00077 std::vector<double> omega; 00079 //std::vector<double> theta; 00081 double thetaInitial; 00082 }; 00083 00084 }}} 00085 00086 #endif
1.5.5