mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-07-01 15:20:34 +02:00
* libguile/random.h (scm_t_rstate): Put a tag word in the beginning. (scm_is_random_state, scm_to_random_state, scm_from_random_state): New helpers. (SCM_RSTATEP, SCM_RSTATE): Use the new helpers. (scm_masktab): Make private. * libguile/random.c: Adapt random states to not be a smob. * libguile/eq.c: * libguile/print.c: * libguile/scm.h: * module/oop/goops.scm: Add new random-state cases. Fix a number of classes for other types that were recently changed to not be smobs.
120 lines
3.8 KiB
C
120 lines
3.8 KiB
C
#ifndef SCM_RANDOM_H
|
||
#define SCM_RANDOM_H
|
||
|
||
/* Copyright 1999-2001,2006,2008,2010,2018,2025
|
||
Free Software Foundation, Inc.
|
||
|
||
This file is part of Guile.
|
||
|
||
Guile is free software: you can redistribute it and/or modify it
|
||
under the terms of the GNU Lesser General Public License as published
|
||
by the Free Software Foundation, either version 3 of the License, or
|
||
(at your option) any later version.
|
||
|
||
Guile is distributed in the hope that it will be useful, but WITHOUT
|
||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
||
License for more details.
|
||
|
||
You should have received a copy of the GNU Lesser General Public
|
||
License along with Guile. If not, see
|
||
<https://www.gnu.org/licenses/>. */
|
||
|
||
|
||
|
||
#include <libguile/error.h>
|
||
|
||
|
||
/*
|
||
* A plugin interface for RNGs
|
||
*
|
||
* Using this interface, it is possible for the application to tell
|
||
* libguile to use a different RNG. This is desirable if it is
|
||
* necessary to use the same RNG everywhere in the application in
|
||
* order to prevent interference, if the application uses RNG
|
||
* hardware, or if the application has special demands on the RNG.
|
||
*
|
||
* Look how the default generator is "plugged in" in scm_init_random().
|
||
*/
|
||
|
||
typedef struct scm_t_rstate {
|
||
scm_t_bits tag;
|
||
struct scm_t_rng *rng;
|
||
double normal_next; /* For scm_c_normal01 */
|
||
/* Custom fields follow here */
|
||
} scm_t_rstate;
|
||
|
||
typedef struct scm_t_rng {
|
||
size_t rstate_size; /* size of random state */
|
||
uint32_t (*random_bits) (scm_t_rstate *state); /* gives 32 random bits */
|
||
void (*init_rstate) (scm_t_rstate *state, const char *seed, int n);
|
||
scm_t_rstate *(*copy_rstate) (scm_t_rstate *state);
|
||
void (*from_datum) (scm_t_rstate *state, SCM datum);
|
||
SCM (*to_datum) (scm_t_rstate *state);
|
||
} scm_t_rng;
|
||
|
||
SCM_API scm_t_rng scm_the_rng;
|
||
|
||
|
||
/*
|
||
* Random number library functions
|
||
*/
|
||
SCM_API scm_t_rstate *scm_c_make_rstate (const char *, int);
|
||
SCM_API scm_t_rstate *scm_c_rstate_from_datum (SCM datum);
|
||
SCM_API scm_t_rstate *scm_c_default_rstate (void);
|
||
#define scm_c_uniform32(RSTATE) ((RSTATE)->rng->random_bits (RSTATE))
|
||
SCM_API double scm_c_uniform01 (scm_t_rstate *);
|
||
SCM_API double scm_c_normal01 (scm_t_rstate *);
|
||
SCM_API double scm_c_exp1 (scm_t_rstate *);
|
||
SCM_API uint32_t scm_c_random (scm_t_rstate *, uint32_t m);
|
||
SCM_API uint64_t scm_c_random64 (scm_t_rstate *state, uint64_t m);
|
||
SCM_API SCM scm_c_random_bignum (scm_t_rstate *, SCM m);
|
||
|
||
|
||
/*
|
||
* Scheme level interface
|
||
*/
|
||
static inline int
|
||
scm_is_random_state (SCM x)
|
||
{
|
||
return SCM_HAS_TYP16 (x, scm_tc16_random_state);
|
||
}
|
||
|
||
static inline struct scm_t_rstate *
|
||
scm_to_random_state (SCM x)
|
||
{
|
||
if (!scm_is_random_state (x))
|
||
abort ();
|
||
return (struct scm_t_rstate *) SCM_UNPACK_POINTER (x);
|
||
}
|
||
|
||
static inline SCM
|
||
scm_from_random_state (struct scm_t_rstate *x)
|
||
{
|
||
return SCM_PACK_POINTER (x);
|
||
}
|
||
|
||
#define SCM_RSTATEP(obj) scm_is_random_state (obj)
|
||
#define SCM_RSTATE(obj) scm_to_random_state (obj)
|
||
|
||
#define SCM_VALIDATE_RSTATE(pos, v) \
|
||
SCM_MAKE_VALIDATE_MSG (pos, v, RSTATEP, "random-generator-state")
|
||
|
||
SCM_API SCM scm_var_random_state;
|
||
SCM_API SCM scm_random (SCM n, SCM state);
|
||
SCM_API SCM scm_copy_random_state (SCM state);
|
||
SCM_API SCM scm_seed_to_random_state (SCM seed);
|
||
SCM_API SCM scm_datum_to_random_state (SCM datum);
|
||
SCM_API SCM scm_random_state_to_datum (SCM state);
|
||
SCM_API SCM scm_random_state_from_platform (void);
|
||
SCM_API SCM scm_random_uniform (SCM state);
|
||
SCM_API SCM scm_random_solid_sphere_x (SCM v, SCM state);
|
||
SCM_API SCM scm_random_hollow_sphere_x (SCM v, SCM state);
|
||
SCM_API SCM scm_random_normal (SCM state);
|
||
SCM_API SCM scm_random_normal_vector_x (SCM v, SCM state);
|
||
SCM_API SCM scm_random_exp (SCM state);
|
||
SCM_INTERNAL void scm_init_random (void);
|
||
|
||
SCM_INTERNAL void scm_i_random_bytes_from_platform (unsigned char *buf, size_t len);
|
||
|
||
#endif /* SCM_RANDOM_H */
|