32-way branching in intmap.scm, not 16-way
[bpt/guile.git] / libguile / random.h
CommitLineData
e7a72986
MD
1/* classes: h_files */
2
8c494e99
DH
3#ifndef SCM_RANDOM_H
4#define SCM_RANDOM_H
5
77b13912 6/* Copyright (C) 1999,2000,2001, 2006, 2008, 2010 Free Software Foundation, Inc.
8c494e99 7 *
73be1d9e 8 * This library is free software; you can redistribute it and/or
53befeb7
NJ
9 * modify it under the terms of the GNU Lesser General Public License
10 * as published by the Free Software Foundation; either version 3 of
11 * the License, or (at your option) any later version.
8c494e99 12 *
53befeb7
NJ
13 * This library is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
73be1d9e
MV
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
8c494e99 17 *
73be1d9e
MV
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
53befeb7
NJ
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21 * 02110-1301 USA
73be1d9e 22 */
d3a6bc94 23
e7a72986
MD
24\f
25
26#include "libguile/__scm.h"
27
28\f
29/*
30 * A plugin interface for RNGs
31 *
32 * Using this interface, it is possible for the application to tell
33 * libguile to use a different RNG. This is desirable if it is
34 * necessary to use the same RNG everywhere in the application in
35 * order to prevent interference, if the application uses RNG
36 * hardware, or if the application has special demands on the RNG.
37 *
38 * Look how the default generator is "plugged in" in scm_init_random().
39 */
40
92c2555f 41typedef struct scm_t_rstate {
a2a95453 42 struct scm_t_rng *rng;
9defb641 43 double normal_next; /* For scm_c_normal01 */
e7a72986 44 /* Custom fields follow here */
92c2555f 45} scm_t_rstate;
e7a72986 46
92c2555f 47typedef struct scm_t_rng {
e7a72986 48 size_t rstate_size; /* size of random state */
b606ff6a 49 scm_t_uint32 (*random_bits) (scm_t_rstate *state); /* gives 32 random bits */
cc95e00a 50 void (*init_rstate) (scm_t_rstate *state, const char *seed, int n);
92c2555f 51 scm_t_rstate *(*copy_rstate) (scm_t_rstate *state);
99a0ee66
AW
52 void (*from_datum) (scm_t_rstate *state, SCM datum);
53 SCM (*to_datum) (scm_t_rstate *state);
92c2555f 54} scm_t_rng;
e7a72986 55
33b001fd 56SCM_API scm_t_rng scm_the_rng;
e7a72986
MD
57
58\f
e7a72986
MD
59/*
60 * Random number library functions
61 */
cc95e00a 62SCM_API scm_t_rstate *scm_c_make_rstate (const char *, int);
99a0ee66 63SCM_API scm_t_rstate *scm_c_rstate_from_datum (SCM datum);
33b001fd 64SCM_API scm_t_rstate *scm_c_default_rstate (void);
a2a95453 65#define scm_c_uniform32(RSTATE) ((RSTATE)->rng->random_bits (RSTATE))
33b001fd
MV
66SCM_API double scm_c_uniform01 (scm_t_rstate *);
67SCM_API double scm_c_normal01 (scm_t_rstate *);
68SCM_API double scm_c_exp1 (scm_t_rstate *);
b606ff6a 69SCM_API scm_t_uint32 scm_c_random (scm_t_rstate *, scm_t_uint32 m);
2af6e135 70SCM_API scm_t_uint64 scm_c_random64 (scm_t_rstate *state, scm_t_uint64 m);
33b001fd 71SCM_API SCM scm_c_random_bignum (scm_t_rstate *, SCM m);
e7a72986
MD
72
73\f
74/*
75 * Scheme level interface
76 */
33b001fd 77SCM_API scm_t_bits scm_tc16_rstate;
f5710d53
MV
78#define SCM_RSTATEP(obj) SCM_SMOB_PREDICATE (scm_tc16_rstate, obj)
79#define SCM_RSTATE(obj) ((scm_t_rstate *) SCM_SMOB_DATA (obj))
e7a72986 80
33b001fd
MV
81SCM_API unsigned char scm_masktab[256];
82
83SCM_API SCM scm_var_random_state;
84SCM_API SCM scm_random (SCM n, SCM state);
85SCM_API SCM scm_copy_random_state (SCM state);
86SCM_API SCM scm_seed_to_random_state (SCM seed);
99a0ee66
AW
87SCM_API SCM scm_datum_to_random_state (SCM datum);
88SCM_API SCM scm_random_state_to_datum (SCM state);
d47db067 89SCM_API SCM scm_random_state_from_platform (void);
33b001fd
MV
90SCM_API SCM scm_random_uniform (SCM state);
91SCM_API SCM scm_random_solid_sphere_x (SCM v, SCM state);
92SCM_API SCM scm_random_hollow_sphere_x (SCM v, SCM state);
93SCM_API SCM scm_random_normal (SCM state);
94SCM_API SCM scm_random_normal_vector_x (SCM v, SCM state);
95SCM_API SCM scm_random_exp (SCM state);
102dbb6f 96SCM_INTERNAL void scm_init_random (void);
e7a72986 97
d47db067
MW
98SCM_INTERNAL void scm_i_random_bytes_from_platform (unsigned char *buf, size_t len);
99
8c494e99 100#endif /* SCM_RANDOM_H */
89e00824
ML
101
102/*
103 Local Variables:
104 c-file-style: "gnu"
105 End:
106*/