我试图通过按行/列划分进程,在Raytracer中实现具有Callable / Future的多线程。 为此,我需要将变量从Main传递给Callable,而Callable不接受参数。
我尝试将整个函数传递为可调用
这是我尝试进行多线程处理的函数,“ formen”是我要传递的对象组。 发送光线并找到相交点是大多数计算能力所需要的-
static Image raytrace(Camera camera, Group formen, int samples){
Image image = new Image(camera.width, camera.height);
for (int x = 0; x != camera.width; x++) {
for (int y = 0; y != camera.height; y++) {
Vec3 color = new Vec3(0, 0, 0);
for (int xi = 0; xi < samples; xi++) {
for (int yi = 0; yi < samples; yi++) {
double rx = random.nextDouble();
double ry = random.nextDouble();
double xs = x + (xi + rx) / samples;
double ys = y + (yi + ry) / samples;
Ray ray = camera.sendRay(xs,ys);
Hit hit = formen.intersect(ray);
if(hit != null) color = Vec3.add(color, calculateRadiance(formen, ray, 100));
}
}
color = Vec3.divide(color, Math.pow(samples, 2));
image.setPixel(x, y, color);
}
}
return image;
}
这是我的跟踪函数的样子:
int cores = Runtime.getRuntime().availableProcessors();
Thread[] threads = new Thread[cores];
Image[] images = new Image[cores];
// Pool creation
ExecutorService pool = Executors.newFixedThreadPool(4);
//images[core] = raytrace(camera, scene, nn);
for(int i = 0; i < camera.height; i++){
Future<Image> pixel = pool.submit(calculateOneRow);
//threads[i].start();
System.out.println("Thread started:");
pool.shutdown();
try {
System.out.println("Image written");
return pixel.get();
//Image color = pixel.get();
} catch (ExecutionException e) {
e.printStackTrace();
}
final long duration = (System.nanoTime() - startTime) / 1000000;
return image;
}
在内部,for循环必须进入我的Callable中,但是我不知道如何将它们作为单独的任务传递给我。 我的目标是减少渲染时间。