src/FOL/ROOT.ML
author paulson
Fri, 06 Aug 1999 17:29:43 +0200
changeset 7189 55f7679dc59a
parent 6349 f7750d816c21
child 7355 4c43090659ca
permissions -rw-r--r--
the whole file is now loaded only if SVC is enabled
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1459
d12da312eff4 expanded tabs
clasohm
parents: 1356
diff changeset
     1
(*  Title:      FOL/ROOT
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1459
d12da312eff4 expanded tabs
clasohm
parents: 1356
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1993  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
Adds First-Order Logic to a database containing pure Isabelle. 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
Should be executed in the subdirectory FOL.
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
val banner = "First-Order Logic with Natural Deduction";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
writeln banner;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
print_depth 1;  
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
6260
wenzelm
parents: 5310
diff changeset
    16
use "~~/src/Provers/simplifier.ML";
wenzelm
parents: 5310
diff changeset
    17
use "~~/src/Provers/splitter.ML";
wenzelm
parents: 5310
diff changeset
    18
use "~~/src/Provers/ind.ML";
wenzelm
parents: 5310
diff changeset
    19
use "~~/src/Provers/hypsubst.ML";
wenzelm
parents: 5310
diff changeset
    20
use "~~/src/Provers/classical.ML";
wenzelm
parents: 5310
diff changeset
    21
use "~~/src/Provers/blast.ML";
wenzelm
parents: 5310
diff changeset
    22
use "~~/src/Provers/clasimp.ML";
wenzelm
parents: 5310
diff changeset
    23
use "~~/src/Provers/quantifier1.ML";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 2237
diff changeset
    25
use_thy "IFOL";
4349
50403e5a44c0 Instantiated the one-point-rule quantifier simpprocs for FOL
paulson
parents: 4223
diff changeset
    26
use "fologic.ML";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
2866
0a648ebbf6d4 Now loads blast.ML
paulson
parents: 2469
diff changeset
    28
(** Applying HypsubstFun to generate hyp_subst_tac **)
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
structure Hypsubst_Data =
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
  struct
1004
70676af0ac97 Set up for new hyp_subst_tac.
lcp
parents: 731
diff changeset
    31
  structure Simplifier = Simplifier
4466
305390f23734 Better equality handling in Blast_tac, usingd a new variant of hyp_subst_tac
paulson
parents: 4349
diff changeset
    32
    (*These destructors  Match!*)
305390f23734 Better equality handling in Blast_tac, usingd a new variant of hyp_subst_tac
paulson
parents: 4349
diff changeset
    33
  fun dest_eq (Const("op =",T)  $ t $ u) = (t, u, domain_type T)
305390f23734 Better equality handling in Blast_tac, usingd a new variant of hyp_subst_tac
paulson
parents: 4349
diff changeset
    34
  val dest_Trueprop = FOLogic.dest_Trueprop
305390f23734 Better equality handling in Blast_tac, usingd a new variant of hyp_subst_tac
paulson
parents: 4349
diff changeset
    35
  val dest_imp = FOLogic.dest_imp
1004
70676af0ac97 Set up for new hyp_subst_tac.
lcp
parents: 731
diff changeset
    36
  val eq_reflection = eq_reflection
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
  val imp_intr = impI
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
  val rev_mp = rev_mp
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
  val subst = subst
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
  val sym = sym
4223
f60e3d2c81d3 added thin_refl to hyp_subst_tac
oheimb
parents: 4222
diff changeset
    41
  val thin_refl = prove_goal IFOL.thy 
f60e3d2c81d3 added thin_refl to hyp_subst_tac
oheimb
parents: 4222
diff changeset
    42
		  "!!X. [|x=x; PROP W|] ==> PROP W" (K [atac 1]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
  end;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
structure Hypsubst = HypsubstFun(Hypsubst_Data);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
open Hypsubst;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 2237
diff changeset
    48
97
dd350da66c2c renamed int-prover.ML to intprover.ML,
clasohm
parents: 72
diff changeset
    49
use "intprover.ML";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 2237
diff changeset
    51
use_thy "FOL";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
4096
8cdf672a83e8 moved cladata.ML, simpdata.ML to ROOT.ML;
wenzelm
parents: 4024
diff changeset
    53
use "cladata.ML";
8cdf672a83e8 moved cladata.ML, simpdata.ML to ROOT.ML;
wenzelm
parents: 4024
diff changeset
    54
use "simpdata.ML";
8cdf672a83e8 moved cladata.ML, simpdata.ML to ROOT.ML;
wenzelm
parents: 4024
diff changeset
    55
1523
7513fbe502fb changed prove_goal to qed_goal
paulson
parents: 1459
diff changeset
    56
qed_goal "ex1_functional" FOL.thy
666
4d9f6d83c2bf FOL/ROOT/FOL_dup_cs: removed as obsolete
lcp
parents: 393
diff changeset
    57
    "!!a b c. [| EX! z. P(a,z);  P(a,b);  P(a,c) |] ==> b = c"
5310
3e14d6d66dab Blast_tac is faster
paulson
parents: 5219
diff changeset
    58
 (fn _ => [ (Blast_tac 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
print_depth 8;