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

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

?? datagenerator.cc

?? In this implementation of AntNet-3.0 one could get the behavior of both algorithms through a simple
?? CC
字號:
// -*- C++ -*-
// Copyright (C) 2003 Leherstuh f黵 Betrieb System/ Verteilte System, 
// Universitaet Dortmund 
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

// Author: Muddassar Farooq
// Informatik III, Universitaet Dortmund
// Germany

//-------------------------------------------------------------
// file: dataGenerator.cpp
//        (part of AntNet Routing Simulation)
//-------------------------------------------------------------


#include <stdio.h>
#include "dataGenerator.h"
#include "Messages_m.h"

Define_Module( dataGenerator );

void dataGenerator::initialize()
{
  
    numMessages = par("numMessages");
	myAddress = par("address");
	numStations = par("numStations");
	converganceTime = (double) par("converganceTime");
	sleepTime = par("sleepTimeAtStart");
	factor = par("factor");

	
	length = (double) par("messageLength");
	
	sessionSize = (double) par("sessionSize");

	i = 0;
	
	sessionId=0;

	beginWindow = 0.0;

	destWin.first = generateDestination(numStations);
	destWin.second = (int) RANDOMDESTINATION;

	const char *statModulePath = par("statModulePath");
	cModule *tmp1 = simulation.moduleByPath(statModulePath);
	sPtr= check_and_cast<statistics *> (tmp1);	
	
	debug = false;
	logResults = par("logResults");
	sleep = false;

	hotSpot = (int) par("hotSpot");

	hotSession = new cMessage("hotSession",SEND_HOT_SESSION_P);

	if( hotSpot != -1)
	{
		startTime = (double) par("startTime");
		endTime = (double) par("endTime");
		hotmpia = (double) par("hotmpia");
		scheduleAt( simTime() + startTime , hotSession);
	}
	
	cMessage* sendEventMsg=new cMessage("s", SEND_SCHEDULING_P);

	scheduleAt( simTime()+sleepTime, sendEventMsg);	   	    	  	  
    //cout<<"msia "<<msia<<endl;
}

void dataGenerator::handleMessage(cMessage* msg)
{
	// After Initialization one should stop sending the packets
	// before statisitcs is actually started

	int eventType = msg->kind();

	if(eventType == SEND_HOT_SESSION_P)
	{
		sendHotDestination();
	}

	else if(eventType >= SEND_SCHEDULING_P)
	{   
	  //1. create a session
		if(eventType==SEND_SCHEDULING_P)
		{
			creatSession();

			msia = (double) par("msiaTime");

			scheduleAt( simTime()+ msia, msg);	   	    	  	  
		}
		  //2. generate packet for a seesion
		else
		{
			
			int theSession=eventType-SEND_SCHEDULING_P;
			
			sendForSession(theSession);

			if( session[theSession].second == 0 )
			{
				
				stopSession( theSession, msg );
			}
			else	      
				scheduleSession( theSession, msg );
		}	  
	}

}

void dataGenerator::creatSession()
{
	sessionId++;

	int x;

	// set the selection mode with destination selection
	setDestinationSelectionMode();

	//create a packet to a random destination.
	if(destWin.second == (int) PREVIOUSDESTINATION )
	{
		x = getRandom(10) > 5 ? destWin.first : generateDestination(numStations);

	}
	else if (destWin.second == (int) RANDOMDESTINATION)
	{
		x = generateDestination(numStations);

		destWin.first = x;
	}

	pair<int,int> p(x,sessionSize);

	session[sessionId]=p;

	cMessage* sendEventMsg=new cMessage("s", SEND_SCHEDULING_P+sessionId);

	scheduleAt( simTime()+TIME_SMALLEST_UNIT_DOUBLE, sendEventMsg);	   	    	  	  
}


void dataGenerator::sendForSession(int id)
{  

	char msgname[70];
	i++;
	// select a destinatin randomly (but not the local station)
	// one ensures that we generate a destination address 0-4 and then increase it by 
	// one in case the address is local one or a variant of it

	int dest = session[id].first;

	sprintf(msgname, "Packet%d-Source%d-Destination %d", i, myAddress, dest);

	// create Packet

	length = (double) par("messageLength");

	samplePacket *msg = new samplePacket(msgname);

	msg->setSourceAddress(myAddress);
	msg->setKind( (int) NETLAYER_DATA_PACKET);
	msg->setDestAddress(dest);
	msg->setHasPayLoad(true);
	msg->setTimestamp();
	msg->setData("Here is some application dummy data");

	// send this packet on the gate out that is connected to the router at network layer, that
	// will take the routing decisions

	if(debug)
	{
		ev << "Generated application data to send: \"" << msgname << "\", "
			"length=" << length << "bytes, dest=" << dest << endl;
	}

	if(session[id].second >= length*BYTE )
	{
		msg->setLength( BYTE * length);

		session[id].second=session[id].second-BYTE * length;
	}
	else
	{
		msg->setLength(session[id].second);
		session[id].second=0;
	}

	if (simTime() >= converganceTime)
	{
		samplePacket *sendCopy = (samplePacket *) msg->dup();
		send(sendCopy, "toRouter");
		sPtr->incrTotalBitsGenerated();
		sPtr->incrBitsGenerated( msg->length() );
	}

	// now send the copy
	send(msg, "toAntGen");
	
}

