A trajectory-based strict semantics for program slicing

Richard W. Barraclough, David Binkley, Sebastian Danicic, Mark Harman, Robert M. Hierons, Akos Kiss, Mike Laurence, Lahcen Ouarbya

Research output: Contribution to journalArticlepeer-review

20 Citations (Scopus)

Abstract

We define a program semantics that is preserved by dependence-based slicing algorithms. It is a natural extension, to non-terminating programs, of the semantics introduced by Weiser (which only considered terminating ones) and, as such, is an accurate characterisation of the semantic relationship between a program and the slice produced by these algorithms. Unlike other approaches, apart from Weiser's original one, it is based on strict standard semantics which models the 'normal' execution of programs on a von Neumann machine and, thus, has the advantage of being intuitive. This is essential since one of the main applications of slicing is program comprehension. Although our semantics handles nontermination, it is defined wholly in terms of finite trajectories, without having to resort to complex, counter-intuitive, non-standard models of computation. As well as being simpler, unlike other approaches to this problem, Our semantics is substitutive. Substitutivity is an important property because it greatly enhances the ability to reason about correctness of meaning-preserving program transformations such as slicing. (C) 2009 Elsevier B.V. All rights reserved.
Original languageEnglish
Pages (from-to)1372 - 1386
Number of pages15
JournalTheoretical Computer Science
Volume411
Issue number11-13
DOIs
Publication statusPublished - 6 Mar 2010

Fingerprint

Dive into the research topics of 'A trajectory-based strict semantics for program slicing'. Together they form a unique fingerprint.

Cite this