State Isomorphism in Model Programs with Abstract Data Structures

Margus Veanes, Juhan Ernits, and Colin Campbell

Abstract

Modeling software features with model programs in C# is a way of formalizing software requirements that lends itself to automated analysis such as model-based testing. Unordered structures like sets and maps provide a useful abstract view of system state within a model program and greatly reduce the number of states that must be considered during analysis. Similarly, a technique called linearization reduces the number of states that must be considered by identifying isomorphic states, or states that are identical except for reserve element choice (such as the choice of object IDs for instances of classes). Unfortunately, linearization does not work on unordered structures such as sets. The problem turns into graph isomorphism, which is known to have no polynomial time solution. In this paper we discuss the issue of state isomorphism in the presence of unordered structures and give a practical approach that overcomes some of the algorithmic limitations.

Details

Publication typeInproceedings
Published inFORTE'07
Pages112-127
Volume4574
SeriesLNCS
PublisherSpringer Verlag
> Publications > State Isomorphism in Model Programs with Abstract Data Structures