Abstract
AbstractA method is proposed to search for an identifier in a functional program library by using its Hindley–Milner type as a key. This can be seen as an approximation of using the specification as a key.Functions that only differ in their argument order or currying are essentially the same, which is expressed by a congruence relation on types. During a library search, congruent types are identified. If a programmer is not satisfied with the type of a found value, he can use a conversion function (like curry), which must exist between congruent types, to convert the value into the type of his choice.Types are congruent if they are isomorphic in all cartesian closed categories. To put it more simply, types are congruent if they are equal under an arithmetical interpretation, with cartesian product as multiplication and function space as exponentiation. This congruence relation is characterized by seven equational axioms. There is a simple term-rewriting algorithm to decide congruence, using which a search system has been implemented for the functional language Lazy ML, with good performance.The congruence relation can also be used as a basis for other search strategies, e.g. searching for identifiers of a more general type, modulo congruence or allowing free type variables in queries.
Publisher
Cambridge University Press (CUP)
Cited by
43 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. The exp-log normal form of types: decomposing extensional equality and representing terms compactly;ACM SIGPLAN Notices;2017-05-11
2. The exp-log normal form of types: decomposing extensional equality and representing terms compactly;Proceedings of the 44th ACM SIGPLAN Symposium on Principles of Programming Languages;2017-01
3. Axioms and decidability for type isomorphism in the presence of sums;Proceedings of the Joint Meeting of the Twenty-Third EACSL Annual Conference on Computer Science Logic (CSL) and the Twenty-Ninth Annual ACM/IEEE Symposium on Logic in Computer Science (LICS);2014-07-14
4. Isomorphisms of types in the presence of higher-order references (extended version);Logical Methods in Computer Science;2012-08-10
5. ISOMORPHISMS OF TYPES IN THE PRESENCE OF HIGHER-ORDER REFERENCES;LOG METH COMPUT SCI;2012