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

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

?? antnet.cc

?? 基于 NS2 的 AntNet 源代碼
?? CC
?? 第 1 頁 / 共 2 頁
字號:
	nsaddr_t next = rtable_.calc_next(addr(), ah->pkt_dst(), parent);	// if next hop is this node or parent node, dead end, release packet	if(next == addr() || next == parent) {		Packet::free(p);		return;	}		ch->next_hop() = next;	// set next hop node address in common header	ih->saddr() = addr();	// set source address in ip header	ih->daddr() = next;	// set destination address in ip header	if(DEBUG)		fprintf(stdout,"forwarding antnet packet from %d source %d dest %d next hop %d\n", addr(), ah->pkt_src(), ah->pkt_dst(), ih->daddr());	// send packet to next hop node	target_->recv(p);}///////////////////////////////////////////////////////////////////////////// Method to create backward ant packet/// called when forward ant reaches destination node//////////////////////////////////////////////////////////////////////////void Antnet::create_backward_ant_pkt(Packet* p) {	struct hdr_ip* ih = HDR_IP(p);	struct hdr_cmn* ch = HDR_CMN(p);	struct hdr_ant_pkt* ah = HDR_ANT_PKT(p);		// swap source and destination address	nsaddr_t temp = ah->pkt_src();	ah->pkt_src() = ah->pkt_dst();	ah->pkt_dst() = temp;		// retrieve last second entry in memory (last entry is this node)	int index = ah->pkt_mem_size() - 2;	ch->direction() = hdr_cmn::UP;	// chnge direction to backward Ant	ch->ptype() = PT_ANT;	// set packet type as Ant	ch->next_hop() = ah->pkt_memory_[index].node_addr;	// next hop as determined from memory	ih->saddr() = addr();	// source address	ih->daddr() = ch->next_hop();	// destination address		if(DEBUG)		fprintf(stdout,"creating backward antnet packet from %d source %d dest %d next hop %d\n", addr(), ah->pkt_src(), ah->pkt_dst(), ih->daddr());	// send backward ant packet	target_->recv(p);}///////////////////////////////////////////////////////////////////////////////////// Method to send backward ant packet to next hop node as determined from memory/// called when agent recieves a backward ant//////////////////////////////////////////////////////////////////////////////////void Antnet::backward_ant_pkt(Packet* p) {	struct hdr_ip* ih = HDR_IP(p);	struct hdr_cmn* ch = HDR_CMN(p);	struct hdr_ant_pkt* ah = HDR_ANT_PKT(p);		// find node previous to this node in memory	int index;	for(int i = ah->pkt_mem_size()-1; i >= 0; i--) {		if(ah->pkt_memory_[i].node_addr == addr()) {			index = i-1;			break;		}	}	// next hop node determined from memory	ch->next_hop() = ah->pkt_memory_[index].node_addr;	ch->direction() = hdr_cmn::UP;	// backward ant	ch->ptype() = PT_ANT;	// packet type = Ant	ih->saddr() = addr();	// source address	ih->daddr() = ch->next_hop();	// destination addres		if(DEBUG)		fprintf(stdout,"forwarding backward antnet packet from %d source %d dest %d next hop %d\n", addr(), ah->pkt_src(), ah->pkt_dst(), ih->daddr());	// send backward ant to next hop	target_->recv(p);}////////////////////////////////////////////////////////////////// Method to return size of observation window///////////////////////////////////////////////////////////////int Antnet::get_win_size(nsaddr_t dest) {	int count = 0;	window_t::iterator iterWin = window_.find(dest);	triptime_t win_tt = (*iterWin).second;	triptime_t::iterator itertt;	for(itertt = win_tt.begin(); itertt != win_tt.end(); itertt++) {		count++;	}	return count;}/////////////////////////////////////////////////////////////////////////////// Method to update traffic model and calculate reinforcement factor (r)./// Presently, constant value of r is used./// Value of r can be set form tcl script./// Hence, traffic model is not used and this method is not called.///////////////////////////////////////////////////////////////////////////void Antnet::update_traffic(Packet* p) {	//update mean, variance, best.	struct traffic_matrix temp_traffic;	nsaddr_t dest, next;	double tt, oldtt;	double oldvar;	double varsigma = VARSIGMA;		struct hdr_ant_pkt* ah = HDR_ANT_PKT(p);	int i;	for(i=0; ah->pkt_memory_[i].node_addr != addr(); i++);	double initialtt = ah->pkt_memory_[i].trip_time;	i++;	next = ah->pkt_memory_[i].node_addr;		for(int index = i; index < ah->pkt_mem_size(); index++) {							dest = ah->pkt_memory_[index].node_addr;		tt = ah->pkt_memory_[index].trip_time - initialtt;				/* update sample window */		window_t::iterator iterWin = window_.find(dest);		if(iterWin != window_.end()) {	// destination entry exists, add to it in window			(*iterWin).second.push_back(tt);		}		else {	// destination entry does not exist, add new dest entry to window			triptime_t win_tt;			win_tt.push_back(tt);			window_[dest] = win_tt;		}	}		/* update traffic */	for(int index = i; index < ah->pkt_mem_size(); index++) {				dest = ah->pkt_memory_[index].node_addr;		tt = ah->pkt_memory_[index].trip_time - initialtt;		/* find best trip time from this node to dest */		window_t::iterator iterWin = window_.find(dest);		triptime_t win_tt = (*iterWin).second;		triptime_t::iterator itertt = win_tt.begin();		double mintt = (*itertt);		for(; itertt != win_tt.end(); itertt++) {			if((*itertt) < mintt)				mintt = (*itertt);		}				/* update traffic */		state_t::iterator iterFind = state_.find(dest);		if(iterFind != state_.end()) {			// update existing entry			oldtt = (*iterFind).second.mean_tt;			(*iterFind).second.mean_tt = oldtt + varsigma * (tt - oldtt);			oldvar = (*iterFind).second.var_tt;			(*iterFind).second.var_tt = oldvar*oldvar + varsigma * ((tt - oldtt)*(tt - oldtt) -  oldvar*oldvar);			(*iterFind).second.best_tt = mintt;		}		else {			// add map entry			temp_traffic.mean_tt = tt;			temp_traffic.var_tt = tt;			temp_traffic.best_tt = mintt;			state_[dest] = temp_traffic;		}	}		/* find r and update pheromone */	for(int index = i; index < ah->pkt_mem_size(); index++) {			dest = ah->pkt_memory_[index].node_addr;		tt = ah->pkt_memory_[index].trip_time - initialtt;					/* find r */		double W_best = state_[dest].best_tt;		double I_inf = W_best;		double mu = state_[dest].mean_tt;		double sigma = sqrt(state_[dest].var_tt);		int w = get_win_size(dest);		double I_sup = mu + zee * (sigma/sqrt(w));		if(I_sup == I_inf && I_inf == tt)			r = 0.0;		else			r = c1*(W_best/tt) + c2 * ((I_sup - I_inf) / ((I_sup - I_inf) + (tt - I_inf) ));				if(DEBUG) {			printf("r = %f\n", r);		}	}}///////////////////////////////////////////////////////////// Method to update routing table//////////////////////////////////////////////////////////void Antnet::update_table(Packet* p) {		nsaddr_t dest, next;			struct hdr_ant_pkt* ah = HDR_ANT_PKT(p);	// ant header		// read node visited next to this node from memory	// this is the nieghbor node for which routing table will be updated	int i;	for(i=0; ah->pkt_memory_[i].node_addr != addr(); i++);	i++;	next = ah->pkt_memory_[i].node_addr;		if(DEBUG) {		fprintf(stdout,"updating ph at %d\n", addr());		fprintf(stdout,"next: %d\n",next);	}			nsaddr_t node_addr = addr();	N = get_num_neighbors(node_addr);		// routing table is updated for all the destination nodes that are visited after the neighbor node	// update pheromone value corresponding to neighbor node and destination nodes visited thereafter	for(int index = i; index < ah->pkt_mem_size(); index++) {		// read destination nodef rom memory		dest = ah->pkt_memory_[index].node_addr;		// update pheromone valu fro neighbor node and this destination node		rtable_.update(dest, next);			}}///////////////////////////////////////////////////////////// Method to initialize routing table//////////////////////////////////////////////////////////void Antnet::initialize_rtable() {	//NUM_NODES = num_nodes_x_ * num_nodes_y_;	NUM_NODES = num_nodes_;		// set number of nodes in topology (read from tcl script)	r = r_factor_;	// set reinforcement factor (read from tcl script)	nsaddr_t node_addr = addr();	int num_nb = get_num_neighbors(node_addr);	Node *nd = nd->get_node_by_address(addr());	// add destination entry for each node in topology	for(int i = 0; i < NUM_NODES; i++) {		if(addr() != i) {			// read list of neighbors			neighbor_list_node* nb = nd->neighbor_list_;			while(nb != NULL) {				// read node id of neighbor node				int neighb = nb->nodeid;				// initialize equal pheromone value to all neighbor links				double phvalue = 1.0/num_nb;				// add routing table entry				rtable_.add_entry(i, neighb, phvalue);				// iterate in neighbor list				nb = nb->next;			}		}	}	FILE *fp = fopen(file_rtable,"w");	fclose(fp);}///////////////////////////////////////////////////////////// Method to print neighbors of a node//////////////////////////////////////////////////////////voidAntnet::print_neighbors() {	nsaddr_t node_addr = addr();	fprintf(stdout,"addr: %d\tra_addr:%d\n",addr(), ra_addr());	Node *n = n->get_node_by_address(node_addr);	fprintf(stdout,"node id: %d\tnode address: %d\n", n->nodeid(), n->address());	fprintf(stdout,"Neighbors:\n");	neighbor_list_node* nb = n->neighbor_list_;	do {		int neigh = nb->nodeid;		printf("%d\n",neigh);		nb = nb->next;	}while(nb != NULL);}///////////////////////////////////////////////////////////// Method to add neighbors of a node/// Parameters: addresses of two neighbor nodes (n1, n2)/// We assume duplex links/// - Add n1 to neighbor list of n2/// - Add n2 to neighbor list of n1//////////////////////////////////////////////////////////voidAntnet::add_Neighbor(Node *n1, Node *n2) {	n1->addNeighbor(n2);	n2->addNeighbor(n1);}///////////////////////////////////////////////////////////// Method to reset Ant timer//////////////////////////////////////////////////////////void Antnet::reset_ant_timer() {	ant_timer_.resched(timer_ant_);}///////////////////////////////////////////////////////////// Method to handle Ant timer expire event//////////////////////////////////////////////////////////void Ant_timer::expire(Event *e) {	// generate forward ant	agent_->send_ant_pkt();	// reschedule timer	agent_->reset_ant_timer();}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀av国产精品久久久久| 97久久久精品综合88久久| 久久99国内精品| 久久91精品国产91久久小草| 懂色中文一区二区在线播放| 95精品视频在线| 福利一区福利二区| 色狠狠桃花综合| 91精品国产综合久久蜜臀| 亚洲精品一区二区三区四区高清| 国产精品日韩成人| 国产亚洲一本大道中文在线| 亚洲日本韩国一区| 美女尤物国产一区| 精品一区二区综合| 91麻豆免费看| 久久久国际精品| 夜夜亚洲天天久久| 午夜国产不卡在线观看视频| 国产麻豆午夜三级精品| 欧美在线一二三四区| 久久久五月婷婷| 夜夜操天天操亚洲| 成人一级黄色片| 欧美一a一片一级一片| 中文字幕乱码久久午夜不卡 | 成人小视频在线| 欧美日韩国产另类一区| 精品国产乱码久久久久久免费| 亚洲人成精品久久久久| 国产精品亚洲专一区二区三区| 91成人国产精品| 中文字幕av资源一区| 蜜桃av一区二区| 国产成人免费视频精品含羞草妖精| 欧美日韩一区二区不卡| 国产精品嫩草影院com| 国产一区二区三区久久久| 777欧美精品| 亚洲一区视频在线观看视频| gogogo免费视频观看亚洲一| 久久先锋影音av鲁色资源网| 亚洲不卡av一区二区三区| 色哟哟亚洲精品| 国产精品国模大尺度视频| 日韩精品电影一区亚洲| 欧美日韩在线不卡| 婷婷综合另类小说色区| 欧美色窝79yyyycom| 亚洲欧洲日本在线| 国产成人av在线影院| 精品91自产拍在线观看一区| 久久精品国产亚洲aⅴ| 欧美日韩精品欧美日韩精品一综合| 亚洲欧洲精品天堂一级| 99视频国产精品| 亚洲高清视频的网址| 91麻豆精品国产91久久久资源速度 | 国产成a人亚洲精品| 1024国产精品| 欧美日韩高清不卡| 国产精品中文字幕日韩精品| 中文字幕在线不卡一区| 欧美日韩一级二级三级| 免费在线观看一区二区三区| 精品入口麻豆88视频| av在线这里只有精品| 天天操天天干天天综合网| 2023国产精品视频| 91成人免费电影| 国内精品视频一区二区三区八戒| 中文字幕字幕中文在线中不卡视频| 欧美日韩免费高清一区色橹橹| 久久99精品视频| 一区二区在线看| 久久综合狠狠综合久久综合88| 色偷偷久久人人79超碰人人澡| 日韩电影在线免费观看| 国产精品美女久久久久久久网站| 欧美久久久久久蜜桃| 成人不卡免费av| 麻豆精品在线看| 亚洲欧美一区二区不卡| 欧美成人一区二区三区片免费| 99久久国产综合精品麻豆| 另类小说欧美激情| 一区二区三区91| 国产精品国产三级国产aⅴ无密码| 欧美一级淫片007| 91激情在线视频| 成人免费观看av| 国内精品视频666| 日韩成人免费电影| 一区二区三区欧美在线观看| 国产欧美一二三区| 精品精品国产高清a毛片牛牛 | 国产夫妻精品视频| 美女一区二区三区| 五月激情丁香一区二区三区| 亚洲视频在线观看三级| 国产精品久久毛片av大全日韩| 精品久久一区二区三区| 日韩午夜在线影院| 7777精品伊人久久久大香线蕉超级流畅 | 在线视频观看一区| 99国产欧美久久久精品| 国产suv精品一区二区三区| 国产真实乱偷精品视频免| 日韩av午夜在线观看| 日精品一区二区| 日韩精品电影在线| 免费人成精品欧美精品| 秋霞午夜av一区二区三区| 日韩电影免费一区| 久久狠狠亚洲综合| voyeur盗摄精品| caoporm超碰国产精品| 成人一区二区三区中文字幕| 成人黄色国产精品网站大全在线免费观看| 激情深爱一区二区| 激情欧美日韩一区二区| 极品少妇xxxx精品少妇偷拍| 国产自产高清不卡| 国产成人免费视频一区| 成人在线视频一区| 99re热视频这里只精品| 在线影院国内精品| 在线播放91灌醉迷j高跟美女| 欧美少妇一区二区| 欧美二区三区的天堂| 精品精品国产高清a毛片牛牛| 国产亚洲欧美一区在线观看| 日本一区二区免费在线| 亚洲视频你懂的| 日韩国产精品久久| 国产精品性做久久久久久| 成人精品视频一区| 欧美日韩一区久久| 欧美精品一区二区三| 综合在线观看色| 无吗不卡中文字幕| 国产成人激情av| 色av成人天堂桃色av| 欧美不卡视频一区| 中文字幕亚洲一区二区av在线| 亚洲一区二区五区| 国产在线精品视频| 在线精品视频免费观看| 日韩视频在线一区二区| 国产精品久久777777| 午夜影院久久久| 成人黄色小视频| 欧美一区二区私人影院日本| 日本一区二区成人| 日韩高清一区二区| 99久久综合狠狠综合久久| 91 com成人网| 国产精品久久久爽爽爽麻豆色哟哟| 午夜激情一区二区三区| 成人精品视频一区| 日韩欧美一二三| 一级做a爱片久久| 国产a级毛片一区| 欧美一级一区二区| 亚洲欧洲精品一区二区精品久久久| 日韩精品欧美精品| 91精品办公室少妇高潮对白| 久久久精品国产免费观看同学| 午夜视频在线观看一区| 成人动漫一区二区三区| 精品国产成人系列| 日韩成人免费看| 欧美亚洲国产一区二区三区va | 一区二区三区四区高清精品免费观看| 看电影不卡的网站| 欧美日韩一区二区不卡| 中文字幕一区二区三区av| 国产一区二区在线电影| 欧美老肥妇做.爰bbww视频| 一区二区三区自拍| 成人免费黄色大片| 久久免费看少妇高潮| 日本欧美一区二区在线观看| 色噜噜狠狠色综合中国| 国产精品电影一区二区三区| 国产酒店精品激情| 欧美精品一区二区精品网| 亚洲第一精品在线| 欧美性感一区二区三区| 亚洲卡通欧美制服中文| 粉嫩高潮美女一区二区三区| 久久天天做天天爱综合色| 青青草国产成人av片免费| 欧美日韩免费电影| 亚洲第一精品在线| 7777女厕盗摄久久久| 日韩和欧美一区二区三区| 7799精品视频| 免费成人深夜小野草| 日韩精品一区二区三区中文不卡|