English

Making Bubbling Practical

Programming Languages 2018-08-27 v1

Abstract

Bubbling is a run-time graph transformation studied for the execution of non-deterministic steps in functional logic computations. This transformation has been proven correct, but as currently formulated it requires information about the entire context of a step, even when the step affects only a handful of nodes. Therefore, despite some advantages, it does not appear to be competitive with approaches that require only localized information, such as backtracking and pull-tabbing. We propose a novel algorithm that executes bubbling steps accessing only local information. To this aim, we define graphs that have an additional attribute, a dominator of each node, and we maintain this attribute when a rewrite and/or bubbling step is executed. When a bubbling step is executed, the dominator is available at no cost, and only local information is accessed. Our work makes bubbling practical, and theoretically competitive, for implementing non-determinism in functional logic computations.

Keywords

Cite

@article{arxiv.1808.07990,
  title  = {Making Bubbling Practical},
  author = {Sergio Antoy and Steven Libby},
  journal= {arXiv preprint arXiv:1808.07990},
  year   = {2018}
}

Comments

14 pages, Accepted for presentation in WFLP 2018