NBSEBLOCKO: Difference between revisions
No edit summary |
No edit summary |
||
Line 23: | Line 23: | ||
{{NB|mind|Parallelization over bands with {{TAG|NBSEBLOCKV}} does not work with the old BSE driver, i.e., {{TAG|IBSE}}{{=}}0}} | {{NB|mind|Parallelization over bands with {{TAG|NBSEBLOCKV}} does not work with the old BSE driver, i.e., {{TAG|IBSE}}{{=}}0}} | ||
We recommend using parallelization over bands only if the number of MPI ranks in the calculation exceeds <math>\text{total ranks}</math> | We recommend using parallelization over bands only if the number of MPI ranks in the calculation exceeds <math>\text{total ranks}</math>. | ||
== Related tags and sections == | == Related tags and sections == |
Revision as of 12:57, 12 June 2024
NBSEBLOCKO = [integer]
Default: NBSEBLOCKO | = -1 |
Description: NBSEBLOCKO specifies the blocking factor for the occupied states when setting up the BSE Hamiltonian.
By default, the construction of the BSE Hamiltonian in VASP is parallelized over k-points, such that each MPI rank can compute a pair of k-points. This way the BSE Hamiltonian setup can be parallelized with
or for spin-polarized case
- ,
where is the total number of k-points in the full Brillouin zone. However, if a large number of MPI ranks is used in a calculation with too few k-point, this leads to load imbalance, where some of the MPI ranks will have no data to compute. In such cases, it is recommended to use parallelization over bands. If the parallelization over bands is used, all occupied (unoccupied) bands are divided into
and
blocks, respectively.
Such a band blocking allows VASP to parallelize the setup of the matrix with
or for spin-polarized case
If neither nor is specified, no paralliziation over bands is used and and .
Mind: Parallelization over bands with NBSEBLOCKV does not work with the old BSE driver, i.e., IBSE=0 |
We recommend using parallelization over bands only if the number of MPI ranks in the calculation exceeds .
Related tags and sections
BSE, NBSEBLOCKV, BSE calculations