Stefan Marr | Johannes Kepler University Linz (original) (raw)

Papers by Stefan Marr

Research paper thumbnail of Domains: Sharing State in the Communicating Event-Loop Actor Model

The actor model is a message-passing concurrency model that avoids deadlocks and low-level data r... more The actor model is a message-passing concurrency model that avoids deadlocks and low-level data races by construction. This facilitates concurrent programming, especially in the context of complex interactive applications where modularity, security and fault-tolerance are required. The tradeoff is that the actor model sacrifices expressiveness and safety guarantees with respect to parallel access to shared state. In this paper we present domains as a set of novel language abstractions for safely encapsulating and sharing state within the actor model. We introduce four types of domains, namely immutable, isolated, observable and shared domains that each are tailored to a certain access pattern on that shared state. The domains are characterized with an operational semantics. For each we discuss how the actor model's safety guarantees are upheld even in the presence of conceptually shared state. Furthermore, the proposed language abstractions are evaluated with a case study in Scala comparing them to other synchonisation mechanisms to demonstrate their benefits in deadlock freedom, parallel reads, and enforced isolation.

Research paper thumbnail of Data interface + algorithms = efficient programs

Proceedings of the 9th International Workshop on Implementation, Compilation, Optimization of Object-Oriented Languages, Programs and Systems PLE - ICOOOLPS '14, 2014

ABSTRACT Finding the right algorithm--data structure combination is easy, but finding the right d... more ABSTRACT Finding the right algorithm--data structure combination is easy, but finding the right data structure for a set of algorithms is much less trivial. Moreover, using the same data representation throughout the whole program might be sub-optimal. Depending on several factors, often only known at runtime, some programs benefit from changing the data representation during execution. In this position paper we introduce the idea of Just-In-Time data structures, a combination of a data interface and a set of concrete data representations with different performance characteristics. These Just-In-Time data structures can dynamically swap their internal data representation when the cost of swapping is payed back many times in the remainder of the computation. To make Just-In-Time data structures work, research is needed at three fronts: 1. We need to better understand the synergy between different data representations and algorithms; 2. We need a structured approach to handle the transitions between data representations; 3. We need descriptive programming constructs to express which representation fits a program fragment best. Combined, this research will result in a structured programming approach where separating data interface from data representation, not only improves understandability and maintainability, but also improves performance through automated transitions of data representation.

Research paper thumbnail of Virtual Machine Support for Many-Core Architectures: Decoupling Abstract from Concrete Concurrency Models

Electronic Proceedings in Theoretical Computer Science, Feb 4, 2010

The upcoming many-core architectures require software developers to exploit concurrency to utiliz... more The upcoming many-core architectures require software developers to exploit concurrency to utilize available computational power. Today's high-level language virtual machines (VMs), which are a cornerstone of software development, do not provide sufficient abstraction for concurrency concepts. We analyze concrete and abstract concurrency models and identify the challenges they impose for VMs. To provide sufficient concurrency support in VMs, we propose to integrate concurrency operations into VM instruction sets. Since there will always be VMs optimized for special purposes, our goal is to develop a methodology to design instruction sets with concurrency support. Therefore, we also propose a list of trade-offs that have to be investigated to advise the design of such instruction sets. As a first experiment, we implemented one instruction set extension for shared memory and one for non-shared memory concurrency. From our experimental results, we derived a list of requirements for a full-grown experimental environment for further research.

Research paper thumbnail of Synchronization views for event-loop actors

Proceedings of the 17th Acm Sigplan Symposium, Feb 25, 2012

The actor model has already proven itself as an interesting concurrency model that avoids issues ... more The actor model has already proven itself as an interesting concurrency model that avoids issues such as deadlocks and race conditions by construction, and thus facilitates concurrent programming. The tradeoff is that it sacrifices expressiveness and efficiency especially with respect to data parallelism. However, many standard solutions to computationally expensive problems employ data parallel algorithms for better performance on parallel systems.

Research paper thumbnail of A language-oriented approach to teaching concurrency

This paper argues in favour of a language-oriented approach to teach the principles of concurrenc... more This paper argues in favour of a language-oriented approach to teach the principles of concurrency to graduate students. Over the past years, the popularity of programming languages that promote a functional programming style has steadily grown. We want to promote the use of such languages as the appropriate basic tools to deal with the "multicore revolution".

Research paper thumbnail of Intermediate Language Design of High-level Language Virtual Machines

Research paper thumbnail of ezcReflection

Research paper thumbnail of Zero-overhead metaprogramming: reflection and metaobject protocols fast and without compromises

