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