summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/cl-extra.el
diff options
context:
space:
mode:
authorStefan Monnier <monnier@iro.umontreal.ca>2019-06-25 17:08:01 -0400
committerStefan Monnier <monnier@iro.umontreal.ca>2019-06-25 17:08:01 -0400
commit5463b7e77ab4f22bb10192fb23af6df88dde37e6 (patch)
treeac7710dacb52acd30326b9ec68707b596a683240 /lisp/emacs-lisp/cl-extra.el
parent955e3703736d3de5a3d0784f3b70a95132a4f7bd (diff)
downloademacs-5463b7e77ab4f22bb10192fb23af6df88dde37e6.tar.gz
* lisp/emacs-lisp/cl-extra.el (cl-isqrt): Speed up bignum case
Diffstat (limited to 'lisp/emacs-lisp/cl-extra.el')
-rw-r--r--lisp/emacs-lisp/cl-extra.el5
1 files changed, 2 insertions, 3 deletions
diff --git a/lisp/emacs-lisp/cl-extra.el b/lisp/emacs-lisp/cl-extra.el
index 90533295b68..ca33c56a958 100644
--- a/lisp/emacs-lisp/cl-extra.el
+++ b/lisp/emacs-lisp/cl-extra.el
@@ -332,10 +332,9 @@ If so, return the true (non-nil) value returned by PREDICATE.
;;;###autoload
(defun cl-isqrt (x)
- "Return the integer square root of the argument."
+ "Return the integer square root of the (integer) argument."
(if (and (integerp x) (> x 0))
- (let ((g (cond ((<= x 100) 10) ((<= x 10000) 100)
- ((<= x 1000000) 1000) (t x)))
+ (let ((g (ash 2 (/ (logb x) 2)))
g2)
(while (< (setq g2 (/ (+ g (/ x g)) 2)) g)
(setq g g2))