Better equidistributed and faster/less consing integer RANDOM.
[sbcl.git] / src / code / random.lisp
1 ;;;; This software is part of the SBCL system. See the README file for
2 ;;;; more information.
3 ;;;;
4 ;;;; This software is derived from the CMU CL system, which was
5 ;;;; written at Carnegie Mellon University and released into the
6 ;;;; public domain. The software is in the public domain and is
7 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
8 ;;;; files for more information.
9
10 (in-package "SB!KERNEL")
11
12 ;;; the size of the chunks returned by RANDOM-CHUNK
13 (def!constant n-random-chunk-bits 32)
14
15 (sb!xc:defstruct (random-state (:constructor %make-random-state)
16                                (:copier nil)) ; since shallow copy is wrong
17   (state (init-random-state) :type (simple-array (unsigned-byte 32) (627))))