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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? setdest.cc

?? 一款用來進(jìn)行網(wǎng)絡(luò)模擬的軟件
?? CC
?? 第 1 頁 / 共 2 頁
字號(hào):
/* * * The original code of setdest was included in ns-2.1b8a. * This file is the modified version by J. Yoon <jkyoon@eecs.umich.edu>, *	Department of EECS, University of Michigan, Ann Arbor.  * * (1) Input parameters *	<Original version> *		=> -M maximum speed (minimum speed is zero as a default) *		=> -p pause time (constant)  *		=> -n number of nodes *		=> -x x dimension of space *		=> -y y dimension of space * *	<Modified version> *		=> -s speed type (uniform, normal) *		=> -m minimum speed > 0  *		=> -M maximum speed *		=> -P pause type (constant, uniform) *		=> -p pause time (a median if uniform is chosen) *		=> -n number of nodes *		=> -x x dimension of space *		=> -y y dimension of space * * (2) In case of modified version, the steady-state speed distribution is applied to  *	the first trip to eliminate any speed decay. If pause is not zero, the first  *	trip could be either a move or a pause depending on the probabilty that the  *	first trip is a pause. After the first trip regardless of whether it is  *	a move or a pause, all subsequent speeds are determined from the given speed  *	distribution (e.g., uniform or normal). * * (3) Refer to and use scenario-generating scripts (make-scen.csh for original version,  *	make-scen-steadystate.csh for modified version). * * */extern "C" {#include <assert.h>#include <fcntl.h>#include <math.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <sys/time.h>#include <sys/types.h>#include <sys/uio.h>#include <unistd.h>#if !defined(sun)#include <err.h>#endif};#include "../../../tools/rng.h"#include "setdest.h"// #define		DEBUG#define		SANITY_CHECKS//#define		SHOW_SYMMETRIC_PAIRS#define GOD_FORMAT	"$ns_ at %.12f \"$god_ set-dist %d %d %d\"\n"#define GOD_FORMAT2	"$god_ set-dist %d %d %d\n"#define NODE_FORMAT	"$ns_ at %.12f \"$node_(%d) setdest %.12f %.12f %.12f\"\n"#define NODE_FORMAT2	"$node_(%d) setdest %.12f %.12f %.12f\n"#define NODE_FORMAT3	"$node_(%d) set %c_ %.12f\n"#define		RTG_INFINITY	0x00ffffff#ifndef min#define		min(x,y)	((x) < (y) ? (x) : (y))#define		max(x,y)	((x) > (y) ? (x) : (y))#endif#define		ROUND_ERROR	1e-9#ifndef PI#define 	PI	 	3.1415926	#endifstatic int count = 0;/* ======================================================================   Function Prototypes   ====================================================================== */void		usage(char**);void		init(void);double		uniform(void);void		dumpall(void);void		ComputeW(void);void		floyd_warshall(void);void		show_diffs(void);void		show_routes(void);void		show_counters(void);/* ======================================================================   Global Variables   ====================================================================== */const double	RANGE = 250.0;	// transmitter range in metersdouble		TIME = 0.0;			// my clock;double		MAXTIME = 0.0;		// duration of simulationdouble		MAXX = 0.0;			// width of spacedouble		MAXY = 0.0;			// height of spacedouble		PAUSE = 0.0;		// pause timedouble		MAXSPEED = 0.0;		// max speeddouble		MINSPEED = 0.0;		// min speed double		SS_AVGSPEED = 0.0;	// steady-state avg speed double 		KAPPA = 0.0;		// normalizing constant double 		MEAN = 0.0;			// mean for normal speeddouble 		SIGMA = 0.0;		// std for normal speeddouble 		EXP_1_V = 0.0;		// expactation of 1/Vdouble 		EXP_R = 0.0;		// expectation of travel distance Rdouble 		PDFMAX = 0.0;		// max of pdf for rejection techniqueu_int32_t	SPEEDTYPE = 1;		// speed type (default = uniform)u_int32_t	PAUSETYPE = 1;		// pause type (default = constant)u_int32_t	VERSION = 1;		// setdest version (default = original by CMU) u_int32_t	NODES = 0;			// number of nodesu_int32_t	RouteChangeCount = 0;u_int32_t	LinkChangeCount = 0;u_int32_t	DestUnreachableCount = 0;Node		*NodeList = 0;u_int32_t	*D1 = 0;u_int32_t	*D2 = 0;/* ======================================================================   Random Number Generation   ====================================================================== */#define M		2147483647L#define INVERSE_M	((double)4.656612875e-10)char random_state[32];RNG *rng;doubleuniform(){        count++;        return rng->uniform_double() ;}/* ======================================================================   Misc Functions...   ====================================================================== *//* compute the expectation of travel distance E[R] in a rectangle */voidcompute_EXP_R(){	#define csc(x) 		(1.0/sin(x))		// csc function	#define sec(x)		(1.0/cos(x))		// sec function	#define sin2(x)		(sin(x)*sin(x))		// sin^2	#define sin3(x)		(sin2(x)*sin(x))	// sin^3	#define cos2(x)		(cos(x)*cos(x))		// cos^2	#define cos3(x)		(cos2(x)*cos(x))	// cos^3	double x = MAXX, y = MAXY;			// max x and max y	double x2 = x*x, x3 = x*x*x;			// x^2 and x^3	double y2 = y*y, y3 = y*y*y;			// y^2 and y^3	double term1 = sin(atan2(y,x)) / 2.0 / cos2(atan2(y,x));	double term2 = 0.5 * log( sec(atan2(y,x)) + y/x );	double term3 = -1.0 * x3 / y2 / 60.0 / cos3(atan2(y,x)) + 1.0/60.0 * x3 / y2;	double term4 = (term1 + term2) * x2 / 12.0 / y + term3;	double term5 = -1.0 * cos(atan2(y,x)) / 2.0 / sin2(atan2(y,x));	double term6 = 0.5 * log( csc(atan2(y,x)) - x/y );	double term7 = -1.0 * y3 / x2 / 60.0 / sin3(atan2(y,x)) + 1.0/60.0 * y3 / x2;	double term8 = -1.0 * (term5 + term6) * y2 / 12.0 / x + term7;	EXP_R = (4 * (term4 + term8)); 			// E[R]}voidusage(char **argv){	fprintf(stderr, "\nusage:\n");	fprintf(stderr,		"\n<original 1999 CMU version (version 1)>\n %s\t-v <1> -n <nodes> -p <pause time> -M <max speed>\n",		argv[0]);	fprintf(stderr,		"\t\t-t <simulation time> -x <max X> -y <max Y>\n");	fprintf(stderr,		"\nOR\n<modified 2003 U.Michigan version (version 2)>\n %s\t-v <2> -n <nodes> -s <speed type> -m <min speed> -M <max speed>\n",		argv[0]);	fprintf(stderr,		"\t\t-t <simulation time> -P <pause type> -p <pause time> -x <max X> -y <max Y>\n");	fprintf(stderr,		"\t\t(Refer to the script files make-scen.csh and make-scen-steadystate.csh for detail.) \n\n");}voidinit(){	/*	 * Initialized the Random Number Generation	 */	/* 	This part of init() is commented out and is replaced by more	portable RNG (random number generator class of ns) functions.		struct timeval tp;	int fd, seed, bytes;	if((fd = open("/dev/random", O_RDONLY)) < 0) {		perror("open");		exit(1);	}	if((bytes = read(fd, random_state, sizeof(random_state))) < 0) {		perror("read");		exit(1);	}	close(fd);	fprintf(stderr, "*** read %d bytes from /dev/random\n", bytes);	if(bytes != sizeof(random_state)) {	  fprintf(stderr,"Not enough randomness. Reading `.rand_state'\n");	  if((fd = open(".rand_state", O_RDONLY)) < 0) {	    perror("open .rand_state");	    exit(1);	  }	  if((bytes = read(fd, random_state, sizeof(random_state))) < 0) {	    perror("reading .rand_state");	    exit(1);	  }	  close(fd);	}         if(gettimeofday(&tp, 0) < 0) {		perror("gettimeofday");		exit(1);	}	seed = (tp.tv_sec  >> 12 ) ^ tp.tv_usec;        (void) initstate(seed, random_state, bytes & 0xf8);*/	/*	 * Allocate memory for globals	 */	NodeList = new Node[NODES];	if(NodeList == 0) {		perror("new");		exit(1);	}	D1 = new u_int32_t[NODES * NODES];	if(D1 == 0) {		perror("new");		exit(1);	}	memset(D1, '\xff', sizeof(u_int32_t) * NODES * NODES);	D2 = new u_int32_t[NODES * NODES];	if(D2 == 0) {		perror("new");		exit(1);	}	memset(D2, '\xff', sizeof(u_int32_t) * NODES * NODES);}extern "C" char *optarg;intmain(int argc, char **argv){	char ch;	while ((ch = getopt(argc, argv, "v:n:s:m:M:t:P:p:x:y:i:o:")) != EOF) {       		switch (ch) { 				case 'v':		  VERSION = atoi(optarg);		  break;		case 'n':		  NODES = atoi(optarg);		  break;		case 's':			SPEEDTYPE = atoi(optarg);				break;		case 'm':			MINSPEED = atof(optarg);				break;		case 'M':			MAXSPEED = atof(optarg);			break;		case 't':			MAXTIME = atof(optarg);			break;		case 'P':			PAUSETYPE = atoi(optarg);				break;		case 'p':			PAUSE = atof(optarg);			break;		case 'x':			MAXX = atof(optarg);			break;		case 'y':			MAXY = atof(optarg);			break;		default:			usage(argv);			exit(1);		}	}	if(MAXX == 0.0 || MAXY == 0.0 || NODES == 0 || MAXTIME == 0.0) {		usage(argv);		exit(1);	}		/* specify the version */	if (VERSION != 1 && VERSION != 2) {	  printf("Please specify the setdest version you want to use. For original 1999 CMU version use 1; For modified 2003 U.Michigan version use 2\n");	  exit(1);	}	if (VERSION == 2 && MINSPEED <= 0) {	  usage(argv);	  exit(1);	} else if (VERSION == 1 && MINSPEED > 0) {	  usage(argv);	  exit(1);	}	// The more portable solution for random number generation	rng = new RNG;	rng->set_seed(RNG::HEURISTIC_SEED_SOURCE); 	/**************************************************************************************** 	 * Steady-state avg speed and distribution depending on the initial distirbutions given	 ****************************************************************************************/		/* original setdest */		if (VERSION == 1) {			fprintf(stdout, "#\n# nodes: %d, pause: %.2f, max speed: %.2f, max x: %.2f, max y: %.2f\n#\n",			NODES, PAUSE, MAXSPEED, MAXX, MAXY);	}		/* modified version */	else if (VERSION == 2) {		/* compute the expectation of travel distance in a rectangle */		compute_EXP_R();		/* uniform speed from min to max */		if (SPEEDTYPE == 1) {			EXP_1_V = log(MAXSPEED/MINSPEED) / (MAXSPEED - MINSPEED);	// E[1/V]			SS_AVGSPEED = EXP_R / (EXP_1_V*EXP_R + PAUSE);				// steady-state average speed			PDFMAX = 1/MINSPEED*EXP_R / (EXP_1_V*EXP_R + PAUSE) / (MAXSPEED-MINSPEED);	// max of pdf for rejection technique		}				/* normal speed clipped from min to max */		else if (SPEEDTYPE == 2) {			int bin_no = 10000;									// the number of bins for summation			double delta = (MAXSPEED - MINSPEED)/bin_no; 		// width of each bin 			int i;			double acc_k, acc_e, square, temp_v;			MEAN = (MAXSPEED + MINSPEED)/2.0;					// means for normal dist.			SIGMA = (MAXSPEED - MINSPEED)/4.0;					// std for normal dist.			/* computing a normalizing constant KAPPA, E[1/V], and pdf max */			KAPPA = 0.0;			EXP_1_V = 0.0;			PDFMAX = 0.0;			/* numerical integrals */			for (i=0; i<bin_no; ++i) {				temp_v = MINSPEED + i*delta;		// ith v from min speed				square = (temp_v - MEAN)*(temp_v - MEAN)/SIGMA/SIGMA;				acc_k = 1.0/sqrt(2.0*PI*SIGMA*SIGMA)*exp(-0.5*square);				KAPPA += (acc_k*delta);				// summing up the area of rectangle				acc_e = 1.0/temp_v/sqrt(2.0*PI*SIGMA*SIGMA)*exp(-0.5*square);				EXP_1_V += (acc_e*delta);			// summing up for the denominator of pdf					/* find a max of pdf */				if (PDFMAX < acc_e) PDFMAX = acc_e;			}			EXP_1_V /= KAPPA;						// normalizing			SS_AVGSPEED = EXP_R / (EXP_1_V*EXP_R + PAUSE);			// steady-state average speed			PDFMAX = EXP_R*PDFMAX/KAPPA / (EXP_1_V*EXP_R + PAUSE);	// max of pdf for rejection technique		}		/* other types of speed for future use */		else			;			fprintf(stdout, "#\n# nodes: %d, speed type: %d, min speed: %.2f, max speed: %.2f\n# avg speed: %.2f, pause type: %d, pause: %.2f, max x: %.2f, max y: %.2f\n#\n",			NODES , SPEEDTYPE, MINSPEED, MAXSPEED, SS_AVGSPEED, PAUSETYPE, PAUSE, MAXX, MAXY);	} 		init();	while(TIME <= MAXTIME) {		double nexttime = 0.0;		u_int32_t i;		for(i = 0; i < NODES; i++) {			NodeList[i].Update();		}		for(i = 0; i < NODES; i++) {			NodeList[i].UpdateNeighbors();		}		for(i = 0; i < NODES; i++) {			Node *n = &NodeList[i];				if(n->time_transition > 0.0) {				if(nexttime == 0.0)					nexttime = n->time_transition;				else					nexttime = min(nexttime, n->time_transition);			}			if(n->time_arrival > 0.0) {				if(nexttime == 0.0)					nexttime = n->time_arrival;				else					nexttime = min(nexttime, n->time_arrival);			}		}		floyd_warshall();#ifdef DEBUG		show_routes();#endif	 	show_diffs();#ifdef DEBUG		dumpall();#endif		assert(nexttime > TIME + ROUND_ERROR);		TIME = nexttime;	}	show_counters();	int of;	if ((of = open(".rand_state",O_WRONLY | O_TRUNC | O_CREAT, 0777)) < 0) {	  fprintf(stderr, "open rand state\n");	  exit(-1);	  }	for (unsigned int i = 0; i < sizeof(random_state); i++)          random_state[i] = 0xff & (int) (uniform() * 256);	if (write(of,random_state, sizeof(random_state)) < 0) {	  fprintf(stderr, "writing rand state\n");	  exit(-1);	  }	close(of);}/* ======================================================================   Node Class Functions   ====================================================================== */u_int32_t Node::NodeIndex = 0;Node::Node(){	u_int32_t i;	index = NodeIndex++;	//if(index == 0)	//	return;	route_changes = 0;    link_changes = 0;    /*******************************************************************************	 * Determine if the first trip is a pause or a move with the steady-state pdf     *******************************************************************************/	/* original version */	if (VERSION == 1) {			time_arrival = TIME + PAUSE;			// constant pause	}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜精品一区二区| 欧美美女视频在线观看| 91精品国产免费久久综合| 中文字幕字幕中文在线中不卡视频| 久久精品国产亚洲一区二区三区| 欧美色区777第一页| 韩国v欧美v亚洲v日本v| 欧美蜜桃一区二区三区| 亚洲黄色免费电影| 91美女精品福利| 成人欧美一区二区三区在线播放| 国产成人精品免费| 欧美精品一区二区高清在线观看 | 精品国产凹凸成av人网站| 亚洲福中文字幕伊人影院| av亚洲精华国产精华精华| 国产精品激情偷乱一区二区∴| 国产毛片精品视频| 久久久一区二区| 国产美女精品人人做人人爽| 精品国产亚洲一区二区三区在线观看 | 91麻豆高清视频| 国产目拍亚洲精品99久久精品| 国产成+人+日韩+欧美+亚洲| 久久嫩草精品久久久久| 国产伦精品一区二区三区在线观看| 精品久久一二三区| 国产91丝袜在线18| 中文字幕在线不卡一区| 在线观看视频一区| 亚洲成人中文在线| 欧美人牲a欧美精品| 日韩影视精彩在线| 精品国产一区二区三区不卡| 国产一区二区电影| 国产精品福利一区| 在线中文字幕不卡| 午夜精品成人在线视频| 日韩一级片在线播放| 精品无人区卡一卡二卡三乱码免费卡| 国产视频一区在线播放| 91麻豆国产在线观看| 天堂资源在线中文精品| 精品欧美一区二区三区精品久久| 国产精品88888| 亚洲日本丝袜连裤袜办公室| 91麻豆精品国产91| 国产一区二区看久久| 中文字幕一区二| 欧美色中文字幕| 另类小说色综合网站| 久久理论电影网| 91啪亚洲精品| 久久av中文字幕片| 亚洲精品成人悠悠色影视| 日韩一区二区中文字幕| 97精品久久久久中文字幕| 视频一区视频二区中文| 国产精品视频一区二区三区不卡| 欧美日韩久久一区| 国产成人综合网| 一区二区在线观看免费| 久久亚洲一级片| 欧美色综合天天久久综合精品| 国产精品一区二区在线观看不卡| 一区二区三区国产精华| 欧美综合色免费| 狠狠狠色丁香婷婷综合久久五月| 欧美高清在线视频| 99精品视频免费在线观看| 亚洲国产日韩精品| 日韩免费观看高清完整版| 成人丝袜高跟foot| 亚洲va欧美va天堂v国产综合| 精品久久久久香蕉网| 99久久99久久精品免费看蜜桃| 免费成人美女在线观看.| 国产精品欧美精品| 26uuu精品一区二区三区四区在线| 欧美午夜电影一区| 成人av动漫在线| 亚洲妇熟xx妇色黄| 国产精品女人毛片| 日韩欧美久久一区| 色噜噜夜夜夜综合网| 久久99在线观看| 亚洲一区二区在线免费观看视频| 久久综合久久综合九色| 91麻豆swag| 国产在线乱码一区二区三区| 婷婷亚洲久悠悠色悠在线播放| 综合在线观看色| 久久久久久99久久久精品网站| 91精品国产欧美一区二区| 在线免费av一区| 91丨porny丨国产| 成人午夜激情片| 免费成人av在线播放| 亚洲综合一二三区| 国产欧美精品一区aⅴ影院| 日韩亚洲欧美在线| 在线看国产一区二区| 91美女在线观看| 国产成人超碰人人澡人人澡| 毛片一区二区三区| 午夜一区二区三区在线观看| 亚洲欧洲日韩av| 国产精品久久一级| 亚洲特级片在线| 亚洲精品你懂的| 亚洲一区二区在线播放相泽| 亚洲成a人片综合在线| 亚洲一区二区三区爽爽爽爽爽| 亚洲精品乱码久久久久久黑人| 一区二区在线电影| 亚洲一区在线播放| 性做久久久久久| 日本亚洲一区二区| 韩国欧美国产1区| 国产一区二区三区最好精华液| 国产一区二区三区美女| 成人影视亚洲图片在线| 91污片在线观看| 欧美日精品一区视频| 欧美一区二区三区四区在线观看| 日韩一区二区在线看| www激情久久| 亚洲欧洲精品一区二区三区不卡| 亚洲精品综合在线| 日韩综合一区二区| 韩国v欧美v日本v亚洲v| 成人开心网精品视频| 在线精品视频免费播放| 91精品国产综合久久福利软件| 欧美一区二区视频网站| 欧美一区二区三区日韩| 欧美不卡一区二区三区四区| 精品盗摄一区二区三区| 国产亚洲福利社区一区| 日韩一区在线免费观看| 日韩高清一区二区| 国产一区二区三区不卡在线观看| 不卡大黄网站免费看| 欧美日韩中字一区| 精品国产乱码久久久久久夜甘婷婷| 国产精品午夜春色av| 五月综合激情日本mⅴ| 亚洲高清视频中文字幕| 日韩成人免费电影| 狠狠色伊人亚洲综合成人| 成人精品视频一区二区三区| 欧美亚洲一区二区三区四区| 精品国产乱子伦一区| 亚洲欧美另类综合偷拍| 日本人妖一区二区| 成人h版在线观看| 欧美高清激情brazzers| 国产精品免费看片| 午夜在线电影亚洲一区| 成人app网站| 精品久久一区二区三区| 亚洲一区二区三区影院| 国产乱妇无码大片在线观看| 国产高清在线精品| 欧美性猛交xxxxxxxx| 精品理论电影在线| 亚洲国产aⅴ天堂久久| 国产成人免费av在线| 91精品国产综合久久久久久久久久| 国产日韩成人精品| 亚洲欧洲99久久| 国产一区二区在线影院| 7777精品伊人久久久大香线蕉的 | 日本久久一区二区| 久久亚洲欧美国产精品乐播 | 日韩一区二区不卡| 一区二区视频在线看| 国产成人免费在线观看| 日韩一区二区三区在线观看| 亚洲激情图片小说视频| 成人精品一区二区三区四区| 精品国免费一区二区三区| 亚洲国产一区二区三区青草影视| 波多野结衣一区二区三区 | 国产成人自拍在线| 日韩欧美国产一区二区三区 | 欧美图片一区二区三区| 中文字幕免费一区| 国产乱人伦偷精品视频免下载| 51久久夜色精品国产麻豆| 亚洲成人免费影院| 色综合久久久久久久久久久| 国产精品久久久久桃色tv| 国产成人在线网站| 国产亚洲一本大道中文在线| 久久99国产精品久久99 | 欧美变态tickle挠乳网站| 日韩av电影一区| 欧美一区二区性放荡片| 日本欧美一区二区|