TY - RPRT TI - Programming the Interactions of Collective Adaptive Systems by Relying on Attribute-based Communication ID - eprints3946 M1 - working_paper AV - public N2 - Collective adaptive systems are new emerging computational systems consisting of a large number of interacting components and featuring complex behaviour. These systems are usually distributed, heterogeneous, decentralised and interdependent, and are operating in dynamic and possibly unpredictable environments. Finding ways to understand and design these systems and, most of all, to model the interactions of their components, is a difficult but important endeavour. In this article we propose a language-based approach for programming the interactions of collective-adaptive systems by relying on attribute-based communication; a paradigm that permits a group of partners to communicate by considering their run-time properties and capabilities. We introduce AbC, a foundational calculus for attribute-based communication and show how its linguistic primitives can be used to program a complex and sophisticated variant of the well-known problem of Stable Allocation in Content Delivery Networks. Also other interesting case studies, from the realm of collective-adaptive systems, are considered. We also illustrate the expressive power of attribute-based communication by showing the natural encoding of other existing communication paradigms into AbC. KW - Computing methodologies - Distributed programming languages; Theory of computation - Distributed computing models; Operational semantics; Process calculi UR - https://arxiv.org/abs/1711.06092 PB - arXiv EP - 36 VL - arXiv:1711.06092 A1 - Abd Alrahman, Yehia Moustafa A1 - De Nicola, Rocco A1 - Loreti, Michele Y1 - 2017/// ER -