Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
119 lines (96 loc) · 3.17 KB

SDL_test_random.h

File metadata and controls

119 lines (96 loc) · 3.17 KB
 
Nov 27, 2012
Nov 27, 2012
1
2
/*
Simple DirectMedia Layer
Feb 15, 2013
Feb 15, 2013
3
Copyright (C) 1997-2013 Sam Lantinga <slouken@libsdl.org>
Nov 27, 2012
Nov 27, 2012
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this software must not be misrepresented; you must not
claim that you wrote the original software. If you use this software
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original software.
3. This notice may not be removed or altered from any source distribution.
*/
/**
* \file SDL_test_random.h
*
* Include file for SDL test framework.
*
* This code is a part of the SDL2_test library, not the main SDL library.
*/
/*
A "32-bit Multiply with carry random number generator. Very fast.
Includes a list of recommended multipliers.
multiply-with-carry generator: x(n) = a*x(n-1) + carry mod 2^32.
period: (a*2^31)-1
*/
#ifndef _SDL_test_random_h
#define _SDL_test_random_h
#include "begin_code.h"
/* Set up for C function definitions, even when using C++ */
#ifdef __cplusplus
/* *INDENT-OFF* */
extern "C" {
/* *INDENT-ON* */
#endif
Nov 29, 2012
Nov 29, 2012
51
/* --- Definitions */
Nov 27, 2012
Nov 27, 2012
52
53
/*
Nov 28, 2012
Nov 28, 2012
54
* Macros that return a random number in a specific format.
Nov 27, 2012
Nov 27, 2012
55
*/
Nov 28, 2012
Nov 28, 2012
56
#define SDLTest_RandomInt(c) ((int)SDLTest_Random(c))
Nov 27, 2012
Nov 27, 2012
57
58
59
60
61
62
63
64
65
66
67
68
/*
* Context structure for the random number generator state.
*/
typedef struct {
unsigned int a;
unsigned int x;
unsigned int c;
unsigned int ah;
unsigned int al;
} SDLTest_RandomContext;
Nov 29, 2012
Nov 29, 2012
69
70
/* --- Function prototypes */
Nov 27, 2012
Nov 27, 2012
71
72
73
74
/**
* \brief Initialize random number generator with two integers.
*
Nov 29, 2012
Nov 29, 2012
75
76
* Note: The random sequence of numbers returned by ...Random() is the
* same for the same two integers and has a period of 2^31.
Nov 27, 2012
Nov 27, 2012
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
*
* \param rndContext pointer to context structure
* \param xi integer that defines the random sequence
* \param ci integer that defines the random sequence
*
*/
void SDLTest_RandomInit(SDLTest_RandomContext * rndContext, unsigned int xi,
unsigned int ci);
/**
* \brief Initialize random number generator based on current system time.
*
* \param rndContext pointer to context structure
*
*/
void SDLTest_RandomInitTime(SDLTest_RandomContext *rndContext);
/**
* \brief Initialize random number generator based on current system time.
*
Nov 29, 2012
Nov 29, 2012
98
99
* Note: ...RandomInit() or ...RandomInitTime() must have been called
* before using this function.
Nov 27, 2012
Nov 27, 2012
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
*
* \param rndContext pointer to context structure
*
* \returns A random number (32bit unsigned integer)
*
*/
unsigned int SDLTest_Random(SDLTest_RandomContext *rndContext);
/* Ends C function definitions when using C++ */
#ifdef __cplusplus
/* *INDENT-OFF* */
}
/* *INDENT-ON* */
#endif
#include "close_code.h"
#endif /* _SDL_test_random_h */
/* vi: set ts=4 sw=4 expandtab: */