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] A DISTRIBUTED-PROGRAMMING MODEL FOR REAL-TIME INDUSTRIAL CONTROL
    BAYNE, JS
    CONTROL ENGINEERING PRACTICE, 1995, 3 (08) : 1133 - 1138
  • [22] An object-oriented programming paradigm based on Ada 95
    Loeper, H
    Khattab, A
    Neubert, P
    El-Gabali, M
    KUWAIT JOURNAL OF SCIENCE & ENGINEERING, 1998, 25 (02): : 275 - 296
  • [23] The Design and Formalization of Mezzo, a Permission-Based Programming Language
    Balabonski, Thibaut
    Pottier, Francois
    Protzenko, Jonathan
    ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2016, 38 (04):
  • [24] Distributed Pipeline Programming Framework for State-Based Pattern
    Liao, Yin
    Sun, Guang-Zhong
    Chen, Guoliang
    2009 EIGHTH INTERNATIONAL CONFERENCE ON GRID AND COOPERATIVE COMPUTING, PROCEEDINGS, 2009, : 201 - 207
  • [25] Ripple: Improved Architecture and Programming Model for Bulk Synchronous Parallel Style of Analytics
    Spreitzer, Mike
    Steinder, Malgorzata
    Whalley, Ian
    2013 IEEE 33RD INTERNATIONAL CONFERENCE ON DISTRIBUTED COMPUTING SYSTEMS (ICDCS), 2013, : 460 - 469
  • [26] Reactors: A data-oriented synchronous/asynchronous programming model for distributed applications
    Field, John
    Marinescu, Maria-Cristina
    Stefansen, Christian
    THEORETICAL COMPUTER SCIENCE, 2009, 410 (2-3) : 168 - 201
  • [27] AEMINIUM: A Permission Based Concurrent-by-Default Programming Language Approach
    Stork, Sven
    Naden, Karl
    Sunshine, Joshua
    Mohr, Manual
    Fonseca, Alcides
    Marques, Paulo
    Aldrich, Jonathan
    ACM SIGPLAN NOTICES, 2014, 49 (06) : 26 - 26
  • [28] A Programming Language Approach to Internet-Based Virtual Computing Environment
    王戟
    沈锐
    王怀民
    JournalofComputerScience&Technology, 2011, 26 (04) : 600 - 615
  • [29] A Programming Language Approach to Internet-Based Virtual Computing Environment
    Ji Wang
    Rui Shen
    Huai-Min Wang
    Journal of Computer Science and Technology, 2011, 26 : 600 - 615
  • [30] AN OBJECT-BASED TOOL AND METHODOLOGICAL APPROACH FOR DISTRIBUTED-PROGRAMMING
    CAPEL, M
    TROYA, JM
    SOFTWARE-CONCEPTS AND TOOLS, 1994, 15 (04) : 177 - 195