亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cmu-trace.cc

?? linux平臺下,在ns2里面實現的基于價格的分布式優化算法源代碼
?? CC
?? 第 1 頁 / 共 3 頁
字號:
/* -*-	Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- *//* * Copyright (c) 1997 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. * * Ported from CMU/Monarch's code, appropriate copyright applies. * nov'98 -Padma. * * $Header: /nfs/jade/vint/CVSROOT/ns-2/trace/cmu-trace.cc,v 1.72 2003/02/22 03:53:35 buchheim Exp $ */#include <packet.h>#include <ip.h>#include <tcp.h>#include <rtp.h>#include <arp.h>#include <dsr/hdr_sr.h>	// DSR#include <mac.h>#include <mac-802_11.h>#include <address.h>#include <tora/tora_packet.h> //TORA#include <imep/imep_spec.h>         // IMEP#include <aodv/aodv_packet.h> //AODV#include <cmu-trace.h>#include <mobilenode.h>#include "diffusion/diff_header.h" // DIFFUSION -- Chalermek//#define LOG_POSITION//extern char* pt_names[];static class CMUTraceClass : public TclClass {public:	CMUTraceClass() : TclClass("CMUTrace") { }	TclObject* create(int, const char*const* argv) {		return (new CMUTrace(argv[4], *argv[5]));	}} cmutrace_class;double CMUTrace::bradius = 0.0;double CMUTrace::radius_scaling_factor_ = 0.0;double CMUTrace::duration_scaling_factor_ = 0.0;CMUTrace::CMUTrace(const char *s, char t) : Trace(t){	bzero(tracename, sizeof(tracename));	strncpy(tracename, s, MAX_ID_LEN);        if(strcmp(tracename, "RTR") == 0) {                tracetype = TR_ROUTER;        }	else if(strcmp(tracename, "TRP") == 0) {                tracetype = TR_ROUTER;        }        else if(strcmp(tracename, "MAC") == 0) {                tracetype = TR_MAC;        }        else if(strcmp(tracename, "IFQ") == 0) {                tracetype = TR_IFQ;        }        else if(strcmp(tracename, "AGT") == 0) {                tracetype = TR_AGENT;        }        else {                fprintf(stderr, "CMU Trace Initialized with invalid type\n");                exit(1);        }	assert(type_ == DROP || type_ == SEND || type_ == RECV);	newtrace_ = 0;	for (int i=0 ; i < MAX_NODE ; i++) 		nodeColor[i] = 3 ;        node_ = 0;}voidCMUTrace::format_mac(Packet *p, const char *why, int offset){	struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_ip *ih = HDR_IP(p);	struct hdr_mac802_11 *mh = HDR_MAC802_11(p);	double x = 0.0, y = 0.0, z = 0.0;       	char op = (char) type_;	Node* thisnode = Node::get_node_by_address(src_);	double energy = -1;	if (thisnode) {	    if (thisnode->energy_model()) {		    energy = thisnode->energy_model()->energy();	    }	}	// hack the IP address to convert pkt format to hostid format	// for now until port ids are removed from IP address. -Padma.	int src = Address::instance().get_nodeaddr(ih->saddr());	if(tracetype == TR_ROUTER && type_ == SEND) {		if(src_ != src)			op = FWRD;	}	// use tagged format if appropriate	if (pt_->tagged()) {		int next_hop = -1 ;		Node* nextnode = Node::get_node_by_address(ch->next_hop_);        	if (nextnode) next_hop = nextnode->nodeid(); 		node_->getLoc(&x, &y, &z);		if (op == DROP) op = 'd';		if (op == SEND) op = '+';		if (op == FWRD) op = 'h';		sprintf(pt_->buffer() + offset,			"%c "TIME_FORMAT" -s %d -d %d -p %s -k %3s -i %d "			"-N:loc {%.2f %.2f %.2f} -N:en %f "			"-M:dur %x -M:s %x -M:d %x -M:t %x ",			op,				// event type			Scheduler::instance().clock(),	// time			src_,				// this node			next_hop,			// next hop			packet_info.name(ch->ptype()),	// packet type			tracename,			// trace level			ch->uid(),			// event id			x, y, z,			// location			energy,				// energy			mh->dh_duration,		// MAC: duration			ETHER_ADDR(mh->dh_da),		// MAC: source			ETHER_ADDR(mh->dh_sa),		// MAC: destination			GET_ETHER_TYPE(mh->dh_body)	// MAC: type			);		return;	}	// Use new ns trace format to replace the old cmu trace format)	if (newtrace_) {	    	    node_->getLoc(&x, &y, &z);	    // consistence	    if ( op == DROP ) { op = 'd';}	        // basic trace infomation + basic exenstion	    sprintf(pt_->buffer() + offset,		   "%c -t %.9f -Hs %d -Hd %d -Ni %d -Nx %.2f -Ny %.2f -Nz %.2f -Ne %f -Nl %3s -Nw %s ",		    op,                       // event type		    Scheduler::instance().clock(),  // time		    src_,                           // this node                    ch->next_hop_,                  // next hop		    src_,                           // this node		    x,                              // x coordinate		    y,                              // y coordinate		    z,                              // z coordinate		    energy,                         // energy, -1 = not existing		    tracename,                      // trace level                    why);                            // reason	    // mac layer extension	    offset = strlen(pt_->buffer());	    sprintf(pt_->buffer() + offset, 		    "-Ma %x -Md %x -Ms %x -Mt %x ",		    mh->dh_duration,		    ETHER_ADDR(mh->dh_da),		    ETHER_ADDR(mh->dh_sa),		    GET_ETHER_TYPE(mh->dh_body));		    	     return;	}#ifdef LOG_POSITION        double x = 0.0, y = 0.0, z = 0.0;        node_->getLoc(&x, &y, &z);#endif	sprintf(pt_->buffer() + offset,#ifdef LOG_POSITION		"%c %.9f %d (%6.2f %6.2f) %3s %4s %d %s %d [%x %x %x %x] ",#else		"%c %.9f _%d_ %3s %4s %d %s %d [%x %x %x %x] ",#endif		op,		Scheduler::instance().clock(),                src_,                           // this node#ifdef LOG_POSITION                x,                y,#endif		tracename,		why,		                ch->uid(),                      // identifier for this event				((ch->ptype() == PT_MAC) ? (		  (mh->dh_fc.fc_subtype == MAC_Subtype_RTS) ? "RTS"  :		  (mh->dh_fc.fc_subtype == MAC_Subtype_CTS) ? "CTS"  :		  (mh->dh_fc.fc_subtype == MAC_Subtype_ACK) ? "ACK"  :		  "UNKN"		  ) : packet_info.name(ch->ptype())),				ch->size(),		//*((u_int16_t*) &mh->dh_fc),		mh->dh_duration,		ETHER_ADDR(mh->dh_da),		ETHER_ADDR(mh->dh_sa),		GET_ETHER_TYPE(mh->dh_body));	offset = strlen(pt_->buffer());	if (thisnode) {		if (thisnode->energy_model()) {			sprintf(pt_->buffer() + offset,				"[energy %f] ",				thisnode->energy_model()->energy());		}        }}voidCMUTrace::format_ip(Packet *p, int offset){        struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_ip *ih = HDR_IP(p);		// hack the IP address to convert pkt format to hostid format	// for now until port ids are removed from IP address. -Padma.	int src = Address::instance().get_nodeaddr(ih->saddr());	int dst = Address::instance().get_nodeaddr(ih->daddr());	if (pt_->tagged()) {		sprintf(pt_->buffer() + offset,			"-IP:s %d -IP:sp %d -IP:d %d -IP:dp %d -p %s -e %d "			"-c %d -i %d -IP:ttl %d ",			src,                           // packet src			ih->sport(),                   // src port			dst,                           // packet dest			ih->dport(),                   // dst port			packet_info.name(ch->ptype()), // packet type			ch->size(),                    // packet size			ih->flowid(),                  // flow id			ch->uid(),                     // unique id			ih->ttl_                       // ttl			);	} else if (newtrace_) {	    sprintf(pt_->buffer() + offset,		    "-Is %d.%d -Id %d.%d -It %s -Il %d -If %d -Ii %d -Iv %d ",		    src,                           // packet src		    ih->sport(),                   // src port		    dst,                           // packet dest		    ih->dport(),                   // dst port		    packet_info.name(ch->ptype()),  // packet type		    ch->size(),                     // packet size		    ih->flowid(),                   // flow id		    ch->uid(),                      // unique id		    ih->ttl_);                      // ttl	} else {        //Yuan change for flowid trace	    sprintf(pt_->buffer() + offset, "------- [%d:%d %d:%d %d %d] <%d>",		src, ih->sport(),		dst, ih->dport(),		ih->ttl_, (ch->next_hop_ < 0) ? 0 : ch->next_hop_,        ih->flowid());	}}voidCMUTrace::format_arp(Packet *p, int offset){	struct hdr_arp *ah = HDR_ARP(p);	if (pt_->tagged()) {	    sprintf(pt_->buffer() + offset,		    "-arp:op %s -arp:ms %d -arp:s %d -arp:md %d -arp:d %d ",		    ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		    ah->arp_sha,		    ah->arp_spa,		    ah->arp_tha,		    ah->arp_tpa);	} else if (newtrace_) {	    sprintf(pt_->buffer() + offset,		    "-P arp -Po %s -Pms %d -Ps %d -Pmd %d -Pd %d ",		    ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		    ah->arp_sha,		    ah->arp_spa,		    ah->arp_tha,		    ah->arp_tpa);	} else {	    sprintf(pt_->buffer() + offset,		"------- [%s %d/%d %d/%d]",		ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		ah->arp_sha,		ah->arp_spa,		ah->arp_tha,		ah->arp_tpa);	}}voidCMUTrace::format_dsr(Packet *p, int offset){	hdr_sr *srh = hdr_sr::access(p);	if (pt_->tagged()) {	    sprintf(pt_->buffer() + offset,		    "-dsr:h %d -dsr:q %d -dsr:s %d -dsr:p %d -dsr:n %d "		    "-dsr:l %d -dsr:e {%d %d} -dsr:w %d -dsr:m %d -dsr:c %d "		    "-dsr:b {%d %d} ",		    srh->num_addrs(),		    srh->route_request(),		    srh->rtreq_seq(),		    srh->route_reply(),		    srh->rtreq_seq(),		    srh->route_reply_len(),		    srh->reply_addrs()[0].addr,		    srh->reply_addrs()[srh->route_reply_len()-1].addr,		    srh->route_error(),		    srh->num_route_errors(),		    srh->down_links()[srh->num_route_errors() - 1].tell_addr,		    srh->down_links()[srh->num_route_errors() - 1].from_addr,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产sm捆绑调教视频| proumb性欧美在线观看| 国产成人午夜片在线观看高清观看| 成人污污视频在线观看| 欧美日本在线一区| 欧美国产日韩一二三区| 视频在线在亚洲| 97se亚洲国产综合自在线观| 日韩精品一区二区三区四区| 亚洲精品视频在线看| 国产一区免费电影| 91精品欧美综合在线观看最新| 国产精品网站导航| 免费xxxx性欧美18vr| 欧美视频在线观看一区| 中文在线一区二区| 国产精品一区二区在线观看网站| 欧美日本一区二区三区四区| 亚洲欧美成aⅴ人在线观看| 国产乱色国产精品免费视频| 日韩亚洲欧美在线观看| 一区二区三区在线观看国产 | 日韩三级免费观看| 一区二区三区在线播| 北条麻妃国产九九精品视频| 久久久91精品国产一区二区三区| 免费观看一级特黄欧美大片| 欧美性感一区二区三区| 亚洲男人天堂av网| 色婷婷国产精品综合在线观看| 欧美经典三级视频一区二区三区| 国内精品视频一区二区三区八戒 | 欧美一卡在线观看| 午夜精品免费在线观看| 欧美日韩一区二区三区不卡| 一区二区三区蜜桃| 欧美在线你懂得| 亚洲综合一二三区| 欧美日韩视频不卡| 肉肉av福利一精品导航| 欧美卡1卡2卡| 免费成人在线观看| 精品成人私密视频| 成人黄色国产精品网站大全在线免费观看| 久久久精品黄色| 顶级嫩模精品视频在线看| 欧美激情艳妇裸体舞| 99视频精品在线| 亚洲自拍偷拍图区| 欧美另类高清zo欧美| 美日韩一级片在线观看| 精品欧美一区二区在线观看| 国产一区91精品张津瑜| 国产精品女主播av| 欧美在线观看一二区| 亚洲成人综合在线| 欧美成人bangbros| 成人国产免费视频| 亚洲国产精品一区二区www| 精品视频在线免费| 黄色日韩三级电影| 亚洲欧美一区二区三区国产精品 | 久久品道一品道久久精品| 国产精品69久久久久水密桃| 欧美国产日韩在线观看| 在线视频一区二区三| 奇米精品一区二区三区在线观看一| 久久综合久久综合久久综合| 91免费看`日韩一区二区| 亚洲成精国产精品女| 国产亚洲综合av| 欧美性受xxxx黑人xyx性爽| 老司机精品视频导航| 亚洲色图另类专区| 日韩欧美一二区| 9色porny自拍视频一区二区| 五月婷婷另类国产| 国产精品久久久久久亚洲伦 | 成人小视频在线| 亚洲最色的网站| 久久久久高清精品| 欧美视频在线一区二区三区 | 91亚洲国产成人精品一区二三| 天天爽夜夜爽夜夜爽精品视频| 国产视频视频一区| 在线播放视频一区| 91日韩在线专区| 国产精品1024| 国产乱淫av一区二区三区| 亚洲精品国产a久久久久久 | 免费成人在线网站| 亚洲精品国产一区二区精华液| 久久久久国产精品麻豆| 在线播放视频一区| 91在线视频免费91| 国产成人亚洲精品狼色在线| 麻豆极品一区二区三区| 亚洲成av人片观看| 国产精品久久久久一区二区三区共 | 久久av中文字幕片| 五月激情综合婷婷| 亚洲愉拍自拍另类高清精品| 国产精品视频一二三区| 精品久久久久香蕉网| 欧美日韩夫妻久久| 欧美系列亚洲系列| 日本韩国欧美三级| 91香蕉视频污在线| 91丨九色丨尤物| 白白色 亚洲乱淫| 成人性生交大片免费看视频在线| 久久精品国产亚洲aⅴ| 日韩高清在线观看| 日本成人在线一区| 美国精品在线观看| 久久99精品国产.久久久久| 强制捆绑调教一区二区| 日本最新不卡在线| 日韩av一区二区三区| 日韩成人免费电影| 奇米色777欧美一区二区| 奇米四色…亚洲| 国产精品1区2区3区| 成人丝袜高跟foot| 91网站在线观看视频| 91精品1区2区| 欧美在线影院一区二区| 7777精品伊人久久久大香线蕉的 | 99国产精品视频免费观看| 成人激情午夜影院| 色老汉av一区二区三区| 欧美日韩亚洲不卡| 欧美一二区视频| 久久久www成人免费无遮挡大片| 国产精品福利一区| 国产精品电影院| 亚洲6080在线| 久久精品99国产精品| 国产69精品一区二区亚洲孕妇| 成人av在线资源| 精品视频在线免费看| 日韩午夜三级在线| 国产精品久久久久久久久免费丝袜| 中文字幕五月欧美| 爽好久久久欧美精品| 国产乱子轮精品视频| 一本色道亚洲精品aⅴ| 欧美美女一区二区在线观看| 欧美va日韩va| 亚洲六月丁香色婷婷综合久久| 亚洲成va人在线观看| 国产盗摄视频一区二区三区| 99久久精品免费看国产免费软件| 欧美三级电影精品| 国产婷婷色一区二区三区四区 | 亚洲一区二区三区自拍| 日韩av不卡一区二区| 丁香六月综合激情| 欧美日韩精品欧美日韩精品| 亚洲精品一线二线三线| 尤物在线观看一区| 国产一区二区三区黄视频 | 国产激情视频一区二区三区欧美| 91在线porny国产在线看| 日韩一级二级三级精品视频| 中国色在线观看另类| 蜜臀av性久久久久蜜臀aⅴ四虎| 成人黄色免费短视频| 欧美sm极限捆绑bd| 亚洲自拍偷拍麻豆| 成人综合婷婷国产精品久久蜜臀 | 这里是久久伊人| 国产精品久久久久久久午夜片| 美女脱光内衣内裤视频久久网站 | 国产精品一区二区免费不卡| 91久久精品一区二区| 国产精品亲子伦对白| 激情亚洲综合在线| 欧美高清www午色夜在线视频| 日韩伦理免费电影| 国产成人在线免费| 日韩免费一区二区三区在线播放| 亚洲一区精品在线| 99国产精品国产精品久久| 久久久久久一二三区| 老司机精品视频一区二区三区| 欧美日韩精品一区二区三区四区| 最新高清无码专区| www..com久久爱| 日本一区二区在线不卡| 国产成人精品综合在线观看| 日韩午夜三级在线| 美女精品自拍一二三四| 欧美一区二区三区四区高清| 五月婷婷另类国产| 欧美精选一区二区| 视频一区在线播放| 777欧美精品| 日本网站在线观看一区二区三区| 欧美日韩精品免费观看视频|