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

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

?? radio_link_agent.cpp

?? 各種視頻壓縮格式的網(wǎng)絡(luò)傳輸?shù)哪M信道分析
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
	      fprintf(stderr,"!!error in module %s: Retransmit buffer overflow\n",ModuleName);
	      exit(-1);
	    }
          else
	    {
	      Retransmit_Buffer[Retransmit_buffer_write_position].retransmission_frame = incoming_frame;
	      Retransmit_Buffer[Retransmit_buffer_write_position].retransmission_time = simulation_time + RETRANSMISSION_DELAY_FACTOR*transmission_time_interval;
	      Retransmit_buffer_length++;
	      Retransmit_buffer_write_position++;
	      if ( Retransmit_buffer_write_position == FRAME_BUFFER_SIZE )
		{
		  Retransmit_buffer_write_position = 0;   // wrap around circular retransmission_buffer
		}
	      //printf("retransmission scheduled at time %d \n",simulation_time);
	    }
	  return;
	}
      else
	{
	  // frame has been received correctly
          // determine the SDUs for which segments are contained in the frame, update the receive counters
          // if all segments of an SDU have been received now, either:
          //     - forward it to the upper layer agent in case of no erroneous segments
          //     - envoke the discard procedure of the upper layer agent, if there is at least one erroneous segment
          for (i=0;i<incoming_frame->number_of_contained_SDUs;i++)
            {
              identifier = incoming_frame->contained_SDU[i].identifier;
              SDU_Buffer[identifier].received_bytes_counter += incoming_frame->contained_SDU[i].size;
              SDU_Buffer[identifier].correct_bytes_counter += incoming_frame->contained_SDU[i].size;
              total_correct_payload_bits_counter += incoming_frame->contained_SDU[i].size*8;
              if ( SDU_Buffer[identifier].received_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
                {
	          // all segments of an SDU have already arrived
	          if ( SDU_Buffer[identifier].correct_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
	            {
  	              // all segments of an SDU are error-free
//   	              printf("sequence number of current frame: %d\n",incoming_frame->sequence_number);
//  	              printf("identifier %d\n",identifier);
//  	              printf("last segment size: %d\n",incoming_frame->contained_SDU[i].size);
 	              Upper_Layer_Agent->put_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	            }
                  else
	            {
	              // at least one segment is corrupt
	              Upper_Layer_Agent->discard_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	            }
	         // update SDU buffer
                 SDU_Buffer[identifier].upper_layer_PDU.internal_identifier = 0;
                 SDU_Buffer[identifier].upper_layer_PDU.size = 0;
                 SDU_Buffer[identifier].unsent_bytes = 0;
	         SDU_Buffer[identifier].received_bytes_counter = 0;
	         SDU_Buffer[identifier].correct_bytes_counter = 0;
	         SDU_buffer_total_length--;
               }
            }
	  free(incoming_frame);
	}
      break;

    case RETRANSMIT:
      // check frame error status
      if ( frame_error_indicator )
	{
	  // determine, if further retransmissions of this frame are still allowed
	  if ( fully_persistent_ARQ || (incoming_frame->number_of_retransmissions < max_number_of_retransmissions) )
	    {
	      // check for retransmission buffer overflow
  	      if ( Retransmit_buffer_length == FRAME_BUFFER_SIZE )
	        {
	          fprintf(stderr,"!!error in module %s: Retransmit buffer overflow\n",ModuleName);
	          exit(-1);
	        }
              else
	        {
	          Retransmit_Buffer[Retransmit_buffer_write_position].retransmission_frame = incoming_frame;
	          Retransmit_Buffer[Retransmit_buffer_write_position].retransmission_time = simulation_time + RETRANSMISSION_DELAY_FACTOR*transmission_time_interval;
	          Retransmit_buffer_length++;
	          Retransmit_buffer_write_position++;
	          if ( Retransmit_buffer_write_position == FRAME_BUFFER_SIZE )
		    {
		      Retransmit_buffer_write_position = 0;   // wrap around circular retransmission_buffer
		    }
		  //printf("retransmission rescheduled at time %d\n",simulation_time);
	        }
	      return;
	    }
	  else
            {
	      // frame cannot be retransmitted anymore
              // determine the SDUs for which segments are contained in the frame, update the receive counter
              // if all segments of an SDU have been received now, envoke the discard procedure of the upper layer agent,
	      // since there is at least one erroneous segment
              for (i=0;i<incoming_frame->number_of_contained_SDUs;i++)
                {
                  identifier = incoming_frame->contained_SDU[i].identifier;
                  SDU_Buffer[identifier].received_bytes_counter += incoming_frame->contained_SDU[i].size;
                  if ( SDU_Buffer[identifier].received_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
                    {
	              // at least one segment is corrupt
	              Upper_Layer_Agent->discard_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
 	              // update SDU buffer
                      SDU_Buffer[identifier].upper_layer_PDU.internal_identifier = 0;
                      SDU_Buffer[identifier].upper_layer_PDU.size = 0;
                      SDU_Buffer[identifier].unsent_bytes = 0;
	              SDU_Buffer[identifier].received_bytes_counter = 0;
	              SDU_Buffer[identifier].correct_bytes_counter = 0;
	              SDU_buffer_total_length--;
		    }
                }
	      free(incoming_frame);
	    } 
	}
      else
	{
	  // frame has been received correctly
          // determine the SDUs for which segments are contained in the frame, update the receive counters
          // if all segments of an SDU have been received now, either:
          //     - forward it to the upper layer agent in case of no erroneous segments
          //     - envoke the discard procedure of the upper layer agent, if there is at least one erroneous segment
          for (i=0;i<incoming_frame->number_of_contained_SDUs;i++)
            {
              identifier = incoming_frame->contained_SDU[i].identifier;
              SDU_Buffer[identifier].received_bytes_counter += incoming_frame->contained_SDU[i].size;
              SDU_Buffer[identifier].correct_bytes_counter += incoming_frame->contained_SDU[i].size;
              total_correct_payload_bits_counter += incoming_frame->contained_SDU[i].size*8;
              if ( SDU_Buffer[identifier].received_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
                {
	          // all segments of an SDU have already arrived
	          if ( SDU_Buffer[identifier].correct_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
	            {
  	              // all segments of an SDU are error-free
//   	              printf("sequence number of current frame: %d\n",incoming_frame->sequence_number);
//  	              printf("identifier %d\n",identifier);
//  	              printf("last segment size: %d\n",incoming_frame->contained_SDU[i].size);
 	              Upper_Layer_Agent->put_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	            }
                  else
	            {
	              // at least one segment is corrupt
	              Upper_Layer_Agent->discard_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	            }
	         // update SDU buffer
                 SDU_Buffer[identifier].upper_layer_PDU.internal_identifier = 0;
                 SDU_Buffer[identifier].upper_layer_PDU.size = 0;
                 SDU_Buffer[identifier].unsent_bytes = 0;
	         SDU_Buffer[identifier].received_bytes_counter = 0;
	         SDU_Buffer[identifier].correct_bytes_counter = 0;
	         SDU_buffer_total_length--;
               }
            }
	  free(incoming_frame);
	}
      break;

    case DUMMY:
      // check for frame sequence reordering
      if ( incoming_frame->sequence_number != receive_sequence_number )
        {
          fprintf(stderr,"!!error in module %s: frame reordering in acknowledged mode has occurred\n",ModuleName);
        }
      receive_sequence_number++;
      // discard all dummy frames
      free(incoming_frame);
      return;

    default:
      fprintf(stderr,"!!error in module %s: illegal frame type %d received\n",ModuleName,incoming_frame->frame_type);
      exit(-1);
    }
}



// reception procedure for unacknowledged mode operation 
void RADIO_LINK_AGENT::UM_receive_frame(RADIO_LINK_FRAME *incoming_frame, Boolean frame_error_indicator)
{
  int32 i, identifier;

  // check for frame sequence reordering
  if ( incoming_frame->sequence_number != receive_sequence_number )
    {
      fprintf(stderr,"!!error in module %s: frame reordering in unacknowledged mode has occurred\n",ModuleName);
    }

  // determine the type of the received frame
  switch ( incoming_frame->frame_type )
    {
    case DATA:
      receive_sequence_number++;
      break;
    case DUMMY:
      receive_sequence_number++;
      // discard all dummy frames
      free(incoming_frame);
      return;
    default:
      fprintf(stderr,"!!error in module %s: illegal frame type %d received\n",ModuleName,incoming_frame->frame_type);
      exit(-1);
    }

  // determine the SDUs for which segments are contained in the frame, update the receive counters depending on the
  // error indication for the radio link frame;
  // if all segments of an SDU have been received now, either:
  //     - forward it to the upper layer agent in case of no erroneous segments
  //     - envoke the discard procedure of the upper layer agent, if there is at least one erroneous segment
  for (i=0;i<incoming_frame->number_of_contained_SDUs;i++)
    {
      identifier = incoming_frame->contained_SDU[i].identifier;
      SDU_Buffer[identifier].received_bytes_counter += incoming_frame->contained_SDU[i].size;
      if ( !frame_error_indicator )
	{
	  SDU_Buffer[identifier].correct_bytes_counter += incoming_frame->contained_SDU[i].size;
          total_correct_payload_bits_counter += incoming_frame->contained_SDU[i].size*8;
	}
      if ( SDU_Buffer[identifier].received_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
        {
	  // all segments of an SDU have already arrived
	  if ( SDU_Buffer[identifier].correct_bytes_counter == SDU_Buffer[identifier].upper_layer_PDU.size )
	    {
	      // all segments of an SDU are error-free
// 	      printf("sequence number of current frame: %d\n",incoming_frame->sequence_number);
// 	      printf("identifier %d\n",identifier);
// 	      printf("last segment size: %d\n",incoming_frame->contained_SDU[i].size);
	      Upper_Layer_Agent->put_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	    }
          else
	    {
	      // at least one segment is corrupt
	      Upper_Layer_Agent->discard_PDU(simulation_time,&(SDU_Buffer[identifier].upper_layer_PDU));
	    }
	  // update SDU buffer
          SDU_Buffer[identifier].upper_layer_PDU.internal_identifier = 0;
          SDU_Buffer[identifier].upper_layer_PDU.size = 0;
          SDU_Buffer[identifier].unsent_bytes = 0;
	  SDU_Buffer[identifier].received_bytes_counter = 0;
	  SDU_Buffer[identifier].correct_bytes_counter = 0;
	  SDU_buffer_total_length--;
        }
    }

  free(incoming_frame);
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费观看在线观看| 亚洲欧美偷拍卡通变态| 久久99精品国产麻豆婷婷| 91丨porny丨在线| 久久久久国产成人精品亚洲午夜| 亚洲精品高清在线| 成人在线视频一区二区| 精品蜜桃在线看| 午夜精品一区二区三区免费视频 | 精品在线你懂的| 国产视频亚洲色图| 狠狠色2019综合网| 日韩欧美国产电影| 奇米精品一区二区三区四区| 欧美在线视频不卡| 成人免费在线视频观看| 国v精品久久久网| 欧美激情一区二区在线| 国产精品亚洲综合一区在线观看| 日韩女同互慰一区二区| 成人手机电影网| 亚洲午夜久久久久久久久电影网| 色综合久久久久久久久久久| 国产精品二三区| 91麻豆国产精品久久| 欧美a级理论片| 国产精品美女视频| www.亚洲在线| 亚洲人成影院在线观看| 欧美一区二区不卡视频| 另类小说一区二区三区| 日韩美一区二区三区| 北岛玲一区二区三区四区| 午夜欧美视频在线观看| 国产亚洲精品中文字幕| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 亚洲美女电影在线| 欧美成人a视频| 91影院在线免费观看| 美腿丝袜在线亚洲一区| 久久综合成人精品亚洲另类欧美 | 亚洲电影一级黄| 777精品伊人久久久久大香线蕉| 亚洲成人自拍偷拍| 国产三级精品三级在线专区| av亚洲精华国产精华精华| 日本不卡不码高清免费观看| 国产精品国产三级国产aⅴ无密码| 91精品国产综合久久精品麻豆| 成人av免费在线| 亚洲日本va午夜在线电影| 欧美中文字幕不卡| 大胆欧美人体老妇| 日韩精品电影在线观看| 精品国产91亚洲一区二区三区婷婷| 国产剧情一区二区三区| 午夜精品久久久久久久99水蜜桃| 中文字幕第一页久久| 911精品产国品一二三产区| 99久久免费国产| 同产精品九九九| 亚洲欧洲日本在线| 26uuu精品一区二区在线观看| 欧美性大战久久久久久久蜜臀| 青青草精品视频| 一区二区三区美女| 欧美电影免费观看高清完整版在| 色老头久久综合| 麻豆国产一区二区| 亚洲国产成人av好男人在线观看| 国产精品理论片在线观看| 久久天天做天天爱综合色| 在线播放日韩导航| 懂色av一区二区在线播放| 久久99久久精品欧美| 天天综合色天天| 一区二区激情视频| 亚洲欧洲国产日韩| 中文字幕的久久| 久久久久久久久久久久久久久99 | 国产成人综合精品三级| 亚洲美女精品一区| 中文字幕日本不卡| 国产精品嫩草影院av蜜臀| 久久久久88色偷偷免费| 精品入口麻豆88视频| 日韩一区二区视频在线观看| av高清久久久| 国产91富婆露脸刺激对白| 国产一区二区三区精品视频| 色激情天天射综合网| 高清在线观看日韩| 国产精品资源站在线| 紧缚奴在线一区二区三区| 久久精品噜噜噜成人88aⅴ| 奇米精品一区二区三区在线观看一| 亚洲成人激情自拍| 亚洲二区视频在线| 亚洲国产成人高清精品| 亚洲国产成人av网| 婷婷一区二区三区| 天天av天天翘天天综合网| 午夜精品福利在线| 亚洲123区在线观看| 亚洲3atv精品一区二区三区| 亚洲大片一区二区三区| 亚洲第一狼人社区| 丝袜亚洲另类欧美| 日本视频中文字幕一区二区三区| 成人免费小视频| 亚洲欧美一区二区久久| 一个色综合av| 亚洲不卡一区二区三区| 日本美女一区二区| 老司机免费视频一区二区| 精品一区二区三区在线观看 | 99热精品国产| 色综合 综合色| 欧美色区777第一页| 67194成人在线观看| 日韩午夜在线播放| 久久综合国产精品| 国产精品久久久久一区二区三区共| 亚洲欧洲av在线| 亚洲一区二区三区视频在线| 国产精品天美传媒沈樵| **性色生活片久久毛片| 亚洲午夜免费电影| 日本欧美肥老太交大片| 国产一区二区三区美女| 成人av电影在线| 欧美性生活久久| 欧美一卡二卡在线观看| 久久色中文字幕| 亚洲免费观看高清完整版在线| 亚洲高清不卡在线| 精品一区在线看| 成人h动漫精品一区二区| 在线视频一区二区免费| 欧美一区二区三区啪啪| 国产精品一区二区久久不卡| 成人福利视频在线看| 欧美色成人综合| 精品国产精品一区二区夜夜嗨| 国产喷白浆一区二区三区| 亚洲人成精品久久久久久| 婷婷综合久久一区二区三区| 国产综合成人久久大片91| 99精品欧美一区二区三区综合在线| 欧美日韩国产在线观看| 欧美日韩精品一区二区| 欧美精品一区二区久久久| 国产精品理伦片| 天堂在线亚洲视频| 国产xxx精品视频大全| 欧美性淫爽ww久久久久无| 26uuu另类欧美| 一区二区三区中文字幕| 韩国精品主播一区二区在线观看| 99久久夜色精品国产网站| 欧美精品1区2区3区| 中文字幕精品一区二区三区精品| 亚洲图片欧美综合| 国产美女精品在线| 欧美午夜精品一区| 国产日产欧美一区二区视频| 亚洲国产va精品久久久不卡综合| 国产精品自拍av| 欧美日本国产一区| 国产精品久久久久aaaa樱花| 日本免费在线视频不卡一不卡二| 成人激情午夜影院| 欧美一级免费观看| 亚洲日本乱码在线观看| 精品系列免费在线观看| 欧洲精品在线观看| 国产免费成人在线视频| 日本不卡的三区四区五区| jlzzjlzz亚洲日本少妇| 欧美xxxxx牲另类人与| 一区二区三区av电影| 国产传媒一区在线| 欧美一级欧美三级| 樱桃国产成人精品视频| 国产成人av影院| 日韩片之四级片| 一区二区成人在线视频| 丁香婷婷综合色啪| 日韩亚洲欧美综合| 一区二区三区精品视频| 国产99久久久国产精品潘金网站| 91精品国产综合久久精品app| 一区在线观看免费| 国产精品2024| 日韩欧美国产一区二区三区| 亚洲国产综合色| 91视频观看视频| 久久精品在这里| 久久91精品国产91久久小草| 欧美精品久久久久久久久老牛影院 |