mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-11-03 21:20:31 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 | 
						|
 This file is a part of JRTPLIB
 | 
						|
 Copyright (c) 1999-2017 Jori Liesenborgs
 | 
						|
 | 
						|
 Contact: jori.liesenborgs@gmail.com
 | 
						|
 | 
						|
 This library was developed at the Expertise Centre for Digital Media
 | 
						|
 (http://www.edm.uhasselt.be), a research center of the Hasselt University
 | 
						|
 (http://www.uhasselt.be). The library is based upon work done for
 | 
						|
 my thesis at the School for Knowledge Technology (Belgium/The Netherlands).
 | 
						|
 | 
						|
 Permission is hereby granted, free of charge, to any person obtaining a
 | 
						|
 copy of this software and associated documentation files (the "Software"),
 | 
						|
 to deal in the Software without restriction, including without limitation
 | 
						|
 the rights to use, copy, modify, merge, publish, distribute, sublicense,
 | 
						|
 and/or sell copies of the Software, and to permit persons to whom the
 | 
						|
 Software is furnished to do so, subject to the following conditions:
 | 
						|
 | 
						|
 The above copyright notice and this permission notice shall be included
 | 
						|
 in all copies or substantial portions of the Software.
 | 
						|
 | 
						|
 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
						|
 OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
						|
 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 | 
						|
 THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
						|
 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | 
						|
 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 | 
						|
 IN THE SOFTWARE.
 | 
						|
 | 
						|
 */
 | 
						|
 | 
						|
#include "rtprandomrand48.h"
 | 
						|
 | 
						|
namespace qrtplib
 | 
						|
{
 | 
						|
 | 
						|
RTPRandomRand48::RTPRandomRand48()
 | 
						|
{
 | 
						|
    SetSeed(PickSeed());
 | 
						|
}
 | 
						|
 | 
						|
RTPRandomRand48::RTPRandomRand48(uint32_t seed)
 | 
						|
{
 | 
						|
    SetSeed(seed);
 | 
						|
}
 | 
						|
 | 
						|
RTPRandomRand48::~RTPRandomRand48()
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
void RTPRandomRand48::SetSeed(uint32_t seed)
 | 
						|
{
 | 
						|
    state = ((uint64_t) seed) << 16 | 0x330EULL;
 | 
						|
}
 | 
						|
 | 
						|
uint8_t RTPRandomRand48::GetRandom8()
 | 
						|
{
 | 
						|
    uint32_t x = ((GetRandom32() >> 24) & 0xff);
 | 
						|
 | 
						|
    return (uint8_t) x;
 | 
						|
}
 | 
						|
 | 
						|
uint16_t RTPRandomRand48::GetRandom16()
 | 
						|
{
 | 
						|
    uint32_t x = ((GetRandom32() >> 16) & 0xffff);
 | 
						|
 | 
						|
    return (uint16_t) x;
 | 
						|
}
 | 
						|
 | 
						|
uint32_t RTPRandomRand48::GetRandom32()
 | 
						|
{
 | 
						|
    state = ((0x5DEECE66DULL * state) + 0xBULL) & 0x0000ffffffffffffULL;
 | 
						|
    uint32_t x = (uint32_t) ((state >> 16) & 0xffffffffULL);
 | 
						|
 | 
						|
    return x;
 | 
						|
}
 | 
						|
 | 
						|
double RTPRandomRand48::GetRandomDouble()
 | 
						|
{
 | 
						|
 | 
						|
    state = ((0x5DEECE66DULL * state) + 0xBULL) & 0x0000ffffffffffffULL;
 | 
						|
    int64_t x = (int64_t) state;
 | 
						|
 | 
						|
    double y = 3.552713678800500929355621337890625e-15 * (double) x;
 | 
						|
    return y;
 | 
						|
}
 | 
						|
 | 
						|
} // end namespace
 | 
						|
 |