LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
|
Namespaces | |
namespace | version |
Classes | |
class | LibraryException |
Unable to load library. More... | |
class | ModuleImporter |
Base class that defines an interface for importing Python modules. More... | |
class | NoThreadsException |
No threading library is available. More... | |
class | PythonModuleImporter |
Functions | |
std::string | libraryExtension () |
Return filename extension for libraries. More... | |
std::string | getLibraryFilename (std::string const &name) |
Get filename for library. More... | |
bool | canLoadLibrary (std::string const &libName) |
Return whether we can load a library. More... | |
template<typename T > | |
T * | loadSymbol (std::string const &libName, std::string const &symName) |
Load a symbol from a dynamic library. More... | |
bool | haveThreads () |
Are threaded packages available? More... | |
void | setNumThreads (unsigned int numThreads) |
Set number of threads to use. More... | |
unsigned int | getNumThreads () |
Get maximum number of threads we might use. More... | |
bool | disableImplicitThreading () |
Disable threading that has not been set explicitly. More... | |
void | installPythonModuleImporter () |
PYBIND11_MODULE (cppimport, mod) | |
PYBIND11_MODULE (threads, mod) | |
Variables | |
bool const | haveOpenBlas = loadOpenBlas() |
Is OpenBLAS available? More... | |
bool const | haveMkl = loadMkl() |
Is MKL available? More... | |
std::string const | allowEnvvar = "LSST_ALLOW_IMPLICIT_THREADS" |
Environment variable to allow implicit threading. More... | |
bool lsst::base::canLoadLibrary | ( | std::string const & | libName | ) |
Return whether we can load a library.
The proper filename extension will be added to the library name unless one is specified.
libName | Library name |
Definition at line 37 of file library.cc.
bool lsst::base::disableImplicitThreading | ( | ) |
Disable threading that has not been set explicitly.
Some threaded packages implicitly use multiple threads if the user doesn't explicitly state the number of desired threads. However, this can interfere with operations that are parallelised at a higher level. This function will disable threading unless the user has explicitly specified the number of desired threads through environment variables.
This behavior may be disabled by setting the environment variable specified by allowEnvvar.
This is principally intended for Linux machines (we explicitly load .so dynamic libraries); MacOS has its own way of doing threading (Grand Central Dispatch) that throttles threads to avoid overwhelming the machine.
@ return whether we disabled threading
Definition at line 132 of file threads.cc.
std::string lsst::base::getLibraryFilename | ( | std::string const & | name | ) |
Get filename for library.
We'll add the typical filename extension for the platform unless the user specifies a ".so" or ".dylib" extension.
Definition at line 27 of file library.cc.
unsigned int lsst::base::getNumThreads | ( | ) |
Get maximum number of threads we might use.
Returns the maximum value of the number of threads being used by the threading libraries that are available.
Definition at line 120 of file threads.cc.
bool lsst::base::haveThreads | ( | ) |
void lsst::base::installPythonModuleImporter | ( | ) |
Definition at line 60 of file cppimport.cc.
std::string lsst::base::libraryExtension | ( | ) |
Return filename extension for libraries.
Typically ".so" for Linux and ".dylib" for Mac.
Definition at line 17 of file library.cc.
T * lsst::base::loadSymbol | ( | std::string const & | libName, |
std::string const & | symName | ||
) |
lsst::base::PYBIND11_MODULE | ( | cppimport | , |
mod | |||
) |
Definition at line 62 of file cppimport.cc.
lsst::base::PYBIND11_MODULE | ( | threads | , |
mod | |||
) |
Definition at line 32 of file threads.cc.
void lsst::base::setNumThreads | ( | unsigned int | numThreads | ) |
Set number of threads to use.
NoThreadsException | if no threading library is available |
Definition at line 107 of file threads.cc.
std::string const lsst::base::allowEnvvar = "LSST_ALLOW_IMPLICIT_THREADS" |
|
extern |
Is MKL available?
Definition at line 105 of file threads.cc.
|
extern |
Is OpenBLAS available?
Definition at line 104 of file threads.cc.