void dataGenerator::scheduleSession(int id, cMessage* msg)
{
  mpia = (double) par("iaTime");
  scheduleAt( simTime()+ mpia, msg);	   	    	  	  
}

void dataGenerator::stopSession(int id, cMessage* msg)
{
  session.erase(id);
  delete msg;
}
int dataGenerator::getRandom(int i)
{
	return intuniform(0,i-1);
}

int dataGenerator::generateDestination(int k)
{
	int dest = intuniform(0,k - 2);
	if(dest >= myAddress) dest++;
	return dest;
}

void dataGenerator::setDestinationSelectionMode()
{
	endWindow = simTime();
	double window = endWindow - beginWindow;

	if( window >= (double) TIMEWINDOW)
	{
		// toggle the destination

		beginWindow = endWindow;

		if(destWin.second == (int) RANDOMDESTINATION)
		{
			destWin.second = (int) PREVIOUSDESTINATION;
		}
		else 
		{
			destWin.second = (int) RANDOMDESTINATION;

		}
	}

	// do not do anything as we need not to toggle our mode
}

void dataGenerator::sendHotDestination()
{
	char msgname[70];
	// select a destinatin randomly (but not the local station)
	// one ensures that we generate a destination address 0-4 and then increase it by 
	// one in case the address is local one or a variant of it

	int dest = hotSpot;
	sprintf(msgname, "Packet%d-Source%d-Destination %d", i, myAddress, dest);

	// create Packet

	length = (double) par("messageLength");

	samplePacket *msg = new samplePacket(msgname);

	msg->setSourceAddress(myAddress);
	msg->setKind( (int) NETLAYER_DATA_PACKET);
	msg->setDestAddress(dest);
	msg->setHasPayLoad(true);
	msg->setTimestamp();
	msg->setData("Here is some application dummy data");
	msg->setLength( BYTE * length);

	samplePacket *sendCopy = (samplePacket *) msg->dup();
	send(sendCopy, "toRouter");
	sPtr->incrTotalBitsGenerated();
	sPtr->incrBitsGenerated( msg->length() );

	// now send the copy
	send(msg, "toAntGen");

	if(simTime() < endTime)
	{
		hotmpia = (double) par("hotmpia");
		scheduleAt( simTime() + hotmpia , hotSession);
	}
}

