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 条
[41]   CloudFlow: A data-aware programming model for cloud workflow applications on modern HPC systems [J].
Zhang, Fan ;
Malluhi, Qutaibah M. ;
Elsayed, Tamer ;
Khan, Samee U. ;
Li, Keqin ;
Zomaya, Albert Y. .
FUTURE GENERATION COMPUTER SYSTEMS-THE INTERNATIONAL JOURNAL OF ESCIENCE, 2015, 51 :98-110
[42]   Object-based subcontracting for parallel programming on loosely-coupled distributed systems [J].
Joshi, RK ;
Ram, DJ .
JOURNAL OF PROGRAMMING LANGUAGES, 1996, 4 (03) :169-183
[43]   The programming method of MATLAB language for solving AI-based digital health problems [J].
Jiang S. .
Journal of Commercial Biotechnology, 2022, 27 (01) :151-159
[44]   Applying property-based testing in teaching safety-critical system programming [J].
Fredlund, Lars-Ake ;
Herranz, Angel ;
Marino, Julio .
PROCEEDINGS 41ST EUROMICRO CONFERENCE ON SOFTWARE ENGINEERING AND ADVANCED APPLICATIONS SEAA 2015, 2015, :309-316
[45]   An approach to multicore parallelism using functional programming: A case study based on Presburger Arithmetic [J].
Phan, Anh-Dung ;
Hansen, Michael R. .
JOURNAL OF LOGICAL AND ALGEBRAIC METHODS IN PROGRAMMING, 2015, 84 (01) :2-18
[46]   A Psychologically Based Model of Voter Turnout [J].
Li, Ming ;
Majumdar, Dipjyoti .
JOURNAL OF PUBLIC ECONOMIC THEORY, 2010, 12 (05) :979-1002
[47]   A TRAINING COMPUTER CLUSTER MODELING BASED ON RASPBERRY SINGLE-BOARD COMPUTERS FOR TEACHING DISTRIBUTED PROGRAMMING [J].
Sitsylitsyn, Yurii O. ;
Osadchyi, Viacheslav V. .
INFORMATION TECHNOLOGIES AND LEARNING TOOLS, 2021, 81 (01) :97-108
[48]   How a Language-based GUI Generator Can Influence the Teaching of Object-Oriented Programming [J].
Dewan, Prasun .
SIGCSE 12: PROCEEDINGS OF THE 43RD ACM TECHNICAL SYMPOSIUM ON COMPUTER SCIENCE EDUCATION, 2011, :69-74
[49]   Application of multi-gene genetic programming based on separable functional network for landslide displacement prediction [J].
Chen, Jiejie ;
Zeng, Zhigang ;
Jiang, Ping ;
Tang, Huiming .
NEURAL COMPUTING & APPLICATIONS, 2016, 27 (06) :1771-1784
[50]   A representative model based algorithm for maximal contractions [J].
Jiang DongChen ;
Lou YiHua ;
Jin Yi ;
Luo Jie ;
Li Wei .
SCIENCE CHINA-INFORMATION SCIENCES, 2013, 56 (01) :1-13