ACM SIGPLAN Notices, 2015

Runtime metaprogramming enables many useful applications and is often a convenient solution to so... more Runtime metaprogramming enables many useful applications and is often a convenient solution to solve problems in a generic way, which makes it widely used in frameworks, middleware, and domain-specific languages. However, powerful metaobject protocols are rarely supported and even common concepts such as reflective method invocation or dynamic proxies are not optimized. Solutions proposed in literature either restrict the metaprogramming capabilities or require application or library developers to apply performance improving techniques.

Research paper thumbnail of Web Service Toolkit für PHP5

Research paper thumbnail of Fork/join parallelism in the wild

Proceedings of the 2014 International Conference on Principles and Practices of Programming on the Java platform Virtual machines, Languages, and Tools - PPPJ '14, 2014

Now that multicore processors are commonplace, developing parallel software has escaped the confi... more Now that multicore processors are commonplace, developing parallel software has escaped the confines of high-performance computing and enters the mainstream. The Fork/Join framework, for instance, is part of the standard Java platform since version 7. Fork/Join is a high-level parallel programming model advocated to make parallelizing recursive divide-and-conquer algorithms particularly easy. While, in theory, Fork/Join is a simple and effective technique to expose parallelism in applications, it has not been investigated before whether and how the technique is applied in practice. We therefore performed an empirical study on a corpus of 120 open source Java projects that use the framework for roughly 362 different tasks.

Research paper thumbnail of Many-core virtual machines

Proceedings of the ACM international conference companion on Object oriented programming systems languages and applications companion - SPLASH '10, 2010

We propose to search for common abstractions for concurrency models to enable multi-language virt... more We propose to search for common abstractions for concurrency models to enable multi-language virtual machines to support a wide range of them. This would enable domain-specific solutions for concurrency problems. Furthermore, such an abstraction could improve portability of virtual machines to the vastly different upcoming many-core architectures.

Research paper thumbnail of Identifying a Unifying Mechanism for the Implementation of Concurrency Abstractions on Multi-language Virtual Machines

Lecture Notes in Computer Science, 2012