void dataGenerator::finish()
{
    ev << "*** Module: " << fullPath() << "***" << endl;
    ev << "Stack allocated:      " << stackSize() << " bytes";
    ev << " (includes " << ev.extraStackForEnvir() << " bytes for environment)" << endl;
    ev << "Stack actually used: " << stackUsage() << " bytes" << endl;
	ev << "Total Messages Generated are  " << messageGenerated << endl;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本最新不卡在线| 91视频观看免费| 99精品热视频| 日韩一区二区免费在线电影| 国产喷白浆一区二区三区| 亚洲bdsm女犯bdsm网站| 成人性视频网站| 日韩精品在线看片z| 亚洲精品成人悠悠色影视| 国内成人免费视频| 欧美三级资源在线| 亚洲色图另类专区| 国产精品一二三区| 日韩欧美一二三区| 午夜影院在线观看欧美| 91免费版在线| 国产精品国模大尺度视频| 色偷偷久久人人79超碰人人澡 | 激情都市一区二区| 欧美日韩色综合| 亚洲精品欧美综合四区| 成人18视频日本| 国产精品系列在线| 国产精品一二三在| 亚洲精品一线二线三线| 奇米777欧美一区二区| 欧美色图在线观看| 一区二区久久久久久| 91免费观看视频在线| 亚洲丝袜制服诱惑| av亚洲精华国产精华精华| 国产性天天综合网| 国产精品一区二区久激情瑜伽| 26uuu欧美| 国产主播一区二区| 久久欧美一区二区| 国产精品亚洲一区二区三区妖精| 欧美一区二区三区视频免费 | 一本久久a久久免费精品不卡| 国产婷婷精品av在线| 国产麻豆精品theporn| 精品电影一区二区三区| 精品影院一区二区久久久| 日韩视频一区二区在线观看| 日本成人在线网站| 日韩美女一区二区三区四区| 精品在线播放午夜| 久久精品免视看| 成人性色生活片免费看爆迷你毛片| 国产欧美精品日韩区二区麻豆天美| 欧美一级日韩不卡播放免费| 天天综合色天天综合| 在线播放国产精品二区一二区四区| 午夜视频久久久久久| 日韩午夜精品电影| 国产成人午夜精品5599| 中文字幕在线不卡一区二区三区| 91啪亚洲精品| 日韩av电影免费观看高清完整版 | 日韩毛片精品高清免费| 色婷婷亚洲综合| 日本麻豆一区二区三区视频| 亚洲精品一区二区三区精华液 | 国产亚洲精品久| 日本久久一区二区三区| 首页欧美精品中文字幕| 久久久久成人黄色影片| 色婷婷av一区二区三区gif| 肉色丝袜一区二区| 国产午夜精品福利| 欧美性受极品xxxx喷水| 久久成人18免费观看| 精品一区二区三区不卡 | 中文在线免费一区三区高中清不卡| www.久久精品| 日本欧美韩国一区三区| 国产日韩av一区| 欧美福利电影网| 成人一区在线观看| 免费三级欧美电影| 成人免费一区二区三区视频| 欧美一区二区三区视频免费播放| 波多野结衣的一区二区三区| 偷偷要91色婷婷| 国产精品理论片在线观看| 欧美人体做爰大胆视频| 成人av动漫在线| 精品一二三四在线| 亚洲精品成人精品456| 欧美精品一区男女天堂| 91久久精品国产91性色tv| 久草精品在线观看| 亚洲国产你懂的| 亚洲同性gay激情无套| 精品国产乱子伦一区| 欧美日韩三级在线| 99久久久精品| 国产一区二区三区最好精华液| 亚洲综合色噜噜狠狠| 国产精品久久久久久久久久免费看| 亚洲一区二区三区在线| 中文一区一区三区高中清不卡| 欧美大肚乱孕交hd孕妇| 欧美视频一区二区三区在线观看| 91亚洲国产成人精品一区二三| 国产成人一级电影| 国内偷窥港台综合视频在线播放| 日韩国产精品久久| 亚洲综合男人的天堂| 成人免费在线视频观看| 中文成人av在线| 日本一区二区免费在线| xnxx国产精品| 久久久久97国产精华液好用吗| 精品国产污污免费网站入口| 91精品国产综合久久婷婷香蕉 | 在线观看日韩毛片| 91视频一区二区三区| 成人免费va视频| proumb性欧美在线观看| 成人av一区二区三区| 成人福利视频在线| av高清不卡在线| 色综合天天综合在线视频| 99久久久无码国产精品| 99re视频精品| 欧美午夜精品一区| 在线不卡欧美精品一区二区三区| 制服视频三区第一页精品| 69堂国产成人免费视频| 日韩亚洲欧美中文三级| 欧美xfplay| 国产精品毛片大码女人| 亚洲天堂精品在线观看| 一区二区三区高清| 日本不卡视频一二三区| 国产一区91精品张津瑜| 成人免费观看男女羞羞视频| 色综合久久中文字幕综合网| 欧美三级一区二区| 精品久久人人做人人爰| 国产午夜精品在线观看| 亚洲人成精品久久久久| 日韩综合在线视频| 国产精品小仙女| 欧美性生活久久| 精品粉嫩aⅴ一区二区三区四区| 日本一区二区成人在线| 一个色在线综合| 久久97超碰色| 色素色在线综合| 日韩欧美国产综合| 日韩毛片在线免费观看| 日本va欧美va精品发布| 丁香婷婷深情五月亚洲| 欧美日韩精品欧美日韩精品一 | 天堂va蜜桃一区二区三区| 美国十次综合导航| 91网上在线视频| 日韩一区二区在线看| 中文字幕一区二区三区乱码在线| 三级一区在线视频先锋| 成人高清免费在线播放| 51午夜精品国产| 亚洲精品免费电影| 国产精品系列在线观看| 欧美视频一区在线| 亚洲国产精华液网站w| 日韩中文欧美在线| 91视频你懂的| 欧美经典一区二区三区| 成人手机电影网| 日韩欧美黄色影院| 亚洲免费观看视频| 国产精品一区二区男女羞羞无遮挡| 欧美特级限制片免费在线观看| 久久久国产精华| 免费在线观看成人| 91激情在线视频| 国产精品剧情在线亚洲| 精一区二区三区| 555www色欧美视频| 亚洲精品国产视频| 成人毛片视频在线观看| 日韩精品中文字幕一区| 手机精品视频在线观看| 色欧美乱欧美15图片| 国产欧美日韩综合精品一区二区| 日韩影院免费视频| 欧美亚洲尤物久久| 亚洲激情六月丁香| 91蝌蚪porny| 亚洲欧洲精品一区二区精品久久久 | 国模冰冰炮一区二区| 欧美一区二区三区婷婷月色| 香蕉久久夜色精品国产使用方法| 91在线一区二区三区| 久久精品一区二区三区不卡| 精品一区二区综合| 久久亚洲精品国产精品紫薇|