interference_miv.h

00001 /* -*-  Mode:C++ -*- */
00002 /*
00003  * Copyright (c) 2007 Regents of the SIGNET lab, University of Padova.
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. Neither the name of the University of Padova (SIGNET lab) nor the 
00015  *    names of its contributors may be used to endorse or promote products 
00016  *    derived from this software without specific prior written permission.
00017  *
00018  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
00019  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 
00020  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
00021  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
00022  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
00023  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
00024  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
00025  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
00026  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
00027  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
00028  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00029  */
00030 
00031 #ifndef INTERFERENCE_MIV_H
00032 #define INTERFERENCE_MIV_H
00033 
00034 #include<minterference.h>
00035 #include<list>
00036 #include<scheduler.h>
00037 #include<string>
00038 
00039 class Point {
00040  public:
00041   double time;   
00042   double value;  
00044   Point(double t, double v) {value=v; time=t;}
00045   Point(const Point &c) {value=c.value; time=c.time;}
00046   Point &operator=(const Point &rhs) { this->value=rhs.value; this->time=rhs.time; return *this;}
00047   int operator==(const Point &rhs) const;
00048   int operator<(const Point &rhs) const;
00049 };
00050 
00051 
00052 typedef std::list<Point> Function;
00053 typedef std::list<Point>::iterator FunctionIterator;
00054 
00055 
00056 class MInterferenceMIV;
00057 
00058 class PowerEvent : public Event {
00059 public:
00060   PowerEvent(double pow) : power(pow) {}
00061   virtual ~PowerEvent() {}
00062   double power;
00063 };
00064 
00065 
00066 class EndInterferenceMIVTimer : public Handler {
00067 
00068 public:
00069   EndInterferenceMIVTimer(MInterferenceMIV* ptr) : mimiv(ptr)  {        }
00070   virtual void handle(Event *e);  
00071 
00072 protected:
00073   MInterferenceMIV*       mimiv;
00074 
00075 };
00076 
00077 
00082 class MInterferenceMIV : public MInterference
00083 {
00084   friend class EndInterferenceMIVTimer;
00085  public:
00086   MInterferenceMIV();
00087   virtual ~MInterferenceMIV();
00088   virtual void addToInterference(Packet* p);
00089   virtual void addToInterference(double power, double starttime); 
00090   virtual double getInterferencePower(Packet* p);
00091   virtual double getInterferencePower(double power, double starttime, double endtime);
00092   virtual double getCurrentTotalPower();
00093   
00094  protected:
00095   void dump(string msg); 
00096   Function pp;             
00097   double maxinterval_;     
00098 
00099   EndInterferenceMIVTimer endinterftimer; 
00100   int debug_;              
00101 };
00102 
00103 #endif /* INTERFERENCE_MIV_H */
00104 
00105 

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