在程序源文件中使用脚本变量OMP_NUM_THREADS
Using the script variable OMP_NUM_THREADS in the program source files
如果我在集群上运行c++代码,是否可以在我的程序中使用OMP_NUM_THREADS的值?例如,假设我有两个.cpp文件main.cpp和function .cpp,其中function .cpp是使用OpenMP并行编写的。我希望能够一次定义线程的数量(在下面的脚本中),而不必在function .cpp中再次定义它。
#!/bin/bash
#PBS -S /bin/bash
#PBS -l walltime=00:10:00
#PBS -l select=1:ncpus=4:mem=2gb
#PBS -q QName
#PBS -N Name
#PBS -o Results/output.txt
#PBS -e Results/error.txt
#PBS -m abe -M email@address
module purge
module load intel-compiler/11.1.073
export OMP_NUM_THREADS=4
cd $WORKDIR
./myprog
您可以使用omp_set_num_threads()来设置程序中的线程数。
要使用OMP_NUM_THREADS
外部指定的值,需要使用std::getenv从环境变量中读取它。请确保1)将字符串结果转换为数字,2)在未设置的情况下对值进行消毒。
unsigned int thread_qty = std::max(atoi(std::getenv("OMP_NUM_THREADS")), 1);
omp_set_num_threads(thread_qty);
如果您将环境变量OMP_NUM_THREADS
设置为某个值,并且从不触及代码中的线程数(例如通过omp_set_num_threads()
),您的代码将使用
- 禁用动态调整(
OMP_DYNAMIC=FALSE
/omp_set_dynamic(0)
):代码将使用OMP_NUM_THREADS
线程 - 启用动态调整(
OMP_DYNAMIC=TRUE
/omp_set_dynamic(1)
):代码将使用最多OMP_NUM_THREADS
线程(但可能使用更少)。
所以,只使用OMP_NUM_THREADS
,不要在源代码中指定任何线程数
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 将数组的地址分配给变量并删除
- 为"adjacent"变量赋值时出现问题
- enum是C++中的宏变量还是整数变量
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- 用C++中的一个变量定义一个常量
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 你能重载对象变量名本身返回的内容吗
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 尝试通过多个向量访问变量时,向量下标超出范围
- 试图让变量检查数组中的某些内容
- Cpp-Tuple使用带有变量的get
- 将包含C样式数组的对象初始化为成员变量(C++)
- 当vector是tje全局变量时,c++中vector的内存管理
- 通过多个头文件使用常量变量
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 执行函数时导致崩溃的变量
- 初始化变量以进行 omp 缩减