Skip to main content
Log in

Gillespie’s Stochastic Simulation Algorithm on MIC coprocessors

  • Published:
The Journal of Supercomputing Aims and scope Submit manuscript

Abstract

To investigate the behavior of biochemical systems, many runs of Gillespie’s Stochastic Simulation Algorithm (SSA) are generally needed, causing excessive computational costs on Central Processing Units (CPUs). Since all SSA runs are independent, the Intel Xeon Phi coprocessors based on the Many Integrated Core (MIC) architecture can be exploited to distribute the workload. We considered two execution modalities on MIC: one consisted in running exactly the same CPU code of SSA, while the other exploited MIC’s vector instructions to reuse the CPU code with only few modifications. MIC performance was compared with Graphics Processing Units (GPUs), specifically implemented in CUDA to optimize the use of memory hierarchy. Our results show that GPU largely outperforms MIC and CPU, but required a complete redesign of SSA. MIC allows a relevant speedup, especially when vector instructions are used, with the additional advantage of requiring minimal modifications to CPU code.

This is a preview of subscription content, log in via an institution to check access.

Access this article

Subscribe and save

Springer+ Basic
$34.99 /Month
  • Get 10 units per month
  • Download Article/Chapter or eBook
  • 1 Unit = 1 Article or 1 Chapter
  • Cancel anytime
Subscribe now

Buy Now

Price excludes VAT (USA)
Tax calculation will be finalised during checkout.

Instant access to the full article PDF.

Fig. 1
Fig. 2
Fig. 3

Similar content being viewed by others

