|
INET Framework for OMNeT++/OMNEST
|
00001 // 00002 // Copyright (C) 2006 Andras Varga 00003 // Based on the Mobility Framework's SnrEval by Marc Loebbers 00004 // 00005 // This program is free software; you can redistribute it and/or 00006 // modify it under the terms of the GNU General Public License 00007 // as published by the Free Software Foundation; either version 2 00008 // of the License, or (at your option) any later version. 00009 // 00010 // This program is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 // GNU General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU General Public License 00016 // along with this program; if not, see <http://www.gnu.org/licenses/>. 00017 // 00018 00019 #include "Modulation.h" 00020 00021 00022 double NullModulation::calculateBER(double, double, double) 00023 { 00024 return 0; 00025 } 00026 00027 double BPSKModulation::calculateBER(double snir, double bandwidth, double bitrate) 00028 { 00029 return 0.5 * exp(-snir * bandwidth / bitrate); 00030 } 00031 00032 double QAM16Modulation::calculateBER(double snir, double bandwidth, double bitrate) 00033 { 00034 return 0.5 * (1 - 1 / sqrt(pow(2.0, 4))) * erfc(snir * bandwidth / bitrate); 00035 } 00036 00037 double QAM256Modulation::calculateBER(double snir, double bandwidth, double bitrate) 00038 { 00039 return 0.25 * (1 - 1 / sqrt(pow(2.0, 8))) * erfc(snir * bandwidth / bitrate); 00040 } 00041 00042 00043 00044