Affiliation:
1. IBM T.J. Watson Research Center, Yorktown Heights, NY
2. UCLA, Los Angeles, CA
3. IBM Toronto Laboratory, Markham, ON, Canada
Abstract
It is now well established that the device scaling predicted by Moore's Law is no longer a viable option for increasing the clock frequency of future uniprocessor systems at the rate that had been sustained during the last two decades. As a result, future systems are rapidly moving from uniprocessor to multiprocessor configurations, so as to use parallelism instead of frequency scaling as the foundation for increased compute capacity. The dominant emerging multiprocessor structure for the future is a
Non-Uniform Cluster Computing
(NUCC) system with nodes that are built out of multi-core SMP chips with non-uniform memory hierarchies, and interconnected in horizontally scalable cluster configurations such as blade servers. Unlike previous generations of hardware evolution, this shift will have a major impact on existing software. Current OO language facilities for concurrent and distributed programming are inadequate for addressing the needs of NUCC systems because they do not support the notions of non-uniform data access within a node, or of tight coupling of distributed nodes.We have designed a modern object-oriented programming language, X10, for high performance, high productivity programming of NUCC systems. A member of the
partitioned global address space
family of languages, X10 highlights the explicit reification of locality in the form of
places
}; lightweight activities embodied in
async
,
future
,
foreach
, and
ateach
constructs; a construct for termination detection (
finish
); the use of lock-free synchronization (
atomic blocks
); and the manipulation of cluster-wide global data structures. We present an overview of the X10 programming model and language, experience with our reference implementation, and results from some initial productivity comparisons between the X10 and Java™ languages.
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Cited by
523 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. M‐DFCPP: A runtime library for multi‐machine dataflow computing;Concurrency and Computation: Practice and Experience;2024-08-07
2. Runtime support for CPU-GPU high-performance computing on distributed memory platforms;Frontiers in High Performance Computing;2024-07-19
3. When Is Parallelism Fearless and Zero-Cost with Rust?;Proceedings of the 36th ACM Symposium on Parallelism in Algorithms and Architectures;2024-06-17
4. Developing performance portable plasma edge simulations: A survey;Computer Physics Communications;2024-05
5. Read/write fence-free work-stealing with multiplicity;Journal of Parallel and Distributed Computing;2024-04