INET Framework for OMNeT++/OMNEST
Modulation.cc
Go to the documentation of this file.
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