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

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

?? sim_ashr.cc

?? 無限傳感器網絡的模擬環境
?? CC
?? 第 1 頁 / 共 2 頁
字號:
  {    sent+=nodes[i].app.SentPackets;    recv+=nodes[i].app.RecvPackets;    delay+=nodes[i].app.TotalDelay;  }  printf( "APP -- pkts sent: %10d, rcvd: %10d, success rate: %.3f, "	  "end-to-end delay: %.3f\n", sent, recv, (double) recv/sent,	  delay/recv);  app_recv=recv;  delay=0.0;  samples=0;  hop=0.0;  recv_data=0;  for( j = HCArraySize-1; j >= 0; j--)    hopCounts[j] = 0;  for( int i = NumT2Slots-1; i >= 0; i--)  {    T2Colls[i] = T2PktsSent[i] = 0;    T2PktsRcvd[0][i] = T2PktsRcvd[1][i] = 0;  }  for( int i = NumT3Slots-1; i >= 0; i--)  {    T3Colls[i] = T3PktsSent[i] = 0;    T3PktsRcvd[0][i] = T3PktsRcvd[1][i] = 0;  }  dropPkts = T1PktsSent = 0;  T1Colls = IgnColls = 0;  T1PktsRcvd[0] = T1PktsRcvd[1] = 0;  T4PktsRcvd[0] = T4PktsRcvd[1] = 0;  CanceledPktsRcvd[0] = CanceledPktsRcvd[1] = 0;  BadAddrPktsRcvd[0] = BadAddrPktsRcvd[1] = 0;  WrongHopPktsRcvd[0] = WrongHopPktsRcvd[1] = 0;  for( sent = recv = i = 0; i < NumNodes; i++)  {    sent += nodes[i].net.SentPackets;    recv += nodes[i].net.RecvPackets;    hop += nodes[i].net.TotalHop;    delay += nodes[i].net.TotalDelay;    samples += nodes[i].net.TotalSamples;    recv_data += nodes[i].net.RecvDataPackets;    dropPkts += nodes[i].net.DropPkts;    T1PktsSent += nodes[i].net.T1PktsSent;    T1Colls += nodes[i].net.T1Collisions;    IgnColls += nodes[i].net.IgnoreCollisions;    t3AbnormalPktsSent += nodes[i].net.T3AbnormalPktsSent;    T1PktsRcvd[0] += nodes[i].net.T1PktsRcvd[0];    T1PktsRcvd[1] += nodes[i].net.T1PktsRcvd[1];    T4PktsRcvd[0] += nodes[i].net.T4PktsRcvd[0];    T4PktsRcvd[1] += nodes[i].net.T4PktsRcvd[1];    CanceledPktsRcvd[0] += nodes[i].net.CanceledPktsRcvd[0];    CanceledPktsRcvd[1] += nodes[i].net.CanceledPktsRcvd[1];    BadAddrPktsRcvd[0] += nodes[i].net.BadAddrPktsRcvd[0];    BadAddrPktsRcvd[1] += nodes[i].net.BadAddrPktsRcvd[1];    WrongHopPktsRcvd[0] += nodes[i].net.WrongHopPktsRcvd[0];    WrongHopPktsRcvd[1] += nodes[i].net.WrongHopPktsRcvd[1];    for( j = HCArraySize-1; j >= 0; j--)      hopCounts[j] += nodes[i].net.HopCounts[j];    for( int j = NumT2Slots-1; j >= 0; j--)    {      T2PktsSent[j] += nodes[i].net.T2PktsSent[j];      T2Colls[j] += nodes[i].net.T2Collisions[j];      T2PktsRcvd[0][j] += nodes[i].net.T2PktsRcvd[0][j];      T2PktsRcvd[1][j] += nodes[i].net.T2PktsRcvd[1][j];    }    for( int j = NumT3Slots-1; j >= 0; j--)    {      T3PktsSent[j] += nodes[i].net.T3PktsSent[j];      T3Colls[j] += nodes[i].net.T3Collisions[j];      T3PktsRcvd[0][j] += nodes[i].net.T3PktsRcvd[0][j];      T3PktsRcvd[1][j] += nodes[i].net.T3PktsRcvd[1][j];    }  }  printf( "NET -- pkts sent: %10d, rcvd: %10d, avg hop: %.3f, "	  "backoff delay: %.3f\n", sent, recv, hop/recv_data, delay/samples);  printf( "NET -- hop counts [");  for( i = 0; i < HCArraySize; i++)    printf( " %4d", hopCounts[ i]);  printf( "]\nNET -- T2 Sent [");  for( i = 0; i < NumT2Slots; i++)    printf( " %4d", T2PktsSent[ i]);  printf( "]\nNET -- T3 Sent [");  for( i = 0; i < NumT3Slots; i++)    printf( " %4d", T3PktsSent[ i]);  printf( "]\nNET -- T1 Sent %4d; Dropped Packets %4d; T3 Abnormal %4d\n"	  "NET -- T2 Collisions [", T1PktsSent, dropPkts, t3AbnormalPktsSent);  for( i = 0; i < NumT2Slots; i++)    printf( " %4d", T2Colls[ i]);  printf( "]\nNET -- T3 Collisions [");  for( i = 0; i < NumT3Slots; i++)    printf( " %4d", T3Colls[ i]);  printf( "]\nNET -- T1 Collisions %4d; Ignored Collisions %4d\n", T1Colls,	  IgnColls);  numCollisions = 0;		//mwl  for( sent = recv = i = 0; i < NumNodes; i++)  {    sent += nodes[i].mac.SentPackets;    recv += nodes[i].mac.RecvPackets;    numCollisions += nodes[i].mac.rrCollisions;  }  printf( "NET -- T1 Rcvd [ %4d %4d]\n", T1PktsRcvd[0], T1PktsRcvd[1]);  for( j = 0; j < 2; j++)  {    printf( "NET -- T2 Rcvd[%s] [", nodes[0].net.pktRcvdName[j]);    for( i = 0; i < NumT2Slots; i++)      printf( " %4d", T2PktsRcvd[j][i]);    printf( "]\n");  }  for( j = 0; j < 2; j++)  {    printf( "NET -- T3 Rcvd[%s] [", nodes[0].net.pktRcvdName[j]);    for( i = 0; i < NumT3Slots; i++)      printf( " %4d", T3PktsRcvd[j][i]);    printf( "]\n");  }  printf( "NET -- T4 Rcvd [ %4d %4d]\n", T4PktsRcvd[0], T4PktsRcvd[1]);  printf( "NET -- Cancel[ %4d %4d]; Bad[ %4d %4d]; WrongHop[ %4d %4d]\n",	  CanceledPktsRcvd[0], CanceledPktsRcvd[1], BadAddrPktsRcvd[0],	  BadAddrPktsRcvd[1], WrongHopPktsRcvd[0], WrongHopPktsRcvd[1]);  printf( "MAC -- pkts sent: %10d, rcvd: %10d, # collisions %10d\n", sent,	  recv, numCollisions);  {    double	ie = 0, re = 0;    for( i=0; i < NumNodes; i++)    {      ie += nodes[i].battery.InitialEnergy;      re += nodes[i].battery.RemainingEnergy;    }    printf( "BAT -- Initial: %f, Remaining: %f\n", ie, re);  }//mwl  for( i = 0; i < NumNodes; i++)//mwl    printf( "ea %3d: 4 hc %2d; 69 hc %2d\n", i, nodes[i].net.mwlGetHC( 4), nodes[i].net.mwlGetHC( 69));  return;}/************************************************************************ * The simulation has a @Setup()@ function which must be called before * the simulation can be run.  The reason we don't do this in the constructor * is that we must assign values to * its parameters after the simulation component has been instantiated.  * The @Setup()@ function, which you can rename to anything you like,  * first maps component * parameters to corresponding simulation parameters (for instance, assign * the value of the simulation parameter @interval@ to the component parameter * @source.interval@).  It then connects pairs of inport and outports.  ************************************************************************/void RoutingSim :: Setup(){  int i,j;    /************************************************************************ * The size of the sensor node array must be set using @SetSize()@ before * the array can ever be used. ************************************************************************/      nodes.SetSize(NumNodes);  for(i=0;i<NumNodes;i++)  {    nodes[i].MaxX=MaxX;    nodes[i].MaxY=MaxY;    nodes[i].MyEtherAddr=i;    nodes[i].ID=i;    nodes[i].Setup( TXPower); // don't forget to call this function for each sensor node  }    /************************************************************************ * Set the slot width, transition time. * This is done only once since they are static (class wide) for the SSRv02 * class. But, this must be done after @nodes@ has been initialized. The [] * operator is overloaded and throws an exception if nodes hasn't been * initialized. ************************************************************************/  nodes[0].net.setSlotWidth( SlotWidth);  nodes[0].net.setTransitionTime( TransitionTime);  nodes[0].net.setNumT2Slots( NumT2Slots);  nodes[0].net.setNumT3Slots( NumT3Slots);      /************************************************************************ * The channel component needs to know the total number of sensor nodes. * It also needs to know the value of @CSThresh@ since it won't sent packets * to nodes that can't detect them.  @RXThresh@ is also needed to produce * the same receive power in those nodes that can just correctly receive packets * when using different propagation models. *  * In this example @FreeSpace@ is used. ************************************************************************/  channel.NumNodes=NumNodes;  channel.DumpPackets=false;  channel.CSThresh=nodes[0].phy.CSThresh;  channel.RXThresh=nodes[0].phy.RXThresh;  channel.PropagationModel=channel.FreeSpace;  channel.WaveLength=speed_of_light/nodes[0].phy.Frequency;  channel.X=MaxX;  channel.Y=MaxY;  channel.GridEnabled=false;  channel.MaxTXPower=nodes[0].phy.TXPower;    /************************************************************************ * The channel component also has a @Setup()@ function which is to  * set the size of its outport array. ************************************************************************/  channel.Setup();  for(i=0;i<NumNodes;i++)  {    connect nodes[i].to_channel_packet,channel.from_phy;    connect nodes[i].to_channel_pos,channel.pos_in;    connect channel.to_phy[i],nodes[i].from_channel ;  }/************************************************************************ * This is to create communication pairs. ************************************************************************/  int src,dst;  for(i=0;i<NumSourceNodes;i++)  {    for(j=0;j<NumConnections;j++)    {      double dx,dy;      do      {	src=Random(NumNodes);	dst=Random(NumNodes);	dx=nodes[src].mob.InitX-nodes[dst].mob.InitX;	dy=nodes[src].mob.InitY-nodes[dst].mob.InitY;      }      while( src == dst || (dx*dx+dy*dy) < MaxX * MaxY / 4);       nodes[src].SrcOrDst=true;      nodes[dst].SrcOrDst=true;      nodes[src].app.Connections.push_back(	make_triple(ether_addr_t(dst),Random(PacketSize)+PacketSize/2,		    Random(Interval)+Interval/2));      nodes[dst].app.Connections.push_back(	make_triple(ether_addr_t(src),Random(PacketSize)+PacketSize/2,		    Random(Interval)+Interval/2));     }  }  for(i=0;i<NumNodes;i++)  {    nodes[i].pm.BeginTime=0.0;    nodes[i].pm.FinishTime=StopTime;    nodes[i].pm.ActiveCycle=100.0;    nodes[i].pm.ActivePercent=ActivePercent;    if(nodes[i].SrcOrDst)    {      nodes[i].pm.ActivePercent=1.0;    }    //nodes[i].mob.InitX=(i/20)*MaxX/20;    //nodes[i].mob.InitY=(i%20)*MaxY/20;  }  /*nodes[260].app.Connections.push_back(make_triple(ether_addr_t(273),1000,5.34));    nodes[29].app.Connections.push_back(make_triple(ether_addr_t(235),1000,1.0203));  */}/************************************************************************ * @<h2>Running the Simulation</h2>@ * To run the simulation, first we need to create a * simulation object from the simulation component class.  * Several default simulation parameters must be determined.  * @StopTime@ denotes the ending time of the simulation. * @Seed@ is the initial seed of the random number generator used * by the simulation. * * To compile the program, enter: * * ../../bin/cxx sim_rr.cc * g++ -Wall -o sim_rr sim_rr.cxx *  * To run the simulation, simply type in: * * sim_rr <flags> * mwl ************************************************************************/int main(  int		argc,  char		*argv[]){  RoutingSim	sim;  int		seed;  bool		doDecrement, proceed = true;  const char	*UnsupportedOption = "***** Unsupported option %s *****\n";  seed = (int) time( 0);  for( argv++; argc > 1; argc--, argv++)  {    if( *argv[0] != '-')    {      printf( UnsupportedOption, *argv);      proceed = false;      continue;    }    doDecrement = true;    switch( (*argv)[1])    {      case '2':		// number of slots in T2	sim.NumT2Slots = atoi( argv[1]);	if( sim.NumT2Slots > MaxT2Slots)	{	  printf( "Simulation supports only %d slots in T2.\n", MaxT2Slots);	  proceed = false;	}	break;      case '3':		// number of slots in T3	sim.NumT3Slots = atoi( argv[1]);	if( sim.NumT3Slots > MaxT3Slots)	{	  printf( "Simulation supports only %d slots in T3.\n", MaxT3Slots);	  proceed = false;	}	break;      case 'a':		// percent active	sim.ActivePercent = atof( argv[1]);	if( sim.ActivePercent > 1.0)	{	  printf( "***** Warning: Nodes active more than 100%% of the time *****\n");	  proceed = false;	}	break;      case 'e':		// simulation end time	sim.StopTime = atof( argv[1]);	break;      case 'i':		// interval	sim.Interval = atof( argv[1]);	break;      case 'n':		// number of nodes	sim.NumNodes = atoi( argv[1]);	break;      case 'p':		// antenna transmission power in watts	sim.TXPower = atof( argv[1]);	break;      case 'r':		// random number seed	seed = atoi( argv[1]);	break;      case 's':		// number of sources	sim.NumSourceNodes = atoi( argv[1]);	break;      case 't':		// transition timer	sim.TransitionTime = atof( argv[1]);	break;      case 'w':		// slot width	sim.SlotWidth = atof( argv[1]);	break;      case 'x':		// x (and y) dimension	sim.MaxX = sim.MaxY = atof( argv[1]);	break;      default:	doDecrement = false;	proceed = false;	printf( UnsupportedOption, *argv);	break;    }    if( doDecrement == true)    {      argv++;      argc--;    }  }  if( proceed == false)    return 1;  if( sim.NumSourceNodes == 0)    sim.NumSourceNodes = sim.NumNodes / 10;  sim.Seed = seed;/*** Display parameters that define the simulation.*/  printf( "Fault Tolerant SSR:\t");#ifdef	RR_ACK  printf( "RR_ACK defined\n");#else	//RR_ACK  printf( "RR_ACK not defined\n");#endif	//RR_ACK  printf( "Random number seed:\t%d\nStopTime:\t\t%.0f\n"	  "Number of Nodes:\t%d\nPercent Active:\t\t%5.2f\n"	  "Terrain:\t\t%.0f by %.0f\nNumber of Sources:\t%d\n"	  "Packet Size:\t\t%d\nInterval:\t\t%f\nAntenna Power:\t\t%f\n"	  "Slot Width:\t\t%f\nTransition Time:\t%f\n# slots in T2\t\t%d\n"	  "# slots in T3\t\t%d\n", seed, sim.StopTime, sim.NumNodes,	  sim.ActivePercent * 100.0, sim.MaxX, sim.MaxY, sim.NumSourceNodes,	  sim.PacketSize, sim.Interval, sim.TXPower, sim.SlotWidth,	  sim.TransitionTime, sim.NumT2Slots, sim.NumT3Slots);  sim.Setup();  sim.Run();  return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品久久久久久动态图 | 欧美性猛交xxxxxx富婆| 亚洲成人资源在线| 国产精品美女一区二区三区| 久久综合久久综合久久综合| 欧美日韩精品一区二区| 在线观看国产日韩| 欧美影院一区二区三区| 久久久99精品久久| 国产精品欧美综合在线| 免费成人在线观看视频| 日本在线不卡一区| 麻豆高清免费国产一区| 国产精品一二三四五| 国产黄色精品网站| jiyouzz国产精品久久| 99麻豆久久久国产精品免费 | 波多野结衣在线一区| 国产xxx精品视频大全| 色伊人久久综合中文字幕| 欧美专区日韩专区| 亚洲视频一区在线观看| 亚洲第一主播视频| 欧美性大战久久久久久久蜜臀 | 精品国产污污免费网站入口| 日本一区二区综合亚洲| 亚洲在线观看免费| 精品一区二区三区在线播放视频| 欧美性感一区二区三区| 亚洲国产成人porn| 国产精品1区2区| 久久综合久色欧美综合狠狠| 国产专区欧美精品| 91丨porny丨首页| 欧美日韩国产精品自在自线| 亚洲一二三四区| 欧美色网一区二区| 三级不卡在线观看| 91在线视频官网| 精品国产乱码久久久久久图片 | 日韩欧美国产一区在线观看| 欧美一区二区免费观在线| 久久综合九色综合欧美亚洲| 激情小说亚洲一区| xnxx国产精品| 国产成人精品午夜视频免费| 日本一区二区成人在线| 日日夜夜一区二区| 日韩一区二区影院| 亚洲国产精品一区二区www | 色哟哟一区二区在线观看 | 国产女主播视频一区二区| 国产成人av在线影院| 国产精品高清亚洲| 久久99精品视频| 国产精品欧美极品| 欧美综合欧美视频| 精品一二三四区| 亚洲人成精品久久久久久| 精品一区二区三区影院在线午夜| 久久久精品免费免费| 日本中文字幕一区| 国产日韩欧美a| 一本一本久久a久久精品综合麻豆| 亚洲一级二级在线| 久久久精品欧美丰满| 色婷婷综合久久久| 久久成人久久爱| 精品少妇一区二区三区在线视频| 性欧美疯狂xxxxbbbb| 久久久91精品国产一区二区精品| 91丨九色丨黑人外教| 日本美女一区二区三区| 中文字幕在线播放不卡一区| 成人在线综合网| 中文成人av在线| 欧美精品123区| 日本vs亚洲vs韩国一区三区二区| 国产日韩v精品一区二区| 欧美四级电影网| 岛国一区二区在线观看| 午夜精品一区二区三区三上悠亚| 欧美日韩国产高清一区| 成人毛片在线观看| 美日韩一区二区| 亚洲欧美激情视频在线观看一区二区三区 | 一本大道久久a久久精品综合| 日韩精品乱码免费| 亚洲女与黑人做爰| 久久亚洲欧美国产精品乐播| 欧美精品1区2区3区| 91看片淫黄大片一级在线观看| 久久精品国产99| 视频一区在线播放| 又紧又大又爽精品一区二区| 欧美亚男人的天堂| 成人国产精品免费观看动漫 | 91精品国模一区二区三区| 日韩成人午夜精品| 亚洲免费观看高清完整版在线观看 | 欧美激情一区二区三区四区| 欧美成人猛片aaaaaaa| 欧美人体做爰大胆视频| 91国偷自产一区二区开放时间| 一个色综合av| 欧美成人三级在线| 91精品国产色综合久久不卡蜜臀| 日本韩国欧美一区| 不卡欧美aaaaa| 成a人片国产精品| 成人国产免费视频| 91色视频在线| 在线免费观看日本一区| 91国内精品野花午夜精品| 色素色在线综合| 欧美亚洲高清一区二区三区不卡| 一本色道久久综合精品竹菊| 91麻豆成人久久精品二区三区| 99久久er热在这里只有精品15 | 欧美久久久久免费| 欧美性大战久久久久久久蜜臀| 在线观看不卡视频| 欧美日韩一区二区欧美激情| 国产一区二区三区观看| 一区二区三区久久久| 一区二区三区影院| 香港成人在线视频| 秋霞成人午夜伦在线观看| 蜜桃av一区二区在线观看| 国产在线国偷精品免费看| 成人免费高清在线观看| 色综合视频在线观看| 欧美色图激情小说| 欧美va天堂va视频va在线| 精品国产凹凸成av人导航| 国产日韩欧美亚洲| 一区二区三区四区蜜桃| 丝袜美腿亚洲色图| 国产乱码精品一区二区三| av一二三不卡影片| 制服.丝袜.亚洲.另类.中文| 26uuu国产在线精品一区二区| 国产精品妹子av| 日韩影院精彩在线| 丁香六月综合激情| 欧美亚洲综合久久| 久久久亚洲精华液精华液精华液| 中文字幕视频一区| 日本成人在线网站| 成人黄色软件下载| 欧美一区二区三区在线| 国产精品人妖ts系列视频| 亚欧色一区w666天堂| 国产成人精品aa毛片| 欧美三级日本三级少妇99| 久久色成人在线| 亚洲一区二区欧美| 丁香婷婷深情五月亚洲| 欧美巨大另类极品videosbest| 国产午夜精品久久久久久免费视 | 国产精品看片你懂得| 石原莉奈在线亚洲三区| 成人午夜激情片| 欧美一级在线观看| 亚洲美女精品一区| 国产成人在线视频网站| 欧美另类z0zxhd电影| 亚洲国产精品高清| 久久不见久久见中文字幕免费| 91香蕉视频在线| 国产日本欧洲亚洲| 人人超碰91尤物精品国产| 91在线视频免费观看| 国产偷国产偷精品高清尤物| 午夜精品福利一区二区蜜股av| 成人福利电影精品一区二区在线观看| 3d成人h动漫网站入口| 亚洲精品国产无天堂网2021| 成人一区二区三区| 精品福利一区二区三区免费视频| 亚洲午夜三级在线| 一本到不卡精品视频在线观看 | 成人听书哪个软件好| 日韩无一区二区| 五月婷婷色综合| 在线中文字幕一区| 最新久久zyz资源站| 粉嫩av一区二区三区| 久久久久亚洲蜜桃| 狠狠色2019综合网| 日韩久久久精品| 美女视频黄频大全不卡视频在线播放| 91福利社在线观看| 一区二区三区久久| 欧美午夜精品一区| 亚洲综合激情小说| 欧美性极品少妇| 午夜精彩视频在线观看不卡| 欧美日韩精品高清| 天天爽夜夜爽夜夜爽精品视频|