![]() |
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/decoder/DecoderFix.hpp> 00029 00030 #include <WNS/Assure.hpp> 00031 00032 #include <stdexcept> 00033 00034 using namespace rise; 00035 using namespace std; 00036 00037 DecoderFix::DecoderFix() : 00038 ber(0.1) 00039 {} 00040 00041 DecoderFix::DecoderFix(double aBER) : 00042 ber(aBER) 00043 { 00044 assure(aBER>=0.0 && aBER<=0.5, "BER must be in the range [0:0.5]"); 00045 } 00046 00047 DecoderFix::~DecoderFix() 00048 {} 00049 00050 double DecoderFix::getBER(double) 00051 { 00052 return ber; 00053 } 00054 00055 double DecoderFix::getBER(double, double aPunctuation) 00056 { 00057 double result = ber*aPunctuation; 00058 if (result>0.5) 00059 return 0.5; 00060 else 00061 return result; 00062 } 00063 00064
1.5.5