⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 drop.cc

📁 NS2网络仿真软件是目前最为流行的网络仿真模拟软件
💻 CC
字号:
/* * Copyright (c) 1991,1993 Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *  This product includes software developed by the Computer Systems *  Engineering Group at Lawrence Berkeley Laboratory. * 4. Neither the name of the University nor of the Laboratory may be used *    to endorse or promote products derived from this software without *    specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * @(#) $Header: /cvsroot/nsnam/nam-1/drop.cc,v 1.14 2005/01/24 19:55:14 haldar Exp $ (LBL) */#ifdef WIN32#include <windows.h>#endif#include "netview.h"#include "drop.h"#include "monitor.h"//<zheng: +++>#include "parser.h"#include <math.h>//</zheng: +++>#include "config.h"//----------------------------------------------------------------------//----------------------------------------------------------------------Drop::Drop(float cx, float cy, float b, float size, double now,           long offset, const PacketAttr& p) :  Animation(now, offset),  x_(cx),  y_(cy),  bottom_(b),  psize_(size),  start_(now),   pkt_(p),  rotation_(0) {  curPos_ = CurPos(now);}//----------------------------------------------------------------------//----------------------------------------------------------------------Drop::~Drop() {  if (monitor_!=NULL) {    monitor_->delete_monitor_object(this);  }}//----------------------------------------------------------------------//----------------------------------------------------------------------void Drop::draw(View * c, double now) {  /* XXX nuke array */  //<zheng: +++>  float tx,ty,tx2,ty2,td;  //</zheng: +++>  float fx[4], fy[4];  double yy = CurPos(now);  if (rotation_ & 2) {    double d = (0.75 * 0.7071067812) * psize_;    //<zheng: +++>    //not too large    if (ParseTable::nam4wpan) {	    tx = x_;	    ty = yy;	    c->imap(tx,ty);	    tx2 = x_ + 1;	    ty2 = yy;	    c->imap(tx2,ty2);	    td = (tx2 - tx) * (tx2 - tx) + (ty2 - ty) * (ty2 - ty);	    td = pow(td, 0.5);	    if (d > td)	       d = td;    }    //</zheng: +++>    fx[0] = x_;    fy[0] = yy - d;    fx[1] = x_ - d;    fy[1] = yy;    fx[2] = x_;    fy[2] = yy + d;    fx[3] = x_ + d;    fy[3] = yy;  } else {    double d = (0.75 * 0.5) * psize_;    //<zheng: +++>    //not too large    if (ParseTable::nam4wpan) {	    tx = x_;	    ty = yy;	    c->imap(tx,ty);	    tx2 = x_ + 1;	    ty2 = yy;	    c->imap(tx2,ty2);	    td = (tx2 - tx) * (tx2 - tx) + (ty2 - ty) * (ty2 - ty);	    td = pow(td, 0.5);	    if (d > td)	       d = td;    }    //</zheng: +++>    fx[0] = x_ - d;    fy[0] = yy - d;    fx[1] = x_ - d;    fy[1] = yy + d;    fx[2] = x_ + d;    fy[2] = yy + d;    fx[3] = x_ + d;    fy[3] = yy - d;  }  // Draw a square  c->fill(fx, fy, 4, paint_);  if (monitor_) {    monitor_->draw(c, x_,yy);  }}//----------------------------------------------------------------------//----------------------------------------------------------------------void Drop::update(double now) {  ++rotation_;  if ((now < start_) ||      (CurPos(now) < bottom_)) {    delete this;  } else {    curPos_ = CurPos(now);    update_bb();  }}void Drop::update_bb(){  double d = (0.75 * 0.7071067812) * psize_;  bb_.xmin = x_ - d, bb_.xmax = x_ + d;  bb_.ymin = curPos_ - d, bb_.ymax = curPos_ + d;}void Drop::reset(double now){  if (now < start_ || CurPos(now) < bottom_)    delete this;  else     curPos_ = CurPos(now);}int Drop::inside(double now, float px, float py) const{  //float minx, maxx, miny, maxy;  double yy = CurPos(now);  double d = (0.75 * 0.7071067812) * psize_;  return (px >= x_ - d && px <= x_ + d && py >= yy - d && py <= yy + d);}//----------------------------------------------------------------------// double// Drop::CurPos(double now) const//  - Calculates the current position of the packet based upon the start//    time of the packet drop and the maximum drop time//----------------------------------------------------------------------doubleDrop::CurPos(double now) const {  // This calculation starts the drop at y_ and runs to bottom_ within the  // timeframe of MAX_DROP_TIME.  At start_ + MAX_DROP_TIME the packet   // should be at bottom_.  double drop_distance = (now - start_)*(bottom_ - y_)/MAX_DROP_TIME + y_;//  if (bottom_ < -10) {   //quick hack for wireless model//   drop_distance = y_ - (now - start_) * (0 - bottom_);//   fprintf(stderr, "Using Wireless drop distance.\n");//  }   return drop_distance;}const char* Drop::info() const{  static char text[128];  sprintf(text, "%s %d: %s\n  dropped at %g\n  %d bytes",    pkt_.type, pkt_.id, pkt_.convid, start_, pkt_.size);  return (text);}const char* Drop::getname() const{  static char text[128];  sprintf(text, "d");  return (text);}void Drop::monitor(Monitor *m, double /*now*/, char *result, int /*len*/){  monitor_=m;  sprintf(result, "%s %d: %s\n  dropped at %g\n  %d bytes",                pkt_.type, pkt_.id, pkt_.convid, start_, pkt_.size);}MonState *Drop::monitor_state(){  MonState *ms=new MonState;  ms->type=MON_PACKET;  ms->pkt.id=pkt_.id;  return ms;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -