propagation.h
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:4k
源码类别:

通讯编程

开发平台:

Visual C++

  1. /* -*- Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
  2. /*
  3.  * Copyright (c) 1997 Regents of the University of California.
  4.  * All rights reserved.
  5.  *
  6.  * Redistribution and use in source and binary forms, with or without
  7.  * modification, are permitted provided that the following conditions
  8.  * are met:
  9.  * 1. Redistributions of source code must retain the above copyright
  10.  *    notice, this list of conditions and the following disclaimer.
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in the
  13.  *    documentation and/or other materials provided with the distribution.
  14.  * 3. All advertising materials mentioning features or use of this software
  15.  *    must display the following acknowledgement:
  16.  * This product includes software developed by the Computer Systems
  17.  * Engineering Group at Lawrence Berkeley Laboratory.
  18.  * 4. Neither the name of the University nor of the Laboratory may be used
  19.  *    to endorse or promote products derived from this software without
  20.  *    specific prior written permission.
  21.  *
  22.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  23.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  26.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32.  * SUCH DAMAGE.
  33.  */
  34. /* Ported from CMU/Monarch's code, nov'98 -Padma.
  35.    propagation.h
  36.    superclass of all propagation models
  37. */
  38. #ifndef ns_propagation_h
  39. #define ns_propagation_h
  40. #define SPEED_OF_LIGHT 300000000 // 3 * 10^8 m/s
  41. #define PI 3.1415926535897
  42. #include <topography.h>
  43. #include <phy.h>
  44. #include <wireless-phy.h>
  45. #include <packet-stamp.h>
  46. class PacketStamp;
  47. class WirelessPhy;
  48. /*======================================================================
  49.    Progpagation Models
  50. Using postion and wireless transmission interface properties,
  51. propagation models compute the power with which a given
  52. packet will be received.
  53. Not all propagation models will be implemented for all interface
  54. types, since a propagation model may only be appropriate for
  55. certain types of interfaces.
  56.    ====================================================================== */
  57. class Propagation : public TclObject {
  58. public:
  59.   Propagation() : name(NULL), topo(NULL) {}
  60.   // calculate the Pr by which the receiver will get a packet sent by
  61.   // the node that applied the tx PacketStamp for a given inteface 
  62.   // type
  63.   virtual double Pr(PacketStamp *tx, PacketStamp *rx, Phy *);
  64.   virtual double Pr(PacketStamp *tx, PacketStamp *rx, WirelessPhy *);
  65.   virtual int command(int argc, const char*const* argv);
  66.   // get interference distance
  67.   virtual double getDist(double Pr, double Pt, double Gt, double Gr,
  68.  double hr, double ht, double L, double lambda);
  69.   // Friis free space equation, likely to be used by other propagation models.
  70.   double Friis(double Pt, double Gt, double Gr, double lambda, double L, double d);
  71.    // Pt -- transmitted signal power
  72.    // Gt -- transmitter antenna gain
  73.    // Gr -- receiver antenna gain
  74.    // lambda -- wavelength
  75.    // L -- system loss (L >= 1)
  76.    // d -- distance between transmitter and receiver
  77.    // return -- received signal power
  78. protected:
  79.   char *name;
  80.   Topography *topo;
  81. };
  82. // Friis free space propagation model
  83. class FreeSpace : public Propagation {
  84. public:
  85. // FreeSpace();
  86. virtual double Pr(PacketStamp *tx, PacketStamp *rx, WirelessPhy *ifp);
  87. virtual double getDist(double Pr, double Pt, double Gt, double Gr,
  88.        double ht, double hr, double L, double lambda);
  89. };
  90. #endif /* __propagation_h__ */