bandwidth.py 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. # greaseweazle/tools/bandwidth.py
  2. #
  3. # Greaseweazle control script: Measure USB bandwidth.
  4. #
  5. # Written & released by Keir Fraser <keir.xen@gmail.com>
  6. #
  7. # This is free and unencumbered software released into the public domain.
  8. # See the file COPYING for more details, or visit <http://unlicense.org>.
  9. description = "Report the available USB bandwidth for the Greaseweazle device."
  10. import sys
  11. from timeit import default_timer as timer
  12. from greaseweazle.tools import util
  13. from greaseweazle import usb as USB
  14. def measure_bandwidth(usb, args):
  15. print()
  16. print("%19s%-7s/ %-7s/ %-7s" % ("", "Min.", "Mean", "Max."))
  17. w_nr = 1000000
  18. start = timer()
  19. usb.sink_bytes(w_nr)
  20. end = timer()
  21. av_w_bw = (w_nr * 8) / ((end-start) * 1e6)
  22. min_w_bw, max_w_bw = usb.bw_stats()
  23. print("Write Bandwidth: %8.3f / %8.3f / %8.3f Mbps"
  24. % (min_w_bw, av_w_bw, max_w_bw))
  25. r_nr = 1000000
  26. start = timer()
  27. usb.source_bytes(r_nr)
  28. end = timer()
  29. av_r_bw = (r_nr * 8) / ((end-start) * 1e6)
  30. min_r_bw, max_r_bw = usb.bw_stats()
  31. print("Read Bandwidth: %8.3f / %8.3f / %8.3f Mbps"
  32. % (min_r_bw, av_r_bw, max_r_bw))
  33. est_min_bw = 0.9 * min(min_r_bw, min_w_bw)
  34. print()
  35. print("Estimated Consistent Min. Bandwidth: %.3f Mbps" % est_min_bw)
  36. max_flux_rate = ((est_min_bw * 0.9) * 1e6) / 8
  37. twobyte_us = 249/72 # Smallest time requiring a 2-byte transmission code
  38. req_min_bw = 16 / twobyte_us # Bandwidth (Mbps) to transmit above time
  39. if req_min_bw > est_min_bw:
  40. print(" -> **WARNING** BELOW REQUIRED MIN.: %.3f Mbps" % req_min_bw)
  41. else:
  42. print(" -> Max. Flux Rate: %.3f Msamples/sec"
  43. % (max_flux_rate / 1e6))
  44. print(" -> Min. Ave. Flux: %.3f us"
  45. % (1e6 / max_flux_rate))
  46. def main(argv):
  47. parser = util.ArgumentParser(usage='%(prog)s [options]')
  48. parser.add_argument("--device", help="greaseweazle device name")
  49. parser.description = description
  50. parser.prog += ' ' + argv[1]
  51. args = parser.parse_args(argv[2:])
  52. try:
  53. usb = util.usb_open(args.device)
  54. measure_bandwidth(usb, args)
  55. except USB.CmdError as error:
  56. print("Command Failed: %s" % error)
  57. if __name__ == "__main__":
  58. main(sys.argv)
  59. # Local variables:
  60. # python-indent: 4
  61. # End: