opencl
Przykład jądra generatora liczb pseudolosowych
Szukaj…
Parametry
Parametr | Detale |
---|---|
__global unsigned int * rnd_buffer | unsigned int jest standaryzowany przez standard OpenCL jako 32-bitowy |
* | __global oznacza główną pamięć urządzenia do odczytu / zapisu |
* | rnd_buffer to tylko nazwa w zakresie „programu opencl” (nie host, ale urządzenie) |
Korzystanie z funkcji skrótu liczb całkowitych Thomasa Wanga
Funkcja pomocnicza, która pobiera ziarno i ocenia:
uint wang_hash(uint seed)
{
seed = (seed ^ 61) ^ (seed >> 16);
seed *= 9;
seed = seed ^ (seed >> 4);
seed *= 0x27d4eb2d;
seed = seed ^ (seed >> 15);
return seed;
}
kolejna funkcja pomocnicza, która używa jej do inicjowania lokalizacji bufora pokazanej przez „id”:
void wang_rnd_0(__global unsigned int * rnd_buffer,int id)
{
uint maxint=0;
maxint--;
uint rndint=wang_hash(id);
rnd_buffer[id]=rndint;
}
a drugi robi dodatkowe wyjście zmiennoprzecinkowe między 0 a 1
float wang_rnd(__global unsigned int * rnd_buffer,int id)
{
uint maxint=0;
maxint--; // not ok but works
uint rndint=wang_hash(rnd_buffer[id]);
rnd_buffer[id]=rndint;
return ((float)rndint)/(float)maxint;
}
Jądro inicjalizatora:
__kernel void rnd_init(__global unsigned int * rnd_buffer)
{
int id=get_global_id(0);
wang_rnd_0(rnd_buffer,id); // each (id) thread has its own random seed now
}
Jądro z pojedynczą iteracją:
__kernel void rnd_1(__global unsigned int * rnd_buffer)
{
int id=get_global_id(0);
// can use this to populate a buffer with random numbers
// concurrently on all cores of a gpu
float thread_private_random_number=wang_rnd(rnd_buffer,id);
}
Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow