Turn off OpenMP
-
20-09-2019 - |
Question
In my C++ program, I'd like to run its executable sometimes with and sometimes without using OpenMP (i.e. multi-threading or single-threading). I am considering any of the following two cases how my code is using OpenMP:
(1) Assume that my code is only having #include <omp.h>
and OpenMP directives.
(2) Same as (1) and my code further calls OpenMP functions like omp_get_thread_num()
.
In order not to have different code for different running, is it the only way using some self-defined precompiler variable to guard where OpenMP appears in my code ?
Thanks and regards!
Solution
Hi the easiest way to do this is
omp_set_num_threads(m_iUseableProcessors);
where m_iUseableProcessors
is the number of processors you want to split the calculation over. I don't know how to do it without the OpenMP functions. You could probably #ifdef
them out, but that makes you turn off OpenMP at compile time.
OTHER TIPS
You can use the environment variable:
set OMP_NUM_THREADS=1
Actually, it will not turn OpenMP off. It will force OpenMP to create only one thread for an application. It works without recompilation. I use this variable to test scalability on 1, 2, 3, 4 etc threads.
You can put the include as follows:
#ifdef _OPENMP_
#include<omp.h>
#endif
Now if you run your program without -fopenmp flag, it would ignore openmp directives
In addition to the suggestion of _OPENMP
, you might find it useful to use C99's _Pragma
(or __pragma
, if you use some C++ compilers - see this StackOverflow question for details) to prevent your code from being littered with #ifdef _OPENMP
and #endif
, thereby reducing the lines associated with conditional compilation by 3x, and otherwise giving you O(1) control over O(n) instances of OpenMP annotations.
For example, I use the following style in my C99 OpenMP codes. The changes to support C++ should be fairly modest, although possibly compiler-specific (in which case, macros like __GNUC__
, __clang__
, __INTEL_COMPILER
, etc. may be useful).
#ifndef PRAGMA_OPENMP_H
#define PRAGMA_OPENMP_H
#if defined(_OPENMP) && ( __STDC_VERSION__ >= 199901L )
#define PRAGMA(x) _Pragma(#x)
#define OMP_PARALLEL PRAGMA(omp parallel)
#define OMP_PARALLEL_FOR PRAGMA(omp parallel for schedule(static))
#define OMP_FOR PRAGMA(omp for schedule(static))
#define OMP_PARALLEL_FOR_COLLAPSE(n) PRAGMA(omp parallel for collapse(n) schedule(static))
#define OMP_PARALLEL_FOR_COLLAPSE2 OMP_PARALLEL_FOR_COLLAPSE(2)
#define OMP_PARALLEL_FOR_COLLAPSE3 OMP_PARALLEL_FOR_COLLAPSE(3)
#define OMP_PARALLEL_FOR_COLLAPSE4 OMP_PARALLEL_FOR_COLLAPSE(4)
#define OMP_PARALLEL_FOR_REDUCE_ADD(r) PRAGMA(omp parallel for reduction (+ : r) schedule(static))
#else
#warning No OpenMP, either because compiler does not understand OpenMP or C99 _Pragma.
#define OMP_PARALLEL
#define OMP_PARALLEL_FOR
#define OMP_FOR
#define OMP_PARALLEL_FOR_COLLAPSE(n)
#define OMP_PARALLEL_FOR_COLLAPSE2
#define OMP_PARALLEL_FOR_COLLAPSE3
#define OMP_PARALLEL_FOR_COLLAPSE4
#define OMP_PARALLEL_FOR_REDUCE_ADD(r)
#endif
#endif // PRAGMA_OPENMP_H