gpt4 book ai didi

c++ - 如何设置参与计算的 CPU 内核数(C++ 和 OpenMP)

转载 作者:行者123 更新时间:2023-11-28 01:21:18 27 4
gpt4 key购买 nike

我正在尝试使用 C++ 和 OpenMP 在 Qt5 中计算 Pi(重点是减少数据子句)。在这个程序中,我提供了计算精度和占用的 CPU 内核数。

到目前为止,我有以下代码:

    int num_steps= ui->numberStepsLineEdit->text().toInt();
double x=0.0;
double sum = 0.0;
#pragma omp parallel private(i,x)
{
#pragma omp for reduction(+:sum) schedule(static)
for (int i=0; i<num_steps; i++)
{
x=(i+0.5)/(double)num_steps;
sum = sum + 4.0/(1.0+x*x);
}
}
double pi=sum/(double)num_steps;
QString result= QString::number(pi, 'g', 10);
ui->piLabel->setText(result);

问题是我需要指定参与计算的CPU核数,网上找了例子没有成功。

如何设置参与计算的CPU核数? (我不想设置线程数)。

非常感谢您。

最佳答案

如何模拟您所要求的方法是使用 num_threads() 子句或 omp_set_num_threads() API 调用将所需的核心数设置为 OpenMP 代码中的线程数。然后使用 OMP_PROC_BIND 和 OMP_PLACES 环境变量来控制线程到所需内核数的映射。

因此,例如,如果您只想使用系统的四个核心,您可以这样做:

#pragma omp parallel num_threads(4)
{
// your parallel code
}

$> OMP_PLACES=cores(4) OMP_PROC_BIND=compact ./a.out

关于c++ - 如何设置参与计算的 CPU 内核数(C++ 和 OpenMP),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56146672/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com