]> Cypherpunks repositories - gostls13.git/commit
sort: optimize average calculation in binary search
authorDavid R. Jenni <david.r.jenni@gmail.com>
Sun, 5 Feb 2017 10:02:03 +0000 (11:02 +0100)
committerRobert Griesemer <gri@golang.org>
Mon, 6 Feb 2017 17:08:13 +0000 (17:08 +0000)
commitfd37b8ccf2262bb3f0a608f7545f78a72e8d661f
tree3a72bdc5931c3c12283d3f79ed323433711f3363
parent91ad2a219445d6df3ddb796d0f44190da24f429d
sort: optimize average calculation in binary search

Use fewer instructions to calculate the average of i and j without
overflowing at the addition.

Even if both i and j are math.MaxInt{32,64}, the sum fits into a
uint{32,64}. Because the sum of i and j is always ≥ 0, the right
shift by one does the same as a division by two. The result of the
shift operation is at most math.MaxInt{32,64} and fits again into
an int{32,64}.

name              old time/op  new time/op  delta
SearchWrappers-4   153ns ± 3%   143ns ± 6%  -6.33%  (p=0.000 n=90+100)

This calculation is documented in:
https://research.googleblog.com/2006/06/extra-extra-read-all-about-it-nearly.html

Change-Id: I2be7922afc03b3617fce32e59364606c37a83678
Reviewed-on: https://go-review.googlesource.com/36332
Reviewed-by: Robert Griesemer <gri@golang.org>
Run-TryBot: Robert Griesemer <gri@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
src/sort/search.go