我试图并行在下面的函数循环使用OpenMPOpenMP的减少与重载运营商
void CEnergymulti::forcetwobody(vector<CMolecule*> m_mols,CPnt force0,CPnt torque0)
{
const int nmol=m_mols.size();
vector<CMolecule*> twomols(2);
CPnt forcetemp,torquetemp;
twomols.clear();
force0.zero();
torque0.zero();
forcetemp.zero();
torquetemp.zero();
#pragma omp parallel for reduction(+:force0,torque0) private(twomols)
for(int j=1;j<nmol;j++)
{ twomols.push_back(m_mols[0]);
twomols.push_back(m_mols[j]);
CMolecule::polarize_mutual(twomols,false, 1000);
twomols[0]->computeMol_Force_and_Torque(forcetemp,torquetemp);
force0+=forcetemp;
torque0+=torquetemp;
forcetemp.zero();
torquetemp.zero();
twomols.clear();
}
REAL converter=COUL_K*IKbT;
force0*=converter;
torque0*=converter;
return;
}
当我编译的代码,它提供了以下消息:
EnergyD_multi.cpp: In static member function ‘static void
CEnergymulti::forcetwobody(std::vector<CMolecule*,
std::allocator<CMolecule*> >, CPnt, CPnt)’: EnergyD_multi.cpp:226:
error: ‘torque0’ has invalid type for ‘reduction’
EnergyD_multi.cpp:226: error: ‘force0’ has invalid type for
‘reduction’
我明白变量'force0'和'torque0'既不是双重数据也不是整型数据,而是'CPnt'类型,这是一种定义为表示空间中三维向量的类。对于'CPnt'类,运算符'+'和' - '已经由运算符重载定义。所以我的问题是:在OpenMP中的减少不能处理这样的重载操作符吗?有没有其他方法可以将这个循环与OpenMP并行化,而不需要减少'force0'和'torque0'的每个组件?
非常感谢。
您是否得到了应有的工作?我更改了代码以使用OpenMP执行过载操作。让我知道它是否有效。如果有错误,请参阅链接以了解主要思想。 – 2013-04-25 19:32:24
非常感谢@raxman。使用并行化方案,您建议可以编译代码。不过,我仍然对与'nowait'的循环并行化有点困惑。这是因为我仍然认为对于每个线程来说,循环'twomols'和'forcetemp'中的变量应该被视为'私人',但是您没有将它们列为私人。 – user2226358 2013-04-26 06:35:55
“#pragma omp parallel”中的所有内容都是私人定义的。只有force0和torque0是共享的,因为它们不在omp pragma – 2013-04-26 06:40:14