A model for correlation-based choreographic programming

被引:0
作者
Giallorenzo, Saverio [1 ,2 ]
Montesi, Fabrizio [3 ]
Gabbrielli, Maurizio [2 ]
机构
[1] INRIA, Sophia Antipolis, France
[2] Univ Bologna, Dept Comp Sci & Engn, Bologna, Italy
[3] Univ Southern Denmark, Dept Math & Comp Sci, Odense, Denmark
关键词
Concurrency; Distributed programming; Service-oriented computing; Choreographic programming; CALCULUS;
D O I
10.7717/peerj-cs.1907
中图分类号
TP18 [人工智能理论];
学科分类号
081104 ; 0812 ; 0835 ; 1405 ;
摘要
Choreographies provide a clear way to specify the intended communication behaviour of concurrent and distributed systems. Previous theoretical work investigated the translation of choreographies into (models of) programs based on message passing. However, existing theories still present a gap between how they model communications-using channel names & agrave; la CCS or p-calculus-and implementations-which use lower-level mechanisms for message routing. We start bridging this gap with a new formal framework called Applied Choreographies. In Applied Choreographies, developers write choreographies in a familiar syntax (from previous work) and reason about their behaviour through simple, abstract name-based communication semantics. The framework offers state-of-the-art features of choreographic models, e.g., modular programming supported via choreographic types. To provide its correctness guarantee, Applied Choreographies comes with a compilation procedure that transforms a choreography into a low-level, implementation-adherent calculus of Service-Oriented Computing (SOC). To manage the complexity of the compilation, we divide its formalisation and proof into three stages, respectively dealing with: (a) the translation of name-based communications into their SOC equivalents, namely, using correlation mechanisms based on message data; (b) the projection of the given choreography into a composition of partial, single-participant choreographies (towards their translation into SOC processes); (c) the translation of partial choreographies and the distribution of global, choreography-level state into local SOC processes. We provide behavioural correspondence results for each stage. Thus, given a choreography specification, we guarantee to synthesise its faithful service-oriented implementation.
引用
收藏
页数:47
相关论文
共 50 条
[31]   A Programming Language Approach to Internet-Based Virtual Computing Environment [J].
王戟 ;
沈锐 ;
王怀民 .
Journal of Computer Science & Technology, 2011, 26 (04) :600-615
[32]   A Programming Language Approach to Internet-Based Virtual Computing Environment [J].
Ji Wang ;
Rui Shen ;
Huai-Min Wang .
Journal of Computer Science and Technology, 2011, 26 :600-615
[33]   A Programming Language Approach to Internet-Based Virtual Computing Environment [J].
Wang, Ji ;
Shen, Rui ;
Wang, Huai-Min .
JOURNAL OF COMPUTER SCIENCE AND TECHNOLOGY, 2011, 26 (04) :600-615
[34]   AN OBJECT-BASED TOOL AND METHODOLOGICAL APPROACH FOR DISTRIBUTED-PROGRAMMING [J].
CAPEL, M ;
TROYA, JM .
SOFTWARE-CONCEPTS AND TOOLS, 1994, 15 (04) :177-195
[35]   Enhancing Spectrum-Based Fault Localization in the Context of Reactive Programming [J].
Aondowase James Orban .
2025 IEEE CONFERENCE ON SOFTWARE TESTING, VERIFICATION AND VALIDATION, ICST, 2025, :788-790
[36]   ABEL - A Domain Specific Framework for Programming with Attribute-Based Communication [J].
De Nicola, Rocco ;
Duong, Tan ;
Loreti, Michele .
COORDINATION MODELS AND LANGUAGES, COORDINATION 2019, 2019, 11533 :111-128
[37]   ConMR: Concurrent MapReduce Programming Model for Large Scale Shared-Data Applications [J].
Zhang, Fan ;
Malluhi, Qutaibah M. ;
Elsyed, Tamer M. .
2013 42ND ANNUAL INTERNATIONAL CONFERENCE ON PARALLEL PROCESSING (ICPP), 2013, :671-679
[38]   Fractional-order viscoelastic model of musculoskeletal tissues: correlation with fractals [J].
Guo, Jianqiao ;
Yin, Yajun ;
Peng, Gang .
PROCEEDINGS OF THE ROYAL SOCIETY A-MATHEMATICAL PHYSICAL AND ENGINEERING SCIENCES, 2021, 477 (2249)
[39]   AEMINIUM: A Permission-Based Concurrent-by-Default Programming Language Approach [J].
Stork, Sven ;
Naden, Karl ;
Sunshine, Joshua ;
Mohr, Manuel ;
Fonseca, Alcides ;
Marques, Paulo ;
Aldrich, Jonathan .
ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2014, 36 (01)
[40]   Programming interactions in collective adaptive systems byrelying on attribute-based communication [J].
Abd Alrahman, Yehia ;
De Nicola, Rocco ;
Loreti, Michele .
SCIENCE OF COMPUTER PROGRAMMING, 2020, 192