Refining types of numerical data with units of measurement has the potential to increase safety of programming languages but is restricted to homogeneous units when checked statically with parametric polymorphism. We lift units to vectors and show how type inference of linear algebra expressions can statically determine safety for data with heterogeneous units. The typing is based on the dyadic product of units that is found in linear transformations and the corresponding vector spaces. Since it is a refinement of Kennedy’s types for units we automatically obtain a unification algorithm, which gives principal types for linear algebra. The extension of unit-unification to numerical data with heterogeneous units makes the safety of statically checked numerical expressions available to a significantly larger set of use-cases.
Additional Metadata
THEME Software (theme 1)
Publisher CWI
Series Software analysis and transformation [SwAT]
Citation
Griffioen, P.R. (2013). Type inference for linear algebra with units of measurement. Software analysis and transformation [SwAT]. CWI.