skip to main content
10.1145/96709.96748acmconferencesArticle/Chapter ViewAbstractPublication PagespoplConference Proceedingsconference-collections
Article
Free access

Deciding ML typability is complete for deterministic exponential time

Published: 01 December 1989 Publication History

Abstract

A well known but incorrect piece of functional programming folklore is that ML expressions can be efficiently typed in polynomial time. In probing the truth of that folklore, various researchers, including Wand, Buneman, Kanellakis, and Mitchell, constructed simple counterexamples consisting of typable ML programs having length n, with principal types having Ω(2cn) distinct type variables and length Ω(22cn). When the types associated with these ML constructions were represented as directed acyclic graphs, their sizes grew as Ω(2cn). The folklore was even more strongly contradicted by the recent result of Kanellakis and Mitchell that simply deciding whether or not an ML expression is typable is PSPACE-hard.
We improve the latter result, showing that deciding ML typability is DEXPTIME-hard. As Kanellakis and Mitchell have shown containment in DEXPTIME, the problem is DEXPTIME-complete. The proof of DEXPTIME-hardness is carried out via a generic reduction: it consists of a very straightforward simulation of any deterministic one-tape Turing machine M with input χ running in Ο(c|χ|) time by a polynomial-sized ML formula ΦM,χ, such that M accepts χ iff ΦM,χ is typable. The simulation of the transition function δ of the Turing Machine is realized uniquely through terms in the lambda calculus without the use of the polymorphic let construct. We use let for two purposes only: to generate an exponential amount of blank tape for the Turing Machine simulation to begin, and to compose an exponential number of applications of the ML formula simulating state transition.
It is purely the expressive power of ML polymorphism to succinctly express function composition which results in a proof of DEXPTIME-hardness. We conjecture that lower bounds on deciding typability for extensions to the typed lambda calculus can be regarded precisely in terms of this expressive capacity for succinct function composition.
To further understand this lower bound, we relate it to the problem of proving equality of type variables in a system of type equations generated from an ML expression with let-polymorphism. We show that given an oracle for solving this problem, deciding typability would be in PSPACE, as would be the actual computation of the principal type of the expression, were it indeed typable.

References

[1]
Harold Abelson and Gerald Sussman, Structure and Interpretation of Computer Programs. MIT Press, 1985.
[2]
Alfred V. Aho, John E. Hopcroft, and Jeffrey D. Ullman. The Design and Analysis of Computer Algorithms. Addison-Wesley, 1974.
[3]
Cynthia Dwork, Paris Kanellakis, and John Mitchell, On the Sequential Nature of Unification. J. Logic Programming 1(1):35-50.
[4]
Jean-Yves Girard, Yves Lafont, and Paul Taylor, Proofs and Types. Cambridge University Press, 1989.
[5]
Robert Harper, David MacQueen, and Robin Milner, Standard ML. Research Report ECS- LFCS-86-2, Computer Science Department, University of Edinburgh, March 1986.
[6]
John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages, and Computation. Addison-Wesley, 1979.
[7]
Harry B. Hunt, The equivalence problem for regular expressions with intersection is not polynomial in tape. TR 73-156, Computer Science Department, Cornell University, 1973.
[8]
Paris Kanellakis, personal communication.
[9]
Paris Kanellakis and John Mitchell, Polymorphic unification and ML typing:, POPL 1989.
[10]
Dennis Kfoury, personal communication.
[11]
Dennis Kfoury, Jerzy Tiuryn, and Pavel Urzyczyn, An anMysis of ML typability. Preprint.
[12]
Dennis Kfoury, Jerzy Tiuryn, and Pavel Urzyczyn, Undecidability of the semi-unification problem. Preprint.
[13]
Robin Milner, A theory of type polymorphism in programming, JCSS 17 (1978), pp. 348- 375.
[14]
Walter Savitch, Relationship between nondeterministic and deterministic tape complexities, JCSS 4:2 (1970), pp. 177-192.
[15]
Frank Pfenning, Partial polymorphic type inference and higher-order unification. 1988 Confercnce on Lisp and Functional Programming.
[16]
Mitch Wand, A simple algorithm and proof for type inference. Fundamenta Informaticae 10 (1987).

Cited By

View all

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Conferences
POPL '90: Proceedings of the 17th ACM SIGPLAN-SIGACT symposium on Principles of programming languages
December 1989
401 pages
ISBN:0897913434
DOI:10.1145/96709
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 01 December 1989

Permissions

Request permissions for this article.

Check for updates

Qualifiers

  • Article

Acceptance Rates

Overall Acceptance Rate 824 of 4,130 submissions, 20%

Upcoming Conference

POPL '25

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)189
  • Downloads (Last 6 weeks)21
Reflects downloads up to 01 Jan 2025

Other Metrics

Citations

Cited By

View all

View Options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Login options

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media