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 条
[21]   Implications of the Turing machine model of computation for processor and programming language design [J].
Hunter, G .
APPLICATIONS AND SCIENCE OF NEURAL NETWORKS, FUZZY SYSTEMS, AND EVOLUTIONARY COMPUTATION VI, 2003, 5200 :103-112
[22]   Phoenix: a parallel programming model for accommodating dynamically joining/leaving resources [J].
Taura, K ;
Kaneda, K ;
Endo, T ;
Yonezawa, A .
ACM SIGPLAN NOTICES, 2003, 38 (10) :215-228
[23]   Towards a programming model and middleware architecture for self-configuring systems [J].
Bellur, Umesh ;
Narendra, N. C. .
2006 1ST INTERNATIONAL CONFERENCE ON COMMUNICATION SYSTEMS SOFTWARE & MIDDLEWARE, VOLS 1 AND 2, 2006, :190-+
[24]   A DISTRIBUTED-PROGRAMMING MODEL FOR REAL-TIME INDUSTRIAL CONTROL [J].
BAYNE, JS .
CONTROL ENGINEERING PRACTICE, 1995, 3 (08) :1133-1138
[25]   An object-oriented programming paradigm based on Ada 95 [J].
Loeper, H ;
Khattab, A ;
Neubert, P ;
El-Gabali, M .
KUWAIT JOURNAL OF SCIENCE & ENGINEERING, 1998, 25 (02) :275-296
[26]   The Design and Formalization of Mezzo, a Permission-Based Programming Language [J].
Balabonski, Thibaut ;
Pottier, Francois ;
Protzenko, Jonathan .
ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2016, 38 (04)
[27]   Distributed Pipeline Programming Framework for State-Based Pattern [J].
Liao, Yin ;
Sun, Guang-Zhong ;
Chen, Guoliang .
2009 EIGHTH INTERNATIONAL CONFERENCE ON GRID AND COOPERATIVE COMPUTING, PROCEEDINGS, 2009, :201-207
[28]   Ripple: Improved Architecture and Programming Model for Bulk Synchronous Parallel Style of Analytics [J].
Spreitzer, Mike ;
Steinder, Malgorzata ;
Whalley, Ian .
2013 IEEE 33RD INTERNATIONAL CONFERENCE ON DISTRIBUTED COMPUTING SYSTEMS (ICDCS), 2013, :460-469
[29]   Reactors: A data-oriented synchronous/asynchronous programming model for distributed applications [J].
Field, John ;
Marinescu, Maria-Cristina ;
Stefansen, Christian .
THEORETICAL COMPUTER SCIENCE, 2009, 410 (2-3) :168-201
[30]   AEMINIUM: A Permission Based Concurrent-by-Default Programming Language Approach [J].
Stork, Sven ;
Naden, Karl ;
Sunshine, Joshua ;
Mohr, Manual ;
Fonseca, Alcides ;
Marques, Paulo ;
Aldrich, Jonathan .
ACM SIGPLAN NOTICES, 2014, 49 (06) :26-26