Published online by Cambridge University Press: 12 March 2014
This note presents a practical algorithm for carrying out abstraction on combinatory terms. The well-known abstraction algorithms [1, pp. 188ff.] defining abstracts in terms of the combinator sets { S, K }, { B, C, K, W }, etc. operate on one variable at a time, and result in rather long abstracts when several variables are involved. These algorithms are not practical for the applications of the combinatory logic to the theory of computing which make much use of multi-variable abstraction (e.g., [2], [3]). The present algorithm performs the abstraction with respect to all specified variables in a single step, and yields abstracts in a concise form (with sizes proportional to those of given combinatory terms).
The material in this paper is derived from the author's Ph.D. dissertation [3], written under the supervision of Professor George W. Petznick. The author is also thankful to Professor Haskell B. Curry for several suggestions, including the present definition of (in formulae (3)). The preparation of this paper was supported by NSF grant GJ 25393.