, , C-Code, SSE. . , SSE.
#include <emmintrin.h>
static __m128i LFSR;
void InitRandom (int Seed)
{
LFSR = _mm_cvtsi32_si128 (Seed);
}
int GetRandom (int NumBits)
{
__m128i seed = LFSR;
__m128i one = _mm_cvtsi32_si128(1);
__m128i mask;
int i;
for (i=0; i<NumBits; i++)
{
__m128i temp = _mm_xor_si128(seed, _mm_srli_epi64(seed,1));
__m128i NewBit = _mm_xor_si128( _mm_srli_epi64(temp,5),
_mm_srli_epi64(temp,61));
NewBit = _mm_and_si128 (NewBit, one);
seed = _mm_or_si128 (NewBit, _mm_add_epi64 (seed,seed));
}
LFSR = seed;
mask = _mm_srli_epi64 (_mm_cmpeq_epi8(seed, seed), 64-NumBits);
return _mm_cvtsi128_si32 (_mm_and_si128(seed,mask));
}
. intrinsics SSE .
Btw - , 4.61169E + 18 . , 32- . .