stddev.pl
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:2k
源码类别:

通讯编程

开发平台:

Visual C++

  1. #!/usr/bin/perl
  2. #use Math::Complex
  3. $infile = shift;
  4. $outfile = shift;
  5. $retries = shift;
  6. open(DATA, "$infile") || die "Can't open $filenamen";
  7. $sumtcpgood1 = 0;
  8. $sumtcpgood2 = 0;
  9. $sumlinkthru1 = 0;
  10. $sumlinkthru2 = 0;
  11. $sumideal = 0;
  12. @ontime = 0;
  13. @tcpgoodput1 = 0;
  14. @tcpgoodput2 = 0;
  15. @linkthruput1 = 0;
  16. @linkthruput2 = 0;
  17. @idealput = 0;
  18. $n = 0;
  19. while ($temp = <DATA>) {
  20.     chomp($temp);
  21.     @line = split " ", $temp;
  22.     @ontime[$n] = @line[0];
  23.     @tcpgoodput1[$n] = @line[1];
  24.     @tcpgoodput2[$n] = @line[2];
  25.     @linkthruput1[$n] = @line[3];
  26.     @linkthruput2[$n] = @line[4];
  27.     @idealput[$n] = @line[5];
  28.     
  29.     $sumontime += @ontime[$n];
  30.     $sumtcpgood1 += @tcpgoodput1[$n];
  31.     $sumtcpgood2 += @tcpgoodput2[$n];
  32.     $sumlinkthru1 += @linkthruput1[$n];
  33.     $sumlinkthru2 += @linkthruput2[$n];
  34.     $sumideal += @idealput[$n];
  35.     $n++;
  36. }
  37. $avgontime = $sumontime / $n;
  38. $avggood1 = $sumtcpgood1 / $n;
  39. $avggood2 = $sumtcpgood2 / $n;
  40. $avglink1 = $sumlinkthru1 / $n;
  41. $avglink2 = $sumlinkthru2 / $n;
  42. $avgideal = $sumideal / $n;
  43. print "avg=$avggood1n";
  44. for ($i = 0; $i < $n; $i++) {
  45.     $sum_good1_diff_sq += ((@tcpgoodput1[$i] - $avggood1) ** 2);
  46.     $sum_good2_diff_sq += ((@tcpgoodput2[$i] - $avggood2) ** 2);
  47.     $sum_thru1_diff_sq += ((@linkthruput1[$i] - $avglink1) ** 2);
  48.     $sum_thru2_diff_sq += ((@linkthruput2[$i] - $avglink2) ** 2);
  49.     $sum_ideal_diff_sq += ((@idealput[$i] - $avgideal) ** 2);
  50. }
  51. print "$sum_good1_diff_sq, $nn";
  52. $stddev_goodput1 = sqrt($sum_good1_diff_sq / ($n-1));
  53. $stddev_goodput2 = sqrt($sum_good2_diff_sq / ($n-1));
  54. $stddev_linkthru1 = sqrt($sum_thru1_diff_sq / ($n-1));
  55. $stddev_linkthru2 = sqrt($sum_thru2_diff_sq / ($n-1));
  56. print "$stddev_goodput1n";
  57. open(LOG, ">>$outfile") || die "Can't open $outfilen";
  58. printf LOG "%s %.2f %.2f %.2f %.2f %.2f %.2f %.2f %.2f %.2f %.2fn", $retries, $avgontime, $avggood1, $stddev_goodput1, $avggood2, $stddev_goodput2, $avglink1, $stddev_linkthru1, $avglink2, $stddev_linkthru2, $avgideal;