MADNESS
version 0.9
|
The source is here.
This is one of the more computationally demanding examples - either run it on 50 or more nodes of jaguar or reduce the number of functions employed (value of NFUNC
in the source).
Poor distribution of work (load imbalance) is the largest reason for inefficient parallel execution within MADNESS. Poor data distribution (data imbalance) contributes to load imbalance and also leads to out-of-memory problems due to one or more processes having too much data. Thus, we are interested in uniform distribution of both work and data.
Many operations in MADNESS are entirely data driven (i.e., computation occurs in the processor that "owns" the data) since there is insufficient work to justify moving data between processes (e.g., computing the inner product between functions). However, a few expensive operations can have work shipped to other processors.
There are presently three load balancing mechanisms within MADNESS
Until the work stealing becomes production quality we must exploit the first two forms. The random work assignment is controlled by options in the FunctionDefaults class.
The process map (an instance of WorldDCPmapInterface) controls mapping of data to processors and it is actually quite easy to write your own (e.g., see WorldDCDefaultPmap or LevelPmap) that ensure uniform data distribution. However, you also seek to incorporate estimates of the computational cost into the distribution. The class LBDeuxPmap (deux since it is the second such class) in mra/lbdeux.h does this by examining the functions you request and using provided weights to estimate the computational cost. Communication costs are proportional to the number of broken links in the tree. Since some operations work in the scaling function basis, some in the wavelet basis, and some in non-standard form, there is an element of empiricism in getting best performance from most algorithms.
The example times how long it takes to perform the following operations
The process map (data distribution) is then modified using the LBDeux heuristic and the operations repeated.
/tmp/work/harrison % aprun -n 50 -d 12 -cc none ./dataloadbal Runtime initialized with 10 threads in the pool and affinity 1 0 2 Before load balancing project 2.57 truncate 9.18 differentiate 11.80 convolve 12.57 balance 0.00 project 2.74 truncate 9.08 differentiate 11.33 convolve 13.07 balance 0.00 project 2.80 truncate 8.84 differentiate 10.76 convolve 12.66 balance 2.19 After load balancing project 2.96 truncate 2.56 differentiate 3.28 convolve 9.81 balance 0.00 project 3.05 truncate 2.61 differentiate 3.46 convolve 9.24 balance 0.00 project 3.01 truncate 2.60 differentiate 3.25 convolve 9.30 balance 0.00