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

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

?? sim_ashr.cc

?? 大名鼎鼎的傳感器網(wǎng)絡(luò)仿真實驗室平臺SENSE
?? 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;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产91九色蝌蚪| 国产成人自拍在线| 奇米四色…亚洲| 国产电影精品久久禁18| 91麻豆免费观看| 日韩女优av电影在线观看| 国产精品乱码久久久久久| 亚洲综合图片区| 久久国产福利国产秒拍| 91在线精品秘密一区二区| 欧美男女性生活在线直播观看| 91精品国产综合久久久久| 欧美极品xxx| 日韩成人av影视| 成人激情av网| 精品美女一区二区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 亚洲电影第三页| 国产99一区视频免费| 欧美日韩国产另类不卡| 国产女人18毛片水真多成人如厕| 亚洲大片在线观看| 成人一道本在线| 欧美成人精品高清在线播放 | 国产一区二区三区免费观看| 91蜜桃在线免费视频| 精品久久久久久综合日本欧美| 亚洲欧美视频在线观看| 国产一区二区在线电影| 欧美亚洲综合一区| 中文在线一区二区 | 久久午夜免费电影| 亚洲成年人网站在线观看| 国产 欧美在线| 日韩免费视频一区二区| 亚洲狠狠爱一区二区三区| www..com久久爱| 久久久夜色精品亚洲| 日本欧美一区二区三区乱码| 91搞黄在线观看| 中文字幕一区二区日韩精品绯色| 麻豆91免费看| 欧美美女一区二区三区| 亚洲女厕所小便bbb| 国产成人小视频| 精品国产免费视频| 蜜桃av一区二区三区电影| 欧美性三三影院| 亚洲激情欧美激情| 日韩免费观看2025年上映的电影| 亚洲图片有声小说| 91高清视频免费看| 亚洲精品国产精品乱码不99| 不卡的av在线播放| 国产精品青草综合久久久久99| 激情偷乱视频一区二区三区| 欧美一区二区在线看| 亚洲成人www| 欧美在线一区二区| 亚洲免费观看视频| 91社区在线播放| 亚洲天堂福利av| 99久久精品一区| 中文字幕一区免费在线观看| 成人激情文学综合网| 国产日产欧美一区| 懂色av噜噜一区二区三区av| 国产亚洲午夜高清国产拍精品 | 久久久国产综合精品女国产盗摄| 精品在线播放午夜| 欧美成人vps| 国产伦精品一区二区三区免费| 精品国产髙清在线看国产毛片 | 久久久精品国产免费观看同学| 国产在线精品免费| 久久久久青草大香线综合精品| 狠狠久久亚洲欧美| 久久久亚洲高清| 国产高清在线观看免费不卡| 久久精品网站免费观看| 国产激情偷乱视频一区二区三区| 久久精品网站免费观看| kk眼镜猥琐国模调教系列一区二区| 亚洲日本va午夜在线电影| 色菇凉天天综合网| 亚洲va韩国va欧美va精品 | 免费欧美在线视频| 精品成人在线观看| 成人综合在线观看| 亚洲精品成人天堂一二三| 欧美中文字幕一区二区三区亚洲| 亚洲mv在线观看| 欧美v国产在线一区二区三区| 国产酒店精品激情| 综合欧美亚洲日本| 欧美日韩一区二区三区高清| 伦理电影国产精品| 国产精品午夜电影| 欧美色图免费看| 九九久久精品视频| 中文字幕免费观看一区| 色婷婷久久久久swag精品| 天天综合色天天综合| 久久一日本道色综合| 不卡的av电影| 午夜精品久久久久久久99樱桃| 日韩一区二区精品葵司在线 | 琪琪一区二区三区| 久久综合久色欧美综合狠狠| 国产91对白在线观看九色| 亚洲午夜免费电影| 久久亚洲春色中文字幕久久久| 一本大道久久a久久精二百| 秋霞成人午夜伦在线观看| 国产午夜精品福利| 在线观看日韩电影| 国内成人精品2018免费看| 亚洲三级在线免费观看| 欧美一区二区在线视频| 99久久精品免费看| 日韩av中文在线观看| 国产精品第13页| 欧美一区二区日韩| 99re热这里只有精品免费视频| 午夜精品123| 国产精品麻豆视频| 欧美一级片在线| 91在线国产福利| 激情综合色播五月| 亚洲综合色丁香婷婷六月图片| 欧美电影免费观看高清完整版在| 99国产精品久久久| 看电影不卡的网站| 亚洲一区二区在线观看视频 | 粉嫩av一区二区三区在线播放| 亚洲综合久久av| 国产精品乱码久久久久久| 日韩精品一区二区三区在线| 在线观看日产精品| 丁香网亚洲国际| 麻豆传媒一区二区三区| 亚洲国产一区二区视频| 国产精品久久综合| 精品剧情在线观看| 在线不卡中文字幕播放| 色综合天天综合网天天看片| 国产精品一区二区果冻传媒| 秋霞午夜鲁丝一区二区老狼| 曰韩精品一区二区| 中文av一区二区| 久久久久久久精| 日韩精品一区二区三区swag| 欧美性受xxxx黑人xyx性爽| 波多野结衣视频一区| 精品无人区卡一卡二卡三乱码免费卡 | 亚洲大片精品永久免费| 亚洲图片你懂的| 国产欧美一区视频| 欧美大片顶级少妇| 91麻豆精品91久久久久久清纯| 欧美午夜精品免费| 日本道精品一区二区三区| 91色|porny| 不卡的电视剧免费网站有什么| 国产精品一区不卡| 国产在线麻豆精品观看| 七七婷婷婷婷精品国产| 天天综合网天天综合色| 亚洲国产cao| 亚洲亚洲人成综合网络| 樱花草国产18久久久久| 亚洲情趣在线观看| 亚洲品质自拍视频| 国产一区二区电影| 国产一区二区美女诱惑| 精品一区二区免费视频| 韩国中文字幕2020精品| 黑人巨大精品欧美黑白配亚洲| 寂寞少妇一区二区三区| 蜜桃视频在线观看一区二区| 奇米色777欧美一区二区| 日本不卡在线视频| 另类专区欧美蜜桃臀第一页| 久久国产精品99精品国产| 狠狠色2019综合网| 国产精品一区二区视频| 成人天堂资源www在线| 成人性生交大合| 99精品黄色片免费大全| 9久草视频在线视频精品| 色综合天天综合给合国产| 在线观看精品一区| 欧美日韩极品在线观看一区| 欧美一区二区三区人| 欧美精品一区二区在线观看| 久久久久一区二区三区四区| 国产精品网曝门| 伊人性伊人情综合网| 婷婷激情综合网| 激情综合网av|