modulation.cc

Go to the documentation of this file.
00001 /* -*-  Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
00002 /*
00003  * Copyright (c) 1997 Regents of the University of California.
00004  * All rights reserved.
00005  *
00006  * Redistribution and use in source and binary forms, with or without
00007  * modification, are permitted provided that the following conditions
00008  * are met:
00009  * 1. Redistributions of source code must retain the above copyright
00010  *    notice, this list of conditions and the following disclaimer.
00011  * 2. Redistributions in binary form must reproduce the above copyright
00012  *    notice, this list of conditions and the following disclaimer in the
00013  *    documentation and/or other materials provided with the distribution.
00014  * 3. All advertising materials mentioning features or use of this software
00015  *    must display the following acknowledgement:
00016  *  This product includes software developed by the Computer Systems
00017  *  Engineering Group at Lawrence Berkeley Laboratory.
00018  * 4. Neither the name of the University nor of the Laboratory may be used
00019  *    to endorse or promote products derived from this software without
00020  *    specific prior written permission.
00021  *
00022  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
00023  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00024  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00025  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
00026  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00027  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00028  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00029  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00031  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00032  * SUCH DAMAGE.
00033  */
00034 /* Ported from CMU/Monarch's code, nov'98 -Padma.*/
00035 
00036 #include <math.h>
00037 #include <stdlib.h>
00038 #include <random.h>
00039 //#include <debug.h>
00040 #include <modulation.h>
00041 
00042 /* ======================================================================
00043    Binary Phase Shift Keying
00044    ====================================================================== */
00045 BPSK::BPSK()
00046 {
00047     Rs = 0;
00048 }
00049 
00050 BPSK::BPSK(int S)
00051 {
00052     Rs = S;
00053 }
00054 
00055 int
00056 BPSK::BitError(double Pr)
00057 {
00058     double Pe;          // probability of error
00059     double x;
00060     int nbit = 0;           // number of bit errors tolerated
00061 
00062     if(nbit == 0) {
00063         Pe = ProbBitError(Pr);
00064     }
00065     else {
00066         Pe = ProbBitError(Pr, nbit);
00067     }
00068 
00069     // quick check
00070     if(Pe == 0.0)
00071         return 0;       // no bit errors
00072 
00073     // scale the error probabilty
00074     Pe *= 1e3;
00075 
00076     x = (double)(((int)Random::uniform()) % 1000);
00077 
00078     if(x < Pe)
00079         return 1;       // bit error
00080     else
00081         return 0;       // no bit errors
00082 }
00083 
00084 double
00085 BPSK::ProbBitError(double)
00086 {
00087     double Pe = 0.0;
00088 
00089     return Pe;
00090 }
00091 
00092 double
00093 BPSK::ProbBitError(double, int)
00094 {
00095     double Pe = 0.0;
00096 
00097     return Pe;
00098 }
00099 
00100 

Generated on Tue Mar 6 16:47:47 2007 for ns2 Network Simulator 2.29 by  doxygen 1.4.6