A rewrite-based type discipline for a subset of computer algebra (Q1176783)

From MaRDI portal
Revision as of 06:03, 28 February 2024 by SwMATHimport240215 (talk | contribs) (‎Changed an Item)
scientific article
Language Label Description Also known as
English
A rewrite-based type discipline for a subset of computer algebra
scientific article

    Statements

    A rewrite-based type discipline for a subset of computer algebra (English)
    0 references
    25 June 1992
    0 references
    This paper is originated from computer algebra and its main features are the use of terms of an order-sorted algebra to denote polymorphic types with properties and the use of rewrite rules to define subtyping relations. The type system aims at the contradictory goals which must be solved simultaneously: static type checking and the possibility to omit typing information. A solution is to use a type inference algorithm, which allows the system to compute statically the type of every expression with no typing information provided by the user. A basic idea to handle polymorphism is to denote types by terms where a given set of functors denotes the construction of more complex types from simpler ones and where variables ranges over types. A type system into which polymorphism with properties may be expressed, and where subtyping information is given through rewrite rules is presented. This system uses an initial term algebra and a presentation (an order sorted signature and a finite set of subtype rules \(l_ i-r_ i\)). The rules contained in a presentation are used to derive types by ``rewriting''. In this system, unfortunately, the type inference problem is undecidable, but the authors show that when some not unreasonable restrictions are made it is possible to get an efficient semi-decision procedure. Many relations with other work are presented.
    0 references
    0 references
    order-sorted algebra
    0 references
    type system
    0 references
    polymorphism
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references

    Identifiers