sdist.cc

来自「ns2--网络仿真软件扩展!·」· CC 代码 · 共 39 行

CC
39
字号
#include <math.h>#include <packet.h>#include <packet-stamp.h>#include <sdist.h>static class SimpleDistanceClass: public TclClass {public:        SimpleDistanceClass() : TclClass("Propagation/SimpleDistance") {}        TclObject* create(int, const char*const*) {                return (new SimpleDistance);        }} class_simpledistance;SimpleDistance::SimpleDistance(){}doubleSimpleDistance::Pr(PacketStamp *t, PacketStamp *r, WirelessPhy *ifp){	double rX, rY, rZ;		// loc of receiver	double tX, tY, tZ;		// loc of xmitter	double d;			// dist	r->getNode()->getLoc(&rX, &rY, &rZ);	t->getNode()->getLoc(&tX, &tY, &tZ);	rX += r->getAntenna()->getX();	rY += r->getAntenna()->getY();	tX += t->getAntenna()->getX();	tY += t->getAntenna()->getY();	d = sqrt((rX - tX) * (rX - tX) 		 + (rY - tY) * (rY - tY) 		 + (rZ - tZ) * (rZ - tZ));	return (t->getTxPr() >= d) ? ifp->getRXThresh() * 2 : 0.0; // XXX *2 just to be on the safe side}

⌨️ 快捷键说明

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