skip to main content
OSTI.GOV title logo U.S. Department of Energy
Office of Scientific and Technical Information

Title: UPC++ Specification v1.0, Draft 6

Technical Report ·
DOI:https://doi.org/10.2172/1430689· OSTI ID:1430689

UPC++ is a C++11 library providing classes and functions that support Partitioned Global Address Space (PGAS) programming. We are revising the library under the auspices of the DOE’s Exascale Computing Project, to meet the needs of applications requiring PGAS support. UPC++ is intended for implementing elaborate distributed data structures where communication is irregular or fine-grained. The UPC++ interfaces for moving non-contiguous data and handling memories with different optimal access methods are composable and similar to those used in conventional C++. The UPC++ programmer can expect communication to run at close to hardware speeds. The key facilities in UPC++ are global pointers, that enable the programmer to express ownership information for improving locality, one-sided communication, both put/get and RPC, futures and continuations. Futures capture data readiness state, which is useful in making scheduling decisions, and continuations provide for completion handling via callbacks. Together, these enable the programmer to chain together a DAG of operations to execute asynchronously as high-latency dependencies become satisfied.

Research Organization:
Lawrence Berkeley National Lab. (LBNL), Berkeley, CA (United States)
Sponsoring Organization:
USDOE Office of Science (SC), Advanced Scientific Computing Research (ASCR)
DOE Contract Number:
AC02-05CH11231
OSTI ID:
1430689
Country of Publication:
United States
Language:
English

Similar Records

UPC++ Specification v1.0, Draft 10
Technical Report · Fri Mar 15 00:00:00 EDT 2019 · OSTI ID:1430689

UPC++ Specification v1.0, Draft 8
Technical Report · Wed Sep 26 00:00:00 EDT 2018 · OSTI ID:1430689

UPC++ Specification v1.0, Draft 4
Technical Report · Wed Sep 27 00:00:00 EDT 2017 · OSTI ID:1430689

Related Subjects