ZMCintegral-v5.1: Support for multi-function integrations on GPUs

Xiao-Yan Cao,Jun-Jie Zhang
DOI: https://doi.org/10.1016/j.cpc.2021.107994
IF: 4.717
2021-08-01
Computer Physics Communications
Abstract:<p>In this new version of ZMCintegral, we have added the functionality of multi-function integrations, i.e. the ability to integrate more than 10<sup>3</sup> different functions on GPUs. The Python API remains the similar as the previous versions. For integrands less than 5 dimensions, it usually takes less than 10 minutes to finish the evaluation of 10<sup>3</sup> integrations on one Tesla v100 card. The performance scales linearly with the increasing of the GPUs.</p><h3 class="u-h4 u-margin-m-top u-margin-xs-bottom">New version program summary</h3><p><em>Program Title:</em> ZMCintegral</p><p><em>CPC Library link to program files:</em> <a href="https://doi.org/10.17632/p7wc7k6mpp.3">https://doi.org/10.17632/p7wc7k6mpp.3</a></p><p><em>Licensing provisions:</em> Apache-2.0</p><p><em>Programming language:</em> Python</p><p><em>Journal reference of previous version:</em> Hong-Zhong Wu, Jun-Jie Zhang, Long-Gang Pang, Qun Wang, Comput. Phys. Commun. 248 (2020) 106962 and Jun-Jie Zhang, Hong-Zhong Wu, Comput. Phys. Commun. 251 (2020) 107240</p><p><em>Does the new version supersede the previous version?:</em> Yes</p><p><em>Reasons for the new version:</em> When solving the Boltzmann equation with radiations [1], one encounters different collision integrals for different energy beams. In the relativistic QED plasma, the collision terms involve various Feynman graphs [2] and usually the contribution from each graph is of great interest. In these circumstances one needs to integrate many functions of different forms simultaneously. In our previous versions [3,4], we focused on single integration of high dimensions and functions with parameters. Therefore, it is necessary to include the functionality for integrating many functions which have different dimensions, forms and integration domains.</p><p><em>Summary of revisions:</em></p><p>• Multi-function Integrations</p><p>Suppose we have a series of integrations defined as<span class="display"><span class="formula"><span class="label">(1)</span><span class="math"><math>fn(x)=ancos(kn⋅x)+bnsin(kn⋅x),</math></span></span></span> where <span class="math"><math>n=1,2,3,...,100</math></span>. The above integration series can be treated as a set of Harmonic bases if one wishes to evaluate the contribution of each Harmonic mode. In our previous versions, these series cannot be manipulated in a convenient and efficient way. It is worth noting that the integration domains or dimensions can be different, for example<span class="display"><span class="formula"><span class="label">(2)</span><span class="math"><math>gn(x1,x2)=an|x1+x2|for 0</math></span></span></span> The support of multi-functions gives the users full flexibility to integrate as many different functions as possible.</p><p>• Test on GPUs</p><p>As an illustrative example, we report the solution of Eq. (1) with <span class="math"><math>x=(x1,x2,x3,x4)</math></span>, <span class="math"><math>an=bn=1</math></span>. The ranges for all components are taken to be <span class="math"><math>[0,1]</math></span> and <span class="math"><math>kn=(n+502π,n+502π,n+502π,n+502π)</math></span> such that the integration is highly fluctuating around the zero line. The hardware condition in this case is taken to be: Intel(R) Xeon(R) Silver 4110 CPU with 10 processors + one Nvidia Tesla V100 GPU. The results are shown in Fig. <a class="workspace-trigger" href="#fg0010">1</a>.</p><p><em>Nature of problem:</em> ZMCintegral is an easy to use Python package for doing high dimensional integrations on distributed GPU clusters. Using the Python libraries Numba [5] and Ray [6], as well as the NVIDIA CUDA [7] capability, ZMCintegral offers a succinct Python interface to evaluate numerical integrations for physical problems. In this updated version, we mainly focus on the problems where the users have various functions to integrate. These integrations can take different forms and domains.</p><p><em>Solution method:</em> This new version contains three Python classes. ZMCintegral_normal utilizes the stratified-sampling and heuristic-tree-search techniques, while ZMCintegral_functional and ZMCintegral_multifunctions use the direct-Monte Carlo method for each integrand which benefits mainly from the heavily distributed GPU clusters.</p><p><em>Additional comments including restrictions and unusual features:</em> If the integrations are high-dimensional (e.g. dimensionality of 8-12), users are encouraged to use ZMCintegral_normal. If the integrations are middle-dimensional (e.g. dimensionality of 1-7) but with a large parameter space, we suggest users to try ZMCintegral_functional. If the integrations contains many different integrands and domains (e.g. 10<sup>4</sup> different integrations), then ZMCintegral_multifunctions is suggested. The detailed instructions can be found here: [8].</p><h3 class="u-h4 u-margin-m-top u-margin-xs-bottom">References</h3><dl class="list"><dt class="list-label">[1]</dt>< <p>-Abstract Truncated-</p>
physics, mathematical,computer science, interdisciplinary applications
What problem does this paper attempt to address?