Add --ib option to use binary prefixes

This is mainly for use with the --bytes options since many file managers and applications assume use of 1024 intead of 1000 when it comes to dealing with data sizes in bytes. This is so users can get a closer to realistic view for general data (pretty much except those on OS X and possibly Ubuntu, whose file manager(s) use SI units).

Please see http://en.wikipedia.org/wiki/Binary_prefix
This commit is contained in:
Andrew Udvare 2013-04-27 07:53:25 -07:00
parent cdec9d4788
commit ab2bda7ea3
3 changed files with 22 additions and 6 deletions

View File

@ -24,4 +24,6 @@ speedtest-cli-3 is written for use with Python 3
--simple Suppress verbose output, only show basic information --simple Suppress verbose output, only show basic information
--list Display a list of speedtest.net servers sorted by distance --list Display a list of speedtest.net servers sorted by distance
--bytes Display speeds in MBytes/s (instead of Mbit/s) --bytes Display speeds in MBytes/s (instead of Mbit/s)
--ib Use IEC binary prefixes (MiB, etc)
http://en.wikipedia.org/wiki/Binary_prefix
--server SERVER Specify a server ID to test against --server SERVER Specify a server ID to test against

View File

@ -291,6 +291,7 @@ def speedtest():
'sorted by distance') 'sorted by distance')
parser.add_argument('--server', help='Specify a server ID to test against') parser.add_argument('--server', help='Specify a server ID to test against')
parser.add_argument('--bytes', action='store_true', help='Show speed in MB per second') parser.add_argument('--bytes', action='store_true', help='Show speed in MB per second')
parser.add_argument('--ib', action='store_true', help='Use IEC binary prefixes (MiB, etc)')
options = parser.parse_args() options = parser.parse_args()
if isinstance(options, tuple): if isinstance(options, tuple):
@ -343,8 +344,13 @@ def speedtest():
print 'Ping: %(latency)s ms' % best print 'Ping: %(latency)s ms' % best
unit = 'bits' unit = 'bits'
size_divisor = 1000
if args.bytes: if args.bytes:
unit = 'B' unit = 'B'
if args.ib:
unit = 'i' + unit
size_divisor = 1024
sizes = [350, 500, 750, 1000, 1500, 2000, 2500, 3000, 3500, 4000] sizes = [350, 500, 750, 1000, 1500, 2000, 2500, 3000, 3500, 4000]
urls = [] urls = []
@ -358,12 +364,12 @@ def speedtest():
if not args.simple: if not args.simple:
print print
dlspeed = dlspeed / 1000 / 1000 dlspeed = dlspeed / size_divisor / size_divisor
if not args.bytes: if not args.bytes:
dlspeed = dlspeed * 8 dlspeed = dlspeed * 8
print 'Download: %0.2f M%s/s' % (dlspeed, unit) print 'Download: %0.2f M%s/s' % (dlspeed, unit)
sizesizes = [int(.25 * 1000 * 1000), int(.5 * 1000 * 1000)] sizesizes = [int(.25 * size_divisor * size_divisor), int(.5 * size_divisor * size_divisor)]
sizes = [] sizes = []
for size in sizesizes: for size in sizesizes:
for i in xrange(0, 25): for i in xrange(0, 25):
@ -374,11 +380,12 @@ def speedtest():
if not args.simple: if not args.simple:
print print
ulspeed = ulspeed / 1000 / 1000 ulspeed = ulspeed / size_divisor / size_divisor
if not args.bytes: if not args.bytes:
ulspeed = ulspeed * 8 ulspeed = ulspeed * 8
print 'Upload: %0.2f M%s/s' % (ulspeed, unit) print 'Upload: %0.2f M%s/s' % (ulspeed, unit)
# --ib option does not affect this part
if args.share: if args.share:
dlspeedk = int(round((dlspeed / 1000) * 8, 0)) dlspeedk = int(round((dlspeed / 1000) * 8, 0))
ping = int(round(best['latency'], 0)) ping = int(round(best['latency'], 0))

View File

@ -273,6 +273,7 @@ def speedtest():
'sorted by distance') 'sorted by distance')
parser.add_argument('--server', help='Specify a server ID to test against') parser.add_argument('--server', help='Specify a server ID to test against')
parser.add_argument('--bytes', action='store_true', help='Show speed in MB per second') parser.add_argument('--bytes', action='store_true', help='Show speed in MB per second')
parser.add_argument('--ib', action='store_true', help='Use IEC binary prefixes (MiB, etc)')
args = parser.parse_args() args = parser.parse_args()
if not args.simple: if not args.simple:
@ -320,8 +321,13 @@ def speedtest():
print('Ping: %(latency)s ms' % best) print('Ping: %(latency)s ms' % best)
unit = 'bits' unit = 'bits'
size_divisor = 1000
if args.bytes: if args.bytes:
unit = 'B' unit = 'B'
if args.ib:
unit = 'i' + unit
size_divisor = 1024
sizes = [350, 500, 750, 1000, 1500, 2000, 2500, 3000, 3500, 4000] sizes = [350, 500, 750, 1000, 1500, 2000, 2500, 3000, 3500, 4000]
urls = [] urls = []
@ -335,12 +341,12 @@ def speedtest():
if not args.simple: if not args.simple:
print() print()
dlspeed = dlspeed / 1000 / 1000 dlspeed = dlspeed / size_divisor / size_divisor
if not args.bytes: if not args.bytes:
dlspeed = dlspeed * 8 dlspeed = dlspeed * 8
print('Download: %0.2f M%s/s' % (dlspeed, unit)) print('Download: %0.2f M%s/s' % (dlspeed, unit))
sizesizes = [int(.25 * 1000 * 1000), int(.5 * 1000 * 1000)] sizesizes = [int(.25 * size_divisor * size_divisor), int(.5 * size_divisor * size_divisor)]
sizes = [] sizes = []
for size in sizesizes: for size in sizesizes:
for i in range(0, 25): for i in range(0, 25):
@ -351,11 +357,12 @@ def speedtest():
if not args.simple: if not args.simple:
print() print()
ulspeed = ulspeed / 1000 / 1000 ulspeed = ulspeed / size_divisor / size_divisor
if not args.bytes: if not args.bytes:
ulspeed = ulspeed * 8 ulspeed = ulspeed * 8
print('Upload: %0.2f M%s/s' % (ulspeed, unit)) print('Upload: %0.2f M%s/s' % (ulspeed, unit))
# --ib option does not affect this part
if args.share: if args.share:
dlspeedk = int(round((dlspeed / 1000) * 8, 0)) dlspeedk = int(round((dlspeed / 1000) * 8, 0))
ping = int(round(best['latency'], 0)) ping = int(round(best['latency'], 0))