mfreespace.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 /* -*-  Mode:C++ -*- */
00031 
00032 #include<node-core.h>
00033 #include"mfreespace.h"
00034 #include"mphy.h"
00035 
00036 
00037 static class MFreeSpaceClass : public TclClass {
00038 public:
00039   MFreeSpaceClass() : TclClass("MPropagation/MFreeSpace") {}
00040   TclObject* create(int, const char*const*) {
00041     return (new MFreeSpace);
00042   }
00043 } class_MFreeSpace;
00044 
00045 
00046 
00047 int MFreeSpace::command(int argc, const char*const* argv)
00048 {
00049 
00050   return MPropagation::command(argc, argv);
00051 }
00052 
00053 
00054 double MFreeSpace::getGain(Packet* p)
00055 {
00056    hdr_MPhy *ph = HDR_MPHY(p);
00057 
00058    Position* sp = ph->srcPosition;
00059    Position* rp = ph->dstPosition;
00060 
00061    MSpectralMask* sm = ph->srcSpectralMask;
00062 
00063    assert(sp);
00064    assert(rp);
00065    assert(sm);
00066 
00067    double lambda = ph->srcSpectralMask->getLambda();
00068    double d = sp->getDist(rp);
00069    if (d>0) 
00070      {
00071        double g = lambda / (4 * M_PI * d);
00072        if (g<1)
00073          return  g*g;
00074        else 
00075          return 1;
00076      }
00077    else 
00078      return 1;
00079 
00080 }

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