Nuprl Definition : rat_termco_size

rat_termco_size(p) ==
  fix((λsize,p. let lbl,x 
                in if lbl =a "Constant" then 0
                   if lbl =a "Var" then 0
                   if lbl =a "Add" then (size (fst(x))) (size (snd(x)))
                   if lbl =a "Subtract" then (size (fst(x))) (size (snd(x)))
                   if lbl =a "Multiply" then (size (fst(x))) (size (snd(x)))
                   if lbl =a "Divide" then (size (fst(x))) (size (snd(x)))
                   if lbl =a "Minus" then (size x)
                   else 0
                   fi )) 
  p



Definitions occuring in Statement :  ifthenelse: if then else fi  eq_atom: =a y pi1: fst(t) pi2: snd(t) apply: a fix: fix(F) lambda: λx.A[x] spread: spread def add: m natural_number: $n token: "$token"
Definitions occuring in definition :  fix: fix(F) lambda: λx.A[x] spread: spread def pi1: fst(t) pi2: snd(t) ifthenelse: if then else fi  eq_atom: =a y token: "$token" add: m apply: a natural_number: $n
FDL editor aliases :  rat_termco_size

Latex:
rat\_termco\_size(p)  ==
    fix((\mlambda{}size,p.  let  lbl,x  =  p 
                                in  if  lbl  =a  "Constant"  then  0
                                      if  lbl  =a  "Var"  then  0
                                      if  lbl  =a  "Add"  then  1  +  (size  (fst(x)))  +  (size  (snd(x)))
                                      if  lbl  =a  "Subtract"  then  1  +  (size  (fst(x)))  +  (size  (snd(x)))
                                      if  lbl  =a  "Multiply"  then  1  +  (size  (fst(x)))  +  (size  (snd(x)))
                                      if  lbl  =a  "Divide"  then  1  +  (size  (fst(x)))  +  (size  (snd(x)))
                                      if  lbl  =a  "Minus"  then  1  +  (size  x)
                                      else  0
                                      fi  )) 
    p



Date html generated: 2019_10_29-AM-09_24_59
Last ObjectModification: 2019_03_31-PM-05_15_44

Theory : reals


Home Index