summaryrefslogtreecommitdiff
path: root/gf-book/examples/chapter6/Aggregation.gf
blob: 28cbd39efa9814af7eaa80d5aa0382cda0554dae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
abstract Aggregation = {
  cat S ; NP ; VP ;
  data 
    PredVP : NP -> VP -> S ;
    ConjS  : S -> S -> S ;
    ConjVP : VP -> VP -> VP ;
    ConjNP : NP -> NP -> NP ;
    Run, Walk : VP ;
    John, Mary : NP ;

  fun aggr : S -> S ; -- main aggregation function
  def aggr (ConjS (PredVP x X) (PredVP y Y)) = 
    ifS (eqNP x y) 
      (PredVP x (ConjVP X Y)) 
      (ifS (eqVP X Y) 
         (PredVP (ConjNP x y) X)
         (ConjS (PredVP x X) (PredVP y Y))) ;
  fun ifS : Bool -> S -> S -> S ; -- if b then x else y 
  def
    ifS True  x _ = x ;
    ifS False _ y = y ;
  fun eqNP : NP -> NP -> Bool ;  -- x == y
  def 
    eqNP John John = True ;
    eqNP Mary Mary = True ;
    eqNP _ _ = False ;
  fun eqVP : VP -> VP -> Bool ;  -- X == Y
  def 
    eqVP Run  Run  = True ;
    eqVP Walk Walk = True ;
    eqVP _ _ = False ;
  cat Bool ; data True, False : Bool ;
}