diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2019-06-25 17:08:01 -0400 |
---|---|---|
committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2019-06-25 17:08:01 -0400 |
commit | 5463b7e77ab4f22bb10192fb23af6df88dde37e6 (patch) | |
tree | ac7710dacb52acd30326b9ec68707b596a683240 /lisp/emacs-lisp/cl-extra.el | |
parent | 955e3703736d3de5a3d0784f3b70a95132a4f7bd (diff) | |
download | emacs-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.el | 5 |
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)) |