pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
plank_RNGInline.h
00001 /*
00002  -------------------------------------------------------------------------------
00003  This file is part of the Plink, Plonk, Plank libraries
00004   by Martin Robinson
00005  
00006  http://code.google.com/p/pl-nk/
00007  
00008  Copyright University of the West of England, Bristol 2011-14
00009  All rights reserved.
00010  
00011  Redistribution and use in source and binary forms, with or without
00012  modification, are permitted provided that the following conditions are met:
00013  
00014  * Redistributions of source code must retain the above copyright
00015    notice, this list of conditions and the following disclaimer.
00016  * Redistributions in binary form must reproduce the above copyright
00017    notice, this list of conditions and the following disclaimer in the
00018    documentation and/or other materials provided with the distribution.
00019  * Neither the name of University of the West of England, Bristol nor 
00020    the names of its contributors may be used to endorse or promote products
00021    derived from this software without specific prior written permission.
00022  
00023  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00024  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00025  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00026  DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF THE WEST OF ENGLAND, BRISTOL BE 
00027  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
00028  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 
00029  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 
00030  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
00031  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 
00032  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00033  
00034  This software makes use of third party libraries. For more information see:
00035  doc/license.txt included in the distribution.
00036  -------------------------------------------------------------------------------
00037  */
00038 
00039 // help prevent accidental inclusion other than via the intended header
00040 #if PLANK_INLINING_FUNCTIONS
00041 
00042 #if !DOXYGEN
00043 typedef struct PlankRNG
00044 {
00045     unsigned int value;
00046 } PlankRNG;
00047 #endif
00048 
00049 #define PLANK_RNG_MAGIC1            1664525
00050 #define PLANK_RNG_MAGIC2            1013904223
00051 #define PLANK_RNG_FLOAT_ONE         PLANK_FLOAT_ONE
00052 #define PLANK_RNG_FLOAT_ONEMASK     PLANK_FLOAT_ONEMASK
00053 #define PLANK_RNG_DOUBLE_ONE        PLANK_DOUBLE_ONE
00054 #define PLANK_RNG_DOUBLE_ONEMASK    PLANK_DOUBLE_ONEMASK
00055 
00056 static inline int pl_RNG_Next (PlankRNGRef p)
00057 {
00058     p->value = (unsigned int)PLANK_RNG_MAGIC1 * p->value + (unsigned int)PLANK_RNG_MAGIC2;
00059     return p->value;
00060 }
00061 
00062 static inline unsigned int pl_RNG_NextInt (PlankRNGRef p, unsigned int max)
00063 {
00064     unsigned int value = pl_RNG_Next (p);
00065     return value % max;
00066 }
00067 
00068 static inline float pl_RNG_NextFloat (PlankRNGRef p)
00069 {    
00070     unsigned int bits;
00071         float value;
00072         bits = PLANK_RNG_FLOAT_ONE | (PLANK_RNG_FLOAT_ONEMASK & pl_RNG_Next (p));
00073     value = *(float*)(&bits);
00074     return value - 1.f;
00075 }
00076 
00077 static inline double pl_RNG_NextDouble (PlankRNGRef p)
00078 {    
00079     unsigned int bits;
00080         float value;
00081         bits = PLANK_RNG_FLOAT_ONE | (PLANK_RNG_FLOAT_ONEMASK & pl_RNG_Next (p));
00082     value = *(float*)(&bits);
00083     return (double)value - 1.0;
00084 }
00085 
00086 #endif
 All Classes Functions Typedefs Enumerations Enumerator Properties