Intel® oneAPI Math Kernel Library
Ask questions and share information with other developers who use Intel® Math Kernel Library.
7122 Discussions

How to set number of LAPACK threads during runtime?

hakkelt
Beginner
541 Views

I want to set the number of BLAS+LAPACK threads but not FFT. The documentation page Threading Control states that I can specifically set the thread number for different domains, but this page only mentions BLAS, not LAPACK. Another page of documentation (MKL_DOMAIN_NUM_THREADS) shows, however, that the MKL_DOMAIN_LAPACK environment variable is available, suggesting that there should be a "LAPACK" domain.

In practice, I experienced that setting the BLAS threads doesn't affect the number of LAPACK threads (e.g., when calculating SVD). I only managed to control the number of threads for the LAPACK functions by setting the number of threads for MKL_DOMAIN_ALL.

Is there any way to change only the number of LAPACK threads during runtime?

0 Kudos
1 Solution
Ruqiu_C_Intel
Moderator
268 Views

Thank you for the reply with the introduction of your project .

Based on your inputs, we will consider to add the thread setting for MKL_DOMAIN_LAPACK in the future release.


View solution in original post

0 Kudos
3 Replies
Ruqiu_C_Intel
Moderator
371 Views

Thanks for posting the issue.

You are right, MKL_DOMAIN_LAPACK doesn't enable in C interface yet. Threading Control states correct, another page of documentation (MKL_DOMAIN_NUM_THREADS) should be updated in the future.

Is it sufficient to use MKL_DOMAIN_ALL instead of MKL_DOMAIN_LAPACK ? If not, how important is it for your project to enable set MKL_DOMAIN_LAPACK thread numbers? We would appreciate it if you could share your project information.


Regards,

ruqiu



0 Kudos
hakkelt
Beginner
297 Views

Hi Ruqui,

Thanks for your response. For the specific project through which I encountered the problem, setting MKL_DOMAIN_ALL suffices. Looking at the broader picture, however, it would be nice to have the option of setting MKL_DOMAIN_LAPACK, or at least setting MKL_DOMAIN_LAPACK together with MKL_DOMAIN_BLAS.

I'm working on a research project, and I write codes in Julia programming language. I use a simple Julia package (MKL.jlthat automatically switches the BLAS+LAPACK backend from OpenBLAS to MKL. In Julia, there is a function (BLAS.set_num_threads) that sets the BLAS+LAPACK thread number when OpenBLAS is used, but it can only call mkl_domain_set_num_threads with MKL_DOMAIN_BLAS when MKL is active.

The reason why it is not viable to set MKL_DOMAIN_ALL when BLAS.set_num_threads is called is that there is another Julia package (FFTW.jl) that offers MKL as an optional backend, and this package also has a function that sets the number of threads used by FFT functions...

In my case, I need to set the BLAS/LAPACK/FFTW thread number because part of my program contains nested parallelism. In these parts, I needed to disable BLAS/LAPACK/FFTW threading temporarily, and therefore, setting threads for the "ALL" domain is fine. On the other hand, the lack of controllability of LAPACK threads makes it impossible to write convenient wrappers that allow users to forget about the backends they are using.

0 Kudos
Ruqiu_C_Intel
Moderator
269 Views

Thank you for the reply with the introduction of your project .

Based on your inputs, we will consider to add the thread setting for MKL_DOMAIN_LAPACK in the future release.


0 Kudos
Reply