summaryrefslogtreecommitdiff
path: root/examples/mathtext/LogicI.gf
blob: e84861550bf370956904d50812d3d43591b62ba1 (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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
incomplete concrete LogicI of Logic = SymbolsX ** open 
  LexLogic, 
  Syntax, 
  Symbolic, 
  (Lang = Lang), -- for SSubjS
  Prelude in {
lincat
  Prop = S ; 
  Atom = Cl ; 
  Ind = NP ; 
  Dom = N ; 
  Var = NP ; 
  [Prop] = [S] ; 
  [Var] = NP * Bool ;
lin
  And = mkS and_Conj ;
  Or = mkS or_Conj ;
  If A B = mkS (mkAdv if_Subj A) B ;
  Iff A B = Lang.SSubjS A iff_Subj B ;
  Not A = 
    Lang.SSubjS
      (mkS negativePol (mkCl 
        (mkVP (mkNP the_Quant case_N)))) that_Subj A ; 
  All xs A B = mkS (mkAdv for_Prep (mkNP all_Predet 
                 (mkNP all_Det (mkCN A xs.p1)))) B ;
  Exist xs A B = mkS (mkCl (indef xs.p2 
                   (mkCN (mkCN A xs.p1) (mkAP (mkAP such_A) B)))) ;
  PAtom = mkS ;
  NAtom = mkS negativePol ;
  MkVar s = symb (dollar s.s) ;
  BaseProp = mkListS ;
  ConsProp = mkListS ;
  BaseVar x = <x,False> ;
  ConsVar x xs = <mkNP and_Conj (mkListNP x xs.p1), True> ;

  PExp e = symb (mkSymb (dollar e.s)) ;
  IExp e = symb (dollar e.s) ;

lincat
  Pred1 = VP ;
  Pred2 = VPSlash ;
lin
  PredPred1 f x = mkCl x f ;
  PredPred2 f x y = mkCl x (mkVP f y) ;

oper 
  dollar : Str -> Str = \s -> "$" ++ s ++ "$" ;
}