OpenLB 1.7
Loading...
Searching...
No Matches
olbInit.cpp
Go to the documentation of this file.
1/* This file is part of the OpenLB library
2 *
3 * Copyright (C) 2008 Jonas Latt
4 * E-mail contact: info@openlb.net
5 * The most recent release of OpenLB can be downloaded at
6 * <http://www.openlb.net/>
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License
10 * as published by the Free Software Foundation; either version 2
11 * of the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public
19 * License along with this program; if not, write to the Free
20 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21 * Boston, MA 02110-1301, USA.
22*/
23
24#include "olbInit.h"
25
26#include "io/ostreamManager.h"
27
30
32
33namespace olb {
34
35namespace singleton {
36
38{
39 static ThreadPool instance;
40 return instance;
41}
42
43}
44
45void olbInit(int *argc, char ***argv, bool multiOutput, bool verbose)
46{
47 // create an OstreamManager object in order to enable multi output
48 olb::OstreamManager clout(std::cout, "olbInit");
49 clout.setMultiOutput(multiOutput);
50 singleton::mpi().init(argc, argv, verbose);
51
52#ifdef PARALLEL_MODE_OMP
53 singleton::omp().init(verbose);
54#endif
55
56 int nThreads = 1;
57 if (const char* envOlbNumThreads = std::getenv("OLB_NUM_THREADS")) {
58 nThreads = std::stoi(envOlbNumThreads);
59 }
60 singleton::pool().init(nThreads, verbose);
61
63 #ifdef PLATFORM_GPU_CUDA
65 #endif
66}
67
68}
class for marking output with some text
void setMultiOutput(bool b)
enable message output for all MPI processes, disabled by default
Pool of threads for CPU-based background processing.
Definition threadPool.h:47
void init(int nThreads, bool verbose)
Initialization to be called by olbInit.
Definition threadPool.h:99
void init(int *argc, char ***argv, bool verbose=true)
Initializes the mpi manager.
Wrapper functions that simplify the use of MPI.
ThreadPool & pool()
Definition olbInit.cpp:37
MpiManager & mpi()
ompManager omp()
Top level namespace for all of OpenLB.
void checkPlatform< Platform::GPU_CUDA >()
Verifies availability of CUDA device and MPI support.
void olbInit(int *argc, char ***argv, bool multiOutput, bool verbose)
Definition olbInit.cpp:45
LB initialisation routine – header file.
void init(bool verbose=true)