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

Files in This Item:
File Description SizeFormat 
2024_1_LEONARDO_GIBROWSKI_FAE_TCC.pdfTexto completo657,02 kBAdobe PDFOpen
View


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.