Algorithms and data structures for massively parallel generic adaptive finite element codes

Wolfgang Bangerth, Carsten Burstedde, Timo Heister, Martin Kronbichler

Research output: Contribution to journalArticlepeer-review

154 Scopus citations

Abstract

Today's largest supercomputers have 100,000s of processor cores and offer the potential to solve partial differential equations discretized by billions of unknowns. However, the complexity of scaling to such large machines and problem sizes has so far prevented the emergence of generic software libraries that support such computations, although these would lower the threshold of entry and enable many more applications to benefit from large-scale computing. We are concerned with providing this functionality for mesh-adaptive finite element computations. We assume the existence of an "oracle" that implements the generation and modification of an adaptive mesh distributed across many processors, and that responds to queries about its structure. Based on querying the oracle, we develop scalable algorithms and data structures for generic finite element methods. Specifically, we consider the parallel distribution of mesh data, global enumeration of degrees of freedom, constraints, and postprocessing. Our algorithms remove the bottlenecks that typically limit large-scale adaptive finite element analyses. We demonstrate scalability of complete finite element workflows on up to 16,384 processors. An implementation of the proposed algorithms, based on the open source software p4est as mesh oracle, is provided under an open source license through the widely used deal.II finite element software library. © 2011 ACM 0098-3500/2011/12-ART10 $\$$10.00.
Original languageEnglish (US)
Pages (from-to)1-28
Number of pages28
JournalACM Transactions on Mathematical Software
Volume38
Issue number2
DOIs
StatePublished - Dec 1 2011
Externally publishedYes

Fingerprint

Dive into the research topics of 'Algorithms and data structures for massively parallel generic adaptive finite element codes'. Together they form a unique fingerprint.

Cite this