, .
opencl..
:
( opencl, .. .!)
"Mapper.c" → Host
typedef struct data
{
double dattr[10];
int d_id;
int bestCent;
}Data;
typedef struct cent
{
double cattr[5];
int c_id;
}Cent;
Data *dataNode;
Cent *centNode;
.
, :
mapper.cl:
#pragma OPENCL EXTENSION cl_khr_fp64 : enable
typedef struct data
{
double dattr[10];
int d_id;
int bestCent;
}Data;
typedef struct cent
{
double cattr[5];
int c_id;
}Cent;
__kernel void mapper(__global int *keyMobj, __global int *valueMobj,__global Data *dataMobj,__global Cent *centMobj)
{
int i= get_global_id(0);
int j,k,color=0;
double dmin=1000000.0, dx;
for(j=0; j<2; j++)
{
dx = 0.0;
for(k=0; k<2; k++)
{
dx+= ((centMobj[j].cattr[k])-(dataMobj[i].dattr[k])) * ((centMobj[j].cattr[k])-(dataMobj[i].dattr[k]));
}
if(dx<dmin)
{ color = j;
dmin = dx;
}
}
keyMobj[i] = color;
valueMobj[i] = dataMobj[i].d_id;
}
, , .. keyMobj valueMobj.
kernel = clCreateKernel(program, "mapper", &ret);
ret = clSetKernelArg(kernel, 0, sizeof(cl_mem), (void *)&keyMobj);
ret = clSetKernelArg(kernel, 1, sizeof(cl_mem), (void *)&valueMobj);
ret = clSetKernelArg(kernel, 2, sizeof(cl_mem), (void *)&dataMobj);
ret = clSetKernelArg(kernel, 3, sizeof(cl_mem), (void *)¢Mobj);
(mapper.c), (mapper.cl).. 4 (clSetKernelArg..) .