Supporting all known abstractions for concurrent and parallel programming in a virtual machines (... more Supporting all known abstractions for concurrent and parallel programming in a virtual machines (VM) is a futile undertaking, but it is required to give programmers appropriate tools and performance. Instead of supporting all abstractions directly, VMs need a unifying mechanism similar to INVOKEDYNAMIC for JVMs. Our survey of parallel and concurrent programming concepts identifies concurrency abstractions as the ones benefiting most from support in a VM. Currently, their semantics is often weakened, reducing their engineering benefits. They require a mechanism to define flexible language guarantees. Based on this survey, we define an ownership-based meta-object protocol as candidate for VM support. We demonstrate its expressiveness by implementing actor semantics, software transactional memory, agents, CSP, and active objects. While the performance of our prototype confirms the need for VM support, it also shows that the chosen mechanism is appropriate to express a wide range of concurrency abstractions in a unified way.

Research paper thumbnail of Partitioned Global Address Space Languages

ACM Computing Surveys, 2015

The Partitioned Global Address Space (PGAS) model is a parallel programming model that aims to im... more The Partitioned Global Address Space (PGAS) model is a parallel programming model that aims to improve programmer productivity while at the same time aiming for high performance. The main premise of PGAS is that a globally shared address space improves productivity, but that a distinction between local and remote data accesses is required to allow performance optimizations and to support scalability on large-scale parallel architectures. To this end, PGAS preserves the global address space while embracing awareness of non-uniform communication costs.

Research paper thumbnail of Intermediate language design of high-level language virtual machines

Proceedings of the Third Workshop on Virtual Machines and Intermediate Languages - VMIL '09, 2009

Research paper thumbnail of Cloud PARTE

Proceedings of the 2013 workshop on Programming based on actors, agents, and decentralized control - AGERE! '13, 2013

Traffic monitoring or crowd management systems produce large amounts of data in the form of event... more Traffic monitoring or crowd management systems produce large amounts of data in the form of events that need to be processed to detect relevant incidents. Rule-based pattern recognition is a promising approach for these applications, however, increasing amounts of data as well as large and complex rule sets demand for more and more processing power and memory. In order to scale such applications, a rule-based pattern detection system needs to be distributable over multiple machines. Today's approaches are however focused on static distribution of rules or do not support reasoning over the full set of events.

Research paper thumbnail of Towards Composable Concurrency Abstractions

Electronic Proceedings in Theoretical Computer Science, 2014

In the past decades, many different programming models for managing concurrency in applications h... more In the past decades, many different programming models for managing concurrency in applications have been proposed, such as the actor model, Communicating Sequential Processes, and Software Transactional Memory. The ubiquity of multi-core processors has made harnessing concurrency even more important. We observe that modern languages, such as Scala, Clojure, or F#, provide not one, but multiple concurrency models that help developers manage concurrency. Large end-user applications are rarely built using just a single concurrency model. Programmers need to manage a responsive UI, deal with file or network I/O, asynchronous workflows, and shared resources. Different concurrency models facilitate different requirements. This raises the issue of how these concurrency models interact, and whether they are composable. After all, combining different concurrency models may lead to subtle bugs or inconsistencies.

Research paper thumbnail of Web Service Toolkit für PHP5

Research paper thumbnail of Tanks: multiple reader, single writer actors

Research paper thumbnail of Insertion Tree Phasers: Efficient and Scalable Barrier Synchronization for Fine-Grained Parallelism

2010 IEEE 12th International Conference on High Performance Computing and Communications (HPCC), 2010

This paper presents an algorithm and a data structure for scalable dynamic synchronization in fin... more This paper presents an algorithm and a data structure for scalable dynamic synchronization in fine-grained parallelism. The algorithm supports the full generality of phasers with dynamic, two-phase, and point-to-point synchronization. It retains the scalability of classical tree barriers, but provides unbounded dynamicity by employing a tailor-made insertion tree data structure.

Research paper thumbnail of Towards an actor-based concurrent machine model

Proceedings of the 4th workshop on the Implementation, Compilation, Optimization of Object-Oriented Languages and Programming Systems - ICOOOLPS '09, 2009

In this position paper we propose to extend an existing delegation-based machine model with concu... more In this position paper we propose to extend an existing delegation-based machine model with concurrency primitives. The original machine model which is built on the concepts of objects, messages, and delegation, provides support for languages enabling multi-dimensional separation of concerns (MDSOC). We propose to extend this model with an actor-based concurrency model, allowing for both true parallelism as well as lightweight concurrency primitives such as coroutines. In order to demonstrate its expressiveness, we informally describe how three high-level languages supporting different concurrency models can be mapped onto our extended machine model. We also provide an outlook on the extended model's potential to support concurrencyrelated MDSOC features.

Research paper thumbnail of Domains: Sharing State in the Communicating Event-Loop Actor Model

The actor model is a message-passing concurrency model that avoids deadlocks and low-level data r... more The actor model is a message-passing concurrency model that avoids deadlocks and low-level data races by construction. This facilitates concurrent programming, especially in the context of complex interactive applications where modularity, security and fault-tolerance are required. The tradeoff is that the actor model sacrifices expressiveness and safety guarantees with respect to parallel access to shared state. In this paper we present domains as a set of novel language abstractions for safely encapsulating and sharing state within the actor model. We introduce four types of domains, namely immutable, isolated, observable and shared domains that each are tailored to a certain access pattern on that shared state. The domains are characterized with an operational semantics. For each we discuss how the actor model's safety guarantees are upheld even in the presence of conceptually shared state. Furthermore, the proposed language abstractions are evaluated with a case study in Scala comparing them to other synchonisation mechanisms to demonstrate their benefits in deadlock freedom, parallel reads, and enforced isolation.

Research paper thumbnail of Data interface + algorithms = efficient programs

Proceedings of the 9th International Workshop on Implementation, Compilation, Optimization of Object-Oriented Languages, Programs and Systems PLE - ICOOOLPS '14, 2014

ABSTRACT Finding the right algorithm--data structure combination is easy, but finding the right d... more ABSTRACT Finding the right algorithm--data structure combination is easy, but finding the right data structure for a set of algorithms is much less trivial. Moreover, using the same data representation throughout the whole program might be sub-optimal. Depending on several factors, often only known at runtime, some programs benefit from changing the data representation during execution. In this position paper we introduce the idea of Just-In-Time data structures, a combination of a data interface and a set of concrete data representations with different performance characteristics. These Just-In-Time data structures can dynamically swap their internal data representation when the cost of swapping is payed back many times in the remainder of the computation. To make Just-In-Time data structures work, research is needed at three fronts: 1. We need to better understand the synergy between different data representations and algorithms; 2. We need a structured approach to handle the transitions between data representations; 3. We need descriptive programming constructs to express which representation fits a program fragment best. Combined, this research will result in a structured programming approach where separating data interface from data representation, not only improves understandability and maintainability, but also improves performance through automated transitions of data representation.

Research paper thumbnail of Virtual Machine Support for Many-Core Architectures: Decoupling Abstract from Concrete Concurrency Models

Electronic Proceedings in Theoretical Computer Science, Feb 4, 2010

The upcoming many-core architectures require software developers to exploit concurrency to utiliz... more The upcoming many-core architectures require software developers to exploit concurrency to utilize available computational power. Today's high-level language virtual machines (VMs), which are a cornerstone of software development, do not provide sufficient abstraction for concurrency concepts. We analyze concrete and abstract concurrency models and identify the challenges they impose for VMs. To provide sufficient concurrency support in VMs, we propose to integrate concurrency operations into VM instruction sets. Since there will always be VMs optimized for special purposes, our goal is to develop a methodology to design instruction sets with concurrency support. Therefore, we also propose a list of trade-offs that have to be investigated to advise the design of such instruction sets. As a first experiment, we implemented one instruction set extension for shared memory and one for non-shared memory concurrency. From our experimental results, we derived a list of requirements for a full-grown experimental environment for further research.

Research paper thumbnail of Synchronization views for event-loop actors

Proceedings of the 17th Acm Sigplan Symposium, Feb 25, 2012

The actor model has already proven itself as an interesting concurrency model that avoids issues ... more The actor model has already proven itself as an interesting concurrency model that avoids issues such as deadlocks and race conditions by construction, and thus facilitates concurrent programming. The tradeoff is that it sacrifices expressiveness and efficiency especially with respect to data parallelism. However, many standard solutions to computationally expensive problems employ data parallel algorithms for better performance on parallel systems.

Research paper thumbnail of A language-oriented approach to teaching concurrency

This paper argues in favour of a language-oriented approach to teach the principles of concurrenc... more This paper argues in favour of a language-oriented approach to teach the principles of concurrency to graduate students. Over the past years, the popularity of programming languages that promote a functional programming style has steadily grown. We want to promote the use of such languages as the appropriate basic tools to deal with the "multicore revolution".

Research paper thumbnail of Intermediate Language Design of High-level Language Virtual Machines

Research paper thumbnail of ezcReflection

Research paper thumbnail of Zero-overhead metaprogramming: reflection and metaobject protocols fast and without compromises

ACM SIGPLAN Notices, 2015

Runtime metaprogramming enables many useful applications and is often a convenient solution to so... more Runtime metaprogramming enables many useful applications and is often a convenient solution to solve problems in a generic way, which makes it widely used in frameworks, middleware, and domain-specific languages. However, powerful metaobject protocols are rarely supported and even common concepts such as reflective method invocation or dynamic proxies are not optimized. Solutions proposed in literature either restrict the metaprogramming capabilities or require application or library developers to apply performance improving techniques.

Research paper thumbnail of Web Service Toolkit für PHP5

Research paper thumbnail of Fork/join parallelism in the wild

Proceedings of the 2014 International Conference on Principles and Practices of Programming on the Java platform Virtual machines, Languages, and Tools - PPPJ '14, 2014

Now that multicore processors are commonplace, developing parallel software has escaped the confi... more Now that multicore processors are commonplace, developing parallel software has escaped the confines of high-performance computing and enters the mainstream. The Fork/Join framework, for instance, is part of the standard Java platform since version 7. Fork/Join is a high-level parallel programming model advocated to make parallelizing recursive divide-and-conquer algorithms particularly easy. While, in theory, Fork/Join is a simple and effective technique to expose parallelism in applications, it has not been investigated before whether and how the technique is applied in practice. We therefore performed an empirical study on a corpus of 120 open source Java projects that use the framework for roughly 362 different tasks.

Research paper thumbnail of Many-core virtual machines

Proceedings of the ACM international conference companion on Object oriented programming systems languages and applications companion - SPLASH '10, 2010

We propose to search for common abstractions for concurrency models to enable multi-language virt... more We propose to search for common abstractions for concurrency models to enable multi-language virtual machines to support a wide range of them. This would enable domain-specific solutions for concurrency problems. Furthermore, such an abstraction could improve portability of virtual machines to the vastly different upcoming many-core architectures.

Research paper thumbnail of Identifying a Unifying Mechanism for the Implementation of Concurrency Abstractions on Multi-language Virtual Machines

Lecture Notes in Computer Science, 2012

Supporting all known abstractions for concurrent and parallel programming in a virtual machines (... more Supporting all known abstractions for concurrent and parallel programming in a virtual machines (VM) is a futile undertaking, but it is required to give programmers appropriate tools and performance. Instead of supporting all abstractions directly, VMs need a unifying mechanism similar to INVOKEDYNAMIC for JVMs. Our survey of parallel and concurrent programming concepts identifies concurrency abstractions as the ones benefiting most from support in a VM. Currently, their semantics is often weakened, reducing their engineering benefits. They require a mechanism to define flexible language guarantees. Based on this survey, we define an ownership-based meta-object protocol as candidate for VM support. We demonstrate its expressiveness by implementing actor semantics, software transactional memory, agents, CSP, and active objects. While the performance of our prototype confirms the need for VM support, it also shows that the chosen mechanism is appropriate to express a wide range of concurrency abstractions in a unified way.

Research paper thumbnail of Partitioned Global Address Space Languages

ACM Computing Surveys, 2015

The Partitioned Global Address Space (PGAS) model is a parallel programming model that aims to im... more The Partitioned Global Address Space (PGAS) model is a parallel programming model that aims to improve programmer productivity while at the same time aiming for high performance. The main premise of PGAS is that a globally shared address space improves productivity, but that a distinction between local and remote data accesses is required to allow performance optimizations and to support scalability on large-scale parallel architectures. To this end, PGAS preserves the global address space while embracing awareness of non-uniform communication costs.

Research paper thumbnail of Intermediate language design of high-level language virtual machines

Proceedings of the Third Workshop on Virtual Machines and Intermediate Languages - VMIL '09, 2009

Research paper thumbnail of Cloud PARTE

Proceedings of the 2013 workshop on Programming based on actors, agents, and decentralized control - AGERE! '13, 2013

Traffic monitoring or crowd management systems produce large amounts of data in the form of event... more Traffic monitoring or crowd management systems produce large amounts of data in the form of events that need to be processed to detect relevant incidents. Rule-based pattern recognition is a promising approach for these applications, however, increasing amounts of data as well as large and complex rule sets demand for more and more processing power and memory. In order to scale such applications, a rule-based pattern detection system needs to be distributable over multiple machines. Today's approaches are however focused on static distribution of rules or do not support reasoning over the full set of events.

Research paper thumbnail of Towards Composable Concurrency Abstractions

Electronic Proceedings in Theoretical Computer Science, 2014

In the past decades, many different programming models for managing concurrency in applications h... more In the past decades, many different programming models for managing concurrency in applications have been proposed, such as the actor model, Communicating Sequential Processes, and Software Transactional Memory. The ubiquity of multi-core processors has made harnessing concurrency even more important. We observe that modern languages, such as Scala, Clojure, or F#, provide not one, but multiple concurrency models that help developers manage concurrency. Large end-user applications are rarely built using just a single concurrency model. Programmers need to manage a responsive UI, deal with file or network I/O, asynchronous workflows, and shared resources. Different concurrency models facilitate different requirements. This raises the issue of how these concurrency models interact, and whether they are composable. After all, combining different concurrency models may lead to subtle bugs or inconsistencies.

Research paper thumbnail of Web Service Toolkit für PHP5

Research paper thumbnail of Tanks: multiple reader, single writer actors

Research paper thumbnail of Insertion Tree Phasers: Efficient and Scalable Barrier Synchronization for Fine-Grained Parallelism

2010 IEEE 12th International Conference on High Performance Computing and Communications (HPCC), 2010

This paper presents an algorithm and a data structure for scalable dynamic synchronization in fin... more This paper presents an algorithm and a data structure for scalable dynamic synchronization in fine-grained parallelism. The algorithm supports the full generality of phasers with dynamic, two-phase, and point-to-point synchronization. It retains the scalability of classical tree barriers, but provides unbounded dynamicity by employing a tailor-made insertion tree data structure.

Research paper thumbnail of Towards an actor-based concurrent machine model

Proceedings of the 4th workshop on the Implementation, Compilation, Optimization of Object-Oriented Languages and Programming Systems - ICOOOLPS '09, 2009

In this position paper we propose to extend an existing delegation-based machine model with concu... more In this position paper we propose to extend an existing delegation-based machine model with concurrency primitives. The original machine model which is built on the concepts of objects, messages, and delegation, provides support for languages enabling multi-dimensional separation of concerns (MDSOC). We propose to extend this model with an actor-based concurrency model, allowing for both true parallelism as well as lightweight concurrency primitives such as coroutines. In order to demonstrate its expressiveness, we informally describe how three high-level languages supporting different concurrency models can be mapped onto our extended machine model. We also provide an outlook on the extended model's potential to support concurrencyrelated MDSOC features.