Update contrib.
2 * LIBOIL - Library of Optimized Inner Loops
3 * Copyright (c) 2003,2004,2005 David A. Schleef <ds@schleef.org>
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
19 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
21 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
23 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
24 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
28 #ifndef _LIBOIL_RANDOM_H_
29 #define _LIBOIL_RANDOM_H_
31 #include <liboil/liboilutils.h>
32 #include <liboil/liboiltypes.h>
37 #ifdef OIL_ENABLE_UNSTABLE_API
39 IMPORT_C void oil_random_s32(oil_type_s32 *dest, int n);
40 IMPORT_C void oil_random_s64 (oil_type_s64 *dest, int n);
41 IMPORT_C void oil_random_s16 (oil_type_s16 *dest, int n);
42 IMPORT_C void oil_random_s8 (oil_type_s8 *dest, int n);
43 IMPORT_C void oil_random_u32 (oil_type_u32 *dest, int n);
44 IMPORT_C void oil_random_u64 (oil_type_u64 *dest, int n);
45 IMPORT_C void oil_random_u16 (oil_type_u16 *dest, int n);
46 IMPORT_C void oil_random_u8 (oil_type_u8 *dest, int n);
47 IMPORT_C void oil_random_f64 (oil_type_f64 *dest, int n);
48 IMPORT_C void oil_random_f32 (oil_type_f32 *dest, int n);
49 IMPORT_C void oil_random_argb (oil_type_u32 *dest, int n);
50 IMPORT_C void oil_random_alpha (oil_type_u8 *dest, int n);
55 * Evaluates to a random integer in the range [-(1<<31), (1<<31)-1].
57 #define oil_rand_s32() ((rand()&0xffff)<<16 | (rand()&0xffff))
61 * Evaluates to a random integer in the range [-(1<<63), (1<<63)-1].
63 #define oil_rand_s64() ((int64_t)(oil_rand_s32())<<32 | oil_rand_s32())
68 * Evaluates to a random integer in the range [-(1<<15), (1<<15)-1].
70 #define oil_rand_s16() ((int16_t)(rand()&0xffff))
75 * Evaluates to a random integer in the range [-(1<<7), (1<<7)-1].
77 #define oil_rand_s8() ((int8_t)(rand()&0xffff))
82 * Evaluates to a random integer in the range [0, (1<<32)-1].
84 #define oil_rand_u32() ((uint32_t)((rand()&0xffff)<<16 | (rand()&0xffff)))
89 * Evaluates to a random integer in the range [0, (1<<64)-1].
91 #define oil_rand_u64() ((uint64_t)(oil_rand_u32())<<32 | oil_rand_u32())
96 * Evaluates to a random integer in the range [0, (1<<16)-1].
98 #define oil_rand_u16() ((uint16_t)(rand()&0xffff))
103 * Evaluates to a random integer in the range [0, (1<<8)-1].
105 #define oil_rand_u8() ((uint8_t)(rand()&0xffff))
111 * Evaluates to a random double-precision floating point number
112 * in the range [0, 1.0).
114 #define oil_rand_f64() (((rand()/(RAND_MAX+1.0))+rand())/(RAND_MAX+1.0))
119 * Evaluates to a random single-precision floating point number
120 * in the range [0, 1.0).
122 #define oil_rand_f32() (rand()/(RAND_MAX+1.0))