在递归函数上的OpenMP并行化

Ant*_*son 6 c++ drawing openmp

我正在尝试使用并行化来提高绘制具有层次排序对象的3D场景的刷新率.场景绘制算法首先递归地遍历对象树,并从中构建绘制场景所需的有序数据的有序数组.然后它多次遍历该数组以绘制对象/覆盖等.从我读到的OpenGL不是一个线程安全的API,我假设数组遍历/绘图代码必须在主线程上完成,但我我想我可能能够并行化填充数组的递归函数.关键问题是必须按照对象在场景中出现的顺序填充数组,因此所有将给定对象与数组索引相关联的功能必须按正确顺序完成,但是一旦分配了数组索引,我可以使用工作线程填充该数组元素的数据(这不一定是一个简单的操作).所以这是我想要的伪代码.我希望你能理解xml-ish线程的语法.

recursivepopulatearray(theobject)
{
  <main thread>
  for each child of theobject
  {
     assign array index
     <child thread(s)>
       populate array element for child object
     </child thread(s)>
     recursivepopulatearray(childobject)
  }
  </main thread>
}
Run Code Online (Sandbox Code Playgroud)

那么,是否可以使用OpenMP执行此操作,如果是这样,怎么做?是否有其他并行化库可以更好地处理这个问题?

附录:为了回应Davide要求进一步澄清的请求,让我详细解释一下.让我们说场景是这样排序的:

-Bicycle Frame
  - Handle Bars 
  - Front Wheel
  - Back Wheel
-Car Frame
  - Front Left Wheel
  - Front Right Wheel
  - Back Left Wheel
  - Back Right Wheel
Run Code Online (Sandbox Code Playgroud)

现在,这些对象中的每一个都有很多与之相关的数据,即位置,旋转,大小,不同的绘图参数等.另外,我需要在这个场景上进行多次传递才能正确绘制它.一个通道绘制对象的形状,另一个通道绘制描述对象的文本,另一个通道绘制对象之间的连接/关联(如果有).无论如何,如果我必须多次访问它,从这些不同的对象中获取所有绘图数据是相当慢的,所以我决定使用一个通道将所有数据缓存到一维数组中,然后实际所有绘图传递只看数组.问题在于,因为我需要以正确的顺序进行OpenGL推送/弹出,所以数组必须处于代表树层次结构的正确深度优先搜索顺序中.在上面的示例中,必须按如下方式对数组进行排序:

index 0: Bicycle Frame
index 1: Handle Bars 
index 2: Front Wheel
index 3: Back Wheel
index 4: Car Frame
index 5: Front Left Wheel
index 6: Front Right Wheel
index 7: Back Left Wheel
index 8: Back Right Wheel
Run Code Online (Sandbox Code Playgroud)

因此,必须正确地序列化数组的顺序,但是一旦我正确地分配了该顺序,我就可以并行化数组的填充.例如,一旦我将自行车框架分配给索引0并将把手杆分配给索引1,一个线程可以为自行车框架填充数组元素,而另一个线程则为句柄条填充数组元素.

好吧,我想澄清这一点,我已经回答了我自己的问题,所以感谢Davide.所以我发布了自己的答案.

Ant*_*son 0

这是一段经过修改的伪代码,应该可以工作。

populatearray(thescene)
{
  recursivepopulatearray(thescene)

  #pragma omp parallel for
  for each element in array
    populate array element based on associated object
}

recursivepopulatearray(theobject)
{
  for each childobject in theobject
  {
     assign array index and associate element with childobject
     recursivepopulatearray(childobject)
  }
}
Run Code Online (Sandbox Code Playgroud)