Please use this identifier to cite or link to this item:
https://hdl.handle.net/10923/26797
Type: | Artigo |
Title: | An internal domain-specific language for expressing linear pipelines: a proof-of-concept with MPI in Rust |
Author(s): | Faé, Leonardo Gibrowski |
Advisor: | Griebler, Dalvan |
Issue Date: | 2024 |
Keywords: | PARALLEL PROGRAMMING DOMAIN SPECIFIC LANGUAGE PARALLELISM ABSTRACTION MULTI-THREAD MPI |
Abstract: | Parallel computation is necessary in order to process massive volumes of data in a timely manner. There are many parallel programming interfaces and environments, each with their own idiosyncrasies. This, alongside non-deterministic errors, make parallel programs notoriously challenging to write. Great effort has been put forth to make parallel programming for several environments easier. In this work, we propose a DSL for Rust, using the language’s source-to-source transformation facilities, that allows for automatic code generation for distributed environments that support the Message Passing Interface (MPI). Our DSL simplifies MPI’s quirks, allowing the programmer to focus almost exclusively on the computation at hand. Performance experiments show nearly or no runtime difference between our abstraction and manually written MPI code while resulting in less than half the lines of code. More elaborate code complexity metrics (Halstead) estimate from 4.5 to 14.7 times lower effort for expressing parallelism. |
URI: | https://hdl.handle.net/10923/26797 |
Appears in Collections: | TCC Ciência da Computação
|
All Items in PUCRS Repository are protected by copyright, with all rights reserved, and are licensed under a Creative Commons Attribution-NonCommercial 4.0 International License. Read more.