sinr-tracer.cc

00001 /*
00002  * Copyright (c) 2007 Regents of the SIGNET lab, University of Padova.
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University of Padova (SIGNET lab) nor the 
00014  *    names of its contributors may be used to endorse or promote products 
00015  *    derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
00018  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 
00019  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
00020  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
00021  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
00022  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
00023  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
00024  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
00025  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
00026  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
00027  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 
00030 #include "mphy.h"
00031 #include<math.h>
00032 #include<node-core.h>
00033 
00034 class SinrTracer : public Tracer
00035 {
00036  public:
00037   SinrTracer();
00038  protected:
00039   void format(Packet *p, SAP* sap);
00040 };
00041 
00042 
00043 
00044 SinrTracer::SinrTracer() : Tracer(1) {}
00045 
00046 
00047 
00048 void SinrTracer::format(Packet *p, SAP *sap)
00049 {
00050 
00051   hdr_MPhy* ph = HDR_MPHY(p);
00052   hdr_cmn* ch = HDR_CMN(p);
00053 
00054   // tracing only downward packets
00055   //if (ch->direction() == hdr_cmn::DOWN) return;
00056 
00057 
00058   // tracing only worth packets
00059   if (ph->worth_tracing)
00060     {
00061       assert((ph->Pn + ph->Pi)>0);
00062       double sinr = ph->Pr / (ph->Pn + ph->Pi);
00063       assert(sinr > 0);
00064       
00065       
00066       // linear version
00067       writeTrace(sap, " SINR=%05.2f %s ",
00068                  sinr,
00069                  ch->error() ? "ERR" : "OK "
00070                  );
00071 
00072       // dB version
00073 //       writeTrace(sap, " SINR=%4.2fdB %s ",
00074 //               10*log10(sinr),
00075 //               ch->error() ? "ERR" : "OK "
00076 //               );
00077     
00078     }
00079 }
00080 
00081 extern "C" int Sinrtracer_Init()
00082 {  
00083   SAP::addTracer(new SinrTracer);
00084   return 0;
00085 }
00086 extern "C" int  Cygsinrtracer_Init()
00087 {
00088   Sinrtracer_Init();
00089 }
00090 
00091 

Generated on Wed Nov 26 15:47:28 2008 for NS-MIRACLE library by  doxygen 1.5.2