Nuprl Definition : bm_try_remove

bm_try_remove(compare;m;x) ==
  binary_map_ind(m;<bm_E(), inr ⋅ >;key,value,cnt,left,right,recL,recR.eval compare key in
                                                      if 0 <c
                                                        then let left',v recL 
                                                             in <bm_T'(key;value;left';right), v>
                                                      if c <0
                                                        then let right',v recR 
                                                             in <bm_T'(key;value;left;right'), v>
                                                      else <bm_delete'(left;right), inl value>
                                                      fi )



Definitions occuring in Statement :  bm_delete': bm_delete'(m1;m2) bm_T': bm_T'(k;v;m1;m2) binary_map_ind: binary_map_ind(v;E;key,value,cnt,left,right,rec1,rec2.T[key;value;cnt;left;right;rec1;rec2]) bm_E: bm_E() callbyvalue: callbyvalue ifthenelse: if then else fi  lt_int: i <j it: apply: a spread: spread def pair: <a, b> inr: inr  inl: inl x natural_number: $n
FDL editor aliases :  bm_try_remove
bm\_try\_remove(compare;m;x)  ==
    binary\_map\_ind(m;<bm\_E(),  inr  \mcdot{}  >key,value,cnt,left,right,recL,recR.eval  c  =  compare  key  x  in
                                                                                                            if  0  <z  c
                                                                                                                then  let  left',v  =  recL 
                                                                                                                          in  <bm\_T'(key;value;left';right),  v>
                                                                                                            if  c  <z  0
                                                                                                                then  let  right',v  =  recR 
                                                                                                                          in  <bm\_T'(key;value;left;right'),  v>
                                                                                                            else  <bm\_delete'(left;right),  inl  value>
                                                                                                            fi  )



Date html generated: 2015_07_17-AM-08_20_00
Last ObjectModification: 2013_01_04-PM-00_02_51

Home Index