Misplaced Pages

Row polymorphism

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Kind of polymorphism
This article provides insufficient context for those unfamiliar with the subject. Please help improve the article by providing more context for the reader. (October 2018) (Learn how and when to remove this message)

In programming language type theory, row polymorphism is a kind of polymorphism that allows one to write programs that are polymorphic on row types such as record types and polymorphic variants. A row-polymorphic type system and proof of type inference was introduced by Mitchell Wand.

Row-polymorphic record type definition

The row-polymorphic record type defines a list of fields with their corresponding types, a list of missing fields, and a variable indicating the absence or presence of arbitrary additional fields. Both lists are optional, and the variable may be constrained. Specifically, the variable may be "empty", indicating that no additional fields may be present for the record.

It may be written as { 1 : T 1 , , n : T n , absent ( f 1 ) , , absent ( f m ) , ρ } {\displaystyle \{\ell _{1}:T_{1},\dots ,\ell _{n}:T_{n},{\text{absent}}(f_{1}),\dots ,{\text{absent}}(f_{m}),\rho \}} . This indicates a record type that has fields i {\displaystyle \ell _{i}} with respective types of T i {\displaystyle T_{i}} (for i = 1 n {\displaystyle i=1\dots n} ), and does not have any of the fields f j {\displaystyle f_{j}} (for j = 1 m {\displaystyle j=1\dots m} ), while ρ {\displaystyle \rho } expresses the fact the record may contain other fields than i {\displaystyle \ell _{i}} .

Row-polymorphic record types allow us to write programs that operate only on a section of a record. For example, one may define a function that performs some two-dimensional transformation that accepts a record with two or more coordinates, and returns an identical type:

   
  
    
      
        
          transform2d
        
        :
        {
        x
        :
        
          Number
        
        ,
        y
        :
        
          Number
        
        ,
        ρ

        }
        
        {
        x
        :
        
          Number
        
        ,
        y
        :
        
          Number
        
        ,
        ρ

        }
      
    
    {\displaystyle {\text{transform2d}}:\{x:{\text{Number}},y:{\text{Number}},\rho \}\to \{x:{\text{Number}},y:{\text{Number}},\rho \}}
  

Thanks to row polymorphism, the function may perform two-dimensional transformation on a three-dimensional (in fact, n-dimensional) point, leaving the z coordinate (or any other coordinates) intact. In a more general sense, the function can perform on any record that contains the fields x {\displaystyle x} and y {\displaystyle y} with type Number {\displaystyle {\text{Number}}} . There is no loss of information: the type ensures that all the fields represented by the variable ρ {\displaystyle \rho } are present in the return type. In contrast, the type definition { x : Number , y : Number , e m p t y } {\displaystyle \{x:{\text{Number}},y:{\text{Number}},\mathbf {empty} \}} expresses the fact that a record of that type has exactly the x {\displaystyle x} and y {\displaystyle y} fields and nothing else. In this case, a classic record type is obtained.

Typing operations on records

The record operations of selecting a field r . {\displaystyle r.\ell } , adding a field r [ := e ] {\displaystyle r} , and removing a field r {\displaystyle r\backslash \ell } can be given row-polymorphic types.

s e l e c t = λ r . ( r . ) : { : T , ρ } T {\displaystyle \mathrm {select_{\ell }} =\lambda r.(r.\ell )\;:\;\{\ell :T,\rho \}\rightarrow T}

a d d = λ r . λ e . r [ := e ] : { a b s e n t ( ) , ρ } T { : T , ρ } {\displaystyle \mathrm {add_{\ell }} =\lambda r.\lambda e.r\;:\;\{\mathrm {absent} (\ell ),\rho \}\rightarrow T\rightarrow \{\ell :T,\rho \}}

r e m o v e = λ r . r : { : T , ρ } { a b s e n t ( ) , ρ } {\displaystyle \mathrm {remove_{\ell }} =\lambda r.r\backslash \ell \;:\;\{\ell :T,\rho \}\rightarrow \{\mathrm {absent} (\ell ),\rho \}}

Notes

  1. "OCaml - Polymorphic variants". v2.ocaml.org. Retrieved 2022-12-03.
  2. Wand, Mitchell (June 1989). "Type inference for record concatenation and multiple inheritance". Proceedings. Fourth Annual Symposium on Logic in Computer Science. pp. 92–97. doi:10.1109/LICS.1989.39162.
  3. Wand, Mitchell (1991). "Type inference for record concatenation and multiple inheritance". Information and Computation. 93 (Selections from 1989 IEEE Symposium on Logic in Computer Science): 1–15. doi:10.1016/0890-5401(91)90050-C. ISSN 0890-5401.
Category:
Row polymorphism Add topic