Hide metadata

dc.date.accessioned2020-03-13T19:03:58Z
dc.date.available2020-03-13T19:03:58Z
dc.date.created2019-07-05T13:20:36Z
dc.date.issued2019
dc.identifier.citationLagraviere, Jeremie Alexandre Emilien Langguth, Johannes Prugger, Martina Einkemmer, Lukas Ha, Hoai Phuong Cai, Xing . Performance optimization and modeling of fine-grained irregular communication in UPC. Scientific Programming. 2019, 2019:6825728, 1-20
dc.identifier.urihttp://hdl.handle.net/10852/74005
dc.description.abstractThe Unified Parallel C (UPC) programming language offers parallelism via logically partitioned shared memory, which typically spans physically disjoint memory subsystems. One convenient feature of UPC is its ability to automatically execute between-thread data movement, such that the entire content of a shared data array appears to be freely accessible by all the threads. The programmer friendliness, however, can come at the cost of substantial performance penalties. This is especially true when indirectly indexing the elements of a shared array, for which the induced between-thread data communication can be irregular and have a fine-grained pattern. In this paper, we study performance enhancement strategies specifically targeting such fine-grained irregular communication in UPC. Starting from explicit thread privatization, continuing with block-wise communication, and arriving at message condensing and consolidation, we obtained considerable performance improvement of UPC programs that originally require fine-grained irregular communication. Besides the performance enhancement strategies, the main contribution of the present paper is to propose performance models for the different scenarios, in the form of quantifiable formulas that hinge on the actual volumes of various data movements plus a small number of easily obtainable hardware characteristic parameters. These performance models help to verify the enhancements obtained, while also providing insightful predictions of similar parallel implementations, not limited to UPC, that also involve between-thread or between-process irregular communication. As a further validation, we also apply our performance modeling methodology and hardware characteristic parameters to an existing UPC code for solving a 2D heat equation on a uniform mesh.
dc.languageEN
dc.publisherIOS Press
dc.rightsAttribution 4.0 International
dc.rights.urihttps://creativecommons.org/licenses/by/4.0/
dc.titlePerformance optimization and modeling of fine-grained irregular communication in UPC
dc.typeJournal article
dc.creator.authorLagraviere, Jeremie Alexandre Emilien
dc.creator.authorLangguth, Johannes
dc.creator.authorPrugger, Martina
dc.creator.authorEinkemmer, Lukas
dc.creator.authorHa, Hoai Phuong
dc.creator.authorCai, Xing
cristin.unitcode185,15,5,35
cristin.unitnameForskningsgruppen for biomedisinsk informatikk
cristin.ispublishedtrue
cristin.fulltextoriginal
cristin.qualitycode1
dc.identifier.cristin1710351
dc.identifier.bibliographiccitationinfo:ofi/fmt:kev:mtx:ctx&ctx_ver=Z39.88-2004&rft_val_fmt=info:ofi/fmt:kev:mtx:journal&rft.jtitle=Scientific Programming&rft.volume=2019:6825728&rft.spage=1&rft.date=2019
dc.identifier.jtitleScientific Programming
dc.identifier.volume2019
dc.identifier.doihttps://doi.org/10.1155/2019/6825728
dc.identifier.urnURN:NBN:no-77117
dc.type.documentTidsskriftartikkel
dc.type.peerreviewedPeer reviewed
dc.source.issn1058-9244
dc.identifier.fulltextFulltext https://www.duo.uio.no/bitstream/handle/10852/74005/2/article98718.pdf
dc.type.versionPublishedVersion
cristin.articleid6825728
dc.relation.projectNFR/214113
dc.relation.projectEU/671657
dc.relation.projectNOTUR/NORSTORE/NN2849K
dc.relation.projectNFR/251186
dc.relation.projectNFR/231746
dc.relation.projectEU/611183


Files in this item

Appears in the following Collection

Hide metadata

Attribution 4.0 International
This item's license is: Attribution 4.0 International