Prev


finite maps are sets of rows and hence have a partial order


m <= n := m.x ~ n.x


finite map (as data) lookup is the same as finite map (as fun) application


m x := m.x NB. (m`) == (m.)


{Nuts} <= (m && n) <= m <= (m || n) <= {Null}	

application is not only continuous, but determined by atoms; in particular this implies that keys should be elements (and that the elemental maps are the functions)

(m|n) x == m x | n x
m (x|y) == m x | m y
x ~ y ==> m x ~ m y		NB. fun by def
m ~ n ==> m x ~ n x

(m&n) x == m x & n x
m (x&y) ~ m x & m y

use (%*) to give sequences of keys a map action, chaining lookup

m %* (k, l) := (m %* k) %* l

m %* k := m.k

m %* Nil := m


(&&) and (||) behave as one would expect


m && m == m
m && n == n && m
m && (n && o) == (m && n) && o
{Null} && m == m
m && {Nuts} == {Nuts}

m || m == m
m || n == n || m
m || (n || o) == (m || n) || o
{Nuts} || m == m
m || {Null} == {Null}

(!!) is like (&&), but also operates on bare rows, packing them as singletons.


m !! k:v := m && {k:v}


{d} !! {k:v | j:w} <=> {d} !! (k:v) !! (j:w) 		NB. Action
{Nuts} !! {d} <=> {d}
{d} !! {Null} <=> {Null}

(::) combines symmetrically, with priority by specificity


a::a <=> a
a::b <=> b::a
a::(b::c) <=> (a::b)::c
{Null}::a <=> a
NB. no zero

{k: v} :: {k: w | j: u} <=> {k: v | j: u} <=> {k: w | j: u} :: {k: v}
{k: v} :: {Nuts} <=> {k: v}	NB. ({k: v} :: {Null}) == bare {k:v}

(//) combines asymmetrically, with priority to the left


{k: v} // {k: w | j: u} <=> {k: v | j: u}
{k: w | j: u} // {k: v} <=> {k: w | j: u}

a//a <=> a
a//{Null} == bare a	    NB. a//Nuts == Nuts
{Null}//a == {Null}
{Nuts}//a == a
a//{Nuts} == a
a//(b//c) == (a//b)//c

these operations are also available at (*) == (&&), (%) == (||), and (/) == (//)


OPEN: at least (//) needs to distribute over sequencing (for (<-) to behave properly in def'ns); are there reasons for or against the other synthetic ops doing so?


Yet another (commutative) action with map intersection

m && {k: v | j: w} == (m && {k: v}) && {j: w}

example

xor: {(True,True): False | (False,False): False 
     |(True,False): True | (False,True): True}

Next



/junk/