References

  1. Aldridge BB, Burke JM, Lauffenburger DA, Sorger PK (2006) Physicochemical modelling of cell signalling pathways. Nat Cell Biol 8(11):1195–1203

    Article  Google Scholar 

  2. Bernaschi M, Bisson M, Salvadore F (2014) Multi-Kepler GPU vs. multi-Intel MIC for spin systems simulations. Comput Phys Commun 185(10):2495–2503

    Article  Google Scholar 

  3. Besozzi D, Cazzaniga P, Pescini D, Mauri G, Colombo S, Martegani E (2012) The role of feedback control mechanisms on the establishment of oscillatory regimes in the Ras/cAMP/PKA pathway in S. cerevisiae. EURASIP J Bioinform Syst Biol 2012(10)

  4. Cazzaniga P, Ferrara F, Nobile MS, Besozzi D, Mauri G (2015) Parallelizing biochemical stochastic simulations: a comparison of GPUs and Intel Xeon Phi processors. In: Malyshkin V (ed) Proceedings of 13th international conference on parallel computing technologies (PaCT 2015), LNCS, vol 9251, pp 363–374

  5. Fang J, Varbanescu AL, Imbernon B, Cecilia JM, Perez-Sanchez H (2014) Parallel computation of non-bonded interactions in drug discovery: Nvidia GPUs vs. Intel Xeon Phi. In: Proceedings of second international work-conference on bioinformatics and biomedical engineering (IWBBIO’14)

  6. Fang J, Varbanescu AL, Sips H, Zhang L, Che Y, Xu C (2013) Benchmarking Intel Xeon Phi to guide kernel design. Tech. Rep. PDS-2013-005, Delft University of Technology, The Netherlands

  7. Gillespie DT (1977) Exact stochastic simulation of coupled chemical reactions. J Phys Chem 81(25):2340–2361

    Article  Google Scholar 

  8. Gillespie DT (1992) A rigorous derivation of the chemical master equation. Phys A 188(1):404–425

    Article  Google Scholar 

  9. Halyo V, LeGresley P, Lujan P, Karpusenko V, Vladimirov A (2014) First evaluation of the CPU, GPGPU and MIC architectures for real time particle tracking based on Hough transform at the LHC. J Instrum 9 (04)

  10. Kent E, Hoops S, Mendes P (2012) Condor-COPASI: high-throughput computing for biochemical networks. BMC Syst Biol 6:91

  11. Kraus J, Pivanti M, Schifano SF, Tripiccione R, Zanella M (2013) Benchmarking GPUs with a parallel Lattice-Boltzmann code. In: 25th international symposium on computer architecture and high performance computing. IEEE, pp 160–167

  12. L’Ecuyer P, Simard R, Chen EJ, Kelton WD (2002) An object-oriented random-number package with many long streams and substreams. Oper Res 50(6):1073–1075

    Article  Google Scholar 

  13. Lyakh DI (2015) An efficient tensor transpose algorithm for multicore CPU, Intel Xeon Phi, and NVidia Tesla GPU. Comput Phys Commun 189:84–91

    Article  Google Scholar 

  14. Macchiarulo L (2008) A massively parallel implementation of Gillespie algorithm on FPGAs. In: International conference of the IEEE on Engineering in Medicine and Biology Society, pp 1343–1346

  15. Nickolls J, Dally WJ (2010) The GPU computing era. IEEE Micro 30(2):56–69

    Article  Google Scholar 

  16. Nobile MS, Besozzi D, Cazzaniga P, Mauri G, Pescini D (2012) A GPU-based multi-swarm PSO method for parameter estimation in stochastic biological systems exploiting discrete-time target series. In: Giacobini M, Vanneschi L, Bush W (eds) Evolutionary computation, machine learning and data mining in bioinformatics. Proceedings of 10th European conference, EvoBIO 2012, LNCS, vol 7246, pp 74–85

  17. Nobile MS, Besozzi D, Cazzaniga P, Mauri G, Pescini D (2013) cupSODA: a CUDA-powered simulator of mass-action kinetics. In: Malyshkin V (ed) Proceedings of 12th international conference on parallel computing technologies, LNCS, vol 7979, pp 344–357

  18. Nobile MS, Cazzaniga P, Besozzi D, Mauri G (2014) GPU-accelerated simulations of mass-action kinetics models with cupSODA. J Supercomput 69(1):17–24

    Article  Google Scholar 

  19. Nobile MS, Cazzaniga P, Besozzi D, Pescini D, Mauri G (2013) Reverse engineering of kinetic reaction networks by means of Cartesian Genetic Programming and Particle Swarm Optimization. In: IEEE congress of evolutionary computation, pp 1594–1601

  20. Nobile MS, Cazzaniga P, Besozzi D, Pescini D, Mauri G (2014) cuTauLeaping: a GPU-powered tau-leaping stochastic simulator for massive parallel analyses of biological systems. PLoS One 9:e91963

  21. Saltelli A, Ratto M, Andres T, Campolongo F, Cariboni J, Gatelli D, Saisana M, Tarantola S (2008) Global sensitivity analysis: the primer. Wiley, New York

    MATH  Google Scholar 

  22. Shimoda T, Suzuki S, Ohue M, Ishida T, Akiyama Y (2015) Protein–protein docking on hardware accelerators: comparison of GPU and MIC architectures. BMC Syst Biol 9(Suppl 1):S6

  23. Tian T, Burrage K (2005) Parallel implementation of stochastic simulation of large-scale cellular processes. In: 8th international conference on high-performance computing in Asia-Pacific region, pp 621–626

  24. Wilkinson D (2009) Stochastic modelling for quantitative description of heterogeneous biological systems. Nat Rev Genet 10(2):122–133

Download references

Acknowledgments

We acknowledge the CINECA award under the ISCRA initiative, for the availability of high-performance computing resources and support.

Author information

Authors and Affiliations

Authors

Corresponding author

Correspondence to Andrea Tangherloni.

Rights and permissions

Reprints and permissions

About this article

Check for updates. Verify currency and authenticity via CrossMark

Cite this article

Tangherloni, A., Nobile, M.S., Cazzaniga, P. et al. Gillespie’s Stochastic Simulation Algorithm on MIC coprocessors. J Supercomput 73, 676–686 (2017). https://doi.org/10.1007/s11227-016-1778-8

Download citation

  • Published:

  • Issue Date:

  • DOI: https://doi.org/10.1007/s11227-016-1778-8

Keywords

Navigation