wireless-channelpa.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 and the Daedalus
  18.  * research group at UC Berkeley.
  19.  * 4. Neither the name of the University nor of the Laboratory may be used
  20.  *    to endorse or promote products derived from this software without
  21.  *    specific prior written permission.
  22.  *
  23.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  24.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  27.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  29.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  30.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  31.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  32.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  33.  * SUCH DAMAGE.
  34.  *
  35.  *
  36.  * Ported from ns-2.29/mac/channel.h by Federico Maguolo, Nicola Baldo and Simone Merlin 
  37.  * (SIGNET lab, University of Padova, Department of Information Engineering)
  38.  *
  39.  */
  40. #ifndef _PAWIRELESSCHANNEL_
  41. #define _PAWIRELESSCHANNEL_
  42. #include "channel.h"
  43. class PAWirelessChannel : public Channel{
  44. friend class Topography;
  45. public:
  46. PAWirelessChannel();
  47. virtual int command(int argc, const char*const* argv);
  48. //         inline double gethighestAntennaZ() { return highestAntennaZ_; }
  49. private:
  50. void sendUp(Packet* p, Phy *txif);
  51. double get_pdelay(Node* tnode, Node* rnode);
  52. /* For list-keeper, channel keeps list of mobilenodes 
  53.    listening on to it */
  54. int numNodes_;
  55. MobileNode *xListHead_;
  56. bool sorted_;
  57. void addNodeToList(MobileNode *mn);
  58. void removeNodeFromList(MobileNode *mn);
  59. void sortLists(void);
  60. void updateNodesList(class MobileNode *mn, double oldX);
  61. MobileNode **getAffectedNodes(MobileNode *mn, double radius, int *numAffectedNodes);
  62. protected:
  63. // CS threshold is no more used to determined affected nodes
  64. // this is because nodes well below the CS threshold might still provide
  65. // a non-negligible contribution to interference
  66. //      static double distCST_;        
  67. /**
  68.  * Nodes beyond this distance are not considered for
  69.  * interference calculations. This is useful to reduce
  70.  * computational load in very large multihop topologies 
  71.  * It should however be used with caution in order to preserve 
  72.  * the correctness of interference calculations.
  73.  * Also remember that the distance metric used for this
  74.  * purpose is the Manhattan distance, not the Euclidean
  75.  * distance. 
  76.  */
  77. double distInterference_; 
  78. // Not needed any more since distInterference_ is explicitly
  79. // set via tcl in meters. 
  80. //      static double highestAntennaZ_;
  81. //      void calcHighestAntennaZ(Phy *tifp);
  82. };
  83. #endif