summaryrefslogtreecommitdiff
path: root/grammars/logic/Logic.gf
blob: dbd0566f22ffa29ede0ef8522bf1ea9af957278e (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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
-- many-sorted predicate calculus
-- AR 1999, revised 2001

abstract Logic = {

flags startcat=Prop ; -- this is what you want to parse

cat 
  Prop ;       -- proposition
  Dom ;        -- domain of quantification
  Elem Dom ;   -- individual element of a domain
  Proof Prop ; -- proof of a proposition
  Text ;       -- theorem with proof etc. 

fun 
  -- texts
  Statement : Prop -> Text ;
  ThmWithProof : (A : Prop) -> Proof A -> Text ;
  ThmWithTrivialProof : (A : Prop) -> Proof A -> Text ;

  -- logically complex propositions
  Disj : (A,B : Prop) -> Prop ;
  Conj : (A,B : Prop) -> Prop ;
  Impl : (A,B : Prop) -> Prop ;
  Abs  : Prop ;
  Neg  : Prop -> Prop ;

  Univ  : (A : Dom) -> (Elem A -> Prop) -> Prop ;
  Exist : (A : Dom) -> (Elem A -> Prop) -> Prop ;
 
  -- progressive implication à la type theory
  ImplP : (A : Prop) -> (Proof A -> Prop) -> Prop ;

  -- inference rules
data  
  ConjI  : (A,B : Prop) -> Proof A -> Proof B -> Proof (Conj A B) ;
fun  
  ConjEl : (A,B : Prop) -> Proof (Conj A B) -> Proof A ;
  ConjEr : (A,B : Prop) -> Proof (Conj A B) -> Proof B ;
data  
  DisjIl : (A,B : Prop) -> Proof A -> Proof (Disj A B) ;
  DisjIr : (A,B : Prop) -> Proof B -> Proof (Disj A B) ;
fun  
  DisjE  : (A,B,C : Prop) -> Proof (Disj A B) -> 
              (Proof A -> Proof C) -> (Proof B -> Proof C) -> Proof C ;
data
  ImplI  : (A,B : Prop) -> (Proof A -> Proof B) -> Proof (Impl A B) ;
fun
  ImplE  : (A,B : Prop) -> Proof (Impl A B) -> Proof A -> Proof B ;
data
  NegI   : (A : Prop) -> (Proof A -> Proof Abs) -> Proof (Neg A) ;
fun
  NegE   : (A : Prop) -> Proof (Neg A) -> Proof A -> Proof Abs ;
  AbsE   : (C : Prop) -> Proof Abs -> Proof C ;
data
  UnivI  : (A : Dom) -> (B : Elem A -> Prop) -> 
              ((x : Elem A) -> Proof (B x)) -> Proof (Univ A B) ;
fun
  UnivE  : (A : Dom) -> (B : Elem A -> Prop) -> 
              Proof (Univ A B) -> (a : Elem A) -> Proof (B a) ;
data
  ExistI : (A : Dom) -> (B : Elem A -> Prop) -> 
              (a : Elem A) -> Proof (B a) -> Proof (Exist A B) ;
fun
  ExistE : (A : Dom) -> (B : Elem A -> Prop) -> (C : Prop) -> 
              Proof (Exist A B) -> ((x : Elem A) -> Proof (B x) -> Proof C) -> 
              Proof C ;

  -- use a hypothesis
  Hypo : (A : Prop) -> Proof A -> Proof A ;

  -- pronoun
  Pron : (A : Dom) -> Elem A -> Elem A ;

def 
  -- proof normalization; does not tc 13/9/2005

  ConjEl _ _ (ConjI _ _ a _) = a ;
  ConjEr _ _ (ConjI _ _ _ b) = b ;
  DisjE _ _ _ (DisjIl _ _ a) d _ = d a ;
  DisjE _ _ _ (DisjIr _ _ b) _ e = e b ;
  ImplE _ _ (ImplI _ _ b) a = b a ;
  NegE _ (NegI _ b) a = b a ;
  UnivE _ _ (UnivI _ _ b) a = b a ;
  ExistE A B _ (ExistI A B a b) d = d a b ;
 
---  ExistE _ _ _ (ExistI _ _  a b) d = d a b ; 
--- does not tc 13/9/2005: {a{-2-}<>a{-0-}}
--- moreover: no problem with
--- ConjEr _ _ (ConjI _ _ a _) = a ;
--- But this changes when A B are used instead of _ _

  -- Hypo and Pron are identities
  Hypo _ a = a ;
  Pron _ a = a ;

} ;