Towards Absolutely Efficient Gradually Typed Languages
Siek and Taha (2006) introduce gradual typing as a theory for integrating static and dynamic typing in programming languages. Siek et al. (2015) expand on the goals of gradual typing. The goals are:
- support both fully static and fully dynamic typing,
- enable gradual migration between static and dynamic regions,
- provide sound interoperability between such regions, and
- static regions of code are as efficient as they would be in a statically typed language.
In addition to these goals, we add that dynamic regions should perform within a constant factor of the time in dynamically typed languages.
However, there is a tension between enabling interoperability between static and dynamic regions and achieving efficiency, especially in static regions of code. The purpose of our present work is to study the essential efficiency of gradual typing by constructing a prototype compiler in which we can implement approaches to minimizing overheads and carefully evaluate their impact on efficiency through empirical studies. Towards this goal, we give a status report on Schml, a compiler that translates the Gradually Typed Lambda Calculus to C.
|Towards Absolutely Efficient Gradually Typed Languages (abstract.pdf)||93KiB|
Mon 6 JulDisplayed time zone: Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna change
16:10 - 17:10
|Position Paper: Performance Evaluation for Gradual Typing|
A: Asumu Takikawa Northeastern University, A: Daniel Feltey Northeastern University, A: Ben Greenman Northeastern University, A: Max New , A: Jan Vitek Northeastern University, A: Matthias Felleisen Northeastern UniversityMedia Attached
|Towards Absolutely Efficient Gradually Typed Languages|
A: Andre Kuhlenschmidt Indiana University, A: Deyaaeldeen Almahallawi Indiana University, A: Jeremy G. Siek Indiana UniversityFile Attached
|Towards a Static Type Checker for Python|
A: Francisco Ortin University of Oviedo, A: Baltasar García Perez-Schofield , A: José Manuel Redondo López University of OviedoFile Attached