本文整理汇总了C++中Program::compileCL2方法的典型用法代码示例。如果您正苦于以下问题:C++ Program::compileCL2方法的具体用法?C++ Program::compileCL2怎么用?C++ Program::compileCL2使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Program
的用法示例。
在下文中一共展示了Program::compileCL2方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
int main(int argc, char **argv) {
time();
if (argc < 2) {
printf("Usage: %s <exp> to Lucas-Lehmer test 2^exp - 1 \n", argv[0]);
exit(1);
}
int exp = atoi(argv[1]);
int words = SIZE / 2;
int bitsPerWord = exp / words + 1; // 'exp' being prime, 'words' does not divide it.
if (bitsPerWord < 2) { bitsPerWord = 2; } // Min 2 bits/word.
int wordsUsed = exp / bitsPerWord + 1;
printf("Lucas-Lehmer test for 2^%d - 1. %d words, %d bits/word, %d words used\n",
exp, words, bitsPerWord, wordsUsed);
Context c;
Queue queue(c);
Program program;
time("OpenCL init");
program.compileCL2(c, "conv.cl");
K(program, dif2);
K(program, dif4);
K(program, dif8);
K(program, dit2);
K(program, dit4);
K(program, dit8);
K(program, dit8d);
// K(program, sq2k);
K(program, mul);
time("Kernels compilation");
/*
Buf bitsBuf(c, CL_MEM_READ_WRITE, sizeof(int) * words, 0);
int data = 0;
clEnqueueFillBuffer(queue.queue, bitsBuf.buf, &data, sizeof(data), 0, words, 0, 0, 0);
data = 4; // LL seed
queue.writeBlocking(bitsBuf, &data, sizeof(data));
*/
int *data = new int[SIZE];
srandom(0);
for (int i = 0; i < SIZE; ++i) { data[i] = (random() & 0xffffff) - (1 << 23); }
time("random");
Buf buf1(c, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, sizeof(int) * SIZE, data);
Buf buf2(c, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, sizeof(int) * SIZE, data);
Buf bufTmp(c, CL_MEM_READ_WRITE, sizeof(int) * SIZE, 0);
time("alloc gpu buffers");
mul.setArgs(buf1);
queue.run(mul, 256, 8 * 1024 * 1024 / 4);
queue.finish();
time("sq2k ini");
for (int i = 0; i < 1000; ++i) {
mul.setArgs(buf1);
queue.run(mul, 256, 8 * 1024 * 1024 / 4);
}
queue.finish();
time("sq2k");
exit(0);
for (int round = 3; round >= 0; round -= 2) {
dif8.setArgs(round, buf1, bufTmp);
queue.run(dif8, GS, SIZE / 32);
dif8.setArgs(round - 1, bufTmp, buf1);
queue.run(dif8, GS, SIZE / 32);
}
std::unique_ptr<long[]> tmpLong1(new long[SIZE]);
{
std::unique_ptr<int[]> tmp1(new int[SIZE]);
queue.readBlocking(&buf1, 0, sizeof(int) * SIZE, tmp1.get());
for (int i = 0; i < SIZE; ++i) {
tmpLong1[i] = tmp1[i];
}
}
Buf bufLong1(c, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, sizeof(long) * SIZE, tmpLong1.get());
Buf bufLongTmp(c, CL_MEM_READ_WRITE, sizeof(long) * SIZE, 0);
for (int round = 0; round < 4; round += 2) {
dit8.setArgs(round, bufLong1, bufLongTmp);
queue.run(dit8, GS, SIZE / 32);
dit8.setArgs(round + 1, bufLongTmp, bufLong1);
queue.run(dit8, GS, SIZE / 32);
}
queue.readBlocking(&bufLong1, 0, sizeof(long) * SIZE, tmpLong1.get());
int err = 0;
for (int i = 0; i < SIZE; ++i) {
//.........这里部分代码省略.........