我正在尝试用OpenCL和Java(LWJGL)编写一个raycaster引擎。
但是在运行内核时,我无法printf,或者写入调试变量。我觉得内核突然被切断,因为报告的时间(在opencl之外)显示非常快的结果(60fps),比在mandelbrot示例中更快!
我正在看gDEBugger,但我不认为它会支持Java。
我对代码化妆的任何评论都非常受欢迎,因为我是初学者。我也欢迎对我的raycast-mathmatics发表评论。
#ifdef USE_TEXTURE
#define OUTPUT_TYPE __write_only image2d_t
#else
#define OUTPUT_TYPE global uint *
#endif
#define MAX_RAY_LENGTH 1024
bool isSolid(int x, int y, int z, global uchar *objectIsSolidStorage, int width, int height, int depth) {
uint placex = x / 8;
uint placey = y / 8;
uint placez = z / 8;
uint widthbychar = (width/8);
uint heightbychar = (height/8);
int calcbychar = placex + placey * widthbychar + placez * widthbychar * heightbychar;
int leftover = x % 8;
uchar solidchar = objectIsSolidStorage[calcbychar];
if (x > width || y > height || z >> depth ||
x < 0 || y < 0 || z < 0) return 1;
if ((solidchar & ( 1 << leftover )) >> leftover) {
return 1;
}
return 0;
}
int getColor(int x, int y, int z)
{
return 0xFFFFFFFF;
}
kernel void raycast(
const int width,
const int height,
const float positionX,
const float positionY,
const float positionZ,
const float directionX,
const float directionY,
const float directionZ,
OUTPUT_TYPE output,
global uchar *objectIsSolidStorage,
const int objectStorageWidth,
const int objectStorageHeight,
const int objectStorageDepth,
global uint *objectColorStorage,
global uint *smallObjectsMap,
global uint *hangableObjectsMap,
global uint *largeObjectsMap,
const int objectMapWidth,
const int objectMapHeight,
const float frustrumAngleX,
const float frustrumAngleY,
global char debug
) {
unsigned int rayx = get_global_id(0);
unsigned int rayy = get_global_id(1);
bool hit = false;
int itr = 0;
float x = positionX;
float y = positionY;
float z = positionZ;
printf("work");
int addX = (rayx - width / 2) * frustrumAngleX;
int addY = (rayy - height / 2) * frustrumAngleY;
int color = 0xFFAAFF;
while(!hit) {
x += addX;
y += addY;
z += itr;
if (MAX_RAY_LENGTH < itr) {
hit = true;
color = 0xFFFFFFFF;
break;
} else if (isSolid(x,y,z,objectIsSolidStorage,objectStorageWidth,objectStorageHeight,objectStorageDepth)) {
hit = true;
color = 0xAAAAAAAA;
break;
}
itr++;
}
#ifdef USE_TEXTURE
float4 oc = (float4)(
(c & 0xFF) >> 0,
(c & 0xFF00) >> 8,
(c & 0xFF0000) >> 16,
255.0f
);
write_imagef(output, (int2)(rayx, rayy), color / 255.0f);
#else
output[rayy * width + rayx] = color;
#endif
}
答案 0 :(得分:1)
它应该适用于您的OpenCL + Java开发:附加到java进程并轻松调试OpenCL内核
http://suhorukov.blogspot.com/2011/12/opencl-kernel-debugging-for-java-host.html
答案 1 :(得分:0)
您可以在CPU上运行它以进行调试(扩展名为)
#pragma OPENCL EXTENSION cl_amd_printf : enable