Network


Latest external collaboration on country level. Dive into details by clicking on the dots.

Hotspot


Dive into the research topics where István Bozó is active.

Publication


Featured researches published by István Bozó.


annual erlang workshop | 2014

Discovering parallel pattern candidates in Erlang

István Bozó; Viktoria Fordós; Zoltán Horváth; Melinda Tóth; Dániel Horpácsi; Tamás Kozsik; Judit Köszegi; Adam D. Barwell; Christopher Brown; Kevin Hammond

The ParaPhrase Refactoring Tool for Erlang PaRTE provides automatic, comprehensive and reliable pattern candidate discovery to locate parallelisable components in Erlang programs. It uses semi-automatic and semantics-preserving program transformations to reshape source code and to introduce high level parallel patterns that can be mapped adaptively to the available hardware resources. This paper describes the main PaRTE tools and demonstrates that significant parallel speedups can be obtained.


CEFP'11 Proceedings of the 4th Summer School conference on Central European Functional Programming School | 2011

Static analysis of complex software systems implemented in erlang

Melinda Tóth; István Bozó

Static software analyser tools use different levels of intermediate source code representations that depend on the syntax and semantics of the language to be analysed. Most of the analyser tools use graph representation to efficiently retrieve information. Building such graphs for dynamically typed languages, such as Erlang, is not straightforward. In this paper we present static analysis methods to define the Dependency Graph representation of Erlang programs. The introduced methods cover the data-, control-, behaviour-flow and dependency analyses for sequential and parallel language constructs.


CEFP'09 Proceedings of the Third summer school conference on Central European functional programming school | 2009

Impact analysis of erlang programs using behaviour dependency graphs

Melinda Tóth; István Bozó; Zoltán Horváth; László Lövei; Máté Tejfel; Tamás Kozsik

During the lifetime of a software product certain changes could be performed on its source code. After those changes a regression test should be performed, which is the most expensive part of the software development cycle. This paper focuses on programs written in a dynamic functional programming language Erlang, and discusses a mechanism that could select those test cases, which are affected by a change, i.e. altering the program on some point may have impact on the result/behaviour of those test cases. In the result of that analysis it is possible to reduce the number of necessary test cases, and after modifying the source code, just a subset of the test cases should be retested. The discussed approach introduces a behaviour dependency graph for Erlang programs to represent the dependencies in the source code. The impact of a change can be calculated by traversing the graph.


trends in functional programming | 2014

Refactorings to Enable Parallelization

István Bozó; Viktória Fördős; Dániel Horpácsi; Zoltán Horváth; Tamás Kozsik; Judit Kőszegi; Melinda Tóth

We propose program analyses to identify parallelizable code fragments, and program transformations to change those fragments into applications of high-level parallel patterns. The methodology has been worked out, and is presented here, in the context of the Erlang programming language, but the approach is applicable in other languages as well.


NUMERICAL ANALYSIS AND APPLIED MATHEMATICS ICNAAM 2011: International Conference on Numerical Analysis and Applied Mathematics | 2011

Selecting Erlang Test Cases Using Impact Analysis

István Bozó; Melinda Tóth

Refactoring is a commonly used technology in the software development and maintenance process. However refactorings preserve the original behaviour of the system, developers want to be convinced about that, thus they retest the software after some modifications. Software testing is said to be the most expensive part of the lifecycle of software systems. Therefore our research focuses on selecting test cases affected by refactorings and have to be retested after the transformation. We describe the used mechanism in case of a dynamically typed functional programming language, Erlang.


INTERNATIONAL CONFERENCE OF NUMERICAL ANALYSIS AND APPLIED MATHEMATICS 2015 (ICNAAM 2015) | 2016

Analysing and visualising Erlang behaviours

István Bozó; Melinda Tóth

Understanding and maintaining the source code of industrial-scale software product is hard and time-consuming, and it is getting more difficult when the software implements parallel/concurrent/distributed computations and behaviours. Static source code analysis tools support program comprehension through detecting dependencies and relations among small (like functions and processes) or large (modules and components) software elements. For Erlang, which is a dynamically typed language, only an approximation of the real dependencies can be calculated statically. However it is possible to improve these analyses by adding application specific information, such as the most frequently used behaviours. In this paper we introduce an extension of the process relation analysis for Erlang which extract information of generic server behaviour implementations. The Communication Graph is extended with the result of the analysis.


annual erlang workshop | 2010

Analysis of preprocessor constructs in Erlang

Róbert Kitlei; István Bozó; Tamás Kozsik; Máté Tejfel; Melinda Tóth

Program analysis and transformation tools work on source code, which - as in the case of Erlang - may contain macros and other preprocessor directives. Such preprocessor constructs have to be treated in an utterly different way than lexical and syntactical constructs. This paper presents an approach to treat preprocessor constructs in a non-invasive way that is reasonably efficient and supports code transformations and analyses in an Erlang specific framework.


implementation and application of functional languages | 2017

Pattern Candidate Discovery and Parallelization Techniques

Melinda Tóth; István Bozó; Tamás Kozsik

Parallel computations in a program can be expressed conveniently, at a high level of abstraction, using parallel patterns such as task farm, pipeline or divide-and-conquer. In order to transform a sequential program into a pattern-based parallel one, the software developer may want to apply refactoring transformations on it. This tutorial explains a methodology to perform tool supported parallelization of programs by presenting how to use a specific static source code analysis and transformation system for Erlang. A key element of the approach is pattern candidate discovery, a static analysis technique to identify code fragments that can be refactored into a parallel pattern.


annual erlang workshop | 2017

Towards change-driven testing

Viktória Fördős; István Bozó; Melinda Tóth

Engineering complex business critical systems that should never stop or fail is very much challenging. In Klarna, we tackle this challenge day by day. The secret sauce, which enables us to ensure the highest software quality, is the thorough validation process. However, one must pay the price of such validation process, which is essentially time. In this paper we present our initial work on fast tracking the validation of code changes without compromising software quality and give a preliminary evaluation on our technique.


international conference on conceptual structures | 2014

Detecting and Visualising Process Relationships in Erlang

Melinda Tóth; István Bozó

Abstract Static software analyser tools can help in program comprehension by detecting relations among program parts. Detecting relations among the concurrent program parts, e.g. relations between processes, is not straightforward. In case of dynamic languages only a (good) approximation of the real dependencies can be calculated. In this paper we present algorithms to build a process relation graph for Erlang programs. The graph contains direct relation through message passing and hidden relations represented by the ETS (Erlang Term Storage) tables.

Collaboration


Dive into the István Bozó's collaboration.

Top Co-Authors

Avatar

Melinda Tóth

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Tamás Kozsik

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Zoltán Horváth

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

M. Toth

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Dániel Horpácsi

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Judit Kőszegi

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Máté Tejfel

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Viktória Fördős

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

A. Poor

Eötvös Loránd University

View shared research outputs
Top Co-Authors

Avatar

Judit Köszegi

Eötvös Loránd University

View shared research outputs
Researchain Logo
Decentralizing Knowledge